pub struct Cookie(/* private fields */);
Expand description
represents an RPC authentication cookie
a cookie file is created each time neptune-core is started.
local (same-device) RPC clients with read access to the cookie file can read it and provide the cookie as an auth Token when calling RPC methods.
The cookie serves a couple purposes:
- proves to neptune-core that the client is on the same device and has read access for files written by neptune-core.
- enables automated authentication without requiring user to manually set a password somewhere.
Implementations§
Source§impl Cookie
impl Cookie
Sourcepub async fn try_load(data_dir: &DataDirectory) -> Result<Self, CookieFileError>
pub async fn try_load(data_dir: &DataDirectory) -> Result<Self, CookieFileError>
try loading cookie from a file
Sourcepub async fn try_new(data_dir: &DataDirectory) -> Result<Self, CookieFileError>
pub async fn try_new(data_dir: &DataDirectory) -> Result<Self, CookieFileError>
try creating a new cookie file
This will overwrite any existing cookie file.
The overwrite is performed via rename, so should be an atomic operation on most filesystems.
note: will create missing directories in path if necessary.
Sourcepub fn auth(&self, valid: &Self) -> Result<(), AuthError>
pub fn auth(&self, valid: &Self) -> Result<(), AuthError>
authenticate against a known valid cookie
get cookie file path
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Cookie
impl<'de> Deserialize<'de> for Cookie
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>,
Deserialize this value from the given Serde deserializer. Read more
impl Copy for Cookie
impl Eq for Cookie
impl StructuralPartialEq for Cookie
Auto Trait Implementations§
impl Freeze for Cookie
impl RefUnwindSafe for Cookie
impl Send for Cookie
impl Sync for Cookie
impl Unpin for Cookie
impl UnwindSafe for Cookie
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.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>
Converts
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>
Converts
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