Bigquery Golang客户端获取项目列表

时间:2018-03-14 01:08:35

标签: go google-bigquery

如何使用我提供的serviceaccount密钥获取golang云客户端有权访问的项目列表? 似乎有可用的API:https://cloud.google.com/bigquery/docs/reference/rest/v2/projects/list

但是,Google Cloud客户端库不会公开它。

我的代码看起来像这样

client, err := bigquery.NewClient(ctx, conn.ProjectID, option.WithServiceAccountFile(fname))

我想枚举此客户端可以访问的项目列表。

1 个答案:

答案 0 :(得分:3)

以下示例可以为您提供一个想法 - 它是沙箱,是我们BQ UI的一部分

enter image description here

func mainReturn() interface{} {
    bigqueryService, err := getBigqueryService() ; if(err != nil) {return "ERROR"}
    err2 := getProjects(bigqueryService)         ; if(err2 != nil) {return "ERROR"}
    return "OK"
}

func getProjects(bigqueryService *bigquery.Service)(error) {
    var buf bytes.Buffer
    var pagetoken string = ""
    ind := 0
    for {
        call := bigqueryService.Projects.List()
        if len(pagetoken) > 0 {call = call.PageToken(pagetoken)}

        list, err := call.Do() ; if err != nil {return err}

        if len(pagetoken) == 0 {
            xFprintf(&buf, "TotalItems: %v\n", list.TotalItems)
        }

        for _, project := range list.Projects {
            xFprintf(&buf, "========= Projects %v ==============\n", ind)
            xFprintf(&buf, "Id: %v\n", project.Id)
            xFprintf(&buf, "Kind: %v\n", project.Kind)
            project := project.Id
            del := strings.LastIndex(project, ".")
            if del != -1 {project = project[del+1:]}
            ind++;
        }

        pagetoken = list.NextPageToken ; if len(pagetoken) == 0 {break}
    }

    xPrintln(buf.String())
    return nil
}

请忽略一些有趣的外观功能,比如xFprintf - 这只是我们沙箱去的方式