Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Inboxen/Inboxen
Main repo for Inboxen.org
https://github.com/Inboxen/Inboxen
agplv3 django emails privacy python
Last synced: 2 months ago
JSON representation
Main repo for Inboxen.org
- Host: GitHub
- URL: https://github.com/Inboxen/Inboxen
- Owner: Inboxen
- License: agpl-3.0
- Archived: true
- Created: 2014-09-13T14:36:17.000Z (over 10 years ago)
- Default Branch: main
- Last Pushed: 2023-12-16T16:14:02.000Z (about 1 year ago)
- Last Synced: 2024-08-01T17:32:43.664Z (5 months ago)
- Topics: agplv3, django, emails, privacy, python
- Language: Python
- Homepage: https://inboxen.org
- Size: 5.1 MB
- Stars: 260
- Watchers: 7
- Forks: 20
- Open Issues: 40
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-python-applications - Repo
- awesome-starred - Inboxen/Inboxen - Main repo for Inboxen.org (django)
- awesome-python-applications - Repo
README
# Migrated to [Codeberg](https://codeberg.org/Inboxen/Inboxen)
This repo is no longer used as we have migrated to Codeberg
Inboxen
=======[![Tests](https://github.com/Inboxen/Inboxen/actions/workflows/tests.yml/badge.svg)](https://github.com/Inboxen/Inboxen/actions/workflows/tests.yml)
[![Test coverage](http://codecov.io/github/Inboxen/Inboxen/coverage.svg)](http://codecov.io/github/Inboxen/Inboxen)
[![Documentation Status](https://readthedocs.org/projects/inboxen/badge/?version=latest)](https://inboxen.readthedocs.io/en/latest/?badge=latest)This is the complete system with everything you need to set up Inboxen.
The current maintainer of this repo is [Matt Molyneaux](https://github.com/moggers87)
GPG keys
--------GPG keys used by Inboxen developers to sign releases:
```
Matt Molyneaux
19F5 A8DC C917 FD00 E859 02F4 878B 5A2A 1D47 C084
```Security
--------If you find a security issue with Inboxen, email . If
you wish to send an encrypted report, then please use key id `0x878B5A2A1D47C084`Once reported, all security vulnerabilities will be acted on immediately and a
fix with full disclosure will go out to everyone at the same time.Developing
----------You'll need the following tools:
* Git
* Python (we strongly recommend you use virtualenv too)
* PostgreSQL
* NodeJS
* GNU Make
* [EditorConfig](http://editorconfig.org/) *(optional)*This project comes with a `.editorconfig` file - we recommend installing it to
avoid things like mixing tabs/spaces or accidentally saving files with
DOS-style newlines.Set yourself up with a virtual environment and run the following:
```
git clone https://github.com/Inboxen/Inboxen.git
cd Inboxen
make
```When you've made your changes, remember to check your code
style and run unit tests.Python tests:
```
python manage.py test
```JS tests:
```
npx grunt karma
```To check code style on Python:
```
tox -e isort,lint
```And finally, check JS code style:
```
npx grunt jshint
```### Local HTTP server
You'll need a `inboxen.config` file, for example:
```
secret_key: some_random_string
debug: true
tasks:
always_eager: true
```If you want to start a local HTTP server to test out your changes, run the following:
```
python manage.py runserver
```You can connect to it on .
With `debug=true`, you'll have the Django Debug Toolbar enabled and you can
find the Inboxen styleguide at### Pinned Dependencies
Inboxen uses `pip-tools` to help manage its dependencies. The direct
requirements of Inboxen are kept in `requirements.in` and then we use the
following command to pin the entire dependency graph:```
pip-compile --upgrade --output-file requirements.txt requirements.in
```The resulting `requirements.txt` can be installed to a clean virtualenv with
`pip` to get the exact package versions that Inboxen uses in production. You
can also use the `pip-sync` (which comes with `pip-tools`) to update an
existing virtualenv as well as remove packages that are no longer required.The same principal applies to `requirements-dev.txt`/`requirements-dev.txt` and
any files found in `extras/requirements`.If for any reason you wish to bypass pinning dependencies, `requirements.in`
and `requirements-dev.in` are in the format expected by `pip`.Committing and Branching
------------------------### Branching
All development happens in branches off of `main`. Each branch should have an
associated issue - if there isn't one for what you're working on then create a
new issue first!Branch names should be of the format `-` where:
* `` is the issue you are working on
* `` is a brief description of what's happening on that branchFor example, `129-pin-inboxes` was the branch used for implementing the [pin
inbox feature](https://github.com/Inboxen/Inboxen/issues/129)Finished branches are then merged into `main`. If there is someone available
to review your branch, your branch should be reviewed and merged by them.
Remember to add a note to CHANGELOG.md when merging!#### Hotfix branches
Hotfixes should be branched from the latest deploy tag, and then be tagged
themselves as a normal deployment before being merged back into `main`.### Commit messages
You should follow the pattern of "summary, gap, details, gap, issue references"
For example:
```
Blah blah thingFixes this thing, changes how we should do something else
fix #345
touch #234
```If you are committing on `main`, then make sure to end your commit message
with "IN MAIN" so we know who to blame when stuff breaks.