overleaf/services/clsi
2014-02-18 16:58:21 +00:00
..
app/coffee Update a missed setting 2014-02-13 11:08:40 +00:00
config Fix up smoke tests 2014-02-13 09:33:39 +00:00
test Fix unit tests 2014-02-13 11:11:53 +00:00
.gitignore Fix unit tests 2014-02-13 11:11:53 +00:00
app.coffee Initial open source commit 2014-02-12 17:27:43 +00:00
Gruntfile.coffee Fix up smoke tests 2014-02-13 09:33:39 +00:00
package.json Use master branch of logger-settings module 2014-02-17 15:09:12 +00:00
README.md Create README.md 2014-02-18 16:58:21 +00:00

clsi-sharelatex

A web api for compiling LaTeX documents in the cloud

Installation

The CLSI can be installed and set up as part of the entire ShareLaTeX stack (complete with front end editor and document storage), or it can be run as a standalone service. To run is as a standalone service, first checkout this repository:

$ git clone git@github.com:sharelatex/clsi-sharelatex.git

Then install the require npm modules:

$ npm install

Then compile the coffee script source files:

$ grunt compile

Finally, (after configuring your local database - see the Config section), run the CLSI service:

$ grunt run

The CLSI should then be running at http://localhost:3013.

Config

You will need to set up a database in mysql to use with the CLSI, and then fill in the database name, username and password in the config file at config/settings.development.coffee.

API

The CLSI is based on a JSON API.

Example Request

    {
      "options": {
          "compiler": "lualatex" # Can be latex, pdflatex, xelatex or lualatex
          "timeout": 40 # How many seconds to wait before killing the process. Default is 60.
      },
      "rootResourcePath": "main.tex", # The main file to run LaTeX on
      # An array of files to include in the compilation
      "resources": [{
        "path": "main.tex",
        "content": "\\documentclass{article}\n\\begin{document}\nHello World\n\\end{document}"
      }]
    }