Struct HttpResponse

Source
pub struct HttpResponse { /* private fields */ }
Expand description

Represents a HTTP output binding.

The following binding attributes are supported:

NameDescription
nameThe name of the parameter being bound.

Responses can be created for any type that implements Into<Body>.

§Examples

Creating a response from a string:

use azure_functions::bindings::{HttpRequest, HttpResponse};
use azure_functions::func;

#[func]
pub fn example(_req: HttpRequest) -> HttpResponse {
    "Hello world!".into()
}

Creating a response from a JSON value (see the json! macro from the serde_json crate):

use azure_functions::bindings::{HttpRequest, HttpResponse};
use azure_functions::func;
use serde_json::json;

#[func]
pub fn example(_req: HttpRequest) -> HttpResponse {
    json!({ "hello": "world" }).into()
}

Creating a response from a sequence of bytes:

use azure_functions::bindings::{HttpRequest, HttpResponse};
use azure_functions::func;

#[func]
pub fn example(_req: HttpRequest) -> HttpResponse {
    [1, 2, 3][..].into()
}

Building a custom response:

use azure_functions::bindings::{HttpRequest, HttpResponse};
use azure_functions::func;
use azure_functions::http::Status;

#[func]
pub fn example(_req: HttpRequest) -> HttpResponse {
    HttpResponse::build()
        .status(Status::MovedPermanently)
        .header("Location", "http://example.com")
        .body("The requested resource has moved to: http://example.com")
        .finish()
}

Implementations§

Source§

impl HttpResponse

Source

pub fn build() -> ResponseBuilder

Creates a new ResponseBuilder for building a response.

§Examples
use azure_functions::http::Status;

let response = HttpResponse::build().status(Status::NotFound).finish();
assert_eq!(response.status(), Status::NotFound);
Source

pub fn status(&self) -> Status

Gets the status code for the response.

§Examples
use azure_functions::http::Status;

let response = HttpResponse::build().status(Status::BadRequest).finish();
assert_eq!(response.status(), Status::BadRequest);
Source

pub fn body(&self) -> Body<'_>

Gets the body of the response.

§Examples
let response = HttpResponse::build().body("example").finish();

assert_eq!(response.body().as_str().unwrap(), "example");
Source

pub fn headers(&self) -> &HashMap<String, String>

Gets the headers of the response.

§Examples
let response = HttpResponse::build().header("Content-Type", "text/plain").finish();

assert_eq!(response.headers().get("Content-Type").unwrap(), "text/plain");

Trait Implementations§

Source§

impl Debug for HttpResponse

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for HttpResponse

Source§

fn default() -> HttpResponse

Returns the “default value” for a type. Read more
Source§

impl<'a, T> From<T> for HttpResponse
where T: Into<Body<'a>>,

Source§

fn from(data: T) -> Self

Converts to this type from the input type.

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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