ffmpeg.wasm icon indicating copy to clipboard operation
ffmpeg.wasm copied to clipboard

ReferenceError: SharedArrayBuffer is not defined

Open avi12 opened this issue 4 years ago • 47 comments

Describe the bug Getting a ReferenceError: SharedArrayBuffer is not defined error after [info] ffmpeg-core.js script loaded

To Reproduce Simply initialize FFmpeg on Firefox

Expected behavior It should work as usual on Firefox, but it cannot properly initialize

Screenshots image

Desktop (please complete the following information):

  • OS: Windows 10 x64 21H1
  • Browser: Firefox 92.0.1

Additional context This is my repository

avi12 avatar Oct 02 '21 18:10 avi12

as the Readme states:

SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with Cross-Origin-Embedder-Policy: require-corp and Cross-Origin-Opener-Policy: same-origin headers to use ffmpeg.wasm.

SharedArrayBuffer is not available until you do add these headers

and in Safari it will never be available, because SharedArrayBuffer is disabled there

https://caniuse.com/sharedarraybuffer

RSWilli avatar Oct 06 '21 10:10 RSWilli

The reason I made my browser extension in the first place is that it doesn't need a server to work but instead use the user's computational power

avi12 avatar Oct 06 '21 11:10 avi12

as the Readme states:

SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with Cross-Origin-Embedder-Policy: require-corp and Cross-Origin-Opener-Policy: same-origin headers to use ffmpeg.wasm.

SharedArrayBuffer is not available until you do add these headers

and in Safari it will never be available, because SharedArrayBuffer is disabled there

https://caniuse.com/sharedarraybuffer

I add these headers when getting my html page and it works.But now I have trouble with add third party JS in my page,which will be blocked by cross-origin isolated. Any work around method to use third party JS in my video edit page(with wasm)?

MemoryAndDream avatar Oct 13 '21 08:10 MemoryAndDream

Dumb question from someone who knows nothing - what would it take / would it even be possible to rewrite this not to use SharedArrayBuffer?

Given the current state of how difficult it is to use, seems like if it's possible, it'd be worth it.

donatj avatar Oct 15 '21 21:10 donatj

Even if you manage to rewrite it in a different way, I doubt the progress of releases A couple of pull requests have been merged (including my #232), but the last release was on June 14

avi12 avatar Oct 15 '21 21:10 avi12

If there is someone using vite for development environment. https://github.com/chaosprint/vite-plugin-cross-origin-isolation

Fanna1119 avatar Nov 09 '21 06:11 Fanna1119

@Fanna1119 This doesn't solve the issue in a live environment

Zophiel avatar Dec 02 '21 13:12 Zophiel

Hello, in react easier way is using this library: https://create-react-app.dev/docs/proxying-api-requests-in-development/#configuring-the-proxy-manually

With this you can create a proxy, in the proxy you will be able to set the headers, example bellow:

module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });

    app.use(
        '/api',
        createProxyMiddleware({
          target: 'http://localhost:8080',
          changeOrigin: true,
        })
      );
};

I really don't know how to deal with this in SPAs production env, but for server-client applications it should work fine (for example react SSR).

martins-a avatar Jan 07 '22 00:01 martins-a

Safari now has support for SharedArrayBuffer as of March 2022 https://caniuse.com/sharedarraybuffer

zack-pronto avatar Apr 08 '22 19:04 zack-pronto

Hello, in react easier way is using this library: https://create-react-app.dev/docs/proxying-api-requests-in-development/#configuring-the-proxy-manually

With this you can create a proxy, in the proxy you will be able to set the headers, example bellow:

I had to tune your example for it to work with React. Beware that even when running a Typescript react project, you need to write this as a setupProxy.JS (and not .TS):

module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};

For SPAs, you don't need to create a proxy middleware, you just need to intercept the req/resp and add your headers.

Also, you don't need to install http-proxy-middleware at all for this to work. It just works straight out of the box on React apps.

Why we need those headers, according to the doc.

usr-ein avatar Jun 07 '22 08:06 usr-ein

For developing in vite, you can set the vite.config.js:

export default {
  server: {
    headers: {
      'Cross-Origin-Embedder-Policy': 'require-corp',
      'Cross-Origin-Opener-Policy': 'same-origin',
    },
  },
};

hankchiutw avatar Jun 11 '22 03:06 hankchiutw

Anyone who's using Next.js,

here's my next.config.js file and it works perfectly

// next.config.js

/** @type {import('next').NextConfig} */
const nextConfig = {
  reactStrictMode: true,
  async headers() {
    return [
      {
        source: '/',
        headers: [
          {
            key: 'Cross-Origin-Embedder-Policy',
            value: 'require-corp',
          },
          {
            key: 'Cross-Origin-Opener-Policy',
            value: 'same-origin',
          },
        ],
      },
    ];
  },
};

module.exports = nextConfig;

seiwonpark avatar Jun 30 '22 13:06 seiwonpark

I've created a setupProxy.js file for my React app, and have installed http-proxy-middleware suggested on the link, but the following code doesn't seem to work for me.

module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};

It doesn't seem like this module.exports is getting called when I run npm start I continue to get the error Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined.

I'm trying to follow along this React/ffmpeg WASM tutorial. I'm using Chrome 103, ffmpeg wasm 0.10.0, snowpack 2.1, react 17.0.2

filmo avatar Jul 18 '22 01:07 filmo

as the Readme states:

SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with Cross-Origin-Embedder-Policy: require-corp and Cross-Origin-Opener-Policy: same-origin headers to use ffmpeg.wasm.

SharedArrayBuffer is not available until you do add these headers

and in Safari it will never be available, because SharedArrayBuffer is disabled there

https://caniuse.com/sharedarraybuffer

It is now available though, no?

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer#browser_compatibility

khaled-shaaban avatar Jul 31 '22 12:07 khaled-shaaban

module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};

It is working on my side (React : 17.0.2, ffmpeg wasm: 0.10.3, chrome 103), but all the social logins (google, Microsoft, apple) does not work. All return the error saying pop up is closed by user.

Will be any solutions?

cleandevcode avatar Aug 02 '22 18:08 cleandevcode

anyone use UmiJS ?

kiradea avatar Jan 17 '23 07:01 kiradea

Permanant solution of Shared Array buffer is not define in react js when i am include fbsdk in my project

#484 #483 #190 #482 #402 #121 #469

donsaale5722 avatar Mar 20 '23 07:03 donsaale5722

for someone working with php, writing this code to the php file that contains the html document worked for me.

<?php
header("Cross-Origin-Embedder-Policy: require-corp");
header("Cross-Origin-Opener-Policy: same-origin");
?>

hlp-pls avatar Apr 20 '23 04:04 hlp-pls

Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue.

Whenever I load ffmpeg, I get the error, and establishing these headers did not help. f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (

AlRodriguezGar14 avatar May 12 '23 01:05 AlRodriguezGar14

For next js ,having following type of config worked for me.

`/** @type {import('next').NextConfig} */ const nextConfig = { reactStrictMode: true, async headers() { return [ { source: '/', headers: [ { key: 'Cross-Origin-Embedder-Policy', value: 'require-corp', }, { key: 'Cross-Origin-Opener-Policy', value: 'same-origin', }, ], }, ] }

webpack(config, { webpack }) { config.module.rules.push({ test: /.svg$/, use: ['@svgr/webpack'], })

config.plugins.push(
  new webpack.IgnorePlugin({
    resourceRegExp: /^\.\/wordlists\/(?!english)/,
    contextRegExp: /bip39\/src$/,
  })
)

config.resolve.alias = {
  ...config.resolve.alias,
  assets: getSharedPath('assets'),
  components: getSharedPath('components'),
  containers: getSharedPath('containers'),
  layouts: getSharedPath('layouts'),
  lib: getSharedPath('lib'),
  screens: getSharedPath('screens'),
  store: getSharedPath('store'),
  styles: getSharedPath('styles'),
}

return config

} env: {

}, }

module.exports = nextTranslate(withTM(withPWA(nextConfig)))`

SrLeet03 avatar Jul 01 '23 22:07 SrLeet03

All the sudden, like right now, the headers are not enough. There's an experimental Chrome flag but even that doesn't expose the SharedMemoryBuffer. It worked yesterday and even 10 minutes ago...

image

This WAS my workaround - https://vercel.com/guides/fix-shared-array-buffer-not-defined-nextjs-react

I have all the headers set via php. I confirmed the headers were set in the response.

header("Cross-Origin-Opener-Policy: same-origin"); header("Cross-Origin-Embedder-Policy: require-corp");

Broken in Edge/Chrome.

Firefox is still okay.

WebView2 browser is okay - https://learn.microsoft.com/en-us/microsoft-edge/webview2/samples/webview2browser?source=recommendations

I restarted my Chrome and the issue seems to have gone away. So I'm not sure what caused it. It's just odd that Chrome/Edge had the issue at the same time.

tgraupmann avatar Jul 12 '23 21:07 tgraupmann

I had the same issue just start recently on a Chrome 114 build using a different wasm project. Previously I had NOT enabled:

Cross-Origin-Opener-Policy

I only enabled

Cross-Origin-Embedder-Policy

and everything worked. Now the Opener policy seems to be required also.

nibk avatar Jul 13 '23 00:07 nibk

Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue.

Whenever I load ffmpeg, I get the error, and establishing these headers did not help. f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (

I am also using nuxt 3. DId you find a solution for this?

dataexcess avatar Jul 13 '23 08:07 dataexcess

Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue. Whenever I load ffmpeg, I get the error, and establishing these headers did not help. f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (

I am also using nuxt 3. DId you find a solution for this?

Sadly not @dataexcess. I had to move to React to make it work.

AlRodriguezGar14 avatar Jul 13 '23 08:07 AlRodriguezGar14

Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue. Whenever I load ffmpeg, I get the error, and establishing these headers did not help. f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (

I am also using nuxt 3. DId you find a solution for this?

Sadly not @dataexcess. I had to move to React to make it work.

Hey! Using this nuxt plugin "nuxt-security" fixed it for me ! :D

https://snyk.io/blog/adding-security-to-nuxt-3/

dataexcess avatar Jul 13 '23 08:07 dataexcess

I can still reproduce the issue. If you use a lot of memory by using a canvas element and capture a lot of frames with getImageData into memory, somehow the added memory knocks out the settings. And even if both headers are present you get the SharedMemoryBuffer error.

image

I thought the workaround was to kill all your browser instances and relaunch. But it still happens so I have to use one of the browsers that still works.

Hmmm Firefox is showing duplicate headers, that might be the problem.

image

I had a .htaccess adding the headers and php adding the headers. So if you have a duplicate header it is discarded and SharedMemoryBuffer goes away.

After I fixed the duplicate header issue, it's working normally.

tgraupmann avatar Jul 14 '23 17:07 tgraupmann

For anyone trying to find a solution when hosting on netlify for instance, you can use : https://github.com/gzuidhof/coi-serviceworker which makes it available.

gabrielstuff avatar Sep 01 '23 14:09 gabrielstuff

So, ive run into this issue too now. I added the stuff to my htaccess but its not working. When running the included example server on my local machine it works but when running it on my remote system under apache2, firefox keeps complaining. I have tried putting it in the .htaccess, in php and even tried writing it from javascript after the page loaded (which doesnt work btw but still tried it because i am really desperate to get this working). For htaccess and php it shows up in firefox when looking at the header but the browser seems to just ignore it and throws the error anyways. The same happens in chrome too. If anyone can help me out with that id be really thankful.

iAmInActions avatar Sep 08 '23 17:09 iAmInActions

I think this issue could be closed because there are multiple solutions presented. According to the third point in https://caniuse.com/?search=SharedArrayBuffer, this is the way to enable support. If this doesn't work for your browser, consider opening an issue in the browser's issue tracker.

Bessonov avatar Nov 17 '23 15:11 Bessonov

How to solve this issue using Github Pages?

jumpjack avatar Mar 04 '24 13:03 jumpjack