google-api-client 0.34.1 → 0.35.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.yardopts +16 -3
- data/CHANGELOG.md +114 -0
- data/OVERVIEW.md +36 -0
- data/README.md +49 -1
- data/Rakefile +1 -1
- data/docs/api-keys.md +20 -0
- data/docs/auth.md +53 -0
- data/docs/client-secrets.md +69 -0
- data/docs/getting-started.md +340 -0
- data/docs/installation.md +0 -0
- data/docs/logging.md +34 -0
- data/docs/media-upload.md +25 -0
- data/docs/oauth-installed.md +191 -0
- data/docs/oauth-server.md +135 -0
- data/docs/oauth-web.md +280 -0
- data/docs/oauth.md +268 -0
- data/docs/pagination.md +29 -0
- data/docs/performance.md +25 -0
- data/generated/google/apis/adexchangebuyer2_v2beta1.rb +1 -1
- data/generated/google/apis/adexchangebuyer_v1_3.rb +1 -1
- data/generated/google/apis/adexchangebuyer_v1_3/classes.rb +9 -0
- data/generated/google/apis/adexchangebuyer_v1_3/representations.rb +1 -0
- data/generated/google/apis/adexchangebuyer_v1_4.rb +1 -1
- data/generated/google/apis/adexchangebuyer_v1_4/classes.rb +9 -0
- data/generated/google/apis/adexchangebuyer_v1_4/representations.rb +1 -0
- data/generated/google/apis/androidmanagement_v1.rb +1 -1
- data/generated/google/apis/androidpublisher_v3.rb +1 -1
- data/generated/google/apis/androidpublisher_v3/classes.rb +93 -0
- data/generated/google/apis/androidpublisher_v3/representations.rb +49 -0
- data/generated/google/apis/appengine_v1.rb +1 -1
- data/generated/google/apis/appengine_v1beta.rb +1 -1
- data/generated/google/apis/appsmarket_v2.rb +1 -1
- data/generated/google/apis/bigquery_v2.rb +1 -1
- data/generated/google/apis/bigquery_v2/classes.rb +46 -4
- data/generated/google/apis/bigquery_v2/representations.rb +17 -0
- data/generated/google/apis/bigquery_v2/service.rb +1 -5
- data/generated/google/apis/bigqueryconnection_v1beta1.rb +1 -1
- data/generated/google/apis/bigqueryconnection_v1beta1/classes.rb +6 -5
- data/generated/google/apis/bigquerydatatransfer_v1.rb +1 -1
- data/generated/google/apis/bigquerydatatransfer_v1/service.rb +30 -4
- data/generated/google/apis/bigqueryreservation_v1.rb +1 -1
- data/generated/google/apis/bigqueryreservation_v1/classes.rb +0 -21
- data/generated/google/apis/bigqueryreservation_v1/representations.rb +0 -13
- data/generated/google/apis/bigqueryreservation_v1alpha2.rb +1 -1
- data/generated/google/apis/bigqueryreservation_v1alpha2/classes.rb +116 -1
- data/generated/google/apis/bigqueryreservation_v1alpha2/representations.rb +35 -0
- data/generated/google/apis/bigqueryreservation_v1alpha2/service.rb +71 -0
- data/generated/google/apis/bigqueryreservation_v1beta1.rb +1 -1
- data/generated/google/apis/bigqueryreservation_v1beta1/classes.rb +61 -77
- data/generated/google/apis/bigqueryreservation_v1beta1/representations.rb +16 -17
- data/generated/google/apis/bigqueryreservation_v1beta1/service.rb +112 -78
- data/generated/google/apis/bigtableadmin_v1.rb +1 -1
- data/generated/google/apis/bigtableadmin_v1/classes.rb +1 -1
- data/generated/google/apis/bigtableadmin_v2.rb +1 -1
- data/generated/google/apis/bigtableadmin_v2/classes.rb +1 -1
- data/generated/google/apis/bigtableadmin_v2/service.rb +1 -1
- data/generated/google/apis/{sqladmin_v1beta4.rb → billingbudgets_v1beta1.rb} +10 -13
- data/generated/google/apis/billingbudgets_v1beta1/classes.rb +392 -0
- data/generated/google/apis/billingbudgets_v1beta1/representations.rb +191 -0
- data/generated/google/apis/billingbudgets_v1beta1/service.rb +233 -0
- data/generated/google/apis/binaryauthorization_v1.rb +1 -1
- data/generated/google/apis/binaryauthorization_v1/classes.rb +6 -5
- data/generated/google/apis/binaryauthorization_v1beta1.rb +1 -1
- data/generated/google/apis/binaryauthorization_v1beta1/classes.rb +6 -5
- data/generated/google/apis/books_v1.rb +1 -1
- data/generated/google/apis/books_v1/classes.rb +20 -0
- data/generated/google/apis/books_v1/representations.rb +3 -0
- data/generated/google/apis/calendar_v3.rb +1 -1
- data/generated/google/apis/calendar_v3/classes.rb +1 -1
- data/generated/google/apis/calendar_v3/service.rb +18 -30
- data/generated/google/apis/civicinfo_v2.rb +1 -1
- data/generated/google/apis/civicinfo_v2/classes.rb +0 -156
- data/generated/google/apis/civicinfo_v2/representations.rb +0 -58
- data/generated/google/apis/cloudasset_v1.rb +1 -1
- data/generated/google/apis/cloudasset_v1/classes.rb +6 -5
- data/generated/google/apis/cloudasset_v1beta1.rb +1 -1
- data/generated/google/apis/cloudasset_v1beta1/classes.rb +6 -5
- data/generated/google/apis/cloudbilling_v1.rb +1 -1
- data/generated/google/apis/cloudbilling_v1/classes.rb +17 -0
- data/generated/google/apis/cloudbuild_v1.rb +1 -1
- data/generated/google/apis/cloudbuild_v1/classes.rb +8 -2
- data/generated/google/apis/cloudbuild_v1/representations.rb +1 -0
- data/generated/google/apis/cloudbuild_v1/service.rb +18 -18
- data/generated/google/apis/cloudbuild_v1alpha1.rb +1 -1
- data/generated/google/apis/cloudbuild_v1alpha1/classes.rb +8 -2
- data/generated/google/apis/cloudbuild_v1alpha1/representations.rb +1 -0
- data/generated/google/apis/cloudbuild_v1alpha1/service.rb +4 -1
- data/generated/google/apis/cloudfunctions_v1.rb +1 -1
- data/generated/google/apis/cloudfunctions_v1/classes.rb +13 -5
- data/generated/google/apis/cloudfunctions_v1/representations.rb +1 -0
- data/generated/google/apis/cloudfunctions_v1/service.rb +3 -1
- data/generated/google/apis/cloudiot_v1.rb +1 -1
- data/generated/google/apis/cloudiot_v1/classes.rb +6 -5
- data/generated/google/apis/cloudkms_v1.rb +1 -1
- data/generated/google/apis/cloudkms_v1/classes.rb +6 -5
- data/generated/google/apis/cloudprivatecatalogproducer_v1beta1.rb +1 -1
- data/generated/google/apis/cloudprivatecatalogproducer_v1beta1/classes.rb +6 -5
- data/generated/google/apis/cloudresourcemanager_v1.rb +1 -1
- data/generated/google/apis/cloudresourcemanager_v1/classes.rb +6 -5
- data/generated/google/apis/cloudresourcemanager_v1beta1.rb +1 -1
- data/generated/google/apis/cloudresourcemanager_v1beta1/classes.rb +6 -5
- data/generated/google/apis/cloudresourcemanager_v2.rb +1 -1
- data/generated/google/apis/cloudresourcemanager_v2/classes.rb +6 -5
- data/generated/google/apis/cloudresourcemanager_v2beta1.rb +1 -1
- data/generated/google/apis/cloudresourcemanager_v2beta1/classes.rb +6 -5
- data/generated/google/apis/cloudscheduler_v1.rb +1 -1
- data/generated/google/apis/cloudscheduler_v1/classes.rb +2 -1
- data/generated/google/apis/cloudscheduler_v1beta1.rb +1 -1
- data/generated/google/apis/cloudscheduler_v1beta1/classes.rb +2 -1
- data/generated/google/apis/cloudsearch_v1.rb +8 -8
- data/generated/google/apis/cloudsearch_v1/classes.rb +5 -130
- data/generated/google/apis/cloudsearch_v1/representations.rb +0 -75
- data/generated/google/apis/cloudsearch_v1/service.rb +42 -7
- data/generated/google/apis/cloudtasks_v2.rb +1 -1
- data/generated/google/apis/cloudtasks_v2/classes.rb +212 -5
- data/generated/google/apis/cloudtasks_v2/representations.rb +50 -0
- data/generated/google/apis/cloudtasks_v2beta2.rb +1 -1
- data/generated/google/apis/cloudtasks_v2beta2/classes.rb +6 -5
- data/generated/google/apis/cloudtasks_v2beta3.rb +1 -1
- data/generated/google/apis/cloudtasks_v2beta3/classes.rb +6 -5
- data/generated/google/apis/commentanalyzer_v1alpha1.rb +1 -1
- data/generated/google/apis/commentanalyzer_v1alpha1/classes.rb +14 -19
- data/generated/google/apis/compute_alpha.rb +1 -1
- data/generated/google/apis/compute_alpha/classes.rb +75 -12
- data/generated/google/apis/compute_alpha/representations.rb +2 -0
- data/generated/google/apis/compute_beta.rb +1 -1
- data/generated/google/apis/compute_beta/classes.rb +54 -10
- data/generated/google/apis/compute_v1.rb +1 -1
- data/generated/google/apis/compute_v1/classes.rb +54 -10
- data/generated/google/apis/containeranalysis_v1alpha1.rb +1 -1
- data/generated/google/apis/containeranalysis_v1alpha1/classes.rb +6 -5
- data/generated/google/apis/containeranalysis_v1beta1.rb +1 -1
- data/generated/google/apis/containeranalysis_v1beta1/classes.rb +6 -5
- data/generated/google/apis/content_v2.rb +1 -1
- data/generated/google/apis/content_v2/classes.rb +13 -4
- data/generated/google/apis/content_v2_1.rb +1 -1
- data/generated/google/apis/content_v2_1/classes.rb +13 -4
- data/generated/google/apis/datacatalog_v1beta1.rb +35 -0
- data/generated/google/apis/datacatalog_v1beta1/classes.rb +1646 -0
- data/generated/google/apis/datacatalog_v1beta1/representations.rb +700 -0
- data/generated/google/apis/datacatalog_v1beta1/service.rb +1982 -0
- data/generated/google/apis/dataproc_v1.rb +1 -1
- data/generated/google/apis/dataproc_v1/classes.rb +75 -4
- data/generated/google/apis/dataproc_v1/representations.rb +22 -0
- data/generated/google/apis/dataproc_v1/service.rb +14 -7
- data/generated/google/apis/dataproc_v1beta2.rb +1 -1
- data/generated/google/apis/dataproc_v1beta2/classes.rb +2 -4
- data/generated/google/apis/dataproc_v1beta2/service.rb +14 -7
- data/generated/google/apis/dfareporting_v3_3.rb +1 -1
- data/generated/google/apis/dfareporting_v3_3/classes.rb +21 -1
- data/generated/google/apis/dfareporting_v3_3/service.rb +6 -6
- data/generated/google/apis/dfareporting_v3_4.rb +40 -0
- data/generated/google/apis/dfareporting_v3_4/classes.rb +12717 -0
- data/generated/google/apis/dfareporting_v3_4/representations.rb +4595 -0
- data/generated/google/apis/dfareporting_v3_4/service.rb +8685 -0
- data/generated/google/apis/dialogflow_v2.rb +1 -1
- data/generated/google/apis/dialogflow_v2/classes.rb +484 -1
- data/generated/google/apis/dialogflow_v2/representations.rb +220 -0
- data/generated/google/apis/dialogflow_v2beta1.rb +1 -1
- data/generated/google/apis/dialogflow_v2beta1/classes.rb +497 -1
- data/generated/google/apis/dialogflow_v2beta1/representations.rb +221 -0
- data/generated/google/apis/dlp_v2.rb +1 -1
- data/generated/google/apis/dlp_v2/classes.rb +68 -25
- data/generated/google/apis/dlp_v2/representations.rb +9 -4
- data/generated/google/apis/dlp_v2/service.rb +1925 -193
- data/generated/google/apis/dns_v1beta2.rb +1 -1
- data/generated/google/apis/dns_v1beta2/classes.rb +47 -0
- data/generated/google/apis/dns_v1beta2/representations.rb +17 -0
- data/generated/google/apis/docs_v1.rb +1 -1
- data/generated/google/apis/docs_v1/classes.rb +4 -8
- data/generated/google/apis/doubleclickbidmanager_v1.rb +1 -1
- data/generated/google/apis/doubleclickbidmanager_v1_1.rb +34 -0
- data/generated/google/apis/doubleclickbidmanager_v1_1/classes.rb +826 -0
- data/generated/google/apis/doubleclickbidmanager_v1_1/representations.rb +372 -0
- data/generated/google/apis/doubleclickbidmanager_v1_1/service.rb +371 -0
- data/generated/google/apis/drive_v3.rb +1 -1
- data/generated/google/apis/drive_v3/classes.rb +12 -3
- data/generated/google/apis/fcm_v1.rb +1 -1
- data/generated/google/apis/fcm_v1/classes.rb +15 -0
- data/generated/google/apis/fcm_v1/representations.rb +2 -0
- data/generated/google/apis/firebase_v1beta1.rb +1 -1
- data/generated/google/apis/firebase_v1beta1/classes.rb +3 -4
- data/generated/google/apis/firebase_v1beta1/service.rb +6 -6
- data/generated/google/apis/firebasehosting_v1beta1.rb +1 -1
- data/generated/google/apis/firebasehosting_v1beta1/classes.rb +25 -0
- data/generated/google/apis/firebasehosting_v1beta1/representations.rb +15 -0
- data/generated/google/apis/firebasehosting_v1beta1/service.rb +47 -0
- data/generated/google/apis/firebaserules_v1.rb +1 -1
- data/generated/google/apis/firebaserules_v1/classes.rb +26 -0
- data/generated/google/apis/firebaserules_v1/representations.rb +15 -0
- data/generated/google/apis/genomics_v2alpha1.rb +1 -1
- data/generated/google/apis/genomics_v2alpha1/classes.rb +32 -0
- data/generated/google/apis/genomics_v2alpha1/representations.rb +16 -0
- data/generated/google/apis/healthcare_v1beta1.rb +1 -1
- data/generated/google/apis/healthcare_v1beta1/classes.rb +8 -7
- data/generated/google/apis/homegraph_v1.rb +1 -1
- data/generated/google/apis/homegraph_v1/classes.rb +15 -1
- data/generated/google/apis/homegraph_v1/representations.rb +2 -1
- data/generated/google/apis/iam_v1.rb +1 -1
- data/generated/google/apis/iam_v1/classes.rb +6 -5
- data/generated/google/apis/logging_v2.rb +1 -1
- data/generated/google/apis/logging_v2/classes.rb +18 -2
- data/generated/google/apis/logging_v2/representations.rb +2 -0
- data/generated/google/apis/ml_v1.rb +1 -1
- data/generated/google/apis/ml_v1/classes.rb +173 -97
- data/generated/google/apis/ml_v1/representations.rb +58 -0
- data/generated/google/apis/ml_v1/service.rb +37 -0
- data/generated/google/apis/monitoring_v3.rb +1 -1
- data/generated/google/apis/monitoring_v3/classes.rb +780 -6
- data/generated/google/apis/monitoring_v3/representations.rb +347 -0
- data/generated/google/apis/monitoring_v3/service.rb +382 -0
- data/generated/google/apis/pagespeedonline_v5.rb +1 -1
- data/generated/google/apis/pagespeedonline_v5/classes.rb +8 -0
- data/generated/google/apis/pagespeedonline_v5/representations.rb +1 -0
- data/generated/google/apis/policytroubleshooter_v1beta.rb +1 -1
- data/generated/google/apis/policytroubleshooter_v1beta/classes.rb +6 -5
- data/generated/google/apis/pubsub_v1.rb +1 -1
- data/generated/google/apis/pubsub_v1/classes.rb +8 -6
- data/generated/google/apis/pubsub_v1/service.rb +6 -7
- data/generated/google/apis/pubsub_v1beta2.rb +1 -1
- data/generated/google/apis/pubsub_v1beta2/classes.rb +6 -5
- data/generated/google/apis/recommender_v1beta1.rb +1 -1
- data/generated/google/apis/recommender_v1beta1/classes.rb +1 -1
- data/generated/google/apis/recommender_v1beta1/service.rb +10 -8
- data/generated/google/apis/remotebuildexecution_v1.rb +1 -1
- data/generated/google/apis/remotebuildexecution_v1/classes.rb +33 -0
- data/generated/google/apis/remotebuildexecution_v1/representations.rb +15 -0
- data/generated/google/apis/remotebuildexecution_v1alpha.rb +1 -1
- data/generated/google/apis/remotebuildexecution_v1alpha/classes.rb +33 -0
- data/generated/google/apis/remotebuildexecution_v1alpha/representations.rb +15 -0
- data/generated/google/apis/remotebuildexecution_v2.rb +1 -1
- data/generated/google/apis/remotebuildexecution_v2/classes.rb +33 -0
- data/generated/google/apis/remotebuildexecution_v2/representations.rb +15 -0
- data/generated/google/apis/run_v1.rb +1 -1
- data/generated/google/apis/run_v1/classes.rb +8 -169
- data/generated/google/apis/run_v1/representations.rb +0 -71
- data/generated/google/apis/run_v1/service.rb +229 -1207
- data/generated/google/apis/run_v1alpha1.rb +1 -1
- data/generated/google/apis/run_v1alpha1/classes.rb +9 -9
- data/generated/google/apis/runtimeconfig_v1beta1.rb +1 -1
- data/generated/google/apis/runtimeconfig_v1beta1/classes.rb +6 -5
- data/generated/google/apis/securitycenter_v1.rb +1 -1
- data/generated/google/apis/securitycenter_v1/classes.rb +66 -11
- data/generated/google/apis/securitycenter_v1/representations.rb +19 -0
- data/generated/google/apis/securitycenter_v1beta1.rb +1 -1
- data/generated/google/apis/securitycenter_v1beta1/classes.rb +16 -13
- data/generated/google/apis/servicebroker_v1.rb +1 -1
- data/generated/google/apis/servicebroker_v1/classes.rb +6 -5
- data/generated/google/apis/servicebroker_v1alpha1.rb +1 -1
- data/generated/google/apis/servicebroker_v1alpha1/classes.rb +6 -5
- data/generated/google/apis/servicebroker_v1beta1.rb +1 -1
- data/generated/google/apis/servicebroker_v1beta1/classes.rb +6 -5
- data/generated/google/apis/serviceconsumermanagement_v1.rb +1 -1
- data/generated/google/apis/serviceconsumermanagement_v1/classes.rb +3 -2
- data/generated/google/apis/servicecontrol_v1.rb +1 -1
- data/generated/google/apis/servicecontrol_v1/classes.rb +8 -1
- data/generated/google/apis/servicecontrol_v1/representations.rb +1 -0
- data/generated/google/apis/servicemanagement_v1.rb +1 -1
- data/generated/google/apis/servicemanagement_v1/classes.rb +12 -9
- data/generated/google/apis/servicemanagement_v1/service.rb +1 -9
- data/generated/google/apis/servicenetworking_v1.rb +1 -1
- data/generated/google/apis/servicenetworking_v1/classes.rb +130 -13
- data/generated/google/apis/servicenetworking_v1/representations.rb +58 -0
- data/generated/google/apis/servicenetworking_v1/service.rb +42 -3
- data/generated/google/apis/servicenetworking_v1beta.rb +1 -1
- data/generated/google/apis/servicenetworking_v1beta/classes.rb +3 -2
- data/generated/google/apis/serviceusage_v1.rb +1 -1
- data/generated/google/apis/serviceusage_v1/classes.rb +3 -2
- data/generated/google/apis/serviceusage_v1beta1.rb +1 -1
- data/generated/google/apis/serviceusage_v1beta1/classes.rb +3 -2
- data/generated/google/apis/sheets_v4.rb +1 -1
- data/generated/google/apis/spanner_v1.rb +1 -1
- data/generated/google/apis/spanner_v1/classes.rb +70 -30
- data/generated/google/apis/spanner_v1/service.rb +270 -0
- data/generated/google/apis/speech_v1.rb +1 -1
- data/generated/google/apis/speech_v1/classes.rb +6 -0
- data/generated/google/apis/speech_v1/representations.rb +1 -0
- data/generated/google/apis/speech_v1p1beta1.rb +1 -1
- data/generated/google/apis/speech_v1p1beta1/classes.rb +6 -0
- data/generated/google/apis/speech_v1p1beta1/representations.rb +1 -0
- data/generated/google/apis/sql_v1beta4.rb +1 -1
- data/generated/google/apis/sql_v1beta4/service.rb +59 -10
- data/generated/google/apis/storagetransfer_v1.rb +1 -1
- data/generated/google/apis/videointelligence_v1.rb +1 -1
- data/generated/google/apis/videointelligence_v1/classes.rb +112 -0
- data/generated/google/apis/videointelligence_v1/representations.rb +62 -0
- data/generated/google/apis/videointelligence_v1beta2.rb +1 -1
- data/generated/google/apis/videointelligence_v1beta2/classes.rb +112 -0
- data/generated/google/apis/videointelligence_v1beta2/representations.rb +62 -0
- data/generated/google/apis/videointelligence_v1p1beta1.rb +1 -1
- data/generated/google/apis/videointelligence_v1p1beta1/classes.rb +112 -0
- data/generated/google/apis/videointelligence_v1p1beta1/representations.rb +62 -0
- data/generated/google/apis/videointelligence_v1p2beta1.rb +1 -1
- data/generated/google/apis/videointelligence_v1p2beta1/classes.rb +112 -0
- data/generated/google/apis/videointelligence_v1p2beta1/representations.rb +62 -0
- data/generated/google/apis/videointelligence_v1p3beta1.rb +1 -1
- data/generated/google/apis/videointelligence_v1p3beta1/classes.rb +112 -0
- data/generated/google/apis/videointelligence_v1p3beta1/representations.rb +62 -0
- data/generated/google/apis/youtube_partner_v1.rb +1 -1
- data/lib/google/apis/core/api_command.rb +3 -0
- data/lib/google/apis/core/http_command.rb +10 -8
- data/lib/google/apis/version.rb +1 -1
- data/rakelib/devsite/devsite_builder.rb +1 -1
- metadata +33 -11
- data/generated/google/apis/sqladmin_v1beta4/classes.rb +0 -2633
- data/generated/google/apis/sqladmin_v1beta4/representations.rb +0 -1110
- data/generated/google/apis/sqladmin_v1beta4/service.rb +0 -1793
- data/generated/google/apis/storage_v1beta1.rb +0 -40
- data/generated/google/apis/storage_v1beta1/classes.rb +0 -616
- data/generated/google/apis/storage_v1beta1/representations.rb +0 -249
- data/generated/google/apis/storage_v1beta1/service.rb +0 -1032
data/docs/oauth.md
ADDED
@@ -0,0 +1,268 @@
|
|
1
|
+
# OAuth 2.0
|
2
|
+
|
3
|
+
This document describes OAuth 2.0, when to use it, how to acquire client IDs and client secrets, and generally how to use OAuth 2.0 with the Google API Client Library for Ruby.
|
4
|
+
|
5
|
+
## About OAuth 2.0
|
6
|
+
|
7
|
+
OAuth 2.0 is the authorization protocol used by Google APIs. It is summarized on the Authentication page of this library's documentation, and there are other good references as well:
|
8
|
+
|
9
|
+
- [The OAuth 2.0 Authorization Protocol](https://tools.ietf.org/html/rfc6749)
|
10
|
+
- [Using OAuth 2.0 to Access Google APIs](https://developers.google.com/identity/protocols/OAuth2)
|
11
|
+
|
12
|
+
## Acquiring client IDs and secrets
|
13
|
+
|
14
|
+
To find your project's client ID and client secret, do the following:
|
15
|
+
|
16
|
+
Select an existing OAuth 2.0 credential or open the Credentials page.
|
17
|
+
If you haven't done so already, create your project's OAuth 2.0 credentials by clicking Create credentials > OAuth client ID, and providing the information needed to create the credentials.
|
18
|
+
Look for the Client ID in the OAuth 2.0 client IDs section. For details, click the client ID.
|
19
|
+
There are different types of client IDs, so be sure to get the correct type for your application:
|
20
|
+
|
21
|
+
* Web application client IDs
|
22
|
+
* Installed application client IDs
|
23
|
+
* [Service Account](https://developers.google.com/accounts/docs/OAuth2ServiceAccount) client IDs
|
24
|
+
|
25
|
+
**Warning**: Keep your client secret private. If someone obtains your client secret, they could use it to consume your quota, incur charges against your Google APIs Console project, and request access to user data.
|
26
|
+
|
27
|
+
## The Signet library
|
28
|
+
|
29
|
+
The [Signet](https://github.com/googleapis/signet) library is included with the Google API Client Library for Ruby. It handles all steps of the OAuth 2.0 protocol required for making API calls. It is available as a separate gem if you only need an OAuth 2.0 library.
|
30
|
+
|
31
|
+
## Flows
|
32
|
+
|
33
|
+
There are three main OAuth 2.0 flows in the Google API Client Library for Ruby: web server, installed application and service account.
|
34
|
+
|
35
|
+
## Web server
|
36
|
+
|
37
|
+
We start by retrieving the client ID and client secret from a preconfigured client_secrets.json file:
|
38
|
+
|
39
|
+
```rb
|
40
|
+
client_secrets = Google::APIClient::ClientSecrets.load
|
41
|
+
```
|
42
|
+
For web-based applications, we then redirect the user to an authorization page:
|
43
|
+
|
44
|
+
```rb
|
45
|
+
# Request authorization
|
46
|
+
redirect user_credentials.authorization_uri.to_s, 303
|
47
|
+
```
|
48
|
+
|
49
|
+
The user completes the steps on her browser, and control gets returned to the application via the callback URL:
|
50
|
+
|
51
|
+
```rb
|
52
|
+
get '/oauth2callback' do
|
53
|
+
# Exchange token
|
54
|
+
user_credentials.code = params[:code] if params[:code]
|
55
|
+
user_credentials.fetch_access_token!
|
56
|
+
redirect to('/')
|
57
|
+
end
|
58
|
+
```
|
59
|
+
|
60
|
+
user_credentials now has everything needed to make authenticated requests:
|
61
|
+
|
62
|
+
```rb
|
63
|
+
events = calendar.list_events('primary', options: { authorization: user_credentials })
|
64
|
+
```
|
65
|
+
|
66
|
+
Below is the full sample we've been looking at.
|
67
|
+
|
68
|
+
```rb
|
69
|
+
require 'google/apis/calendar_v3'
|
70
|
+
require 'google/api_client/client_secrets'
|
71
|
+
require 'sinatra'
|
72
|
+
require 'logger'
|
73
|
+
|
74
|
+
enable :sessions
|
75
|
+
|
76
|
+
def logger; settings.logger end
|
77
|
+
|
78
|
+
def calendar; settings.calendar; end
|
79
|
+
|
80
|
+
def user_credentials
|
81
|
+
# Build a per-request oauth credential based on token stored in session
|
82
|
+
# which allows us to use a shared API client.
|
83
|
+
@authorization ||= (
|
84
|
+
auth = settings.authorization.dup
|
85
|
+
auth.redirect_uri = to('/oauth2callback')
|
86
|
+
auth.update_token!(session)
|
87
|
+
auth
|
88
|
+
)
|
89
|
+
end
|
90
|
+
|
91
|
+
configure do
|
92
|
+
log_file = File.open('calendar.log', 'a+')
|
93
|
+
log_file.sync = true
|
94
|
+
logger = Logger.new(log_file)
|
95
|
+
logger.level = Logger::DEBUG
|
96
|
+
|
97
|
+
Google::Apis::ClientOptions.default.application_name = 'Ruby Calendar sample'
|
98
|
+
Google::Apis::ClientOptions.default.application_version = '1.0.0'
|
99
|
+
calendar_api = Google::Apis::CalendarV3::CalendarService.new
|
100
|
+
|
101
|
+
client_secrets = Google::APIClient::ClientSecrets.load
|
102
|
+
authorization = client_secrets.to_authorization
|
103
|
+
authorization.scope = 'https://www.googleapis.com/auth/calendar'
|
104
|
+
|
105
|
+
set :authorization, authorization
|
106
|
+
set :logger, logger
|
107
|
+
set :calendar, calendar_api
|
108
|
+
end
|
109
|
+
|
110
|
+
before do
|
111
|
+
# Ensure user has authorized the app
|
112
|
+
unless user_credentials.access_token || request.path_info =~ /^\/oauth2/
|
113
|
+
redirect to('/oauth2authorize')
|
114
|
+
end
|
115
|
+
end
|
116
|
+
|
117
|
+
after do
|
118
|
+
# Serialize the access/refresh token to the session and credential store.
|
119
|
+
session[:access_token] = user_credentials.access_token
|
120
|
+
session[:refresh_token] = user_credentials.refresh_token
|
121
|
+
session[:expires_in] = user_credentials.expires_in
|
122
|
+
session[:issued_at] = user_credentials.issued_at
|
123
|
+
end
|
124
|
+
|
125
|
+
get '/oauth2authorize' do
|
126
|
+
# Request authorization
|
127
|
+
redirect user_credentials.authorization_uri.to_s, 303
|
128
|
+
end
|
129
|
+
|
130
|
+
get '/oauth2callback' do
|
131
|
+
# Exchange token
|
132
|
+
user_credentials.code = params[:code] if params[:code]
|
133
|
+
user_credentials.fetch_access_token!
|
134
|
+
redirect to('/')
|
135
|
+
end
|
136
|
+
|
137
|
+
get '/' do
|
138
|
+
# Fetch list of events on the user's default calandar
|
139
|
+
events = calendar.list_events('primary', options: { authorization: user_credentials })
|
140
|
+
[200, {'Content-Type' => 'application/json'}, events.to_h.to_json]
|
141
|
+
end
|
142
|
+
```
|
143
|
+
|
144
|
+
### Installed application
|
145
|
+
|
146
|
+
We start by retrieving the client ID and client secret from a preconfigured client_secrets.json file:
|
147
|
+
|
148
|
+
```rb
|
149
|
+
client_secrets = Google::APIClient::ClientSecrets.load
|
150
|
+
```
|
151
|
+
|
152
|
+
For installed applications, we can use the Google::APIClient::InstalledAppFlow helper class to handle most of the setup:
|
153
|
+
|
154
|
+
```rb
|
155
|
+
flow = Google::APIClient::InstalledAppFlow.new(
|
156
|
+
:client_id => client_secrets.client_id,
|
157
|
+
:client_secret => client_secrets.client_secret,
|
158
|
+
:scope => ['https://www.googleapis.com/auth/adsense.readonly']
|
159
|
+
)
|
160
|
+
```
|
161
|
+
|
162
|
+
The user completes the steps on her browser, which is opened automatically, and the authorization code is fed into the application automatically, so all it takes is:
|
163
|
+
|
164
|
+
```rb
|
165
|
+
adsense.authorization = flow.authorize(storage)
|
166
|
+
```
|
167
|
+
|
168
|
+
The client now has everything needed to make an authenticated request:
|
169
|
+
|
170
|
+
```rb
|
171
|
+
report = adsense.generate_report(start_date: '2011-01-01', end_date: '2011-08-31',
|
172
|
+
metric: %w(PAGE_VIEWS AD_REQUESTS AD_REQUESTS_COVERAGE
|
173
|
+
CLICKS AD_REQUESTS_CTR COST_PER_CLICK
|
174
|
+
AD_REQUESTS_RPM EARNINGS),
|
175
|
+
dimension: %w(DATE),
|
176
|
+
sort: %w(+DATE))
|
177
|
+
```
|
178
|
+
|
179
|
+
Below is the full sample we've been looking at.
|
180
|
+
|
181
|
+
```rb
|
182
|
+
# AdSense Management API command-line sample.
|
183
|
+
require 'google/apis/adsense_v1_4'
|
184
|
+
require 'google/api_client/client_secrets'
|
185
|
+
require 'google/api_client/auth/installed_app'
|
186
|
+
require 'google/api_client/auth/storage'
|
187
|
+
require 'google/api_client/auth/storages/file_store'
|
188
|
+
require 'logger'
|
189
|
+
require 'json'
|
190
|
+
|
191
|
+
CREDENTIAL_STORE_FILE = "#{$0}-oauth2.json"
|
192
|
+
|
193
|
+
# Handles authentication and loading of the API.
|
194
|
+
def setup
|
195
|
+
log_file = File.open('adsense.log', 'a+')
|
196
|
+
log_file.sync = true
|
197
|
+
logger = Logger.new(log_file)
|
198
|
+
logger.level = Logger::DEBUG
|
199
|
+
|
200
|
+
adsense = Google::Apis::AdsenseV1_4::AdSenseService.new
|
201
|
+
|
202
|
+
# Stores auth credentials in a file, so they survive multiple runs
|
203
|
+
# of the application. This avoids prompting the user for authorization every
|
204
|
+
# time the access token expires, by remembering the refresh token.
|
205
|
+
# Note: FileStorage is not suitable for multi-user applications.
|
206
|
+
storage = Google::APIClient::Storage.new(
|
207
|
+
Google::APIClient::FileStore.new(CREDENTIAL_STORE_FILE))
|
208
|
+
adsense.authorization = storage.authorize
|
209
|
+
if storage.authorization.nil?
|
210
|
+
client_secrets = Google::APIClient::ClientSecrets.load
|
211
|
+
# The InstalledAppFlow is a helper class to handle the OAuth 2.0 installed
|
212
|
+
# application flow, which ties in with Stroage to store credentials
|
213
|
+
# between runs.
|
214
|
+
flow = Google::APIClient::InstalledAppFlow.new(
|
215
|
+
:client_id => client_secrets.client_id,
|
216
|
+
:client_secret => client_secrets.client_secret,
|
217
|
+
:scope => ['https://www.googleapis.com/auth/adsense.readonly']
|
218
|
+
)
|
219
|
+
adsense.authorization = flow.authorize(storage)
|
220
|
+
end
|
221
|
+
return adsense
|
222
|
+
end
|
223
|
+
|
224
|
+
# Generates a report for the default account.
|
225
|
+
def generate_report(adsense)
|
226
|
+
report = adsense.generate_report(start_date: '2011-01-01', end_date: '2011-08-31',
|
227
|
+
metric: %w(PAGE_VIEWS AD_REQUESTS AD_REQUESTS_COVERAGE
|
228
|
+
CLICKS AD_REQUESTS_CTR COST_PER_CLICK
|
229
|
+
AD_REQUESTS_RPM EARNINGS),
|
230
|
+
dimension: %w(DATE),
|
231
|
+
sort: %w(+DATE))
|
232
|
+
|
233
|
+
# Display headers.
|
234
|
+
report.headers.each do |header|
|
235
|
+
print '%25s' % header.name
|
236
|
+
end
|
237
|
+
puts
|
238
|
+
|
239
|
+
# Display results.
|
240
|
+
report.rows.each do |row|
|
241
|
+
row.each do |column|
|
242
|
+
print '%25s' % column
|
243
|
+
end
|
244
|
+
puts
|
245
|
+
end
|
246
|
+
end
|
247
|
+
|
248
|
+
|
249
|
+
if __FILE__ == $0
|
250
|
+
adsense = setup()
|
251
|
+
generate_report(adsense)
|
252
|
+
end
|
253
|
+
```
|
254
|
+
|
255
|
+
## Service accounts
|
256
|
+
|
257
|
+
For server-to-server interactions, like those between a web application and Google Cloud Storage, Prediction, or BigQuery APIs, you can use service accounts.
|
258
|
+
|
259
|
+
```rb
|
260
|
+
require 'googleauth'
|
261
|
+
require 'google/apis/compute_v1'
|
262
|
+
|
263
|
+
compute = Google::Apis::ComputeV1::ComputeService.new
|
264
|
+
|
265
|
+
# Get the environment configured authorization
|
266
|
+
scopes = ['https://www.googleapis.com/auth/cloud-platform', 'https://www.googleapis.com/auth/compute']
|
267
|
+
compute.authorization = Google::Auth.get_application_default(scopes)
|
268
|
+
```
|
data/docs/pagination.md
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
# Pagination
|
2
|
+
|
3
|
+
Some API methods may return very large lists of data. To reduce the response size, many of these API methods support pagination. With paginated results, your application can iteratively request and process large lists one page at a time. When using API methods that support pagination, responses will come back with a next_page property, which builds a request for the next page for you.
|
4
|
+
|
5
|
+
To process the first page of results, construct a request as you normally would. There's usually an API-level parameter you can provide to specify the maximum size of each page, so be sure to check the API's documentation.
|
6
|
+
|
7
|
+
`stamps = service.list_stamps(cents: 5, max_results: 20)`
|
8
|
+
|
9
|
+
For further pages, repeat the request including the next page token from the previous result.
|
10
|
+
|
11
|
+
`stamps = service.list_stamps(cents:5, max_results: 20, page_token: stamps.next_page_token)`
|
12
|
+
|
13
|
+
Here is a full example which loops through the paginated results of a user's public Google Plus activities feed:
|
14
|
+
|
15
|
+
```rb
|
16
|
+
require 'google/apis/plus_v1'
|
17
|
+
|
18
|
+
plus = Google::Apis::PlusV1::PlusService.new
|
19
|
+
plus.key = '...' # API Key from the Google Developers Console
|
20
|
+
next_page = nil
|
21
|
+
begin
|
22
|
+
puts "Fetching page of activities"
|
23
|
+
activities = plus.list_activities('103354693083460731603', 'public', page_token: next_page)
|
24
|
+
activities.items.each do |activity|
|
25
|
+
puts "#{activity.published} #{activity.title}"
|
26
|
+
end
|
27
|
+
next_page = activities.next_page_token
|
28
|
+
end while next_page
|
29
|
+
```
|
data/docs/performance.md
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
# Performance Tips
|
2
|
+
|
3
|
+
This document covers techniques you can use to improve the performance of your application. The documentation for the specific API you are using should have a similar page with more detail on some of these topics. For example, see the Performance Tips page for the Google Drive API.
|
4
|
+
|
5
|
+
## Partial response (fields parameter)
|
6
|
+
|
7
|
+
By default, the server sends back the full representation of a resource after processing requests. For better performance, you can ask the server to send only the fields you really need and get a partial response instead.
|
8
|
+
|
9
|
+
To request a partial response, add the standard fields parameter to any API method. The value of this parameter specifies the fields you want returned. You can use this parameter with any request that returns response data.
|
10
|
+
|
11
|
+
In the following code snippet, the list_stamps method of a fictitious Stamps API is called. The cents parameter is defined by the API to only return stamps with the given value. The value of the fields parameter is set to 'count,items/name'code>. The response will only contain stamps whose value is 5 cents, and the data returned will only include the number of stamps found along with the stamp names:
|
12
|
+
|
13
|
+
`response = service.list_stamps(cents: 5, fields: 'count,items/name')`
|
14
|
+
|
15
|
+
Note how commas are used to delimit the desired fields, and slashes are used to indicate fields that are contained in parent fields. There are other formatting options for the fields parameter, and you should see the "Performance Tips" page in the documentation for the API you are using.
|
16
|
+
|
17
|
+
## Partial update (patch)
|
18
|
+
|
19
|
+
If the API you are calling supports patch, you can avoid sending unnecessary data when modifying resources. For these APIs, you can call the patch() method and supply the arguments you wish to modify for the resource. If supported, the API's reference will have documentation for the patch() method.
|
20
|
+
|
21
|
+
For more information about patch semantics, see the "Performance Tips" page in the documentation for the API you are using.
|
22
|
+
|
23
|
+
## Batch
|
24
|
+
|
25
|
+
If you are sending many small requests you may benefit from batching, which allows those requests to be bundled into a single HTTP request.
|
@@ -27,7 +27,7 @@ module Google
|
|
27
27
|
# @see https://developers.google.com/authorized-buyers/apis/reference/rest/
|
28
28
|
module Adexchangebuyer2V2beta1
|
29
29
|
VERSION = 'V2beta1'
|
30
|
-
REVISION = '
|
30
|
+
REVISION = '20191111'
|
31
31
|
|
32
32
|
# Manage your Ad Exchange buyer account configuration
|
33
33
|
AUTH_ADEXCHANGE_BUYER = 'https://www.googleapis.com/auth/adexchange.buyer'
|
@@ -26,7 +26,7 @@ module Google
|
|
26
26
|
# @see https://developers.google.com/ad-exchange/buyer-rest
|
27
27
|
module AdexchangebuyerV1_3
|
28
28
|
VERSION = 'V1_3'
|
29
|
-
REVISION = '
|
29
|
+
REVISION = '20191108'
|
30
30
|
|
31
31
|
# Manage your Ad Exchange buyer account configuration
|
32
32
|
AUTH_ADEXCHANGE_BUYER = 'https://www.googleapis.com/auth/adexchange.buyer'
|
@@ -1193,6 +1193,14 @@ module Google
|
|
1193
1193
|
# @return [Array<String>]
|
1194
1194
|
attr_accessor :languages
|
1195
1195
|
|
1196
|
+
# The maximum QPS allocated to this pretargeting configuration, used for
|
1197
|
+
# pretargeting-level QPS limits. By default, this is not set, which indicates
|
1198
|
+
# that there is no QPS limit at the configuration level (a global or account-
|
1199
|
+
# level limit may still be imposed).
|
1200
|
+
# Corresponds to the JSON property `maximumQps`
|
1201
|
+
# @return [Fixnum]
|
1202
|
+
attr_accessor :maximum_qps
|
1203
|
+
|
1196
1204
|
# Requests containing any of these mobile carrier ids will match. Values are
|
1197
1205
|
# from mobile-carriers.csv in the downloadable files section.
|
1198
1206
|
# Corresponds to the JSON property `mobileCarriers`
|
@@ -1266,6 +1274,7 @@ module Google
|
|
1266
1274
|
@is_active = args[:is_active] if args.key?(:is_active)
|
1267
1275
|
@kind = args[:kind] if args.key?(:kind)
|
1268
1276
|
@languages = args[:languages] if args.key?(:languages)
|
1277
|
+
@maximum_qps = args[:maximum_qps] if args.key?(:maximum_qps)
|
1269
1278
|
@mobile_carriers = args[:mobile_carriers] if args.key?(:mobile_carriers)
|
1270
1279
|
@mobile_devices = args[:mobile_devices] if args.key?(:mobile_devices)
|
1271
1280
|
@mobile_operating_system_versions = args[:mobile_operating_system_versions] if args.key?(:mobile_operating_system_versions)
|
@@ -463,6 +463,7 @@ module Google
|
|
463
463
|
property :is_active, as: 'isActive'
|
464
464
|
property :kind, as: 'kind'
|
465
465
|
collection :languages, as: 'languages'
|
466
|
+
property :maximum_qps, :numeric_string => true, as: 'maximumQps'
|
466
467
|
collection :mobile_carriers, as: 'mobileCarriers'
|
467
468
|
collection :mobile_devices, as: 'mobileDevices'
|
468
469
|
collection :mobile_operating_system_versions, as: 'mobileOperatingSystemVersions'
|
@@ -26,7 +26,7 @@ module Google
|
|
26
26
|
# @see https://developers.google.com/ad-exchange/buyer-rest
|
27
27
|
module AdexchangebuyerV1_4
|
28
28
|
VERSION = 'V1_4'
|
29
|
-
REVISION = '
|
29
|
+
REVISION = '20191108'
|
30
30
|
|
31
31
|
# Manage your Ad Exchange buyer account configuration
|
32
32
|
AUTH_ADEXCHANGE_BUYER = 'https://www.googleapis.com/auth/adexchange.buyer'
|
@@ -2497,6 +2497,14 @@ module Google
|
|
2497
2497
|
# @return [Array<String>]
|
2498
2498
|
attr_accessor :languages
|
2499
2499
|
|
2500
|
+
# The maximum QPS allocated to this pretargeting configuration, used for
|
2501
|
+
# pretargeting-level QPS limits. By default, this is not set, which indicates
|
2502
|
+
# that there is no QPS limit at the configuration level (a global or account-
|
2503
|
+
# level limit may still be imposed).
|
2504
|
+
# Corresponds to the JSON property `maximumQps`
|
2505
|
+
# @return [Fixnum]
|
2506
|
+
attr_accessor :maximum_qps
|
2507
|
+
|
2500
2508
|
# Requests where the predicted viewability is below the specified decile will
|
2501
2509
|
# not match. E.g. if the buyer sets this value to 5, requests from slots where
|
2502
2510
|
# the predicted viewability is below 50% will not match. If the predicted
|
@@ -2591,6 +2599,7 @@ module Google
|
|
2591
2599
|
@is_active = args[:is_active] if args.key?(:is_active)
|
2592
2600
|
@kind = args[:kind] if args.key?(:kind)
|
2593
2601
|
@languages = args[:languages] if args.key?(:languages)
|
2602
|
+
@maximum_qps = args[:maximum_qps] if args.key?(:maximum_qps)
|
2594
2603
|
@minimum_viewability_decile = args[:minimum_viewability_decile] if args.key?(:minimum_viewability_decile)
|
2595
2604
|
@mobile_carriers = args[:mobile_carriers] if args.key?(:mobile_carriers)
|
2596
2605
|
@mobile_devices = args[:mobile_devices] if args.key?(:mobile_devices)
|
@@ -1165,6 +1165,7 @@ module Google
|
|
1165
1165
|
property :is_active, as: 'isActive'
|
1166
1166
|
property :kind, as: 'kind'
|
1167
1167
|
collection :languages, as: 'languages'
|
1168
|
+
property :maximum_qps, :numeric_string => true, as: 'maximumQps'
|
1168
1169
|
property :minimum_viewability_decile, as: 'minimumViewabilityDecile'
|
1169
1170
|
collection :mobile_carriers, as: 'mobileCarriers'
|
1170
1171
|
collection :mobile_devices, as: 'mobileDevices'
|
@@ -26,7 +26,7 @@ module Google
|
|
26
26
|
# @see https://developers.google.com/android/management
|
27
27
|
module AndroidmanagementV1
|
28
28
|
VERSION = 'V1'
|
29
|
-
REVISION = '
|
29
|
+
REVISION = '20191113'
|
30
30
|
|
31
31
|
# Manage Android devices and apps for your customers
|
32
32
|
AUTH_ANDROIDMANAGEMENT = 'https://www.googleapis.com/auth/androidmanagement'
|
@@ -25,7 +25,7 @@ module Google
|
|
25
25
|
# @see https://developers.google.com/android-publisher
|
26
26
|
module AndroidpublisherV3
|
27
27
|
VERSION = 'V3'
|
28
|
-
REVISION = '
|
28
|
+
REVISION = '20191113'
|
29
29
|
|
30
30
|
# View and manage your Google Play Developer account
|
31
31
|
AUTH_ANDROIDPUBLISHER = 'https://www.googleapis.com/auth/androidpublisher'
|
@@ -293,6 +293,31 @@ module Google
|
|
293
293
|
end
|
294
294
|
end
|
295
295
|
|
296
|
+
#
|
297
|
+
class Control
|
298
|
+
include Google::Apis::Core::Hashable
|
299
|
+
|
300
|
+
#
|
301
|
+
# Corresponds to the JSON property `modRanges`
|
302
|
+
# @return [Array<Google::Apis::AndroidpublisherV3::ModRange>]
|
303
|
+
attr_accessor :mod_ranges
|
304
|
+
|
305
|
+
#
|
306
|
+
# Corresponds to the JSON property `versionCodes`
|
307
|
+
# @return [Array<Fixnum>]
|
308
|
+
attr_accessor :version_codes
|
309
|
+
|
310
|
+
def initialize(**args)
|
311
|
+
update!(**args)
|
312
|
+
end
|
313
|
+
|
314
|
+
# Update properties of this object
|
315
|
+
def update!(**args)
|
316
|
+
@mod_ranges = args[:mod_ranges] if args.key?(:mod_ranges)
|
317
|
+
@version_codes = args[:version_codes] if args.key?(:version_codes)
|
318
|
+
end
|
319
|
+
end
|
320
|
+
|
296
321
|
#
|
297
322
|
class CountryTargeting
|
298
323
|
include Google::Apis::Core::Hashable
|
@@ -1067,6 +1092,62 @@ module Google
|
|
1067
1092
|
end
|
1068
1093
|
end
|
1069
1094
|
|
1095
|
+
#
|
1096
|
+
class MendelSampling
|
1097
|
+
include Google::Apis::Core::Hashable
|
1098
|
+
|
1099
|
+
#
|
1100
|
+
# Corresponds to the JSON property `modRanges`
|
1101
|
+
# @return [Array<Google::Apis::AndroidpublisherV3::ModRange>]
|
1102
|
+
attr_accessor :mod_ranges
|
1103
|
+
|
1104
|
+
#
|
1105
|
+
# Corresponds to the JSON property `modulus`
|
1106
|
+
# @return [Fixnum]
|
1107
|
+
attr_accessor :modulus
|
1108
|
+
|
1109
|
+
#
|
1110
|
+
# Corresponds to the JSON property `salt`
|
1111
|
+
# @return [Fixnum]
|
1112
|
+
attr_accessor :salt
|
1113
|
+
|
1114
|
+
def initialize(**args)
|
1115
|
+
update!(**args)
|
1116
|
+
end
|
1117
|
+
|
1118
|
+
# Update properties of this object
|
1119
|
+
def update!(**args)
|
1120
|
+
@mod_ranges = args[:mod_ranges] if args.key?(:mod_ranges)
|
1121
|
+
@modulus = args[:modulus] if args.key?(:modulus)
|
1122
|
+
@salt = args[:salt] if args.key?(:salt)
|
1123
|
+
end
|
1124
|
+
end
|
1125
|
+
|
1126
|
+
#
|
1127
|
+
class ModRange
|
1128
|
+
include Google::Apis::Core::Hashable
|
1129
|
+
|
1130
|
+
#
|
1131
|
+
# Corresponds to the JSON property `end`
|
1132
|
+
# @return [Fixnum]
|
1133
|
+
attr_accessor :end
|
1134
|
+
|
1135
|
+
#
|
1136
|
+
# Corresponds to the JSON property `start`
|
1137
|
+
# @return [Fixnum]
|
1138
|
+
attr_accessor :start
|
1139
|
+
|
1140
|
+
def initialize(**args)
|
1141
|
+
update!(**args)
|
1142
|
+
end
|
1143
|
+
|
1144
|
+
# Update properties of this object
|
1145
|
+
def update!(**args)
|
1146
|
+
@end = args[:end] if args.key?(:end)
|
1147
|
+
@start = args[:start] if args.key?(:start)
|
1148
|
+
end
|
1149
|
+
end
|
1150
|
+
|
1070
1151
|
#
|
1071
1152
|
class MonthDay
|
1072
1153
|
include Google::Apis::Core::Hashable
|
@@ -1902,6 +1983,11 @@ module Google
|
|
1902
1983
|
class TrackRelease
|
1903
1984
|
include Google::Apis::Core::Hashable
|
1904
1985
|
|
1986
|
+
#
|
1987
|
+
# Corresponds to the JSON property `controls`
|
1988
|
+
# @return [Array<Google::Apis::AndroidpublisherV3::Control>]
|
1989
|
+
attr_accessor :controls
|
1990
|
+
|
1905
1991
|
#
|
1906
1992
|
# Corresponds to the JSON property `countryTargeting`
|
1907
1993
|
# @return [Google::Apis::AndroidpublisherV3::CountryTargeting]
|
@@ -1919,6 +2005,11 @@ module Google
|
|
1919
2005
|
# @return [Array<Google::Apis::AndroidpublisherV3::LocalizedText>]
|
1920
2006
|
attr_accessor :release_notes
|
1921
2007
|
|
2008
|
+
#
|
2009
|
+
# Corresponds to the JSON property `sampling`
|
2010
|
+
# @return [Google::Apis::AndroidpublisherV3::MendelSampling]
|
2011
|
+
attr_accessor :sampling
|
2012
|
+
|
1922
2013
|
# The desired status of this release.
|
1923
2014
|
# Corresponds to the JSON property `status`
|
1924
2015
|
# @return [String]
|
@@ -1944,9 +2035,11 @@ module Google
|
|
1944
2035
|
|
1945
2036
|
# Update properties of this object
|
1946
2037
|
def update!(**args)
|
2038
|
+
@controls = args[:controls] if args.key?(:controls)
|
1947
2039
|
@country_targeting = args[:country_targeting] if args.key?(:country_targeting)
|
1948
2040
|
@name = args[:name] if args.key?(:name)
|
1949
2041
|
@release_notes = args[:release_notes] if args.key?(:release_notes)
|
2042
|
+
@sampling = args[:sampling] if args.key?(:sampling)
|
1950
2043
|
@status = args[:status] if args.key?(:status)
|
1951
2044
|
@user_fraction = args[:user_fraction] if args.key?(:user_fraction)
|
1952
2045
|
@version_codes = args[:version_codes] if args.key?(:version_codes)
|