lockitron/selfstarter · GitHub

This repository

public  lockitron/selfstarter

HTTPS clone URL

You can clone with HTTPS, or Subversion.
Roll your own crowdfunding
 branch: master
/
notion image
authored 5 months ago
app
Update user.rb
5 months ago
Merge pull request #37 from steakknife/develop
6 months ago
documentation of the payment optoins component
8 months ago
Initial Commit
a year ago
Initial Commit
a year ago
Initial Commit
a year ago
Initial Commit
a year ago
Initial Commit
a year ago
made changes to Order model to reflect the fact that a site may use t…
8 months ago
Added html5 shiv so that the FAQ section will work in IE (it uses sem…
8 months ago
added an optional payment options section
8 months ago
added RSpec and Shoulda. Tested User
10 months ago
[security - heroku] ruby 1.9.2 -> 1.9.3
6 months ago
Updated amazon_flex_pay, fixing #44
6 months ago
Added MIT license
11 months ago
Initial Commit
a year ago
fixed formatting
8 months ago
Initial Commit
a year ago
Making it so that files will get gzipped. Because the heroku cedar st…
8 months ago
 README.md

Selfstarter

Selfstarter makes it easy to roll your own crowdfunding site. To get started, fork this repository and change around config/settings.yml to suit your needs.

Background

After a rejection from Kickstarter, we decided to follow in the footsteps of App.net and make our own crowdfunding site for Lockitron. We've been absolutely blown away by the response. As a first step in what will hopefully be a long history of giving back, we have decided to open source the crowdfunding platform that got us here. Please send questions, comments, or concerns to hello@lockitron.com!
Selfstarter is a starting point. We made some specific choices with Selfstarter for Lockitron and we recommend you tailor it for your project:
  • We use Amazon Payments for payments. You can use Stripe or WePay. We used Kickstarter's awesome amazon_flex_pay gem.
  • We collect multi-use tokens from customers with Amazon Payments - this let's us collect payment information without charging the customer until we are ready to ship
  • Selfstarter doesn't come with any authentication, administration, mailers or analytics tools. We recommend adding a basic set of these so that you can message backers and manage orders.
  • There is a payment options component that allows you to define different packages or levels for people to puchase/support at. You can turn it on and off with a configuration setting.

Getting Started

Note: This assumes you have Ruby 1.9.2 or later installed properly and have a basic working knowledge of how to use RubyGems
First you'll need to fork and clone this repo
git clone https://github.com/lockitron/selfstarter.git
Let's get all our dependencies setup:
bundle install --without production
Now let's create the database:
rake db:migrate
If you're using the payment options component (use_payment_options = true in settings.yml) then need to seed some data for the options:
rake db:seed
Let's get it running:
rails s

Customizing

While it is just a skeleton, we did make it a little quicker to change around things like your product name, the colors, pricing, etc.
To change around the product name, tweet text, and more, open this file:
config/settings.yml
To change around the colors and fonts, open this file:
app/assets/stylesheets/variables.css.scss
To dive into the code, open this file:
app/controllers/preorder_controller.rb

Deploying to Production

We recommend using Heroku, and we even include a Procfile for you. All you need to do is first install the Heroku Toolbelt and then run:
heroku creategit push heroku masterheroku run rake db:migrateheroku open

Contributing

In it's current state, Selfstarter is very skeletal. We welcome your pull requests. If you're looking to contribute, here are some good starting points.

Email Updates

Using Amazon FPS will send users a notification when they place an order, however, it's nice to notify people when they place an order.
Something that we built into Lockitron.com was "Remind Me" functionality. The idea behind this is that you can capture potential backers and notify them near the end of your campaign that they should reserve your product. We have no data on this yet, however, it seems to be part of why Kickstarter campaigns pick up a lot of steam in their final hours.

Reporting

There is no admin panel with Selfstarter. This could be useful when the project's funding time is over and you want to export your orders elsewhere.
Relatedly, some analytics would be nice. It'd be good to know how many reservations you receive over time, as well as the specifics of each order. Customers may have questions or might want to modify their order after they've placed it.

Alternate Payment Processors

Amazon Payments works great for us, but it may not work out for everyone. If you'd rather use Stripe, WePay, or any other payment processor, feel free to send out a pull request.

Tests

There aren't any tests yet. Tests are very welcome!
  • © 2013 GitHub, Inc.