raven-ecp

Crates.ioraven-ecp
lib.rsraven-ecp
version0.1.1
sourcesrc
created_at2022-11-16 16:54:45.093752
updated_at2022-11-17 16:57:23.327931
descriptionSend error reports from Compute@Edge to Sentry
homepage
repositoryhttps://github.com/fastly/raven-ecp
max_upload_size
id716581
size454,472
Kailan Blanks (kailan)

documentation

README

raven-ecp

Send error reports from Rust Compute@Edge services to Sentry.

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

Usage

Add the crate to your Cargo.toml:

raven-ecp = "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> {
    let raven = Raven::from_dsn_and_backend(
        Url::parse(
            "https://abcdef@o122324.ingest.sentry.io/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
Commit count: 7

cargo fmt