diff options
author | kaniini <nenolod@gmail.com> | 2018-08-30 23:05:01 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2018-08-30 23:05:01 +0000 |
commit | 65e8d47cfb74e76bf966a0340fd5ced184c74fec (patch) | |
tree | 4535e1e1fbc7c52573a29e053ec4a025eb511095 /lib/pleroma/uploaders/swift/swift.ex | |
parent | 1a70d41f8e7ce0eb30242d58077b69816e443c10 (diff) | |
parent | adffad55028a8c43a6f2fcf43376009a43c25cf7 (diff) | |
download | pleroma-65e8d47cfb74e76bf966a0340fd5ced184c74fec.tar.gz |
Merge branch 'backendhack' into 'develop'
Flexible Storage Backends
See merge request pleroma/pleroma!304
Diffstat (limited to 'lib/pleroma/uploaders/swift/swift.ex')
-rw-r--r-- | lib/pleroma/uploaders/swift/swift.ex | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/pleroma/uploaders/swift/swift.ex b/lib/pleroma/uploaders/swift/swift.ex new file mode 100644 index 000000000..819dfebda --- /dev/null +++ b/lib/pleroma/uploaders/swift/swift.ex @@ -0,0 +1,28 @@ +defmodule Pleroma.Uploaders.Swift.Client do + use HTTPoison.Base + + @settings Application.get_env(:pleroma, Pleroma.Uploaders.Swift) + + def process_url(url) do + Enum.join( + [Keyword.fetch!(@settings, :storage_url), url], + "/" + ) + end + + def upload_file(filename, body, content_type) do + object_url = Keyword.fetch!(@settings, :object_url) + token = Pleroma.Uploaders.Swift.Keystone.get_token() + + case put("#{filename}", body, "X-Auth-Token": token, "Content-Type": content_type) do + {:ok, %HTTPoison.Response{status_code: 201}} -> + {:ok, "#{object_url}/#{filename}"} + + {:ok, %HTTPoison.Response{status_code: 401}} -> + {:error, "Unauthorized, Bad Token"} + + {:error, _} -> + {:error, "Swift Upload Error"} + end + end +end |