pub struct Client { /* private fields */ }
Expand description

A client used to send requests to Piston.

Implementations

Creates a new client.

Returns
Example
let client = piston_rs::Client::new();

assert!(client.get_headers().contains_key("Accept"));
assert!(client.get_headers().contains_key("User-Agent"));
assert!(!client.get_headers().contains_key("Authorization"));

Creates a new Client with a url that runs the piston code execution engine.

This makes it possible to interact with a self-hosted instance of piston.

Arguments
  • url - The url to use as the underlying piston backend.
Returns
Example
let client = piston_rs::Client::with_url("http://localhost:3000");
assert_eq!(client.get_url(), "http://localhost:3000");

Creates a new client, with an api key.

Arguments
  • key - The api key to use.
Returns
Example
let client = piston_rs::Client::with_key("123abc");

assert!(client.get_headers().contains_key("Authorization"));
assert_eq!(client.get_headers().get("Authorization").unwrap(), "123abc");

Creates a new Client using a url and an api key.

Arguments
  • url - The url to use as the underlying piston backend.
  • key - The api key to use.
Returns
Example
let client = piston_rs::Client::with_url_and_key("http://localhost:3000", "123abc");
assert_eq!(client.get_url(), "http://localhost:3000");
assert!(client.get_headers().contains_key("Authorization"));
assert_eq!(client.get_headers().get("Authorization").unwrap(), "123abc");

The base url for the Piston V2 API that is being used by this client.

Returns
Example
let client = piston_rs::Client::new();

assert_eq!(client.get_url(), "https://emkc.org/api/v2/piston".to_string());

The headers being used by this client.

Returns
  • HeaderMap - A map of Header key, value pairs.
Example
let client = piston_rs::Client::new();
let headers = client.get_headers();

assert_eq!(headers.get("Accept").unwrap(), "application/json");

Fetches the runtimes from Piston. This is an http request.

Returns
Example
let client = piston_rs::Client::new();

if let Ok(runtimes) = client.fetch_runtimes().await {
    assert!(!runtimes.is_empty());
} else {
    // There was an error contacting Piston.
}

Executes code using a given executor. This is an http request.

Arguments
  • executor - The executor to use.
Returns
Example
let client = piston_rs::Client::new();
let executor = piston_rs::Executor::new()
    .set_language("rust")
    .set_version("1.50.0")
    .add_file(piston_rs::File::default().set_content(
        "fn main() { println!(\"42\"); }",
    ));

if let Ok(response) = client.execute(&executor).await {
    assert!(response.compile.is_some());
    assert!(response.run.is_ok());
    assert!(response.is_ok());
} else {
    // There was an error contacting Piston.
}

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Creates a new client. Alias for Client::new.

Returns
Example
let client = piston_rs::Client::default();

assert!(client.get_headers().contains_key("Accept"));
assert!(client.get_headers().contains_key("User-Agent"));
assert!(!client.get_headers().contains_key("Authorization"));
assert_eq!(client.get_url(), "https://emkc.org/api/v2/piston".to_string());

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more

Instruments this type with the current Span, returning an Instrumented wrapper. Read more

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more