]> cat aescling's git repositories - mastodon.git/commit
HTTP signatures (#4146)
authorEugen Rochko <eugen@zeonfederated.com>
Fri, 14 Jul 2017 18:41:49 +0000 (20:41 +0200)
committerGitHub <noreply@github.com>
Fri, 14 Jul 2017 18:41:49 +0000 (20:41 +0200)
commit1618b68bfa740ed655ac45d7d5f4f46fed6c8c62
tree1a82bc4cbbbab2a1ff3ce6743c64af4d8694cc38
parentc1f201c49a007e5c0740c00651e549a7b0416b05
HTTP signatures (#4146)

* Add Request class with HTTP signature generator

Spec: https://tools.ietf.org/html/draft-cavage-http-signatures-06

* Add HTTP signature verification concern

* Add test for SignatureVerification concern

* Add basic test for Request class

* Make PuSH subscribe/unsubscribe requests use new Request class

Accidentally fix lease_seconds not being set and sent properly, and
change the new minimum subscription duration to 1 day

* Make all PuSH workers use new Request class

* Make Salmon sender use new Request class

* Make FetchLinkService use new Request class

* Make FetchAtomService use the new Request class

* Make Remotable use the new Request class

* Make ResolveRemoteAccountService use the new Request class

* Add more tests

* Allow +-30 seconds window for signed request to remain valid

* Disable time window validation for signed requests, restore 7 days
as PuSH subscription duration (which was previous default due to a bug)
23 files changed:
app/controllers/accounts_controller.rb
app/controllers/api/subscriptions_controller.rb
app/controllers/concerns/signature_verification.rb [new file with mode: 0644]
app/controllers/stream_entries_controller.rb
app/helpers/http_helper.rb [deleted file]
app/lib/provider_discovery.rb
app/lib/request.rb [new file with mode: 0644]
app/models/account.rb
app/models/concerns/remotable.rb
app/models/subscription.rb
app/services/fetch_atom_service.rb
app/services/fetch_link_card_service.rb
app/services/resolve_remote_account_service.rb
app/services/send_interaction_service.rb
app/services/subscribe_service.rb
app/services/unsubscribe_service.rb
app/workers/pubsubhubbub/confirmation_worker.rb
app/workers/pubsubhubbub/delivery_worker.rb
spec/controllers/concerns/signature_verification_spec.rb [new file with mode: 0644]
spec/helpers/http_helper_spec.rb [deleted file]
spec/lib/request_spec.rb [new file with mode: 0644]
spec/workers/pubsubhubbub/confirmation_worker_spec.rb
spec/workers/pubsubhubbub/delivery_worker_spec.rb