pub struct PermissionsServiceClient<T> { /* private fields */ }
Expand description

PermissionsService implements a set of RPCs that perform operations on relationships and permissions.

Implementations§

source§

impl PermissionsServiceClient<Channel>

source

pub async fn connect<D>(dst: D) -> Result<Self, Error>
where D: TryInto<Endpoint>, D::Error: Into<StdError>,

Attempt to create a new client by connecting to a given endpoint.

source§

impl<T> PermissionsServiceClient<T>
where T: GrpcService<BoxBody>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,

source

pub fn new(inner: T) -> Self

source

pub fn with_origin(inner: T, origin: Uri) -> Self

source

pub fn with_interceptor<F>( inner: T, interceptor: F, ) -> PermissionsServiceClient<InterceptedService<T, F>>
where F: Interceptor, T::ResponseBody: Default, T: Service<Request<BoxBody>, Response = Response<<T as GrpcService<BoxBody>>::ResponseBody>>, <T as Service<Request<BoxBody>>>::Error: Into<StdError> + Send + Sync,

source

pub fn send_compressed(self, encoding: CompressionEncoding) -> Self

Compress requests with the given encoding.

This requires the server to support it otherwise it might respond with an error.

source

pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self

Enable decompressing responses.

source

pub fn max_decoding_message_size(self, limit: usize) -> Self

Limits the maximum size of a decoded message.

Default: 4MB

source

pub fn max_encoding_message_size(self, limit: usize) -> Self

Limits the maximum size of an encoded message.

Default: usize::MAX

source

pub async fn read_relationships( &mut self, request: impl IntoRequest<ReadRelationshipsRequest>, ) -> Result<Response<Streaming<ReadRelationshipsResponse>>, Status>

ReadRelationships reads a set of the relationships matching one or more filters.

source

pub async fn write_relationships( &mut self, request: impl IntoRequest<WriteRelationshipsRequest>, ) -> Result<Response<WriteRelationshipsResponse>, Status>

WriteRelationships atomically writes and/or deletes a set of specified relationships. An optional set of preconditions can be provided that must be satisfied for the operation to commit.

source

pub async fn delete_relationships( &mut self, request: impl IntoRequest<DeleteRelationshipsRequest>, ) -> Result<Response<DeleteRelationshipsResponse>, Status>

DeleteRelationships atomically bulk deletes all relationships matching the provided filter. If no relationships match, none will be deleted and the operation will succeed. An optional set of preconditions can be provided that must be satisfied for the operation to commit.

source

pub async fn check_permission( &mut self, request: impl IntoRequest<CheckPermissionRequest>, ) -> Result<Response<CheckPermissionResponse>, Status>

CheckPermission determines for a given resource whether a subject computes to having a permission or is a direct member of a particular relation.

source

pub async fn check_bulk_permissions( &mut self, request: impl IntoRequest<CheckBulkPermissionsRequest>, ) -> Result<Response<CheckBulkPermissionsResponse>, Status>

CheckBulkPermissions evaluates the given list of permission checks and returns the list of results.

source

pub async fn expand_permission_tree( &mut self, request: impl IntoRequest<ExpandPermissionTreeRequest>, ) -> Result<Response<ExpandPermissionTreeResponse>, Status>

ExpandPermissionTree reveals the graph structure for a resource’s permission or relation. This RPC does not recurse infinitely deep and may require multiple calls to fully unnest a deeply nested graph.

source

pub async fn lookup_resources( &mut self, request: impl IntoRequest<LookupResourcesRequest>, ) -> Result<Response<Streaming<LookupResourcesResponse>>, Status>

LookupResources returns all the resources of a given type that a subject can access whether via a computed permission or relation membership.

source

pub async fn lookup_subjects( &mut self, request: impl IntoRequest<LookupSubjectsRequest>, ) -> Result<Response<Streaming<LookupSubjectsResponse>>, Status>

LookupSubjects returns all the subjects of a given type that have access whether via a computed permission or relation membership.

Trait Implementations§

source§

impl<T: Clone> Clone for PermissionsServiceClient<T>

source§

fn clone(&self) -> PermissionsServiceClient<T>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: Debug> Debug for PermissionsServiceClient<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromRef<T> for T
where T: Clone,

source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more