summaryrefslogtreecommitdiff
path: root/helpers.rb
blob: dca18e7c07808971d87f327f10162864d81fd1c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
helpers do

  def curl ext, url
    response = `/run/current-system/sw/bin/curl -ifsSL #{ext} #{url}`
    $?.success? ? response : nil
  end

  def fetch url, accept = 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"'
    response = curl("-H 'Accept: #{accept}'", url)
    response ? JSON.parse(response) : nil
  end

  # https://github.com/mastodon/mastodon/blob/main/app/lib/request.rb
  def send_signed object, url

    keypair = OpenSSL::PKey::RSA.new(File.read('private.pem'))
    date = Time.now.utc.httpdate
    body = object.to_json
    sha256 = OpenSSL::Digest::SHA256.new
    digest = "SHA-256=" + sha256.base64digest(body)
    host = URI.parse(url).host
    inbox = fetch(url)["inbox"]
    return false unless inbox
    request_uri = URI(inbox).request_uri

    signed_string = "(request-target): post #{request_uri}\nhost: #{host}\ndate: #{date}\ndigest: #{digest}\ncontent-type: application/activity+json"
    signature = Base64.strict_encode64(keypair.sign(OpenSSL::Digest.new('SHA256'), signed_string))
    signed_header = 'keyId="' + ACTOR + '#main-key",algorithm="rsa-sha256",headers="(request-target) host date digest content-type",signature="' + signature + '"'

    curl "-X POST -H 'Content-Type: application/activity+json' -H 'Host: #{host}' -H 'Date: #{date}' -H 'Digest: #{digest}' -H 'Signature: #{signed_header}' -d '#{body}'", inbox
    $?.success?

  end

end