Skip to content
Ben Cipollini edited this page Mar 25, 2014 · 10 revisions

KA Lite is a medium-size project, so keeping a well-defined structure is essential to making it understandable.

Below is an outline of the directory structure for the project, as well as how apps are currently structured.

Directories

The KA Lite project has the following subdirectories:

Code

  • kalite - Django apps we've created or downloaded and modified for the ka lite projects
  • python-packages - Django apps and Python package dependencies for apps within kalite
  • scripts - OS-specific scripts for starting/stopping server (and other similar tasks)

Resources

  • content - contains video files and video preview images
  • data - private json data files the server uses
  • docs - .md files for developers and KA Lite users
  • locale - contains translations that are downloaded via language pack updates

Apps

KA Lite created / modified apps

Distributed server-specific - only used on the installable KA Lite server

  • chronograph - Like UNIX cron: runs jobs (Django management commands), keeps logs
  • config - generic app for setting server config options in the database
  • django_cherrypy_wsgiserver - wrapper around cherrypy for use in Django
  • khanload - code and commands for downloading Khan Academy's topic tree and user data
  • updates - sister app of chronograph; updates job status from back-end management commands to the front-end UI

Shared - Shared between both technologies

  • coachreports - graphical displays of student progress
  • control_panel - summaries of all data (usage and syncing)
  • i18n - tools for implementing language packs, including interface translations, subtitles, and dubbed videos
  • main - main website and student progress recording
  • securesync - engine for syncing data, as well as defining users
  • tests - framework for functional and performance testing
  • utils - app-independent utilities (could be shared with the world!)

Central server-specific - only used on our online website and central data repository

  • central - main KA Lite website
  • contact - contact form
  • faq - FAQ page
  • registration - user registration and sign-in
  • stats - summaries of data shared centrally.

Library apps

These are located in the python-packages directory.

True libraries - usually get via sudo apt-get, but we download and ship for offline completeness

  • cherrypy
  • collections
  • django
  • httplib2
  • pytz
  • requests
  • rsa
  • selenium
  • south

External helpers - Collected from around the web, we use this code without modification. ** NOTE **: many of these may belong to "true libraries" above.

  • annoying
  • dateutil
  • debug_toolbar
  • decorator
  • django_extensions
  • django_snippets
  • git
  • ifcfg
  • iso8601
  • khanacademy
  • memory_profiler
  • mplayer
  • oauth
  • pbkdf2
  • polib
  • postmark
  • pyasn1
  • werkzeug

Internal helpers - Other projects we authored, but that is used without modification here.

  • playground

App file structure

Apps are now self-contained entities with as few inter-app and global project dependencies as possible.

Files

  • Each app contains relevant standard Django files (forms.py, models.py, views.py, urls.py)
  • Some apps have both HTML views as well as API/JSON views. These are defined by api_xxx.py files, such as api_views.py, api_urls.py, etc.
  • Any shared functions across the app/module with other apps should be defined within the __init__.py file
  • App-specific settings should be put inside the app's settings.py file. This includes required middleware and context processors.
  • App-related template files should be put inside the {app}/templates/{app}/ folder (or any subfolders), and referenced as {app}/template.html from view functions.
  • App-related static files should be put inside the {app}/static/[css|images|js]/{app}/ folder, and referenced as {% static 'static/[css|images|js]/{app}/file.ext' %} from template files.
Clone this wiki locally