Skip to content

My payment providers is getting 403 Forbidden: Cross-site POST form submissions are forbidden. trustedOrigins not helping. #14889

@samal-rasmussen

Description

@samal-rasmussen

Describe the bug

My payment providers is getting 403 Forbidden: Cross-site POST form submissions are forbidden when making their success callback to my site after a payment.

trustedOrigins not helping as my payment provider doesn't set headers.origin, which is the only thing trustedOrigins checks as far as I can see. The payment provider sets their hostname in referrer instead.

So a fix would be to add a check for headers.referrer here too:

const request_origin = request.headers.get('origin');

Reproduction

Derp. Is this even feasible to do?

Logs

System Info

System:
    OS: macOS 15.6.1
    CPU: (8) arm64 Apple M1 Pro
    Memory: 114.30 MB / 16.00 GB
    Shell: 5.9 - /bin/zsh
  Binaries:
    Node: 22.18.0 - /Users/samalrasmussen/.nvm/versions/node/v22.18.0/bin/node
    Yarn: 1.22.22 - /opt/homebrew/bin/yarn
    npm: 11.6.0 - /Users/samalrasmussen/.nvm/versions/node/v22.18.0/bin/npm
    pnpm: 10.14.0 - /Users/samalrasmussen/Library/pnpm/pnpm
    Deno: 1.35.2 - /Users/samalrasmussen/.deno/bin/deno
    Watchman: 2025.06.30.00 - /opt/homebrew/bin/watchman
  Browsers:
    Brave Browser: 140.1.82.173
    Chrome: 141.0.7390.55
    Firefox: 144.0.2
    Safari: 18.6
  npmPackages:
    @sveltejs/adapter-node: 5.3.3 => 5.3.3 
    @sveltejs/kit: 2.43.7 => 2.43.7 
    @sveltejs/vite-plugin-svelte: 6.2.1 => 6.2.1 
    svelte: 5.39.8 => 5.39.8 
    vite: 7.1.8 => 7.1.8

Severity

blocking an upgrade

Additional Information

No response

Metadata

Metadata

Assignees

No one assigned

    Labels

    feature / enhancementNew feature or requestneeds-decisionNot sure if we want to do this yet, also design work needed

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions