|
|
|
@ -87,31 +87,6 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
plug(Pleroma.Plugs.EnsureUserKeyPlug)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :oauth_read_or_public do
|
|
|
|
|
plug(Pleroma.Plugs.OAuthScopesPlug, %{
|
|
|
|
|
scopes: ["read"],
|
|
|
|
|
fallback: :proceed_unauthenticated
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
plug(Pleroma.Plugs.EnsurePublicOrAuthenticatedPlug)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :oauth_read do
|
|
|
|
|
plug(Pleroma.Plugs.OAuthScopesPlug, %{scopes: ["read"]})
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :oauth_write do
|
|
|
|
|
plug(Pleroma.Plugs.OAuthScopesPlug, %{scopes: ["write"]})
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :oauth_follow do
|
|
|
|
|
plug(Pleroma.Plugs.OAuthScopesPlug, %{scopes: ["follow"]})
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :oauth_push do
|
|
|
|
|
plug(Pleroma.Plugs.OAuthScopesPlug, %{scopes: ["push"]})
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :well_known do
|
|
|
|
|
plug(:accepts, ["json", "jrd+json", "xml", "xrd+xml"])
|
|
|
|
|
end
|
|
|
|
@ -154,7 +129,7 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/pleroma/admin", Pleroma.Web.AdminAPI do
|
|
|
|
|
pipe_through([:admin_api, :oauth_write])
|
|
|
|
|
pipe_through(:admin_api)
|
|
|
|
|
|
|
|
|
|
post("/users/follow", AdminAPIController, :user_follow)
|
|
|
|
|
post("/users/unfollow", AdminAPIController, :user_unfollow)
|
|
|
|
@ -213,7 +188,7 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
scope "/api/pleroma/emoji", Pleroma.Web.PleromaAPI do
|
|
|
|
|
scope "/packs" do
|
|
|
|
|
# Modifying packs
|
|
|
|
|
pipe_through([:admin_api, :oauth_write])
|
|
|
|
|
pipe_through(:admin_api)
|
|
|
|
|
|
|
|
|
|
post("/import_from_fs", EmojiAPIController, :import_from_fs)
|
|
|
|
|
|
|
|
|
@ -238,32 +213,21 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
post("/main/ostatus", UtilController, :remote_subscribe)
|
|
|
|
|
get("/ostatus_subscribe", UtilController, :remote_follow)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_follow)
|
|
|
|
|
post("/ostatus_subscribe", UtilController, :do_remote_follow)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/pleroma", Pleroma.Web.TwitterAPI do
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_write)
|
|
|
|
|
|
|
|
|
|
post("/change_email", UtilController, :change_email)
|
|
|
|
|
post("/change_password", UtilController, :change_password)
|
|
|
|
|
post("/delete_account", UtilController, :delete_account)
|
|
|
|
|
put("/notification_settings", UtilController, :update_notificaton_settings)
|
|
|
|
|
post("/disable_account", UtilController, :disable_account)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_follow)
|
|
|
|
|
|
|
|
|
|
post("/blocks_import", UtilController, :blocks_import)
|
|
|
|
|
post("/follow_import", UtilController, :follow_import)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/oauth", Pleroma.Web.OAuth do
|
|
|
|
|
scope [] do
|
|
|
|
@ -289,14 +253,14 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
scope "/api/v1/pleroma", Pleroma.Web.PleromaAPI do
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
pipe_through(:oauth_read)
|
|
|
|
|
|
|
|
|
|
get("/conversations/:id/statuses", PleromaAPIController, :conversation_statuses)
|
|
|
|
|
get("/conversations/:id", PleromaAPIController, :conversation)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
pipe_through(:oauth_write)
|
|
|
|
|
|
|
|
|
|
patch("/conversations/:id", PleromaAPIController, :update_conversation)
|
|
|
|
|
post("/notifications/read", PleromaAPIController, :read_notification)
|
|
|
|
|
|
|
|
|
@ -312,13 +276,11 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:api)
|
|
|
|
|
pipe_through(:oauth_read_or_public)
|
|
|
|
|
get("/accounts/:id/favourites", AccountController, :favourites)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
pipe_through(:oauth_follow)
|
|
|
|
|
|
|
|
|
|
post("/accounts/:id/subscribe", AccountController, :subscribe)
|
|
|
|
|
post("/accounts/:id/unsubscribe", AccountController, :unsubscribe)
|
|
|
|
@ -328,17 +290,13 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/v1/pleroma", Pleroma.Web.PleromaAPI do
|
|
|
|
|
pipe_through([:api, :oauth_read_or_public])
|
|
|
|
|
|
|
|
|
|
pipe_through(:api)
|
|
|
|
|
get("/accounts/:id/scrobbles", ScrobbleController, :user_scrobbles)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/v1", Pleroma.Web.MastodonAPI do
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read)
|
|
|
|
|
|
|
|
|
|
get("/accounts/verify_credentials", AccountController, :verify_credentials)
|
|
|
|
|
|
|
|
|
|
get("/accounts/relationships", AccountController, :relationships)
|
|
|
|
@ -378,11 +336,7 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
get("/conversations", ConversationController, :index)
|
|
|
|
|
post("/conversations/:id/read", ConversationController, :read)
|
|
|
|
|
|
|
|
|
|
get("/endorsements", MastodonAPIController, :empty_array)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_write)
|
|
|
|
|
get("/endorsements", AccountController, :endorsements)
|
|
|
|
|
|
|
|
|
|
patch("/accounts/update_credentials", AccountController, :update_credentials)
|
|
|
|
|
|
|
|
|
@ -421,10 +375,6 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
delete("/filters/:id", FilterController, :delete)
|
|
|
|
|
|
|
|
|
|
post("/reports", ReportController, :create)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_follow)
|
|
|
|
|
|
|
|
|
|
post("/follows", AccountController, :follows)
|
|
|
|
|
post("/accounts/:id/follow", AccountController, :follow)
|
|
|
|
@ -439,20 +389,15 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
|
|
|
|
|
post("/domain_blocks", DomainBlockController, :create)
|
|
|
|
|
delete("/domain_blocks", DomainBlockController, :delete)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_push)
|
|
|
|
|
|
|
|
|
|
post("/push/subscription", SubscriptionController, :create)
|
|
|
|
|
get("/push/subscription", SubscriptionController, :get)
|
|
|
|
|
put("/push/subscription", SubscriptionController, :update)
|
|
|
|
|
delete("/push/subscription", SubscriptionController, :delete)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/web", Pleroma.Web do
|
|
|
|
|
pipe_through([:authenticated_api, :oauth_write])
|
|
|
|
|
pipe_through(:authenticated_api)
|
|
|
|
|
|
|
|
|
|
put("/settings", MastoFEController, :put_settings)
|
|
|
|
|
end
|
|
|
|
@ -477,9 +422,6 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
|
|
|
|
|
get("/trends", MastodonAPIController, :empty_array)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read_or_public)
|
|
|
|
|
|
|
|
|
|
get("/timelines/public", TimelineController, :public)
|
|
|
|
|
get("/timelines/tag/:tag", TimelineController, :hashtag)
|
|
|
|
|
get("/timelines/list/:list_id", TimelineController, :list)
|
|
|
|
@ -497,10 +439,9 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
|
|
|
|
|
get("/search", SearchController, :search)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/api/v2", Pleroma.Web.MastodonAPI do
|
|
|
|
|
pipe_through([:api, :oauth_read_or_public])
|
|
|
|
|
pipe_through(:api)
|
|
|
|
|
get("/search", SearchController, :search2)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
@ -531,12 +472,8 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
get("/oauth_tokens", TwitterAPI.Controller, :oauth_tokens)
|
|
|
|
|
delete("/oauth_tokens/:id", TwitterAPI.Controller, :revoke_token)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read)
|
|
|
|
|
|
|
|
|
|
post("/qvitter/statuses/notifications/read", TwitterAPI.Controller, :notifications_read)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :ap_service_actor do
|
|
|
|
|
plug(:accepts, ["activity+json", "json"])
|
|
|
|
@ -599,24 +536,15 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
scope "/", Pleroma.Web.ActivityPub do
|
|
|
|
|
pipe_through([:activitypub_client])
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read)
|
|
|
|
|
get("/api/ap/whoami", ActivityPubController, :whoami)
|
|
|
|
|
get("/users/:nickname/inbox", ActivityPubController, :read_inbox)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_write)
|
|
|
|
|
post("/users/:nickname/outbox", ActivityPubController, :update_outbox)
|
|
|
|
|
post("/api/ap/upload_media", ActivityPubController, :upload_media)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read_or_public)
|
|
|
|
|
get("/users/:nickname/followers", ActivityPubController, :followers)
|
|
|
|
|
get("/users/:nickname/following", ActivityPubController, :following)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
scope "/", Pleroma.Web.ActivityPub do
|
|
|
|
|
pipe_through(:activitypub)
|
|
|
|
@ -665,11 +593,8 @@ defmodule Pleroma.Web.Router do
|
|
|
|
|
|
|
|
|
|
post("/auth/password", MastodonAPI.AuthController, :password_reset)
|
|
|
|
|
|
|
|
|
|
scope [] do
|
|
|
|
|
pipe_through(:oauth_read)
|
|
|
|
|
get("/web/*path", MastoFEController, :index)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
pipeline :remote_media do
|
|
|
|
|
end
|
|
|
|
|