sendr_scaleway

A sendr backend for sending emails via the Scaleway Transactional Email REST API.

Installation

gleam add sendr sendr_scaleway

Usage

import gleam/http
import sendr
import sendr/message
import sendr/message/body
import sendr/message/mailbox
import sendr_scaleway

pub fn send() {
  let cfg = sendr_scaleway.config("scw-api-key", "fr-par", "proj-123456")

  let msg =
    message.new()
    |> message.set_from(mailbox.new("Alice", "alice@example.com"))
    |> message.set_to([mailbox.new("Bob", "bob@example.com")])
    |> message.set_subject("Hello from sendr_scaleway")
    |> message.set_body(body.new() |> body.set_text("Hello world!"))

  let assert Ok(req) = sendr_scaleway.request(msg, cfg)

  // Make the HTTP request with your HTTP client of choice:
  // let resp = http_client.send(req)
  // let result = sendr_scaleway.response(resp)
}

Configuration

ScalewayConfig accepts three parameters:

ParameterDescription
api_keyYour Scaleway secret key (X-Auth-Token)
regionScaleway region (e.g. "fr-par", "nl-ams")
project_idYour Scaleway Project UUID

Shortcomings / Restrictions

Development

gleam test                                      # Run the tests
SCALEWAY_API_KEY=your_token_here \
SCALEWAY_PROJECT_ID=your_project_id gleam test  # Run integration tests and unit tests
gleam run -m devutils/glinter -- --stats        # Run the code style checks
Search Document