Metadata-Version: 2.0
Name: cloudlaunch-server
Version: 2.0.2
Summary: CloudLaunch is a ReSTful, extensible Django app for discovering and launching applications on cloud, container, or local infrastructure
Home-page: https://github.com/galaxyproject/cloudlaunch
Author: Galaxy Project
Author-email: help@cloudve.org
License: MIT
Description-Content-Type: UNKNOWN
Keywords: cloudlaunch
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Framework :: Django
Classifier: Framework :: Django :: 2.0
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Topic :: Internet :: WWW/HTTP :: WSGI :: Application
Requires-Dist: Django (>=2.0)
Requires-Dist: celery (>=4.1)
Requires-Dist: django-celery-results (>=1.0.1)
Requires-Dist: django-celery-beat (>=1.1.0)
Requires-Dist: djangorestframework (>=3.7.3)
Requires-Dist: django-rest-auth (>=0.9.1)
Requires-Dist: django-allauth (>=0.34.0)
Requires-Dist: drf-nested-routers (>=0.90.0)
Requires-Dist: django-filter (>=1.1.0)
Requires-Dist: coreapi (>=2.2.3)
Requires-Dist: cloudbridge
Requires-Dist: djcloudbridge
Requires-Dist: django-model-utils
Requires-Dist: django-fernet-fields (>=0.5)
Requires-Dist: django-cors-headers (>=2.1.0)
Requires-Dist: django-nested-admin (>=3.0.21)
Requires-Dist: django-smart-selects (>=1.5.3)
Requires-Dist: django-countries (>=5.0)
Requires-Dist: bioblend
Requires-Dist: jsonmerge (>=1.4.0)
Requires-Dist: click
Provides-Extra: dev
Requires-Dist: redis; extra == 'dev'
Requires-Dist: sphinx (>=1.3.1); extra == 'dev'
Requires-Dist: bumpversion (>=0.5.3); extra == 'dev'
Requires-Dist: tox (>=2.9.1); extra == 'dev'
Requires-Dist: coverage (>=4.4.1); extra == 'dev'
Requires-Dist: flake8 (>=3.4.1); extra == 'dev'
Requires-Dist: flake8-import-order (>=0.13); extra == 'dev'
Requires-Dist: Django (>=2.0); extra == 'dev'
Requires-Dist: celery (>=4.1); extra == 'dev'
Requires-Dist: django-celery-results (>=1.0.1); extra == 'dev'
Requires-Dist: django-celery-beat (>=1.1.0); extra == 'dev'
Requires-Dist: djangorestframework (>=3.7.3); extra == 'dev'
Requires-Dist: django-rest-auth (>=0.9.1); extra == 'dev'
Requires-Dist: django-allauth (>=0.34.0); extra == 'dev'
Requires-Dist: drf-nested-routers (>=0.90.0); extra == 'dev'
Requires-Dist: django-filter (>=1.1.0); extra == 'dev'
Requires-Dist: coreapi (>=2.2.3); extra == 'dev'
Requires-Dist: cloudbridge; extra == 'dev'
Requires-Dist: djcloudbridge; extra == 'dev'
Requires-Dist: django-model-utils; extra == 'dev'
Requires-Dist: django-fernet-fields (>=0.5); extra == 'dev'
Requires-Dist: django-cors-headers (>=2.1.0); extra == 'dev'
Requires-Dist: django-nested-admin (>=3.0.21); extra == 'dev'
Requires-Dist: django-smart-selects (>=1.5.3); extra == 'dev'
Requires-Dist: django-countries (>=5.0); extra == 'dev'
Requires-Dist: bioblend; extra == 'dev'
Requires-Dist: jsonmerge (>=1.4.0); extra == 'dev'
Requires-Dist: click; extra == 'dev'
Provides-Extra: prod
Requires-Dist: psycopg2; extra == 'prod'
Requires-Dist: gunicorn; extra == 'prod'
Requires-Dist: Django (>=2.0); extra == 'prod'
Requires-Dist: celery (>=4.1); extra == 'prod'
Requires-Dist: django-celery-results (>=1.0.1); extra == 'prod'
Requires-Dist: django-celery-beat (>=1.1.0); extra == 'prod'
Requires-Dist: djangorestframework (>=3.7.3); extra == 'prod'
Requires-Dist: django-rest-auth (>=0.9.1); extra == 'prod'
Requires-Dist: django-allauth (>=0.34.0); extra == 'prod'
Requires-Dist: drf-nested-routers (>=0.90.0); extra == 'prod'
Requires-Dist: django-filter (>=1.1.0); extra == 'prod'
Requires-Dist: coreapi (>=2.2.3); extra == 'prod'
Requires-Dist: cloudbridge; extra == 'prod'
Requires-Dist: djcloudbridge; extra == 'prod'
Requires-Dist: django-model-utils; extra == 'prod'
Requires-Dist: django-fernet-fields (>=0.5); extra == 'prod'
Requires-Dist: django-cors-headers (>=2.1.0); extra == 'prod'
Requires-Dist: django-nested-admin (>=3.0.21); extra == 'prod'
Requires-Dist: django-smart-selects (>=1.5.3); extra == 'prod'
Requires-Dist: django-countries (>=5.0); extra == 'prod'
Requires-Dist: bioblend; extra == 'prod'
Requires-Dist: jsonmerge (>=1.4.0); extra == 'prod'
Requires-Dist: click; extra == 'prod'
Provides-Extra: test
Requires-Dist: tox (>=2.9.1); extra == 'test'
Requires-Dist: coverage (>=4.4.1); extra == 'test'
Requires-Dist: flake8 (>=3.4.1); extra == 'test'
Requires-Dist: flake8-import-order (>=0.13); extra == 'test'
Requires-Dist: Django (>=2.0); extra == 'test'
Requires-Dist: celery (>=4.1); extra == 'test'
Requires-Dist: django-celery-results (>=1.0.1); extra == 'test'
Requires-Dist: django-celery-beat (>=1.1.0); extra == 'test'
Requires-Dist: djangorestframework (>=3.7.3); extra == 'test'
Requires-Dist: django-rest-auth (>=0.9.1); extra == 'test'
Requires-Dist: django-allauth (>=0.34.0); extra == 'test'
Requires-Dist: drf-nested-routers (>=0.90.0); extra == 'test'
Requires-Dist: django-filter (>=1.1.0); extra == 'test'
Requires-Dist: coreapi (>=2.2.3); extra == 'test'
Requires-Dist: cloudbridge; extra == 'test'
Requires-Dist: djcloudbridge; extra == 'test'
Requires-Dist: django-model-utils; extra == 'test'
Requires-Dist: django-fernet-fields (>=0.5); extra == 'test'
Requires-Dist: django-cors-headers (>=2.1.0); extra == 'test'
Requires-Dist: django-nested-admin (>=3.0.21); extra == 'test'
Requires-Dist: django-smart-selects (>=1.5.3); extra == 'test'
Requires-Dist: django-countries (>=5.0); extra == 'test'
Requires-Dist: bioblend; extra == 'test'
Requires-Dist: jsonmerge (>=1.4.0); extra == 'test'
Requires-Dist: click; extra == 'test'

.. image:: https://readthedocs.org/projects/cloudlaunch/badge/?version=latest
   :target: http://cloudlaunch.readthedocs.io/en/latest/?badge=latest
   :alt: Documentation Status

===========
CloudLaunch
===========

CloudLaunch is a ReSTful, extensible Django app for discovering and launching
applications on cloud, container, or local infrastructure. A live version is
available at https://beta.launch.usegalaxy.org/.

CloudLaunch can be extended with your own plug-ins which can provide custom
launch logic for arbitrary custom applications. Visit the live site to see
currently available applications in the Catalog. CloudLaunch is also tightly
integrated with `CloudBridge <github.com/gvlproject/cloudbridge>`_, which makes
CloudLaunch natively multi-cloud.

CloudLaunch has a web and commandline front-end. The Web UI is maintained in the
`CloudLaunch-UI <https://github.com/galaxyproject/cloudlaunch-ui>`_ repository.
The commandline client is maintained in the
`cloudlaunch-cli <https://github.com/CloudVE/cloudlaunch-cli>`_ repository.

This is an all-new version of CloudLaunch that replaces the original
BioCloudCentral launcher. Code for that version is available in the
`BioCloudCentral branch <https://github.com/galaxyproject/cloudlaunch/tree/BioCloudCentral>`_.

Install Production Version
--------------------------

1. Install the cloudlaunch django server

.. code-block:: bash

    $ pip install cloudlaunch-server

Once installed, You can run django admin commands as follows:

.. code-block:: bash

    $ cloudlaunch-server django

2. Copy ``cloudlaunchserver/settings_local.py.sample`` to
   ``cloudlaunchserver/settings_local.py`` and make any desired configuration
   changes. **Make sure to change** the value for ``FERNET_KEYS`` variable
   because it is used to encrypt sensitive database fields.

3. Prepare the database with:

.. code-block:: bash

    $ cloudlaunch-server django migrate
    $ cloudlaunch-server django createsuperuser
    $ cloudlaunch-server django runserver

4. Start the development server and celery task queue (along with a Redis
   server as the message broker), each process in its own tab.

.. code-block:: bash

    $ python manage.py runserver
    $ redis-server & celery -A cloudlaunchserver worker -l info --beat

5. Visit http://127.0.0.1:8000/admin/ to define your application and
   infrastructure properties.

6. Visit http://127.0.0.1:8000/api/v1/ to explore the API.

You will probably also want to install the UI for the server. The default UI
is available at https://github.com/galaxyproject/cloudlaunch-ui.


Install Development Version
----------------------------

CloudLaunch is based on Python 3.6 and although it may work on older Python
versions, 3.6 is the only supported version. Use of virtualenv is also highly advised.

1. Checkout cloudlaunch and create environment

.. code-block:: bash

    $ mkdir launcher && cd launcher
    $ virtualenv venv -p python3.6 --prompt "(cloudlaunch)" && source venv/bin/activate
    $ git clone -b dev https://github.com/galaxyproject/cloudlaunch.git
    $ cd cloudlaunch
    $ python setup.py develop
    $ cd django-cloudlaunch
    $ python manage.py migrate
    $ python manage.py runserver
    $ python manage.py createsuperuser

2. Follow step 2 onwards from the production instructions above



History
-------

2.0.0 (2017-01-28)
++++++++++++++++++

* First release of the rewritten CloudLaunch on PyPI.


