The googleapis client demonstrates how to use Dart gRPC libraries to communicate with Google APIs.
This example uses the Stackdriver Logging API. Please follow the documentation on Stackdriver Logging Documentation to create a project and enable the logging API.
Then follow the documentation to create a service account. This example uses the Logging/Logs Writer role.
Create a new service key, download the JSON file for it, and save it as
logging-service-account.json
.
To run the example, assuming you are in the root of the googleapis folder, i.e., .../example/googleapis/, first get the dependencies by running:
$ dart pub get
Then, to run the logging client sample:
$ dart run bin/logging.dart
The Dart gRPC stubs and message classes are generated based on protobuf definition files from googleapis/googleapis.
To regenerate them, you will need to check out both googleapis/googleapis and google/protobuf.
You will also need to have protoc version 3.0.0 or higher and the Dart protoc plugin version 0.7.9 or higher on your PATH.
To install protoc, see the instructions on the Protocol Buffers website.
The easiest way to get the Dart protoc plugin is by running
$ pub global activate protoc_plugin
and follow the directions to add ~/.pub-cache/bin
to your PATH, if you haven't
already done so.
You can now regenerate the Dart files. Set the PROTOBUF
and GOOGLEAPIS
environment variables to point to your clone of
google/protobuf and
googleapis/googleapis, respectively,
and then run
$ tool/regenerate.sh