Metadata-Version: 2.1
Name: cacahuate
Version: 2.0.2
Summary: The process virtual machine
Home-page: https://github.com/tracsa/cacahuate
Author: Abraham Toriz Cruz
Author-email: categulario@gmail.com
License: MIT
Keywords: process
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Requires-Dist: Flask-Coralillo
Requires-Dist: Flask-Cors
Requires-Dist: Flask-PyMongo
Requires-Dist: case-conversion
Requires-Dist: coralillo (>=0.8)
Requires-Dist: flask (>=1.0)
Requires-Dist: itacate
Requires-Dist: lark-parser
Requires-Dist: ldap3
Requires-Dist: pika
Requires-Dist: simplejson
Requires-Dist: requests

Cacahuate
=========

.. image:: https://travis-ci.org/tracsa/cacahuate.svg?branch=master
   :target: https://travis-ci.org/tracsa/cacahuate
   :alt: Build Status

**The process virtual machine**

This project defines storage for an abstract _process_ in a company, and
implements a virtual machine that keeps track of the execution of instances of
the process.

Develop
-------

You will need the **redis** and **mongo** databases, and **rabbitmq** for this to work.

.. code-block:: bash

   git clone https://github.com/tracsa/cacahuate.git && cd cacahuate
   virtualenv -p /usr/bin/python3 .env
   echo "export CACAHUATE_SETTINGS=$(pwd)/settings_develop.py" >> .env/bin/activate
   echo "export FLASK_APP=cacahuate.http.wsgi" >> .env/bin/activate
   echo "export FLASK_DEBUG=1" >> .env/bin/activate
   touch settings_develop.py
   source .env/bin/activate
   pip install -r requirements.txt
   pytest

Installation
------------

.. code-block:: bash

   pip install cacahuate

Cacahuated
----------

This is the daemon in charge of moving pointers in the process, run with:

.. code-block:: bash

   cacahuated

The Cacahuate REST API
----------------------

In this same repository you will find a flask application that exposes a REST
api for controling Cacahuate.

**How to run**

.. code-block:: bash

   FLASK_APP=cacahuate.http.wsgi flask run

You can use any wsgi-compliant server, like gunicorn, to run this:

.. code-block:: bash

   gunicorn cacahuate.http.wsgi:app

TODO
----

* cambiar api de LoginProvider y HierarchyProvider, no deben guardar usuarios
* auth backends no deben crear usuarios, solo devolver objetos calificados

* date input solo debe recibir yyyy-mm-dd

* hacer validación intensiva de xml:
  - dependencias existen arriba en el xml
  - id de nodos son únicos
  - condicionales validan
  - params existen
  - validar auth param, devuelva un usuario

* guardar en un store privado por hash los xml al iniciar proceso, obsoleta el sistema de versiones (borrar toda referencia a la versión)
  - correr validaciones al mover un xml a este storage
* atrapar excepciones de template de jinja y añadir mensaje al titulo
* todo uso de jinja debe tener try


