Class: Google::Apis::IamV1::ServiceAccount
- Inherits:
-
Object
- Object
- Google::Apis::IamV1::ServiceAccount
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/iam_v1/classes.rb,
lib/google/apis/iam_v1/representations.rb,
lib/google/apis/iam_v1/representations.rb
Overview
An IAM service account. A service account is an account for an application or a virtual machine (VM) instance, not a person. You can use a service account to call Google APIs. To learn more, read the overview of service accounts. When you create a service account, you specify the project ID that owns the service account, as well as a name that must be unique within the project. IAM uses these values to create an email address that identifies the service account. //
Instance Attribute Summary collapse
-
#description ⇒ String
Optional.
-
#disabled ⇒ Boolean
(also: #disabled?)
Output only.
-
#display_name ⇒ String
Optional.
-
#email ⇒ String
Output only.
-
#etag ⇒ String
Deprecated.
-
#name ⇒ String
The resource name of the service account.
-
#oauth2_client_id ⇒ String
Output only.
-
#project_id ⇒ String
Output only.
-
#unique_id ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ ServiceAccount
constructor
A new instance of ServiceAccount.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ ServiceAccount
Returns a new instance of ServiceAccount.
1794 1795 1796 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1794 def initialize(**args) update!(**args) end |
Instance Attribute Details
#description ⇒ String
Optional. A user-specified, human-readable description of the service account.
The maximum length is 256 UTF-8 bytes.
Corresponds to the JSON property description
1736 1737 1738 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1736 def description @description end |
#disabled ⇒ Boolean Also known as: disabled?
Output only. Whether the service account is disabled.
Corresponds to the JSON property disabled
1741 1742 1743 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1741 def disabled @disabled end |
#display_name ⇒ String
Optional. A user-specified, human-readable name for the service account. The
maximum length is 100 UTF-8 bytes.
Corresponds to the JSON property displayName
1748 1749 1750 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1748 def display_name @display_name end |
#email ⇒ String
Output only. The email address of the service account.
Corresponds to the JSON property email
1753 1754 1755 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1753 def email @email end |
#etag ⇒ String
Deprecated. Do not use.
Corresponds to the JSON property etag
NOTE: Values are automatically base64 encoded/decoded in the client library.
1759 1760 1761 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1759 def etag @etag end |
#name ⇒ String
The resource name of the service account. Use one of the following formats: *
projects/
PROJECT_ID/serviceAccounts/
EMAIL_ADDRESS* `projects/`PROJECT_ID`
/serviceAccounts/`UNIQUE_ID
As an alternative, you can use the -
wildcard
character instead of the project ID: * projects/-/serviceAccounts/
EMAIL_ADDRESS* `projects/-/serviceAccounts/`UNIQUE_ID
When possible,
avoid using the -
wildcard character, because it can cause response messages
to contain misleading error codes. For example, if you try to access the
service account projects/-/serviceAccounts/fake@example.com
, which does not
exist, the response contains an HTTP 403 Forbidden
error instead of a 404
Not Found
error.
Corresponds to the JSON property name
1773 1774 1775 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1773 def name @name end |
#oauth2_client_id ⇒ String
Output only. The OAuth 2.0 client ID for the service account.
Corresponds to the JSON property oauth2ClientId
1778 1779 1780 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1778 def oauth2_client_id @oauth2_client_id end |
#project_id ⇒ String
Output only. The ID of the project that owns the service account.
Corresponds to the JSON property projectId
1783 1784 1785 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1783 def project_id @project_id end |
#unique_id ⇒ String
Output only. The unique, stable numeric ID for the service account. Each
service account retains its unique ID even if you delete the service account.
For example, if you delete a service account, then create a new service
account with the same name, the new service account has a different unique ID
than the deleted service account.
Corresponds to the JSON property uniqueId
1792 1793 1794 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1792 def unique_id @unique_id end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 |
# File 'lib/google/apis/iam_v1/classes.rb', line 1799 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 |