Struct google_drive3::api::Permission
source · pub struct Permission {Show 15 fields
pub allow_file_discovery: Option<bool>,
pub deleted: Option<bool>,
pub display_name: Option<String>,
pub domain: Option<String>,
pub email_address: Option<String>,
pub expiration_time: Option<DateTime<Utc>>,
pub id: Option<String>,
pub kind: Option<String>,
pub pending_owner: Option<bool>,
pub permission_details: Option<Vec<PermissionPermissionDetails>>,
pub photo_link: Option<String>,
pub role: Option<String>,
pub team_drive_permission_details: Option<Vec<PermissionTeamDrivePermissionDetails>>,
pub type_: Option<String>,
pub view: Option<String>,
}
Expand description
A permission for a file. A permission grants a user, group, domain, or the world access to a file or a folder hierarchy. Some resource methods (such as permissions.update
) require a permissionId
. Use the permissions.list
method to retrieve the ID for a file, folder, or shared drive.
§Activities
This type is used in activities, which are methods you may call on this type or where this type is involved in. The list links the activity name, along with information about where it is used (one of request and response).
- create permissions (request|response)
- delete permissions (none)
- get permissions (response)
- list permissions (none)
- update permissions (request|response)
Fields§
§allow_file_discovery: Option<bool>
Whether the permission allows the file to be discovered through search. This is only applicable for permissions of type domain
or anyone
.
deleted: Option<bool>
Output only. Whether the account associated with this permission has been deleted. This field only pertains to user and group permissions.
display_name: Option<String>
Output only. The “pretty” name of the value of the permission. The following is a list of examples for each type of permission: * user
- User’s full name, as defined for their Google account, such as “Joe Smith.” * group
- Name of the Google Group, such as “The Company Administrators.” * domain
- String domain name, such as “thecompany.com.” * anyone
- No displayName
is present.
domain: Option<String>
The domain to which this permission refers.
email_address: Option<String>
The email address of the user or group to which this permission refers.
expiration_time: Option<DateTime<Utc>>
The time at which this permission will expire (RFC 3339 date-time). Expiration times have the following restrictions: - They can only be set on user and group permissions - The time must be in the future - The time cannot be more than a year in the future
id: Option<String>
Output only. The ID of this permission. This is a unique identifier for the grantee, and is published in User resources as permissionId
. IDs should be treated as opaque values.
kind: Option<String>
Output only. Identifies what kind of resource this is. Value: the fixed string "drive#permission"
.
pending_owner: Option<bool>
Whether the account associated with this permission is a pending owner. Only populated for user
type permissions for files that are not in a shared drive.
permission_details: Option<Vec<PermissionPermissionDetails>>
Output only. Details of whether the permissions on this shared drive item are inherited or directly on this item. This is an output-only field which is present only for shared drive items.
photo_link: Option<String>
Output only. A link to the user’s profile photo, if available.
role: Option<String>
The role granted by this permission. While new values may be supported in the future, the following are currently allowed: * owner
* organizer
* fileOrganizer
* writer
* commenter
* reader
team_drive_permission_details: Option<Vec<PermissionTeamDrivePermissionDetails>>
Output only. Deprecated: Output only. Use permissionDetails
instead.
type_: Option<String>
The type of the grantee. Valid values are: * user
* group
* domain
* anyone
When creating a permission, if type
is user
or group
, you must provide an emailAddress
for the user or group. When type
is domain
, you must provide a domain
. There isn’t extra information required for an anyone
type.
view: Option<String>
Indicates the view for this permission. Only populated for permissions that belong to a view. ‘published’ is the only supported value.
Trait Implementations§
source§impl Clone for Permission
impl Clone for Permission
source§fn clone(&self) -> Permission
fn clone(&self) -> Permission
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for Permission
impl Debug for Permission
source§impl Default for Permission
impl Default for Permission
source§fn default() -> Permission
fn default() -> Permission
source§impl<'de> Deserialize<'de> for Permission
impl<'de> Deserialize<'de> for Permission
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl Serialize for Permission
impl Serialize for Permission
impl RequestValue for Permission
impl Resource for Permission
impl ResponseResult for Permission
Auto Trait Implementations§
impl Freeze for Permission
impl RefUnwindSafe for Permission
impl Send for Permission
impl Sync for Permission
impl Unpin for Permission
impl UnwindSafe for Permission
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more