Implement uploader behaviour

run formatter <#
This commit is contained in:
Thurloat 2018-08-28 09:57:41 -03:00
parent 0df558a6a5
commit 8d2d7a8859
5 changed files with 10 additions and 10 deletions

View file

@ -14,11 +14,9 @@
uploader: Pleroma.Uploaders.Local,
strip_exif: false
config :pleroma, Pleroma.Uploaders.Local,
uploads: "uploads"
config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads"
config :pleroma, Pleroma.Uploaders.S3,
s3_bucket: nil
config :pleroma, Pleroma.Uploaders.S3, s3_bucket: nil
config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png"]

View file

@ -1,17 +1,17 @@
defmodule Pleroma.Upload do
alias Ecto.UUID
def store(%Plug.Upload{} = file, should_dedupe) do
settings = Application.get_env(:pleroma, Pleroma.Upload)
storage_backend = Keyword.fetch!(settings, :storage_backend)
@storage_backend Application.get_env(:pleroma, Pleroma.Upload)
|> Keyword.fetch!(:uploader)
def store(%Plug.Upload{} = file, should_dedupe) do
content_type = get_content_type(file.path)
uuid = get_uuid(file, should_dedupe)
name = get_name(file, uuid, content_type, should_dedupe)
strip_exif_data(content_type, file.path)
url_path = storage_backend.put_file(name, uuid, content_type)
url_path = @storage_backend.put_file(name, uuid, file, content_type, should_dedupe)
%{
"type" => "Document",
@ -25,6 +25,7 @@ def store(%Plug.Upload{} = file, should_dedupe) do
"name" => name
}
end
"""
# XXX: does this code actually work? i am skeptical. --kaniini
def store(%{"img" => "data:image/" <> image_data}, should_dedupe) do

View file

@ -1,9 +1,9 @@
defmodule Pleroma.Uploaders.Local do
@behaviour Pleroma.Uploaders.Uploader
alias Pleroma.Web
def put_file(name, uuid, file, _content_type, should_dedupe) do
upload_folder = get_upload_path(uuid, should_dedupe)
url_path = get_url(name, uuid, should_dedupe)

View file

@ -1,7 +1,7 @@
defmodule Pleroma.Uploaders.S3 do
@behaviour Pleroma.Uploaders.Uploader
def put_file(name, uuid, path, content_type, _should_dedupe) do
settings = Application.get_env(:pleroma, Pleroma.Uploaders.S3)
bucket = Keyword.fetch!(settings, :bucket)
public_endpoint = Keyword.fetch!(settings, :public_endpoint)

View file

@ -0,0 +1 @@