Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nervous-systems/serverless-cljs-plugin
Serverless plugin for Clojurescript deployment w/ cljs-lambda
https://github.com/nervous-systems/serverless-cljs-plugin
aws aws-lambda clojure clojurescript serverless serverless-plugin
Last synced: 3 months ago
JSON representation
Serverless plugin for Clojurescript deployment w/ cljs-lambda
- Host: GitHub
- URL: https://github.com/nervous-systems/serverless-cljs-plugin
- Owner: nervous-systems
- License: unlicense
- Created: 2017-01-28T23:33:41.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2019-02-25T21:56:41.000Z (almost 6 years ago)
- Last Synced: 2024-10-07T08:12:24.073Z (4 months ago)
- Topics: aws, aws-lambda, clojure, clojurescript, serverless, serverless-plugin
- Language: JavaScript
- Size: 36.1 KB
- Stars: 75
- Watchers: 7
- Forks: 10
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# serverless-cljs-plugin
[![npm version](https://badge.fury.io/js/serverless-cljs-plugin.svg)](https://badge.fury.io/js/serverless-cljs-plugin)
A [Serverless](https://github.com/serverless/serverless) plugin which
uses lein/[cljs-lambda](https://github.com/nervous-systems/cljs-lambda) (or,
optionally [Lumo](https://github.com/anmonteiro/lumo)) to package services
written in [Clojurescript](https://clojurescript.org/).## Leiningen Template
``` shell
$ lein new serverless-cljs example
example$ lein deps
```Will generate an `example` directory containing a minimal `serverless.yml` and
`project.clj` demonstrating this plugin's functionality.### [Guide to using the plugin via Lein/JVM compilation.](https://nervous.io/clojurescript/lambda/2017/02/06/serverless-cljs/)
## Usage
```yaml
functions:
echo:
cljs: example.core/echoplugins:
- serverless-cljs-plugin
```With the above `serverless.yml`, `serverless deploy` will create a zip file
containing your functions. Doing this is similar to setting the Serverless
`packaging.artifact` option - `cljs-lambda` is responsible for the zip contents,
and Serverless includes/excludes will be skipped (`cljs-lambda` offers
equivalent functionality).In the example above, there needn't be a corresponding entry for `echo` in
`project.clj`.## Lumo
Alternatively you can use the [Lumo](https://github.com/anmonteiro/lumo)
[compiler](https://anmonteiro.com/2017/02/compiling-clojurescript-projects-without-the-jvm/).In order to enable it, pass the `--lumo` switch to either `deploy` or `package`:
```shell
$ serverless deploy --lumo
```Or add the following to your `serverless.yml`:
```yaml
custom:
cljsCompiler: lumo
```- _Compiler options_
The source paths and compiler options will be read from the optional file
`serverless-lumo.edn`. Below are the defaults:```clojure
{:source-paths ["src"]
:compiler {:output-to "out/lambda.js"
:output-dir "out"
:source-map false ;; because of a bug in lumo <= 1.8.0
:target :nodejs
:optimizations :none}}
```- _Lumo Configuration_
As an alternative to `cljsCompiler: lumo`, `cljsCompiler.lumo` may be specified
as a map of options. These options are passed directly to the `lumo` process.
Currently supported:```yaml
custom:
cljsCompiler:
lumo:
dependencies:
- andare:0.7.0
classpath:
- /tmp/
localRepo: /xyz
cache: /cache | none
index: true | false
exitOnWarning: true | false
```_Note_: caching is always on unless you specify "none" in the config.
- _The index.js file_
The `index` option will materialize a custom `index.js` in `:output-dir`'s parent folder. This
file should be thought as managed by `serverless-cljs-plugin` and it is necessary for some plugin (e.g.: [`serverless-offline`](https://github.com/dherault/serverless-offline)) to work properly._Note_: with the default compiler options, `index.js` will be saved in the project root, overwriting without warning.
- _Exit on compilation warnings_
Lumo generates warnings such as `WARNING: Use of undeclared Var` to signal
failures. You can tune the ones you want to see by using the
[`:warnings` compiler option](https://clojurescript.org/reference/compiler-options#warnings)
in `serverless-lumo.edn`, but by default the `lumo` process emits the warnings,
does not throw and returns `0`. This means that `serverless` will keep going in
presence of warnings.## License
serverless-cljs-plugin is free and unencumbered public domain software. For more
information, see http://unlicense.org/ or the accompanying LICENSE
file.