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
1231 1232 1233 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1231 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
1176 1177 1178 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1176 def description @description end |
#disabled ⇒ Boolean Also known as: disabled?
The field is currently in alpha phase.
Corresponds to the JSON property disabled
1182 1183 1184 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1182 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
1189 1190 1191 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1189 def display_name @display_name end |
#email ⇒ String
Corresponds to the JSON property email
1194 1195 1196 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1194 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.
1201 1202 1203 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1201 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
1212 1213 1214 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1212 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
1219 1220 1221 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1219 def oauth2_client_id @oauth2_client_id end |
#project_id ⇒ String
Corresponds to the JSON property projectId
1224 1225 1226 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1224 def project_id @project_id end |
#unique_id ⇒ String
Corresponds to the JSON property uniqueId
1229 1230 1231 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1229 def unique_id @unique_id end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 |
# File 'generated/google/apis/iam_v1/classes.rb', line 1236 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 |