X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=fabfile.py;h=90fa97732dfbb8a4518e3d40b52008b52ca36ad7;hb=09f84052976f6a31a882f99bfc04ec704ff9d69b;hp=2ba37d334382c4a647d61f28fcf3699fd19e98da;hpb=bff105aac3e1f6dd25ad7786c38e773d06e55047;p=oweals%2Fkarmaworld.git diff --git a/fabfile.py b/fabfile.py old mode 100644 new mode 100755 index 2ba37d3..90fa977 --- a/fabfile.py +++ b/fabfile.py @@ -1,28 +1,17 @@ """Management utilities.""" +import os +from contextlib import contextmanager as _contextmanager from fabric.contrib.console import confirm -from fabric.api import abort, env, local, settings, task +from fabric.api import abort, cd, env, local, prefix, run, settings, task ########## GLOBALS -env.run = 'heroku run python manage.py' -HEROKU_ADDONS = ( - 'cloudamqp:lemur', - 'heroku-postgresql:dev', - 'scheduler:standard', - 'memcache:5mb', - 'newrelic:standard', - 'pgbackups:auto-month', - 'sentry:developer', -) -HEROKU_CONFIGS = ( - 'DJANGO_SETTINGS_MODULE=karmaworld.settings.prod', - 'SECRET_KEY=(s1k!&^7l28k&nrm2ek(qqo&19%y(zn#=^zq_*ur2@irjun0x4' - 'AWS_ACCESS_KEY_ID=xxx', - 'AWS_SECRET_ACCESS_KEY=xxx', - 'AWS_STORAGE_BUCKET_NAME=xxx', -) +env.proj_repo = 'git@github.com:FinalsClub/karmaworld.git' +env.virtualenv = 'venv-kw' +env.activate = 'workon %s' % env.virtualenv +env.run = './manage.py' ########## END GLOBALS @@ -48,8 +37,40 @@ def cont(cmd, message): if message and result.failed and not confirm(message): abort('Stopped execution per user request.') + + +@_contextmanager +def _virtualenv(): + """ + Changes to the proj_dir and activates the virtualenv + """ + with cd(env.proj_dir): + with prefix(env.activate): + yield + ########## END HELPERS +########## ENVIRONMENTS +def beta(): + """ + Beta connection information + """ + env.user = 'djkarma' + env.hosts = ['beta.karmanotes.org'] + env.proj_root = '/var/www/karmaworld' + env.proj_dir = os.path.join(env.proj_root, 'karmaworld') + + +def prod(): + """ + Production connection information + """ + env.user = 'djkarma' + env.hosts = ['karmanotes.org'] + env.proj_root = '/var/www/karmaworld' + env.proj_dir = os.path.join(env.proj_root, 'karmaworld') +########## END ENVIRONMENTS + ########## DATABASE MANAGEMENT @task @@ -80,44 +101,55 @@ def collectstatic(): ########## END FILE MANAGEMENT -########## HEROKU MANAGEMENT -@task -def bootstrap(): - """Bootstrap your new application with Heroku, preparing it for a production - deployment. This will: +########## COMMANDS - - Create a new Heroku application. - - Install all ``HEROKU_ADDONS``. - - Sync the database. - - Apply all database migrations. - - Initialize New Relic's monitoring add-on. +def make_virtualenv(): """ - cont('heroku create', "Couldn't create the Heroku app, continue anyway?") + Creates a virtualenv on the remote host + """ + run('mkvirtualenv %s' % env.virtualenv) - for addon in HEROKU_ADDONS: - cont('heroku addons:add %s' % addon, - "Couldn't add %s to your Heroku app, continue anyway?" % addon) - for config in HEROKU_CONFIGS: - cont('heroku config:add %s' % config, - "Couldn't add %s to your Heroku app, continue anyway?" % config) +def update_reqs(): + """ + Makes sure all packages listed in requirements are installed + """ + with _virtualenv(): + with cd(env.proj_dir): + run('pip install -r requirements/production.pip') - cont('git push heroku master', - "Couldn't push your application to Heroku, continue anyway?") - syncdb() - migrate() +def clone(): + """ + Clones the project from the central repository + """ + run('git clone %s %s' % (env.proj_repo, env.proj_dir)) - cont('%(run)s newrelic-admin validate-config - stdout' % env, - "Couldn't initialize New Relic, continue anyway?") +def update_code(): + """ + Pulls the latest changes from the central repository + """ + with cd(env.proj_dir): + run('git pull') -@task -def destroy(): - """Destroy this Heroku application. Wipe it from existance. - .. note:: - This really will completely destroy your application. Think twice. +def deploy(): """ - local('heroku apps:destroy') -########## END HEROKU MANAGEMENT + Creates or updates the project, runs migrations, installs dependencies. + """ + first_deploy = False + with settings(warn_only=True): + if run('test -d %s' % env.proj_dir).failed: + # first_deploy var is for initial deploy information + first_deploy = True + clone() + if run('test -d $WORKON_HOME/%s' % env.virtualenv).failed: + make_virtualenv() + + update_code() + update_reqs() + syncdb() + #TODO: run gunicorn + #restart_uwsgi() +########## END COMMANDS