Merge branch 'feature/uploader-mdii' into 'develop'
Feature / MDII Uploader See merge request pleroma/pleroma!454
This commit is contained in:
commit
05967472f2
@ -23,6 +23,10 @@
|
|||||||
public_endpoint: "https://s3.amazonaws.com",
|
public_endpoint: "https://s3.amazonaws.com",
|
||||||
force_media_proxy: false
|
force_media_proxy: false
|
||||||
|
|
||||||
|
config :pleroma, Pleroma.Uploaders.MDII,
|
||||||
|
cgi: "https://mdii.sakura.ne.jp/mdii-post.cgi",
|
||||||
|
files: "https://mdii.sakura.ne.jp"
|
||||||
|
|
||||||
config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png"]
|
config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png"]
|
||||||
|
|
||||||
config :pleroma, :uri_schemes,
|
config :pleroma, :uri_schemes,
|
||||||
|
26
lib/pleroma/uploaders/mdii.ex
Normal file
26
lib/pleroma/uploaders/mdii.ex
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
defmodule Pleroma.Uploaders.MDII do
|
||||||
|
alias Pleroma.Config
|
||||||
|
|
||||||
|
@behaviour Pleroma.Uploaders.Uploader
|
||||||
|
|
||||||
|
@httpoison Application.get_env(:pleroma, :httpoison)
|
||||||
|
|
||||||
|
def put_file(name, uuid, path, content_type, should_dedupe) do
|
||||||
|
cgi = Pleroma.Config.get([Pleroma.Uploaders.MDII, :cgi])
|
||||||
|
files = Pleroma.Config.get([Pleroma.Uploaders.MDII, :files])
|
||||||
|
|
||||||
|
{:ok, file_data} = File.read(path)
|
||||||
|
|
||||||
|
extension = String.split(name, ".") |> List.last()
|
||||||
|
query = "#{cgi}?#{extension}"
|
||||||
|
|
||||||
|
with {:ok, %{status_code: 200, body: body}} <- @httpoison.post(query, file_data) do
|
||||||
|
File.rm!(path)
|
||||||
|
remote_file_name = String.split(body) |> List.first()
|
||||||
|
public_url = "#{files}/#{remote_file_name}.#{extension}"
|
||||||
|
{:ok, public_url}
|
||||||
|
else
|
||||||
|
_ -> Pleroma.Uploaders.Local.put_file(name, uuid, path, content_type, should_dedupe)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user