首页
/ Mailgun Rubygem 技术文档

Mailgun Rubygem 技术文档

2024-12-27 15:04:58作者:江焘钦

1. 安装指南

在开始使用 Mailgun Rubygem 之前,请确保您的环境中已经安装了 Ruby。以下是安装指南:

gem install mailgun

2. 项目的使用说明

Mailgun Rubygem 是一个 Ruby 库,允许您在 Ruby 应用程序中以直观的方式使用 Mailgun 服务。Mailgun 是一项电子邮件即服务(email-as-a-service),让您使用电子邮件变得更加合理。

配置

首先,您需要初始化 Mailgun 对象并配置 API 密钥和域名:

Mailgun.configure do |config|
  config.api_key = 'your-api-key'
  config.domain  = 'your-mailgun-domain'
end

@mailgun = Mailgun()

发送电子邮件

以下是发送电子邮件的基本示例:

parameters = {
  :to => "cooldev@your.mailgun.domain",
  :subject => "missing tps reports",
  :text => "yeah, we're gonna need you to come in on friday...yeah.",
  :from => "lumberg.bill@initech.mailgun.domain"
}
@mailgun.messages.send_email(parameters)

邮件列表

邮件列表相关的操作如下:

# 创建邮件列表
@mailgun.lists.create "devs@your.mailgun.domain"

# 列出所有邮件列表
@mailgun.lists.list

# 查找邮件列表
@mailgun.lists.find "devs@your.mailgun.domain"

# 更新邮件列表
@mailgun.lists.update("devs@your.mailgun.domain", "developers@your.mailgun.domain", "Developers", "Developer Mailing List")

# 删除邮件列表
@mailgun.lists.delete("developers@your.mailgun.domain")

邮件列表成员

邮件列表成员的操作包括:

# 列出邮件列表中的所有成员
@mailgun.list_members.list "devs@your.mailgun.domain"

# 在邮件列表中查找特定成员
@mailgun.list_members.find "devs@your.mailgun.domain", "bond@mi6.co.uk"

# 向邮件列表添加成员
@mailgun.list_members.add "devs@your.mailgun.domain", "Q@mi6.co.uk"

# 向邮件列表添加多个成员
@mailgun.list_members.add_multi "devs@your.mailgun.domain", [{"address": "Alice <alice@example.com>", "vars": {"age": 26}}, {"name": "Bob", "address": "bob@example.com", "vars": {"age": 34}}].to_json, {:upsert => true}
    
# 更新邮件列表中的成员信息
@mailgun.list_members.update "devs@your.mailgun.domain", "Q@mi6.co.uk", "Q", {:gender => 'male'}.to_json, :subscribed => 'no'

# 从邮件列表中移除成员
@mailgun.list_members.remove "devs@your.mailgun.domain", "M@mi6.co.uk"

邮箱

邮箱相关的操作包括:

# 创建邮箱
@mailgun.mailboxes.create "new-mailbox@your-domain.com", "password"

# 列出属于域的所有邮箱
@mailgun.mailboxes.list "domain.com"

# 销毁邮箱
@mailgun.mailboxes.destroy "bond@mi6.co.uk"

路由

路由操作如下:

# 创建路由
@mailgun.routes.create "Description for the new route", 1,
     [:match_recipient, "apowers@mi5.co.uk"],
     [[:forward, "http://my-site.com/incoming-mail-route"], [:stop]]

# 列出属于域的所有路由
@mailgun.routes.list 100, 0

# 通过 id 获取路由详情
@mailgun.routes.find "4e97c1b2ba8a48567f007fb6"

# 通过 id 更新路由
@mailgun.routes.update "4e97c1b2ba8a48567f007fb6", {
     :priority   => 2,
     :expression => [:match_header, :subject, "*.support"],
     :actions    => [[:forward, "http://new-site.com/incoming-emails"]]
     }

# 通过 id 销毁路由
@mailgun.routes.destroy "4e97c1b2ba8a48567f007fb6"

域名

域名操作如下:

# 添加域名
@mailgun.domains.create "example.com"

# 列出所有域名
@mailgun.domains.list

# 获取域名信息
@mailgun.domains.find "example.com"

# 删除域名
@mailgun.domains.delete "example.com"

Webhooks

Webhooks 操作包括:

# 获取可用的 webhooks 列表
@mailgun.webhooks.available_ids

# 获取指定域的 webhooks 列表
@mailgun.webhooks.list

# 获取指定的 webhook 详情
@mailgun.webhooks.find(:open)

# 创建新的 webhook
@mailgun.webhooks.create(:open, "http://bin.example.com/8de4a9c4")

# 更新 webhook
@mailgun.webhooks.update(:open, "http://bin.example.com/8de4a9c4")

# 删除 webhook
@mailgun.webhooks.delete(:open)

地址验证

地址验证需要设置 public_api_key

# 验证任意地址
@mailgun.addresses.validate('hello@example.com')

3. 项目API使用文档

Mailgun Rubygem 的 API 使用文档在上述项目使用说明中已经包含。所有操作都是通过 Mailgun 对象的方法调用来实现的。

4. 项目安装方式

项目的安装方式在安装指南中已经说明,使用以下命令:

gem install mailgun
登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
470
3.48 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
flutter_flutterflutter_flutter
暂无简介
Dart
718
172
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
209
84
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.27 K
695
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
1