Add syndication commands
This commit is contained in:
@@ -12,13 +12,15 @@ module Adamantium
|
|||||||
create_resolver: "commands.posts.creation_resolver",
|
create_resolver: "commands.posts.creation_resolver",
|
||||||
delete_post: "commands.posts.delete",
|
delete_post: "commands.posts.delete",
|
||||||
undelete_post: "commands.posts.undelete",
|
undelete_post: "commands.posts.undelete",
|
||||||
update_post: "commands.posts.update"
|
update_post: "commands.posts.update",
|
||||||
|
syndicate: "commands.posts.syndicate"
|
||||||
]
|
]
|
||||||
|
|
||||||
def handle(req, res)
|
def handle(req, res)
|
||||||
req_entity = post_param_parser.call(params: req.params.to_h)
|
req_entity = post_param_parser.call(params: req.params.to_h)
|
||||||
action = req.params[:action]
|
action = req.params[:action]
|
||||||
|
|
||||||
|
# delete, undelete, update
|
||||||
if action
|
if action
|
||||||
operation, permission_check = resolve_operation(action)
|
operation, permission_check = resolve_operation(action)
|
||||||
|
|
||||||
@@ -28,13 +30,16 @@ module Adamantium
|
|||||||
else
|
else
|
||||||
res.status = 401
|
res.status = 401
|
||||||
end
|
end
|
||||||
elsif req_entity
|
elsif req_entity # create
|
||||||
halt 401 unless verify_scope(req: req, scope: :create)
|
halt 401 unless verify_scope(req: req, scope: :create)
|
||||||
|
|
||||||
command, contract = create_resolver.call(entry_type: req_entity).values_at(:command, :validation)
|
command, contract = create_resolver.call(entry_type: req_entity).values_at(:command, :validation)
|
||||||
|
|
||||||
validation = contract.call(req_entity.to_h)
|
validation = contract.call(req_entity.to_h)
|
||||||
if validation.success?
|
if validation.success?
|
||||||
|
|
||||||
|
url = syndicate(validation.to_h) # TODO: set URL on post
|
||||||
|
|
||||||
post = command.call(validation.to_h)
|
post = command.call(validation.to_h)
|
||||||
|
|
||||||
res.status = 201
|
res.status = 201
|
||||||
|
15
app/commands/posts/syndicate.rb
Normal file
15
app/commands/posts/syndicate.rb
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
module Adamantium
|
||||||
|
module Commands
|
||||||
|
module Posts
|
||||||
|
class Syndicate
|
||||||
|
include Deps["settings", "syndication.mastodon"]
|
||||||
|
|
||||||
|
def call(post)
|
||||||
|
if post.syndicate_to.include settings.mastodon_server
|
||||||
|
mastodon.call(post: post)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
5
config/providers/syndication.rb
Normal file
5
config/providers/syndication.rb
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Hanami.app.register_provider :syndication, namespace: true do
|
||||||
|
start do
|
||||||
|
register "mastodon", Adamantium::Syndication::Mastodon.new
|
||||||
|
end
|
||||||
|
end
|
42
lib/adamantium/syndication/mastodon.rb
Normal file
42
lib/adamantium/syndication/mastodon.rb
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
require "digest"
|
||||||
|
require "dry/monads"
|
||||||
|
require "httparty"
|
||||||
|
|
||||||
|
module Adamantium
|
||||||
|
module Syndication
|
||||||
|
class Mastodon
|
||||||
|
include Dry::Monads[:result]
|
||||||
|
include Deps["settings"]
|
||||||
|
|
||||||
|
def call(post:)
|
||||||
|
return Failure(:no_mastodon_credentials) unless settings.mastodon_token && settings.mastodon_server
|
||||||
|
|
||||||
|
text = post.name
|
||||||
|
text_with_link = "#{text} — #{settings.micropub_site_url}"
|
||||||
|
tags = post.category.map { |tag| "##{tag}" }.join(" ")
|
||||||
|
text_with_tags = "#{text_with_link} #{tags}"
|
||||||
|
|
||||||
|
key = Digest::MD5.hexdigest text_with_tags
|
||||||
|
mastodon_token = settings.mastodon_token
|
||||||
|
mastodon_server = settings.mastodon_server.split("@").first
|
||||||
|
|
||||||
|
response = HTTParty.post(mastodon_server, {
|
||||||
|
headers: {
|
||||||
|
"Idempotency-Key": key,
|
||||||
|
Authorization: "Bearer #{mastodon_token}"
|
||||||
|
},
|
||||||
|
body: {
|
||||||
|
status: text_with_tags
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
if response.code > 200
|
||||||
|
status = response.message
|
||||||
|
Success("#{mastodon_server}/#{status[:id]}")
|
||||||
|
else
|
||||||
|
Failure(response.message)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Reference in New Issue
Block a user