1<?php
2/*
3 * Copyright 2014 Google Inc.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6 * use this file except in compliance with the License. You may obtain a copy of
7 * the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14 * License for the specific language governing permissions and limitations under
15 * the License.
16 */
17
18namespace Google\Service;
19
20use Google\Client;
21
22/**
23 * Service definition for Groupssettings (v1).
24 *
25 * <p>
26 * Manages permission levels and related settings of a group.</p>
27 *
28 * <p>
29 * For more information about this service, see the API
30 * <a href="https://developers.google.com/google-apps/groups-settings/get_started" target="_blank">Documentation</a>
31 * </p>
32 *
33 * @author Google, Inc.
34 */
35class Groupssettings extends \Google\Service
36{
37  /** View and manage the settings of a G Suite group. */
38  const APPS_GROUPS_SETTINGS =
39      "https://www.googleapis.com/auth/apps.groups.settings";
40
41  public $groups;
42
43  /**
44   * Constructs the internal representation of the Groupssettings service.
45   *
46   * @param Client|array $clientOrConfig The client used to deliver requests, or a
47   *                                     config array to pass to a new Client instance.
48   * @param string $rootUrl The root URL used for requests to the service.
49   */
50  public function __construct($clientOrConfig = [], $rootUrl = null)
51  {
52    parent::__construct($clientOrConfig);
53    $this->rootUrl = $rootUrl ?: 'https://www.googleapis.com/';
54    $this->servicePath = 'groups/v1/groups/';
55    $this->batchPath = 'batch/groupssettings/v1';
56    $this->version = 'v1';
57    $this->serviceName = 'groupssettings';
58
59    $this->groups = new Groupssettings\Resource\Groups(
60        $this,
61        $this->serviceName,
62        'groups',
63        [
64          'methods' => [
65            'get' => [
66              'path' => '{groupUniqueId}',
67              'httpMethod' => 'GET',
68              'parameters' => [
69                'groupUniqueId' => [
70                  'location' => 'path',
71                  'type' => 'string',
72                  'required' => true,
73                ],
74              ],
75            ],'patch' => [
76              'path' => '{groupUniqueId}',
77              'httpMethod' => 'PATCH',
78              'parameters' => [
79                'groupUniqueId' => [
80                  'location' => 'path',
81                  'type' => 'string',
82                  'required' => true,
83                ],
84              ],
85            ],'update' => [
86              'path' => '{groupUniqueId}',
87              'httpMethod' => 'PUT',
88              'parameters' => [
89                'groupUniqueId' => [
90                  'location' => 'path',
91                  'type' => 'string',
92                  'required' => true,
93                ],
94              ],
95            ],
96          ]
97        ]
98    );
99  }
100}
101
102// Adding a class alias for backwards compatibility with the previous class name.
103class_alias(Groupssettings::class, 'Google_Service_Groupssettings');
104