/snowdrift

Infrastructure for Snowdrift.coop

Primary LanguageJavaScriptGNU Affero General Public License v3.0AGPL-3.0

Snowdrift.coop

Snowdrift.coop is a non-profit, cooperative platform for funding Free/Libre/Open (FLO) works. Using a many-to-many matching pledge, we aim to empower the global community to better promote freedom-respecting projects of all sorts.

For the basic idea, see our illustrated intro.

Other pages on the site explain our mission and include discussion and research on issues like the economics of FLO projects, the incentives behind donations, how our model departs from that of the other 600+ donation-style crowdfunding sites, and more.

As a work in progress, we are still clarifying the details and adjusting our presentation.

Contributing

Our how-to-help page includes further notes about the site and info about volunteering (including in non-programming ways). We also have an in-progress, self-hosted ticket system.

Snowdrift.coop is built in Haskell using the Yesod web framework, but even if you don't know any Haskell, you may still put your HTML/CSS/Javascript skills to work! We welcome contributions from developers of all skill levels.

Whatever your background, we're happy to answer questions or get any comments. Hop on #snowdrift on freenode.net, and say hello!

Essential build instructions

Note: our code is mirrored at GitHub (which is popular but proprietary) and Gitorious (which is FLO, licensed AGPL, but less popular).

You really should read our full guide to our code which has step-by-step instructions that even a true beginner can follow. It also contains links for learning Haskell, comments about our development methods, and more.

But for those experienced with Git, Haskell, PostgreSQL, and perhaps even Yesod, here's quick and dirty minimal instructions to get started:

// Install any dependencies you don't have:
// GHC **7.8.3** (7.8.2 should be ok), cabal, PostgreSQL, zlib1g-dev, libpq-dev, happy, alex, llvm
// update cabal, set PATH, etc. — see GUIDE.md for more detailed instructions

// Fork, clone and install
git clone [your remote address, e.g. git@gitorious.org:snowdrift/yourusername-snowdrift.git]
cd snowdrift
cabal sandbox init
cabal install --enable-tests

// Set up the database with our quick script.
// To understand what the script does or to run the commands manually, see GUIDE.md
sdm init

// Launch the development site
Snowdrift Development

// To see the live site, point your browser to localhost:3000

//To rebuild after making changes run
cabal install

// For fast, automatic rebuilding whenever you change the code, install the yesod-bin package
cabal install yesod-bin
// then instead of "Snowdrift Development" run the site with
yesod devel
// which can be left running in a terminal while working elsewhere

Read through GUIDE.md for thorough details and more about development, testing, and so on.