Django backend for GlitchTip https://glitchtip.com/

David Burke d6e269fa60 Files CRUD API 3 years ago
.vscode 64d976e6d1 Show isMember on organizations projects serializer. Related to 4 years ago
alerts 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
api_tokens 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
assets 7b290b5349 HTML emails! 4 years ago
bin 2531aee1d1 Added dyno env var check for running migrations and workers in Heroku 4 years ago
djstripe_ext d4bc82966d Fix products list test 3 years ago
environments 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
events 9b531a7e97 Prefer using "glitchtip_key" over "sentry_key" when not using a Sentry 3 years ago
files d6e269fa60 Files CRUD API 3 years ago
glitchtip d6e269fa60 Files CRUD API 3 years ago
issues 9b531a7e97 Prefer using "glitchtip_key" over "sentry_key" when not using a Sentry 3 years ago
organizations_ext d8993fc6cd Send email when event quota is near on hosted glitchtip 4 years ago
performance aea843845a Move transaction events to own model for performance reasons 4 years ago
projects d6e269fa60 Files CRUD API 3 years ago
releases d6e269fa60 Files CRUD API 3 years ago
sentry 66292de7f9 Semi support malformed incoming event exception values that aren't 4 years ago
teams 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
templates 36896f77ea Resolve "Style 404 page" 4 years ago
test_api 476fc2bd5d more projects 4 years ago
user_reports 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
users e792a54e4b Fixes #67 technically allow user creation without open registration. No 4 years ago
.dockerignore 9291afe61b Save transaction events (still not used) 4 years ago
.gitignore 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago
.gitlab-ci.yml 7ec2c63bbb Update poetry 3 years ago
.pylintrc 248d915ceb Add pylintrc 4 years ago
CONTRIBUTING.md 4168a6cdc3 Document serializer naming 5 years ago
Dockerfile 7ec2c63bbb Update poetry 3 years ago
LICENSE 5718e945ba Add license 5 years ago
NOTICE.md 8b3a243b24 Add environment tag creation 4 years ago
README.md 8b3a243b24 Add environment tag creation 4 years ago
docker-compose.locust.yml 199dbcc672 Update docker compose version 4 years ago
docker-compose.yml 691cb1d0c1 Make console email backend not the default to simplify installation 4 years ago
locustfile.py ef2b80bcdc Move events model to own app 4 years ago
manage.py 5e245f6ac0 initial commit 5 years ago
mypy.ini 04ed0813c0 Start on webhook ideas 4 years ago
poetry.lock a31c6aea82 Package updates 3 years ago
pyproject.toml 315af98567 Experiment with file uploads, related to https://gitlab.com/glitchtip/glitchtip/-/issues/13 3 years ago

README.md

Gitter

GlitchTip Backend

GlitchTip is an open source, Sentry API compatible error tracking platform. It is a partial fork/mostly reimplementation of Sentry's open source codebase before it went proprietary. Its goals are to be a modern, easy-to-develop error tracking platform that respects your freedom to use it any way you wish. Some differences include:

  • A modern development environment with Python 3 and Django 3.1.
  • Simplicity over features. We use Postgres to store error data. Our code base is a fraction of the size of Sentry and looks like a typical Django app. We leverage existing open source Django ecosystem apps whenever possible.
  • Respects your privacy. No massive JS bundles. No invasive tracking. No third party spying. Even our marketing site runs Matomo and respects Do Not Track. GlitchTip will never report home. We will never know if you run it yourself.
  • Commitment to open source. We use open source tools like GitLab whenever possible. With our MIT license, you can use it for anything you'd like and even sell it. We believe in competition and hope you make GlitchTip even better.

Project status: Stable. Open an issue and say hello if you'd like to help. We are able to process basic error requests from the open source Sentry client tools. More features are on the way.

Developing

We use Docker for development. View our Contributing documentation if you'd like to help make GlitchTip better.

Run local dev environment

  1. Ensure docker and docker-compose are installed
  2. docker-compose up
  3. `docker-compose run --rm web ./manage.py migrate

Run tests with docker-compose run --rm web ./manage.py test

VS Code (Optional)

VS Code can do type checking and type inference. However, it requires setting up a virtual environment.

  1. Install Python 3 dependencies. For Ubuntu this is apt install python3-dev python3-venv
  2. Install poetry
  3. Create Python virtual environment python3 -m venv env
  4. Activate environment source env/bin/activate
  5. Install packages poetry install

Load testing

Locust is built into the dev dependencies. To run with locus run docker-compose -f docker-compose.yml -f docker-compose.locust.yml up

Now go to localhost:8089 to run the test.

Locust will not be intalled to production docker images and cannot be run from them.

Acknowledgements

  • Thank you to the Sentry team for their ongoing open source SDK work and formerly open source backend of which this project is based on.
  • We use Rocket Chat for embedded support on glitchtip.com and in app
  • Matomo is used for analytics and is not shared with any third party