cloud_run_grpc_auth 0.11.0 cloud_run_grpc_auth: ^0.11.0 copied to clipboard
Identity for Google Cloud Run Services as gRPC clients
import 'dart:convert';
import 'dart:io';
import 'package:cloud_run_grpc_auth/cloud_run_grpc_auth.dart';
import 'package:grpc/grpc.dart';
import 'grpc/recipe.pbgrpc.dart';
void main() async {
// See https://developers.google.com/identity/protocols/oauth2/service-account
// We begin by creating a normal gRPC client
// in this case, we are focused on calling
// a Google Cloud Run service from another
// Google Cloud Run service
final creds = ChannelCredentials.secure();
final clientChannel = ClientChannel(
'my-internal-service.run.app',
port: 443,
options: ChannelOptions(
credentials: creds,
),
);
// One of the options is to use the service's default credentials.
// This can only be used from Google Cloud.
// First, we create the authenticator:
final defaultAuthenticator = GrpcAuthenticator.idTokenFromMeta();
// then the client:
final defaultClient = GRecipeServiceClient(clientChannel,
options: defaultAuthenticator.toCallOptions);
// Finally, we simply use the client
final recipe = GRecipe();
defaultClient.create(recipe);
// Another option is to download the key from the user running the
// service, and make it available to the container as a file
// (or an environment variable, which ideally would be served by a secret)
// This is convenient for development time and debugging as it allows to
// authenticate with Google Cloud Run services from services being
// hosted outside Google Cloud, as for instance developer machine.
final serviceCredencials = await File('service-account.json').readAsString();
final keyAuthenticator = GrpcAuthenticator.idTokenFromServiceAccountOAuth(
jsonDecode(serviceCredencials));
final keyClient = GRecipeServiceClient(clientChannel,
options: keyAuthenticator.toCallOptions);
// Finally, again we simply use the client
keyClient.create(recipe);
// ********* GOOGLE API usage *********
//
// This package can also be used to authenticate calls to
// Google APIs that are available via gRPC. You may
// use this package with the https://pub.dev/packages/grpc_googleapis
// package.
// to get an authenticaticator that uses the host's metadata
// the easiest way is to use the ikTokenFromMeta constructor of
// the authenticator:
final autoTokenAuthenticator = GrpcAuthenticator.idTokenFromMeta();
// or
// ignore: unused_local_variable
final oauthTokenAuthenticator =
GrpcAuthenticator.idTokenFromServiceAccountOAuth(
jsonDecode(serviceCredencials));
// ignore: unused_local_variable
final options = autoTokenAuthenticator.toCallOptions;
// ignore: unused_local_variable
final pubSubClientChannel = ClientChannel(
'pubsub.googleapis.com',
port: 443,
options: ChannelOptions(
credentials: creds,
),
);
// then, assuming the import
// import 'package:grpc_googleapis/google/pubsub_v1.dart' as ps;
// we could call:
/*
final cli = ps.PublisherClient(clientChannel, options: options);
final tr = ps.Topic(name: 'projects/nozard-tl/topics/user-nadia');
await cli.createTopic(tr);
*/
}