Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rezach/secure-electron-template
The best way to build Electron apps with security in mind.
https://github.com/rezach/secure-electron-template
boilerplate electron i18next react redux security template webpack
Last synced: 6 days ago
JSON representation
The best way to build Electron apps with security in mind.
- Host: GitHub
- URL: https://github.com/rezach/secure-electron-template
- Owner: reZach
- License: mit
- Created: 2020-01-02T04:48:11.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-14T18:01:33.000Z (10 months ago)
- Last Synced: 2025-02-10T19:04:17.918Z (10 days ago)
- Topics: boilerplate, electron, i18next, react, redux, security, template, webpack
- Language: JavaScript
- Homepage:
- Size: 9.91 MB
- Stars: 1,667
- Watchers: 15
- Forks: 155
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# secure-electron-template
A current electron app template with the most popular frameworks, designed and built with security in mind. (If you are curious about what makes an electron app secure, please check out [this page](https://github.com/reZach/secure-electron-template/blob/master/docs/secureapps.md)).[data:image/s3,"s3://crabby-images/f8e79/f8e79fde5182f4e7f04c0302ba5cdbc6b491bc05" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=reZach_secure-electron-template)
[data:image/s3,"s3://crabby-images/f5dbc/f5dbc3dbab775f8fbd19c10bf3c239909a63088f" alt="Security Rating"](https://sonarcloud.io/dashboard?id=reZach_secure-electron-template)
[data:image/s3,"s3://crabby-images/e8be6/e8be63d6cdf7239d2853c2083005063935398aa6" alt="Maintainability Rating"](https://sonarcloud.io/dashboard?id=reZach_secure-electron-template)
[data:image/s3,"s3://crabby-images/6494a/6494ae3937872f9815b73ff9632168e141d0cc73" alt="Bugs"](https://sonarcloud.io/dashboard?id=reZach_secure-electron-template)
[data:image/s3,"s3://crabby-images/1d316/1d3160f4afdf047ee8b7acf0ac2f5b8f28031594" alt="Vulnerabilities"](https://sonarcloud.io/dashboard?id=reZach_secure-electron-template)## How to get started
To get started, clone the repository by clicking the [data:image/s3,"s3://crabby-images/01deb/01debb63333f0d254a9b4dd677f3f056d538eb81" alt="Use this template"](https://github.com/reZach/secure-electron-template/generate) button, or through the command line (`git clone https://github.com/reZach/secure-electron-template.git`).Once cloned, install the dependencies for the repo by running the following commands (you do _not_ have to run the first command if your command line is already inside the newly cloned repository):
```
cd secure-electron-template
npm i
npm run dev
```> Are you using `yarn`? You'll want to [read this issue](https://github.com/reZach/secure-electron-template/issues/62).
When you'd like to test your app in production, or package it for distribution, please navigate to [this page](https://github.com/reZach/secure-electron-template/blob/master/docs/scripts.md) for more details on how to do this.
## Demo
data:image/s3,"s3://crabby-images/0fcc5/0fcc5d7749f005bd422a9358df3861493d143843" alt="Demo"## Features
Taken from the [best-practices](https://electronjs.org/docs/tutorial/security) official page, here is what this repository offers!1. [Only load secure content](https://electronjs.org/docs/tutorial/security#1-only-load-secure-content) - ✅ (But the developer is responsible for loading secure assets only 🙂)
2. [Do not enable node.js integration for remote content](https://electronjs.org/docs/tutorial/security#2-do-not-enable-nodejs-integration-for-remote-content) - ✅
3. [Enable context isolation for remote content](https://electronjs.org/docs/tutorial/security#3-enable-context-isolation-for-remote-content) - ✅
4. [Handle session permission requests from remote content](https://electronjs.org/docs/tutorial/security#4-handle-session-permission-requests-from-remote-content) - ✅
5. [Do not disable websecurity](https://electronjs.org/docs/tutorial/security#5-do-not-disable-websecurity) - ✅
6. [Define a content security policy](https://electronjs.org/docs/tutorial/security#6-define-a-content-security-policy) - ✅
7. [Do not set allowRunningInsecureContent to true](https://electronjs.org/docs/tutorial/security#7-do-not-set-allowrunninginsecurecontent-to-true) - ✅
8. [Do not enable experimental features](https://electronjs.org/docs/tutorial/security#8-do-not-enable-experimental-features) - ✅
9. [Do not use enableBlinkFeatures](https://electronjs.org/docs/tutorial/security#9-do-not-use-enableblinkfeatures) - ✅
10. [Do not use allowpopups](https://electronjs.org/docs/tutorial/security#10-do-not-use-allowpopups) - ✅
11. [<webview> verify options and params](https://electronjs.org/docs/tutorial/security#11-verify-webview-options-before-creation) - ✅
12. [Disable or limit navigation](https://electronjs.org/docs/tutorial/security#12-disable-or-limit-navigation) - ✅
13. [Disable or limit creation of new windows](https://electronjs.org/docs/tutorial/security#13-disable-or-limit-creation-of-new-windows) - ✅
14. [Do not use openExternal with untrusted content](https://electronjs.org/docs/tutorial/security#14-do-not-use-openexternal-with-untrusted-content) - ✅
15. [Disable remote module](https://electronjs.org/docs/tutorial/security#15-disable-the-remote-module) - ✅
16. [Filter the remote module](https://electronjs.org/docs/tutorial/security#16-filter-the-remote-module) - ✅
17. [Use a current version of electron](https://electronjs.org/docs/tutorial/security#17-use-a-current-version-of-electron) - ✅## Included frameworks
Built-in to this template are a number of popular frameworks already wired up to get you on the road running.- [Electron](https://electronjs.org/)
- [React](https://reactjs.org/)
- [Typescript](https://www.typescriptlang.org)
- [Redux](https://redux.js.org/) (with [Redux toolkit](https://redux-toolkit.js.org/))
- [Babel](https://babeljs.io/)
- [Webpack](https://webpack.js.org/) (with [webpack-dev-server](https://github.com/webpack/webpack-dev-server))
- [Electron builder](https://www.electron.build/) (for packaging up your app)
- [Mocha](https://mochajs.org/)## Bonus modules
What would a template be without some helpful additions?- [i18next](https://www.i18next.com/) (with [this plugin](https://github.com/reZach/i18next-electron-fs-backend) for localization).
- [Store](https://github.com/reZach/secure-electron-store) (for saving config/data)
- [Context menu](https://github.com/reZach/secure-electron-context-menu) (supports custom context menus)
- [Easy redux undo](https://github.com/reZach/easy-redux-undo) (for undo/redoing your redux actions)
- [License key validation](https://github.com/reZach/secure-electron-license-keys) (for validating a user has the proper license to use your app) **new!**## Architecture
For a more detailed view of the architecture of the template, please check out [here](https://github.com/reZach/secure-electron-template/blob/master/docs/architecture.md). I would _highly_ recommend reading this document to get yourself familiarized with this template.## FAQ
Please see [our faq](https://github.com/reZach/secure-electron-template/blob/master/docs/faq.md) for any common questions you might have.
**NEW TO ELECTRON?** Please visit [this page](https://github.com/reZach/secure-electron-template/blob/master/docs/newtoelectron.md).## Show us your apps!
If you've built any applications with our template, we'd [love to see them!](https://github.com/reZach/secure-electron-template/blob/master/docs/yourapps.md).