class Azure::KeyVault::V7_2_preview::Models::RoleDefinition

Role definition.

Attributes

assignable_scopes[RW]

@return [Array<RoleScope>] Role definition assignable scopes.

description[RW]

@return [String] The role definition description.

id[RW]

@return [String] The role definition ID.

name[RW]

@return [String] The role definition name.

permissions[RW]

@return [Array<Permission>] Role definition permissions.

role_name[RW]

@return [String] The role name.

role_type[RW]

@return [RoleType] The role type. Possible values include: 'BuiltInRole', 'CustomRole'

type[RW]

@return [RoleDefinitionType] The role definition type. Possible values include: 'Microsoft.Authorization/roleDefinitions'

Private Class Methods

mapper() click to toggle source

Mapper for RoleDefinition class as Ruby Hash. This will be used for serialization/deserialization.

# File lib/7.2-preview/generated/azure_key_vault/models/role_definition.rb, line 46
def self.mapper()
  {
    client_side_validation: true,
    required: false,
    serialized_name: 'RoleDefinition',
    type: {
      name: 'Composite',
      class_name: 'RoleDefinition',
      model_properties: {
        id: {
          client_side_validation: true,
          required: false,
          read_only: true,
          serialized_name: 'id',
          type: {
            name: 'String'
          }
        },
        name: {
          client_side_validation: true,
          required: false,
          read_only: true,
          serialized_name: 'name',
          type: {
            name: 'String'
          }
        },
        type: {
          client_side_validation: true,
          required: false,
          read_only: true,
          serialized_name: 'type',
          type: {
            name: 'String'
          }
        },
        role_name: {
          client_side_validation: true,
          required: false,
          serialized_name: 'properties.roleName',
          type: {
            name: 'String'
          }
        },
        description: {
          client_side_validation: true,
          required: false,
          serialized_name: 'properties.description',
          type: {
            name: 'String'
          }
        },
        role_type: {
          client_side_validation: true,
          required: false,
          serialized_name: 'properties.type',
          type: {
            name: 'String'
          }
        },
        permissions: {
          client_side_validation: true,
          required: false,
          serialized_name: 'properties.permissions',
          type: {
            name: 'Sequence',
            element: {
                client_side_validation: true,
                required: false,
                serialized_name: 'PermissionElementType',
                type: {
                  name: 'Composite',
                  class_name: 'Permission'
                }
            }
          }
        },
        assignable_scopes: {
          client_side_validation: true,
          required: false,
          serialized_name: 'properties.assignableScopes',
          type: {
            name: 'Sequence',
            element: {
                client_side_validation: true,
                required: false,
                serialized_name: 'RoleScopeElementType',
                type: {
                  name: 'String'
                }
            }
          }
        }
      }
    }
  }
end