Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fecgov/fec-cms

The content management system (CMS) for the new Federal Election Commission website.
https://github.com/fecgov/fec-cms

Last synced: 2 months ago
JSON representation

The content management system (CMS) for the new Federal Election Commission website.

Awesome Lists containing this project

README

        

**Develop**
[![CircleCI](https://circleci.com/gh/fecgov/fec-cms.svg?style=svg)](https://circleci.com/gh/fecgov/fec-cms)
[![Test Coverage](https://img.shields.io/codecov/c/github/fecgov/fec-cms/develop.svg)](https://codecov.io/github/fecgov/fec-cms)
**package.json**
[![[Known Vulnerabilities]](https://snyk.io/test/github/fecgov/fec-cms/badge.svg)](https://snyk.io/test/github/fecgov/fec-cms?targetFile=package.json)
**requirements.txt**
[![[Known Vulnerabilities]](https://snyk.io/test/github/fecgov/fec-cms/badge.svg)](https://snyk.io/test/github/fecgov/fec-cms?targetFile=requirements.txt)

**Master**
[![Test Coverage](https://img.shields.io/codecov/c/github/fecgov/fec-cms/master.svg)](https://codecov.io/github/fecgov/fec-cms)

## Campaign finance for everyone
The Federal Election Commission (FEC) releases information to the public about
money that’s raised and spent in federal elections—that’s elections for US
President, Senate, and House of Representatives.

Are you interested in seeing how much money a candidate raised? Or spent? How
much debt they took on? Who contributed to their campaign? The FEC is the
authoritative source for that information.

The new FEC.gov aims to make campaign finance information more accessible (and understandable) to all users.

## FEC repositories
We welcome you to explore, make suggestions, and contribute to our code.

This repository, fec-cms, houses the content management system (CMS) for FEC.gov.

- [FEC](https://github.com/fecgov/fec): a general discussion forum. We compile
[feedback](https://github.com/fecgov/fec/issues) from the FEC.gov feedback widget
here, and this is the best place to submit general feedback.
- [openFEC](https://github.com/fecgov/openfec): the first RESTful API for the Federal Election Commission
- [fec-cms](https://github.com/fecgov/fec-cms): the content management system
(CMS) for FEC.gov. This project uses [Wagtail](https://github.com/torchbox/wagtail), an open source CMS written
in Python and built on the Django framework.
- [fec-eregs](https://github.com/fecgov/fec-eregs): the FEC’s Code of Federal Regulations explorer
- [fec-proxy](https://github.com/fecgov/fec-proxy): the proxy application to manage and route requests coming to the FEC.gov site
- [fec-infrastructure](https://github.com/fecgov/fec-infrastructure): manages the gov cloud RDS instances

## Get involved
We’re thrilled you want to get involved!
- Read our contributing
[guidelines](https://github.com/fecgov/openfec/blob/master/CONTRIBUTING.md).
Then, file an [issue](https://github.com/fecgov/fec/issues) or submit a pull
request.
- Send us an email at [email protected].
- If you're a developer, follow the installation instructions in the
README.md page of each repository to run the apps on your computer.

## Set up
We are always trying to improve our documentation. If you have suggestions or
run into problems please
[file an issue](https://github.com/fecgov/fec-cms/issues)!

### Project prerequisites
1. Ensure you have the following requirements installed:

* Python (the latest 3.10 release, which includes `pip` and and a built-in version of `virtualenv` called `venv`).
* The latest long term support (LTS) or stable release of Node.js (which
includes `npm`).
* PostgreSQL (the latest 15 release).
* Read a [Mac OSX tutorial](https://www.moncefbelyamani.com/how-to-install-postgresql-on-a-mac-with-homebrew-and-lunchy/).
* Read a [Windows tutorial](https://www.postgresqltutorial.com/install-postgresql/).
* Read a [Linux tutorial](https://www.postgresql.org/docs/13/installation.html)
(or follow your OS package manager).

2. Set up your Node environment — learn how to do this with 18F’s
[Javascript Ecosystem Guide](https://github.com/18F/dev-environment-standardization/blob/18f-pages/pages/languages/javascript.md).

3. Set up your Python environment — learn how to do this with 18F’s
[Python Ecosystem Guide](https://github.com/18F/dev-environment-standardization/blob/18f-pages/pages/languages/python.md).

4. Clone this repository.

### Install project dependencies
Use `pip` to install the Python dependencies:

```bash
pip install -r requirements.txt
pip install -r requirements-dev.txt
```

Use `npm` to install JavaScript dependencies:

```bash
npm install
```

### Give default user privileges to create database
If you would like your default user to create the database, alter their user role:
```bash
sudo su - postgres
psql
alter user [default_username] createdb;
\q
exit
```

### Create local databases
Before you can run this project locally, you'll need a development database:

```bash
createdb cfdm_cms_test
```

##### Load our sample data into the local development database:
For details see the section below: Restoring your local database from a backup

### Set environment variables
You will also need to set the environment variables:

#### Set local environment variables
Connection string for the local database as an
environment variable:

```bash
export DATABASE_URL=postgresql://:@/cfdm_cms_test
```

#### running with openFEC API
By default, `FEC_API_URL` points to the local running instance of the API (http://localhost:5000).
To set the URL for the API as an environment variable, run:

```bash
export FEC_API_URL=http://localhost:5000
```

Set it to either production, dev, or staging API URLs if you are not running the API locally.

for example: (prod API) https://api.open.fec.gov
export FEC_API_URL=https://api.open.fec.gov

The base settings file will read this value in instead of using the default (which is `http://localhost:5000`).

Also set API keys: `FEC_WEB_API_KEY_PRIVATE` and `FEC_WEB_API_KEY_PUBLIC`

### Finish project setup
Once all prerequisites and dependencies are installed, you can finish the
project setup by running these commands:

```bash
npm run build
cd fec/
./manage.py migrate
./manage.py createsuperuser
```

## Running the application
In the root project folder, run:

```bash
cd fec/
./manage.py runserver
```

## Front End Development
Front end assets are all located in `/fec/fec/static/*`.

### Icon building
Icons only need to be built if there are new SVG files in the `/fec/fec/static/icons/input` directory, which transforms that SVG file into a SCSS variable to be used on the stylesheets.

``` npm run build-icons ```

### SCSS compilation
``` npm run build-sass ```

### JavaScript compilation
``` npm run build-js ```

### Compilation of both SCSS and JS files
``` npm run build ```

### Command to watch for SCSS and JS changes
``` npm run watch ```

## Running tests
There are two kinds of tests that you can run with the project, Python tests and JavaScript tests.

To run the JavaScript tests, run this command in the root project directory:

```bash
npm run test-single
```

*Note: You may be prompted to allow `node` to accept connections; this is okay and required for the tests to run.*

To run the Python tests, run this command in the root project directory:

```bash
pytest
```

It’s necessary to specify the Postgresql URL, which can be done on the
command line, e.g.:

```bash
env DATABASE_URL=postgresql://:@/cfdm_cms_test pytest
```

`pytest` is configured to report test coverage automatically.

## Enabling/toggling features
[settings/base.py](https://github.com/fecgov/fec-cms/blob/develop/fec/fec/settings/base.py)
includes a set of `FEATURES` which can also be enabled using environment flags:

```bash
FEC_FEATURE_LEGAL=1 python fec/manage.py runserver
```

## Additional local development instructions

### Watch for static asset changes
To watch for changes to JavaScript files, run this command in the root project directory:

```bash
npm run watch
```

### Restoring your local database from a backup
*Likely only useful for FEC team members*

### Load our sample data into the local development database from a production backup

first download the web app sample database dump

*FEC team can download from the project’s google drive folder: CMS DB Backups*

then save the file to a local drive:

then run this command:

`pg_restore --dbname cfdm_cms_test --no-acl --no-owner `

Lastly run migrations to account for any very recent changes that are not present in the latest backup
run this command:
`./manage.py migrate`

### Generating code.json

Code.gov uses the code.json file located at fec.gov/code.json to inventory our repositories. The file is generated using [LLNL’s scraper tool](https://github.com/LLNL/scraper). Follow the instructions in scraper’s README file to generate a new code.json, or manually update as needed.

Scraper config file is in the root directory.

```
scraper --config code-gov-config.json
```

Examples of code.json files: https://github.com/GSA/code-gov/blob/master/METADATA_EXAMPLES.md

## Deploy
*Likely only useful for FEC team members*

We use CircleCI for automated deploys after tests pass. If you want to deploy something it is much better to push an empty commit with a tag than doing a manual deploy.

If there is a problem with CircleCI and something needs to be deployed, you can do so with the following commands. Though, you will need to pull the environment variables from the space you are deploying to and remake your static assets. That will ensure things like the links are correct. You will also want to clear your dist/ directory. That way, you will not exceed the alloted space.

Before deploying, install version 7 of the
[Cloud Foundry CLI](https://docs.cloudfoundry.org/devguide/cf-cli/install-go-cli.html):

Provision development database:

```bash
cf create-service rds micro-psql fec-rds-stage
```

Provision credentials service:

```bash
cf cups cms-creds-dev -p '{"DJANGO_SECRET_KEY": "..."}'
```

To deploy to Cloud Foundry, run `invoke deploy`. The `deploy` task will
attempt to detect the appropriate Cloud Foundry space based the current
branch; to override, pass the optional `--space` flag:

```bash
invoke deploy --space feature
```

The `deploy` task will use the `FEC_CF_USERNAME` and `FEC_CF_PASSWORD`
environment variables to log in. If these variables are not provided, you
will be prompted for your Cloud Foundry credentials.

Deploys of a single app can be performed manually by targeting the env/space,
and specifying the corresponding manifest, as well as the app you want, like
so:

```bash
cf target -s [feature|dev|stage|prod] && cf push -f manifest_<[feature|dev|stage|prod]>.yml [api|cms]
```

**NOTE:** Performing a deploy in this manner will result in a brief period of
downtime.

### A note about deploying to the `feature` space
As noted above, you can manually deploy the application if you specify the space you want to deploy to, e.g., `invoke deploy --space feature`.

In the case of the `feature` space, there are a few things to note:

* To deploy to the feature space, an automated deployer account has been set up. To trigger, go to the `tasks.py` file `DEPLOY_RULES` [here](https://github.com/fecgov/fec-cms/blob/784e6540cfcec58e6e763fa711de19cdcb475bb7/tasks.py#L74).
* Only the CMS app is setup and configured for the `feature` space; it points to the `dev` space for all other things (e.g., the API).
* The CMS in the `feature` space has its own database that has been loaded with data from a production backup; this data can be refreshed in the future using the same steps outlined in the Wiki.
* The `feature` space has its own S3 bucket for content.

## SSH
*Likely only useful for FEC team members*

You can SSH directly into the running app container to help troubleshoot or inspect things with the instance(s). Run the following command:

```bash
cf ssh
```

Where ** is the name of the application instance you want to connect to. Once you are logged into the remote secure shell, you'll also want to run this command to setup the shell environment correctly:

```bash
. /home/vcap/app/bin/cf_env_setup.sh
```

More information about using SSH with cloud.dov can be found in the [cloud.gov SSH documentation](https://cloud.gov/docs/apps/using-ssh/#cf-ssh).

## Accounts
Accounts are handled in the cms admin. All accounts will be reviewed annually.

## Licensing and attribution
A few parts of this project are not in the public domain. Attribution and licensing information for those parts are described in detail in [LICENSE.md](LICENSE.md).

The rest of this project is in the worldwide public domain, released under the [CC0 1.0 Universal public domain dedication](https://creativecommons.org/publicdomain/zero/1.0/). Read more in [LICENSE.md](LICENSE.md).

A few restrictions limit the way you can use FEC data. For example, you can't
use contributor lists for commercial purposes or to solicit donations. Learn
more on [FEC.gov](https://www.FEC.gov).