Skip to content

bbc88ks/opennode-management

 
 

Repository files navigation

OpenNode Management Service

OpenNode Management Service (OMS) is a modular framework for creating management applications. Its initial target was hosting the OMS Knot cloud management platform.

OMS main documentation is generated and can be viewed online.

Build Status

Requirements

Currently the only requirement is Python 2.7.

On Mac OS X, Python 2.7 can be installed either manually, using MacPorts by running sudo port install python27, or using Homebrew by running brew install python.

Setup

  1. git clone [email protected]:opennode/opennode-management.git.

  2. Boostrap buildout: python boostrap.py -v 1.7.0

  3. Run buildout: bin/buildout

  4. Setup user accounts with the bin/passwd utility

  5. Start the Twisted twistd server on port 8080 by executing bin/omsd

Testing

  1. ./test.sh

Plugins

You can quickly enable plugins by adding the plugin buildout snippet to the eggnest dir, e.g:

bin/plugin install opennode.oms.onc

This will download the published egg for the plugin. If you want to use a development plugin you have to specify the plugin checkout:

bin/plugin install opennode.oms.knot -d ../opennode-knot

Development

During development, you can use the autoreload mode with bin/omsd -d. If you make changes in the dependencies, just rerun bin/buildout. You can use bin/buildout -o to avoid waiting for the network, if you already have the eggs in the cache.

You can get a python prompt with the correct python path with bin/python.

High level architecture

The core consists of:

  • The models:

    These are mostly ORM backed and some transient classes which contain CRUD and most of the domain logic.

  • Traversal:

    Mapping of URIs/paths to model objects, i.e. /datacentres/123/computes/9 -> .

  • Interaction layers a.k.a endpoints (in Twisted terminology):

    This is a thin layer that takes an incoming request/interaction (either SSH/vconsole, HTTP or WebSocket) which is always bound to a URI/path (cwd in SSH, request URI in HTTP/Websocket) and maps it, using traversal, to a domain object and executes appropriate methods and returns a result.

    This layer can be thought of as the controller.

    The interaction layer is as thin as possible as traversal, domain logic and security are in the core, and serialisation is generic.

Interaction layers/endpoints

The primary interaction layer is the HTTP REST endpoint which contains an HTTP request handler and a set of views, one for each content type. The views can either be generic over content types, or specialised for specific models. Generic is preferred over specialised though.

The WebSocket endpoint is in big part complementary to the HTTP REST endpoint. It is mostly an alternative carrier or transport mechanism for individual HTTP-like requests. In addition, it is used to push a stream of data/events to the browser for real time updates of the UI. As HTTP REST like requests can be transported from client to server over this layer, it also provides a performance boost over classic HTTP as it eliminates any request overhead both in terms of responsiveness and network/resource usage. It is also easier to manage than classic HTTP as browser security restrictions do not apply to WebSocket connections.

The SSH virtual console endpoint provides a bash-like pseudo shell over SSH that exposes a filesystem-like hierarchy to navigate in and manage the server infrastructure environment. It provides or will provide all the basic shell-like commands such as cd, ls, pwd, cat, mv, cp and rm. It also provides the generic command set to modify attributes of objects.

License

OpenNode Management Service is released under an open-source Apache v2 license. Commercial support is possible, please contact [email protected] for more information.

About

OpenNode Management Service (core).

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 98.8%
  • Shell 1.2%