Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lirantal/express-security-txt
A Node.js middleware for Express that implements Security.txt - A Method for Web Security Policies
https://github.com/lirantal/express-security-txt
express hacktoberfest nodejs security
Last synced: 3 months ago
JSON representation
A Node.js middleware for Express that implements Security.txt - A Method for Web Security Policies
- Host: GitHub
- URL: https://github.com/lirantal/express-security-txt
- Owner: lirantal
- License: mit
- Created: 2017-10-10T21:09:10.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-01-29T16:30:03.000Z (almost 3 years ago)
- Last Synced: 2024-10-04T13:32:29.640Z (3 months ago)
- Topics: express, hacktoberfest, nodejs, security
- Language: JavaScript
- Homepage:
- Size: 477 KB
- Stars: 18
- Watchers: 3
- Forks: 3
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
[![view on npm](http://img.shields.io/npm/v/express-security-txt.svg)](https://www.npmjs.org/package/express-security-txt)
[![view on npm](http://img.shields.io/npm/l/express-security-txt.svg)](https://www.npmjs.org/package/express-security-txt)
[![npm module downloads](http://img.shields.io/npm/dt/express-security-txt.svg)](https://www.npmjs.org/package/express-security-txt)
[![Build Status](https://github.com/lirantal/express-security-txt/workflows/CI/badge.svg)](https://github.com/lirantal/express-security-txt/actions?workflow=main)
[![codecov](https://codecov.io/gh/lirantal/express-security-txt/branch/master/graph/badge.svg)](https://codecov.io/gh/lirantal/express-security-txt)
[![Known Vulnerabilities](https://snyk.io/test/github/lirantal/express-security-txt/badge.svg)](https://snyk.io/test/github/lirantal/express-security-txt)
[![Security Responsible Disclosure](https://img.shields.io/badge/Security-Responsible%20Disclosure-yellow.svg)](https://github.com/nodejs/security-wg/blob/master/processes/responsible_disclosure_template.md)[![express-security-txt](https://snyk.io/advisor/npm-package/express-security-txt/badge.svg)](https://snyk.io/advisor/npm-package/express-security-txt)
# Express Security Txt
Express middleware that implements a security.txt path and policy. Allows the repeating of a directive, as well as the insertion of comments.
References:
* [security.txt RFC](https://tools.ietf.org/html/draft-foudil-securitytxt-05)
* [security.txt project on github](https://github.com/securitytxt/security-txt)## Installation
```bash
yarn add express-security-txt
```## Usage
Define an options object with the keys that make up a valid [security.txt](https://tools.ietf.org/html/draft-foudil-securitytxt-05) file. All the keys are in camelCase.
```javascript
const securityTxt = require('express-security-txt')const options = {
contact: 'https://example.com/security/',
preferredLanguages: 'en'
}app.use(securityTxt.setup(options))
```### Passing multiple values
Some directives allow you to specify multiple values. This package allows you to do this by passing an array:
```javascript
const options = {
contact: ['mailto:[email protected]', 'https://example.com/security/']
}
```### Adding comments
Comments can be included in the generated file. The `#` at the beggining of each line of a comment is automatically inserted by the package.
Comments at the start and end of a file can be added by using the `_prefixComment` and `_postfixComment` keys, like so:
```javascript
const options = {
_prefixComment: 'This comment will appear at the beggining of the security.txt file',
contact: 'mailto:[email protected]',
_postfixComment: 'This comment will appear at the end of the security.txt file'
}
```NOTE: You may include the newline character (`\n`), and the package will automatically insert the `#` symbol at the beggining of each line.
Multiline comments can also be added by specifying an array, where each element is a line of the comment.
Comments just before a directive can be added by creating an object of the form `{ comment: '...', value: '...' }`, where the value associated with the `value` key is the value of the field; and the `comment` is the comment to appear directly before the field.
For example,
```javascript
const options = {
contact: 'https://example.com/security/',
acknowledgments: {
comment: 'This comment will appear just above the Acknowledgments field',
value: 'https://example.com/hall_of_fame'
}
}
```Would become
```
Contact: https://example.com/security/
# This comment will appear just above the Acknowledgments field
Acknowledgments: https://example.com/hall_of_fame
```
If a field allows multiple values, you can leave a comment on each one like so:
```javascript
const options = {
contact: [
{ comment: 'You can rarely reach me by email', value: 'mailto:[email protected]' },
{ comment: 'Try this online form instead?', value: 'https://example.com/security/' }
]
}
```## Tests
Project tests:
```bash
yarn run test
```Project linting:
```bash
yarn run lint
```## Contributing
### Commit Guidelines
The project uses the commitizen tool for standardizing changelog style commit
messages so you should follow it as so:```bash
git add . # add files to staging
yarn run commit # use the wizard for the commit message
```