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