Skip to main content

BackendMessage

Enum BackendMessage 

Source
pub enum BackendMessage {
Show 24 variants AuthenticationOk, AuthenticationMD5Password([u8; 4]), AuthenticationSASL(Vec<String>), AuthenticationSASLContinue(Vec<u8>), AuthenticationSASLFinal(Vec<u8>), ParameterStatus { name: String, value: String, }, BackendKeyData { process_id: i32, secret_key: i32, }, ReadyForQuery(TransactionStatus), RowDescription(Vec<FieldDescription>), DataRow(Vec<Option<Vec<u8>>>), CommandComplete(String), ErrorResponse(ErrorFields), ParseComplete, BindComplete, NoData, CopyInResponse { format: u8, column_formats: Vec<u8>, }, CopyOutResponse { format: u8, column_formats: Vec<u8>, }, CopyData(Vec<u8>), CopyDone, NotificationResponse { process_id: i32, channel: String, payload: String, }, EmptyQueryResponse, NoticeResponse(ErrorFields), ParameterDescription(Vec<u32>), CloseComplete,
}
Expand description

Backend (server → client) message types

Variants§

§

AuthenticationOk

Authentication request Authentication succeeded.

§

AuthenticationMD5Password([u8; 4])

Server requests MD5-hashed password; salt provided.

§

AuthenticationSASL(Vec<String>)

Server initiates SASL handshake with supported mechanisms.

§

AuthenticationSASLContinue(Vec<u8>)

SASL challenge from server.

§

AuthenticationSASLFinal(Vec<u8>)

SASL authentication complete; final server data.

§

ParameterStatus

Parameter status (server config)

Fields

§name: String

Parameter name (e.g. server_version, TimeZone).

§value: String

Current parameter value.

§

BackendKeyData

Backend key data (for cancel)

Fields

§process_id: i32

Backend process ID (used for cancel requests).

§secret_key: i32

Cancel secret key.

§

ReadyForQuery(TransactionStatus)

Server is ready; transaction state indicated.

§

RowDescription(Vec<FieldDescription>)

Column metadata for the upcoming data rows.

§

DataRow(Vec<Option<Vec<u8>>>)

One data row; each element is None for SQL NULL or the raw bytes.

§

CommandComplete(String)

Command completed with a tag like SELECT 5 or INSERT 0 1.

§

ErrorResponse(ErrorFields)

Error response with structured fields (severity, code, message, etc.).

§

ParseComplete

Parse step succeeded.

§

BindComplete

Bind step succeeded.

§

NoData

Describe returned no row description (e.g. for DML statements).

§

CopyInResponse

Copy in response (server ready to receive COPY data)

Fields

§format: u8

Overall format: 0 = text, 1 = binary.

§column_formats: Vec<u8>

Per-column format codes.

§

CopyOutResponse

Copy out response (server will send COPY data)

Fields

§format: u8

Overall format: 0 = text, 1 = binary.

§column_formats: Vec<u8>

Per-column format codes.

§

CopyData(Vec<u8>)

Raw COPY data chunk from the server.

§

CopyDone

COPY transfer complete.

§

NotificationResponse

Notification response (async notification from LISTEN/NOTIFY)

Fields

§process_id: i32

Backend process ID that sent the notification.

§channel: String

Channel name.

§payload: String

Notification payload string.

§

EmptyQueryResponse

Empty query string was submitted.

§

NoticeResponse(ErrorFields)

Notice response (warning/info messages, not errors)

§

ParameterDescription(Vec<u32>)

Parameter description (OIDs of parameters in a prepared statement) Sent by server in response to Describe(Statement)

§

CloseComplete

Close complete (server confirmation that a prepared statement/portal was released)

Implementations§

Source§

impl BackendMessage

Source

pub fn decode(buf: &[u8]) -> Result<(Self, usize), String>

Decode a message from wire bytes.

Trait Implementations§

Source§

impl Clone for BackendMessage

Source§

fn clone(&self) -> BackendMessage

Returns a duplicate 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 Debug for BackendMessage

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§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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>,

Source§

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>,

Source§

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<T> ColumnValue<Value> for T