Skip to content
Snippets Groups Projects
This project is mirrored from https://akkoma.dev/AkkomaGang/akkoma.git. Pull mirroring updated .
  1. Mar 31, 2025
  2. Mar 20, 2025
  3. Mar 19, 2025
  4. Mar 18, 2025
  5. Mar 13, 2025
  6. Mar 12, 2025
  7. Mar 11, 2025
    • Oneric's avatar
      Fix Content-Type sanitisation for emoji and local uploads · 066d5b48
      Oneric authored
      
      This was accidentally broken in c8e0f784
      due to a one-letter mistake in the plug option name and an absence of
      tests. Therefore it was once again possible to serve e.g. Javascript or
      CSS payloads via uploads and emoji.
      However due to other protections it was still NOT possible for anyone to
      serve any payload with an ActivityPub Content-Type. With the CSP policy
      hardening from previous JS payload exloits predating the Content-Type
      sanitisation, there is currently no known way of abusing this weakened
      Content-Type sanitisation, but should be fixed regardless.
      
      This commit fixes the option name and adds tests to ensure
      such a regression doesn't occur again in the future.
      
      Reported-by: default avatarLain Soykaf <lain@lain.com>
      066d5b48
  8. Mar 02, 2025
  9. Mar 01, 2025
  10. Feb 27, 2025
  11. Feb 24, 2025
  12. Feb 23, 2025
  13. Feb 22, 2025
    • Oneric's avatar
      changelog: add entries for preceding commits · 7c23793e
      Oneric authored
      7c23793e
    • Oneric's avatar
      federation: strip internal fields from incoming updates and history · 8243fc0e
      Oneric authored
      When note editing support was added, it was omitted to strip internal
      fields from edited notes and their history.
      
      This was uncovered due to Mastodon inlining the like count as a "likes"
      collection conflicting with our internal "likes" list causing validation
      failures. In a spot check with likes/like_count it was not possible to
      inject those internal fields into the local db via Update, but this
      was not extensively tested for all fields and avenues.
      
      Similarly address normalisation did not normalise addressing in the
      object history, although this was never at risk of being exploitable.
      
      The revision history of the Pleroma MR adding edit support reveals
      recusrive stripping was intentionally avoided, since it will end up
      removing e.g. emoji from outgoing activities. This appears to still
      be true. However, all current internal fields ("pleroma_interal"
      appears to be unused) contain data already publicised otherwise anyway.
      In the interest of fixing a federation bug (and at worst potential data
      injection) quickly outgoing stripping is left non-recursive for now.
      
      Of course the ultimate fix here is to not mix remote and internal data
      into the same map in the first place, but unfortunately having a single
      map of all truth is a core assumption of *oma's AP doc processing.
      Changing this is a masive undertaking and not suitable for providing
      a short-term fix.
      8243fc0e
    • Oneric's avatar
    • Oneric's avatar
      http_signatures: tweak order of route aliases · d8e40173
      Oneric authored
      We expect most requests to be made for the actual canonical ID,
      so check this one first (starting without query headers matching the
      predominant albeit spec-breaking version).
      
      Also avoid unnecessary rerewrites of the digest header on each route
      alias by just setting it once before iterating through aliases.
      d8e40173
    • Oneric's avatar
      signature: refetch key upon verification failure · 9cc5fe9a
      Oneric authored
      This matches behaviour prioir to the SigningKey migration
      and the expected semantics of the http_signatures lib.
      Additionally add a min interval paramter, to avoid
      refetch floods on bugs causing incompatible signatures
      (like e.g. currently with Bridgy)
      9cc5fe9a
    • floatingghost's avatar
      Merge pull request 'Expose Port IO stats via Prometheus' (#869) from... · 35526385
      floatingghost authored
      Merge pull request 'Expose Port IO stats via Prometheus' (#869) from Oneric/akkoma:io-telemetry into develop
      
      Reviewed-on: https://akkoma.dev/AkkomaGang/akkoma/pulls/869
      35526385
Loading