mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-04-16 21:08:59 -04:00
- Merge Config and Core File Changes 4.6.3 > 4.6.4 - Merge Config and Core File Changes 4.6.4 > 4.7.0 - Added app\Config\WorkerMode.php - Merge Config and Core File Changes Not previously merged - Added app\Config\Hostnames.php - Corrected incorrect CSS property used in invoice.php view. - Corrected unknown CSS properties used in register.php view. - Used shorthand CSS in debug.css - Corrected indentation in barcode_sheet.php view. - Corrected indentation in footer.php view. - Corrected indentation in invoice_email.php view. - Replaced obsolete attributes with CSS style attributes in barcode_sheet.php - Replaced obsolete attribute in error_exception.php - Replaced obsolete attribute in invoice_email.php - Replaced obsolete attribute in quote_email.php - Replaced obsolete attributes in work_order_email.php - Fixed indentation in system_info.php - Replaced <strong> tag outside <p> tags, which isn't allowed, with style attributes. - Simplified js return logic and indentation fixes in tax_categories.php - Simplified js return logic in tax_codes.php - Simplified js return logic in tax_jurisdictions.php - Removed unnecessary labels in manage views. - Rewrite JavaScript function and PHP to be more readable in bar.php, hbar.php, line.php and pie.php - Added type declarations, return types and an import to app\Config\Services - Updated Attribute.php parameter type - Updated Receiving_lib.php parameter type - Updated Receivings.php parameter types and updated PHPdocs - Updated tabular_helper.php parameter types and updated PHPdocs - Added type declarations and corrected PHPdocs in url_helper.php - Added return types to functions - Revert $objectSrc value in ContentSecurityPolicy.php - Correct return type in Customer->get_stats() - Correct return type in Item->get_info_by_id_or_number() - Correct misspelling in border-spacing - Added missing css style semicolons - Resolve operator precedence ambiguity. - Resolve column mismatch. - Added missing escaping in view. - Updated requirement for PHP 8.2 - Resolve unresolved conflicts - Added PHP 8.2 requirement to the README.md - Fixed bugs in display of UI - Fixed duplicated `>` in app\Views\Expenses\manage.php - Removed excess whitespace at the end of some lines in table_filter_persistence.php - Added missing `>` in app\Views\Expenses\manage.php - Corrected grammar in PHPdoc in table_filter_persistence.php - Remove bug causing `\` to be injected into the new giftcard value - Fix bug causing DROPDOWN Attribute Values to not save correctly - Added check for null in $normalizedItemId - Removing < PHP 8.2 from linting and tests - Update Linter to not include PHP 8.2 and 8.1 - Remove PHP 8.1 unit test cycle. - Update Bug Report Template - Update Composer files for CodeIgniter 4.7.2 - Updated INSTALL.md to reflect changes. --------- Signed-off-by: objec <objecttothis@gmail.com>
241 lines
5.6 KiB
PHP
241 lines
5.6 KiB
PHP
<?php
|
|
|
|
namespace Config;
|
|
|
|
use CodeIgniter\Config\BaseConfig;
|
|
|
|
/**
|
|
* Stores the default settings for the ContentSecurityPolicy, if you
|
|
* choose to use it. The values here will be read in and set as defaults
|
|
* for the site. If needed, they can be overridden on a page-by-page basis.
|
|
*
|
|
* Suggested reference for explanations:
|
|
*
|
|
* @see https://www.html5rocks.com/en/tutorials/security/content-security-policy/
|
|
*/
|
|
class ContentSecurityPolicy extends BaseConfig
|
|
{
|
|
// -------------------------------------------------------------------------
|
|
// Broadbrush CSP management
|
|
// -------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Default CSP report context
|
|
*/
|
|
public bool $reportOnly = false;
|
|
|
|
/**
|
|
* Specifies a URL where a browser will send reports
|
|
* when a content security policy is violated.
|
|
*/
|
|
public ?string $reportURI = null;
|
|
|
|
/**
|
|
* Specifies a reporting endpoint to which violation reports ought to be sent.
|
|
*/
|
|
public ?string $reportTo = null;
|
|
|
|
/**
|
|
* Instructs user agents to rewrite URL schemes, changing
|
|
* HTTP to HTTPS. This directive is for websites with
|
|
* large numbers of old URLs that need to be rewritten.
|
|
*/
|
|
public bool $upgradeInsecureRequests = false;
|
|
|
|
// -------------------------------------------------------------------------
|
|
// CSP DIRECTIVES SETTINGS
|
|
// NOTE: once you set a policy to 'none', it cannot be further restricted
|
|
// -------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Will default to `'self'` if not overridden
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $defaultSrc = [
|
|
'self',
|
|
'www.google.com',
|
|
];
|
|
|
|
/**
|
|
* Lists allowed scripts' URLs.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $scriptSrc = [
|
|
'self',
|
|
'unsafe-inline',
|
|
'unsafe-eval',
|
|
'www.google.com www.gstatic.com'
|
|
];
|
|
|
|
/**
|
|
* Specifies valid sources for JavaScript <script> elements.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public array|string $scriptSrcElem = 'self';
|
|
|
|
/**
|
|
* Specifies valid sources for JavaScript inline event
|
|
* handlers and JavaScript URLs.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public array|string $scriptSrcAttr = 'self';
|
|
|
|
/**
|
|
* Lists allowed stylesheets' URLs.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $styleSrc = [
|
|
'self',
|
|
'unsafe-inline',
|
|
'nonce-{csp-style-nonce}',
|
|
'https://fonts.googleapis.com',
|
|
];
|
|
|
|
/**
|
|
* Specifies valid sources for stylesheets <link> elements.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public array|string $styleSrcElem = 'self';
|
|
|
|
/**
|
|
* Specifies valid sources for stylesheets inline
|
|
* style attributes and `<style>` elements.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public array|string $styleSrcAttr = 'self';
|
|
|
|
/**
|
|
* Defines the origins from which images can be loaded.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $imageSrc = [
|
|
'self',
|
|
'data:',
|
|
'blob:',
|
|
];
|
|
|
|
/**
|
|
* Restricts the URLs that can appear in a page's `<base>` element.
|
|
*
|
|
* Will default to self if not overridden
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $baseURI;
|
|
|
|
/**
|
|
* Lists the URLs for workers and embedded frame contents
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $childSrc = 'self';
|
|
|
|
/**
|
|
* Limits the origins that you can connect to (via XHR,
|
|
* WebSockets, and EventSource).
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $connectSrc = [
|
|
'self',
|
|
'nominatim.openstreetmap.org',
|
|
];
|
|
|
|
/**
|
|
* Specifies the origins that can serve web fonts.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $fontSrc = [
|
|
'self',
|
|
'fonts.googleapis.com',
|
|
'fonts.gstatic.com',
|
|
];
|
|
|
|
/**
|
|
* Lists valid endpoints for submission from `<form>` tags.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $formAction = 'self';
|
|
|
|
/**
|
|
* Specifies the sources that can embed the current page.
|
|
* This directive applies to `<frame>`, `<iframe>`, `<embed>`,
|
|
* and `<applet>` tags. This directive can't be used in
|
|
* `<meta>` tags and applies only to non-HTML resources.
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $frameAncestors;
|
|
|
|
/**
|
|
* The frame-src directive restricts the URLs which may
|
|
* be loaded into nested browsing contexts.
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $frameSrc;
|
|
|
|
/**
|
|
* Restricts the origins allowed to deliver video and audio.
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $mediaSrc;
|
|
|
|
/**
|
|
* Allows control over Flash and other plugins.
|
|
*
|
|
* @var list<string>|string
|
|
*/
|
|
public $objectSrc = 'none';
|
|
|
|
/**
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $manifestSrc;
|
|
|
|
/**
|
|
* @var list<string>|string
|
|
*/
|
|
public array|string $workerSrc = [];
|
|
|
|
/**
|
|
* Limits the kinds of plugins a page may invoke.
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $pluginTypes;
|
|
|
|
/**
|
|
* List of actions allowed.
|
|
*
|
|
* @var list<string>|string|null
|
|
*/
|
|
public $sandbox;
|
|
|
|
/**
|
|
* Nonce placeholder for style tags.
|
|
*/
|
|
public string $styleNonceTag = '{csp-style-nonce}';
|
|
|
|
/**
|
|
* Nonce placeholder for script tags.
|
|
*/
|
|
public string $scriptNonceTag = '{csp-script-nonce}';
|
|
|
|
/**
|
|
* Replace nonce tag automatically?
|
|
*/
|
|
public bool $autoNonce = true;
|
|
}
|