Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/peer/mind
Decide together.
https://github.com/peer/mind
decision-making delegation democracy meteor voting
Last synced: 3 months ago
JSON representation
Decide together.
- Host: GitHub
- URL: https://github.com/peer/mind
- Owner: peer
- License: other
- Created: 2015-10-20T04:53:22.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2020-08-20T15:12:11.000Z (over 4 years ago)
- Last Synced: 2024-08-01T12:19:45.627Z (6 months ago)
- Topics: decision-making, delegation, democracy, meteor, voting
- Language: CoffeeScript
- Homepage: http://peermind.org
- Size: 1.2 MB
- Stars: 57
- Watchers: 9
- Forks: 12
- Open Issues: 172
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.md
- Contributing: CONTRIBUTING.md
- License: COPYING
Awesome Lists containing this project
- awesome-starred - peer/mind - Decide together. (others)
README
# PeerMind #
The goal of this application is to improve how we do group decision making in our communities.
Instead of just digitizing current voting practices and moving them online, without much added value,
this project aims to explore and improve technologies we use for decision making. Some current ideas:
* support for communities which meet offline, but want to use online tools to augment their decision making
* tools for better facilitation of discussions
* score voting for better multiple-choices decision making
* dynamic statistical quorum
* vote delegation
* visual feedback on decision making process and progressThe project is in early stages. Consider it a beta/prototype. Any feedback is welcome.
You can use it but keep in mind that it has not yet been security audited so you should
probably not use it for sensitive or critical decisions and where privacy of data and votes is
important.## Development ##
The application uses [Meteor](https://www.meteor.com/) web framework. Install it:
```bash
curl https://install.meteor.com/ | sh
```Clone the repository:
```bash
git clone --recursive https://github.com/peer/mind.git
```Run it:
```bash
meteor
```And open [http://localhost:3000/](http://localhost:3000/).
Currently you will have to manually create accounts using `meteor shell`:
```javascript
var userId = Package['accounts-base'].Accounts.createUser({username: 'admin', password: 'password'});
Package['alanning:roles'].Roles.addUsersToRoles(userId, ['admin', 'moderator', 'manager', 'member']);
```Furthermore, currently the app has hard-coded four user roles with hard-coded permissions for them:
* `member`s can add discussion items, add comments to them, propose motions, upvote content, and vote on motions
* `moderator`s can make points, and edit content of others
* `manager`s can add discussion items, comment, and propose motions
* `admin`s can manage user accounts
* `guest`s can commentAfter you have created an admin account, you can invite new users into the app. They will get an
e-mail with instructions how to setup their password. To invite a user, run the following function
in your browser's web console:```javascript
Meteor.call('User.invite', '[email protected]', 'name', console.log.bind(console));
```Invited users initially do not belong to any role. Currently this means that effectively they cannot do anything
in the app without being added to at least one role. To add them to a role, you can use an admin interface at
[http://localhost:3000/admin/accounts](http://localhost:3000/admin/accounts).### Used technologies ###
The application is built on top of many other technologies and Meteor packages:
* [Blaze](https://guide.meteor.com/blaze.html) for rendering HTML through [Blaze Components](http://components.meteorapp.com/) abstraction.
* [MongoDB](https://www.mongodb.com/) through [PeerDB](https://github.com/peerlibrary/meteor-peerdb) abstraction.
* [CoffeeScript](http://coffeescript.org/).
* [Material Design](https://material.google.com/) through [Materialize](http://materializecss.com/).
* [job-collection](https://github.com/vsivsi/meteor-job-collection/) for background tasks through [Classy Job](https://github.com/peerlibrary/meteor-classy-job) abstraction.## Running ##
To run the application in production you can use [Docker](https://www.docker.com/).
The application is provided as [peermind/peermind](https://hub.docker.com/r/peermind/peermind/) Docker image.
It is based on [tozd/meteor](https://hub.docker.com/r/tozd/meteor/) image for Meteor applications.
[tozd/meteor-mongodb](https://hub.docker.com/r/tozd/meteor-mongodb/) image is recommended for MongoDB because
it creates necessary Meteor MongoDB database configuration automatically.You can see [`run.sh`](https://github.com/peer/mind/blob/master/run.sh) file for an example how to run it.
**You have to adapt the script for your installation.** It contains hard-coded values for another installation.The application is a regular Meteor application, so you can
[consider also other ways to deploy and run Meteor applications](https://guide.meteor.com/deployment.html).## Related projects ##
* https://www.loomio.org/
* http://democracy.earth/
* https://airesis.eu/
* https://consider.it/
* https://decidim.org/