Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alvinwan/piipod
staff and event management, with Google calendar sync
https://github.com/alvinwan/piipod
Last synced: about 2 months ago
JSON representation
staff and event management, with Google calendar sync
- Host: GitHub
- URL: https://github.com/alvinwan/piipod
- Owner: alvinwan
- License: apache-2.0
- Created: 2016-01-12T22:56:11.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2020-10-27T20:54:48.000Z (about 4 years ago)
- Last Synced: 2024-10-12T13:44:46.831Z (3 months ago)
- Language: Python
- Homepage: http://piipod.herokuapp.com
- Size: 269 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# [Piipod](http://piipod.com)
Staff and event management, with Google calendar sync and a one-click Google sign in; used at [TEDxBerkeley](http://tedxberkeley.piipod.com) to manage 230 volunteers, now being used to manage ~150 staff members across 2 courses - [CS61B](http://cs61b.piipod.com), [CS70](http://staff.eecs70.org) - at UC Berkeley.created by [Alvin Wan](http://alvinwan.com), Spring 2016
To get started, see [piipod.com](http://piipod.com)
## Features
**Google Login**
One-click login and registration for ease-of-use**Staff Approval**
Add staff emails to the whitelist to auto-promote staff.**Google Calendar Sync**
One-click synchronization to load events from Google calendar.Automatic Waitlist Resolution:
- **Constraint Satisifaction Problem Model** allows staff to setup event signup minimum or maximum, per-user signups maximum or minimum for a group of events.
- **Stable Marriage Algorithm** allows staff to accept waitlisted users based on user preferences.**Batch Processing and Filtering**
Allows you to auto-categorize signups, process multiple events at once, and/or filter by signup properties. Categories can be shifts, tasks, or anything else representable with a string.## Installation
> These instructions assume the mySQL server has been started. See MySQL below.
### Dependencies
Check that Python3 and MySQL are installed using `make check`.
### Getting Started
1. Run the installation using `make install`.
- Optionally, use `make install CONDA=false` instead, to use `virtualenv`.
1. Add valid mysql user credentials to `configvars.py`.
1. Create the database using `make db`.> If the bash scripts do not work, see the Details section below for an outline
of what each script does.During development, you may additionally want to remember the following:
- In the future, use `source manage.sh activate` to activate the virtual environment. If installed without Anaconda, use `source manage.sh activate CONDA=false`
- Any model modifications, in the **development** environment, should be
followed by `make refresh`, which will **delete** the old database and replace
it with a new one.### Unix and Mac OSX Details
In case the installation script fails, you may execute the contents of the
installation bash script line by line:1. Setup a new virtual environment: `conda create -n piipod python=3.4`.
1. Start the virtual environment: `source activate piipod`.
1. Install all requirements: `pip install -r requirements.txt`.
1. Make a new configuration file: `cp sampleconfigvars.py configvars.py`.
1. Add valid MySQL user credentials to `configvars.py`.
1. Create the database: `python3 run.py -db create'`.Any model modifications should be followed by the following, which will
**delete** the old database and replace it with a new one: `python3 run.py -db refresh`### Windows Details
Because of incompatbility issues with the makefile, on Windows you will have to manually run the installation instructions.
1. Setup a new virtual environment by calling `python -m virtualenv env`.
1. Start the virtual environment by calling `env/Scripts/activate.bat` in cmd.
1. Install all requirements `pip install -r requirements.txt`.
1. Make a new configuration file: `cp sampleconfigvars.py configvars.py`.
1. Add valid MySQL user credentials to `configvars.py`.
1. Start the MySQL service using services.msc
1. Create the database by using `mysql -u root -p`, then entering `create database queue;` in the interactive prompt.
1. Setup the database using `python3 run.py -db create`.## Launch
Use `make run`.
> If the bash script does not work, see the Details section below for an outline
of `make run`.### Unix and Mac OSX Details
1. Start the virtual environment: `source env/bin/activate`.
1. Launch server: `python3 run.py`.### Windows Details
1. Start the virtual environment by calling `env/Scripts/activate.bat` in cmd.
1. Launch server: `python run.py`.## MySQL
- For Mac OSX installations of MySQL, via Brew, start the server using
`mysql.server start`. For other Linux-based operating systems, use
`sudo service mysql start`.
- For Windows, just start the server using `services.msc`.