首页
/ Mailgun Rubygem 技术文档

Mailgun Rubygem 技术文档

2024-12-27 09:32:49作者:江焘钦

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
热门项目推荐
相关项目推荐

项目优选

收起
国产编程语言蓝皮书国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
47
11
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
193
44
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
52
42
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
264
68
GitCode光引计划有奖征文大赛GitCode光引计划有奖征文大赛
GitCode光引计划有奖征文大赛
17
1
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
135
12
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
168
39
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
smart-adminsmart-admin
SmartAdmin国内首个以「高质量代码」为核心,「简洁、高效、安全」中后台快速开发平台;基于SpringBoot2/3 + Sa-Token + Mybatis-Plus 和 Vue3 + Vite5 + Ant Design Vue 4.x (同时支持JavaScript和TypeScript双版本);满足国家三级等保要求、支持登录限制、接口数据国产加解密、高防SQL注入等一系列安全体系。
Java
19
3
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
84
58