pub struct Resource { /* private fields */ }
Expand description
A Resource python class which implements twisted.web.resource.IResource
from a Service
.
It doesn’t have a Python constructor, so it is expected to be either subclassed or returned
from a Rust function:
use std::convert::Infallible;
use bytes::Bytes;
use http::{Request, Response};
use pyo3::prelude::*;
use pyo3_twisted_web::Resource;
#[pyclass(extends=Resource)]
struct MyResource;
#[pymethods]
impl MyResource {
#[new]
fn new() -> (Self, Resource) {
let service = tower::service_fn(|_request: Request<_>| async move {
let response = Response::new(String::from("hello"));
Ok(response)
});
let super_ = Resource::from_service::<_, _, Infallible>(service);
(Self, super_)
}
}
#[pyfunction]
fn my_resource(py: Python) -> PyResult<Py<Resource>> {
let service = tower::service_fn(|_request: Request<_>| async move {
let response = Response::new(String::from("hello"));
Ok(response)
});
Py::new(py, Resource::from_service::<_, _, Infallible>(service))
}
Implementations§
Trait Implementations§
Source§impl PyClassImpl for Resource
impl PyClassImpl for Resource
Source§const DOC: &'static str = "A Resource python class which implements ``twisted.web.resource.IResource`` from a [`Service`].\nIt doesn\'t have a Python constructor, so it is expected to be either subclassed or returned\nfrom a Rust function:\n\n```rust\nuse std::convert::Infallible;\n\nuse bytes::Bytes;\nuse http::{Request, Response};\nuse pyo3::prelude::*;\n\nuse pyo3_twisted_web::Resource;\n\n#[pyclass(extends=Resource)]\nstruct MyResource;\n\n#[pymethods]\nimpl MyResource {\n #[new]\n fn new() -> (Self, Resource) {\n let service = tower::service_fn(|_request: Request<_>| async move {\n let response = Response::new(String::from(\"hello\"));\n Ok(response)\n });\n\n let super_ = Resource::from_service::<_, _, Infallible>(service);\n (Self, super_)\n }\n}\n\n#[pyfunction]\nfn my_resource(py: Python) -> PyResult<Py<Resource>> {\n let service = tower::service_fn(|_request: Request<_>| async move {\n let response = Response::new(String::from(\"hello\"));\n Ok(response)\n });\n\n Py::new(py, Resource::from_service::<_, _, Infallible>(service))\n}\n```\u{0}"
const DOC: &'static str = "A Resource python class which implements ``twisted.web.resource.IResource`` from a [`Service`].\nIt doesn\'t have a Python constructor, so it is expected to be either subclassed or returned\nfrom a Rust function:\n\n```rust\nuse std::convert::Infallible;\n\nuse bytes::Bytes;\nuse http::{Request, Response};\nuse pyo3::prelude::*;\n\nuse pyo3_twisted_web::Resource;\n\n#[pyclass(extends=Resource)]\nstruct MyResource;\n\n#[pymethods]\nimpl MyResource {\n #[new]\n fn new() -> (Self, Resource) {\n let service = tower::service_fn(|_request: Request<_>| async move {\n let response = Response::new(String::from(\"hello\"));\n Ok(response)\n });\n\n let super_ = Resource::from_service::<_, _, Infallible>(service);\n (Self, super_)\n }\n}\n\n#[pyfunction]\nfn my_resource(py: Python) -> PyResult<Py<Resource>> {\n let service = tower::service_fn(|_request: Request<_>| async move {\n let response = Response::new(String::from(\"hello\"));\n Ok(response)\n });\n\n Py::new(py, Resource::from_service::<_, _, Infallible>(service))\n}\n```\u{0}"
Class doc string
Source§const IS_BASETYPE: bool = true
const IS_BASETYPE: bool = true
#[pyclass(subclass)]
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
#[pyclass(extends=…)]
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
#[pyclass(mapping)]
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
#[pyclass(sequence)]
Source§type ThreadChecker = ThreadCheckerStub<Resource>
type ThreadChecker = ThreadCheckerStub<Resource>
This handles following two situations: Read more
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Immutable or mutable
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
The closest native ancestor. This is
PyAny
by default, and when you declare
#[pyclass(extends=PyDict)]
, it’s PyDict
.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyMethods<Resource> for PyClassImplCollector<Resource>
impl PyMethods<Resource> for PyClassImplCollector<Resource>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for Resource
impl PyTypeInfo for Resource
Source§type AsRefTarget = PyCell<Resource>
type AsRefTarget = PyCell<Resource>
Utility type to make Py::as_ref work.
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
Source§fn type_object(py: Python<'_>) -> &PyType
fn type_object(py: Python<'_>) -> &PyType
Returns the safe abstraction over the type object.
Source§fn is_type_of(object: &PyAny) -> bool
fn is_type_of(object: &PyAny) -> bool
Checks if
object
is an instance of this type or a subclass of this type.Source§fn is_exact_type_of(object: &PyAny) -> bool
fn is_exact_type_of(object: &PyAny) -> bool
Checks if
object
is an instance of this type.Auto Trait Implementations§
impl Freeze for Resource
impl !RefUnwindSafe for Resource
impl Send for Resource
impl !Sync for Resource
impl Unpin for Resource
impl !UnwindSafe for Resource
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
Mutably borrows from an owned value. Read more