Skip to main content

Iris is a highly configurable and flexible service for paging and messaging.

Project description

Iris Build Status License Gitter chat

Iris core, API, UI and sender service. For third-party integration support, see iris-relay, a stateless proxy designed to sit at the edge of a production network and allow external traffic to pass through. We also have an Iris mobile app for iOS/Android, at the iris-mobile repo.

Setup database

  1. remove ONLY_FULL_GROUP_BY from MySQL config sql_mode
  2. create mysql schema: mysql -u USER -p < ./db/schema_0.sql
  3. import dummy data: mysql -u USER -p -o iris < ./db/dummy_data.sql

dummy_data.sql contains the following entities:

  • user demo with password demo
  • team demo_team
  • application Autoalerts with key: a7a9d7657ac8837cd7dfed0b93f4b8b864007724d7fa21422c24f4ff0adb2e49

Setup dev environment

  1. create & source your virtualenv
  2. install build dependencies: libssl-dev libxml2-dev libxslt1-dev libsasl2-dev python-dev libldap2-dev
  3. run pip install -e '.[dev,kazoo]'
  4. edit ./configs/config.dev.yaml to setup database credential and other settings

To install iris with extra features, you can pass in feature flag with pip:

pip install -e '.[prometheus]'

For list of extra features, please see extras_require setting in setup.py.

Run everything

forego start

Run web server

make serve

Run sender

iris-sender configs/config.dev.yaml

Tests

Run tests:

make test  # all tests, e2e + unit
make e2e  # e2e tests
make unit  # unit tests

Generate test coverage reports:

make e2e-cov
make unit-cov

Adding new plugins

  1. create the plugin file under src/iris/plugins dir
  2. edit src/iris/plugins/__init__.py to add plugin module to __all__ list

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

irisapi-1.0.14.tar.gz (913.8 kB view details)

Uploaded Source

Built Distribution

irisapi-1.0.14-py3-none-any.whl (947.5 kB view details)

Uploaded Python 3

File details

Details for the file irisapi-1.0.14.tar.gz.

File metadata

  • Download URL: irisapi-1.0.14.tar.gz
  • Upload date:
  • Size: 913.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.2

File hashes

Hashes for irisapi-1.0.14.tar.gz
Algorithm Hash digest
SHA256 74a6ec7abcfcecb22bed0d0642d70db36d1b6cd42e3e79a5e5f63723dd8fea1d
MD5 d5493cc86ed891ad264e89cfcdf56094
BLAKE2b-256 cf8dc88e1713622007fb202e221971bb219264a763f5f7bda5540d7618f0056f

See more details on using hashes here.

File details

Details for the file irisapi-1.0.14-py3-none-any.whl.

File metadata

  • Download URL: irisapi-1.0.14-py3-none-any.whl
  • Upload date:
  • Size: 947.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.2

File hashes

Hashes for irisapi-1.0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 6e435990d4927dc2d30d48cb21b4bb4f7e607a87ff12075071265bfeb7c19f33
MD5 ca272b19423ceab712f3eca4afc850db
BLAKE2b-256 3a559ba916bf85a286a97feedefdf868544e704e0a2725ee0eaf7d640a2f2ce0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page