diff --git a/Changelog.md b/Changelog.md index baf62dbf226d55b7d0b54fdd0e00498d7b525167..86cf393aff151018de55bad1d7e950ea6a8e04ae 100644 --- a/Changelog.md +++ b/Changelog.md @@ -31,6 +31,7 @@ * Fix javascripts error in invitations facebox. [#3638](https://github.com/diaspora/diaspora/pull/3638) * Fix css overflow problem in aspect dropdown on welcome page. [#3637](https://github.com/diaspora/diaspora/pull/3637) * Fix empty page after authenticating with other services. [#3693](https://github.com/diaspora/diaspora/pull/3693) +* Fix posting public posts to Facebook. [#2882](https://github.com/diaspora/diaspora/issues/2882), [#3650](https://github.com/diaspora/diaspora/issues/3650) # 0.0.1.2 diff --git a/app/models/services/facebook.rb b/app/models/services/facebook.rb index 39d2b10863f8e52e8011a4357fc8ab779584ba24..45ee65817407d7e82bed434f59fbe9adbb06b9dc 100644 --- a/app/models/services/facebook.rb +++ b/app/models/services/facebook.rb @@ -11,21 +11,13 @@ class Services::Facebook < Service def post(post, url='') Rails.logger.debug("event=post_to_service type=facebook sender_id=#{self.user_id}") - if post.public? - post_to_facebook("https://graph.facebook.com/me/joindiaspora:make", create_open_graph_params(post).to_param) - else - post_to_facebook("https://graph.facebook.com/me/feed", create_post_params(post).to_param) - end + post_to_facebook("https://graph.facebook.com/me/feed", create_post_params(post).to_param) end def post_to_facebook(url, body) Faraday.post(url, body) end - def create_open_graph_params(post) - {:post => "#{AppConfig.pod_uri.to_s}#{short_post_path(post)}", :access_token => self.access_token} - end - def create_post_params(post) message = post.text(:plain_text => true) {:message => message, :access_token => self.access_token, :link => URI.extract(message, ['https', 'http']).first} diff --git a/config/defaults.yml b/config/defaults.yml index fffeeb1a9ea7ea9c0b9d91dc8b5d96b7e8cf1826..169edaa7e92f307eccd4d3abc9f85381d1be6e4b 100644 --- a/config/defaults.yml +++ b/config/defaults.yml @@ -56,7 +56,6 @@ defaults: enable: false app_id: secret: - open_graph_namespace: 'joindiaspora' twitter: enable: false key: diff --git a/config/diaspora.yml.example b/config/diaspora.yml.example index b9b241c5eb91f0325fec2ce9f87e6df7b3257aa5..1932a7a6eefc605d4c21a6e93c7f4e8c0529bf82 100644 --- a/config/diaspora.yml.example +++ b/config/diaspora.yml.example @@ -252,9 +252,6 @@ configuration: ## Section #enable: true #app_id: 'abcdef' #secret: 'changeme' - ## this will be the namespace for your object, - ## it should be configured in your FB app - #open_graph_namespace: ## OAuth credentials for Twitter: twitter: ## Section diff --git a/spec/models/services/facebook_spec.rb b/spec/models/services/facebook_spec.rb index 792c4df96fa908a2f2a58e2095d9bd15751e02bb..f401b83a539461715630c81368ce2fd81d18a1ac 100644 --- a/spec/models/services/facebook_spec.rb +++ b/spec/models/services/facebook_spec.rb @@ -11,7 +11,7 @@ describe Services::Facebook do describe '#post' do it 'posts a status message to facebook' do - stub_request(:post, "https://graph.facebook.com/me/joindiaspora:make"). + stub_request(:post, "https://graph.facebook.com/me/feed"). to_return(:status => 200, :body => "", :headers => {}) @service.post(@post) end @@ -19,13 +19,13 @@ describe Services::Facebook do it 'swallows exception raised by facebook always being down' do pending "temporarily disabled to figure out while some requests are failing" - stub_request(:post,"https://graph.facebook.com/me/joindiaspora:make"). + stub_request(:post,"https://graph.facebook.com/me/feed"). to_raise(StandardError) @service.post(@post) end it 'should call public message' do - stub_request(:post, "https://graph.facebook.com/me/joindiaspora:make"). + stub_request(:post, "https://graph.facebook.com/me/feed"). to_return(:status => 200) url = "foo" @service.should_not_receive(:public_message)