首页
/ Mailgun Rubygem 技术文档

Mailgun Rubygem 技术文档

2024-12-27 10:33:31作者:江焘钦

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
登录后查看全文
热门项目推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
139
1.91 K
kernelkernel
deepin linux kernel
C
22
6
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
273
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
923
551
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
421
392
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
74
64
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
344
1.3 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
36
8