aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-03-21 18:17:35 +0100
committerRoger Braun <roger@rogerbraun.net>2017-03-21 18:17:35 +0100
commitad303783afc0be046d0bcb4b70b3bce9aabac27f (patch)
tree40bda29bbd065c721dbbe9d0e5d958d87ad8281e /lib
parent9a8850eb9ec9eba9350fcb6aadf70fd966623c94 (diff)
downloadpleroma-ad303783afc0be046d0bcb4b70b3bce9aabac27f.tar.gz
Add status posting via TwAPI.
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/router.ex1
-rw-r--r--lib/pleroma/web/twitter_api/twitter_api.ex12
-rw-r--r--lib/pleroma/web/twitter_api/twitter_api_controller.ex10
3 files changed, 15 insertions, 8 deletions
diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex
index 83e4253ce..1e865b358 100644
--- a/lib/pleroma/web/router.ex
+++ b/lib/pleroma/web/router.ex
@@ -21,5 +21,6 @@ defmodule Pleroma.Web.Router do
pipe_through :authenticated_api
post "/account/verify_credentials.json", TwitterAPI.Controller, :verify_credentials
+ post "/statuses/update.json", TwitterAPI.Controller, :status_update
end
end
diff --git a/lib/pleroma/web/twitter_api/twitter_api.ex b/lib/pleroma/web/twitter_api/twitter_api.ex
index 16e05ded3..9e3251df6 100644
--- a/lib/pleroma/web/twitter_api/twitter_api.ex
+++ b/lib/pleroma/web/twitter_api/twitter_api.ex
@@ -6,15 +6,15 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
def create_status(user = %User{}, data = %{}) do
activity = %{
- type: "Create",
- to: [
+ "type" => "Create",
+ "to" => [
User.ap_followers(user),
"https://www.w3.org/ns/activitystreams#Public"
],
- actor: User.ap_id(user),
- object: %{
- type: "Note",
- content: data.status
+ "actor" => User.ap_id(user),
+ "object" => %{
+ "type" => "Note",
+ "content" => data["status"]
}
}
diff --git a/lib/pleroma/web/twitter_api/twitter_api_controller.ex b/lib/pleroma/web/twitter_api/twitter_api_controller.ex
index 836013cff..1f0a547d0 100644
--- a/lib/pleroma/web/twitter_api/twitter_api_controller.ex
+++ b/lib/pleroma/web/twitter_api/twitter_api_controller.ex
@@ -1,7 +1,7 @@
defmodule Pleroma.Web.TwitterAPI.Controller do
use Pleroma.Web, :controller
-
- alias Pleroma.Web.TwitterAPI.Representers.UserRepresenter
+ alias Pleroma.Web.TwitterAPI.TwitterAPI
+ alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ActivityRepresenter}
def verify_credentials(%{assigns: %{user: user}} = conn, _params) do
response = user |> UserRepresenter.to_json
@@ -10,6 +10,12 @@ defmodule Pleroma.Web.TwitterAPI.Controller do
|> json_reply(200, response)
end
+ def status_update(%{assigns: %{user: user}} = conn, status_data) do
+ {:ok, activity} = TwitterAPI.create_status(user, status_data)
+ conn
+ |> json_reply(200, ActivityRepresenter.to_json(activity, %{user: user}))
+ end
+
defp json_reply(conn, status, json) do
conn
|> put_resp_content_type("application/json")