登录
首页 >  Golang >  Go问答

优化多个谷歌 API 日历的 freeBusy 查询

来源:stackoverflow

时间:2024-02-17 20:57:25 416浏览 收藏

从现在开始,努力学习吧!本文《优化多个谷歌 API 日历的 freeBusy 查询》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!

问题内容

我正在开发一个 go rest api 项目,在该项目中我收到了不同时间间隔的 post 请求。这反映了商店的营业时间,以下是一个示例:

{
    ...
    "intervals": [
        {
            "day": "1600347600",
            "starthours": "800",
            "endhours": "1200"
        },
        {
            "day": "1600434000",
            "starthours": "1300",
            "endhours": "1700"
        },
        {
            "day": "1600520400",
            "starthours": "800",
            "endhours": "1200"
        },
        ...
    ]
}

我向 google 发出请求的代码如下:

// Some code to get the token
    
    //We treat every interval obj sent on the params
    if len(sc.Intervals) > 0 {
        for _, i := range sc.Intervals {
            //This is a necessary step as the format of the dates that the client gives me
            //are 
            dStart, dEnd, err := getDateStartAndEnd(i)
            if err != nil {
                log.Error(err)
                return responseInterval, err
            }
            //0. build search criteria
            var query = events.SearchCriteria{
                Email:          sc.Owner.Email,
                FreeBussyQuery: calendar.FreeBusyRequest{
                    TimeMin: dStart.Format(time.RFC3339),
                    TimeMax: dEnd.Format(time.RFC3339),
                },
            }
            isFree, err := calendarService.Freebusy.Query(setCalendarId(query)).Do()
            if err != nil {
                log.Error(err)
            }
            //In this function I do two things, get all the "slots" of 15m availables
            //in an given interval, then compare them to the bussy answer of Google
            //to fill a new slice with free "slots"
            freeIntervales := findFreeIntervales(isFree,dStart,dEnd)
            responseInterval.Interval = append(responseInterval.Interval,freeIntervales)
        }
    }

虽然我承认这可能不是最有效的算法,但我的主要问题是,假设有 8 个间隔,我的请求需要 5 秒才能执行。

是否有更好的方法来查询 google 日历? 或者我应该在这里重新设计我的逻辑?我想过只进行一个具有多个时间间隔的查询来检查 google 日历,但这似乎是不可能的。

一个可能的解决方案是我采取最早和最晚的时间并提出独特的请求。这是一个可行的解决方案吗?


解决方案


最后,我意识到,当我只打一个电话就可以逃脱惩罚时,为什么还要打五个电话呢?这大大加快了速度。之前,需要 5 - 6 秒,现在需要 900 毫秒 - 1400 毫秒。

我只是获取第一个间隔的第一个日期和最后一个间隔的最后一个日期,然后要求 google 为我提供该范围内的所有繁忙详细信息。

if len(sc.Intervals) > 0 {

    dStartResult, _, err:= getDateStartAndEnd(sc.Intervals[0])
    if err != nil {
        log.Error(err)
    }
    _, dEndResultLast, err:= getDateStartAndEnd(sc.Intervals[len(sc.Intervals)-1])
    if err != nil {
        log.Error(err)
    }

    //0. build search criteria
    var query = events.SearchCriteria{
        Email:          sc.Owner.Email,
        FreeBussyQuery: calendar.FreeBusyRequest{
            TimeMin: dStartResult.Format(time.RFC3339),
            TimeMax: dEndResultLast.Format(time.RFC3339),
        },
    }
    isFree, err := calendarService.Freebusy.Query(setCalendarId(query)).Do()
    if err != nil {
        log.Error(err)
    }

    for _, i := range sc.Intervals {
        ....
        //Do some magic to get the free intervals

今天关于《优化多个谷歌 API 日历的 freeBusy 查询》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>