X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Fweb%2Fendpoint.ex;h=564fc2c1d446a314668d1de3c0f8447f8ca4e2d4;hb=61a88a6757bc557a370888d288f93681cff9668b;hp=b57cf3917e166ba7e00d0545d9596ff2637a631b;hpb=5fc6e9d467f69af155627cccaa27616fe7ffc61f;p=akkoma diff --git a/lib/pleroma/web/endpoint.ex b/lib/pleroma/web/endpoint.ex index b57cf3917..564fc2c1d 100644 --- a/lib/pleroma/web/endpoint.ex +++ b/lib/pleroma/web/endpoint.ex @@ -1,46 +1,71 @@ defmodule Pleroma.Web.Endpoint do use Phoenix.Endpoint, otp_app: :pleroma - socket "/socket", Pleroma.Web.UserSocket - socket "/api/v1", Pleroma.Web.MastodonAPI.MastodonSocket + socket("/socket", Pleroma.Web.UserSocket) # Serve at "/" the static files from "priv/static" directory. # # You should set gzip to true if you are running phoenix.digest # when deploying your static files in production. - plug Plug.Static, - at: "/media", from: "uploads", gzip: false - plug Plug.Static, - at: "/", from: :pleroma, - only: ~w(index.html static finmoji emoji packs sounds sw.js) + plug(CORSPlug) + plug(Pleroma.Plugs.HTTPSecurityPlug) + + plug(Pleroma.Plugs.UploadedMedia) + + # InstanceStatic needs to be before Plug.Static to be able to override shipped-static files + # If you're adding new paths to `only:` you'll need to configure them in InstanceStatic as well + plug(Pleroma.Plugs.InstanceStatic, at: "/") + + plug( + Plug.Static, + at: "/", + from: :pleroma, + only: + ~w(index.html static finmoji emoji packs sounds images instance sw.js favicon.png schemas doc) + ) # Code reloading can be explicitly enabled under the # :code_reloader configuration of your endpoint. if code_reloading? do - plug Phoenix.CodeReloader + plug(Phoenix.CodeReloader) end - plug TrailingFormatPlug - plug Plug.RequestId - plug Plug.Logger + plug(TrailingFormatPlug) + plug(Plug.RequestId) + plug(Plug.Logger) - plug Plug.Parsers, + plug( + Plug.Parsers, parsers: [:urlencoded, :multipart, :json], pass: ["*/*"], - json_decoder: Poison + json_decoder: Jason, + length: Application.get_env(:pleroma, :instance) |> Keyword.get(:upload_limit), + body_reader: {Pleroma.Web.Plugs.DigestPlug, :read_body, []} + ) + + plug(Plug.MethodOverride) + plug(Plug.Head) - plug Plug.MethodOverride - plug Plug.Head + cookie_name = + if Application.get_env(:pleroma, Pleroma.Web.Endpoint) |> Keyword.get(:secure_cookie_flag), + do: "__Host-pleroma_key", + else: "pleroma_key" # The session will be stored in the cookie and signed, # this means its contents can be read but not tampered with. # Set :encryption_salt if you would also like to encrypt it. - plug Plug.Session, + plug( + Plug.Session, store: :cookie, - key: "_pleroma_key", - signing_salt: "CqaoopA2" + key: cookie_name, + signing_salt: {Pleroma.Config, :get, [[__MODULE__, :signing_salt], "CqaoopA2"]}, + http_only: true, + secure: + Application.get_env(:pleroma, Pleroma.Web.Endpoint) |> Keyword.get(:secure_cookie_flag), + extra: "SameSite=Strict" + ) - plug Pleroma.Web.Router + plug(Pleroma.Web.Router) @doc """ Dynamically loads configuration from the system environment