ThinkUp.com's member and installation management system.
Upstart doesn't have ThinkUp's easy web-based installer, but its innards are very similar. Here's how to get it installed locally.
- First, clone this repository:
$ git clone git@github.com:ThinkUpLLC/upstart.git
- Get the submodules. Upstart uses one, called Isosceles, a simple MVC framework extracted from ThinkUp. After you run this command, make sure there are files in
webapp/extlibs/isosceles/
.
$ git submodule init
$ git submodule update
-
Build the database tables. In your MySQL admin of choice, create an Upstart database and build the required tables using this file:
sql/build_db.sql
-
Symlink Upstart's webapp directory to a web-accessible folder on your local web server. On ThinkUp.com, that directory is currently
join
. So if you symlink webapp to join on localhost, you'd loadhttp://localhost/join/
in your browser. -
Create your base Isosceles config file. This file lives in the Isosceles directory. Copy over the sample using this command:
$ cp webapp/extlibs/isosceles/libs/config.sample.inc.php webapp/extlibs/isosceles/libs/config.inc.php
-
Fill in the config.inc.php file basic values from your setup, particularly site_root_path and db_name, db_user, and db_password. Upstarts datadir_path must be writable by the web server (for caching Smarty output).
-
Create your Upstart custom config file. Copy the sample using this command:
$ cp webapp/config.sample.inc.php webapp/config.inc.php
-
Fill in the config.inc.php file values from your setup.
There are two interfaces for Upstart: a user-facing area, and the internal admin area.
User-facing signup is what you see exposed on ThinkUp.com. It's the user flow which brings you through Amazon Payments, Twitter/Facebook authorization, and ThinkUp.com account creation. UPDATE: There's now a work-in-progress user area in the /user/ folder.
The internal admin area is located in the admin directory and allows us to browse, search and manage members who have signed up. If your Upstart installation is at http://localhost/join/
then you can see the admin interface at http://localhost/join/admin/
. There will be zero data in admin when you first install Upstart. To get test data in there, sign up via the user flow a few times using various email addresses. If you're using Gmail, you can add a +test to your email address to get multiple addresses, that is, ginatrapani+test1@gmail.com and ginatrapani+test2@gmail.com all go to ginatrapani@gmail.com but count as different accounts in Upstart, which enforces email address uniqueness. (With the amazon_sandbox config value set to true, you won't be actually authorizing ThinkUp to charge you for these authorizations. No actual money moves in the sandbox.)
If you see a red error that reads something like "Dispatch status: 15 running worker(s) found - NOT OK" - ignore it. Dispatch is our crawler queue system and it's currently not running while we're in development.
Grunt is a task-runner used to automate development, er, tasks. We use it for three things (right now):
- Convert LESS files to CSS
- Convert Coffeescript files to Javascript
- Inline styles in emails using Premailer
In order to compile, you need to have NodeJS and Ruby installed on your machine. This has been tested on a Mac, but should work on any machine that supports Ruby and Node. We'll cover installation below, but these are the required packages.
- grunt-cli
- grunt
- grunt-contrib-watch
- grunt-contrib-less
- grunt-contrib-coffee
- grunt-premailer
- hpricot
- premailer
-
If you haven't done so already, install NodeJS via homebrew Homebrew (brew install node) or their installer.
-
Assuming you have ruby on your system, install the two required gems with
gem install hpricot premailer
. -
Navigate to the root directory of your Upstart repo and run
npm install
. This should install all of the NodeJS modules we use in ThinkUp (the command installs everything inUpstart/package.json
). -
In order to run the inliner, you'll need the grunt command line interface, which must be installed gloablly. Install that with
npm install -g grunt-cli
.
If you want to run every command, just navigate to the root directory of the repository and run grunt
from your
command line. It’s more likely you’ll want to do something specific, so refer to the guides below.
HTML rendering in email clients is pretty poor, but it does pretty well if you use inline styles. Since it's a pain to write your CSS rules inline, we don’t; we use software.
The precompiled HTML email templates live at extras/dev/precompiled-emails/*.html
and are written to webapp/libs/view/_email.*.tpl
.
If you haven't already, install Grunt (see above).
- Make your changes to the precompiled template (location is listed above).
- Navigate to the root directory of your repository from the command line and run
grunt email
.
There are also two fancier options.
- Run
grunt email_dev
and it will create an *.html file in your webapp directory for testing in addition to rendering the Smarty template. - Run
grunt watch:email
orgrunt watch:email_dev
and it will automatically compile every time you save.
Now, your CSS styles should be precompiled. Good work!
Our styles and Javascript are written using LESS and Coffeescript, respectively. Sadly, browsers can’t read them, so we must convert. Here’s the easiest way to do that.
If you haven't already, install Grunt (see above).
- Navigate to the root directory of your repository and run
grunt coffee
orgrunt less
.
That’s it. Do you want the files to compile every time you save a .coffee or .less file? Run grunt watch
.