google-api-client 0.32.1 → 0.36.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (491) hide show
  1. checksums.yaml +5 -5
  2. data/.kokoro/continuous/linux.cfg +2 -2
  3. data/.kokoro/continuous/post.cfg +30 -0
  4. data/.kokoro/presubmit/linux.cfg +1 -1
  5. data/.kokoro/release.cfg +94 -0
  6. data/.repo-metadata.json +5 -0
  7. data/.rubocop.yml +5 -0
  8. data/.yardopts +16 -3
  9. data/CHANGELOG.md +327 -0
  10. data/Gemfile +1 -0
  11. data/OVERVIEW.md +36 -0
  12. data/README.md +50 -2
  13. data/Rakefile +71 -2
  14. data/docs/api-keys.md +20 -0
  15. data/docs/auth.md +53 -0
  16. data/docs/client-secrets.md +69 -0
  17. data/docs/getting-started.md +340 -0
  18. data/docs/installation.md +0 -0
  19. data/docs/logging.md +34 -0
  20. data/docs/media-upload.md +25 -0
  21. data/docs/oauth-installed.md +191 -0
  22. data/docs/oauth-server.md +135 -0
  23. data/docs/oauth-web.md +280 -0
  24. data/docs/oauth.md +268 -0
  25. data/docs/pagination.md +29 -0
  26. data/docs/performance.md +25 -0
  27. data/generated/google/apis/accessapproval_v1beta1/classes.rb +35 -2
  28. data/generated/google/apis/accessapproval_v1beta1/representations.rb +13 -0
  29. data/generated/google/apis/accessapproval_v1beta1/service.rb +108 -6
  30. data/generated/google/apis/accessapproval_v1beta1.rb +1 -1
  31. data/generated/google/apis/accesscontextmanager_v1/classes.rb +1 -1
  32. data/generated/google/apis/accesscontextmanager_v1.rb +1 -1
  33. data/generated/google/apis/accesscontextmanager_v1beta/classes.rb +1 -73
  34. data/generated/google/apis/accesscontextmanager_v1beta/representations.rb +0 -32
  35. data/generated/google/apis/accesscontextmanager_v1beta.rb +1 -1
  36. data/generated/google/apis/adexchangebuyer2_v2beta1.rb +1 -1
  37. data/generated/google/apis/adexchangebuyer_v1_3/classes.rb +24 -2
  38. data/generated/google/apis/adexchangebuyer_v1_3/representations.rb +1 -0
  39. data/generated/google/apis/adexchangebuyer_v1_3.rb +1 -1
  40. data/generated/google/apis/adexchangebuyer_v1_4/classes.rb +25 -3
  41. data/generated/google/apis/adexchangebuyer_v1_4/representations.rb +1 -0
  42. data/generated/google/apis/adexchangebuyer_v1_4.rb +1 -1
  43. data/generated/google/apis/admin_datatransfer_v1/classes.rb +5 -5
  44. data/generated/google/apis/admin_datatransfer_v1/service.rb +2 -2
  45. data/generated/google/apis/admin_datatransfer_v1.rb +1 -1
  46. data/generated/google/apis/admin_directory_v1/classes.rb +4 -3
  47. data/generated/google/apis/admin_directory_v1.rb +4 -1
  48. data/generated/google/apis/admin_reports_v1/classes.rb +87 -44
  49. data/generated/google/apis/admin_reports_v1/service.rb +310 -64
  50. data/generated/google/apis/admin_reports_v1.rb +2 -2
  51. data/generated/google/apis/androidmanagement_v1.rb +1 -1
  52. data/generated/google/apis/androidpublisher_v3/classes.rb +105 -0
  53. data/generated/google/apis/androidpublisher_v3/representations.rb +51 -0
  54. data/generated/google/apis/androidpublisher_v3.rb +1 -1
  55. data/generated/google/apis/appengine_v1/service.rb +10 -6
  56. data/generated/google/apis/appengine_v1.rb +1 -1
  57. data/generated/google/apis/appengine_v1beta/service.rb +10 -6
  58. data/generated/google/apis/appengine_v1beta.rb +1 -1
  59. data/generated/google/apis/appsmarket_v2.rb +1 -1
  60. data/generated/google/apis/bigquery_v2/classes.rb +104 -23
  61. data/generated/google/apis/bigquery_v2/representations.rb +37 -0
  62. data/generated/google/apis/bigquery_v2/service.rb +1 -5
  63. data/generated/google/apis/bigquery_v2.rb +1 -1
  64. data/generated/google/apis/bigqueryconnection_v1beta1/classes.rb +6 -5
  65. data/generated/google/apis/bigqueryconnection_v1beta1/service.rb +3 -2
  66. data/generated/google/apis/bigqueryconnection_v1beta1.rb +1 -1
  67. data/generated/google/apis/bigquerydatatransfer_v1/service.rb +30 -4
  68. data/generated/google/apis/bigquerydatatransfer_v1.rb +1 -1
  69. data/generated/google/apis/bigqueryreservation_v1/classes.rb +0 -21
  70. data/generated/google/apis/bigqueryreservation_v1/representations.rb +0 -13
  71. data/generated/google/apis/bigqueryreservation_v1.rb +1 -1
  72. data/generated/google/apis/bigqueryreservation_v1alpha2/classes.rb +116 -1
  73. data/generated/google/apis/bigqueryreservation_v1alpha2/representations.rb +35 -0
  74. data/generated/google/apis/bigqueryreservation_v1alpha2/service.rb +71 -0
  75. data/generated/google/apis/bigqueryreservation_v1alpha2.rb +1 -1
  76. data/generated/google/apis/bigqueryreservation_v1beta1/classes.rb +61 -77
  77. data/generated/google/apis/bigqueryreservation_v1beta1/representations.rb +16 -17
  78. data/generated/google/apis/bigqueryreservation_v1beta1/service.rb +116 -78
  79. data/generated/google/apis/bigqueryreservation_v1beta1.rb +1 -1
  80. data/generated/google/apis/bigtableadmin_v1/classes.rb +1 -1
  81. data/generated/google/apis/bigtableadmin_v1.rb +1 -1
  82. data/generated/google/apis/bigtableadmin_v2/classes.rb +63 -30
  83. data/generated/google/apis/bigtableadmin_v2/service.rb +1 -1
  84. data/generated/google/apis/bigtableadmin_v2.rb +1 -1
  85. data/generated/google/apis/billingbudgets_v1beta1/classes.rb +392 -0
  86. data/generated/google/apis/billingbudgets_v1beta1/representations.rb +191 -0
  87. data/generated/google/apis/billingbudgets_v1beta1/service.rb +233 -0
  88. data/generated/google/apis/billingbudgets_v1beta1.rb +35 -0
  89. data/generated/google/apis/binaryauthorization_v1/classes.rb +6 -5
  90. data/generated/google/apis/binaryauthorization_v1/service.rb +2 -0
  91. data/generated/google/apis/binaryauthorization_v1.rb +1 -1
  92. data/generated/google/apis/binaryauthorization_v1beta1/classes.rb +6 -5
  93. data/generated/google/apis/binaryauthorization_v1beta1/service.rb +2 -0
  94. data/generated/google/apis/binaryauthorization_v1beta1.rb +1 -1
  95. data/generated/google/apis/books_v1/classes.rb +20 -0
  96. data/generated/google/apis/books_v1/representations.rb +3 -0
  97. data/generated/google/apis/books_v1.rb +1 -1
  98. data/generated/google/apis/calendar_v3/classes.rb +1 -1
  99. data/generated/google/apis/calendar_v3/service.rb +18 -30
  100. data/generated/google/apis/calendar_v3.rb +1 -1
  101. data/generated/google/apis/civicinfo_v2/classes.rb +0 -156
  102. data/generated/google/apis/civicinfo_v2/representations.rb +2 -60
  103. data/generated/google/apis/civicinfo_v2.rb +1 -1
  104. data/generated/google/apis/cloudasset_v1/classes.rb +89 -55
  105. data/generated/google/apis/cloudasset_v1/service.rb +1 -2
  106. data/generated/google/apis/cloudasset_v1.rb +1 -1
  107. data/generated/google/apis/cloudasset_v1beta1/classes.rb +75 -40
  108. data/generated/google/apis/cloudasset_v1beta1.rb +1 -1
  109. data/generated/google/apis/cloudbilling_v1/classes.rb +82 -36
  110. data/generated/google/apis/cloudbilling_v1/representations.rb +0 -1
  111. data/generated/google/apis/cloudbilling_v1/service.rb +5 -3
  112. data/generated/google/apis/cloudbilling_v1.rb +1 -1
  113. data/generated/google/apis/cloudbuild_v1/classes.rb +8 -2
  114. data/generated/google/apis/cloudbuild_v1/representations.rb +1 -0
  115. data/generated/google/apis/cloudbuild_v1/service.rb +18 -18
  116. data/generated/google/apis/cloudbuild_v1.rb +1 -1
  117. data/generated/google/apis/clouddebugger_v2/service.rb +14 -14
  118. data/generated/google/apis/clouddebugger_v2.rb +1 -1
  119. data/generated/google/apis/cloudfunctions_v1/classes.rb +13 -5
  120. data/generated/google/apis/cloudfunctions_v1/representations.rb +1 -0
  121. data/generated/google/apis/cloudfunctions_v1/service.rb +10 -4
  122. data/generated/google/apis/cloudfunctions_v1.rb +1 -1
  123. data/generated/google/apis/cloudfunctions_v1beta2/classes.rb +7 -0
  124. data/generated/google/apis/cloudfunctions_v1beta2/representations.rb +1 -0
  125. data/generated/google/apis/cloudfunctions_v1beta2/service.rb +10 -4
  126. data/generated/google/apis/cloudfunctions_v1beta2.rb +1 -1
  127. data/generated/google/apis/cloudidentity_v1/classes.rb +11 -8
  128. data/generated/google/apis/cloudidentity_v1/service.rb +2 -1
  129. data/generated/google/apis/cloudidentity_v1.rb +1 -1
  130. data/generated/google/apis/cloudidentity_v1beta1/classes.rb +13 -10
  131. data/generated/google/apis/cloudidentity_v1beta1/service.rb +2 -1
  132. data/generated/google/apis/cloudidentity_v1beta1.rb +1 -1
  133. data/generated/google/apis/cloudiot_v1/classes.rb +6 -5
  134. data/generated/google/apis/cloudiot_v1.rb +1 -1
  135. data/generated/google/apis/cloudkms_v1/classes.rb +6 -5
  136. data/generated/google/apis/cloudkms_v1/service.rb +3 -0
  137. data/generated/google/apis/cloudkms_v1.rb +1 -1
  138. data/generated/google/apis/cloudprivatecatalogproducer_v1beta1/classes.rb +75 -40
  139. data/generated/google/apis/cloudprivatecatalogproducer_v1beta1.rb +1 -1
  140. data/generated/google/apis/cloudresourcemanager_v1/classes.rb +18 -17
  141. data/generated/google/apis/cloudresourcemanager_v1.rb +1 -1
  142. data/generated/google/apis/cloudresourcemanager_v1beta1/classes.rb +6 -5
  143. data/generated/google/apis/cloudresourcemanager_v1beta1.rb +1 -1
  144. data/generated/google/apis/cloudresourcemanager_v2/classes.rb +10 -13
  145. data/generated/google/apis/cloudresourcemanager_v2/service.rb +11 -13
  146. data/generated/google/apis/cloudresourcemanager_v2.rb +1 -1
  147. data/generated/google/apis/cloudresourcemanager_v2beta1/classes.rb +10 -13
  148. data/generated/google/apis/cloudresourcemanager_v2beta1/service.rb +11 -13
  149. data/generated/google/apis/cloudresourcemanager_v2beta1.rb +1 -1
  150. data/generated/google/apis/cloudscheduler_v1/classes.rb +2 -1
  151. data/generated/google/apis/cloudscheduler_v1.rb +1 -1
  152. data/generated/google/apis/cloudscheduler_v1beta1/classes.rb +2 -1
  153. data/generated/google/apis/cloudscheduler_v1beta1.rb +1 -1
  154. data/generated/google/apis/cloudsearch_v1/classes.rb +10 -132
  155. data/generated/google/apis/cloudsearch_v1/representations.rb +0 -75
  156. data/generated/google/apis/cloudsearch_v1/service.rb +47 -9
  157. data/generated/google/apis/cloudsearch_v1.rb +8 -8
  158. data/generated/google/apis/cloudshell_v1/classes.rb +24 -1
  159. data/generated/google/apis/cloudshell_v1/representations.rb +3 -0
  160. data/generated/google/apis/cloudshell_v1.rb +1 -1
  161. data/generated/google/apis/cloudshell_v1alpha1/classes.rb +24 -1
  162. data/generated/google/apis/cloudshell_v1alpha1/representations.rb +3 -0
  163. data/generated/google/apis/cloudshell_v1alpha1.rb +1 -1
  164. data/generated/google/apis/cloudtasks_v2/classes.rb +212 -5
  165. data/generated/google/apis/cloudtasks_v2/representations.rb +50 -0
  166. data/generated/google/apis/cloudtasks_v2.rb +1 -1
  167. data/generated/google/apis/cloudtasks_v2beta2/classes.rb +6 -5
  168. data/generated/google/apis/cloudtasks_v2beta2.rb +1 -1
  169. data/generated/google/apis/cloudtasks_v2beta3/classes.rb +6 -5
  170. data/generated/google/apis/cloudtasks_v2beta3.rb +1 -1
  171. data/generated/google/apis/commentanalyzer_v1alpha1/classes.rb +14 -19
  172. data/generated/google/apis/commentanalyzer_v1alpha1.rb +1 -1
  173. data/generated/google/apis/compute_alpha/classes.rb +594 -164
  174. data/generated/google/apis/compute_alpha/representations.rb +110 -2
  175. data/generated/google/apis/compute_alpha/service.rb +1035 -640
  176. data/generated/google/apis/compute_alpha.rb +1 -1
  177. data/generated/google/apis/compute_beta/classes.rb +1070 -276
  178. data/generated/google/apis/compute_beta/representations.rb +284 -0
  179. data/generated/google/apis/compute_beta/service.rb +1242 -532
  180. data/generated/google/apis/compute_beta.rb +1 -1
  181. data/generated/google/apis/compute_v1/classes.rb +335 -133
  182. data/generated/google/apis/compute_v1/representations.rb +24 -0
  183. data/generated/google/apis/compute_v1/service.rb +759 -473
  184. data/generated/google/apis/compute_v1.rb +1 -1
  185. data/generated/google/apis/container_v1/classes.rb +410 -83
  186. data/generated/google/apis/container_v1/representations.rb +134 -0
  187. data/generated/google/apis/container_v1/service.rb +119 -119
  188. data/generated/google/apis/container_v1.rb +1 -1
  189. data/generated/google/apis/container_v1beta1/classes.rb +157 -3
  190. data/generated/google/apis/container_v1beta1/representations.rb +38 -0
  191. data/generated/google/apis/container_v1beta1.rb +1 -1
  192. data/generated/google/apis/containeranalysis_v1alpha1/classes.rb +6 -5
  193. data/generated/google/apis/containeranalysis_v1alpha1.rb +1 -1
  194. data/generated/google/apis/containeranalysis_v1beta1/classes.rb +6 -5
  195. data/generated/google/apis/containeranalysis_v1beta1.rb +1 -1
  196. data/generated/google/apis/content_v2/classes.rb +35 -223
  197. data/generated/google/apis/content_v2/representations.rb +0 -115
  198. data/generated/google/apis/content_v2/service.rb +0 -160
  199. data/generated/google/apis/content_v2.rb +1 -1
  200. data/generated/google/apis/content_v2_1/classes.rb +69 -21
  201. data/generated/google/apis/content_v2_1/representations.rb +3 -0
  202. data/generated/google/apis/content_v2_1.rb +1 -1
  203. data/generated/google/apis/datacatalog_v1beta1/classes.rb +1646 -0
  204. data/generated/google/apis/datacatalog_v1beta1/representations.rb +700 -0
  205. data/generated/google/apis/datacatalog_v1beta1/service.rb +1982 -0
  206. data/generated/google/apis/{cloudbuild_v1alpha1.rb → datacatalog_v1beta1.rb} +10 -9
  207. data/generated/google/apis/dataflow_v1b3/classes.rb +6 -9
  208. data/generated/google/apis/dataflow_v1b3/representations.rb +1 -1
  209. data/generated/google/apis/dataflow_v1b3.rb +1 -1
  210. data/generated/google/apis/datafusion_v1beta1/classes.rb +156 -46
  211. data/generated/google/apis/datafusion_v1beta1/representations.rb +33 -0
  212. data/generated/google/apis/datafusion_v1beta1/service.rb +10 -1
  213. data/generated/google/apis/datafusion_v1beta1.rb +1 -1
  214. data/generated/google/apis/dataproc_v1/classes.rb +119 -11
  215. data/generated/google/apis/dataproc_v1/representations.rb +39 -0
  216. data/generated/google/apis/dataproc_v1/service.rb +14 -7
  217. data/generated/google/apis/dataproc_v1.rb +1 -1
  218. data/generated/google/apis/dataproc_v1beta2/classes.rb +9 -11
  219. data/generated/google/apis/dataproc_v1beta2/service.rb +26 -19
  220. data/generated/google/apis/dataproc_v1beta2.rb +1 -1
  221. data/generated/google/apis/datastore_v1/service.rb +85 -1
  222. data/generated/google/apis/datastore_v1.rb +1 -1
  223. data/generated/google/apis/datastore_v1beta3/service.rb +1 -1
  224. data/generated/google/apis/datastore_v1beta3.rb +1 -1
  225. data/generated/google/apis/dfareporting_v3_3/classes.rb +21 -1
  226. data/generated/google/apis/dfareporting_v3_3/service.rb +6 -6
  227. data/generated/google/apis/dfareporting_v3_3.rb +1 -1
  228. data/generated/google/apis/{dfareporting_v3_2 → dfareporting_v3_4}/classes.rb +1215 -797
  229. data/generated/google/apis/{dfareporting_v3_2 → dfareporting_v3_4}/representations.rb +593 -395
  230. data/generated/google/apis/{dfareporting_v3_2 → dfareporting_v3_4}/service.rb +966 -1074
  231. data/generated/google/apis/{dfareporting_v3_2.rb → dfareporting_v3_4.rb} +6 -6
  232. data/generated/google/apis/dialogflow_v2/classes.rb +509 -8
  233. data/generated/google/apis/dialogflow_v2/representations.rb +222 -0
  234. data/generated/google/apis/dialogflow_v2.rb +1 -1
  235. data/generated/google/apis/dialogflow_v2beta1/classes.rb +530 -8
  236. data/generated/google/apis/dialogflow_v2beta1/representations.rb +224 -0
  237. data/generated/google/apis/dialogflow_v2beta1.rb +1 -1
  238. data/generated/google/apis/dlp_v2/classes.rb +109 -33
  239. data/generated/google/apis/dlp_v2/representations.rb +23 -3
  240. data/generated/google/apis/dlp_v2/service.rb +1996 -209
  241. data/generated/google/apis/dlp_v2.rb +1 -1
  242. data/generated/google/apis/dns_v1beta2/classes.rb +47 -0
  243. data/generated/google/apis/dns_v1beta2/representations.rb +17 -0
  244. data/generated/google/apis/dns_v1beta2.rb +1 -1
  245. data/generated/google/apis/docs_v1/classes.rb +175 -0
  246. data/generated/google/apis/docs_v1/representations.rb +77 -0
  247. data/generated/google/apis/docs_v1.rb +1 -1
  248. data/generated/google/apis/doubleclickbidmanager_v1.rb +1 -1
  249. data/generated/google/apis/doubleclickbidmanager_v1_1/classes.rb +826 -0
  250. data/generated/google/apis/doubleclickbidmanager_v1_1/representations.rb +372 -0
  251. data/generated/google/apis/doubleclickbidmanager_v1_1/service.rb +371 -0
  252. data/generated/google/apis/{urlshortener_v1.rb → doubleclickbidmanager_v1_1.rb} +11 -11
  253. data/generated/google/apis/drive_v2/classes.rb +2 -1
  254. data/generated/google/apis/drive_v2/service.rb +3 -3
  255. data/generated/google/apis/drive_v2.rb +1 -1
  256. data/generated/google/apis/drive_v3/classes.rb +12 -3
  257. data/generated/google/apis/drive_v3.rb +1 -1
  258. data/generated/google/apis/fcm_v1/classes.rb +15 -0
  259. data/generated/google/apis/fcm_v1/representations.rb +2 -0
  260. data/generated/google/apis/fcm_v1.rb +1 -1
  261. data/generated/google/apis/firebase_v1beta1/classes.rb +18 -4
  262. data/generated/google/apis/firebase_v1beta1/representations.rb +2 -0
  263. data/generated/google/apis/firebase_v1beta1/service.rb +6 -6
  264. data/generated/google/apis/firebase_v1beta1.rb +1 -1
  265. data/generated/google/apis/firebasehosting_v1beta1/classes.rb +62 -0
  266. data/generated/google/apis/firebasehosting_v1beta1/representations.rb +31 -0
  267. data/generated/google/apis/firebasehosting_v1beta1/service.rb +47 -0
  268. data/generated/google/apis/firebasehosting_v1beta1.rb +1 -1
  269. data/generated/google/apis/firebaserules_v1/classes.rb +26 -0
  270. data/generated/google/apis/firebaserules_v1/representations.rb +15 -0
  271. data/generated/google/apis/firebaserules_v1.rb +1 -1
  272. data/generated/google/apis/firestore_v1.rb +1 -1
  273. data/generated/google/apis/firestore_v1beta1.rb +1 -1
  274. data/generated/google/apis/fitness_v1/service.rb +1 -1
  275. data/generated/google/apis/fitness_v1.rb +1 -1
  276. data/generated/google/apis/games_management_v1management/classes.rb +6 -26
  277. data/generated/google/apis/games_management_v1management/representations.rb +1 -14
  278. data/generated/google/apis/games_management_v1management/service.rb +0 -158
  279. data/generated/google/apis/games_management_v1management.rb +1 -1
  280. data/generated/google/apis/games_v1/classes.rb +6 -292
  281. data/generated/google/apis/games_v1/representations.rb +1 -98
  282. data/generated/google/apis/games_v1/service.rb +0 -123
  283. data/generated/google/apis/games_v1.rb +1 -1
  284. data/generated/google/apis/genomics_v2alpha1/classes.rb +32 -0
  285. data/generated/google/apis/genomics_v2alpha1/representations.rb +16 -0
  286. data/generated/google/apis/genomics_v2alpha1.rb +1 -1
  287. data/generated/google/apis/healthcare_v1beta1/classes.rb +213 -16
  288. data/generated/google/apis/healthcare_v1beta1/representations.rb +101 -0
  289. data/generated/google/apis/healthcare_v1beta1/service.rb +207 -116
  290. data/generated/google/apis/healthcare_v1beta1.rb +1 -1
  291. data/generated/google/apis/homegraph_v1/classes.rb +15 -1
  292. data/generated/google/apis/homegraph_v1/representations.rb +2 -1
  293. data/generated/google/apis/homegraph_v1.rb +1 -1
  294. data/generated/google/apis/iam_v1/classes.rb +15 -7
  295. data/generated/google/apis/iam_v1/representations.rb +1 -0
  296. data/generated/google/apis/iam_v1.rb +1 -1
  297. data/generated/google/apis/iap_v1/classes.rb +187 -2
  298. data/generated/google/apis/iap_v1/representations.rb +102 -0
  299. data/generated/google/apis/iap_v1/service.rb +72 -0
  300. data/generated/google/apis/iap_v1.rb +1 -1
  301. data/generated/google/apis/iap_v1beta1/classes.rb +2 -2
  302. data/generated/google/apis/iap_v1beta1.rb +1 -1
  303. data/generated/google/apis/jobs_v2/classes.rb +167 -0
  304. data/generated/google/apis/jobs_v2/representations.rb +40 -0
  305. data/generated/google/apis/jobs_v2.rb +1 -1
  306. data/generated/google/apis/jobs_v3/classes.rb +179 -0
  307. data/generated/google/apis/jobs_v3/representations.rb +41 -0
  308. data/generated/google/apis/jobs_v3.rb +1 -1
  309. data/generated/google/apis/jobs_v3p1beta1/classes.rb +179 -0
  310. data/generated/google/apis/jobs_v3p1beta1/representations.rb +41 -0
  311. data/generated/google/apis/jobs_v3p1beta1.rb +1 -1
  312. data/generated/google/apis/licensing_v1/classes.rb +15 -7
  313. data/generated/google/apis/licensing_v1/service.rb +81 -37
  314. data/generated/google/apis/licensing_v1.rb +4 -4
  315. data/generated/google/apis/lifesciences_v2beta/classes.rb +1329 -0
  316. data/generated/google/apis/lifesciences_v2beta/representations.rb +533 -0
  317. data/generated/google/apis/lifesciences_v2beta/service.rb +303 -0
  318. data/generated/google/apis/lifesciences_v2beta.rb +35 -0
  319. data/generated/google/apis/logging_v2/classes.rb +30 -2
  320. data/generated/google/apis/logging_v2/representations.rb +4 -0
  321. data/generated/google/apis/logging_v2/service.rb +10 -5
  322. data/generated/google/apis/logging_v2.rb +1 -1
  323. data/generated/google/apis/ml_v1/classes.rb +308 -155
  324. data/generated/google/apis/ml_v1/representations.rb +59 -0
  325. data/generated/google/apis/ml_v1/service.rb +44 -3
  326. data/generated/google/apis/ml_v1.rb +2 -2
  327. data/generated/google/apis/monitoring_v1/classes.rb +1153 -0
  328. data/generated/google/apis/monitoring_v1/representations.rb +528 -0
  329. data/generated/google/apis/{cloudbuild_v1alpha1 → monitoring_v1}/service.rb +86 -63
  330. data/generated/google/apis/monitoring_v1.rb +48 -0
  331. data/generated/google/apis/monitoring_v3/classes.rb +836 -60
  332. data/generated/google/apis/monitoring_v3/representations.rb +348 -0
  333. data/generated/google/apis/monitoring_v3/service.rb +384 -2
  334. data/generated/google/apis/monitoring_v3.rb +1 -1
  335. data/generated/google/apis/oslogin_v1/classes.rb +1 -1
  336. data/generated/google/apis/oslogin_v1/service.rb +10 -6
  337. data/generated/google/apis/oslogin_v1.rb +1 -1
  338. data/generated/google/apis/oslogin_v1beta/classes.rb +1 -1
  339. data/generated/google/apis/oslogin_v1beta/service.rb +9 -5
  340. data/generated/google/apis/oslogin_v1beta.rb +1 -1
  341. data/generated/google/apis/pagespeedonline_v5/classes.rb +8 -0
  342. data/generated/google/apis/pagespeedonline_v5/representations.rb +1 -0
  343. data/generated/google/apis/pagespeedonline_v5.rb +1 -1
  344. data/generated/google/apis/people_v1/classes.rb +67 -63
  345. data/generated/google/apis/people_v1/service.rb +53 -44
  346. data/generated/google/apis/people_v1.rb +1 -1
  347. data/generated/google/apis/policytroubleshooter_v1beta/classes.rb +168 -90
  348. data/generated/google/apis/policytroubleshooter_v1beta/service.rb +2 -3
  349. data/generated/google/apis/policytroubleshooter_v1beta.rb +1 -1
  350. data/generated/google/apis/pubsub_v1/classes.rb +8 -6
  351. data/generated/google/apis/pubsub_v1/service.rb +9 -7
  352. data/generated/google/apis/pubsub_v1.rb +1 -1
  353. data/generated/google/apis/pubsub_v1beta2/classes.rb +6 -5
  354. data/generated/google/apis/pubsub_v1beta2/service.rb +2 -0
  355. data/generated/google/apis/pubsub_v1beta2.rb +1 -1
  356. data/generated/google/apis/recommender_v1beta1/classes.rb +1 -1
  357. data/generated/google/apis/recommender_v1beta1/service.rb +10 -8
  358. data/generated/google/apis/recommender_v1beta1.rb +1 -1
  359. data/generated/google/apis/redis_v1/classes.rb +11 -11
  360. data/generated/google/apis/redis_v1/service.rb +5 -5
  361. data/generated/google/apis/redis_v1.rb +1 -1
  362. data/generated/google/apis/redis_v1beta1/classes.rb +11 -11
  363. data/generated/google/apis/redis_v1beta1/service.rb +5 -5
  364. data/generated/google/apis/redis_v1beta1.rb +1 -1
  365. data/generated/google/apis/remotebuildexecution_v1/classes.rb +113 -0
  366. data/generated/google/apis/remotebuildexecution_v1/representations.rb +50 -0
  367. data/generated/google/apis/remotebuildexecution_v1.rb +1 -1
  368. data/generated/google/apis/remotebuildexecution_v1alpha/classes.rb +113 -0
  369. data/generated/google/apis/remotebuildexecution_v1alpha/representations.rb +50 -0
  370. data/generated/google/apis/remotebuildexecution_v1alpha.rb +1 -1
  371. data/generated/google/apis/remotebuildexecution_v2/classes.rb +113 -0
  372. data/generated/google/apis/remotebuildexecution_v2/representations.rb +50 -0
  373. data/generated/google/apis/remotebuildexecution_v2.rb +1 -1
  374. data/generated/google/apis/reseller_v1/service.rb +1 -1
  375. data/generated/google/apis/reseller_v1.rb +1 -1
  376. data/generated/google/apis/run_v1/classes.rb +8 -176
  377. data/generated/google/apis/run_v1/representations.rb +0 -71
  378. data/generated/google/apis/run_v1/service.rb +209 -1125
  379. data/generated/google/apis/run_v1.rb +1 -1
  380. data/generated/google/apis/run_v1alpha1/classes.rb +328 -9
  381. data/generated/google/apis/run_v1alpha1/representations.rb +126 -0
  382. data/generated/google/apis/run_v1alpha1/service.rb +408 -0
  383. data/generated/google/apis/run_v1alpha1.rb +1 -1
  384. data/generated/google/apis/runtimeconfig_v1beta1/classes.rb +75 -40
  385. data/generated/google/apis/runtimeconfig_v1beta1.rb +1 -1
  386. data/generated/google/apis/securitycenter_v1/classes.rb +159 -66
  387. data/generated/google/apis/securitycenter_v1/representations.rb +19 -0
  388. data/generated/google/apis/securitycenter_v1/service.rb +14 -12
  389. data/generated/google/apis/securitycenter_v1.rb +1 -1
  390. data/generated/google/apis/securitycenter_v1beta1/classes.rb +95 -57
  391. data/generated/google/apis/securitycenter_v1beta1/service.rb +14 -12
  392. data/generated/google/apis/securitycenter_v1beta1.rb +1 -1
  393. data/generated/google/apis/servicebroker_v1/classes.rb +75 -40
  394. data/generated/google/apis/servicebroker_v1.rb +1 -1
  395. data/generated/google/apis/servicebroker_v1alpha1/classes.rb +75 -40
  396. data/generated/google/apis/servicebroker_v1alpha1.rb +1 -1
  397. data/generated/google/apis/servicebroker_v1beta1/classes.rb +75 -40
  398. data/generated/google/apis/servicebroker_v1beta1.rb +1 -1
  399. data/generated/google/apis/serviceconsumermanagement_v1/classes.rb +95 -43
  400. data/generated/google/apis/serviceconsumermanagement_v1/representations.rb +30 -0
  401. data/generated/google/apis/serviceconsumermanagement_v1.rb +1 -1
  402. data/generated/google/apis/servicecontrol_v1/classes.rb +8 -12
  403. data/generated/google/apis/servicecontrol_v1/representations.rb +1 -1
  404. data/generated/google/apis/servicecontrol_v1.rb +1 -1
  405. data/generated/google/apis/servicemanagement_v1/classes.rb +142 -91
  406. data/generated/google/apis/servicemanagement_v1/representations.rb +24 -0
  407. data/generated/google/apis/servicemanagement_v1/service.rb +32 -26
  408. data/generated/google/apis/servicemanagement_v1.rb +1 -1
  409. data/generated/google/apis/servicenetworking_v1/classes.rb +181 -54
  410. data/generated/google/apis/servicenetworking_v1/representations.rb +71 -0
  411. data/generated/google/apis/servicenetworking_v1/service.rb +77 -3
  412. data/generated/google/apis/servicenetworking_v1.rb +1 -1
  413. data/generated/google/apis/servicenetworking_v1beta/classes.rb +32 -43
  414. data/generated/google/apis/servicenetworking_v1beta.rb +1 -1
  415. data/generated/google/apis/serviceusage_v1/classes.rb +87 -43
  416. data/generated/google/apis/serviceusage_v1/representations.rb +29 -0
  417. data/generated/google/apis/serviceusage_v1.rb +1 -1
  418. data/generated/google/apis/serviceusage_v1beta1/classes.rb +87 -43
  419. data/generated/google/apis/serviceusage_v1beta1/representations.rb +29 -0
  420. data/generated/google/apis/serviceusage_v1beta1.rb +1 -1
  421. data/generated/google/apis/sheets_v4/classes.rb +1371 -232
  422. data/generated/google/apis/sheets_v4/representations.rb +180 -0
  423. data/generated/google/apis/sheets_v4.rb +1 -1
  424. data/generated/google/apis/spanner_v1/classes.rb +70 -30
  425. data/generated/google/apis/spanner_v1/service.rb +270 -0
  426. data/generated/google/apis/spanner_v1.rb +1 -1
  427. data/generated/google/apis/speech_v1/classes.rb +6 -0
  428. data/generated/google/apis/speech_v1/representations.rb +1 -0
  429. data/generated/google/apis/speech_v1.rb +1 -1
  430. data/generated/google/apis/speech_v1p1beta1/classes.rb +6 -0
  431. data/generated/google/apis/speech_v1p1beta1/representations.rb +1 -0
  432. data/generated/google/apis/speech_v1p1beta1.rb +1 -1
  433. data/generated/google/apis/{speech_v2beta → speech_v2beta1}/classes.rb +9 -8
  434. data/generated/google/apis/{speech_v2beta → speech_v2beta1}/representations.rb +6 -6
  435. data/generated/google/apis/{speech_v2beta → speech_v2beta1}/service.rb +13 -13
  436. data/generated/google/apis/{speech_v2beta.rb → speech_v2beta1.rb} +6 -6
  437. data/generated/google/apis/{sqladmin_v1beta4 → sql_v1beta4}/classes.rb +499 -380
  438. data/generated/google/apis/{sqladmin_v1beta4 → sql_v1beta4}/representations.rb +125 -104
  439. data/generated/google/apis/{sqladmin_v1beta4 → sql_v1beta4}/service.rb +637 -590
  440. data/generated/google/apis/{sqladmin_v1beta4.rb → sql_v1beta4.rb} +7 -8
  441. data/generated/google/apis/storage_v1.rb +1 -1
  442. data/generated/google/apis/storagetransfer_v1.rb +1 -1
  443. data/generated/google/apis/streetviewpublish_v1/classes.rb +1 -1
  444. data/generated/google/apis/streetviewpublish_v1.rb +1 -1
  445. data/generated/google/apis/testing_v1/classes.rb +142 -1
  446. data/generated/google/apis/testing_v1/representations.rb +76 -0
  447. data/generated/google/apis/testing_v1.rb +1 -1
  448. data/generated/google/apis/videointelligence_v1/classes.rb +147 -36
  449. data/generated/google/apis/videointelligence_v1/representations.rb +62 -0
  450. data/generated/google/apis/videointelligence_v1.rb +1 -1
  451. data/generated/google/apis/videointelligence_v1beta2/classes.rb +147 -36
  452. data/generated/google/apis/videointelligence_v1beta2/representations.rb +62 -0
  453. data/generated/google/apis/videointelligence_v1beta2.rb +1 -1
  454. data/generated/google/apis/videointelligence_v1p1beta1/classes.rb +147 -36
  455. data/generated/google/apis/videointelligence_v1p1beta1/representations.rb +62 -0
  456. data/generated/google/apis/videointelligence_v1p1beta1.rb +1 -1
  457. data/generated/google/apis/videointelligence_v1p2beta1/classes.rb +147 -36
  458. data/generated/google/apis/videointelligence_v1p2beta1/representations.rb +62 -0
  459. data/generated/google/apis/videointelligence_v1p2beta1.rb +1 -1
  460. data/generated/google/apis/videointelligence_v1p3beta1/classes.rb +147 -36
  461. data/generated/google/apis/videointelligence_v1p3beta1/representations.rb +62 -0
  462. data/generated/google/apis/videointelligence_v1p3beta1.rb +1 -1
  463. data/generated/google/apis/vision_v1/classes.rb +66 -0
  464. data/generated/google/apis/vision_v1/representations.rb +32 -0
  465. data/generated/google/apis/vision_v1.rb +1 -1
  466. data/generated/google/apis/vision_v1p1beta1/classes.rb +66 -0
  467. data/generated/google/apis/vision_v1p1beta1/representations.rb +32 -0
  468. data/generated/google/apis/vision_v1p1beta1.rb +1 -1
  469. data/generated/google/apis/vision_v1p2beta1/classes.rb +66 -0
  470. data/generated/google/apis/vision_v1p2beta1/representations.rb +32 -0
  471. data/generated/google/apis/vision_v1p2beta1.rb +1 -1
  472. data/generated/google/apis/youtube_partner_v1/service.rb +2 -2
  473. data/generated/google/apis/youtube_partner_v1.rb +1 -1
  474. data/google-api-client.gemspec +6 -3
  475. data/lib/google/apis/core/api_command.rb +3 -0
  476. data/lib/google/apis/core/http_command.rb +10 -8
  477. data/lib/google/apis/core/upload.rb +4 -0
  478. data/lib/google/apis/version.rb +1 -1
  479. data/rakelib/devsite/devsite_builder.rb +126 -0
  480. data/rakelib/devsite/link_checker.rb +64 -0
  481. data/rakelib/devsite/repo_metadata.rb +56 -0
  482. metadata +64 -42
  483. data/generated/google/apis/cloudbuild_v1alpha1/classes.rb +0 -1168
  484. data/generated/google/apis/cloudbuild_v1alpha1/representations.rb +0 -434
  485. data/generated/google/apis/storage_v1beta1/classes.rb +0 -616
  486. data/generated/google/apis/storage_v1beta1/representations.rb +0 -249
  487. data/generated/google/apis/storage_v1beta1/service.rb +0 -1032
  488. data/generated/google/apis/storage_v1beta1.rb +0 -40
  489. data/generated/google/apis/urlshortener_v1/classes.rb +0 -246
  490. data/generated/google/apis/urlshortener_v1/representations.rb +0 -121
  491. data/generated/google/apis/urlshortener_v1/service.rb +0 -169
@@ -0,0 +1,1153 @@
1
+ # Copyright 2015 Google Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ require 'date'
16
+ require 'google/apis/core/base_service'
17
+ require 'google/apis/core/json_representation'
18
+ require 'google/apis/core/hashable'
19
+ require 'google/apis/errors'
20
+
21
+ module Google
22
+ module Apis
23
+ module MonitoringV1
24
+
25
+ # Describes how to combine multiple time series to provide different views of
26
+ # the data. Aggregation consists of an alignment step on individual time series (
27
+ # alignment_period and per_series_aligner) followed by an optional reduction
28
+ # step of the data across the aligned time series (cross_series_reducer and
29
+ # group_by_fields). For more details, see Aggregation.
30
+ class Aggregation
31
+ include Google::Apis::Core::Hashable
32
+
33
+ # The alignment period for per-time series alignment. If present,
34
+ # alignmentPeriod must be at least 60 seconds. After per-time series alignment,
35
+ # each time series will contain data points only on the period boundaries. If
36
+ # perSeriesAligner is not specified or equals ALIGN_NONE, then this field is
37
+ # ignored. If perSeriesAligner is specified and does not equal ALIGN_NONE, then
38
+ # this field must be defined; otherwise an error is returned.
39
+ # Corresponds to the JSON property `alignmentPeriod`
40
+ # @return [String]
41
+ attr_accessor :alignment_period
42
+
43
+ # The approach to be used to combine time series. Not all reducer functions may
44
+ # be applied to all time series, depending on the metric type and the value type
45
+ # of the original time series. Reduction may change the metric type of value
46
+ # type of the time series.Time series data must be aligned in order to perform
47
+ # cross-time series reduction. If crossSeriesReducer is specified, then
48
+ # perSeriesAligner must be specified and not equal ALIGN_NONE and
49
+ # alignmentPeriod must be specified; otherwise, an error is returned.
50
+ # Corresponds to the JSON property `crossSeriesReducer`
51
+ # @return [String]
52
+ attr_accessor :cross_series_reducer
53
+
54
+ # The set of fields to preserve when crossSeriesReducer is specified. The
55
+ # groupByFields determine how the time series are partitioned into subsets prior
56
+ # to applying the aggregation function. Each subset contains time series that
57
+ # have the same value for each of the grouping fields. Each individual time
58
+ # series is a member of exactly one subset. The crossSeriesReducer is applied to
59
+ # each subset of time series. It is not possible to reduce across different
60
+ # resource types, so this field implicitly contains resource.type. Fields not
61
+ # specified in groupByFields are aggregated away. If groupByFields is not
62
+ # specified and all the time series have the same resource type, then the time
63
+ # series are aggregated into a single output time series. If crossSeriesReducer
64
+ # is not defined, this field is ignored.
65
+ # Corresponds to the JSON property `groupByFields`
66
+ # @return [Array<String>]
67
+ attr_accessor :group_by_fields
68
+
69
+ # The approach to be used to align individual time series. Not all alignment
70
+ # functions may be applied to all time series, depending on the metric type and
71
+ # value type of the original time series. Alignment may change the metric type
72
+ # or the value type of the time series.Time series data must be aligned in order
73
+ # to perform cross-time series reduction. If crossSeriesReducer is specified,
74
+ # then perSeriesAligner must be specified and not equal ALIGN_NONE and
75
+ # alignmentPeriod must be specified; otherwise, an error is returned.
76
+ # Corresponds to the JSON property `perSeriesAligner`
77
+ # @return [String]
78
+ attr_accessor :per_series_aligner
79
+
80
+ def initialize(**args)
81
+ update!(**args)
82
+ end
83
+
84
+ # Update properties of this object
85
+ def update!(**args)
86
+ @alignment_period = args[:alignment_period] if args.key?(:alignment_period)
87
+ @cross_series_reducer = args[:cross_series_reducer] if args.key?(:cross_series_reducer)
88
+ @group_by_fields = args[:group_by_fields] if args.key?(:group_by_fields)
89
+ @per_series_aligner = args[:per_series_aligner] if args.key?(:per_series_aligner)
90
+ end
91
+ end
92
+
93
+ # A chart axis.
94
+ class Axis
95
+ include Google::Apis::Core::Hashable
96
+
97
+ # The label of the axis.
98
+ # Corresponds to the JSON property `label`
99
+ # @return [String]
100
+ attr_accessor :label
101
+
102
+ # The axis scale. By default, a linear scale is used.
103
+ # Corresponds to the JSON property `scale`
104
+ # @return [String]
105
+ attr_accessor :scale
106
+
107
+ def initialize(**args)
108
+ update!(**args)
109
+ end
110
+
111
+ # Update properties of this object
112
+ def update!(**args)
113
+ @label = args[:label] if args.key?(:label)
114
+ @scale = args[:scale] if args.key?(:scale)
115
+ end
116
+ end
117
+
118
+ # Options to control visual rendering of a chart.
119
+ class ChartOptions
120
+ include Google::Apis::Core::Hashable
121
+
122
+ # The chart mode.
123
+ # Corresponds to the JSON property `mode`
124
+ # @return [String]
125
+ attr_accessor :mode
126
+
127
+ def initialize(**args)
128
+ update!(**args)
129
+ end
130
+
131
+ # Update properties of this object
132
+ def update!(**args)
133
+ @mode = args[:mode] if args.key?(:mode)
134
+ end
135
+ end
136
+
137
+ # Defines the layout properties and content for a column.
138
+ class Column
139
+ include Google::Apis::Core::Hashable
140
+
141
+ # The relative weight of this column. The column weight is used to adjust the
142
+ # height of rows on the screen (relative to peers). If omitted, a value of 1 is
143
+ # used.
144
+ # Corresponds to the JSON property `weight`
145
+ # @return [Fixnum]
146
+ attr_accessor :weight
147
+
148
+ # The display widgets arranged vertically in this column.
149
+ # Corresponds to the JSON property `widgets`
150
+ # @return [Array<Google::Apis::MonitoringV1::Widget>]
151
+ attr_accessor :widgets
152
+
153
+ def initialize(**args)
154
+ update!(**args)
155
+ end
156
+
157
+ # Update properties of this object
158
+ def update!(**args)
159
+ @weight = args[:weight] if args.key?(:weight)
160
+ @widgets = args[:widgets] if args.key?(:widgets)
161
+ end
162
+ end
163
+
164
+ # A simplified layout that divides the available space into vertical columns and
165
+ # arranges a set of widgets vertically in each column.
166
+ class ColumnLayout
167
+ include Google::Apis::Core::Hashable
168
+
169
+ # The columns of content to display.
170
+ # Corresponds to the JSON property `columns`
171
+ # @return [Array<Google::Apis::MonitoringV1::Column>]
172
+ attr_accessor :columns
173
+
174
+ def initialize(**args)
175
+ update!(**args)
176
+ end
177
+
178
+ # Update properties of this object
179
+ def update!(**args)
180
+ @columns = args[:columns] if args.key?(:columns)
181
+ end
182
+ end
183
+
184
+ # A Google Stackdriver dashboard. Dashboards define the content and layout of
185
+ # pages in the Stackdriver web application.
186
+ class Dashboard
187
+ include Google::Apis::Core::Hashable
188
+
189
+ # A simplified layout that divides the available space into vertical columns and
190
+ # arranges a set of widgets vertically in each column.
191
+ # Corresponds to the JSON property `columnLayout`
192
+ # @return [Google::Apis::MonitoringV1::ColumnLayout]
193
+ attr_accessor :column_layout
194
+
195
+ # The mutable, human-readable name.
196
+ # Corresponds to the JSON property `displayName`
197
+ # @return [String]
198
+ attr_accessor :display_name
199
+
200
+ # etag is used for optimistic concurrency control as a way to help prevent
201
+ # simultaneous updates of a policy from overwriting each other. An etag is
202
+ # returned in the response to GetDashboard, and users are expected to put that
203
+ # etag in the request to UpdateDashboard to ensure that their change will be
204
+ # applied to the same version of the Dashboard configuration. The field should
205
+ # not be passed during dashboard creation.
206
+ # Corresponds to the JSON property `etag`
207
+ # @return [String]
208
+ attr_accessor :etag
209
+
210
+ # A basic layout divides the available space into vertical columns of equal
211
+ # width and arranges a list of widgets using a row-first strategy.
212
+ # Corresponds to the JSON property `gridLayout`
213
+ # @return [Google::Apis::MonitoringV1::GridLayout]
214
+ attr_accessor :grid_layout
215
+
216
+ # The resource name of the dashboard.
217
+ # Corresponds to the JSON property `name`
218
+ # @return [String]
219
+ attr_accessor :name
220
+
221
+ # A simplified layout that divides the available space into rows and arranges a
222
+ # set of widgets horizontally in each row.
223
+ # Corresponds to the JSON property `rowLayout`
224
+ # @return [Google::Apis::MonitoringV1::RowLayout]
225
+ attr_accessor :row_layout
226
+
227
+ def initialize(**args)
228
+ update!(**args)
229
+ end
230
+
231
+ # Update properties of this object
232
+ def update!(**args)
233
+ @column_layout = args[:column_layout] if args.key?(:column_layout)
234
+ @display_name = args[:display_name] if args.key?(:display_name)
235
+ @etag = args[:etag] if args.key?(:etag)
236
+ @grid_layout = args[:grid_layout] if args.key?(:grid_layout)
237
+ @name = args[:name] if args.key?(:name)
238
+ @row_layout = args[:row_layout] if args.key?(:row_layout)
239
+ end
240
+ end
241
+
242
+ # Groups a time series query definition with charting options.
243
+ class DataSet
244
+ include Google::Apis::Core::Hashable
245
+
246
+ # A template string for naming TimeSeries in the resulting data set. This should
247
+ # be a string with interpolations of the form $`label_name`, which will resolve
248
+ # to the label's value.
249
+ # Corresponds to the JSON property `legendTemplate`
250
+ # @return [String]
251
+ attr_accessor :legend_template
252
+
253
+ # Optional. The lower bound on data point frequency for this data set
254
+ # implemented by specifying the minimum alignment period to use in a time series
255
+ # query. For example, if the data is published once every 10 minutes it would
256
+ # not make sense to fetch and align data at one minute intervals.
257
+ # Corresponds to the JSON property `minAlignmentPeriod`
258
+ # @return [String]
259
+ attr_accessor :min_alignment_period
260
+
261
+ # How this data should be plotted on the chart.
262
+ # Corresponds to the JSON property `plotType`
263
+ # @return [String]
264
+ attr_accessor :plot_type
265
+
266
+ # TimeSeriesQuery collects the set of supported methods for querying time series
267
+ # data from the Stackdriver metrics API.
268
+ # Corresponds to the JSON property `timeSeriesQuery`
269
+ # @return [Google::Apis::MonitoringV1::TimeSeriesQuery]
270
+ attr_accessor :time_series_query
271
+
272
+ def initialize(**args)
273
+ update!(**args)
274
+ end
275
+
276
+ # Update properties of this object
277
+ def update!(**args)
278
+ @legend_template = args[:legend_template] if args.key?(:legend_template)
279
+ @min_alignment_period = args[:min_alignment_period] if args.key?(:min_alignment_period)
280
+ @plot_type = args[:plot_type] if args.key?(:plot_type)
281
+ @time_series_query = args[:time_series_query] if args.key?(:time_series_query)
282
+ end
283
+ end
284
+
285
+ # A set of (label, value) pairs which were dropped during aggregation, attached
286
+ # to google.api.Distribution.Exemplars in google.api.Distribution values during
287
+ # aggregation.These values are used in combination with the label values that
288
+ # remain on the aggregated Distribution timeseries to construct the full label
289
+ # set for the exemplar values. The resulting full label set may be used to
290
+ # identify the specific task/job/instance (for example) which may be
291
+ # contributing to a long-tail, while allowing the storage savings of only
292
+ # storing aggregated distribution values for a large group.Note that there are
293
+ # no guarantees on ordering of the labels from exemplar-to-exemplar and from
294
+ # distribution-to-distribution in the same stream, and there may be duplicates.
295
+ # It is up to clients to resolve any ambiguities.
296
+ class DroppedLabels
297
+ include Google::Apis::Core::Hashable
298
+
299
+ # Map from label to its value, for all labels dropped in any aggregation.
300
+ # Corresponds to the JSON property `label`
301
+ # @return [Hash<String,String>]
302
+ attr_accessor :label
303
+
304
+ def initialize(**args)
305
+ update!(**args)
306
+ end
307
+
308
+ # Update properties of this object
309
+ def update!(**args)
310
+ @label = args[:label] if args.key?(:label)
311
+ end
312
+ end
313
+
314
+ # A generic empty message that you can re-use to avoid defining duplicated empty
315
+ # messages in your APIs. A typical example is to use it as the request or the
316
+ # response type of an API method. For instance:
317
+ # service Foo `
318
+ # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
319
+ # `
320
+ # The JSON representation for Empty is empty JSON object ``.
321
+ class Empty
322
+ include Google::Apis::Core::Hashable
323
+
324
+ def initialize(**args)
325
+ update!(**args)
326
+ end
327
+
328
+ # Update properties of this object
329
+ def update!(**args)
330
+ end
331
+ end
332
+
333
+ # A single field of a message type.
334
+ class Field
335
+ include Google::Apis::Core::Hashable
336
+
337
+ # The field cardinality.
338
+ # Corresponds to the JSON property `cardinality`
339
+ # @return [String]
340
+ attr_accessor :cardinality
341
+
342
+ # The string value of the default value of this field. Proto2 syntax only.
343
+ # Corresponds to the JSON property `defaultValue`
344
+ # @return [String]
345
+ attr_accessor :default_value
346
+
347
+ # The field JSON name.
348
+ # Corresponds to the JSON property `jsonName`
349
+ # @return [String]
350
+ attr_accessor :json_name
351
+
352
+ # The field type.
353
+ # Corresponds to the JSON property `kind`
354
+ # @return [String]
355
+ attr_accessor :kind
356
+
357
+ # The field name.
358
+ # Corresponds to the JSON property `name`
359
+ # @return [String]
360
+ attr_accessor :name
361
+
362
+ # The field number.
363
+ # Corresponds to the JSON property `number`
364
+ # @return [Fixnum]
365
+ attr_accessor :number
366
+
367
+ # The index of the field type in Type.oneofs, for message or enumeration types.
368
+ # The first type has index 1; zero means the type is not in the list.
369
+ # Corresponds to the JSON property `oneofIndex`
370
+ # @return [Fixnum]
371
+ attr_accessor :oneof_index
372
+
373
+ # The protocol buffer options.
374
+ # Corresponds to the JSON property `options`
375
+ # @return [Array<Google::Apis::MonitoringV1::Option>]
376
+ attr_accessor :options
377
+
378
+ # Whether to use alternative packed wire representation.
379
+ # Corresponds to the JSON property `packed`
380
+ # @return [Boolean]
381
+ attr_accessor :packed
382
+ alias_method :packed?, :packed
383
+
384
+ # The field type URL, without the scheme, for message or enumeration types.
385
+ # Example: "type.googleapis.com/google.protobuf.Timestamp".
386
+ # Corresponds to the JSON property `typeUrl`
387
+ # @return [String]
388
+ attr_accessor :type_url
389
+
390
+ def initialize(**args)
391
+ update!(**args)
392
+ end
393
+
394
+ # Update properties of this object
395
+ def update!(**args)
396
+ @cardinality = args[:cardinality] if args.key?(:cardinality)
397
+ @default_value = args[:default_value] if args.key?(:default_value)
398
+ @json_name = args[:json_name] if args.key?(:json_name)
399
+ @kind = args[:kind] if args.key?(:kind)
400
+ @name = args[:name] if args.key?(:name)
401
+ @number = args[:number] if args.key?(:number)
402
+ @oneof_index = args[:oneof_index] if args.key?(:oneof_index)
403
+ @options = args[:options] if args.key?(:options)
404
+ @packed = args[:packed] if args.key?(:packed)
405
+ @type_url = args[:type_url] if args.key?(:type_url)
406
+ end
407
+ end
408
+
409
+ # A gauge chart shows where the current value sits within a pre-defined range.
410
+ # The upper and lower bounds should define the possible range of values for the
411
+ # scorecard's query (inclusive).
412
+ class GaugeView
413
+ include Google::Apis::Core::Hashable
414
+
415
+ # The lower bound for this gauge chart. The value of the chart should always be
416
+ # greater than or equal to this.
417
+ # Corresponds to the JSON property `lowerBound`
418
+ # @return [Float]
419
+ attr_accessor :lower_bound
420
+
421
+ # The upper bound for this gauge chart. The value of the chart should always be
422
+ # less than or equal to this.
423
+ # Corresponds to the JSON property `upperBound`
424
+ # @return [Float]
425
+ attr_accessor :upper_bound
426
+
427
+ def initialize(**args)
428
+ update!(**args)
429
+ end
430
+
431
+ # Update properties of this object
432
+ def update!(**args)
433
+ @lower_bound = args[:lower_bound] if args.key?(:lower_bound)
434
+ @upper_bound = args[:upper_bound] if args.key?(:upper_bound)
435
+ end
436
+ end
437
+
438
+ # A basic layout divides the available space into vertical columns of equal
439
+ # width and arranges a list of widgets using a row-first strategy.
440
+ class GridLayout
441
+ include Google::Apis::Core::Hashable
442
+
443
+ # The number of columns into which the view's width is divided. If omitted or
444
+ # set to zero, a system default will be used.
445
+ # Corresponds to the JSON property `columns`
446
+ # @return [Fixnum]
447
+ attr_accessor :columns
448
+
449
+ # The informational elements that are arranged into the columns row-first.
450
+ # Corresponds to the JSON property `widgets`
451
+ # @return [Array<Google::Apis::MonitoringV1::Widget>]
452
+ attr_accessor :widgets
453
+
454
+ def initialize(**args)
455
+ update!(**args)
456
+ end
457
+
458
+ # Update properties of this object
459
+ def update!(**args)
460
+ @columns = args[:columns] if args.key?(:columns)
461
+ @widgets = args[:widgets] if args.key?(:widgets)
462
+ end
463
+ end
464
+
465
+ # The ListDashboards request.
466
+ class ListDashboardsResponse
467
+ include Google::Apis::Core::Hashable
468
+
469
+ # The list of requested dashboards.
470
+ # Corresponds to the JSON property `dashboards`
471
+ # @return [Array<Google::Apis::MonitoringV1::Dashboard>]
472
+ attr_accessor :dashboards
473
+
474
+ # If there are more results than have been returned, then this field is set to a
475
+ # non-empty value. To see the additional results, use that value as pageToken in
476
+ # the next call to this method.
477
+ # Corresponds to the JSON property `nextPageToken`
478
+ # @return [String]
479
+ attr_accessor :next_page_token
480
+
481
+ def initialize(**args)
482
+ update!(**args)
483
+ end
484
+
485
+ # Update properties of this object
486
+ def update!(**args)
487
+ @dashboards = args[:dashboards] if args.key?(:dashboards)
488
+ @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
489
+ end
490
+ end
491
+
492
+ # A protocol buffer option, which can be attached to a message, field,
493
+ # enumeration, etc.
494
+ class Option
495
+ include Google::Apis::Core::Hashable
496
+
497
+ # The option's name. For protobuf built-in options (options defined in
498
+ # descriptor.proto), this is the short name. For example, "map_entry". For
499
+ # custom options, it should be the fully-qualified name. For example, "google.
500
+ # api.http".
501
+ # Corresponds to the JSON property `name`
502
+ # @return [String]
503
+ attr_accessor :name
504
+
505
+ # The option's value packed in an Any message. If the value is a primitive, the
506
+ # corresponding wrapper type defined in google/protobuf/wrappers.proto should be
507
+ # used. If the value is an enum, it should be stored as an int32 value using the
508
+ # google.protobuf.Int32Value type.
509
+ # Corresponds to the JSON property `value`
510
+ # @return [Hash<String,Object>]
511
+ attr_accessor :value
512
+
513
+ def initialize(**args)
514
+ update!(**args)
515
+ end
516
+
517
+ # Update properties of this object
518
+ def update!(**args)
519
+ @name = args[:name] if args.key?(:name)
520
+ @value = args[:value] if args.key?(:value)
521
+ end
522
+ end
523
+
524
+ # Describes a ranking-based time series filter. Each input time series is ranked
525
+ # with an aligner. The filter lets through up to num_time_series time series,
526
+ # selecting them based on the relative ranking.
527
+ class PickTimeSeriesFilter
528
+ include Google::Apis::Core::Hashable
529
+
530
+ # How to use the ranking to select time series that pass through the filter.
531
+ # Corresponds to the JSON property `direction`
532
+ # @return [String]
533
+ attr_accessor :direction
534
+
535
+ # How many time series to return.
536
+ # Corresponds to the JSON property `numTimeSeries`
537
+ # @return [Fixnum]
538
+ attr_accessor :num_time_series
539
+
540
+ # rankingMethod is applied to each time series independently to produce the
541
+ # value which will be used to compare the time series to other time series.
542
+ # Corresponds to the JSON property `rankingMethod`
543
+ # @return [String]
544
+ attr_accessor :ranking_method
545
+
546
+ def initialize(**args)
547
+ update!(**args)
548
+ end
549
+
550
+ # Update properties of this object
551
+ def update!(**args)
552
+ @direction = args[:direction] if args.key?(:direction)
553
+ @num_time_series = args[:num_time_series] if args.key?(:num_time_series)
554
+ @ranking_method = args[:ranking_method] if args.key?(:ranking_method)
555
+ end
556
+ end
557
+
558
+ # Describes a query to build the numerator or denominator of a
559
+ # TimeSeriesFilterRatio.
560
+ class RatioPart
561
+ include Google::Apis::Core::Hashable
562
+
563
+ # Describes how to combine multiple time series to provide different views of
564
+ # the data. Aggregation consists of an alignment step on individual time series (
565
+ # alignment_period and per_series_aligner) followed by an optional reduction
566
+ # step of the data across the aligned time series (cross_series_reducer and
567
+ # group_by_fields). For more details, see Aggregation.
568
+ # Corresponds to the JSON property `aggregation`
569
+ # @return [Google::Apis::MonitoringV1::Aggregation]
570
+ attr_accessor :aggregation
571
+
572
+ # Required. The monitoring filter that identifies the metric types, resources,
573
+ # and projects to query.
574
+ # Corresponds to the JSON property `filter`
575
+ # @return [String]
576
+ attr_accessor :filter
577
+
578
+ def initialize(**args)
579
+ update!(**args)
580
+ end
581
+
582
+ # Update properties of this object
583
+ def update!(**args)
584
+ @aggregation = args[:aggregation] if args.key?(:aggregation)
585
+ @filter = args[:filter] if args.key?(:filter)
586
+ end
587
+ end
588
+
589
+ # Defines the layout properties and content for a row.
590
+ class Row
591
+ include Google::Apis::Core::Hashable
592
+
593
+ # The relative weight of this row. The row weight is used to adjust the height
594
+ # of rows on the screen (relative to peers). If omitted, a value of 1 is used.
595
+ # Corresponds to the JSON property `weight`
596
+ # @return [Fixnum]
597
+ attr_accessor :weight
598
+
599
+ # The display widgets arranged horizontally in this row.
600
+ # Corresponds to the JSON property `widgets`
601
+ # @return [Array<Google::Apis::MonitoringV1::Widget>]
602
+ attr_accessor :widgets
603
+
604
+ def initialize(**args)
605
+ update!(**args)
606
+ end
607
+
608
+ # Update properties of this object
609
+ def update!(**args)
610
+ @weight = args[:weight] if args.key?(:weight)
611
+ @widgets = args[:widgets] if args.key?(:widgets)
612
+ end
613
+ end
614
+
615
+ # A simplified layout that divides the available space into rows and arranges a
616
+ # set of widgets horizontally in each row.
617
+ class RowLayout
618
+ include Google::Apis::Core::Hashable
619
+
620
+ # The rows of content to display.
621
+ # Corresponds to the JSON property `rows`
622
+ # @return [Array<Google::Apis::MonitoringV1::Row>]
623
+ attr_accessor :rows
624
+
625
+ def initialize(**args)
626
+ update!(**args)
627
+ end
628
+
629
+ # Update properties of this object
630
+ def update!(**args)
631
+ @rows = args[:rows] if args.key?(:rows)
632
+ end
633
+ end
634
+
635
+ # A widget showing the latest value of a metric, and how this value relates to
636
+ # one or more thresholds.
637
+ class Scorecard
638
+ include Google::Apis::Core::Hashable
639
+
640
+ # A gauge chart shows where the current value sits within a pre-defined range.
641
+ # The upper and lower bounds should define the possible range of values for the
642
+ # scorecard's query (inclusive).
643
+ # Corresponds to the JSON property `gaugeView`
644
+ # @return [Google::Apis::MonitoringV1::GaugeView]
645
+ attr_accessor :gauge_view
646
+
647
+ # A sparkChart is a small chart suitable for inclusion in a table-cell or inline
648
+ # in text. This message contains the configuration for a sparkChart to show up
649
+ # on a Scorecard, showing recent trends of the scorecard's timeseries.
650
+ # Corresponds to the JSON property `sparkChartView`
651
+ # @return [Google::Apis::MonitoringV1::SparkChartView]
652
+ attr_accessor :spark_chart_view
653
+
654
+ # The thresholds used to determine the state of the scorecard given the time
655
+ # series' current value. For an actual value x, the scorecard is in a danger
656
+ # state if x is less than or equal to a danger threshold that triggers below, or
657
+ # greater than or equal to a danger threshold that triggers above. Similarly, if
658
+ # x is above/below a warning threshold that triggers above/below, then the
659
+ # scorecard is in a warning state - unless x also puts it in a danger state. (
660
+ # Danger trumps warning.)As an example, consider a scorecard with the following
661
+ # four thresholds: ` value: 90, category: 'DANGER', trigger: 'ABOVE', `, `
662
+ # value: 70, category: 'WARNING', trigger: 'ABOVE', `, ` value: 10, category:
663
+ # 'DANGER', trigger: 'BELOW', `, ` value: 20, category: 'WARNING', trigger:
664
+ # 'BELOW', `Then: values less than or equal to 10 would put the scorecard in a
665
+ # DANGER state, values greater than 10 but less than or equal to 20 a WARNING
666
+ # state, values strictly between 20 and 70 an OK state, values greater than or
667
+ # equal to 70 but less than 90 a WARNING state, and values greater than or equal
668
+ # to 90 a DANGER state.
669
+ # Corresponds to the JSON property `thresholds`
670
+ # @return [Array<Google::Apis::MonitoringV1::Threshold>]
671
+ attr_accessor :thresholds
672
+
673
+ # TimeSeriesQuery collects the set of supported methods for querying time series
674
+ # data from the Stackdriver metrics API.
675
+ # Corresponds to the JSON property `timeSeriesQuery`
676
+ # @return [Google::Apis::MonitoringV1::TimeSeriesQuery]
677
+ attr_accessor :time_series_query
678
+
679
+ def initialize(**args)
680
+ update!(**args)
681
+ end
682
+
683
+ # Update properties of this object
684
+ def update!(**args)
685
+ @gauge_view = args[:gauge_view] if args.key?(:gauge_view)
686
+ @spark_chart_view = args[:spark_chart_view] if args.key?(:spark_chart_view)
687
+ @thresholds = args[:thresholds] if args.key?(:thresholds)
688
+ @time_series_query = args[:time_series_query] if args.key?(:time_series_query)
689
+ end
690
+ end
691
+
692
+ # SourceContext represents information about the source of a protobuf element,
693
+ # like the file in which it is defined.
694
+ class SourceContext
695
+ include Google::Apis::Core::Hashable
696
+
697
+ # The path-qualified name of the .proto file that contained the associated
698
+ # protobuf element. For example: "google/protobuf/source_context.proto".
699
+ # Corresponds to the JSON property `fileName`
700
+ # @return [String]
701
+ attr_accessor :file_name
702
+
703
+ def initialize(**args)
704
+ update!(**args)
705
+ end
706
+
707
+ # Update properties of this object
708
+ def update!(**args)
709
+ @file_name = args[:file_name] if args.key?(:file_name)
710
+ end
711
+ end
712
+
713
+ # The context of a span, attached to google.api.Distribution.Exemplars in google.
714
+ # api.Distribution values during aggregation.It contains the name of a span with
715
+ # format: projects/PROJECT_ID/traces/TRACE_ID/spans/SPAN_ID
716
+ class SpanContext
717
+ include Google::Apis::Core::Hashable
718
+
719
+ # The resource name of the span in the following format:
720
+ # projects/[PROJECT_ID]/traces/[TRACE_ID]/spans/[SPAN_ID]
721
+ # TRACE_ID is a unique identifier for a trace within a project; it is a 32-
722
+ # character hexadecimal encoding of a 16-byte array.SPAN_ID is a unique
723
+ # identifier for a span within a trace; it is a 16-character hexadecimal
724
+ # encoding of an 8-byte array.
725
+ # Corresponds to the JSON property `spanName`
726
+ # @return [String]
727
+ attr_accessor :span_name
728
+
729
+ def initialize(**args)
730
+ update!(**args)
731
+ end
732
+
733
+ # Update properties of this object
734
+ def update!(**args)
735
+ @span_name = args[:span_name] if args.key?(:span_name)
736
+ end
737
+ end
738
+
739
+ # A sparkChart is a small chart suitable for inclusion in a table-cell or inline
740
+ # in text. This message contains the configuration for a sparkChart to show up
741
+ # on a Scorecard, showing recent trends of the scorecard's timeseries.
742
+ class SparkChartView
743
+ include Google::Apis::Core::Hashable
744
+
745
+ # The lower bound on data point frequency in the chart implemented by specifying
746
+ # the minimum alignment period to use in a time series query. For example, if
747
+ # the data is published once every 10 minutes it would not make sense to fetch
748
+ # and align data at one minute intervals. This field is optional and exists only
749
+ # as a hint.
750
+ # Corresponds to the JSON property `minAlignmentPeriod`
751
+ # @return [String]
752
+ attr_accessor :min_alignment_period
753
+
754
+ # The type of sparkchart to show in this chartView.
755
+ # Corresponds to the JSON property `sparkChartType`
756
+ # @return [String]
757
+ attr_accessor :spark_chart_type
758
+
759
+ def initialize(**args)
760
+ update!(**args)
761
+ end
762
+
763
+ # Update properties of this object
764
+ def update!(**args)
765
+ @min_alignment_period = args[:min_alignment_period] if args.key?(:min_alignment_period)
766
+ @spark_chart_type = args[:spark_chart_type] if args.key?(:spark_chart_type)
767
+ end
768
+ end
769
+
770
+ # A filter that ranks streams based on their statistical relation to other
771
+ # streams in a request.
772
+ class StatisticalTimeSeriesFilter
773
+ include Google::Apis::Core::Hashable
774
+
775
+ # How many time series to output.
776
+ # Corresponds to the JSON property `numTimeSeries`
777
+ # @return [Fixnum]
778
+ attr_accessor :num_time_series
779
+
780
+ # rankingMethod is applied to a set of time series, and then the produced value
781
+ # for each individual time series is used to compare a given time series to
782
+ # others. These are methods that cannot be applied stream-by-stream, but rather
783
+ # require the full context of a request to evaluate time series.
784
+ # Corresponds to the JSON property `rankingMethod`
785
+ # @return [String]
786
+ attr_accessor :ranking_method
787
+
788
+ def initialize(**args)
789
+ update!(**args)
790
+ end
791
+
792
+ # Update properties of this object
793
+ def update!(**args)
794
+ @num_time_series = args[:num_time_series] if args.key?(:num_time_series)
795
+ @ranking_method = args[:ranking_method] if args.key?(:ranking_method)
796
+ end
797
+ end
798
+
799
+ # A widget that displays textual content.
800
+ class Text
801
+ include Google::Apis::Core::Hashable
802
+
803
+ # The text content to be displayed.
804
+ # Corresponds to the JSON property `content`
805
+ # @return [String]
806
+ attr_accessor :content
807
+
808
+ # How the text content is formatted.
809
+ # Corresponds to the JSON property `format`
810
+ # @return [String]
811
+ attr_accessor :format
812
+
813
+ def initialize(**args)
814
+ update!(**args)
815
+ end
816
+
817
+ # Update properties of this object
818
+ def update!(**args)
819
+ @content = args[:content] if args.key?(:content)
820
+ @format = args[:format] if args.key?(:format)
821
+ end
822
+ end
823
+
824
+ # Defines a threshold for categorizing time series values.
825
+ class Threshold
826
+ include Google::Apis::Core::Hashable
827
+
828
+ # The state color for this threshold. Color is not allowed in a XyChart.
829
+ # Corresponds to the JSON property `color`
830
+ # @return [String]
831
+ attr_accessor :color
832
+
833
+ # The direction for the current threshold. Direction is not allowed in a XyChart.
834
+ # Corresponds to the JSON property `direction`
835
+ # @return [String]
836
+ attr_accessor :direction
837
+
838
+ # A label for the threshold.
839
+ # Corresponds to the JSON property `label`
840
+ # @return [String]
841
+ attr_accessor :label
842
+
843
+ # The value of the threshold. The value should be defined in the native scale of
844
+ # the metric.
845
+ # Corresponds to the JSON property `value`
846
+ # @return [Float]
847
+ attr_accessor :value
848
+
849
+ def initialize(**args)
850
+ update!(**args)
851
+ end
852
+
853
+ # Update properties of this object
854
+ def update!(**args)
855
+ @color = args[:color] if args.key?(:color)
856
+ @direction = args[:direction] if args.key?(:direction)
857
+ @label = args[:label] if args.key?(:label)
858
+ @value = args[:value] if args.key?(:value)
859
+ end
860
+ end
861
+
862
+ # A filter that defines a subset of time series data that is displayed in a
863
+ # widget. Time series data is fetched using the ListTimeSeries method.
864
+ class TimeSeriesFilter
865
+ include Google::Apis::Core::Hashable
866
+
867
+ # Describes how to combine multiple time series to provide different views of
868
+ # the data. Aggregation consists of an alignment step on individual time series (
869
+ # alignment_period and per_series_aligner) followed by an optional reduction
870
+ # step of the data across the aligned time series (cross_series_reducer and
871
+ # group_by_fields). For more details, see Aggregation.
872
+ # Corresponds to the JSON property `aggregation`
873
+ # @return [Google::Apis::MonitoringV1::Aggregation]
874
+ attr_accessor :aggregation
875
+
876
+ # Required. The monitoring filter that identifies the metric types, resources,
877
+ # and projects to query.
878
+ # Corresponds to the JSON property `filter`
879
+ # @return [String]
880
+ attr_accessor :filter
881
+
882
+ # Describes a ranking-based time series filter. Each input time series is ranked
883
+ # with an aligner. The filter lets through up to num_time_series time series,
884
+ # selecting them based on the relative ranking.
885
+ # Corresponds to the JSON property `pickTimeSeriesFilter`
886
+ # @return [Google::Apis::MonitoringV1::PickTimeSeriesFilter]
887
+ attr_accessor :pick_time_series_filter
888
+
889
+ # A filter that ranks streams based on their statistical relation to other
890
+ # streams in a request.
891
+ # Corresponds to the JSON property `statisticalTimeSeriesFilter`
892
+ # @return [Google::Apis::MonitoringV1::StatisticalTimeSeriesFilter]
893
+ attr_accessor :statistical_time_series_filter
894
+
895
+ def initialize(**args)
896
+ update!(**args)
897
+ end
898
+
899
+ # Update properties of this object
900
+ def update!(**args)
901
+ @aggregation = args[:aggregation] if args.key?(:aggregation)
902
+ @filter = args[:filter] if args.key?(:filter)
903
+ @pick_time_series_filter = args[:pick_time_series_filter] if args.key?(:pick_time_series_filter)
904
+ @statistical_time_series_filter = args[:statistical_time_series_filter] if args.key?(:statistical_time_series_filter)
905
+ end
906
+ end
907
+
908
+ # A pair of time series filters that define a ratio computation. The output time
909
+ # series is the pair-wise division of each aligned element from the numerator
910
+ # and denominator time series.
911
+ class TimeSeriesFilterRatio
912
+ include Google::Apis::Core::Hashable
913
+
914
+ # Describes a query to build the numerator or denominator of a
915
+ # TimeSeriesFilterRatio.
916
+ # Corresponds to the JSON property `denominator`
917
+ # @return [Google::Apis::MonitoringV1::RatioPart]
918
+ attr_accessor :denominator
919
+
920
+ # Describes a query to build the numerator or denominator of a
921
+ # TimeSeriesFilterRatio.
922
+ # Corresponds to the JSON property `numerator`
923
+ # @return [Google::Apis::MonitoringV1::RatioPart]
924
+ attr_accessor :numerator
925
+
926
+ # Describes a ranking-based time series filter. Each input time series is ranked
927
+ # with an aligner. The filter lets through up to num_time_series time series,
928
+ # selecting them based on the relative ranking.
929
+ # Corresponds to the JSON property `pickTimeSeriesFilter`
930
+ # @return [Google::Apis::MonitoringV1::PickTimeSeriesFilter]
931
+ attr_accessor :pick_time_series_filter
932
+
933
+ # Describes how to combine multiple time series to provide different views of
934
+ # the data. Aggregation consists of an alignment step on individual time series (
935
+ # alignment_period and per_series_aligner) followed by an optional reduction
936
+ # step of the data across the aligned time series (cross_series_reducer and
937
+ # group_by_fields). For more details, see Aggregation.
938
+ # Corresponds to the JSON property `secondaryAggregation`
939
+ # @return [Google::Apis::MonitoringV1::Aggregation]
940
+ attr_accessor :secondary_aggregation
941
+
942
+ # A filter that ranks streams based on their statistical relation to other
943
+ # streams in a request.
944
+ # Corresponds to the JSON property `statisticalTimeSeriesFilter`
945
+ # @return [Google::Apis::MonitoringV1::StatisticalTimeSeriesFilter]
946
+ attr_accessor :statistical_time_series_filter
947
+
948
+ def initialize(**args)
949
+ update!(**args)
950
+ end
951
+
952
+ # Update properties of this object
953
+ def update!(**args)
954
+ @denominator = args[:denominator] if args.key?(:denominator)
955
+ @numerator = args[:numerator] if args.key?(:numerator)
956
+ @pick_time_series_filter = args[:pick_time_series_filter] if args.key?(:pick_time_series_filter)
957
+ @secondary_aggregation = args[:secondary_aggregation] if args.key?(:secondary_aggregation)
958
+ @statistical_time_series_filter = args[:statistical_time_series_filter] if args.key?(:statistical_time_series_filter)
959
+ end
960
+ end
961
+
962
+ # TimeSeriesQuery collects the set of supported methods for querying time series
963
+ # data from the Stackdriver metrics API.
964
+ class TimeSeriesQuery
965
+ include Google::Apis::Core::Hashable
966
+
967
+ # A filter that defines a subset of time series data that is displayed in a
968
+ # widget. Time series data is fetched using the ListTimeSeries method.
969
+ # Corresponds to the JSON property `timeSeriesFilter`
970
+ # @return [Google::Apis::MonitoringV1::TimeSeriesFilter]
971
+ attr_accessor :time_series_filter
972
+
973
+ # A pair of time series filters that define a ratio computation. The output time
974
+ # series is the pair-wise division of each aligned element from the numerator
975
+ # and denominator time series.
976
+ # Corresponds to the JSON property `timeSeriesFilterRatio`
977
+ # @return [Google::Apis::MonitoringV1::TimeSeriesFilterRatio]
978
+ attr_accessor :time_series_filter_ratio
979
+
980
+ # The unit of data contained in fetched time series. If non-empty, this unit
981
+ # will override any unit that accompanies fetched data. The format is the same
982
+ # as the unit field in MetricDescriptor.
983
+ # Corresponds to the JSON property `unitOverride`
984
+ # @return [String]
985
+ attr_accessor :unit_override
986
+
987
+ def initialize(**args)
988
+ update!(**args)
989
+ end
990
+
991
+ # Update properties of this object
992
+ def update!(**args)
993
+ @time_series_filter = args[:time_series_filter] if args.key?(:time_series_filter)
994
+ @time_series_filter_ratio = args[:time_series_filter_ratio] if args.key?(:time_series_filter_ratio)
995
+ @unit_override = args[:unit_override] if args.key?(:unit_override)
996
+ end
997
+ end
998
+
999
+ # A protocol buffer message type.
1000
+ class Type
1001
+ include Google::Apis::Core::Hashable
1002
+
1003
+ # The list of fields.
1004
+ # Corresponds to the JSON property `fields`
1005
+ # @return [Array<Google::Apis::MonitoringV1::Field>]
1006
+ attr_accessor :fields
1007
+
1008
+ # The fully qualified message name.
1009
+ # Corresponds to the JSON property `name`
1010
+ # @return [String]
1011
+ attr_accessor :name
1012
+
1013
+ # The list of types appearing in oneof definitions in this type.
1014
+ # Corresponds to the JSON property `oneofs`
1015
+ # @return [Array<String>]
1016
+ attr_accessor :oneofs
1017
+
1018
+ # The protocol buffer options.
1019
+ # Corresponds to the JSON property `options`
1020
+ # @return [Array<Google::Apis::MonitoringV1::Option>]
1021
+ attr_accessor :options
1022
+
1023
+ # SourceContext represents information about the source of a protobuf element,
1024
+ # like the file in which it is defined.
1025
+ # Corresponds to the JSON property `sourceContext`
1026
+ # @return [Google::Apis::MonitoringV1::SourceContext]
1027
+ attr_accessor :source_context
1028
+
1029
+ # The source syntax.
1030
+ # Corresponds to the JSON property `syntax`
1031
+ # @return [String]
1032
+ attr_accessor :syntax
1033
+
1034
+ def initialize(**args)
1035
+ update!(**args)
1036
+ end
1037
+
1038
+ # Update properties of this object
1039
+ def update!(**args)
1040
+ @fields = args[:fields] if args.key?(:fields)
1041
+ @name = args[:name] if args.key?(:name)
1042
+ @oneofs = args[:oneofs] if args.key?(:oneofs)
1043
+ @options = args[:options] if args.key?(:options)
1044
+ @source_context = args[:source_context] if args.key?(:source_context)
1045
+ @syntax = args[:syntax] if args.key?(:syntax)
1046
+ end
1047
+ end
1048
+
1049
+ # Widget contains a single dashboard component and configuration of how to
1050
+ # present the component in the dashboard.
1051
+ class Widget
1052
+ include Google::Apis::Core::Hashable
1053
+
1054
+ # A generic empty message that you can re-use to avoid defining duplicated empty
1055
+ # messages in your APIs. A typical example is to use it as the request or the
1056
+ # response type of an API method. For instance:
1057
+ # service Foo `
1058
+ # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
1059
+ # `
1060
+ # The JSON representation for Empty is empty JSON object ``.
1061
+ # Corresponds to the JSON property `blank`
1062
+ # @return [Google::Apis::MonitoringV1::Empty]
1063
+ attr_accessor :blank
1064
+
1065
+ # A widget showing the latest value of a metric, and how this value relates to
1066
+ # one or more thresholds.
1067
+ # Corresponds to the JSON property `scorecard`
1068
+ # @return [Google::Apis::MonitoringV1::Scorecard]
1069
+ attr_accessor :scorecard
1070
+
1071
+ # A widget that displays textual content.
1072
+ # Corresponds to the JSON property `text`
1073
+ # @return [Google::Apis::MonitoringV1::Text]
1074
+ attr_accessor :text
1075
+
1076
+ # Optional. The title of the widget.
1077
+ # Corresponds to the JSON property `title`
1078
+ # @return [String]
1079
+ attr_accessor :title
1080
+
1081
+ # A chart that displays data on a 2D (X and Y axes) plane.
1082
+ # Corresponds to the JSON property `xyChart`
1083
+ # @return [Google::Apis::MonitoringV1::XyChart]
1084
+ attr_accessor :xy_chart
1085
+
1086
+ def initialize(**args)
1087
+ update!(**args)
1088
+ end
1089
+
1090
+ # Update properties of this object
1091
+ def update!(**args)
1092
+ @blank = args[:blank] if args.key?(:blank)
1093
+ @scorecard = args[:scorecard] if args.key?(:scorecard)
1094
+ @text = args[:text] if args.key?(:text)
1095
+ @title = args[:title] if args.key?(:title)
1096
+ @xy_chart = args[:xy_chart] if args.key?(:xy_chart)
1097
+ end
1098
+ end
1099
+
1100
+ # A chart that displays data on a 2D (X and Y axes) plane.
1101
+ class XyChart
1102
+ include Google::Apis::Core::Hashable
1103
+
1104
+ # Options to control visual rendering of a chart.
1105
+ # Corresponds to the JSON property `chartOptions`
1106
+ # @return [Google::Apis::MonitoringV1::ChartOptions]
1107
+ attr_accessor :chart_options
1108
+
1109
+ # The data displayed in this chart.
1110
+ # Corresponds to the JSON property `dataSets`
1111
+ # @return [Array<Google::Apis::MonitoringV1::DataSet>]
1112
+ attr_accessor :data_sets
1113
+
1114
+ # Threshold lines drawn horizontally across the chart.
1115
+ # Corresponds to the JSON property `thresholds`
1116
+ # @return [Array<Google::Apis::MonitoringV1::Threshold>]
1117
+ attr_accessor :thresholds
1118
+
1119
+ # The duration used to display a comparison chart. A comparison chart shows
1120
+ # values from two time periods simultaneously (e.g., week-over-week metrics).
1121
+ # The duration must be positive, and it can only be applied to charts with data
1122
+ # sets of LINE plot type.
1123
+ # Corresponds to the JSON property `timeshiftDuration`
1124
+ # @return [String]
1125
+ attr_accessor :timeshift_duration
1126
+
1127
+ # A chart axis.
1128
+ # Corresponds to the JSON property `xAxis`
1129
+ # @return [Google::Apis::MonitoringV1::Axis]
1130
+ attr_accessor :x_axis
1131
+
1132
+ # A chart axis.
1133
+ # Corresponds to the JSON property `yAxis`
1134
+ # @return [Google::Apis::MonitoringV1::Axis]
1135
+ attr_accessor :y_axis
1136
+
1137
+ def initialize(**args)
1138
+ update!(**args)
1139
+ end
1140
+
1141
+ # Update properties of this object
1142
+ def update!(**args)
1143
+ @chart_options = args[:chart_options] if args.key?(:chart_options)
1144
+ @data_sets = args[:data_sets] if args.key?(:data_sets)
1145
+ @thresholds = args[:thresholds] if args.key?(:thresholds)
1146
+ @timeshift_duration = args[:timeshift_duration] if args.key?(:timeshift_duration)
1147
+ @x_axis = args[:x_axis] if args.key?(:x_axis)
1148
+ @y_axis = args[:y_axis] if args.key?(:y_axis)
1149
+ end
1150
+ end
1151
+ end
1152
+ end
1153
+ end