ruote-extras 0.9.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/lib/openwfe/extras/engine/db_persisted_engine.rb +100 -0
- data/lib/openwfe/extras/expool/dberrorjournal.rb +189 -0
- data/lib/openwfe/extras/expool/dbexpstorage.rb +353 -0
- data/lib/openwfe/extras/listeners/sqslisteners.rb +146 -0
- data/lib/openwfe/extras/misc/activityfeed.rb +264 -0
- data/lib/openwfe/extras/misc/basecamp.rb +485 -0
- data/lib/openwfe/extras/participants/activeparticipants.rb +739 -0
- data/lib/openwfe/extras/participants/atomfeed_participants.rb +174 -0
- data/lib/openwfe/extras/participants/atompub_participants.rb +268 -0
- data/lib/openwfe/extras/participants/basecamp_participants.rb +87 -0
- data/lib/openwfe/extras/participants/csvparticipants.rb +127 -0
- data/lib/openwfe/extras/participants/sqsparticipants.rb +125 -0
- data/lib/openwfe/extras/participants/twitterparticipants.rb +176 -0
- metadata +70 -0
@@ -0,0 +1,174 @@
|
|
1
|
+
#
|
2
|
+
#--
|
3
|
+
# Copyright (c) 2007-2008, John Mettraux, OpenWFE.org
|
4
|
+
# All rights reserved.
|
5
|
+
#
|
6
|
+
# Redistribution and use in source and binary forms, with or without
|
7
|
+
# modification, are permitted provided that the following conditions are met:
|
8
|
+
#
|
9
|
+
# . Redistributions of source code must retain the above copyright notice, this
|
10
|
+
# list of conditions and the following disclaimer.
|
11
|
+
#
|
12
|
+
# . Redistributions in binary form must reproduce the above copyright notice,
|
13
|
+
# this list of conditions and the following disclaimer in the documentation
|
14
|
+
# and/or other materials provided with the distribution.
|
15
|
+
#
|
16
|
+
# . Neither the name of the "OpenWFE" nor the names of its contributors may be
|
17
|
+
# used to endorse or promote products derived from this software without
|
18
|
+
# specific prior written permission.
|
19
|
+
#
|
20
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
21
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
22
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
23
|
+
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
24
|
+
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
25
|
+
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
26
|
+
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
27
|
+
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
28
|
+
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
29
|
+
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
30
|
+
# POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
#++
|
32
|
+
#
|
33
|
+
|
34
|
+
#
|
35
|
+
# "made in Japan"
|
36
|
+
#
|
37
|
+
# John Mettraux at openwfe.org
|
38
|
+
#
|
39
|
+
|
40
|
+
#
|
41
|
+
# this participant requires atom-tools from
|
42
|
+
#
|
43
|
+
# http://code.necronomicorp.com/trac/atom-tools
|
44
|
+
#
|
45
|
+
# atom-tools' license is X11/MIT
|
46
|
+
#
|
47
|
+
|
48
|
+
require 'monitor'
|
49
|
+
|
50
|
+
#require 'rubygems'
|
51
|
+
require 'atom/collection' # gem 'atom-tools'
|
52
|
+
|
53
|
+
require 'openwfe/participants/participant'
|
54
|
+
|
55
|
+
|
56
|
+
module OpenWFE::Extras
|
57
|
+
|
58
|
+
#
|
59
|
+
# Stores the incoming workitem into an 'atom feed'
|
60
|
+
#
|
61
|
+
# An example :
|
62
|
+
#
|
63
|
+
# feed0 = AtomFeedParticipant.new(
|
64
|
+
# 20, # no more than 20 entries are kept
|
65
|
+
# """
|
66
|
+
# <p>
|
67
|
+
# <h1>${f:colour}</h1>
|
68
|
+
# </p>
|
69
|
+
# """) # the template for each entry
|
70
|
+
#
|
71
|
+
# The 'template' parameter may contain an instance of File instead of
|
72
|
+
# an instance of String.
|
73
|
+
#
|
74
|
+
# feed0 = AtomFeedParticipant.new(
|
75
|
+
# 20, File.new("path/to/my/atom/template.txt")
|
76
|
+
#
|
77
|
+
# The template can be passed as the second parameter (after the max entry
|
78
|
+
# count) or as a block :
|
79
|
+
#
|
80
|
+
# feed1 = AtomFeedParticipant.new(20) do |flow_expression, atom_participant, workitem|
|
81
|
+
# #
|
82
|
+
# # usually only the workitem parameter is used
|
83
|
+
# # but the other two allow for advanced tricks...
|
84
|
+
#
|
85
|
+
# atom_participant.content_type = "xml"
|
86
|
+
# # by default, it's "xhtml"
|
87
|
+
#
|
88
|
+
# s = "<task>"
|
89
|
+
# s << "<name>#{workitem.task_name}</name>"
|
90
|
+
# s << "<assignee>#{workitem.task_assignee}</assignee>"
|
91
|
+
# s << "<duedate>#{workitem.task_duedate}</duedate>"
|
92
|
+
# s << "</task>"
|
93
|
+
#
|
94
|
+
# # the block is supposed to 'return' a string which is the
|
95
|
+
# # effective template
|
96
|
+
# end
|
97
|
+
#
|
98
|
+
# This participant uses
|
99
|
+
# "atom-tools" from http://code.necronomicorp.com/trac/atom-tools
|
100
|
+
#
|
101
|
+
#
|
102
|
+
class AtomFeedParticipant
|
103
|
+
include MonitorMixin
|
104
|
+
include OpenWFE::LocalParticipant
|
105
|
+
include OpenWFE::TemplateMixin
|
106
|
+
|
107
|
+
#
|
108
|
+
# Made accessible so that blocks may set it.
|
109
|
+
#
|
110
|
+
attr_accessor :content_type
|
111
|
+
|
112
|
+
def initialize (max_item_count, template=nil, &block)
|
113
|
+
|
114
|
+
super() # very important as this class includes MonitorMixin
|
115
|
+
|
116
|
+
@template = template
|
117
|
+
@max_item_count = max_item_count
|
118
|
+
@block_template = block
|
119
|
+
|
120
|
+
@feed = Atom::Feed.new("http://localhost")
|
121
|
+
@content_type = "xhtml"
|
122
|
+
end
|
123
|
+
|
124
|
+
def consume (workitem)
|
125
|
+
|
126
|
+
e = Atom::Entry.new
|
127
|
+
|
128
|
+
e.id = \
|
129
|
+
"#{workitem.fei.workflow_instance_id}--" +
|
130
|
+
"#{workitem.fei.expression_id}"
|
131
|
+
|
132
|
+
e.title = workitem.atom_entry_title
|
133
|
+
e.content = render(workitem)
|
134
|
+
|
135
|
+
e.content["type"] = @content_type
|
136
|
+
|
137
|
+
@feed << e
|
138
|
+
|
139
|
+
@feed = @feed[0, @max_item_count] \
|
140
|
+
if @feed.entries.size > @max_item_count
|
141
|
+
|
142
|
+
publish workitem
|
143
|
+
|
144
|
+
reply_to_engine workitem
|
145
|
+
end
|
146
|
+
|
147
|
+
protected
|
148
|
+
|
149
|
+
#
|
150
|
+
# This base implementation simply calls the eval_template()
|
151
|
+
# method of the TemplateMixin.
|
152
|
+
# Feel free to override this render() method for custom
|
153
|
+
# representations.
|
154
|
+
#
|
155
|
+
def render (workitem)
|
156
|
+
|
157
|
+
eval_template workitem
|
158
|
+
end
|
159
|
+
|
160
|
+
#
|
161
|
+
# For the moment, just dumps the feed into a file.
|
162
|
+
#
|
163
|
+
def publish (workitem)
|
164
|
+
synchronize do
|
165
|
+
filename = "work/atom_#{workitem.participant_name}.xml"
|
166
|
+
f = File.open(filename, "w")
|
167
|
+
f << @feed.to_s
|
168
|
+
f.close()
|
169
|
+
end
|
170
|
+
end
|
171
|
+
end
|
172
|
+
|
173
|
+
end
|
174
|
+
|
@@ -0,0 +1,268 @@
|
|
1
|
+
#
|
2
|
+
#--
|
3
|
+
# Copyright (c) 2007-2008, John Mettraux, OpenWFE.org
|
4
|
+
# All rights reserved.
|
5
|
+
#
|
6
|
+
# Redistribution and use in source and binary forms, with or without
|
7
|
+
# modification, are permitted provided that the following conditions are met:
|
8
|
+
#
|
9
|
+
# . Redistributions of source code must retain the above copyright notice, this
|
10
|
+
# list of conditions and the following disclaimer.
|
11
|
+
#
|
12
|
+
# . Redistributions in binary form must reproduce the above copyright notice,
|
13
|
+
# this list of conditions and the following disclaimer in the documentation
|
14
|
+
# and/or other materials provided with the distribution.
|
15
|
+
#
|
16
|
+
# . Neither the name of the "OpenWFE" nor the names of its contributors may be
|
17
|
+
# used to endorse or promote products derived from this software without
|
18
|
+
# specific prior written permission.
|
19
|
+
#
|
20
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
21
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
22
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
23
|
+
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
24
|
+
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
25
|
+
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
26
|
+
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
27
|
+
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
28
|
+
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
29
|
+
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
30
|
+
# POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
#++
|
32
|
+
#
|
33
|
+
|
34
|
+
#
|
35
|
+
# "made in Japan"
|
36
|
+
#
|
37
|
+
# John Mettraux at openwfe.org
|
38
|
+
#
|
39
|
+
|
40
|
+
#
|
41
|
+
# this participant requires atom-tools from
|
42
|
+
#
|
43
|
+
# http://code.necronomicorp.com/trac/atom-tools
|
44
|
+
#
|
45
|
+
# atom-tools' license is X11/MIT
|
46
|
+
#
|
47
|
+
|
48
|
+
require 'yaml'
|
49
|
+
require 'rexml/document'
|
50
|
+
|
51
|
+
require 'openwfe/participants/participants'
|
52
|
+
|
53
|
+
#require 'rubygems'
|
54
|
+
require 'atom/entry' # gem 'atom-tools'
|
55
|
+
require 'atom/collection'
|
56
|
+
|
57
|
+
|
58
|
+
module OpenWFE::Extras
|
59
|
+
|
60
|
+
#
|
61
|
+
# This participants posts (as in HTTP POST) a workitem
|
62
|
+
# to an AtomPub enabled resource.
|
63
|
+
#
|
64
|
+
# target_uri = "https://openwferu.wordpress.com/wp-app.php/posts"
|
65
|
+
#
|
66
|
+
# params = {}
|
67
|
+
# params[:username] = 'jmettraux'
|
68
|
+
# params[:password] = ENV['WORDPRESS_PASSWORD']
|
69
|
+
# params[:categories] = 'openwferu, test'
|
70
|
+
#
|
71
|
+
# engine.register_participant(
|
72
|
+
# "app", OpenWFE::Extras::AtomPubParticipant.new target_uri, params)
|
73
|
+
#
|
74
|
+
# This base implementation dumps workitem as YAML in the entry content.
|
75
|
+
#
|
76
|
+
# See BlogParticipant for a human-oriented blog posting participant.
|
77
|
+
#
|
78
|
+
class AtomPubParticipant
|
79
|
+
include OpenWFE::LocalParticipant
|
80
|
+
|
81
|
+
#
|
82
|
+
# The URI to post to
|
83
|
+
#
|
84
|
+
attr_accessor :target_uri
|
85
|
+
|
86
|
+
attr_accessor :author_name, :author_uri
|
87
|
+
|
88
|
+
|
89
|
+
def initialize (target_uri, params)
|
90
|
+
|
91
|
+
@target_uri = target_uri
|
92
|
+
|
93
|
+
@username = params[:username]
|
94
|
+
@password = params[:password]
|
95
|
+
|
96
|
+
@author_name = \
|
97
|
+
params[:author_name] || self.class.name
|
98
|
+
@author_uri = \
|
99
|
+
params[:author_uri] || "http://openwferu.rubyforge.org"
|
100
|
+
|
101
|
+
|
102
|
+
@categories = params[:categories] || []
|
103
|
+
@categories = @categories.split(",") if @categories.is_a?(String)
|
104
|
+
@categories = Array(@categories)
|
105
|
+
end
|
106
|
+
|
107
|
+
#
|
108
|
+
# The incoming workitem will generate an atom entry that will
|
109
|
+
# get posted to the target URI.
|
110
|
+
#
|
111
|
+
# This consume() method returns the URI (as a String) where the
|
112
|
+
# just uploaded post can be edited.
|
113
|
+
#
|
114
|
+
def consume (workitem)
|
115
|
+
|
116
|
+
entry = Atom::Entry.new
|
117
|
+
entry.updated! # set updated time to now
|
118
|
+
|
119
|
+
render_author entry, workitem
|
120
|
+
render_categories entry, workitem
|
121
|
+
render_content entry, workitem
|
122
|
+
|
123
|
+
h = Atom::HTTP.new
|
124
|
+
h.user = @username
|
125
|
+
h.pass = @password
|
126
|
+
h.always_auth = :basic
|
127
|
+
|
128
|
+
res = Atom::Collection.new(@target_uri, h).post!(entry)
|
129
|
+
|
130
|
+
# initial implementation
|
131
|
+
# don't catch an error, let the process fail
|
132
|
+
|
133
|
+
#res.read_body
|
134
|
+
extract_new_link res
|
135
|
+
end
|
136
|
+
|
137
|
+
protected
|
138
|
+
|
139
|
+
#
|
140
|
+
# This base implementation simply uses a YAML dump of the workitem
|
141
|
+
# as the post content (with a content type of 'html').
|
142
|
+
#
|
143
|
+
def render_content (entry, workitem)
|
144
|
+
|
145
|
+
entry.title = \
|
146
|
+
workitem.participant_name + " " +
|
147
|
+
workitem.fei.expression_id + " " +
|
148
|
+
workitem.fei.workflow_instance_id
|
149
|
+
|
150
|
+
entry.content = workitem.to_yaml
|
151
|
+
entry.content["type"] = "html"
|
152
|
+
end
|
153
|
+
|
154
|
+
#
|
155
|
+
# This default implementation simply builds a single author
|
156
|
+
# out of the :author_name, :author_uri passed as initialization
|
157
|
+
# params.
|
158
|
+
#
|
159
|
+
def render_author (entry, workitem)
|
160
|
+
|
161
|
+
author = Atom::Author.new
|
162
|
+
author.name = author_name
|
163
|
+
author.uri = author_uri
|
164
|
+
|
165
|
+
entry.authors << author
|
166
|
+
end
|
167
|
+
|
168
|
+
#
|
169
|
+
# This base implementations simply adds the categories listed
|
170
|
+
# in the :categories initialization parameter.
|
171
|
+
# The target_uri is used as the scheme for the categories.
|
172
|
+
#
|
173
|
+
# You can override this method to add extra categories or to
|
174
|
+
# have completely different categories.
|
175
|
+
#
|
176
|
+
def render_categories (entry, workitem)
|
177
|
+
|
178
|
+
@categories.each do |s|
|
179
|
+
|
180
|
+
c = Atom::Category.new
|
181
|
+
|
182
|
+
c["scheme"] = @target_uri
|
183
|
+
c["term"] = s.strip
|
184
|
+
|
185
|
+
entry.categories << c
|
186
|
+
end
|
187
|
+
end
|
188
|
+
|
189
|
+
#
|
190
|
+
# Extracts the link of the newly created resource (newly posted blog
|
191
|
+
# entry), and returns it as a String.
|
192
|
+
#
|
193
|
+
def extract_new_link (response)
|
194
|
+
|
195
|
+
doc = REXML::Document.new response.read_body
|
196
|
+
|
197
|
+
#REXML::XPath.first(doc.root, "//link[@rel='edit']")
|
198
|
+
#
|
199
|
+
# doesn't work :(
|
200
|
+
|
201
|
+
REXML::XPath.first(doc.root, "//link[2]").attribute('href')
|
202
|
+
#
|
203
|
+
# will break if the order changes :(
|
204
|
+
end
|
205
|
+
end
|
206
|
+
|
207
|
+
#
|
208
|
+
# A participant that blogs.
|
209
|
+
#
|
210
|
+
# require 'openwfe/extras/participants/atompub_participants'
|
211
|
+
# include OpenWFE::Extras
|
212
|
+
#
|
213
|
+
# target_uri = "https://openwferu.wordpress.com/wp-app.php/posts"
|
214
|
+
#
|
215
|
+
# params = {}
|
216
|
+
# params[:username] = 'jeff'
|
217
|
+
# params[:password] = 'whatever'
|
218
|
+
#
|
219
|
+
# params[:categories] = 'openwferu, test'
|
220
|
+
#
|
221
|
+
# #params[:title_field] = "title"
|
222
|
+
# #
|
223
|
+
# # which workitem field will hold the post title ?
|
224
|
+
# # by default, it's "title"
|
225
|
+
#
|
226
|
+
# engine.register_participant "blogger", BlogParticipant.new(target_uri, params) do
|
227
|
+
# """
|
228
|
+
# paragraph 0
|
229
|
+
#
|
230
|
+
# paragraph 1 : ${f:message}
|
231
|
+
#
|
232
|
+
# paragraph 2
|
233
|
+
# """
|
234
|
+
# end
|
235
|
+
#
|
236
|
+
# This participant takes its template and the workitem it receives to
|
237
|
+
# publish a blog entry.
|
238
|
+
#
|
239
|
+
# The template can be specified as a block (as in the previous example)
|
240
|
+
# or via the :template parameter.
|
241
|
+
#
|
242
|
+
class BlogParticipant < AtomPubParticipant
|
243
|
+
include OpenWFE::TemplateMixin
|
244
|
+
|
245
|
+
def initialize (target_uri, params, &block)
|
246
|
+
|
247
|
+
super
|
248
|
+
|
249
|
+
@template = params[:template]
|
250
|
+
@block_template = block
|
251
|
+
|
252
|
+
@content_type = params[:content_type] || "html"
|
253
|
+
|
254
|
+
@title_field = params[:title_field] || "title"
|
255
|
+
end
|
256
|
+
|
257
|
+
protected
|
258
|
+
|
259
|
+
def render_content (entry, workitem)
|
260
|
+
|
261
|
+
entry.title = workitem.attributes[@title_field].to_s
|
262
|
+
|
263
|
+
entry.content = eval_template workitem
|
264
|
+
entry.content["type"] = @content_type
|
265
|
+
end
|
266
|
+
end
|
267
|
+
end
|
268
|
+
|
@@ -0,0 +1,87 @@
|
|
1
|
+
#
|
2
|
+
#--
|
3
|
+
# Copyright (c) 2008, John Mettraux, OpenWFE.org
|
4
|
+
# All rights reserved.
|
5
|
+
#
|
6
|
+
# Redistribution and use in source and binary forms, with or without
|
7
|
+
# modification, are permitted provided that the following conditions are met:
|
8
|
+
#
|
9
|
+
# . Redistributions of source code must retain the above copyright notice, this
|
10
|
+
# list of conditions and the following disclaimer.
|
11
|
+
#
|
12
|
+
# . Redistributions in binary form must reproduce the above copyright notice,
|
13
|
+
# this list of conditions and the following disclaimer in the documentation
|
14
|
+
# and/or other materials provided with the distribution.
|
15
|
+
#
|
16
|
+
# . Neither the name of the "OpenWFE" nor the names of its contributors may be
|
17
|
+
# used to endorse or promote products derived from this software without
|
18
|
+
# specific prior written permission.
|
19
|
+
#
|
20
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
21
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
22
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
23
|
+
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
24
|
+
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
25
|
+
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
26
|
+
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
27
|
+
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
28
|
+
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
29
|
+
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
30
|
+
# POSSIBILITY OF SUCH DAMAGE.
|
31
|
+
#++
|
32
|
+
#
|
33
|
+
|
34
|
+
#
|
35
|
+
# "made in Japan"
|
36
|
+
#
|
37
|
+
# John Mettraux at openwfe.org
|
38
|
+
#
|
39
|
+
|
40
|
+
require 'openwfe/participants/participants'
|
41
|
+
require 'openwfe/extras/misc/basecamp'
|
42
|
+
|
43
|
+
|
44
|
+
module OpenWFE
|
45
|
+
module Extras
|
46
|
+
|
47
|
+
class BasecampParticipant
|
48
|
+
include OpenWFE::LocalParticipant
|
49
|
+
include OpenWFE::TemplateMixin
|
50
|
+
|
51
|
+
def initialize (params, &block)
|
52
|
+
|
53
|
+
super()
|
54
|
+
|
55
|
+
@template = params[:template]
|
56
|
+
@block_template = block
|
57
|
+
|
58
|
+
@company_id = params[:company_id]
|
59
|
+
#@project_id = params[:project_id]
|
60
|
+
|
61
|
+
@responsible_party_id = params[:responsible_party_id]
|
62
|
+
@todo_list_id = params[:todo_list_id]
|
63
|
+
|
64
|
+
ssl = params[:ssl]
|
65
|
+
ssl = true if ssl == nil
|
66
|
+
|
67
|
+
@camp = Basecamp.new(
|
68
|
+
params[:host], params[:username], params[:password], ssl)
|
69
|
+
end
|
70
|
+
|
71
|
+
def consume (workitem)
|
72
|
+
|
73
|
+
text = workitem['todo_text'] || eval_template(wi)
|
74
|
+
|
75
|
+
resp = workitem['todo_responsible_party'] || @responsible_party_id
|
76
|
+
list = workitem['toto_list_id'] || @todo_list_id
|
77
|
+
|
78
|
+
todo = @camp.create_item list, text, resp
|
79
|
+
|
80
|
+
workitem['todo_id'] = todo.id
|
81
|
+
|
82
|
+
reply_to_engine workitem
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|