Module nitric.resources.collections
Expand source code
#
# Copyright (c) 2021 Nitric Technologies Pty Ltd.
#
# This file is part of Nitric Python 3 SDK.
# See https://github.com/nitrictech/python-sdk for further info.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
from __future__ import annotations
from nitric.api.documents import CollectionRef, Documents
from nitric.exception import exception_from_grpc_error
from typing import List, Union
from enum import Enum
from grpclib import GRPCError
from nitric.application import Nitric
from nitric.proto.nitric.resource.v1 import (
Resource,
ResourceType,
Action,
ResourceDeclareRequest,
)
from nitric.resources.base import SecureResource
class CollectionPermission(Enum):
"""Valid query expression operators."""
reading = "reading"
writing = "writing"
deleting = "deleting"
class Collection(SecureResource):
"""A document collection resource."""
def __init__(self, name: str):
"""Construct a new document collection."""
super().__init__()
self.name = name
async def _register(self):
try:
await self._resources_stub.declare(
resource_declare_request=ResourceDeclareRequest(resource=self._to_resource())
)
except GRPCError as grpc_err:
raise exception_from_grpc_error(grpc_err)
def _to_resource(self) -> Resource:
return Resource(name=self.name, type=ResourceType.Collection)
def _perms_to_actions(self, *args: Union[CollectionPermission, str]) -> List[Action]:
permission_actions_map = {
CollectionPermission.reading: [
Action.CollectionDocumentRead,
Action.CollectionQuery,
Action.CollectionList,
],
CollectionPermission.writing: [Action.CollectionDocumentWrite, Action.CollectionList],
CollectionPermission.deleting: [Action.CollectionDocumentDelete, Action.CollectionList],
}
# convert strings to the enum value where needed
perms = [
permission if isinstance(permission, CollectionPermission) else CollectionPermission[permission.lower()]
for permission in args
]
return [action for perm in perms for action in permission_actions_map[perm]]
def allow(self, *args: Union[CollectionPermission, str]) -> CollectionRef:
"""Request the required permissions for this collection."""
# Ensure registration of the resource is complete before requesting permissions.
self._register_policy(*args)
return Documents().collection(self.name)
def collection(name: str) -> Collection:
"""
Create and register a collection.
If a collection has already been registered with the same name, the original reference will be reused.
"""
return Nitric._create_resource(Collection, name)
Functions
def collection(name: str) ‑> Collection
-
Create and register a collection.
If a collection has already been registered with the same name, the original reference will be reused.
Expand source code
def collection(name: str) -> Collection: """ Create and register a collection. If a collection has already been registered with the same name, the original reference will be reused. """ return Nitric._create_resource(Collection, name)
Classes
class Collection (name: str)
-
A document collection resource.
Construct a new document collection.
Expand source code
class Collection(SecureResource): """A document collection resource.""" def __init__(self, name: str): """Construct a new document collection.""" super().__init__() self.name = name async def _register(self): try: await self._resources_stub.declare( resource_declare_request=ResourceDeclareRequest(resource=self._to_resource()) ) except GRPCError as grpc_err: raise exception_from_grpc_error(grpc_err) def _to_resource(self) -> Resource: return Resource(name=self.name, type=ResourceType.Collection) def _perms_to_actions(self, *args: Union[CollectionPermission, str]) -> List[Action]: permission_actions_map = { CollectionPermission.reading: [ Action.CollectionDocumentRead, Action.CollectionQuery, Action.CollectionList, ], CollectionPermission.writing: [Action.CollectionDocumentWrite, Action.CollectionList], CollectionPermission.deleting: [Action.CollectionDocumentDelete, Action.CollectionList], } # convert strings to the enum value where needed perms = [ permission if isinstance(permission, CollectionPermission) else CollectionPermission[permission.lower()] for permission in args ] return [action for perm in perms for action in permission_actions_map[perm]] def allow(self, *args: Union[CollectionPermission, str]) -> CollectionRef: """Request the required permissions for this collection.""" # Ensure registration of the resource is complete before requesting permissions. self._register_policy(*args) return Documents().collection(self.name)
Ancestors
- SecureResource
- BaseResource
- abc.ABC
Methods
def allow(self, *args: Union[CollectionPermission, str]) ‑> CollectionRef
-
Request the required permissions for this collection.
Expand source code
def allow(self, *args: Union[CollectionPermission, str]) -> CollectionRef: """Request the required permissions for this collection.""" # Ensure registration of the resource is complete before requesting permissions. self._register_policy(*args) return Documents().collection(self.name)
Inherited members
class CollectionPermission (value, names=None, *, module=None, qualname=None, type=None, start=1)
-
Valid query expression operators.
Expand source code
class CollectionPermission(Enum): """Valid query expression operators.""" reading = "reading" writing = "writing" deleting = "deleting"
Ancestors
- enum.Enum
Class variables
var deleting
var reading
var writing