This repository has been archived by the owner on Feb 20, 2023. It is now read-only.
forked from raymondEhlers/OVERWATCH
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
152 lines (133 loc) · 5.24 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#/usr/bin/env python
""" Setup OVERWATCH
Originally derived from the ``setup.py`` in ``aliBuild``, with options derived
from `here < https://python-packaging.readthedocs.io/en/latest/index.html>`__.
.. codeauthor:: Raymond Ehlers <[email protected]>, Yale University
"""
# Always prefer setuptools over distutils
from setuptools import setup, find_packages
# To use a consistent encoding
from codecs import open
import os
def getVersion():
versionModule = {}
with open(os.path.join("overwatch", "version.py")) as f:
exec(f.read(), versionModule)
return versionModule["__version__"]
# Get the long description from the README file
here = os.path.abspath(os.path.dirname(__file__))
with open(os.path.join(here, 'README.md'), encoding='utf-8') as f:
long_description = f.read()
setup(
name="aliceoverwatch",
version=getVersion(),
description="ALICE OVERWATCH: Online Monitoring via the HLT",
long_description=long_description,
long_description_content_type="text/markdown",
author="Raymond Ehlers",
author_email="[email protected]",
url="https://github.com/raymondEhlers/OVERWATCH",
license="BSD 3-Clause",
# See https://pypi.python.org/pypi?%3Aaction=list_classifiers
classifiers=[
# How mature is this project? Common values are
# 3 - Alpha
# 4 - Beta
# 5 - Production/Stable
'Development Status :: 4 - Beta',
# Indicate who your project is intended for
'Intended Audience :: Science/Research',
# Specify the Python versions you support here. In particular, ensure
# that you indicate whether you support Python 2, Python 3 or both.
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.6',
'Programming Language :: Python :: 3.7'
],
# What does your project relate to?
keywords='HEP ALICE',
packages=find_packages(exclude=("deploy", ".git", "tests")),
# Rename scripts to the desired executable names
# See: https://stackoverflow.com/a/8506532
entry_points = {
"console_scripts": [
# Note that the flask apps only run the flask development server through these scripts
# because they will be launched directly via ``uwsgi`` (ie not through these scripts)
"overwatchDQMReceiver = overwatch.receiver.run:runDevelopment",
"overwatchWebApp = overwatch.webApp.run:runDevelopment",
# The processing will be launched this way in both production and development, so it
# points to a different type of function. This function will on an interval if the
# sleep time is set to a positive value. Otherwise, it will run once.
"overwatchProcessing = overwatch.processing.run:run",
# Deployment script
"overwatchDeploy = overwatch.base.deploy:run",
# Utility script to update the database users
"overwatchUpdateUsers = overwatch.base.updateDBUsers:updateDBUsers",
# Receiver data transfer script
"overwatchReceiverDataTransfer = overwatch.base.run:runReceiverDataTransfer",
# Replay data scripts
# Standard data replay for a particular run
"overwatchReplay = overwatch.base.run:runReplayData",
# For moving larger quantities of data for later data transfer
"overwatchReplayDataTransfer = overwatch.base.run:runReplayDataTransfer",
# Simple script to monitor ZMQ receivers
"overwatchReceiverMonitor = overwatch.receiver.monitor:run",
],
},
# Required packages.
# Optional dependencies are defined below
install_requires = [
"aenum",
"future",
"pendulum",
"ruamel.yaml",
"numpy",
# rootpy is only used peripherally and it's installation process is sometimes difficult,
# so although it's a strictly speaking a requirement, we leave it out here.
# Plus, this allows us to build the docs.
#"rootpy",
"werkzeug",
"flask",
"Flask-Login",
"Flask-Assets",
# PyYAML is needed for Flask-Assets, but they don't include it as a requirement, so we
# need to explicitly include it here.
"PyYAML",
"Flask-RESTful",
# Database
"ZODB",
"pymongo",
# Install `Flask-ZODB` from git repo to support the newer hook and py 3
# git+https://github.com/SpotlightKid/flask-zodb.git
# Unfortunately, we can't install this directly from git, so it has to be handled directly.
"zodburi",
"bcrypt",
"Flask-Bcrypt",
"Flask-WTF",
"requests",
"uwsgi",
# Flask monitoring
"sentry-sdk[flask]",
# Notifications
"slackclient",
],
# Include additional files
include_package_data=True,
extras_require = {
"tests": [
"pytest",
"pytest-cov",
"pytest-mock",
"codecov",
],
"docs": [
"sphinx",
# Allow markdown files to be used
"recommonmark",
# Allow markdown tables to be used
"sphinx_markdown_tables",
],
"dev": [
"flake8",
]
}
)