Customers Mail Cloud用Ruby SDKをバージョンアップしました

Rubyでメール送信を行う際にはTMailやMail、ActionMailerを使うのが基本だと思いますが、環境によってはSMTPが使えない場合もあります。そうした時にはWeb API経由でのメール送信が便利です。

Customers Mail Cloudにはメール送信用のAPIが用意されており、それを扱うRuby用SDKがcustomers_mail_cloud | RubyGems.org | コミュニティのGemホスティングサービスです(非公式です)。

インストール

インストールは gem コマンドで行います。

gem install customers_mail_cloud

使い方

まずライブラリをインポートします。

require('customers_mail_cloud')

次に初期化します。 Microsoft Azure で手軽にメール送信する - Customers Mail Cloud ブログ を参考にAPIユーザ、APIキーを作成してください。

client = CustomersMailCloud::Client.new(api_user, api_key)

Web APIのエンドポイントは契約ごとに異なります。それを指定します。

client.trial() # トライアルの場合
client.standard() # スタンダードの場合
client.pro(subdomain) # プロの場合。サブドメイン指定が必須です

後はメール送信に必要な宛先、送信元、件名、本文をそれぞれ指定します。

client.from = CustomersMailCloud::MailAddress.new('info@smtps.jp', 'Admin')
client.trial
client.to << CustomersMailCloud::MailAddress.new('test@smtps.jp', 'Tester')
client.subject = 'Mail subject'
client.text = 'Mail body'

そして、バージョンアップして追加のプロパティに対応しました。

client.env_from = 'no-reply@example.com' # エンベロープFrom
client.reply_to = 'reply@example.com'    # Reply-To
client.headers = {
  "X-Api-Data": "((#customer-id#))"
}                     # 任意の追加ヘッダー(差込み文字に対応)
client.charset = 'UTF-8' # 文字コード(デフォルトはUTF-8)

ここまでで準備ができたので、メール送信を行います。エラーがあればエラーとして検出可能です。

begin
  json = client.send
  puts json
rescue => e
  puts e

コードについて

コードは goofmint/CustomersMailCloud-rb: Customers Mail CloudのRubyライブラリです で公開しています。不具合などがあれば、ご指摘ください。

まとめ

Rubyからメール送信を行う際に、ライブラリを使うことでとても簡単に実装ができます。ぜひお試しください。