Skip to content

Send error reports from Rust Fastly Compute services to Sentry.

License

Notifications You must be signed in to change notification settings

fastly/compute-rust-sentry

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

compute-rust-sentry

Send error reports to Sentry from Fastly Compute services written in Rust.

A screenshot of the Sentry dashboard displaying an error in a Compute@Edge application

Usage

Add the crate to your Cargo.toml:

compute-rust-sentry = "0.1.1"

Configure the sentry backend locally (optional):

[local_server]

  [local_server.backends]

    [local_server.backends.sentry]
      url = "https://o122324.ingest.sentry.io"

Configure the sentry backend on your Fastly service:

$ fastly backend create --address o122324.ingest.sentry.io --version latest --autoclone

Wrap your main logic with an error handler in order to catch exceptions:

#[fastly::main]
fn main(req: Request) -> Result<Response, fastly::Error> {
    // Clone the request metadata so it can be attached to any reports later.
    let req_metadata = req.clone_without_body().with_header(header::COOKIE, "REDACTED");

    let raven = Raven::from_dsn_and_backend(
        Url::parse(
            "https://[email protected]/1234",
        )?,
        "sentry",
    );

    match handle_request(req) {
      Ok(resp) => Ok(resp),
      Err(err) => {
          raven.report_error(err, &req_metadata)?;
          Ok(Response::from_status(500))
      }
    }
}

fn handle_request(req: Request) -> Result<Response, fastly::Error> {
    let beresp = req.send("origin_0")?;
    Ok(beresp)
}

Re-deploy your application, trigger an error, and check the Sentry dashboard for the error report:

$ fastly compute publish