Analytics Hub クライアント ライブラリ

このページでは、Analytics Hub API の Cloud クライアント ライブラリの使用を開始する方法を説明します。クライアント ライブラリを使用すると、サポートされている言語で Google Cloud APIs に簡単にアクセスできます。サーバーにリクエストを送信して Google Cloud APIs を直接利用することもできますが、クライアント ライブラリを使用すると、記述するコードの量を大幅に削減できます。

Cloud クライアント ライブラリと以前の Google API クライアント ライブラリの詳細については、クライアント ライブラリの説明をご覧ください。

クライアント ライブラリをインストールする

Install-Package Google.Cloud.BigQuery.AnalyticsHub.V1 -Pre

詳細については、C# 開発環境の設定をご覧ください。

go get cloud.google.com/go/bigquery

詳細については、Go 開発環境の設定をご覧ください。

詳細については、Java 開発環境の設定をご覧ください。

npm install @google-cloud/bigquery-data-exchange

詳細については、Node.js 開発環境の設定をご覧ください。

composer require google/cloud-bigquery-analyticshub

詳細については、Google Cloud での PHP の使用をご覧ください。

pip install --upgrade google-cloud-bigquery-analyticshub

詳細については、Python 開発環境の設定をご覧ください。

gem install google-cloud-bigquery-analytics_hub-v1

詳細については、Ruby 開発環境の設定をご覧ください。

認証を設定する

Google Cloud APIs の呼び出しを認証するために、クライアント ライブラリではアプリケーションのデフォルト認証情報(ADC)がサポートされています。このライブラリは、一連の定義済みのロケーションの中から認証情報を探し、その認証情報を使用して API へのリクエストを認証します。ADC を使用すると、アプリケーション コードを変更することなく、ローカルでの開発や本番環境など、さまざまな環境のアプリケーションで認証情報を使用できるようになります。

本番環境では、ADC の設定方法はサービスとコンテキストによって異なります。詳細については、アプリケーションのデフォルト認証情報を設定するをご覧ください。

ローカル開発環境では、Google アカウントに関連付けられている認証情報を使用して ADC を設定できます。

  1. gcloud CLI をインストールして初期化します

    gcloud CLI を初期化するときは、アプリケーションに必要なリソースにアクセスする権限がある Google Cloud プロジェクトを指定してください。

  2. 認証情報ファイルを作成します。

    gcloud auth application-default login

    ログイン画面が表示されます。ログインすると、ADC で使用されるローカル認証情報ファイルに認証情報が保存されます。

クライアント ライブラリの使用

次の例は、Analytics Hub の基本的な操作を示しています。

GoNode.js
// Copyright 2022 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.


// The analyticshub quickstart application demonstrates usage of the
// Analytics hub API by creating an example data exchange and listing.
package main

import (
       
"context"
       
"flag"
       
"fmt"
       
"log"

        dataexchange
"cloud.google.com/go/bigquery/dataexchange/apiv1beta1"
        dataexchangepb
"google.golang.org/genproto/googleapis/cloud/bigquery/dataexchange/v1beta1"
       
"google.golang.org/grpc/codes"
       
"google.golang.org/grpc/status"
)

func main
() {

       
// Define the command line flags for controlling the behavior of this quickstart.
       
var (
                projectID            
= flag.String("project_id", "", "Cloud Project ID, used for session creation.")
                location            
= flag.String("location", "US", "BigQuery location used for interactions.")
                exchangeID          
= flag.String("exchange_id", "ExampleDataExchange", "identifier of the example data exchange")
                listingID            
= flag.String("listing_id", "ExampleDataExchange", "identifier of the example data exchange")
                exampleDatasetSource
= flag.String("dataset_source", "", "dataset source in the form projects/myproject/datasets/mydataset")
               
delete               = flag.Bool("delete_exchange", true, "delete exchange at the end of quickstart")
       
)
        flag
.Parse()
       
// Perform simple validation of the specified flags.
       
if *projectID == "" {
                log
.Fatal("empty --project_id specified, please provide a valid project ID")
       
}
       
if *exampleDatasetSource == "" {
                log
.Fatalf("empty --dataset_source specified, please provide in the form \"projects/myproject/datasets/mydataset\"")
       
}

       
// Instantiate the client.
        ctx
:= context.Background()
        dataExchClient
, err := dataexchange.NewAnalyticsHubClient(ctx)
       
if err != nil {
                log
.Fatalf("NewClient: %v", err)
       
}
        defer dataExchClient
.Close()

       
// Then, create the data exchange (or return information about one already bearing the example name), and
       
// print information about it.
        exchange
, err := createOrGetDataExchange(ctx, dataExchClient, *projectID, *location, *exchangeID)
       
if err != nil {
                log
.Fatalf("failed to get information about the exchange: %v", err)
       
}
        fmt
.Printf("\nData Exchange Information\n")
        fmt
.Printf("Exchange Name: %s\n", exchange.GetName())
       
if desc := exchange.GetDescription(); desc != "" {
                fmt
.Printf("Exchange Description: %s", desc)
       
}

       
// Finally, create a listing within the data exchange and print information about it.
        listing
, err := createListing(ctx, dataExchClient, *projectID, *location, *exchangeID, *listingID, *exampleDatasetSource)
       
if err != nil {
                log
.Fatalf("failed to create the listing within the exchange: %v", err)
       
}
        fmt
.Printf("\n\nListing Information\n")
        fmt
.Printf("Listing Name: %s\n", listing.GetName())
       
if desc := listing.GetDescription(); desc != "" {
                fmt
.Printf("Listing Description: %s\n", desc)
       
}
        fmt
.Printf("Listing State: %s\n", listing.GetState().String())
       
if source := listing.GetSource(); source != nil {
               
if dsSource, ok := source.(*dataexchangepb.Listing_BigqueryDataset); ok && dsSource.BigqueryDataset != nil {
                       
if dataset := dsSource.BigqueryDataset.GetDataset(); dataset != "" {
                                fmt
.Printf("Source is a bigquery dataset: %s", dataset)
                       
}
               
}
       
}
       
// Optionally, delete the data exchange at the end of the quickstart to clean up the resources used.
       
if *delete {
                fmt
.Printf("\n\n")
               
if err := deleteDataExchange(ctx, dataExchClient, *projectID, *location, *exchangeID); err != nil {
                        log
.Fatalf("failed to delete exchange: %v", err)
               
}
                fmt
.Printf("Exchange projects/%s/locations/%s/dataExchanges/%s was deleted.\n", *projectID, *location, *exchangeID)
       
}
        fmt
.Printf("\nQuickstart completed.\n")
}

// createOrGetDataExchange creates an example data exchange, or returns information about the exchange already bearing
// the example identifier.
func createOrGetDataExchange
(ctx context.Context, client *dataexchange.AnalyticsHubClient, projectID, location, exchangeID string) (*dataexchangepb.DataExchange, error) {
        req
:= &dataexchangepb.CreateDataExchangeRequest{
               
Parent:         fmt.Sprintf("projects/%s/locations/%s", projectID, location),
               
DataExchangeId: exchangeID,
               
DataExchange: &dataexchangepb.DataExchange{
                       
DisplayName:    "Example Data Exchange",
                       
Description:    "Exchange created as part of an API quickstart",
                       
PrimaryContact: "",
                       
Documentation:  "https://link.to.optional.documentation/",
               
},
       
}

        resp
, err := client.CreateDataExchange(ctx, req)
       
if err != nil {
               
// We'll handle one specific error case specially, the case of the exchange already existing.  In this instance,
               
// we'll issue a second request to fetch the exchange information for the already present exchange and return it.
               
if code := status.Code(err); code == codes.AlreadyExists {
                        getReq
:= &dataexchangepb.GetDataExchangeRequest{
                               
Name: fmt.Sprintf("projects/%s/locations/%s/dataExchanges/%s", projectID, location, exchangeID),
                       
}
                        resp
, err = client.GetDataExchange(ctx, getReq)
                       
if err != nil {
                               
return nil, fmt.Errorf("error getting dataExchange: %w", err)
                       
}
                       
return resp, nil
               
}
               
// For all other cases, return the error from creation request.
               
return nil, err
       
}
       
return resp, nil
}

// createListing creates an example listing within the specified exchange using the provided source dataset.
func createListing
(ctx context.Context, client *dataexchange.AnalyticsHubClient, projectID, location, exchangeID, listingID, sourceDataset string) (*dataexchangepb.Listing, error) {
        req
:= &dataexchangepb.CreateListingRequest{
               
Parent:    fmt.Sprintf("projects/%s/locations/%s/dataExchanges/%s", projectID, location, exchangeID),
               
ListingId: listingID,
               
Listing: &dataexchangepb.Listing{
                       
DisplayName: "Example Exchange Listing",
                       
Description: "Example listing created as part of an API quickstart",
                       
Categories: []dataexchangepb.Listing_Category{
                                dataexchangepb
.Listing_CATEGORY_OTHERS,
                       
},
                       
Source: &dataexchangepb.Listing_BigqueryDataset{
                               
BigqueryDataset: &dataexchangepb.Listing_BigQueryDatasetSource{
                                       
Dataset: sourceDataset,
                               
},
                       
},
               
},
       
}
       
return client.CreateListing(ctx, req)
}

// deleteDataExchange deletes a data exchange.
func deleteDataExchange
(ctx context.Context, client *dataexchange.AnalyticsHubClient, projectID, location, exchangeID string) error {
        req
:= &dataexchangepb.DeleteDataExchangeRequest{
               
Name: fmt.Sprintf("projects/%s/locations/%s/dataExchanges/%s", projectID, location, exchangeID),
       
}
       
return client.DeleteDataExchange(ctx, req)
}

/**
 * TODO(developer): Uncomment these variables before running the sample.
 */

/**
 *  Required. The parent resource path of the DataExchanges.
 *  e.g. `projects/myproject/locations/US`.
 */

// const parent = 'abc123'
/**
 *  The maximum number of results to return in a single response page. Leverage
 *  the page tokens to iterate through the entire collection.
 */

// const pageSize = 1234
/**
 *  Page token, returned by a previous call, to request the next page of
 *  results.
 */

// const pageToken = 'abc123'

// Imports the Dataexchange library
const {AnalyticsHubServiceClient} =
  require
('@google-cloud/bigquery-data-exchange').v1beta1;

// Instantiates a client
const dataexchangeClient = new AnalyticsHubServiceClient();

async
function callListDataExchanges() {
 
// Construct request
 
const request = {
    parent
,
 
};

 
// Run request
 
const iterable = await dataexchangeClient.listDataExchangesAsync(request);
 
for await (const response of iterable) {
    console
.log(response);
 
}
}

callListDataExchanges
();

補足資料

次のリストは、C# のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、Go のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、Java のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、Node.js のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、PHP のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、Python のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のリストは、Ruby のクライアント ライブラリに関連するその他のリソースへのリンクを示します。

次のステップ

詳細な背景情報については、Analytics Hub の概要をご覧ください。