yapra 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +4 -0
- data/LICENCE +22 -0
- data/License.txt +22 -0
- data/Manifest.txt +103 -0
- data/PostInstall.txt +7 -0
- data/README.txt +66 -0
- data/Rakefile +13 -0
- data/bin/yapra +52 -0
- data/config/hoe.rb +75 -0
- data/config/requirements.rb +15 -0
- data/legacy_plugins/Download/nicovideo.rb +45 -0
- data/legacy_plugins/Feed/custom_feed.rb +87 -0
- data/legacy_plugins/Feed/google_calendar.rb +51 -0
- data/legacy_plugins/Feed/google_search_history.rb +45 -0
- data/legacy_plugins/Feed/hatena_graph.rb +37 -0
- data/legacy_plugins/Feed/lirs.rb +36 -0
- data/legacy_plugins/Filter/Translations/yahoo.rb +40 -0
- data/legacy_plugins/Filter/apply_text_html.rb +26 -0
- data/legacy_plugins/Filter/average.rb +6 -0
- data/legacy_plugins/Filter/deduped.rb +51 -0
- data/legacy_plugins/Filter/find_num.rb +8 -0
- data/legacy_plugins/Filter/find_regex.rb +9 -0
- data/legacy_plugins/Filter/fresh.rb +9 -0
- data/legacy_plugins/Filter/get_html.rb +11 -0
- data/legacy_plugins/Filter/grep.rb +16 -0
- data/legacy_plugins/Filter/invert.rb +14 -0
- data/legacy_plugins/Filter/sort.rb +10 -0
- data/legacy_plugins/Filter/subs.rb +6 -0
- data/legacy_plugins/Filter/to_integer.rb +4 -0
- data/legacy_plugins/Publish/delicious.rb +91 -0
- data/legacy_plugins/Publish/google_calendar.rb +58 -0
- data/legacy_plugins/Publish/hatena_bookmark.rb +47 -0
- data/legacy_plugins/Publish/hatena_diary_writer.rb +53 -0
- data/legacy_plugins/Publish/hatena_graph.rb +39 -0
- data/legacy_plugins/Publish/lingr.rb +110 -0
- data/legacy_plugins/Publish/mixi_diary_writer.rb +104 -0
- data/legacy_plugins/Publish/scuttle.rb +92 -0
- data/legacy_plugins/Publish/twitter.rb +35 -0
- data/legacy_plugins/RSS/load.rb +38 -0
- data/legacy_plugins/RSS/save.rb +41 -0
- data/legacy_plugins/Yaml/load.rb +5 -0
- data/legacy_plugins/Yaml/save.rb +9 -0
- data/legacy_plugins/argv.rb +5 -0
- data/legacy_plugins/concat.rb +18 -0
- data/legacy_plugins/const_list.rb +15 -0
- data/legacy_plugins/first.rb +11 -0
- data/legacy_plugins/head.rb +14 -0
- data/legacy_plugins/load_path.rb +21 -0
- data/legacy_plugins/plagger.rb +94 -0
- data/legacy_plugins/plugin_from_uri.rb +31 -0
- data/legacy_plugins/pluginbase.rb +4 -0
- data/legacy_plugins/print.rb +15 -0
- data/legacy_plugins/reverse.rb +10 -0
- data/legacy_plugins/send_msg.rb +18 -0
- data/legacy_plugins/stdin.rb +6 -0
- data/legacy_plugins/stdout.rb +6 -0
- data/lib/yapra/config.rb +103 -0
- data/lib/yapra/inflector.rb +55 -0
- data/lib/yapra/legacy_plugin/advance_mode_registry.rb +38 -0
- data/lib/yapra/legacy_plugin/base.rb +26 -0
- data/lib/yapra/legacy_plugin/compatible_mode_registry.rb +34 -0
- data/lib/yapra/legacy_plugin/registry_factory.rb +21 -0
- data/lib/yapra/legacy_plugin.rb +5 -0
- data/lib/yapra/pipeline.rb +74 -0
- data/lib/yapra/plugin/base.rb +14 -0
- data/lib/yapra/plugin/context_aware.rb +14 -0
- data/lib/yapra/plugin/erb_applier.rb +15 -0
- data/lib/yapra/plugin/feed_item_operator.rb +21 -0
- data/lib/yapra/plugin/mechanize_base.rb +26 -0
- data/lib/yapra/plugin.rb +5 -0
- data/lib/yapra/runtime.rb +36 -0
- data/lib/yapra/version.rb +9 -0
- data/lib/yapra.rb +44 -0
- data/lib-plugins/yapra/plugin/config/agent.rb +34 -0
- data/lib-plugins/yapra/plugin/config/basic_auth.rb +19 -0
- data/lib-plugins/yapra/plugin/config/web_post.rb +21 -0
- data/lib-plugins/yapra/plugin/feed/custom.rb +41 -0
- data/lib-plugins/yapra/plugin/feed/load.rb +29 -0
- data/lib-plugins/yapra/plugin/filter/entry_full_text.rb +59 -0
- data/lib-plugins/yapra/plugin/publish/file_download.rb +109 -0
- data/lib-plugins/yapra/plugin/publish/gmail.rb +27 -0
- data/lib-plugins/yapra/plugin/publish/imap.rb +82 -0
- data/lib-plugins/yapra/plugin/test/append_entry.rb +25 -0
- data/plugins/Filter/deduped.rb +57 -0
- data/plugins/Filter/sort.rb +28 -0
- data/plugins/Filter/subs.rb +16 -0
- data/script/console +10 -0
- data/script/destroy +14 -0
- data/script/generate +14 -0
- data/script/txt2html +82 -0
- data/setup.rb +1585 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +11 -0
- data/spec/yapra_spec.rb +11 -0
- data/tasks/deployment.rake +34 -0
- data/tasks/environment.rake +7 -0
- data/tasks/rspec.rake +21 -0
- data/tasks/website.rake +17 -0
- data/website/index.html +115 -0
- data/website/index.txt +57 -0
- data/website/javascripts/rounded_corners_lite.inc.js +285 -0
- data/website/stylesheets/screen.css +138 -0
- data/website/template.html.erb +48 -0
- metadata +170 -0
@@ -0,0 +1,104 @@
|
|
1
|
+
## author "emergent"
|
2
|
+
## descr "post feed(s) to mixi diary"
|
3
|
+
##
|
4
|
+
## example <<EOE
|
5
|
+
## when posting one diary per one feed
|
6
|
+
## - module: publish::mixi_diary_writer
|
7
|
+
## config:
|
8
|
+
## username: test@test.com
|
9
|
+
## password: ********
|
10
|
+
##
|
11
|
+
## when posting merged feeds to one diary
|
12
|
+
## - module: publish::mixi_diary_writer
|
13
|
+
## config:
|
14
|
+
## username: test@test.com
|
15
|
+
## password: ********
|
16
|
+
## title: "フィード一覧"
|
17
|
+
## merge_feeds: 1
|
18
|
+
## EOE
|
19
|
+
## config({ :username => Field.new("username to login", String, true),
|
20
|
+
## :password => Field.new("password to login", String, true),
|
21
|
+
## :merge_feeds => Field.new("aggregate feeds to one diary", String),
|
22
|
+
## :title => Field.new("title when merge_feeds is on", String) })
|
23
|
+
|
24
|
+
require 'rubygems'
|
25
|
+
require 'mechanize'
|
26
|
+
require 'kconv'
|
27
|
+
|
28
|
+
class MixiDiaryWriter
|
29
|
+
|
30
|
+
def initialize username=nil, password=nil
|
31
|
+
@id = nil
|
32
|
+
@username = username
|
33
|
+
@password = password
|
34
|
+
@agent = WWW::Mechanize.new
|
35
|
+
end
|
36
|
+
|
37
|
+
def login username=@username, password=@password
|
38
|
+
if username == nil || password == nil
|
39
|
+
return
|
40
|
+
else
|
41
|
+
@username = username
|
42
|
+
@password = password
|
43
|
+
end
|
44
|
+
@agent.post('http://mixi.jp/login.pl',
|
45
|
+
{ 'email' => @username,
|
46
|
+
'password' => @password,
|
47
|
+
'next_url' => '/home.pl' })
|
48
|
+
@home_page = @agent.get('http://mixi.jp/home.pl')
|
49
|
+
end
|
50
|
+
|
51
|
+
def edit title, content
|
52
|
+
if /add_diary\.pl\?id=(\d+)/ =~ @home_page.body
|
53
|
+
@id = $1
|
54
|
+
end
|
55
|
+
|
56
|
+
@edit_page = @agent.get('http://mixi.jp/add_diary.pl?id='+@id)
|
57
|
+
|
58
|
+
begin
|
59
|
+
edit_form = @edit_page.forms.name("diary").first
|
60
|
+
edit_form['diary_title'] = title.toeuc
|
61
|
+
edit_form['diary_body'] = content.toeuc
|
62
|
+
confirm_page = @agent.submit(edit_form)
|
63
|
+
|
64
|
+
conf_form = confirm_page.forms[0] # select 'hai'
|
65
|
+
@agent.submit(conf_form)
|
66
|
+
rescue => e
|
67
|
+
puts "Exception when posting diary"
|
68
|
+
puts e.message
|
69
|
+
puts e.backtrace.join("\n")
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
OK_TAGS = 'a|p|strong|em|u|del|blockquote'
|
74
|
+
def striptags str
|
75
|
+
str.gsub!(/<br.*?>/, "\n")
|
76
|
+
str.gsub!(/<[\/]{0,1}(?!(?:(?:#{OK_TAGS})(?:\s|>)))\w+[\s]{0,1}.*?>/, '')
|
77
|
+
str
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
def mixi_diary_writer(config, data)
|
82
|
+
title = config['title'] || data[0].title
|
83
|
+
content = []
|
84
|
+
|
85
|
+
if config['merge_feeds'] #.to_i == 1
|
86
|
+
data.each {|item|
|
87
|
+
content << {:title => title, :body => ('- <a href="'+item.link+'">'+item.title+"</a>\n"+item.description+"...\n\n" rescue item.to_s)}
|
88
|
+
}
|
89
|
+
else
|
90
|
+
data.each {|d|
|
91
|
+
# delete line feed and space at the top of content
|
92
|
+
content << {:title => d.title, :body => d.content_encoded.to_s.sub(/^(?:\s+)/, '')}
|
93
|
+
}
|
94
|
+
end
|
95
|
+
|
96
|
+
mdw = MixiDiaryWriter.new(config['username'], config['password'])
|
97
|
+
|
98
|
+
content.each {|entry|
|
99
|
+
mdw.login
|
100
|
+
mdw.edit entry[:title], mdw.striptags(entry[:body])
|
101
|
+
}
|
102
|
+
|
103
|
+
return data
|
104
|
+
end
|
@@ -0,0 +1,92 @@
|
|
1
|
+
## Publish::scuttle - to post feed items to scuttle -- emergent
|
2
|
+
##
|
3
|
+
## - module: Publish::scuttle
|
4
|
+
## config:
|
5
|
+
## url: http://your.example.com/scuttle/
|
6
|
+
## username: your_username
|
7
|
+
## password: your_password
|
8
|
+
## opt_tag: pragger
|
9
|
+
## no_comment: 1
|
10
|
+
##
|
11
|
+
require 'rubygems'
|
12
|
+
require 'mechanize'
|
13
|
+
require 'uri'
|
14
|
+
require 'kconv'
|
15
|
+
|
16
|
+
class Scuttle
|
17
|
+
|
18
|
+
def initialize url, username, password, proxy=nil
|
19
|
+
@post_url = url + 'api/posts/add?'
|
20
|
+
@username = username
|
21
|
+
@password = password
|
22
|
+
@agent = WWW::Mechanize.new
|
23
|
+
@agent.basic_auth(@username, @password)
|
24
|
+
if proxy && proxy.is_a?(Hash) && proxy['proxy_addr'] && proxy['proxy_port']
|
25
|
+
@agent.set_proxy(proxy['proxy_addr'], proxy['proxy_port'],
|
26
|
+
proxy['proxy_user'], proxy['proxy_pass'])
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def post url, desc, option=nil
|
31
|
+
params = {}
|
32
|
+
|
33
|
+
params[:url] = url
|
34
|
+
params[:description] = desc
|
35
|
+
|
36
|
+
if option
|
37
|
+
params[:extended] = option["summary"] if option["summary"]
|
38
|
+
params[:dt] = option["datetime"] if option["datetime"]
|
39
|
+
params[:tags] = option["tags"] if option["tags"]
|
40
|
+
params[:replace] = 'no' if option["no_replace"]
|
41
|
+
params[:shared] = 'no' if option["private"]
|
42
|
+
end
|
43
|
+
|
44
|
+
req_param = []
|
45
|
+
params.each do |k,v|
|
46
|
+
req_param << k.to_s.toutf8 + '=' + v.toutf8 if (v.length > 0)
|
47
|
+
end
|
48
|
+
result = @agent.get(URI.encode(@post_url + req_param.join('&')))
|
49
|
+
if result.body =~ /code="done"/
|
50
|
+
return true
|
51
|
+
end
|
52
|
+
false
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
def get_tags entry
|
57
|
+
entry.dc_subjects.map do |s| s.content end.join(' ') rescue ''
|
58
|
+
end
|
59
|
+
|
60
|
+
def scuttle config, data
|
61
|
+
sleeptime = 3
|
62
|
+
|
63
|
+
if config['sleep']
|
64
|
+
sleeptime = config['sleep'].to_i
|
65
|
+
end
|
66
|
+
|
67
|
+
data.each {|entry|
|
68
|
+
print 'posting ' + entry.title + ': '
|
69
|
+
|
70
|
+
tags = get_tags entry
|
71
|
+
if config['opt_tag']
|
72
|
+
tags = [tags, config['opt_tag']].select{|t| t.length > 0}.join(' ')
|
73
|
+
end
|
74
|
+
|
75
|
+
summary = config['no_comment'] ? entry.description : ''
|
76
|
+
|
77
|
+
begin
|
78
|
+
agent = Scuttle.new(config['url'], config['username'], config['password'])
|
79
|
+
res = agent.post(entry.link, entry.title,
|
80
|
+
'tags' => tags, 'summary' => summary)
|
81
|
+
|
82
|
+
if res then puts 'done' else puts 'failed' end
|
83
|
+
rescue
|
84
|
+
puts 'exception'
|
85
|
+
#raise
|
86
|
+
end
|
87
|
+
|
88
|
+
sleep sleeptime
|
89
|
+
}
|
90
|
+
return data
|
91
|
+
end
|
92
|
+
|
@@ -0,0 +1,35 @@
|
|
1
|
+
##Publish::twitter -- itoshi
|
2
|
+
##
|
3
|
+
## from: http://itoshi.tv/d/?date=20071123#p01
|
4
|
+
##
|
5
|
+
##- module: Publish::twitter
|
6
|
+
## config:
|
7
|
+
## login: xxxxxx
|
8
|
+
## password: xxx
|
9
|
+
## check: 30##
|
10
|
+
##
|
11
|
+
|
12
|
+
begin
|
13
|
+
require 'rubygems'
|
14
|
+
rescue LoadError
|
15
|
+
end
|
16
|
+
require 'twitter'
|
17
|
+
require 'kconv'
|
18
|
+
|
19
|
+
def twitter(config, data)
|
20
|
+
c = Twitter::Client.new(:login=>config["login"], :password=>config["password"])
|
21
|
+
|
22
|
+
posts = c.timeline_for(:me,:count=>config["check"])
|
23
|
+
posted_entries = posts.map do |post| post.text.gsub!(/ http.+$/, '') end
|
24
|
+
|
25
|
+
data.reverse.each {|item|
|
26
|
+
link = item.link
|
27
|
+
title = item.title.toutf8
|
28
|
+
|
29
|
+
next if posted_entries.include? title
|
30
|
+
|
31
|
+
comment = [title, link].join(' ')
|
32
|
+
s = c.status(:post, comment)
|
33
|
+
p comment
|
34
|
+
}
|
35
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
## Load RSS from given URLs -- IKeJI
|
2
|
+
##
|
3
|
+
## Load RSS from given URLs.
|
4
|
+
## If URL is an Array, all URLs in the array will be loaded.
|
5
|
+
##
|
6
|
+
## - module: RSS::load
|
7
|
+
## config:
|
8
|
+
## uri: http://www.example.com/hoge.rdf
|
9
|
+
|
10
|
+
require 'open-uri'
|
11
|
+
require 'rss/1.0'
|
12
|
+
require 'rss/2.0'
|
13
|
+
require 'rss/maker'
|
14
|
+
|
15
|
+
def load(config, data)
|
16
|
+
begin
|
17
|
+
rss_source =
|
18
|
+
if config['url'].is_a?(Array)
|
19
|
+
config['url'].map {|url| open(url) {|io| io.read } }
|
20
|
+
else
|
21
|
+
[ open(config['url']) {|r| r.read } ]
|
22
|
+
end
|
23
|
+
rescue
|
24
|
+
puts "LoadError File = #{config["url"]}"
|
25
|
+
return []
|
26
|
+
end
|
27
|
+
|
28
|
+
feeds = rss_source.collect {|cont|
|
29
|
+
begin
|
30
|
+
RSS::Parser.parse(cont)
|
31
|
+
rescue RSS::InvalidRSSError
|
32
|
+
RSS::Parser.parse(cont, false)
|
33
|
+
end
|
34
|
+
}
|
35
|
+
|
36
|
+
feeds.select {|f| f}.inject([]) {|acc,f| acc + f.items }
|
37
|
+
end
|
38
|
+
|
@@ -0,0 +1,41 @@
|
|
1
|
+
## Save RSS as a file -- IKeJI
|
2
|
+
##
|
3
|
+
## Save RSS as a file.
|
4
|
+
## Title, Link, and Description of the RSS can be set.
|
5
|
+
## The input is expected to be an Array of RSS::RDF::Item.
|
6
|
+
##
|
7
|
+
## - module: RSS::save
|
8
|
+
## config:
|
9
|
+
## title: An Title
|
10
|
+
## link: http://www.example.com/hoge.rdf
|
11
|
+
## description: sample rdf
|
12
|
+
|
13
|
+
require "rss/maker"
|
14
|
+
|
15
|
+
@count = Time.now.to_i
|
16
|
+
|
17
|
+
def save(config,data)
|
18
|
+
rss = RSS::Maker.make("1.0") do |maker|
|
19
|
+
maker.channel.about = config['about'] || config['link'] || "http://example.net/"
|
20
|
+
maker.channel.title = config['title'] || "Pragger output"
|
21
|
+
maker.channel.description = config['description'] || ""
|
22
|
+
maker.channel.link = config['link'] || "http://example.net/"
|
23
|
+
|
24
|
+
data.each do |i|
|
25
|
+
if(i.instance_of?(RSS::RDF::Item))
|
26
|
+
i.setup_maker(maker)
|
27
|
+
else
|
28
|
+
item = maker.items.new_item
|
29
|
+
item.title = i.title rescue i.to_s
|
30
|
+
item.link = i.link rescue (config['link'] || "http://example.net/") + "\##{@count}"
|
31
|
+
item.description = i.description rescue i.to_s
|
32
|
+
item.date = i.date rescue Time.now
|
33
|
+
@count += 1
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
open(config["filename"],"w"){|w| w.puts rss }
|
38
|
+
return data
|
39
|
+
end
|
40
|
+
|
41
|
+
|
@@ -0,0 +1,18 @@
|
|
1
|
+
## concat two data -- IKeJI
|
2
|
+
##
|
3
|
+
## concat two data plugin.
|
4
|
+
## this plugin is concat two data.
|
5
|
+
##
|
6
|
+
## - module: concat
|
7
|
+
## config:
|
8
|
+
## - module: foo
|
9
|
+
## - module: bar
|
10
|
+
## - module: baz
|
11
|
+
##
|
12
|
+
|
13
|
+
|
14
|
+
def concat(config,data)
|
15
|
+
data2 = eval_pragger(config,[])
|
16
|
+
return data+data2
|
17
|
+
end
|
18
|
+
|
@@ -0,0 +1,21 @@
|
|
1
|
+
## Add path to $LOAD_PATH -- gtaka555
|
2
|
+
##
|
3
|
+
## Add path to $LOAD_PATH plugin.
|
4
|
+
##
|
5
|
+
## - module: load_path
|
6
|
+
## config:
|
7
|
+
## path:
|
8
|
+
## - /home/foo/ruby/lib/1
|
9
|
+
## - /home/foo/ruby/lib/2
|
10
|
+
## - /home/foo/ruby/lib/3
|
11
|
+
##
|
12
|
+
|
13
|
+
def load_path(config, data)
|
14
|
+
return data unless config.key?('path')
|
15
|
+
|
16
|
+
config['path'].each {|path|
|
17
|
+
$LOAD_PATH << path
|
18
|
+
}
|
19
|
+
|
20
|
+
data
|
21
|
+
end
|
@@ -0,0 +1,94 @@
|
|
1
|
+
## Interleave Plagger processing -- Soutaro Matsumoto
|
2
|
+
##
|
3
|
+
## Invokes Plagger and process the input with your Plagger.
|
4
|
+
## The input must be an Array of RSS::RDF::Item.
|
5
|
+
## The output is an Array of RSS::RDF::Item.
|
6
|
+
## If "debug" is a value evaluated to true, tempolary files for/from Plagger won't be deleted.
|
7
|
+
## If "input" is not "feed", the input will be ignored.
|
8
|
+
## If you omit "dir", the default is /var.
|
9
|
+
## Make sure your system have /var directory and pragger/Plagger can write.
|
10
|
+
##
|
11
|
+
## - module: plagger
|
12
|
+
## config:
|
13
|
+
## input: feed
|
14
|
+
## debug: false
|
15
|
+
## dir: /var
|
16
|
+
## plugins:
|
17
|
+
## - module: Publish::CSV
|
18
|
+
## config:
|
19
|
+
## dir: /var
|
20
|
+
## filename: a.csv
|
21
|
+
|
22
|
+
require 'rbconfig'
|
23
|
+
require 'open-uri'
|
24
|
+
require 'rss/1.0'
|
25
|
+
require 'rss/2.0'
|
26
|
+
require 'pathname'
|
27
|
+
|
28
|
+
raise LoadError unless ENV['PATH'].split(Config::CONFIG['PATH_SEPARATOR']).find {|dir|
|
29
|
+
File.executable?(File.join(dir, 'plagger')) || File.executable?(File.join(dir, 'plagger.bat'))
|
30
|
+
}
|
31
|
+
|
32
|
+
def plagger(config, data)
|
33
|
+
pla_con = config["plugins"]
|
34
|
+
|
35
|
+
if input_option(config) == :feed
|
36
|
+
pla_con = [{"module" => "Subscription::Feed", "config"=>{ "url" => "file:#{pla_input(config)}" }}] + pla_con
|
37
|
+
eval_pragger([{"module" => "save_rss", "config" => { "filename" => pla_input(config).to_s }}], data)
|
38
|
+
end
|
39
|
+
|
40
|
+
pla_con.push({"module" => "Publish::Feed",
|
41
|
+
"config" =>
|
42
|
+
{"dir" => "/var",
|
43
|
+
"format" => "RSS",
|
44
|
+
"filename" => pla_output(config).basename.to_s}})
|
45
|
+
|
46
|
+
pla_config(config).open("w") {|io| io.write to_plagger_yaml(YAML.dump({ "plugins" => pla_con })) }
|
47
|
+
|
48
|
+
system "plagger -c #{pla_config(config)}"
|
49
|
+
|
50
|
+
begin
|
51
|
+
RSS::Parser.parse(pla_output(config).read).items
|
52
|
+
rescue
|
53
|
+
[]
|
54
|
+
ensure
|
55
|
+
unless config.has_key?("debug")
|
56
|
+
pla_config(config).delete
|
57
|
+
pla_input(config).delete
|
58
|
+
pla_output(config).delete
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def pla_dir(config)
|
64
|
+
Pathname.new(config.has_key?("dir") ? config["dir"] : "/var")
|
65
|
+
end
|
66
|
+
|
67
|
+
def pla_config(config)
|
68
|
+
pla_dir(config) + "pla.yaml"
|
69
|
+
end
|
70
|
+
|
71
|
+
def pla_output(config)
|
72
|
+
pla_dir(config) + "pla_output"
|
73
|
+
end
|
74
|
+
|
75
|
+
def pla_input(config)
|
76
|
+
pla_dir(config) + "pla_input"
|
77
|
+
end
|
78
|
+
|
79
|
+
def input_option(config)
|
80
|
+
opt = config.has_key?("input") ? config["input"] : "nothing"
|
81
|
+
case opt
|
82
|
+
when "feed": :feed
|
83
|
+
when "nothing": :nothing
|
84
|
+
else
|
85
|
+
:nothing
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
def to_plagger_yaml(yaml)
|
90
|
+
a = yaml.split(/\n/)
|
91
|
+
ret = a[1]+"\n"
|
92
|
+
ret + a[2..(a.size-1)].collect {|x| " "+x }.join("\n")+"\n"
|
93
|
+
end
|
94
|
+
|
@@ -0,0 +1,31 @@
|
|
1
|
+
## Load plugin from uri and evaluate it -- Soutaro Matsumoto
|
2
|
+
##
|
3
|
+
## Load plugiin from uri and evaluate it.
|
4
|
+
## If you omit "name", the last component of the uri will be used as the name of plugin.
|
5
|
+
##
|
6
|
+
## - module: plugin_from_uri
|
7
|
+
## config:
|
8
|
+
## uri: http://some_host/some_path
|
9
|
+
## name: super_plugin
|
10
|
+
## config:
|
11
|
+
## ** configuration for the plugin **
|
12
|
+
|
13
|
+
require 'open-uri'
|
14
|
+
require 'uri'
|
15
|
+
|
16
|
+
def plugin_from_uri(config, data)
|
17
|
+
uri = URI(config["uri"])
|
18
|
+
name = config["name"] || uri.path.split("/").last.gsub(/\..*$/,'')
|
19
|
+
|
20
|
+
body = open(uri.to_s) {|io| io.read}
|
21
|
+
|
22
|
+
plugin = Class.new(Plugin)
|
23
|
+
plugin.class_eval {
|
24
|
+
def initialize()
|
25
|
+
end
|
26
|
+
}
|
27
|
+
plugin.class_eval(body, uri.to_s, 1)
|
28
|
+
|
29
|
+
plugin.new().send(name, config["config"], data)
|
30
|
+
end
|
31
|
+
|
@@ -0,0 +1,18 @@
|
|
1
|
+
## Send Message Plugin -- Soutaro Matsumoto
|
2
|
+
##
|
3
|
+
## it invoke ruby method
|
4
|
+
##
|
5
|
+
## -module: send_msg
|
6
|
+
## config:
|
7
|
+
## method: to_s
|
8
|
+
## params: 16
|
9
|
+
##
|
10
|
+
|
11
|
+
def send_msg(config, data)
|
12
|
+
method = config['method'] || nil
|
13
|
+
params = config['params'] || []
|
14
|
+
|
15
|
+
data.collect {|x|
|
16
|
+
method ? x.send(method, *params) : x
|
17
|
+
}
|
18
|
+
end
|