A small Python framework meant to easily create programs with unified CLI and API.
Find a file
Alexandre Aubin 9a8b5c080a
Merge pull request #181 from YunoHost/LDAP_validate_uniqueness
Add possiblity to get attribute name of conflict in LDAP
2018-12-12 13:13:57 +01:00
data Update gitignore and test actionsmap 2014-12-29 18:27:22 +01:00
debian [enh] Transform naive date into UTC aware date 2018-12-10 00:00:49 +01:00
doc [enh] new utils to read yaml files 2018-05-12 06:03:06 +02:00
lib/test [clean] Remove YunoHost files 2014-05-16 16:19:40 +02:00
locales [i18n] Translated using Weblate (French) 2018-11-23 13:37:52 +00:00
moulinette Merge pull request #181 from YunoHost/LDAP_validate_uniqueness 2018-12-12 13:13:57 +01:00
tests Protect against CSRF (#171) 2018-12-02 02:32:59 +01:00
.gitignore [fix] Properly disconnect from LDAP 2015-07-18 16:28:48 +02:00
.travis.yml [mod] continue with pep8 2016-12-18 01:53:49 +01:00
CONTRIBUTORS.md [enh][love] Add CONTRIBUTORS.md 2016-12-22 16:28:23 +01:00
generate_api_doc.py [fix] nargs + option should allows to set several args 2014-12-14 17:15:50 +01:00
generate_function_doc.py [enh] Adapt yunohost_tools + backport update/upgrade function from prerefactoring branch 2014-04-26 12:51:35 +00:00
LICENSE Init 2012-10-06 16:22:15 +02:00
README.md [mod] we moved away from redmine 2018-06-07 13:39:14 +02:00
setup.py Protect against CSRF (#171) 2018-12-02 02:32:59 +01:00

Moulinette

The moulinette is a Python package that allows to quickly and easily prototype interfaces for your application.

Translation status

Issues

Overview

Initially, the moulinette was an application made for the YunoHost project in order to regroup all its related operations into a single program called moulinette. Those operations were available from a command-line interface and a Web server providing an API. Moreover, the usage of these operations (e.g. required/optional arguments) was defined into a simple yaml file - called actionsmap. This file was parsed in order to construct an ArgumentParser object and to parse the command arguments to process the proper operation.

During a long refactoring with the goal of unify both interfaces, the idea to separate the core of the YunoHost operations has emerged. The core kept the same name moulinette and try to follow the same initial principle. An Actions Map - which defines available operations and their usage - is parsed and it's used to process an operation from several unified Interfaces. It also supports a configuration mechanism - which allows to restrict an operation on an interface for example (see Authenticators).

Actions Map

...

Interfaces

...

Authenticators

...

Requirements

  • Python 2.7
  • python-bottle (>= 0.10)
  • python-gnupg (>= 0.3)
  • python-ldap (>= 2.4)
  • PyYAML