2020-10-15 18:54:57 +02:00
# [![Send](./assets/icon.svg)](https://gitlab.com/timvisee/send/) Send
2020-10-16 16:42:40 +02:00
[![Build status on GitLab CI][gitlab-ci-master-badge]][gitlab-ci-link]
2020-10-18 15:55:37 +02:00
[![Latest release][release-badge]][release-link]
2020-10-16 16:42:40 +02:00
[![Docker image][docker-image-badge]][docker-image-link]
[![Project license][repo-license-badge]](LICENSE)
[docker-image-badge]: https://img.shields.io/badge/docker-latest-blue.svg
[docker-image-link]: https://gitlab.com/timvisee/send/container_registry/eyJuYW1lIjoidGltdmlzZWUvc2VuZCIsInRhZ3NfcGF0aCI6Ii90aW12aXNlZS9zZW5kL3JlZ2lzdHJ5L3JlcG9zaXRvcnkvMTQxODUwNC90YWdzP2Zvcm1hdD1qc29uIiwiaWQiOjE0MTg1MDQsImNsZWFudXBfcG9saWN5X3N0YXJ0ZWRfYXQiOm51bGx9
[gitlab-ci-link]: https://gitlab.com/timvisee/send/pipelines
[gitlab-ci-master-badge]: https://gitlab.com/timvisee/send/badges/master/pipeline.svg
2020-10-18 15:55:37 +02:00
[release-badge]: https://img.shields.io/github/v/tag/timvisee/send
2020-10-20 20:56:23 +02:00
[release-link]: https://gitlab.com/timvisee/send/-/tags
2020-10-16 16:42:40 +02:00
[repo-license-badge]: https://img.shields.io/github/license/timvisee/send.svg
2017-06-26 21:34:31 +02:00
2020-10-16 18:49:33 +02:00
A fork of Mozilla's [Firefox Send][mozilla-send].
Mozilla discontinued Send, this fork is a community effort to keep the project
up-to-date and alive.
2020-10-16 18:54:19 +02:00
- Forked [at][fork-commit] Mozilla's last publicly hosted version
2020-10-16 18:49:33 +02:00
- _Mozilla_ & _Firefox_ branding [is][remove-branding-pr] removed so you can legally self-host
- Kept compatible with [`ffsend`][ffsend] (CLI for Send)
- Dependencies have been updated
2020-10-16 18:54:19 +02:00
- Mozilla's [changes][mozilla-patches] since the fork have been selectively [merged][mozilla-patches-pr]
2020-10-16 18:49:33 +02:00
- Mozilla's experimental report feature, download tokens, trust warnings and FxA changes are not included
Find an up-to-date Docker image here: [docs/docker.md ](docs/docker.md )
2020-10-16 18:54:19 +02:00
The original project by Mozilla can be found [here][mozilla-send].
2020-10-16 18:49:33 +02:00
The [`mozilla-master`][branch-mozilla-master] branch holds the `master` branch
as left by Mozilla.
The [`send-v3`][branch-send-v3] branch holds the commit tree of Mozilla's last
2020-10-16 18:54:19 +02:00
publicly hosted version, which this fork is based on.
2020-10-16 18:49:33 +02:00
The [`send-v4`][branch-send-v4] branch holds the commit tree of Mozilla's last
experimental version which was still a work in progress (featuring file
reporting, download tokens, trust warnings and FxA changes), this has
selectively been merged into this fork.
2020-10-16 18:54:19 +02:00
Please consider to [donate][donate] to allow me to keep working on this.
2020-10-16 18:49:33 +02:00
Thanks [Mozilla][mozilla] for building this amazing tool!
[branch-mozilla-master]: https://gitlab.com/timvisee/send/-/tree/mozilla-master
[branch-send-v3]: https://gitlab.com/timvisee/send/-/tree/send-v3
[branch-send-v4]: https://gitlab.com/timvisee/send/-/tree/send-v4
2020-10-16 18:54:19 +02:00
[donate]: https://timvisee.com/donate
2020-10-16 18:49:33 +02:00
[ffsend]: https://github.com/timvisee/ffsend
[fork-commit]: https://gitlab.com/timvisee/send/-/commit/3e9be676413a6e1baaf6a354c180e91899d10bec
[mozilla-patches-pr]: https://gitlab.com/timvisee/send/-/merge_requests/3
[mozilla-patches]: https://gitlab.com/timvisee/send/-/compare/3e9be676413a6e1baaf6a354c180e91899d10bec...mozilla-master
[mozilla-send]: https://github.com/mozilla/send
[mozilla]: https://mozilla.org/
[remove-branding-pr]: https://gitlab.com/timvisee/send/-/merge_requests/2
---
2017-06-26 21:34:31 +02:00
2018-03-06 01:29:09 +01:00
**Docs:** [FAQ ](docs/faq.md ), [Encryption ](docs/encryption.md ), [Build ](docs/build.md ), [Docker ](docs/docker.md ), [Metrics ](docs/metrics.md ), [More ](docs/ )
2017-07-14 22:20:28 +02:00
2017-08-20 14:05:48 +02:00
---
2017-10-06 21:03:14 +02:00
## Table of Contents
* [What it does ](#what-it-does )
* [Requirements ](#requirements )
* [Development ](#development )
* [Commands ](#commands )
* [Configuration ](#configuration )
* [Localization ](#localization )
* [Contributing ](#contributing )
* [Testing ](#testing )
2019-07-12 16:07:24 +02:00
* [Deployment ](#deployment )
2021-01-24 21:38:05 +01:00
* [Clients ](#clients )
2017-10-06 21:03:14 +02:00
* [License ](#license )
---
2017-08-20 14:05:48 +02:00
2017-06-26 21:34:31 +02:00
## What it does
2017-07-19 18:23:42 +02:00
A file sharing experiment which allows you to send encrypted files to other users.
2017-06-26 21:34:31 +02:00
2017-08-20 14:05:48 +02:00
---
2017-06-26 21:34:31 +02:00
## Requirements
2020-05-15 15:53:56 +02:00
- [Node.js 12.x ](https://nodejs.org/ )
2017-08-25 22:58:51 +02:00
- [Redis server ](https://redis.io/ ) (optional for development)
2020-06-09 04:47:39 +02:00
- [AWS S3 ](https://aws.amazon.com/s3/ ) or compatible service (optional)
2017-06-26 21:34:31 +02:00
2017-08-25 22:58:51 +02:00
---
## Development
2020-06-09 04:47:39 +02:00
To start an ephemeral development server, run:
2017-06-26 21:34:31 +02:00
```sh
2017-08-25 22:58:51 +02:00
npm install
npm start
2017-06-26 21:34:31 +02:00
```
2020-06-09 04:47:39 +02:00
Then, browse to http://localhost:8080
2017-08-26 00:41:53 +02:00
2017-08-20 14:05:48 +02:00
---
2017-08-25 22:58:51 +02:00
## Commands
2017-06-26 21:34:31 +02:00
| Command | Description |
|------------------|-------------|
| `npm run format` | Formats the frontend and server code using **prettier** .
| `npm run lint` | Lints the CSS and JavaScript code.
| `npm test` | Runs the suite of mocha tests.
2017-08-24 23:54:02 +02:00
| `npm start` | Runs the server in development configuration.
| `npm run build` | Builds the production assets.
| `npm run prod` | Runs the server in production configuration.
2017-06-26 21:34:31 +02:00
2017-08-20 14:05:48 +02:00
---
2017-08-25 22:58:51 +02:00
## Configuration
2017-08-27 22:45:38 +02:00
The server is configured with environment variables. See [server/config.js ](server/config.js ) for all options and [docs/docker.md ](docs/docker.md ) for examples.
2017-08-25 22:58:51 +02:00
---
2017-06-26 21:34:31 +02:00
## Localization
2020-10-15 18:52:41 +02:00
Send localization is managed via [Pontoon ](https://pontoon.mozilla.org/projects/test-pilot-firefox-send/ ), not direct pull requests to the repository. If you want to fix a typo, add a new language, or simply know more about localization, please get in touch with the [existing localization team ](https://pontoon.mozilla.org/teams/ ) for your language or Mozilla’ s [l10n-drivers ](https://wiki.mozilla.org/L10n:Mozilla_Team#Mozilla_Corporation ) for guidance.
2017-06-26 21:34:31 +02:00
2018-03-06 01:29:09 +01:00
see also [docs/localization.md ](docs/localization.md )
2017-08-20 14:05:48 +02:00
---
2017-06-26 21:34:31 +02:00
## Contributing
2017-12-31 12:09:57 +01:00
Pull requests are always welcome! Feel free to check out the list of ["good first issues" ](https://github.com/mozilla/send/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22 ).
2017-06-26 21:34:31 +02:00
2017-08-20 14:05:48 +02:00
---
2017-07-05 18:47:22 +02:00
## Testing
2017-06-26 21:34:31 +02:00
2017-07-05 18:47:22 +02:00
| ENVIRONMENT | URL
|-------------|-----
2017-07-06 21:12:01 +02:00
| Production | < https: / / send . firefox . com / >
2019-03-08 02:03:50 +01:00
| Stage | < https: / / stage . send . nonprod . cloudops . mozgcp . net / >
| Development | < https: / / send2 . dev . lcip . org / >
2017-06-26 21:34:31 +02:00
2017-08-20 14:05:48 +02:00
---
2019-07-12 16:07:24 +02:00
## Deployment
see also [docs/deployment.md ](docs/deployment.md )
---
2021-01-24 21:38:05 +01:00
## Clients
2018-09-19 16:19:18 +02:00
2021-01-24 21:38:05 +01:00
- Web: _this repository_
- Command-line: [`ffsend` ](https://github.com/timvisee/ffsend )
- Android: _see [Android](#android) section_
#### Android
The android implementation is contained in the `android` directory,
and can be viewed locally for easy testing and editing by running `ANDROID=1 npm
start` and then visiting < http: / / localhost:8080 > . CSS and image files are
located in the `android/app/src/main/assets` directory.
2018-09-19 16:19:18 +02:00
---
2017-06-26 21:34:31 +02:00
## License
[Mozilla Public License Version 2.0 ](LICENSE )
2017-08-20 14:05:48 +02:00
2020-07-27 23:49:10 +02:00
[qrcode.js ](https://github.com/kazuhikoarase/qrcode-generator ) licensed under MIT
2017-08-20 14:05:48 +02:00
---