60 lines
No EOL
2.1 KiB
JavaScript
60 lines
No EOL
2.1 KiB
JavaScript
const rootDomain = process.env.VITE_DOMAIN; // or your server IP for dev
|
|
|
|
const cspDirectives = {
|
|
'base-uri': ["'self'"],
|
|
'child-src': ["'self'"],
|
|
'connect-src': ["'self'", "https://*.google-analytics.com"],
|
|
// 'connect-src': ["'self'", 'ws://localhost:*', 'https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
|
'img-src': ["'self'", 'data:',
|
|
'https://*.googletagmanager.com'],
|
|
'font-src': ["'self'", 'data:'],
|
|
'form-action': ["'self'"],
|
|
'frame-ancestors': ["'self'"],
|
|
'frame-src': [
|
|
"'self'",
|
|
// "https://*.stripe.com",
|
|
// "https://*.facebook.com",
|
|
// "https://*.facebook.net",
|
|
// 'https://hcaptcha.com',
|
|
// 'https://*.hcaptcha.com',
|
|
],
|
|
'manifest-src': ["'self'"],
|
|
'media-src': ["'self'", 'data:'],
|
|
'object-src': ["'none'"],
|
|
'style-src': ["'self'", "'unsafe-inline'"],
|
|
// 'style-src': ["'self'", "'unsafe-inline'", 'https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
|
'default-src': [
|
|
'self',
|
|
...(rootDomain ? [rootDomain, `ws://${rootDomain}`] : []),
|
|
// 'https://*.google.com',
|
|
// 'https://*.googleapis.com',
|
|
// 'https://*.firebase.com',
|
|
// 'https://*.gstatic.com',
|
|
// 'https://*.cloudfunctions.net',
|
|
// 'https://*.algolia.net',
|
|
// 'https://*.facebook.com',
|
|
// 'https://*.facebook.net',
|
|
// 'https://*.stripe.com',
|
|
// 'https://*.sentry.io',
|
|
],
|
|
'script-src': [
|
|
'self',
|
|
'unsafe-inline', // chrome suggestion
|
|
'https://*.googletagmanager.com'
|
|
// 'https://*.stripe.com',
|
|
// 'https://*.facebook.com',
|
|
// 'https://*.facebook.net',
|
|
// 'https://hcaptcha.com',
|
|
// 'https://*.hcaptcha.com',
|
|
// 'https://*.sentry.io',
|
|
// 'https://polyfill.io',
|
|
],
|
|
'worker-src': ["'self'"],
|
|
// remove report-to & report-uri if you do not want to use Sentry reporting
|
|
// 'report-to': ["'csp-endpoint'"],
|
|
// 'report-uri': [
|
|
// `https://sentry.io/api/${process.env.VITE_SENTRY_PROJECT_ID}/security/?sentry_key=${process.env.VITE_SENTRY_KEY}`,
|
|
// ],
|
|
};
|
|
|
|
export default cspDirectives; |