-
Notifications
You must be signed in to change notification settings - Fork 64
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'Baroshem/chore/1.0.0-rc.4' into patch-1
- Loading branch information
Showing
38 changed files
with
1,642 additions
and
77 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,7 @@ on: | |
- '**-rc.**' | ||
- 'renovate/**' | ||
pull_request: | ||
workflow_dispatch: | ||
|
||
jobs: | ||
ci: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
69 changes: 69 additions & 0 deletions
69
docs/content/1.documentation/4.utils/3.subresource-integrity.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
# Subresource Integrity | ||
|
||
:badge[Enabled]{type="success"} Ensure that your application bundle has not been manipulated. | ||
|
||
--- | ||
|
||
:ellipsis{right=0px width=75% blur=150px} | ||
|
||
Subresource Integrity (SRI) is a security feature that enables the browser to verify that the static assets that your application is loading have not been altered. | ||
|
||
Nuxt Security automatically computes the integrity hash of each static asset (scripts, stylesheets, etc.) that are bundled in your Nuxt Application, and then inserts this value in the resulting HTML file. | ||
|
||
|
||
::alert{type="info"} | ||
ℹ Read more about Subresource Integrity [here](https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity). | ||
:: | ||
|
||
## Options | ||
|
||
This feature is enabled globally by default. You can customize it like following: | ||
|
||
```js{}[nuxt.config.ts] | ||
export default defineNuxtConfig({ | ||
// Global | ||
security: { | ||
sri: true | ||
} | ||
}) | ||
``` | ||
|
||
You can disable the feature globally by setting `sri: false`. | ||
|
||
## Usage | ||
|
||
Subresource Integrity is used for two important security features of your application: | ||
|
||
**1. SRI ensures that the assets that _you_ included in your build have not been altered.** | ||
|
||
When you build your Nuxt application and deliver it to your users, a significant number of critical components are included in your final bundle. | ||
|
||
These components are mostly scripts containing Javascript code (files such as `/_nuxt/entry.b8aef440d.js`), stylesheets, etc. An attacker may try to compromise your application by modifying these files. | ||
|
||
Nuxt Security calculates the hash of each of these files _at build time_, therefore guaranteeing that the files that are loaded by your users are exactly the ones that you included in your bundle. | ||
|
||
Arguably, if you host your static assets yourself, the risk that these files are modified by a malicious actor without your authorization can be rated as low. | ||
|
||
However: | ||
|
||
- If you host your application on a public CDN, that CDN could become the target of an attack. | ||
- Even if you host your application on a private hosting service, you should be aware that most hosting providers use elaborate caching strategies to accelerate the delivery of your files (e.g. via edge CDN replication). | ||
- In any case, your own account (or the account of one of the members of your organization) might become compromised. | ||
|
||
For these reasons, most modern web applications rely on SRI to reduce their attack surface. | ||
|
||
::alert{type="success"} | ||
SRI is supported by all modern browsers: [caniuse](https://caniuse.com/subresource-integrity) | ||
:: | ||
|
||
**2. SRI is a critical component of Content Security Policy (CSP) in SSG mode.** | ||
|
||
For more information on the relationship between Subresource Integrity and a Strict CSP, please read our [Advanced Section on Integrity Hashes for CSP](/documentation/advanced/strict-csp/#ssg-mode) | ||
|
||
If you use CSP on a statically-generated application, you will need to enable SRI by setting `sri: true`. | ||
|
||
::alert{type="warning"} | ||
Subresource Integrity hashes can only be inserted on `<script>` and `<link>` elements generated as part of the server bundle. | ||
<br> | ||
To protect your Nuxt application after client-side hydration, you must deploy a Strict CSP. | ||
:: |
Oops, something went wrong.