File: service.rb

package info (click to toggle)
ruby-google-api-client 0.53.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 75,020 kB
  • sloc: ruby: 626,567; makefile: 4
file content (602 lines) | stat: -rw-r--r-- 42,016 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
# Copyright 2015 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#      http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

require 'google/apis/core/base_service'
require 'google/apis/core/json_representation'
require 'google/apis/core/hashable'
require 'google/apis/errors'

module Google
  module Apis
    module AdminReportsV1
      # Admin SDK API
      #
      # Admin SDK lets administrators of enterprise domains to view and manage
      #  resources like user, groups etc. It also provides audit and usage reports of
      #  domain.
      #
      # @example
      #    require 'google/apis/admin_reports_v1'
      #
      #    Admin = Google::Apis::AdminReportsV1 # Alias the module
      #    service = Admin::ReportsService.new
      #
      # @see http://developers.google.com/admin-sdk/
      class ReportsService < Google::Apis::Core::BaseService
        # @return [String]
        #  API key. Your API key identifies your project and provides you with API access,
        #  quota, and reports. Required unless you provide an OAuth 2.0 token.
        attr_accessor :key

        # @return [String]
        #  Available to use for quota purposes for server-side applications. Can be any
        #  arbitrary string assigned to a user, but should not exceed 40 characters.
        attr_accessor :quota_user

        def initialize
          super('https://admin.googleapis.com/', '')
          @batch_path = 'batch'
        end
        
        # Retrieves a list of activities for a specific customer's account and
        # application such as the Admin console application or the Google Drive
        # application. For more information, see the guides for administrator and Google
        # Drive activity reports. For more information about the activity report's
        # parameters, see the activity parameters reference guides.
        # @param [String] user_key
        #   Represents the profile ID or the user email for which the data should be
        #   filtered. Can be `all` for all information, or `userKey` for a user's unique G
        #   Suite profile ID or their primary email address.
        # @param [String] application_name
        #   Application name for which the events are to be retrieved.
        # @param [String] actor_ip_address
        #   The Internet Protocol (IP) Address of host where the event was performed. This
        #   is an additional way to filter a report's summary using the IP address of the
        #   user whose activity is being reported. This IP address may or may not reflect
        #   the user's physical location. For example, the IP address can be the user's
        #   proxy server's address or a virtual private network (VPN) address. This
        #   parameter supports both IPv4 and IPv6 address versions.
        # @param [String] customer_id
        #   The unique ID of the customer to retrieve data for.
        # @param [String] end_time
        #   Sets the end of the range of time shown in the report. The date is in the RFC
        #   3339 format, for example 2010-10-28T10:26:35.000Z. The default value is the
        #   approximate time of the API request. An API report has three basic time
        #   concepts: - *Date of the API's request for a report*: When the API created and
        #   retrieved the report. - *Report's start time*: The beginning of the timespan
        #   shown in the report. The `startTime` must be before the `endTime` (if
        #   specified) and the current time when the request is made, or the API returns
        #   an error. - *Report's end time*: The end of the timespan shown in the report.
        #   For example, the timespan of events summarized in a report can start in April
        #   and end in May. The report itself can be requested in August. If the `endTime`
        #   is not specified, the report returns all activities from the `startTime` until
        #   the current time or the most recent 180 days if the `startTime` is more than
        #   180 days in the past.
        # @param [String] event_name
        #   The name of the event being queried by the API. Each `eventName` is related to
        #   a specific G Suite service or feature which the API organizes into types of
        #   events. An example is the Google Calendar events in the Admin console
        #   application's reports. The Calendar Settings `type` structure has all of the
        #   Calendar `eventName` activities reported by the API. When an administrator
        #   changes a Calendar setting, the API reports this activity in the Calendar
        #   Settings `type` and `eventName` parameters. For more information about `
        #   eventName` query strings and parameters, see the list of event names for
        #   various applications above in `applicationName`.
        # @param [String] filters
        #   The `filters` query string is a comma-separated list. The list is composed of
        #   event parameters that are manipulated by relational operators. Event
        #   parameters are in the form `parameter1 name[parameter1 value],parameter2 name[
        #   parameter2 value],...` These event parameters are associated with a specific `
        #   eventName`. An empty report is returned if the filtered request's parameter
        #   does not belong to the `eventName`. For more information about `eventName`
        #   parameters, see the list of event names for various applications above in `
        #   applicationName`. In the following Admin Activity example, the <> operator is
        #   URL-encoded in the request's query string (%3C%3E): GET...&eventName=
        #   CHANGE_CALENDAR_SETTING &filters=NEW_VALUE%3C%3EREAD_ONLY_ACCESS In the
        #   following Drive example, the list can be a view or edit event's `doc_id`
        #   parameter with a value that is manipulated by an 'equal to' (==) or 'not equal
        #   to' (<>) relational operator. In the first example, the report returns each
        #   edited document's `doc_id`. In the second example, the report returns each
        #   viewed document's `doc_id` that equals the value 12345 and does not return any
        #   viewed document's which have a `doc_id` value of 98765. The <> operator is URL-
        #   encoded in the request's query string (%3C%3E): GET...&eventName=edit&filters=
        #   doc_id GET...&eventName=view&filters=doc_id==12345,doc_id%3C%3E98765 The
        #   relational operators include: - `==` - 'equal to'. - `<>` - 'not equal to'. It
        #   is URL-encoded (%3C%3E). - `<` - 'less than'. It is URL-encoded (%3C). - `<=` -
        #   'less than or equal to'. It is URL-encoded (%3C=). - `>` - 'greater than'. It
        #   is URL-encoded (%3E). - `>=` - 'greater than or equal to'. It is URL-encoded (%
        #   3E=). *Note:* The API doesn't accept multiple values of a parameter. If a
        #   particular parameter is supplied more than once in the API request, the API
        #   only accepts the last value of that request parameter. In addition, if an
        #   invalid request parameter is supplied in the API request, the API ignores that
        #   request parameter and returns the response corresponding to the remaining
        #   valid request parameters. If no parameters are requested, all parameters are
        #   returned.
        # @param [String] group_id_filter
        #   Comma separated group ids (obfuscated) on which user activities are filtered,
        #   i.e, the response will contain activities for only those users that are a part
        #   of at least one of the group ids mentioned here. Format: "id:abc123,id:xyz456"
        # @param [Fixnum] max_results
        #   Determines how many activity records are shown on each response page. For
        #   example, if the request sets `maxResults=1` and the report has two activities,
        #   the report has two pages. The response's `nextPageToken` property has the
        #   token to the second page. The `maxResults` query string is optional in the
        #   request. The default value is 1000.
        # @param [String] org_unit_id
        #   ID of the organizational unit to report on. Activity records will be shown
        #   only for users who belong to the specified organizational unit. Data before
        #   Dec 17, 2018 doesn't appear in the filtered results.
        # @param [String] page_token
        #   The token to specify next page. A report with multiple pages has a `
        #   nextPageToken` property in the response. In your follow-on request getting the
        #   next page of the report, enter the `nextPageToken` value in the `pageToken`
        #   query string.
        # @param [String] start_time
        #   Sets the beginning of the range of time shown in the report. The date is in
        #   the RFC 3339 format, for example 2010-10-28T10:26:35.000Z. The report returns
        #   all activities from `startTime` until `endTime`. The `startTime` must be
        #   before the `endTime` (if specified) and the current time when the request is
        #   made, or the API returns an error.
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [Google::Apis::AdminReportsV1::Activities] parsed result object
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [Google::Apis::AdminReportsV1::Activities]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def list_activities(user_key, application_name, actor_ip_address: nil, customer_id: nil, end_time: nil, event_name: nil, filters: nil, group_id_filter: nil, max_results: nil, org_unit_id: nil, page_token: nil, start_time: nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:get, 'admin/reports/v1/activity/users/{userKey}/applications/{applicationName}', options)
          command.response_representation = Google::Apis::AdminReportsV1::Activities::Representation
          command.response_class = Google::Apis::AdminReportsV1::Activities
          command.params['userKey'] = user_key unless user_key.nil?
          command.params['applicationName'] = application_name unless application_name.nil?
          command.query['actorIpAddress'] = actor_ip_address unless actor_ip_address.nil?
          command.query['customerId'] = customer_id unless customer_id.nil?
          command.query['endTime'] = end_time unless end_time.nil?
          command.query['eventName'] = event_name unless event_name.nil?
          command.query['filters'] = filters unless filters.nil?
          command.query['groupIdFilter'] = group_id_filter unless group_id_filter.nil?
          command.query['maxResults'] = max_results unless max_results.nil?
          command.query['orgUnitID'] = org_unit_id unless org_unit_id.nil?
          command.query['pageToken'] = page_token unless page_token.nil?
          command.query['startTime'] = start_time unless start_time.nil?
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end
        
        # Start receiving notifications for account activities. For more information,
        # see Receiving Push Notifications.
        # @param [String] user_key
        #   Represents the profile ID or the user email for which the data should be
        #   filtered. Can be `all` for all information, or `userKey` for a user's unique G
        #   Suite profile ID or their primary email address.
        # @param [String] application_name
        #   Application name for which the events are to be retrieved.
        # @param [Google::Apis::AdminReportsV1::Channel] channel_object
        # @param [String] actor_ip_address
        #   The Internet Protocol (IP) Address of host where the event was performed. This
        #   is an additional way to filter a report's summary using the IP address of the
        #   user whose activity is being reported. This IP address may or may not reflect
        #   the user's physical location. For example, the IP address can be the user's
        #   proxy server's address or a virtual private network (VPN) address. This
        #   parameter supports both IPv4 and IPv6 address versions.
        # @param [String] customer_id
        #   The unique ID of the customer to retrieve data for.
        # @param [String] end_time
        #   Sets the end of the range of time shown in the report. The date is in the RFC
        #   3339 format, for example 2010-10-28T10:26:35.000Z. The default value is the
        #   approximate time of the API request. An API report has three basic time
        #   concepts: - *Date of the API's request for a report*: When the API created and
        #   retrieved the report. - *Report's start time*: The beginning of the timespan
        #   shown in the report. The `startTime` must be before the `endTime` (if
        #   specified) and the current time when the request is made, or the API returns
        #   an error. - *Report's end time*: The end of the timespan shown in the report.
        #   For example, the timespan of events summarized in a report can start in April
        #   and end in May. The report itself can be requested in August. If the `endTime`
        #   is not specified, the report returns all activities from the `startTime` until
        #   the current time or the most recent 180 days if the `startTime` is more than
        #   180 days in the past.
        # @param [String] event_name
        #   The name of the event being queried by the API. Each `eventName` is related to
        #   a specific G Suite service or feature which the API organizes into types of
        #   events. An example is the Google Calendar events in the Admin console
        #   application's reports. The Calendar Settings `type` structure has all of the
        #   Calendar `eventName` activities reported by the API. When an administrator
        #   changes a Calendar setting, the API reports this activity in the Calendar
        #   Settings `type` and `eventName` parameters. For more information about `
        #   eventName` query strings and parameters, see the list of event names for
        #   various applications above in `applicationName`.
        # @param [String] filters
        #   The `filters` query string is a comma-separated list. The list is composed of
        #   event parameters that are manipulated by relational operators. Event
        #   parameters are in the form `parameter1 name[parameter1 value],parameter2 name[
        #   parameter2 value],...` These event parameters are associated with a specific `
        #   eventName`. An empty report is returned if the filtered request's parameter
        #   does not belong to the `eventName`. For more information about `eventName`
        #   parameters, see the list of event names for various applications above in `
        #   applicationName`. In the following Admin Activity example, the <> operator is
        #   URL-encoded in the request's query string (%3C%3E): GET...&eventName=
        #   CHANGE_CALENDAR_SETTING &filters=NEW_VALUE%3C%3EREAD_ONLY_ACCESS In the
        #   following Drive example, the list can be a view or edit event's `doc_id`
        #   parameter with a value that is manipulated by an 'equal to' (==) or 'not equal
        #   to' (<>) relational operator. In the first example, the report returns each
        #   edited document's `doc_id`. In the second example, the report returns each
        #   viewed document's `doc_id` that equals the value 12345 and does not return any
        #   viewed document's which have a `doc_id` value of 98765. The <> operator is URL-
        #   encoded in the request's query string (%3C%3E): GET...&eventName=edit&filters=
        #   doc_id GET...&eventName=view&filters=doc_id==12345,doc_id%3C%3E98765 The
        #   relational operators include: - `==` - 'equal to'. - `<>` - 'not equal to'. It
        #   is URL-encoded (%3C%3E). - `<` - 'less than'. It is URL-encoded (%3C). - `<=` -
        #   'less than or equal to'. It is URL-encoded (%3C=). - `>` - 'greater than'. It
        #   is URL-encoded (%3E). - `>=` - 'greater than or equal to'. It is URL-encoded (%
        #   3E=). *Note:* The API doesn't accept multiple values of a parameter. If a
        #   particular parameter is supplied more than once in the API request, the API
        #   only accepts the last value of that request parameter. In addition, if an
        #   invalid request parameter is supplied in the API request, the API ignores that
        #   request parameter and returns the response corresponding to the remaining
        #   valid request parameters. If no parameters are requested, all parameters are
        #   returned.
        # @param [String] group_id_filter
        #   Comma separated group ids (obfuscated) on which user activities are filtered,
        #   i.e, the response will contain activities for only those users that are a part
        #   of at least one of the group ids mentioned here. Format: "id:abc123,id:xyz456"
        # @param [Fixnum] max_results
        #   Determines how many activity records are shown on each response page. For
        #   example, if the request sets `maxResults=1` and the report has two activities,
        #   the report has two pages. The response's `nextPageToken` property has the
        #   token to the second page. The `maxResults` query string is optional in the
        #   request. The default value is 1000.
        # @param [String] org_unit_id
        #   ID of the organizational unit to report on. Activity records will be shown
        #   only for users who belong to the specified organizational unit. Data before
        #   Dec 17, 2018 doesn't appear in the filtered results.
        # @param [String] page_token
        #   The token to specify next page. A report with multiple pages has a `
        #   nextPageToken` property in the response. In your follow-on request getting the
        #   next page of the report, enter the `nextPageToken` value in the `pageToken`
        #   query string.
        # @param [String] start_time
        #   Sets the beginning of the range of time shown in the report. The date is in
        #   the RFC 3339 format, for example 2010-10-28T10:26:35.000Z. The report returns
        #   all activities from `startTime` until `endTime`. The `startTime` must be
        #   before the `endTime` (if specified) and the current time when the request is
        #   made, or the API returns an error.
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [Google::Apis::AdminReportsV1::Channel] parsed result object
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [Google::Apis::AdminReportsV1::Channel]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def watch_activity(user_key, application_name, channel_object = nil, actor_ip_address: nil, customer_id: nil, end_time: nil, event_name: nil, filters: nil, group_id_filter: nil, max_results: nil, org_unit_id: nil, page_token: nil, start_time: nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:post, 'admin/reports/v1/activity/users/{userKey}/applications/{applicationName}/watch', options)
          command.request_representation = Google::Apis::AdminReportsV1::Channel::Representation
          command.request_object = channel_object
          command.response_representation = Google::Apis::AdminReportsV1::Channel::Representation
          command.response_class = Google::Apis::AdminReportsV1::Channel
          command.params['userKey'] = user_key unless user_key.nil?
          command.params['applicationName'] = application_name unless application_name.nil?
          command.query['actorIpAddress'] = actor_ip_address unless actor_ip_address.nil?
          command.query['customerId'] = customer_id unless customer_id.nil?
          command.query['endTime'] = end_time unless end_time.nil?
          command.query['eventName'] = event_name unless event_name.nil?
          command.query['filters'] = filters unless filters.nil?
          command.query['groupIdFilter'] = group_id_filter unless group_id_filter.nil?
          command.query['maxResults'] = max_results unless max_results.nil?
          command.query['orgUnitID'] = org_unit_id unless org_unit_id.nil?
          command.query['pageToken'] = page_token unless page_token.nil?
          command.query['startTime'] = start_time unless start_time.nil?
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end
        
        # Stop watching resources through this channel.
        # @param [Google::Apis::AdminReportsV1::Channel] channel_object
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [NilClass] No result returned for this method
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [void]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def stop_channel(channel_object = nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:post, 'admin/reports_v1/channels/stop', options)
          command.request_representation = Google::Apis::AdminReportsV1::Channel::Representation
          command.request_object = channel_object
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end
        
        # Retrieves a report which is a collection of properties and statistics for a
        # specific customer's account. For more information, see the Customers Usage
        # Report guide. For more information about the customer report's parameters, see
        # the Customers Usage parameters reference guides.
        # @param [String] date
        #   Represents the date the usage occurred. The timestamp is in the ISO 8601
        #   format, yyyy-mm-dd. We recommend you use your account's time zone for this.
        # @param [String] customer_id
        #   The unique ID of the customer to retrieve data for.
        # @param [String] page_token
        #   Token to specify next page. A report with multiple pages has a `nextPageToken`
        #   property in the response. For your follow-on requests getting all of the
        #   report's pages, enter the `nextPageToken` value in the `pageToken` query
        #   string.
        # @param [String] parameters
        #   The `parameters` query string is a comma-separated list of event parameters
        #   that refine a report's results. The parameter is associated with a specific
        #   application. The application values for the Customers usage report include `
        #   accounts`, `app_maker`, `apps_scripts`, `calendar`, `classroom`, `cros`, `docs`
        #   , `gmail`, `gplus`, `device_management`, `meet`, and `sites`. A `parameters`
        #   query string is in the CSV form of `app_name1:param_name1, app_name2:
        #   param_name2`. *Note:* The API doesn't accept multiple values of a parameter.
        #   If a particular parameter is supplied more than once in the API request, the
        #   API only accepts the last value of that request parameter. In addition, if an
        #   invalid request parameter is supplied in the API request, the API ignores that
        #   request parameter and returns the response corresponding to the remaining
        #   valid request parameters. An example of an invalid request parameter is one
        #   that does not belong to the application. If no parameters are requested, all
        #   parameters are returned.
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [Google::Apis::AdminReportsV1::UsageReports] parsed result object
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [Google::Apis::AdminReportsV1::UsageReports]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def get_customer_usage_report(date, customer_id: nil, page_token: nil, parameters: nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:get, 'admin/reports/v1/usage/dates/{date}', options)
          command.response_representation = Google::Apis::AdminReportsV1::UsageReports::Representation
          command.response_class = Google::Apis::AdminReportsV1::UsageReports
          command.params['date'] = date unless date.nil?
          command.query['customerId'] = customer_id unless customer_id.nil?
          command.query['pageToken'] = page_token unless page_token.nil?
          command.query['parameters'] = parameters unless parameters.nil?
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end
        
        # Retrieves a report which is a collection of properties and statistics for
        # entities used by users within the account. For more information, see the
        # Entities Usage Report guide. For more information about the entities report's
        # parameters, see the Entities Usage parameters reference guides.
        # @param [String] entity_type
        #   Represents the type of entity for the report.
        # @param [String] entity_key
        #   Represents the key of the object to filter the data with.
        # @param [String] date
        #   Represents the date the usage occurred. The timestamp is in the ISO 8601
        #   format, yyyy-mm-dd. We recommend you use your account's time zone for this.
        # @param [String] customer_id
        #   The unique ID of the customer to retrieve data for.
        # @param [String] filters
        #   The `filters` query string is a comma-separated list of an application's event
        #   parameters where the parameter's value is manipulated by a relational operator.
        #   The `filters` query string includes the name of the application whose usage
        #   is returned in the report. The application values for the Entities usage
        #   report include `accounts`, `docs`, and `gmail`. Filters are in the form `[
        #   application name]:parameter name[parameter value],...`. In this example, the `<
        #   >` 'not equal to' operator is URL-encoded in the request's query string (%3C%
        #   3E): GET https://www.googleapis.com/admin/reports/v1/usage/gplus_communities/
        #   all/dates/2017-12-01 ?parameters=gplus:community_name,gplus:num_total_members &
        #   filters=gplus:num_total_members%3C%3E0 The relational operators include: - `==`
        #   - 'equal to'. - `<>` - 'not equal to'. It is URL-encoded (%3C%3E). - `<` - '
        #   less than'. It is URL-encoded (%3C). - `<=` - 'less than or equal to'. It is
        #   URL-encoded (%3C=). - `>` - 'greater than'. It is URL-encoded (%3E). - `>=` - '
        #   greater than or equal to'. It is URL-encoded (%3E=). Filters can only be
        #   applied to numeric parameters.
        # @param [Fixnum] max_results
        #   Determines how many activity records are shown on each response page. For
        #   example, if the request sets `maxResults=1` and the report has two activities,
        #   the report has two pages. The response's `nextPageToken` property has the
        #   token to the second page.
        # @param [String] page_token
        #   Token to specify next page. A report with multiple pages has a `nextPageToken`
        #   property in the response. In your follow-on request getting the next page of
        #   the report, enter the `nextPageToken` value in the `pageToken` query string.
        # @param [String] parameters
        #   The `parameters` query string is a comma-separated list of event parameters
        #   that refine a report's results. The parameter is associated with a specific
        #   application. The application values for the Entities usage report are only `
        #   gplus`. A `parameter` query string is in the CSV form of `[app_name1:
        #   param_name1], [app_name2:param_name2]...`. *Note:* The API doesn't accept
        #   multiple values of a parameter. If a particular parameter is supplied more
        #   than once in the API request, the API only accepts the last value of that
        #   request parameter. In addition, if an invalid request parameter is supplied in
        #   the API request, the API ignores that request parameter and returns the
        #   response corresponding to the remaining valid request parameters. An example
        #   of an invalid request parameter is one that does not belong to the application.
        #   If no parameters are requested, all parameters are returned.
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [Google::Apis::AdminReportsV1::UsageReports] parsed result object
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [Google::Apis::AdminReportsV1::UsageReports]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def get_entity_usage_report(entity_type, entity_key, date, customer_id: nil, filters: nil, max_results: nil, page_token: nil, parameters: nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:get, 'admin/reports/v1/usage/{entityType}/{entityKey}/dates/{date}', options)
          command.response_representation = Google::Apis::AdminReportsV1::UsageReports::Representation
          command.response_class = Google::Apis::AdminReportsV1::UsageReports
          command.params['entityType'] = entity_type unless entity_type.nil?
          command.params['entityKey'] = entity_key unless entity_key.nil?
          command.params['date'] = date unless date.nil?
          command.query['customerId'] = customer_id unless customer_id.nil?
          command.query['filters'] = filters unless filters.nil?
          command.query['maxResults'] = max_results unless max_results.nil?
          command.query['pageToken'] = page_token unless page_token.nil?
          command.query['parameters'] = parameters unless parameters.nil?
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end
        
        # Retrieves a report which is a collection of properties and statistics for a
        # set of users with the account. For more information, see the User Usage Report
        # guide. For more information about the user report's parameters, see the Users
        # Usage parameters reference guides.
        # @param [String] user_key
        #   Represents the profile ID or the user email for which the data should be
        #   filtered. Can be `all` for all information, or `userKey` for a user's unique G
        #   Suite profile ID or their primary email address.
        # @param [String] date
        #   Represents the date the usage occurred. The timestamp is in the ISO 8601
        #   format, yyyy-mm-dd. We recommend you use your account's time zone for this.
        # @param [String] customer_id
        #   The unique ID of the customer to retrieve data for.
        # @param [String] filters
        #   The `filters` query string is a comma-separated list of an application's event
        #   parameters where the parameter's value is manipulated by a relational operator.
        #   The `filters` query string includes the name of the application whose usage
        #   is returned in the report. The application values for the Users Usage Report
        #   include `accounts`, `docs`, and `gmail`. Filters are in the form `[application
        #   name]:parameter name[parameter value],...`. In this example, the `<>` 'not
        #   equal to' operator is URL-encoded in the request's query string (%3C%3E): GET
        #   https://www.googleapis.com/admin/reports/v1/usage/users/all/dates/2013-03-03 ?
        #   parameters=accounts:last_login_time &filters=accounts:last_login_time%3C%
        #   3E2010-10-28T10:26:35.000Z The relational operators include: - `==` - 'equal
        #   to'. - `<>` - 'not equal to'. It is URL-encoded (%3C%3E). - `<` - 'less than'.
        #   It is URL-encoded (%3C). - `<=` - 'less than or equal to'. It is URL-encoded (%
        #   3C=). - `>` - 'greater than'. It is URL-encoded (%3E). - `>=` - 'greater than
        #   or equal to'. It is URL-encoded (%3E=).
        # @param [String] group_id_filter
        #   Comma separated group ids (obfuscated) on which user activities are filtered,
        #   i.e, the response will contain activities for only those users that are a part
        #   of at least one of the group ids mentioned here. Format: "id:abc123,id:xyz456"
        # @param [Fixnum] max_results
        #   Determines how many activity records are shown on each response page. For
        #   example, if the request sets `maxResults=1` and the report has two activities,
        #   the report has two pages. The response's `nextPageToken` property has the
        #   token to the second page. The `maxResults` query string is optional.
        # @param [String] org_unit_id
        #   ID of the organizational unit to report on. User activity will be shown only
        #   for users who belong to the specified organizational unit. Data before Dec 17,
        #   2018 doesn't appear in the filtered results.
        # @param [String] page_token
        #   Token to specify next page. A report with multiple pages has a `nextPageToken`
        #   property in the response. In your follow-on request getting the next page of
        #   the report, enter the `nextPageToken` value in the `pageToken` query string.
        # @param [String] parameters
        #   The `parameters` query string is a comma-separated list of event parameters
        #   that refine a report's results. The parameter is associated with a specific
        #   application. The application values for the Customers Usage report include `
        #   accounts`, `app_maker`, `apps_scripts`, `calendar`, `classroom`, `cros`, `docs`
        #   , `gmail`, `gplus`, `device_management`, `meet`, and `sites`. A `parameters`
        #   query string is in the CSV form of `app_name1:param_name1, app_name2:
        #   param_name2`. *Note:* The API doesn't accept multiple values of a parameter.
        #   If a particular parameter is supplied more than once in the API request, the
        #   API only accepts the last value of that request parameter. In addition, if an
        #   invalid request parameter is supplied in the API request, the API ignores that
        #   request parameter and returns the response corresponding to the remaining
        #   valid request parameters. An example of an invalid request parameter is one
        #   that does not belong to the application. If no parameters are requested, all
        #   parameters are returned.
        # @param [String] fields
        #   Selector specifying which fields to include in a partial response.
        # @param [String] quota_user
        #   Available to use for quota purposes for server-side applications. Can be any
        #   arbitrary string assigned to a user, but should not exceed 40 characters.
        # @param [Google::Apis::RequestOptions] options
        #   Request-specific options
        #
        # @yield [result, err] Result & error if block supplied
        # @yieldparam result [Google::Apis::AdminReportsV1::UsageReports] parsed result object
        # @yieldparam err [StandardError] error object if request failed
        #
        # @return [Google::Apis::AdminReportsV1::UsageReports]
        #
        # @raise [Google::Apis::ServerError] An error occurred on the server and the request can be retried
        # @raise [Google::Apis::ClientError] The request is invalid and should not be retried without modification
        # @raise [Google::Apis::AuthorizationError] Authorization is required
        def get_user_usage_report(user_key, date, customer_id: nil, filters: nil, group_id_filter: nil, max_results: nil, org_unit_id: nil, page_token: nil, parameters: nil, fields: nil, quota_user: nil, options: nil, &block)
          command = make_simple_command(:get, 'admin/reports/v1/usage/users/{userKey}/dates/{date}', options)
          command.response_representation = Google::Apis::AdminReportsV1::UsageReports::Representation
          command.response_class = Google::Apis::AdminReportsV1::UsageReports
          command.params['userKey'] = user_key unless user_key.nil?
          command.params['date'] = date unless date.nil?
          command.query['customerId'] = customer_id unless customer_id.nil?
          command.query['filters'] = filters unless filters.nil?
          command.query['groupIdFilter'] = group_id_filter unless group_id_filter.nil?
          command.query['maxResults'] = max_results unless max_results.nil?
          command.query['orgUnitID'] = org_unit_id unless org_unit_id.nil?
          command.query['pageToken'] = page_token unless page_token.nil?
          command.query['parameters'] = parameters unless parameters.nil?
          command.query['fields'] = fields unless fields.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
          execute_or_queue_command(command, &block)
        end

        protected

        def apply_command_defaults(command)
          command.query['key'] = key unless key.nil?
          command.query['quotaUser'] = quota_user unless quota_user.nil?
        end
      end
    end
  end
end