Change structure
This commit is contained in:
parent
01c2c57933
commit
ddfb58c041
16 changed files with 153 additions and 66 deletions
21
lib/nulla_web/controllers/activitypub/actor_controller.ex
Normal file
21
lib/nulla_web/controllers/activitypub/actor_controller.ex
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
defmodule NullaWeb.ActivityPub.ActorController do
|
||||||
|
use NullaWeb, :controller
|
||||||
|
alias Nulla.ActivityPub
|
||||||
|
alias Nulla.Models.Actor
|
||||||
|
|
||||||
|
def show(conn, %{"username" => username}) do
|
||||||
|
domain = NullaWeb.Endpoint.host()
|
||||||
|
|
||||||
|
case Actor.get_actor(preferredUsername: username, domain: domain) do
|
||||||
|
nil ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|
||||||
|
%Actor{} = actor ->
|
||||||
|
conn
|
||||||
|
|> put_resp_content_type("application/activity+json")
|
||||||
|
|> send_resp(200, Jason.encode!(ActivityPub.actor(actor)))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.FollowController do
|
defmodule NullaWeb.ActivityPub.FollowController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.ActivityPub
|
alias Nulla.ActivityPub
|
||||||
alias Nulla.Models.Actor
|
alias Nulla.Models.Actor
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.HostmetaController do
|
defmodule NullaWeb.ActivityPub.HostmetaController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
|
|
||||||
def index(conn, _params) do
|
def index(conn, _params) do
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.InboxController do
|
defmodule NullaWeb.ActivityPub.InboxController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.Snowflake
|
alias Nulla.Snowflake
|
||||||
alias Nulla.HTTPSignature
|
alias Nulla.HTTPSignature
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.NodeinfoController do
|
defmodule NullaWeb.ActivityPub.NodeinfoController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.ActivityPub
|
alias Nulla.ActivityPub
|
||||||
alias Nulla.Models.User
|
alias Nulla.Models.User
|
44
lib/nulla_web/controllers/activitypub/note_controller.ex
Normal file
44
lib/nulla_web/controllers/activitypub/note_controller.ex
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
defmodule NullaWeb.ActivityPub.NoteController do
|
||||||
|
use NullaWeb, :controller
|
||||||
|
alias Nulla.Repo
|
||||||
|
alias Nulla.ActivityPub
|
||||||
|
alias Nulla.Models.Note
|
||||||
|
|
||||||
|
def show(conn, %{"username" => username, "id" => id}) do
|
||||||
|
case Integer.parse(id) do
|
||||||
|
{int_id, ""} ->
|
||||||
|
note = Note.get_note(id: int_id) |> Repo.preload([:actor, :media_attachments])
|
||||||
|
|
||||||
|
cond do
|
||||||
|
is_nil(note) ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|> halt()
|
||||||
|
|
||||||
|
username != note.actor.preferredUsername ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|> halt()
|
||||||
|
|
||||||
|
true ->
|
||||||
|
format = Phoenix.Controller.get_format(conn)
|
||||||
|
|
||||||
|
if format == "activity+json" do
|
||||||
|
conn
|
||||||
|
|> put_resp_content_type("application/activity+json")
|
||||||
|
|> json(ActivityPub.note(note))
|
||||||
|
else
|
||||||
|
render(conn, :show, note: note, layout: false)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
_ ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|> halt()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.OutboxController do
|
defmodule NullaWeb.ActivityPub.OutboxController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.ActivityPub
|
alias Nulla.ActivityPub
|
||||||
alias Nulla.Models.Actor
|
alias Nulla.Models.Actor
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.WebfingerController do
|
defmodule NullaWeb.ActivityPub.WebfingerController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.ActivityPub
|
alias Nulla.ActivityPub
|
||||||
alias Nulla.Models.Actor
|
alias Nulla.Models.Actor
|
|
@ -1,40 +0,0 @@
|
||||||
defmodule NullaWeb.ActorController do
|
|
||||||
use NullaWeb, :controller
|
|
||||||
alias Nulla.ActivityPub
|
|
||||||
alias Nulla.Models.Actor
|
|
||||||
alias Nulla.Models.Relation
|
|
||||||
alias Nulla.Models.Note
|
|
||||||
|
|
||||||
def show(conn, %{"username" => username}) do
|
|
||||||
format = Phoenix.Controller.get_format(conn)
|
|
||||||
domain = NullaWeb.Endpoint.host()
|
|
||||||
|
|
||||||
case Actor.get_actor(preferredUsername: username, domain: domain) do
|
|
||||||
nil ->
|
|
||||||
conn
|
|
||||||
|> put_status(:not_found)
|
|
||||||
|> json(%{error: "Not Found"})
|
|
||||||
|
|
||||||
%Actor{} = actor ->
|
|
||||||
if format == "activity+json" do
|
|
||||||
conn
|
|
||||||
|> put_resp_content_type("application/activity+json")
|
|
||||||
|> send_resp(200, Jason.encode!(ActivityPub.actor(actor)))
|
|
||||||
else
|
|
||||||
following = Relation.count_following(actor.id)
|
|
||||||
followers = Relation.count_followers(actor.id)
|
|
||||||
notes = Note.get_latest_notes(actor.id)
|
|
||||||
|
|
||||||
render(
|
|
||||||
conn,
|
|
||||||
:show,
|
|
||||||
actor: actor,
|
|
||||||
following: following,
|
|
||||||
followers: followers,
|
|
||||||
notes: notes,
|
|
||||||
layout: false
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
33
lib/nulla_web/controllers/api/note_controller.ex
Normal file
33
lib/nulla_web/controllers/api/note_controller.ex
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
defmodule NullaWeb.Api.NoteController do
|
||||||
|
use NullaWeb, :controller
|
||||||
|
alias Nulla.Models.Note
|
||||||
|
|
||||||
|
def index(conn, _params) do
|
||||||
|
json(conn, [])
|
||||||
|
end
|
||||||
|
|
||||||
|
def show(conn, %{"id" => id}) do
|
||||||
|
note = Note.get_note(id: id)
|
||||||
|
|
||||||
|
case note do
|
||||||
|
nil ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|
||||||
|
%Note{} = note ->
|
||||||
|
IO.inspect note
|
||||||
|
|
||||||
|
json(conn, %{})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def create(_conn, _params) do
|
||||||
|
end
|
||||||
|
|
||||||
|
def update(_conn, _params) do
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete(_conn, _params) do
|
||||||
|
end
|
||||||
|
end
|
32
lib/nulla_web/controllers/web/actor_controller.ex
Normal file
32
lib/nulla_web/controllers/web/actor_controller.ex
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
defmodule NullaWeb.Web.ActorController do
|
||||||
|
use NullaWeb, :controller
|
||||||
|
alias Nulla.Models.Actor
|
||||||
|
alias Nulla.Models.Relation
|
||||||
|
alias Nulla.Models.Note
|
||||||
|
|
||||||
|
def show(conn, %{"username" => username}) do
|
||||||
|
domain = NullaWeb.Endpoint.host()
|
||||||
|
|
||||||
|
case Actor.get_actor(preferredUsername: username, domain: domain) do
|
||||||
|
nil ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|
||||||
|
%Actor{} = actor ->
|
||||||
|
following = Relation.count_following(actor.id)
|
||||||
|
followers = Relation.count_followers(actor.id)
|
||||||
|
notes = Note.get_latest_notes(actor.id)
|
||||||
|
|
||||||
|
render(
|
||||||
|
conn,
|
||||||
|
:show,
|
||||||
|
actor: actor,
|
||||||
|
following: following,
|
||||||
|
followers: followers,
|
||||||
|
notes: notes,
|
||||||
|
layout: false
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.AuthController do
|
defmodule NullaWeb.Web.AuthController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.Models.User
|
alias Nulla.Models.User
|
||||||
alias Nulla.Models.Actor
|
alias Nulla.Models.Actor
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.NoteController do
|
defmodule NullaWeb.Web.NoteController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
alias Nulla.Repo
|
alias Nulla.Repo
|
||||||
alias Nulla.ActivityPub
|
alias Nulla.ActivityPub
|
|
@ -1,4 +1,4 @@
|
||||||
defmodule NullaWeb.PageController do
|
defmodule NullaWeb.Web.PageController do
|
||||||
use NullaWeb, :controller
|
use NullaWeb, :controller
|
||||||
|
|
||||||
def home(conn, _params) do
|
def home(conn, _params) do
|
|
@ -6,8 +6,8 @@ defmodule NullaWeb.Router do
|
||||||
plug :fetch_session
|
plug :fetch_session
|
||||||
plug :fetch_live_flash
|
plug :fetch_live_flash
|
||||||
plug :put_root_layout, html: {NullaWeb.Layouts, :root}
|
plug :put_root_layout, html: {NullaWeb.Layouts, :root}
|
||||||
# plug :protect_from_forgery
|
plug :protect_from_forgery
|
||||||
# plug :put_secure_browser_headers
|
plug :put_secure_browser_headers
|
||||||
end
|
end
|
||||||
|
|
||||||
pipeline :api do
|
pipeline :api do
|
||||||
|
@ -18,16 +18,11 @@ defmodule NullaWeb.Router do
|
||||||
plug :accepts, ["activity+json"]
|
plug :accepts, ["activity+json"]
|
||||||
end
|
end
|
||||||
|
|
||||||
scope "/", NullaWeb do
|
scope "/", NullaWeb.Web, as: :web do
|
||||||
pipe_through :browser
|
pipe_through :browser
|
||||||
|
|
||||||
get "/", PageController, :home
|
get "/", PageController, :home
|
||||||
|
|
||||||
get "/.well-known/host-meta", HostmetaController, :index
|
|
||||||
get "/.well-known/webfinger", WebfingerController, :index
|
|
||||||
get "/.well-known/nodeinfo", NodeinfoController, :index
|
|
||||||
get "/nodeinfo/2.0", NodeinfoController, :show
|
|
||||||
|
|
||||||
scope "/auth" do
|
scope "/auth" do
|
||||||
post "/", AuthController, :sign_up
|
post "/", AuthController, :sign_up
|
||||||
post "/sign_in", AuthController, :sign_in
|
post "/sign_in", AuthController, :sign_in
|
||||||
|
@ -38,21 +33,24 @@ defmodule NullaWeb.Router do
|
||||||
|
|
||||||
scope "/@:username" do
|
scope "/@:username" do
|
||||||
get "/", ActorController, :show
|
get "/", ActorController, :show
|
||||||
get "/following", FollowController, :following
|
|
||||||
get "/followers", FollowController, :followers
|
|
||||||
post "/inbox", InboxController, :inbox
|
|
||||||
get "/outbox", OutboxController, :outbox
|
|
||||||
get "/:id", NoteController, :show
|
get "/:id", NoteController, :show
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
scope "/api", NullaWeb do
|
scope "/api", NullaWeb.Api, as: :api do
|
||||||
pipe_through :api
|
pipe_through :api
|
||||||
|
|
||||||
|
resources "/notes", NoteController
|
||||||
end
|
end
|
||||||
|
|
||||||
scope "/", NullaWeb do
|
scope "/", NullaWeb.ActivityPub, as: :activitypub do
|
||||||
pipe_through :activitypub
|
pipe_through :activitypub
|
||||||
|
|
||||||
|
get "/.well-known/host-meta", HostmetaController, :index
|
||||||
|
get "/.well-known/webfinger", WebfingerController, :index
|
||||||
|
get "/.well-known/nodeinfo", NodeinfoController, :index
|
||||||
|
get "/nodeinfo/2.0", NodeinfoController, :show
|
||||||
|
|
||||||
post "/inbox", InboxController, :inbox
|
post "/inbox", InboxController, :inbox
|
||||||
|
|
||||||
scope "/users/:username" do
|
scope "/users/:username" do
|
||||||
|
|
|
@ -45,11 +45,10 @@ defmodule Nulla.Fixtures.Data do
|
||||||
})
|
})
|
||||||
|
|
||||||
Note.create_note(%{
|
Note.create_note(%{
|
||||||
actor_url: actor.url,
|
visibility: "public",
|
||||||
content: "Hello World from Nulla!",
|
content: "Hello World from Nulla!",
|
||||||
language: "en",
|
language: "en",
|
||||||
actor_id: actor.id,
|
actor_id: actor.id
|
||||||
visibility: "public"
|
|
||||||
})
|
})
|
||||||
|
|
||||||
{publicKeyPem, privateKeyPem} = KeyGen.gen()
|
{publicKeyPem, privateKeyPem} = KeyGen.gen()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue