nucypher/setup.py

187 lines
5.0 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
This file is part of nucypher.
nucypher is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
nucypher is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with nucypher. If not, see <https://www.gnu.org/licenses/>.
"""
2020-06-26 02:52:04 +00:00
import os
import sys
2020-05-28 18:53:29 +00:00
from pathlib import Path
from typing import Dict
2020-12-20 09:27:59 +00:00
from urllib.parse import urlparse
2020-05-28 18:53:29 +00:00
from setuptools import find_packages, setup
from setuptools.command.develop import develop
from setuptools.command.install import install
2020-06-26 02:52:04 +00:00
#
# Metadata
#
PACKAGE_NAME = 'nucypher'
2020-05-28 18:53:29 +00:00
BASE_DIR = Path(__file__).parent
PYPI_CLASSIFIERS = [
"Development Status :: 3 - Alpha",
"Intended Audience :: Developers",
"License :: OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)",
"Natural Language :: English",
"Operating System :: OS Independent",
"Programming Language :: Python",
"Programming Language :: Python :: 3 :: Only",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
2023-11-03 18:24:59 +00:00
"Programming Language :: Python :: 3.12",
"Topic :: Security",
]
ABOUT: Dict[str, str] = dict()
2020-05-28 18:53:29 +00:00
SOURCE_METADATA_PATH = BASE_DIR / PACKAGE_NAME / "__about__.py"
with open(str(SOURCE_METADATA_PATH.resolve())) as f:
exec(f.read(), ABOUT)
#
# Utilities
#
class VerifyVersionCommand(install):
"""Custom command to verify that the git tag matches our version"""
description = 'verify that the git tag matches our version'
def run(self):
tag = os.getenv('CIRCLE_TAG')
if tag.startswith('v'):
tag = tag[1:]
version = ABOUT['__version__']
if version.startswith('v'):
version = version[1:]
if tag != version:
info = "Git tag: {0} does not match the version of this app: {1}".format(
os.getenv('CIRCLE_TAG'), ABOUT['__version__']
)
sys.exit(info)
class PostDevelopCommand(develop):
"""
Post-installation for development mode.
Execute manually with python setup.py develop or automatically included with
`pip install -e . -r dev-requirements.txt`.
"""
def run(self):
"""development setup scripts (pre-requirements)"""
develop.run(self)
2020-06-26 02:52:04 +00:00
#
# Requirements
#
def read_requirements(path):
2021-05-11 17:55:13 +00:00
with open(BASE_DIR / path) as f:
2020-12-20 09:27:59 +00:00
_pipenv_flags, *lines = f.read().split('\n')
# TODO remove when will be no more git dependencies in requirements.txt
2020-12-20 09:27:59 +00:00
# Transforms VCS requirements to PEP 508
requirements = []
for line in lines:
if line.startswith('-e git:') or line.startswith('-e git+') or \
line.startswith('git:') or line.startswith('git+'):
# parse out egg=... fragment from VCS URL
parsed = urlparse(line)
egg_name = parsed.fragment.partition("egg=")[-1]
without_fragment = parsed._replace(fragment="").geturl()
requirements.append(f"{egg_name} @ {without_fragment}")
else:
requirements.append(line)
2020-05-21 05:32:01 +00:00
return requirements
2023-06-07 15:07:00 +00:00
INSTALL_REQUIRES = read_requirements("requirements.txt")
DEV_REQUIRES = read_requirements("dev-requirements.txt")
2022-05-02 11:10:55 +00:00
BENCHMARK_REQUIRES = [
'pytest-benchmark'
]
DEPLOY_REQUIRES = [
'bumpversion',
'ansible',
'twine',
'wheel'
]
2023-09-22 09:51:37 +00:00
URSULA_REQUIRES = ["sentry-sdk"]
EXTRAS = {
# Admin
2023-06-07 15:07:00 +00:00
"dev": DEV_REQUIRES + URSULA_REQUIRES,
"benchmark": DEV_REQUIRES + BENCHMARK_REQUIRES,
"deploy": DEPLOY_REQUIRES,
"ursula": URSULA_REQUIRES,
}
setup(
# Requirements
python_requires='>=3',
install_requires=INSTALL_REQUIRES,
extras_require=EXTRAS,
# Package Data
packages=find_packages(exclude=["scripts"]),
include_package_data=True,
zip_safe=False,
# Entry Points
entry_points={
'console_scripts': [
'nucypher = nucypher.cli.main:nucypher_cli',
],
'pytest11': [
"pytest-nucypher = tests.fixtures"
]
},
# setup.py commands
cmdclass={
'verify': VerifyVersionCommand,
'develop': PostDevelopCommand
},
# Metadata
name=ABOUT['__title__'],
url=ABOUT['__url__'],
version=ABOUT['__version__'],
author=ABOUT['__author__'],
author_email=ABOUT['__email__'],
description=ABOUT['__summary__'],
license=ABOUT['__license__'],
long_description_content_type="text/markdown",
long_description_markdown_filename='README.md',
keywords="nucypher, proxy re-encryption",
classifiers=PYPI_CLASSIFIERS
)