Skip to content

Commit

Permalink
Integrate with Conda and a publish through CI (#249)
Browse files Browse the repository at this point in the history
* Create metadata file to integrate with conda

* Add github action for publishing to conda

* Attempt to install Conda manually

* Install conda-build with conda

* Install anaconda manually again as miniconda is not enough

* Install anaconda client as part of workflow

* Test if conda activate makes anaconda available

* Run conda init as well

* Trying some changes out to fix upload action

* Add anaconda to PATH

* Testing anaconda bin output

* Enable auto activation

* Remove ls

* Test with setup-miniconda again

* Fix syntax erorrs in workflow

* Use bash as workflow shell

* Confirm fix by using shell

* Only push to conda on tag releases

* Explicitly add optional dependencies for conda compatibility

* Add documentation for working with conda

* Small grammar fix

* docs nits, merge pypi/conda publish workflows

Co-authored-by: Eduardo Armendariz <eduardo@ethyca.com>
Co-authored-by: Thomas La Piana <tal103020@icloud.com>
  • Loading branch information
3 people authored Dec 1, 2021
1 parent 629b102 commit a9f7d2e
Show file tree
Hide file tree
Showing 13 changed files with 123 additions and 95 deletions.
42 changes: 42 additions & 0 deletions .github/workflows/publish_package.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
name: Publish fidesctl

on:
push:
tags:
- "*"

jobs:
upload_to_pypi:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2

- name: Install Twine
run: pip install twine

- name: Twine Upload
run: |
cd fidesctl/
python setup.py sdist
twine upload dist/*
env:
TWINE_USERNAME: __token__
TWINE_PASSWORD: ${{ secrets.PYPI_TOKEN }}

upload_to_conda:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install Anaconda
uses: conda-incubator/setup-miniconda@v2
with:
auto-activate-base: true
activate-environment: ""
- name: Conda Upload
shell: bash -l {0}
run: |
conda install conda-build
conda install anaconda-client
conda install conda-verify
conda build --output-folder ./conda-out/ ./fidesctl/conda/ -c plotly -c conda-forge
anaconda -t "${{ secrets.CONDA_TOKEN }}" upload -u ethyca ./conda-out/noarch/fidesctl*.bz2
24 changes: 0 additions & 24 deletions .github/workflows/publish_pypi.yaml

This file was deleted.

1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ wheels/
.installed.cfg
*.egg
MANIFEST
conda-out/

# PyInstaller
# Usually these files are written by a python script from a template
Expand Down
8 changes: 4 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Meet Fidesctl: Privacy Policies as Code

[![Latest Version][pypi-image]][pypi-url]
[![Latest Release Version][release-image]][release-url]
[![License][license-image]][license-url]
[![Code style: black][black-image]][black-url]
[![Checked with mypy][mypy-image]][mypy-url]
Expand Down Expand Up @@ -223,12 +223,12 @@ Read about the [Fides community](https://ethyca.github.io/fides/community/hints_
## :balance_scale: License
The Fides ecosystem of tools ([Fidesops](https://github.com/ethyca/fidesops) and [Fidesctl](https://github.com/ethyca/fides)) are licensed under the [Apache Software License Version 2.0](https://www.apache.org/licenses/LICENSE-2.0).
Fides tools are built on [Fideslang](https://github.com/ethyca/privacy-taxonomy), the Fides language specification, which is licensed under [CC by 4](https://github.com/ethyca/privacy-taxonomy/blob/main/LICENSE).
Fides tools are built on [Fideslang](https://github.com/ethyca/privacy-taxonomy), the Fides language specification, which is licensed under [CC by 4](https://github.com/ethyca/privacy-taxonomy/blob/main/LICENSE).
Fides is created and sponsored by Ethyca: a developer tools company building the trust infrastructure of the internet. If you have questions or need assistance getting started, let us know at fides@ethyca.com!
[pypi-image]: https://img.shields.io/pypi/v/fidesctl.svg
[pypi-url]: https://pypi.python.org/pypi/fidesctl/
[release-image]: https://img.shields.io/github/release/ethyca/fides.svg
[release-url]: https://github.com/ethyca/fides/releases
[license-image]: https://img.shields.io/:license-Apache%202-blue.svg
[license-url]: https://www.apache.org/licenses/LICENSE-2.0.txt
[black-image]: https://img.shields.io/badge/code%20style-black-000000.svg
Expand Down
53 changes: 0 additions & 53 deletions docs/fides/docs/cli/generate-dataset.md

This file was deleted.

2 changes: 1 addition & 1 deletion docs/fides/docs/development/releases.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ Fidesctl does not follow a set release schedule, but instead ships versions base

For each release a corresponding GitHub Project is created. These projects can be found [here](https://github.com/ethyca/fides/projects). Issues are then added to release projects as a way to organize what will be included in each release.

Once a release project is complete and the core team signs off on the readiness of the release, a new version is cut using GitHub releases. You can see all fidesctl releases [here](https://github.com/ethyca/fides/releases). Each new release triggers a GitHub Action that pushes the new version to PyPI as well as pushes a clean version to DockerHub. The release project is then marked as `closed`.
Once a release project is complete and the core team signs off on the readiness of the release, a new version is cut using GitHub releases. You can see all fidesctl releases [here](https://github.com/ethyca/fides/releases). Each new release triggers a GitHub Action that pushes the new version to PyPI and Conda as well as pushes a clean version to DockerHub. The release project is then marked as `closed`.

Hotfixes are an exception to this and can be added and pushed as patch versions when needed.

Expand Down
17 changes: 17 additions & 0 deletions docs/fides/docs/installation/conda.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Installation from Conda

This page describes installations using the `fidesctl` package [published on Conda](https://anaconda.org/ethyca/fidesctl).

## Installation

To install fidesctl, first create an environment with the fidesctl package and necessary channels:

```bash
conda create --name fidesctl-environment fidesctl \
--channel ethyca \
--channel plotly \
--channel conda-forge
```

Then activate your environment to begin using the `fidesctl` cli:
`conda activate fidesctl-environment`
14 changes: 9 additions & 5 deletions docs/fides/docs/installation/installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,18 @@ You should also check-out the [prerequisites](prerequisites_dependencies.md) tha

When you install fidesctl, you need to [setup the database](database.md) which must also be kept updated when fidesctl is upgraded.

## Using PyPI
## Installation Tools

More details: [Installation from PyPI](pypi.md)
Only `pip` and `conda` installations are currently officially supported. For more details see [Installation from PyPI](pypi.md) or [Installation from Conda](conda.md)

In some cases a lightweight installation might be desired, for instance, if the webserver is not needed. If this is the case, our `pip` installation supports optional dependencies.

While there are some successes with using other tools like poetry or pip-tools, they do not share the same workflow as the supported tools - especially when it comes to constraint vs. requirements management. Installing via Poetry or pip-tools is not currently supported. If you wish to install fidesctl using those tools you do so at your own discretion.

**When this option works best**

* This installation method is useful when you are not familiar with containers and Docker and want to install fidesctl on physical or virtual machines and you are used to installing and running software using custom deployment mechanism.
* The only officially supported mechanism of installation is via pip.
* The only officially supported mechanisms of installation are pip and conda.

**Intended users**

Expand All @@ -27,7 +31,7 @@ More details: [Installation from PyPI](pypi.md)

**What the Fidesctl community provides for this method**

* You have [Installation from PyPI](pypi.md) on how to install the software but due to various environments and tools you might want to use, you might expect that there will be problems which are specific to your deployment and environment that you will have to diagnose and solve.
* You have [Installation from PyPI](pypi.md) and [Installation from Conda](conda.md) on how to install the software but due to various environments and tools you might want to use, you might expect that there will be problems which are specific to your deployment and environment that you will have to diagnose and solve.
* You have the [Running fidesctl Locally](../quickstart/local_full.md) guide where you can see an example of running fidesctl with minimal dependencies and setup. You can use this guide to start fidesctl quickly for local testing and development, however this is only intended to provide inspiration, not to represent a production-grade installation.

**Where to ask for help**
Expand All @@ -37,7 +41,7 @@ More details: [Installation from PyPI](pypi.md)

## Using Production Docker Images

More details: [Installation from Docker](pypi.md)
More details: [Installation from Docker](docker.md)

**When this option works best**

Expand Down
6 changes: 0 additions & 6 deletions docs/fides/docs/installation/pypi.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,6 @@

This page describes installations using the `fidesctl` package [published on PyPI](https://pypi.org/project/fidesctl/).

## Installation Tools

Only `pip` installation is currently officially supported.

While there are some successes with using other tools like poetry or pip-tools, they do not share the same workflow as pip - especially when it comes to constraint vs. requirements management. Installing via Poetry or pip-tools is not currently supported. If you wish to install fidesctl using those tools you do so at your own discretion.

## Basic Installation

To install Fidesctl, run:
Expand Down
1 change: 1 addition & 0 deletions docs/fides/mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ nav:
- Installation Overview: installation/installation.md
- Prerequisites & Dependencies: installation/prerequisites_dependencies.md
- Installation from PyPI: installation/pypi.md
- Installation from Conda: installation/conda.md
- Installation from Docker: installation/docker.md
- Setting up the database: installation/database.md
- Configuration: installation/configuration.md
Expand Down
45 changes: 45 additions & 0 deletions fidesctl/conda/meta.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
{% set data = load_setup_py_data(setup_file='../setup.py', from_recipe_dir=True) %}

package:
name: "{{ data.get('name')|lower }}"
version: "{{ data.get('version') }}"

source:
path: "../.."

build:
number: 0
entry_points:
- fidesctl=fidesctl.cli:cli
script: |
cd fidesctl
{{ PYTHON }} -m pip install . -vv
noarch: python

requirements:
host:
- pip
- python >=3.7, <4
run:
- python >=3.7, <4
{% for package in data.get('install_requires') %}
- {{ package }}
{% endfor %}
{% for package in data.get('extras_require')['all'] %}
- {{ package }}
{% endfor %}

test:
imports:
- fidesctl
commands:
- fidesctl --help

about:
home: "{{ data.get('url') }}"
license: "{{ data.get('license') }}"
license_family: APACHE
license_file: LICENSE
summary: "{{ data.get('description') }}"
description: "{{ data.get('long_description') }}"
doc_url: "https://ethyca.github.io/fides/"
2 changes: 1 addition & 1 deletion fidesctl/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ colorama==0.4.4
deepdiff==5.5.0
pandas==1.3.3
plotly==5.3.1
PyJWT==2.1.0
pydantic==1.8.2
PyJWT==2.1.0
pyyaml==5.4.1
requests==2.25.1
sqlalchemy==1.4.14
Expand Down
3 changes: 2 additions & 1 deletion fidesctl/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,14 @@
long_description = open("README.md").read()

# Requirements
# Explicitly add optional dependencies for conda compatiblity, for instance, avoid using fastapi[all]
install_requires = open("requirements.txt").read().strip().split("\n")
dev_requires = open("dev-requirements.txt").read().strip().split("\n")

extras = {
"postgres": ["psycopg2-binary==2.9.1"],
"mysql": ["pymysql==1.0.2"],
"webserver": ["fastapi[all]==0.68.1", "psycopg2-binary==2.9.1"],
"webserver": ["fastapi==0.68.1", "uvicorn==0.15.0", "psycopg2-binary==2.9.1"],
}
extras["all"] = sum(extras.values(), [])

Expand Down

0 comments on commit a9f7d2e

Please sign in to comment.