1
0
Fork 0
This repository has been archived on 2023-03-27. You can view files and clone it, but cannot push or open issues or pull requests.
lpr-partynest/README.md

99 lines
2.4 KiB
Markdown
Raw Normal View History

2018-11-22 14:35:04 -05:00
Partynest
=========
2018-11-28 09:43:05 -05:00
2018-12-05 17:09:34 -05:00
[![Build Status](https://travis-ci.org/libertarian-party/partynest.svg?branch=master)](https://travis-ci.org/libertarian-party/partynest)
2018-12-05 17:32:07 -05:00
[![Coverage Status](https://coveralls.io/repos/github/libertarian-party/partynest/badge.svg?branch=master)](https://coveralls.io/github/libertarian-party/partynest?branch=master)
2018-12-05 17:09:34 -05:00
[![Maintainability](https://api.codeclimate.com/v1/badges/974d97f03895453189e1/maintainability)](https://codeclimate.com/github/libertarian-party/partynest/maintainability)
2018-12-05 17:49:04 -05:00
[![Test Coverage](https://api.codeclimate.com/v1/badges/974d97f03895453189e1/test_coverage)](https://codeclimate.com/github/libertarian-party/partynest/test_coverage)
2018-12-05 17:09:34 -05:00
[![Inline docs](http://inch-ci.org/github/libertarian-party/partynest.svg?branch=master)](http://inch-ci.org/github/libertarian-party/partynest)
2018-12-05 18:04:51 -05:00
A web application to manage political party members and supporters.
2018-12-05 14:52:50 -05:00
Table of contents
-----------------
* [Overview](#partynest)
* [Table of contents](#table-of-contents)
2018-12-05 15:31:14 -05:00
* [Deploy](#deploy)
Deploy
------
Tested with **Ubuntu Server 18.04 LTS**.
### System packages
* `build-essential`
* `bundler`
* `liblzma-dev`
* `libpq-dev`
* `nodejs`
* `npm`
* `patch`
* `ruby`
* `ruby-dev`
* `rubygems-integration`
* `zlib1g-dev`
### Steps
* Create directory `/var/www/partynest/` writable by deploy user
* Copy file `config/master.key` to `/var/www/partynest/shared/config/`
* Create PostgreSQL role `partynest` with password `password`
* Create PostgreSQL database `partynest_production` owned by `partynest`
2018-12-05 16:28:51 -05:00
2018-12-07 08:53:10 -05:00
### Example systemd services
2018-12-05 16:28:51 -05:00
2018-12-07 08:53:10 -05:00
Replace `user` with the name of user and `group` with the name of group
which you want an application to run as.
#### Web server
2018-12-05 16:28:51 -05:00
```
[Unit]
2018-12-07 08:53:10 -05:00
After=syslog.target network.target
2018-12-05 16:28:51 -05:00
Description=Partynest web server
[Service]
ExecStart=/usr/bin/bundle exec rails server --environment production
2018-12-07 08:53:10 -05:00
Group=group
Restart=on-failure
RestartSec=1
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=partynest-web
Type=simple
User=user
WorkingDirectory=/var/www/partynest/current
[Install]
WantedBy=multi-user.target
```
#### Job processing
```
[Unit]
After=syslog.target network.target
Description=Partynest job processing
[Service]
ExecStart=/usr/bin/bundle exec sidekiq --environment production
Group=group
Restart=on-failure
RestartSec=1
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=partynest-worker
2018-12-05 16:28:51 -05:00
Type=simple
User=user
WorkingDirectory=/var/www/partynest/current
[Install]
WantedBy=multi-user.target
```