BIGQUERY Golang客户获取项目列表

问题描述 投票:0回答:1

如何使用我提供的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))

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

go google-bigquery
1个回答
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 - 这只是我们沙箱去的方式

© www.soinside.com 2019 - 2024. All rights reserved.