我尝试使用Gibbon 2.2.4使用我一直在使用的通用subscribe
方法向用户订阅Mailchimp,然后在我想添加一些额外字段后不久跟踪他们采取的测验结果。
我想将这些数据存储在Mailchimp上,因为我想管理我直接从Mailchimp的信息中心发送的电子邮件。
我为处理订阅而创建的服务:
class MailchimpService
def subscribe(list_id,email,first_name)
GIBBON.lists(list_id).members.create({
body: {
email_address: email,
status: 'subscribed',
merge_fields: {
FNAME: first_name,
},
double_optin: false,
update_existing: true
}
})
end
def subscribe_to_quiz(first_name, email, user_id, quiz_id)
list_id = ENV['QUIZ_MAILCHIMP_LIST_ID']
if subscribe(list_id,email,first_name)
attempt = QuizAttempt.where("user_id = ? AND quiz_id = ?", user_id, quiz_id).last
correct = attempt.correct_answer_count
total = attempt.questions_answered
successful = attempt.successful?
send_quiz_results(list_id, email, correct, total, successful)
end
end
def send_quiz_results(list_id, email, correct, total, successful)
GIBBON.lists(list_id).members(email).upsert(
body: {
email_address: email,
status: 'subscribed',
merge_fields: {
correct_answers: correct,
total_answers: total,
successful: successful
},
update_existing: true
})
end
end
在subscribe_to_quiz
中,我将用户订阅到Mailchimp中的quiz_list。我在这里更新的字段的值是无关紧要的,但我认为它们非常具有说明性。当我尝试在send_quiz_results
中运行我的upsert语句时,出现以下错误:
the server responded with status 400
@title="Member Exists",
@detail="foo@bar.baz is already a list member. Use PUT to insert or update list members.",
@body={"type"=>"http://developer.mailchimp.com/documentation/mailchimp/guides/error-glossary/", "title"=>"Member Exists", "status"=>400, "detail"=>"foo@bar.baz is already a list member. Use PUT to insert or update list members.", "instance"=>""},
@raw_body="{\"type\":\"http://developer.mailchimp.com/documentation/mailchimp/guides/error-glossary/\",\"title\":\"Member Exists\",\"status\":400,\"detail\":\"foo@bar.baz is already a list member. Use PUT to insert or update list members.\",\"instance\":\"\"}",
@status_code=400
我不知道为什么它不会让我这样做......似乎它引用了create
语句,但提取的错误来源引用了我的{{1声明。
我知道我使用相应的PUT动词用于Gibbon,因为以下内容直接来自文档:
当然,body仅支持create,update和upsert调用。它们分别映射到HTTP POST,PATCH和PUT动词。
我不知道为什么这不起作用......我已经尝试取出其他字段而只是简单地投入我更新的字段。我也试过从终端直接运行它以确保没有任何重叠。
答案 0 :(得分:6)
MailChimp API docs表示在更新成员时,您必须提供成员的subscriber_hash,其中包含成员电子邮件地址的小写版本的MD5哈希值。
使用Digest::MD5.hexdigest
使用MD5哈希电子邮件地址:
GIBBON.lists(list_id).members(Digest::MD5.hexdigest(email.downcase)).upsert