Class: Google::Apis::BigqueryV2::Dataset::Access

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
generated/google/apis/bigquery_v2/classes.rb,
generated/google/apis/bigquery_v2/representations.rb,
generated/google/apis/bigquery_v2/representations.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Core::JsonObjectSupport

#to_json

Methods included from Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ Access

Returns a new instance of Access.


1532
1533
1534
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1532

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#domainString

[Pick one] A domain to grant access to. Any users signed in with the domain specified will be granted the specified access. Example: "example.com". Maps to IAM policy member "domain:DOMAIN". Corresponds to the JSON property domain

Returns:

  • (String)

1484
1485
1486
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1484

def domain
  @domain
end

#group_by_emailString

[Pick one] An email address of a Google Group to grant access to. Maps to IAM policy member "group:GROUP". Corresponds to the JSON property groupByEmail

Returns:

  • (String)

1490
1491
1492
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1490

def group_by_email
  @group_by_email
end

#iam_memberString

[Pick one] Some other type of member that appears in the IAM Policy but isn't a user, group, domain, or special group. Corresponds to the JSON property iamMember

Returns:

  • (String)

1496
1497
1498
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1496

def iam_member
  @iam_member
end

#roleString

[Required] An IAM role ID that should be granted to the user, group, or domain specified in this access entry. The following legacy mappings will be applied: OWNER roles/bigquery.dataOwner WRITER roles/bigquery.dataEditor READER roles/bigquery.dataViewer This field will accept any of the above formats, but will return only the legacy format. For example, if you set this field to " roles/bigquery.dataOwner", it will be returned back as "OWNER". Corresponds to the JSON property role

Returns:

  • (String)

1506
1507
1508
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1506

def role
  @role
end

#special_groupString

[Pick one] A special group to grant access to. Possible values include: projectOwners: Owners of the enclosing project. projectReaders: Readers of the enclosing project. projectWriters: Writers of the enclosing project. allAuthenticatedUsers: All authenticated BigQuery users. Maps to similarly- named IAM members. Corresponds to the JSON property specialGroup

Returns:

  • (String)

1515
1516
1517
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1515

def special_group
  @special_group
end

#user_by_emailString

[Pick one] An email address of a user to grant access to. For example: [email protected] example.com. Maps to IAM policy member "user:EMAIL" or "serviceAccount:EMAIL". Corresponds to the JSON property userByEmail

Returns:

  • (String)

1521
1522
1523
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1521

def user_by_email
  @user_by_email
end

#viewGoogle::Apis::BigqueryV2::TableReference

[Pick one] A view from a different dataset to grant access to. Queries executed against that view will have read access to tables in this dataset. The role field is not required when this field is set. If that view is updated by any user, access to the view needs to be granted again via an update operation. Corresponds to the JSON property view


1530
1531
1532
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1530

def view
  @view
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object


1537
1538
1539
1540
1541
1542
1543
1544
1545
# File 'generated/google/apis/bigquery_v2/classes.rb', line 1537

def update!(**args)
  @domain = args[:domain] if args.key?(:domain)
  @group_by_email = args[:group_by_email] if args.key?(:group_by_email)
  @iam_member = args[:iam_member] if args.key?(:iam_member)
  @role = args[:role] if args.key?(:role)
  @special_group = args[:special_group] if args.key?(:special_group)
  @user_by_email = args[:user_by_email] if args.key?(:user_by_email)
  @view = args[:view] if args.key?(:view)
end