social2social 0.0.2 → 0.0.3
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/.gitignore +1 -0
- data/Gemfile +1 -1
- data/Gemfile.lock +71 -70
- data/README.rdoc +1 -1
- data/app/controllers/pshb_controller.rb +14 -21
- data/app/controllers/remoteusers_controller.rb +17 -8
- data/app/models/remote_subject.rb +26 -0
- data/lib/generators/social2social/install_generator.rb +10 -2
- data/lib/generators/social2social/templates/en.yml +34 -0
- data/lib/generators/social2social/templates/initializer.rb +2 -2
- data/lib/generators/social2social/templates/migration.rb +5 -5
- data/lib/generators/social2social/templates/public/images/logos/actor/remote_user.png +0 -0
- data/lib/social2social/engine.rb +9 -9
- data/lib/social2social/models/shareable.rb +1 -1
- data/social2social.gemspec +5 -3
- data/spec/dummy/script/rails +0 -0
- metadata +46 -27
- data/app/models/remote_user.rb +0 -6
- data/social2social-0.0.1.gem +0 -0
data/.gitignore
CHANGED
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
|
@@ -1,42 +1,45 @@
|
|
|
1
1
|
PATH
|
|
2
2
|
remote: .
|
|
3
3
|
specs:
|
|
4
|
-
social2social (0.0.
|
|
5
|
-
|
|
4
|
+
social2social (0.0.2)
|
|
5
|
+
nokogiri (~> 1.4.4)
|
|
6
|
+
social_stream (~> 0.4.4)
|
|
6
7
|
|
|
7
8
|
GEM
|
|
8
9
|
remote: http://rubygems.org/
|
|
9
10
|
specs:
|
|
10
11
|
abstract (1.0.0)
|
|
11
|
-
actionmailer (3.0.
|
|
12
|
-
actionpack (= 3.0.
|
|
12
|
+
actionmailer (3.0.7)
|
|
13
|
+
actionpack (= 3.0.7)
|
|
13
14
|
mail (~> 2.2.15)
|
|
14
|
-
actionpack (3.0.
|
|
15
|
-
activemodel (= 3.0.
|
|
16
|
-
activesupport (= 3.0.
|
|
15
|
+
actionpack (3.0.7)
|
|
16
|
+
activemodel (= 3.0.7)
|
|
17
|
+
activesupport (= 3.0.7)
|
|
17
18
|
builder (~> 2.1.2)
|
|
18
19
|
erubis (~> 2.6.6)
|
|
19
|
-
i18n (~> 0.
|
|
20
|
+
i18n (~> 0.5.0)
|
|
20
21
|
rack (~> 1.2.1)
|
|
21
|
-
rack-mount (~> 0.6.
|
|
22
|
+
rack-mount (~> 0.6.14)
|
|
22
23
|
rack-test (~> 0.5.7)
|
|
23
24
|
tzinfo (~> 0.3.23)
|
|
24
|
-
activemodel (3.0.
|
|
25
|
-
activesupport (= 3.0.
|
|
25
|
+
activemodel (3.0.7)
|
|
26
|
+
activesupport (= 3.0.7)
|
|
26
27
|
builder (~> 2.1.2)
|
|
27
|
-
i18n (~> 0.
|
|
28
|
-
activerecord (3.0.
|
|
29
|
-
activemodel (= 3.0.
|
|
30
|
-
activesupport (= 3.0.
|
|
28
|
+
i18n (~> 0.5.0)
|
|
29
|
+
activerecord (3.0.7)
|
|
30
|
+
activemodel (= 3.0.7)
|
|
31
|
+
activesupport (= 3.0.7)
|
|
31
32
|
arel (~> 2.0.2)
|
|
32
33
|
tzinfo (~> 0.3.23)
|
|
33
|
-
activeresource (3.0.
|
|
34
|
-
activemodel (= 3.0.
|
|
35
|
-
activesupport (= 3.0.
|
|
36
|
-
activesupport (3.0.
|
|
37
|
-
|
|
34
|
+
activeresource (3.0.7)
|
|
35
|
+
activemodel (= 3.0.7)
|
|
36
|
+
activesupport (= 3.0.7)
|
|
37
|
+
activesupport (3.0.7)
|
|
38
|
+
acts-as-taggable-on (2.0.6)
|
|
39
|
+
addressable (2.2.5)
|
|
40
|
+
ancestry (1.2.3)
|
|
41
|
+
activerecord (>= 2.2.2)
|
|
38
42
|
arel (2.0.9)
|
|
39
|
-
atd-ancestry (1.3.0)
|
|
40
43
|
bcrypt-ruby (2.1.4)
|
|
41
44
|
builder (2.1.2)
|
|
42
45
|
cancan (1.6.4)
|
|
@@ -51,7 +54,7 @@ GEM
|
|
|
51
54
|
ffi (~> 1.0.6)
|
|
52
55
|
columnize (0.3.2)
|
|
53
56
|
culerity (0.2.15)
|
|
54
|
-
devise (1.
|
|
57
|
+
devise (1.3.1)
|
|
55
58
|
bcrypt-ruby (~> 2.1.2)
|
|
56
59
|
orm_adapter (~> 0.0.3)
|
|
57
60
|
warden (~> 1.0.3)
|
|
@@ -59,13 +62,13 @@ GEM
|
|
|
59
62
|
erubis (2.6.6)
|
|
60
63
|
abstract (>= 1.0.0)
|
|
61
64
|
factory_girl (1.3.3)
|
|
62
|
-
faraday (0.
|
|
65
|
+
faraday (0.6.1)
|
|
63
66
|
addressable (~> 2.2.4)
|
|
64
67
|
multipart-post (~> 1.1.0)
|
|
65
68
|
rack (>= 1.1.0, < 2)
|
|
66
69
|
ffi (1.0.7)
|
|
67
70
|
rake (>= 0.8.7)
|
|
68
|
-
foreigner (0.9.
|
|
71
|
+
foreigner (0.9.2)
|
|
69
72
|
forgery (0.3.7)
|
|
70
73
|
nokogiri (~> 1.4)
|
|
71
74
|
has_scope (0.5.0)
|
|
@@ -78,65 +81,63 @@ GEM
|
|
|
78
81
|
thor (~> 0.14.4)
|
|
79
82
|
json_pure (1.5.1)
|
|
80
83
|
linecache (0.43)
|
|
81
|
-
mail (2.2.
|
|
84
|
+
mail (2.2.17)
|
|
82
85
|
activesupport (>= 2.3.6)
|
|
83
86
|
i18n (>= 0.4.0)
|
|
84
87
|
mime-types (~> 1.16)
|
|
85
88
|
treetop (~> 1.4.8)
|
|
86
|
-
mailboxer (0.0.
|
|
89
|
+
mailboxer (0.0.16)
|
|
87
90
|
foreigner (~> 0.9.1)
|
|
88
91
|
mime-types (1.16)
|
|
89
92
|
multi_json (0.0.5)
|
|
90
93
|
multipart-post (1.1.0)
|
|
91
|
-
nested_set (1.5.4)
|
|
92
|
-
activerecord (>= 3.0.0)
|
|
93
|
-
railties (>= 3.0.0)
|
|
94
94
|
net-ldap (0.1.1)
|
|
95
95
|
nokogiri (1.4.4)
|
|
96
|
-
oa-basic (0.2.
|
|
96
|
+
oa-basic (0.2.2)
|
|
97
97
|
multi_json (~> 0.0.2)
|
|
98
98
|
nokogiri (~> 1.4.2)
|
|
99
|
-
oa-core (= 0.2.
|
|
99
|
+
oa-core (= 0.2.2)
|
|
100
100
|
rest-client (~> 1.6.0)
|
|
101
|
-
oa-core (0.2.
|
|
101
|
+
oa-core (0.2.2)
|
|
102
102
|
rack (~> 1.1)
|
|
103
|
-
oa-enterprise (0.2.
|
|
103
|
+
oa-enterprise (0.2.2)
|
|
104
104
|
net-ldap (~> 0.1.1)
|
|
105
105
|
nokogiri (~> 1.4.2)
|
|
106
|
-
oa-core (= 0.2.
|
|
106
|
+
oa-core (= 0.2.2)
|
|
107
107
|
pyu-ruby-sasl (~> 0.0.3.1)
|
|
108
108
|
rubyntlm (~> 0.1.1)
|
|
109
|
-
oa-more (0.2.
|
|
109
|
+
oa-more (0.2.2)
|
|
110
110
|
multi_json (~> 0.0.2)
|
|
111
|
-
oa-core (= 0.2.
|
|
111
|
+
oa-core (= 0.2.2)
|
|
112
112
|
rest-client (~> 1.6.0)
|
|
113
|
-
oa-oauth (0.2.
|
|
113
|
+
oa-oauth (0.2.2)
|
|
114
|
+
faraday (~> 0.6.1)
|
|
114
115
|
multi_json (~> 0.0.2)
|
|
115
116
|
nokogiri (~> 1.4.2)
|
|
116
|
-
oa-core (= 0.2.
|
|
117
|
+
oa-core (= 0.2.2)
|
|
117
118
|
oauth (~> 0.4.0)
|
|
118
|
-
oauth2 (~> 0.
|
|
119
|
-
oa-openid (0.2.
|
|
120
|
-
oa-core (= 0.2.
|
|
119
|
+
oauth2 (~> 0.3.0)
|
|
120
|
+
oa-openid (0.2.2)
|
|
121
|
+
oa-core (= 0.2.2)
|
|
121
122
|
rack-openid (~> 1.2.0)
|
|
122
123
|
ruby-openid-apps-discovery
|
|
123
124
|
oauth (0.4.4)
|
|
124
125
|
oauth-plugin (0.4.0.pre4)
|
|
125
126
|
oauth (>= 0.4.4)
|
|
126
|
-
oauth2 (0.
|
|
127
|
-
faraday (~> 0.
|
|
127
|
+
oauth2 (0.3.0)
|
|
128
|
+
faraday (~> 0.6.0)
|
|
128
129
|
multi_json (~> 0.0.4)
|
|
129
|
-
omniauth (0.2.
|
|
130
|
-
oa-basic (= 0.2.
|
|
131
|
-
oa-core (= 0.2.
|
|
132
|
-
oa-enterprise (= 0.2.
|
|
133
|
-
oa-more (= 0.2.
|
|
134
|
-
oa-oauth (= 0.2.
|
|
135
|
-
oa-openid (= 0.2.
|
|
130
|
+
omniauth (0.2.2)
|
|
131
|
+
oa-basic (= 0.2.2)
|
|
132
|
+
oa-core (= 0.2.2)
|
|
133
|
+
oa-enterprise (= 0.2.2)
|
|
134
|
+
oa-more (= 0.2.2)
|
|
135
|
+
oa-oauth (= 0.2.2)
|
|
136
|
+
oa-openid (= 0.2.2)
|
|
136
137
|
orm_adapter (0.0.4)
|
|
137
|
-
paperclip (2.3.
|
|
138
|
-
activerecord
|
|
139
|
-
activesupport
|
|
138
|
+
paperclip (2.3.11)
|
|
139
|
+
activerecord (>= 2.3.0)
|
|
140
|
+
activesupport (>= 2.3.2)
|
|
140
141
|
polyglot (0.3.1)
|
|
141
142
|
pyu-ruby-sasl (0.0.3.2)
|
|
142
143
|
rack (1.2.2)
|
|
@@ -147,18 +148,18 @@ GEM
|
|
|
147
148
|
ruby-openid (>= 2.1.8)
|
|
148
149
|
rack-test (0.5.7)
|
|
149
150
|
rack (>= 1.0)
|
|
150
|
-
rails (3.0.
|
|
151
|
-
actionmailer (= 3.0.
|
|
152
|
-
actionpack (= 3.0.
|
|
153
|
-
activerecord (= 3.0.
|
|
154
|
-
activeresource (= 3.0.
|
|
155
|
-
activesupport (= 3.0.
|
|
151
|
+
rails (3.0.7)
|
|
152
|
+
actionmailer (= 3.0.7)
|
|
153
|
+
actionpack (= 3.0.7)
|
|
154
|
+
activerecord (= 3.0.7)
|
|
155
|
+
activeresource (= 3.0.7)
|
|
156
|
+
activesupport (= 3.0.7)
|
|
156
157
|
bundler (~> 1.0)
|
|
157
|
-
railties (= 3.0.
|
|
158
|
+
railties (= 3.0.7)
|
|
158
159
|
rails_css_themes (1.0.0)
|
|
159
|
-
railties (3.0.
|
|
160
|
-
actionpack (= 3.0.
|
|
161
|
-
activesupport (= 3.0.
|
|
160
|
+
railties (3.0.7)
|
|
161
|
+
actionpack (= 3.0.7)
|
|
162
|
+
activesupport (= 3.0.7)
|
|
162
163
|
rake (>= 0.8.7)
|
|
163
164
|
thor (~> 0.14.4)
|
|
164
165
|
rake (0.8.7)
|
|
@@ -194,15 +195,15 @@ GEM
|
|
|
194
195
|
ffi (>= 1.0.7)
|
|
195
196
|
json_pure
|
|
196
197
|
rubyzip
|
|
197
|
-
social_stream (0.4.
|
|
198
|
-
|
|
199
|
-
|
|
198
|
+
social_stream (0.4.4)
|
|
199
|
+
acts-as-taggable-on (~> 2.0.6)
|
|
200
|
+
ancestry (~> 1.2.3)
|
|
201
|
+
cancan (~> 1.6.4)
|
|
200
202
|
devise (~> 1.2.rc)
|
|
201
203
|
foreigner (~> 0.9.1)
|
|
202
204
|
inherited_resources (~> 1.1.2)
|
|
203
205
|
jquery-rails (~> 0.2.5)
|
|
204
|
-
mailboxer (~> 0.0.
|
|
205
|
-
nested_set (~> 1.5.3)
|
|
206
|
+
mailboxer (~> 0.0.16)
|
|
206
207
|
oauth-plugin (~> 0.4.0.pre1)
|
|
207
208
|
omniauth (~> 0.2.0.beta5)
|
|
208
209
|
paperclip (~> 2.3.4)
|
|
@@ -217,7 +218,7 @@ GEM
|
|
|
217
218
|
thor (0.14.6)
|
|
218
219
|
treetop (1.4.9)
|
|
219
220
|
polyglot (>= 0.3.1)
|
|
220
|
-
tzinfo (0.3.
|
|
221
|
+
tzinfo (0.3.26)
|
|
221
222
|
warden (1.0.3)
|
|
222
223
|
rack (>= 1.0.0)
|
|
223
224
|
will_paginate (3.0.pre2)
|
|
@@ -229,7 +230,7 @@ DEPENDENCIES
|
|
|
229
230
|
capybara (~> 0.3.9)
|
|
230
231
|
factory_girl (~> 1.3.2)
|
|
231
232
|
forgery (~> 0.3.6)
|
|
232
|
-
rails (~> 3.0.
|
|
233
|
+
rails (~> 3.0.7)
|
|
233
234
|
rspec-rails (~> 2.5.0)
|
|
234
235
|
ruby-debug (~> 0.10.3)
|
|
235
236
|
social2social!
|
data/README.rdoc
CHANGED
|
@@ -6,6 +6,7 @@ class PshbController < ApplicationController
|
|
|
6
6
|
render :text => params['hub.challenge'], :status => 200
|
|
7
7
|
# TO-DO: confirm that params['hub.topic'] is a real
|
|
8
8
|
# requested subscription by someone in this node
|
|
9
|
+
return
|
|
9
10
|
end
|
|
10
11
|
|
|
11
12
|
#sync unsubscription verification
|
|
@@ -14,28 +15,20 @@ class PshbController < ApplicationController
|
|
|
14
15
|
# TO-DO: confirm that params['hub.topic'] is a real
|
|
15
16
|
# requested unsubscription by someone in this node
|
|
16
17
|
# and delete permissions/remote actor if necessary
|
|
18
|
+
return
|
|
17
19
|
end
|
|
18
20
|
|
|
19
|
-
|
|
21
|
+
#If we got here we are receiving an XML Activity Feed
|
|
22
|
+
doc = Nokogiri::XML(request.body.read)
|
|
23
|
+
origin = doc.xpath("//xmlns:link[@rel='self']").first['href'].split('/')
|
|
24
|
+
webfinger_slug = origin[5]+"@"+origin[2]
|
|
25
|
+
|
|
26
|
+
activity_texts = doc.xpath("//xmlns:content")
|
|
27
|
+
activity_texts.each do |activity_text|
|
|
28
|
+
r_user = RemoteSubject.find_by_webfinger_slug(webfinger_slug)
|
|
29
|
+
if r_user != nil
|
|
30
|
+
Post.create!(:text => activity_text.content, :_activity_tie_id => r_user.public_tie)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
20
33
|
end
|
|
21
|
-
|
|
22
|
-
#require "net/http"
|
|
23
|
-
#require "uri"
|
|
24
|
-
|
|
25
|
-
#def pshb_subscription_request#(topic,hub,mode)
|
|
26
|
-
# t = Thread.new do
|
|
27
|
-
# #test
|
|
28
|
-
# hub = 'http://138.4.7.113:4567/' # last '/' is mandatory!
|
|
29
|
-
# topic = 'http://138.4.7.69:3000/api/user/demo/home.atom'
|
|
30
|
-
# mode = 'subscribe'
|
|
31
|
-
# #
|
|
32
|
-
# uri = URI.parse(hub)
|
|
33
|
-
# response = Net::HTTP::post_form(uri,{ 'hub.callback' => pshb_callback_url,
|
|
34
|
-
# 'hub.mode' => mode,
|
|
35
|
-
# 'hub.topic' => topic,
|
|
36
|
-
# 'hub.verify' => 'sync'})
|
|
37
|
-
#puts response.body
|
|
38
|
-
# #TO-DO: process 4XX response.status
|
|
39
|
-
# end
|
|
40
|
-
#end
|
|
41
34
|
end
|
|
@@ -3,14 +3,23 @@ class RemoteusersController < ApplicationController
|
|
|
3
3
|
|
|
4
4
|
def index
|
|
5
5
|
if params[:slug].present?
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
6
|
+
#Selecting the remote subject
|
|
7
|
+
u = RemoteSubject.find_or_create_using_wslug(params[:slug])
|
|
8
|
+
|
|
9
|
+
#Creating the tie between me and the remote subject
|
|
10
|
+
t = Tie.create!(:sender => current_user.actor,
|
|
11
|
+
:receiver => u.actor,
|
|
12
|
+
:relation_name => "friend")
|
|
13
|
+
|
|
14
|
+
#Requesting a subscription to the hub
|
|
15
|
+
t = Thread.new do
|
|
16
|
+
uri = URI.parse(Social2social.hub)
|
|
17
|
+
response = Net::HTTP::post_form(uri,{ 'hub.callback' => pshb_callback_url,
|
|
18
|
+
'hub.mode' => "subscribe",
|
|
19
|
+
'hub.topic' => u.home_feed_url,
|
|
20
|
+
'hub.verify' => 'sync'})
|
|
21
|
+
|
|
22
|
+
end
|
|
14
23
|
end
|
|
15
24
|
|
|
16
25
|
respond_to do |format|
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
class RemoteSubject < ActiveRecord::Base
|
|
2
|
+
attr_accessible :name, :webfinger_slug, :hub_url, :origin_node_url
|
|
3
|
+
|
|
4
|
+
#validates_format_of :webfinger_slug, :with => Devise.email_regexp, :allow_blank => true
|
|
5
|
+
|
|
6
|
+
class << self
|
|
7
|
+
def find_or_create_using_wslug(slug)
|
|
8
|
+
r_user = RemoteSubject.find_by_webfinger_slug(slug)
|
|
9
|
+
if r_user == nil
|
|
10
|
+
wfslug = slug.split('@')
|
|
11
|
+
r_user = RemoteSubject.create!(:name => wfslug[0],
|
|
12
|
+
:webfinger_slug => slug,
|
|
13
|
+
:origin_node_url => wfslug[1],
|
|
14
|
+
:hub_url => Social2social.hub)
|
|
15
|
+
end
|
|
16
|
+
r_user
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
#Home feed url for this RemoteUser
|
|
21
|
+
def home_feed_url
|
|
22
|
+
"http://"+origin_node_url.to_s+"/api/user/"+name.to_s+"/home.atom"
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
end
|
|
@@ -19,8 +19,16 @@ class Social2social::InstallGenerator < Rails::Generators::Base
|
|
|
19
19
|
|
|
20
20
|
def inject_remote_user_relation
|
|
21
21
|
append_file 'config/relations.yml',
|
|
22
|
-
"\
|
|
23
|
-
|
|
22
|
+
"\nremote_subject:\n friend:\n name: friend\n permissions:\n - [ follow ]\n sphere: personal\n"+
|
|
23
|
+
" public:\n name: public\n permissions:\n - [ read, tie, star_tie ]\n sphere: personal"
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
def inject_translations
|
|
27
|
+
copy_file 'en.yml', 'config/locales/s2s.en.yml'
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
def copy_public
|
|
31
|
+
directory "public"
|
|
24
32
|
end
|
|
25
33
|
|
|
26
34
|
require 'rails/generators/active_record'
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
en:
|
|
2
|
+
activity:
|
|
3
|
+
verb:
|
|
4
|
+
follow:
|
|
5
|
+
RemoteSubject:
|
|
6
|
+
title: "%{subject} added %{contact} as contact."
|
|
7
|
+
message: "%{name} added you as contact."
|
|
8
|
+
notification:
|
|
9
|
+
subject: "%{name} added you as contact."
|
|
10
|
+
body: "%{name} added you as contact."
|
|
11
|
+
like:
|
|
12
|
+
RemoteSubject:
|
|
13
|
+
title: "%{subject} is a fan of %{contact}."
|
|
14
|
+
message: "%{name} is now your fan."
|
|
15
|
+
notification:
|
|
16
|
+
subject: "%{name} is now your fan."
|
|
17
|
+
body: "%{name} is now your fan."
|
|
18
|
+
make-friend:
|
|
19
|
+
RemoteSubject:
|
|
20
|
+
title: "%{subject} and %{contact} are now connected."
|
|
21
|
+
message: "%{name} also added you as contact."
|
|
22
|
+
notification:
|
|
23
|
+
subject: "%{name} also added you as contact."
|
|
24
|
+
body: "%{name} also added you as contact."
|
|
25
|
+
post:
|
|
26
|
+
RemoteSubject:
|
|
27
|
+
notification:
|
|
28
|
+
subject: "%{name} has posted something(%{direct_object}) in your wall"
|
|
29
|
+
body: "%{name} has posted something(%{direct_object}) in your wall"
|
|
30
|
+
update:
|
|
31
|
+
RemoteSubject:
|
|
32
|
+
notification:
|
|
33
|
+
subject: "%{name} has updated %{direct_object} in your wall"
|
|
34
|
+
body: "%{name} has updated something(%{direct_object}) in your wall"
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
class CreateSocial2social < ActiveRecord::Migration
|
|
2
2
|
|
|
3
3
|
def self.up
|
|
4
|
-
create_table :
|
|
4
|
+
create_table :remote_subjects, :force => true do |t|
|
|
5
5
|
t.integer :actor_id
|
|
6
6
|
t.string :webfinger_slug
|
|
7
7
|
t.string :hub_url
|
|
@@ -9,13 +9,13 @@ class CreateSocial2social < ActiveRecord::Migration
|
|
|
9
9
|
t.timestamps
|
|
10
10
|
end
|
|
11
11
|
|
|
12
|
-
add_index "
|
|
13
|
-
add_foreign_key "
|
|
12
|
+
add_index "remote_subjects", "actor_id"
|
|
13
|
+
add_foreign_key "remote_subjects", "actors", :name => "remote_subjects_on_actor_id"
|
|
14
14
|
end
|
|
15
15
|
|
|
16
16
|
def self.down
|
|
17
|
-
remove_foreign_key "
|
|
18
|
-
drop_table :
|
|
17
|
+
remove_foreign_key "remote_subjects", :name => "remote_subjects_on_actor_id"
|
|
18
|
+
drop_table :remote_subjects
|
|
19
19
|
end
|
|
20
20
|
|
|
21
21
|
end
|
|
Binary file
|
data/lib/social2social/engine.rb
CHANGED
|
@@ -3,19 +3,19 @@ module Social2social
|
|
|
3
3
|
config.app_generators.social_stream :social_stream
|
|
4
4
|
|
|
5
5
|
config.to_prepare do
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class ::Actor
|
|
6
|
+
#Patching Actor
|
|
7
|
+
Actor.class_eval do
|
|
10
8
|
include Social2social::Models::Shareable
|
|
11
9
|
end
|
|
12
10
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
class ::TieActivity
|
|
11
|
+
#Patching TieAct
|
|
12
|
+
TieActivity.class_eval do
|
|
16
13
|
include Social2social::Models::UpdateTriggerable
|
|
17
14
|
end
|
|
18
15
|
end
|
|
19
|
-
|
|
16
|
+
|
|
17
|
+
initializer "social2social.remote_subject_in_social_stream_subjects" do
|
|
18
|
+
SocialStream.subjects << :remote_subject unless SocialStream.subjects.include?(:remote_subject)
|
|
19
|
+
end
|
|
20
20
|
end
|
|
21
|
-
end
|
|
21
|
+
end
|
data/social2social.gemspec
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Gem::Specification.new do |s|
|
|
2
2
|
s.name = "social2social"
|
|
3
|
-
s.version = "0.0.
|
|
3
|
+
s.version = "0.0.3"
|
|
4
4
|
s.authors = ["Víctor Sánchez Belmar"]
|
|
5
5
|
s.summary = "Provides a social stream node able to decentralize contents with the OStatus protocol"
|
|
6
6
|
s.description = "This gem allow you to connect several social stream nodes using PSHB hubs, also allows to follow, and share streams with social stream users in any node."
|
|
@@ -9,9 +9,11 @@ Gem::Specification.new do |s|
|
|
|
9
9
|
s.files = `git ls-files`.split("\n")
|
|
10
10
|
|
|
11
11
|
# Gem dependencies
|
|
12
|
-
s.add_runtime_dependency('social_stream','~> 0.4.
|
|
12
|
+
s.add_runtime_dependency('social_stream','~> 0.4.4')
|
|
13
|
+
s.add_runtime_dependency('nokogiri','~> 1.4.4')
|
|
14
|
+
|
|
13
15
|
# Development Gem dependencies
|
|
14
|
-
s.add_development_dependency('rails', '~> 3.0.
|
|
16
|
+
s.add_development_dependency('rails', '~> 3.0.7')
|
|
15
17
|
s.add_development_dependency('sqlite3-ruby')
|
|
16
18
|
if RUBY_VERSION < '1.9'
|
|
17
19
|
s.add_development_dependency('ruby-debug', '~> 0.10.3')
|
data/spec/dummy/script/rails
CHANGED
|
File without changes
|
metadata
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: social2social
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
hash:
|
|
4
|
+
hash: 25
|
|
5
5
|
prerelease:
|
|
6
6
|
segments:
|
|
7
7
|
- 0
|
|
8
8
|
- 0
|
|
9
|
-
-
|
|
10
|
-
version: 0.0.
|
|
9
|
+
- 3
|
|
10
|
+
version: 0.0.3
|
|
11
11
|
platform: ruby
|
|
12
12
|
authors:
|
|
13
13
|
- "V\xC3\xADctor S\xC3\xA1nchez Belmar"
|
|
@@ -15,7 +15,8 @@ autorequire:
|
|
|
15
15
|
bindir: bin
|
|
16
16
|
cert_chain: []
|
|
17
17
|
|
|
18
|
-
date: 2011-04-
|
|
18
|
+
date: 2011-04-27 00:00:00 +02:00
|
|
19
|
+
default_executable:
|
|
19
20
|
dependencies:
|
|
20
21
|
- !ruby/object:Gem::Dependency
|
|
21
22
|
name: social_stream
|
|
@@ -25,34 +26,50 @@ dependencies:
|
|
|
25
26
|
requirements:
|
|
26
27
|
- - ~>
|
|
27
28
|
- !ruby/object:Gem::Version
|
|
28
|
-
hash:
|
|
29
|
+
hash: 7
|
|
29
30
|
segments:
|
|
30
31
|
- 0
|
|
31
32
|
- 4
|
|
32
|
-
-
|
|
33
|
-
version: 0.4.
|
|
33
|
+
- 4
|
|
34
|
+
version: 0.4.4
|
|
34
35
|
type: :runtime
|
|
35
36
|
version_requirements: *id001
|
|
36
37
|
- !ruby/object:Gem::Dependency
|
|
37
|
-
name:
|
|
38
|
+
name: nokogiri
|
|
38
39
|
prerelease: false
|
|
39
40
|
requirement: &id002 !ruby/object:Gem::Requirement
|
|
40
41
|
none: false
|
|
41
42
|
requirements:
|
|
42
43
|
- - ~>
|
|
43
44
|
- !ruby/object:Gem::Version
|
|
44
|
-
hash:
|
|
45
|
+
hash: 15
|
|
46
|
+
segments:
|
|
47
|
+
- 1
|
|
48
|
+
- 4
|
|
49
|
+
- 4
|
|
50
|
+
version: 1.4.4
|
|
51
|
+
type: :runtime
|
|
52
|
+
version_requirements: *id002
|
|
53
|
+
- !ruby/object:Gem::Dependency
|
|
54
|
+
name: rails
|
|
55
|
+
prerelease: false
|
|
56
|
+
requirement: &id003 !ruby/object:Gem::Requirement
|
|
57
|
+
none: false
|
|
58
|
+
requirements:
|
|
59
|
+
- - ~>
|
|
60
|
+
- !ruby/object:Gem::Version
|
|
61
|
+
hash: 9
|
|
45
62
|
segments:
|
|
46
63
|
- 3
|
|
47
64
|
- 0
|
|
48
|
-
-
|
|
49
|
-
version: 3.0.
|
|
65
|
+
- 7
|
|
66
|
+
version: 3.0.7
|
|
50
67
|
type: :development
|
|
51
|
-
version_requirements: *
|
|
68
|
+
version_requirements: *id003
|
|
52
69
|
- !ruby/object:Gem::Dependency
|
|
53
70
|
name: sqlite3-ruby
|
|
54
71
|
prerelease: false
|
|
55
|
-
requirement: &
|
|
72
|
+
requirement: &id004 !ruby/object:Gem::Requirement
|
|
56
73
|
none: false
|
|
57
74
|
requirements:
|
|
58
75
|
- - ">="
|
|
@@ -62,11 +79,11 @@ dependencies:
|
|
|
62
79
|
- 0
|
|
63
80
|
version: "0"
|
|
64
81
|
type: :development
|
|
65
|
-
version_requirements: *
|
|
82
|
+
version_requirements: *id004
|
|
66
83
|
- !ruby/object:Gem::Dependency
|
|
67
84
|
name: ruby-debug
|
|
68
85
|
prerelease: false
|
|
69
|
-
requirement: &
|
|
86
|
+
requirement: &id005 !ruby/object:Gem::Requirement
|
|
70
87
|
none: false
|
|
71
88
|
requirements:
|
|
72
89
|
- - ~>
|
|
@@ -78,11 +95,11 @@ dependencies:
|
|
|
78
95
|
- 3
|
|
79
96
|
version: 0.10.3
|
|
80
97
|
type: :development
|
|
81
|
-
version_requirements: *
|
|
98
|
+
version_requirements: *id005
|
|
82
99
|
- !ruby/object:Gem::Dependency
|
|
83
100
|
name: rspec-rails
|
|
84
101
|
prerelease: false
|
|
85
|
-
requirement: &
|
|
102
|
+
requirement: &id006 !ruby/object:Gem::Requirement
|
|
86
103
|
none: false
|
|
87
104
|
requirements:
|
|
88
105
|
- - ~>
|
|
@@ -94,11 +111,11 @@ dependencies:
|
|
|
94
111
|
- 0
|
|
95
112
|
version: 2.5.0
|
|
96
113
|
type: :development
|
|
97
|
-
version_requirements: *
|
|
114
|
+
version_requirements: *id006
|
|
98
115
|
- !ruby/object:Gem::Dependency
|
|
99
116
|
name: factory_girl
|
|
100
117
|
prerelease: false
|
|
101
|
-
requirement: &
|
|
118
|
+
requirement: &id007 !ruby/object:Gem::Requirement
|
|
102
119
|
none: false
|
|
103
120
|
requirements:
|
|
104
121
|
- - ~>
|
|
@@ -110,11 +127,11 @@ dependencies:
|
|
|
110
127
|
- 2
|
|
111
128
|
version: 1.3.2
|
|
112
129
|
type: :development
|
|
113
|
-
version_requirements: *
|
|
130
|
+
version_requirements: *id007
|
|
114
131
|
- !ruby/object:Gem::Dependency
|
|
115
132
|
name: forgery
|
|
116
133
|
prerelease: false
|
|
117
|
-
requirement: &
|
|
134
|
+
requirement: &id008 !ruby/object:Gem::Requirement
|
|
118
135
|
none: false
|
|
119
136
|
requirements:
|
|
120
137
|
- - ~>
|
|
@@ -126,11 +143,11 @@ dependencies:
|
|
|
126
143
|
- 6
|
|
127
144
|
version: 0.3.6
|
|
128
145
|
type: :development
|
|
129
|
-
version_requirements: *
|
|
146
|
+
version_requirements: *id008
|
|
130
147
|
- !ruby/object:Gem::Dependency
|
|
131
148
|
name: capybara
|
|
132
149
|
prerelease: false
|
|
133
|
-
requirement: &
|
|
150
|
+
requirement: &id009 !ruby/object:Gem::Requirement
|
|
134
151
|
none: false
|
|
135
152
|
requirements:
|
|
136
153
|
- - ~>
|
|
@@ -142,7 +159,7 @@ dependencies:
|
|
|
142
159
|
- 9
|
|
143
160
|
version: 0.3.9
|
|
144
161
|
type: :development
|
|
145
|
-
version_requirements: *
|
|
162
|
+
version_requirements: *id009
|
|
146
163
|
description: This gem allow you to connect several social stream nodes using PSHB hubs, also allows to follow, and share streams with social stream users in any node.
|
|
147
164
|
email: v.sanchezbelmar@gmail.com
|
|
148
165
|
executables: []
|
|
@@ -161,16 +178,17 @@ files:
|
|
|
161
178
|
- Rakefile
|
|
162
179
|
- app/controllers/pshb_controller.rb
|
|
163
180
|
- app/controllers/remoteusers_controller.rb
|
|
164
|
-
- app/models/
|
|
181
|
+
- app/models/remote_subject.rb
|
|
165
182
|
- app/views/remoteusers/index.html.erb
|
|
166
183
|
- lib/generators/social2social/install_generator.rb
|
|
184
|
+
- lib/generators/social2social/templates/en.yml
|
|
167
185
|
- lib/generators/social2social/templates/initializer.rb
|
|
168
186
|
- lib/generators/social2social/templates/migration.rb
|
|
187
|
+
- lib/generators/social2social/templates/public/images/logos/actor/remote_user.png
|
|
169
188
|
- lib/social2social.rb
|
|
170
189
|
- lib/social2social/engine.rb
|
|
171
190
|
- lib/social2social/models/shareable.rb
|
|
172
191
|
- lib/social2social/models/updatetriggerable.rb
|
|
173
|
-
- social2social-0.0.1.gem
|
|
174
192
|
- social2social.gemspec
|
|
175
193
|
- spec/dummy/Rakefile
|
|
176
194
|
- spec/dummy/app/controllers/application_controller.rb
|
|
@@ -206,6 +224,7 @@ files:
|
|
|
206
224
|
- spec/integration/navigation_spec.rb
|
|
207
225
|
- spec/social2social_spec.rb
|
|
208
226
|
- spec/spec_helper.rb
|
|
227
|
+
has_rdoc: true
|
|
209
228
|
homepage: http://github.com/ging/social2social
|
|
210
229
|
licenses: []
|
|
211
230
|
|
|
@@ -235,7 +254,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
235
254
|
requirements: []
|
|
236
255
|
|
|
237
256
|
rubyforge_project:
|
|
238
|
-
rubygems_version: 1.
|
|
257
|
+
rubygems_version: 1.5.2
|
|
239
258
|
signing_key:
|
|
240
259
|
specification_version: 3
|
|
241
260
|
summary: Provides a social stream node able to decentralize contents with the OStatus protocol
|
data/app/models/remote_user.rb
DELETED
data/social2social-0.0.1.gem
DELETED
|
Binary file
|