Class: Google::Apis::IamV1::ServiceAccount
- Inherits:
-
Object
- Object
- Google::Apis::IamV1::ServiceAccount
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- generated/google/apis/iam_v1/classes.rb,
generated/google/apis/iam_v1/representations.rb,
generated/google/apis/iam_v1/representations.rb
Overview
A service account in the Identity and Access Management API.
To create a service account, specify the project_id
and the account_id
for the account. The account_id
is unique within the project, and is used
to generate the service account email address and a stable
unique_id
.
If the account already exists, the account's resource name is returned
in the format of projects/PROJECT_ID
/serviceAccounts/ACCOUNT
. The caller
can use the name in other methods to access the account.
All other methods can identify the service account using the format
projects/
PROJECT_ID/serviceAccounts/
ACCOUNT`.
Using
-as a wildcard for the
PROJECT_IDwill infer the project from
the account. The
ACCOUNTvalue can be the
emailaddress or the
unique_id` of the service account.
Instance Attribute Summary collapse
-
#description ⇒ String
Optional.
-
#disabled ⇒ Boolean
(also: #disabled?)
The field is currently in alpha phase.
-
#display_name ⇒ String
Optional.
-
#email ⇒ String
Corresponds to the JSON property
email
. -
#etag ⇒ String
Optional.
-
#name ⇒ String
The resource name of the service account in the following format:
projects/
PROJECT_ID/serviceAccounts/
ACCOUNT``. -
#oauth2_client_id ⇒ String
This is used in conjunction with the OAuth2 clientconfig API to make three legged OAuth2 (3LO) flows to access the data of Google users.
-
#project_id ⇒ String
Corresponds to the JSON property
projectId
. -
#unique_id ⇒ String
Corresponds to the JSON property
uniqueId
.
Instance Method Summary collapse
-
#initialize(**args) ⇒ ServiceAccount
constructor
A new instance of ServiceAccount.
-
#update!(**args) ⇒ Object
Update properties of this object.
Methods included from Core::JsonObjectSupport
Methods included from Core::Hashable
Constructor Details
#initialize(**args) ⇒ ServiceAccount
Returns a new instance of ServiceAccount
1324 1325 1326 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1324 def initialize(**args) update!(**args) end |
Instance Attribute Details
#description ⇒ String
Optional. A user-specified opaque description of the service account.
Must be less than or equal to 256 UTF-8 bytes.
Corresponds to the JSON property description
1269 1270 1271 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1269 def description @description end |
#disabled ⇒ Boolean Also known as: disabled?
The field is currently in alpha phase.
Corresponds to the JSON property disabled
1275 1276 1277 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1275 def disabled @disabled end |
#display_name ⇒ String
Optional. A user-specified name for the service account.
Must be less than or equal to 100 UTF-8 bytes.
Corresponds to the JSON property displayName
1282 1283 1284 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1282 def display_name @display_name end |
#email ⇒ String
Corresponds to the JSON property email
1287 1288 1289 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1287 def email @email end |
#etag ⇒ String
Optional. Note: etag
is an inoperable legacy field that is only returned
for backwards compatibility.
Corresponds to the JSON property etag
NOTE: Values are automatically base64 encoded/decoded in the client library.
1294 1295 1296 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1294 def etag @etag end |
#name ⇒ String
The resource name of the service account in the following format:
projects/
PROJECT_ID/serviceAccounts/
ACCOUNT.
Requests using `-` as a wildcard for the `PROJECT_ID` will infer the
project from the `account` and the `ACCOUNT` value can be the `email`
address or the `unique_id` of the service account.
In responses the resource name will always be in the format
`projects/`PROJECT_ID`/serviceAccounts/`ACCOUNT
.
Corresponds to the JSON property name
1305 1306 1307 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1305 def name @name end |
#oauth2_client_id ⇒ String
This is used in conjunction with the OAuth2 clientconfig API to make
three legged OAuth2 (3LO) flows to access the data of Google users.
Corresponds to the JSON property oauth2ClientId
1312 1313 1314 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1312 def oauth2_client_id @oauth2_client_id end |
#project_id ⇒ String
Corresponds to the JSON property projectId
1317 1318 1319 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1317 def project_id @project_id end |
#unique_id ⇒ String
Corresponds to the JSON property uniqueId
1322 1323 1324 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1322 def unique_id @unique_id end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1329 def update!(**args) @description = args[:description] if args.key?(:description) @disabled = args[:disabled] if args.key?(:disabled) @display_name = args[:display_name] if args.key?(:display_name) @email = args[:email] if args.key?(:email) @etag = args[:etag] if args.key?(:etag) @name = args[:name] if args.key?(:name) @oauth2_client_id = args[:oauth2_client_id] if args.key?(:oauth2_client_id) @project_id = args[:project_id] if args.key?(:project_id) @unique_id = args[:unique_id] if args.key?(:unique_id) end |