/nise-populator

A python application for deploying populated nise data for cloud providers

Primary LanguagePythonMIT LicenseMIT

nise-populator

A python application for deploying populated nise data for cloud providers

Development

To get started developing with nise-populator first clone a local copy of the git repository:

git clone https://github.com/project-koku/nise-populator.git

This project is developed uses Pipenv. Many configuration settings can be read in from a .env file. To configure, do the following:

  1. Copy example.env into a .env
  2. Obtain AWS, Azure, GCP, OCI and Insights values and update the following in your .env:
AWS_ACCESS_KEY_ID=AWS_ACCESS_KEY
AWS_SECRET_ACCESS_KEY=AWS_SECRET_KEY

AZURE_STORAGE_ACCOUNT=AZURE_STORAGE_ACCOUNT
AZURE_STORAGE_CONNECTION_STRING=AZURE_STORAGE_CONNECTION_STRING

INSIGHTS_USER=INSIGHTS_USER
INSIGHTS_PASSWORD=INSIGHTS_PASSWORD
INSIGHTS_URL=INSIGHTS_URL
HCC_SERVICE_ACCOUNT_ID=HCC_SERVICE_ACCOUNT_ID
HCC_SERVICE_ACCOUNT_SECRET=HCC_SERVICE_ACCOUNT_SECRET
HCC_TOKEN_URL=HCC_TOKEN_URL


GCP_DATASET=GCP_DATASET
GCP_PROJECT_ID=GCP_PROJECT_ID
GOOGLE_APPLICATION_CREDENTIALS=/path/to/creds.json

OCI_USER=OCI_USER
OCI_FINGERPRINT=OCI_FINGERPRINT
OCI_TENANCY=OCI_TENANCY
OCI_REGION=OCI_REGION
OCI_BUCKET_NAME=OCI_BUCKET_NAME
OCI_CREDENTIALS=OCI_CREDENTIALS
OCI_NAMESPACE=OCI_NAMESPACE
  1. Then project dependencies and a virtual environment can be created using :
pipenv install --dev
  1. To activate the virtual environment run :
    pipenv shell
  1. Install the pre-commit hooks for the repository :
pre-commit install

Deploying to OpenShift

The nise-populator runs as a CronJob on OpenShift creating data daily. You can deploy it to OpenShift as follows:

  1. Login to OpenShift
oc login
  1. Select your project
oc project koku
  1. Copy openshift/example.parameters.properties into a openshift/parameters.properties
  2. Update the values within openshift/parameters.properties
  3. Create OpenShift resources
oc process --param-file openshift/parameters.properties  -f openshift/ |  oc create -f -

Note: Delete OpenShift resources with the following command:

oc process --param-file openshift/parameters.properties  -f openshift/ |  oc delete -f -