mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-24 05:38:11 +00:00
The API itself is documented using Swagger, a lightweight mechanism for documenting RESTful API's using JSON. This allows us to use swagger-ui to provide executable documentation for the API, generate client bindings in different languages, and generate a lot of the boilerplate code for implementing the RESTful bindings. The API docs live in the rest-api/ directory. The RESTful bindings are generated from the Swagger API docs using a set of Mustache templates. The code generator is written in Python, and uses Pystache. Pystache has no dependencies, and be installed easily using pip. Code generation code lives in rest-api-templates/. The generated code reduces a lot of boilerplate when it comes to handling HTTP requests. It also helps us have greater consistency in the REST API. (closes issue ASTERISK-20891) Review: https://reviewboard.asterisk.org/r/2376/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@386232 65c4cc65-6c06-0410-ace0-fbb531ad65f3
16 lines
733 B
Plaintext
16 lines
733 B
Plaintext
This directory contains templates and template processing code for generating
|
|
HTTP bindings for the RESTful API's.
|
|
|
|
The RESTful API's are declared using [Swagger][swagger]. While Swagger provides
|
|
a [code generating toolkit][swagger-codegen], it requires Java to run, which
|
|
would be an unusual dependency to require for Asterisk developers.
|
|
|
|
This code generator is similar, but written in Python. Templates are processed
|
|
by using [pystache][pystache], which is a fairly simply Python implementation of
|
|
[mustache][mustache].
|
|
|
|
[swagger]: https://github.com/wordnik/swagger-core/wiki
|
|
[swagger-codegen]: https://github.com/wordnik/swagger-codegen
|
|
[pystache]: https://github.com/defunkt/pystache
|
|
[mustache]: http://mustache.github.io/
|