#
#--
# Copyright (c) 2007, Alain Hoang and John Mettraux, OpenWFE.org
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# . Redistributions of source code must retain the above copyright notice, this
# list of conditions and the following disclaimer.
#
# . Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions and the following disclaimer in the documentation
# and/or other materials provided with the distribution.
#
# . Neither the name of the "OpenWFE" nor the names of its contributors may be
# used to endorse or promote products derived from this software without
# specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
#++
#
#
# "made in Japan"
#
# Alain Hoang at openwfe.org
# John Mettraux at openwfe.org
#
require 'net/smtp'
require 'openwfe/participants/participant'
module OpenWFE
#
# MailParticipant is a simplification of EmailNotificationParticipant.
#
# It's initialized in this way :
#
# p = MailParticipant.new(
# :smtp_server => "mailhost.ourcompany.co.jp",
# :from_address => "bpms@our.ourcompany.co.jp",
# :template => "Dear ${f:name}, you've got mail")
#
# or
#
# p = MailParticipant.new(
# :smtp_server => "mailhost.ourcompany.co.jp",
# :smtp_port => 25,
# :from_address => "bpms@our.ourcompany.co.jp"
# ) do |workitem|
# s = ""
# s << "Dear #{workitem.name},\n"
# s << "\n"
# s << "it's #{Time.new.to_s} and you've got mail"
# s
# end
#
# As with EmailNotificationParticipant, the "to" address for your email
# is taken from the workitem's email_target field. So, to have
# the email sent to "foo@nowhere.com", set your workitem's
# email_target field to "foo@nowhere.com" prior to feeding it
# to the mail participant.
#
# Likewise, you can also override the :from_address value by setting the
# workitems email_from field.
#
# When passing the mail template as a block, you have
# four possible arities :
# { |workitem| ... }
# { |participant_expression, workitem| ... }
# { |participant_expression, participant_instance, workitem| ... }
# { ... }
#
# The smtp server and host default to "127.0.0.1" / 25.
#
class MailParticipant
include LocalParticipant
def initialize (params, &block)
@smtp_server = params[:smtp_server]
@smtp_port = params[:smtp_port]
@from_address = params[:from_address]
@template = params[:template]
@block_template = block
# some defaults
@smtp_server = "127.0.0.1" unless @smtp_server
@smtp_port = 25 unless @smtp_port
end
#
# The method called each time a workitem reaches this participant
#
def consume (workitem)
fe = get_flow_expression(workitem)
to_address = workitem.email_target
#
# 1. Expand variables
msg = if @block_template
#@block_template.call(fe, self, workitem)
call_block @block_template, workitem
elsif @template
template = if @template.kind_of? File
@template.readlines
else
@template.to_s
end
OpenWFE::dosub(template, fe, workitem)
else
"(no template given)"
end
from_address = workitem.email_from rescue @from_address
puts "msg >>>\n#{msg}<<<"
#
# 2. Send message
Net::SMTP.start(@smtp_server, @smtp_port) do |smtp|
smtp.send_message(msg, from_address, to_address)
end
#
# 3. Reply to engine
reply_to_engine(workitem)
end
end
#
# This participant is used to send an email notification.
#
# It's perhaps better to use MailParticipant which is simpler to
# initialize. This class is anyway an extension of MailParticipant.
#
# @engine.register_participant(
# 'eno',
# EmailNotificationParticipant.new(
# "googlemail.l.google.com",
# 25,
# "eno@outoftheblue.co.jp",
# """Subject: test 0
#
# 0 : ${r:Time.new}
# 1 : ${f:customer_name}
# """))
#
# And then, from the process definition :
#
# class TestDefinition0 < OpenWFE::ProcessDefinition
# def make
# process_definition :name => "test0", :revision => "0" do
# sequence do
# set :field => 'email_target' do
# "whatever56x56@gmail.com"
# end
# set :field => 'customer_name' do
# "Monsieur Toto"
# end
# participant :ref => 'eno'
# end
# end
# end
# end
#
# The 'template' parameter may contain an instance of File instead of
# an instance of String.
#
# @engine.register_participant(
# 'eno',
# EmailNotificationParticipant.new(
# "googlemail.l.google.com",
# 25,
# "eno@outoftheblue.co.jp",
# File.new("path/to/my/mail/template.txt")))
#
# You can also define the email template as a Ruby block :
#
# p = EmailNotificationParticipant.new("googlemail.l.google.com", 25, "eno@co.co.jp") do | flowexpression, participant, workitem |
#
# # generally, only the workitem is used within a template
#
# s = ""
#
# # the header of the message
#
# s << "Subject: #{workitem.subject}\n\n"
#
# # then, the body
#
# workitem.attributes.each do |key, value|
# s << "- '#{k}' => '#{value}'\n"
# end
# s << "\ndone.\n"
# end
#
# Note that the template integrates the subject and requires then a double
# newline before the message body.
#
class EmailNotificationParticipant < MailParticipant
#
# Create a new email notification participant. Requires
# a mail server, port, a from address, and a mail message template
#
def initialize (
smtp_server, smtp_port, from_address, template=nil, &block)
params = {}
params[:smtp_server] = smtp_server
params[:smtp_port] = smtp_port
params[:from_address] = from_address
params[:template] = template if template
super(params, &block)
end
end
end