Courseflow ========== Courseflow lets students participate in online activities. Each such activity is called a "flow". It flows over a couple of pages, each of which can be, say, a video, a quiz question, a page of text, or, within the confines of HTML, something completely different. Courseflow is set apart by the following features: * Emphasizes ease of authoring, using `YAML `_, `Markdown `_ and Python. See `example content `_. * Versioning of content through deep integration with `git `_. Instructors can preview newly-authored content while students work with prior versions, all from the same instance of Courseflow. Installation ------------ Courseflow is written using `Django `_ in Python 2.7. (Optional) Make a virtualenv to install to:: virtualenv --system-site-packages my-courseflow-env source my-courseflow-env/bin/activate To install, clone the repository:: git clone git://github.com/inducer/courseflow Clone the sample content (into the same directory as courseflow):: git clone git://github.com/inducer/courseflow-sample Enter the courseflow directory:: cd courseflow Install the dependencies:: pip install -r requirements.txt Copy (and, optionally, edit) the example configuration:: cp local_settings.py.example local_settings.py vi local_settings.py Initialize the database:: python manage.py migrate python manage.py changepassword $(whoami) Run the server:: python manage.py runserver Open a browser to http://localhost:8000. FIXME: Test/unfinshed