Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/raku-community-modules/email-sendgrid
A Raku module for basic use of the SendGrid API for sending email.
https://github.com/raku-community-modules/email-sendgrid
email raku sendgrid-api
Last synced: 12 days ago
JSON representation
A Raku module for basic use of the SendGrid API for sending email.
- Host: GitHub
- URL: https://github.com/raku-community-modules/email-sendgrid
- Owner: raku-community-modules
- License: artistic-2.0
- Created: 2020-02-04T17:01:50.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-12-25T11:02:41.000Z (13 days ago)
- Last Synced: 2024-12-25T11:29:01.224Z (13 days ago)
- Topics: email, raku, sendgrid-api
- Language: Raku
- Homepage: https://raku.land/zef:raku-community-modules/Email::SendGrid
- Size: 4.88 KB
- Stars: 2
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Actions Status](https://github.com/raku-community-modules/Email-SendGrid/actions/workflows/linux.yml/badge.svg)](https://github.com/raku-community-modules/Email-SendGrid/actions) [![Actions Status](https://github.com/raku-community-modules/Email-SendGrid/actions/workflows/macos.yml/badge.svg)](https://github.com/raku-community-modules/Email-SendGrid/actions) [![Actions Status](https://github.com/raku-community-modules/Email-SendGrid/actions/workflows/windows.yml/badge.svg)](https://github.com/raku-community-modules/Email-SendGrid/actions)
NAME
====Email::SendGrid - Basic email sending via the SendGrid API
DESCRIPTION
===========A basic Raku module for sending email using the [SendGrid Web API (v3)](https://www.twilio.com/docs/sendgrid/for-developers/sending-email/api-getting-started).
At the time of writing, SendGrid allows sending up to 100 emails a day free of charge. This module most certainly does not provide full coverage of the SendGrid API; if you need more, pull requests are welcome.
Usage
=====Construct an `Eamil::SendGrid` object using your SendGrid API key:
```raku
my $sendgrid = Email::SendGrid.new(api-key => 'your_key_here');
```Then call `send-mail` to send email:
```raku
$sendgrid.send-mail:
from => address('[email protected]', 'Sender name'),
to => address('[email protected]', 'Recipient name'),
subject => 'Yay, SendGrid works!',
content => {
'text/plain' => 'This is the plain text message',
'text/html' => 'HTML mail!'
};
```It is not required to including a HTML version of the body. Optionally, pass `cc`, `bcc`, and `reply-to` to send these addresses. It is also possible to pass a list of up to 1000 addresses to `to`, `cc`, and `bcc`.
If sending the mail fails, an exception will be thrown. Since `Cro::HTTP::Client` is used internally, it will be an exception from that.
```raku
CATCH {
default {
note await .response.body;
}
}
```Pass `:async` to `send-mail` to get a `Promise` back instead. Otherwise, it will be ed for you by `send-mail`.
Class / Methods reference
=========================class Email::SendGrid
---------------------A partial implementation of the SendGrid v3 API, sufficient for using it to do basic email sending. Construct it with your API key (passed as the api-key parameter), and optionally a from address to be used for all of the emails sent. Construct with :persistent to use a persistent Cro HTTP client (can give better throughput if sending many emails).
Minimal validation of an email address - simply that it has an @ sign.
class Email::SendGrid::Address
------------------------------Pairs together a name and email address, which are often needed together in the SendGrid API. A name is optional.
Recipient lists may be an address or a list of addresses 1 to 1000 addresses.
### multi sub address
```raku
multi sub address(
) returns Mu
```Construct an Email::SendGrid::Address object from just an email address.
### multi sub address
```raku
multi sub address(
$email,
$name
) returns Mu
```Construct an Email::SendGrid::Address object from an email address and a name.
### has Str $.api-key
The SendGrid API key.
### has Email::SendGrid::Address $.from
The default from address to use.
### has Cro::HTTP::Client $.client
The Cro HTTP client used for communication.
### method send-mail
```raku
method send-mail(
:$to! where { ... },
:$cc where { ... },
:$bcc where { ... },
Email::SendGrid::Address :$from = Code.new,
Email::SendGrid::Address :$reply-to,
Str :$subject!,
:%content!,
:$async,
:$sandbox
) returns Mu
```Send an email. The C, C, and C options may be a single Address object or a list of 1 to 1000 C
objects. Only C is required; C is required if there is no object-level from address. Optionally, a C C may be provided. A C is required, as is a C<%content> hash that maps mime types into the matching bodies. If `async` is passed, the call to the API will take place asynchronously, and a C returned.AUTHOR
======Jonathan Worthington
COPYRIGHT AND LICENSE
=====================Copyright 2020 Jonathan Worthington
Copyright 2024 Raku Community
This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.