Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/arangodb/foxx-cli

CLI for managing Foxx services.
https://github.com/arangodb/foxx-cli

Last synced: 6 days ago
JSON representation

CLI for managing Foxx services.

Awesome Lists containing this project

README

        

# foxx-cli

[![license - APACHE-2.0](https://img.shields.io/npm/l/foxx-cli.svg?style=flat-square)](http://opensource.org/licenses/APACHE-2.0)
[![Dependencies](https://img.shields.io/david/arangodb/foxx-cli.svg?style=flat-square)](https://david-dm.org/arangodb/foxx-cli)

[![NPM status](https://nodei.co/npm/foxx-cli.png?downloads=true&stars=true)](https://npmjs.org/package/foxx-cli)

[![standard-readme compliant](https://img.shields.io/badge/readme%20style-standard-brightgreen.svg?style=flat-square)](https://github.com/RichardLitt/standard-readme)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier)

> CLI for managing and developing ArangoDB Foxx services.

**foxx-cli** is a standalone tool for the shell that can be used to talk to
[ArangoDB](https://www.arangodb.com) servers to manage
[Foxx services](https://www.arangodb.com/why-arangodb/foxx/).

To learn more about Foxx, see the official
[ArangoDB Foxx documentation](https://www.arangodb.com/docs/stable/foxx.html).

_foxx-cli_ relies on the
[Foxx HTTP API](https://www.arangodb.com/docs/stable/http/foxx.html).

## Table of Contents

* [Install](#install)
* [Usage](#usage)
* [Special files](#special-files)
* [manifest.json](#manifestjson)
* [foxxignore](#foxxignore)
* [foxxrc](#foxxrc)
* [Contribute](#contribute)
* [License](#license)

## Install

**foxx-cli** runs on [Node.js](https://nodejs.org) and can be installed with
[yarn](https://yarnpkg.com):

```sh
yarn global add foxx-cli
```

Or with [npm](https://www.npmjs.com):

```sh
npm install --global foxx-cli
```

**Note**: using yarn you can also run **foxx-cli** from your project's
`devDependencies`:

```sh
yarn add --dev foxx-cli
yarn foxx help
```

If you're using a recent version of npm you can also use npx:

```sh
npx -p foxx-cli foxx help
```

## Usage

After you've installed **foxx-cli**, you should be able to use the `foxx`
program. You can learn more about the different commands `foxx` supports by
using the `--help` flag.

```sh
foxx --help
```

You can also use the `--help` flag with commands to learn more about them, e.g.:

```sh
foxx install --help # Help for the "install" command

foxx server --help # Help for the "server" command

foxx server list --help # Subcommands are supported, too
```

If you have no prior knowledge of Foxx, you can get started by
[installing ArangoDB locally](https://www.arangodb.com/download)
and then creating a new Foxx service in the current directory using the `init` command:

```sh
foxx init -i # answer the interactive questions
```

If you want an example, you can also let `init` create an example service for you:

```sh
foxx init -e # create an example service please
```

You can also just use `foxx init` to create a minimal service without the example code.

You can inspect the files created by the program and tweak them as necessary.
Once you're ready, install the service at a _mount path_ using the `install` command:

```sh
foxx install /hello-foxx # installs the current directory
```

You should then be able to view the installed service in your browser at the following URL:

If you continue to work on your Foxx service and want to upgrade the installed
version with your local changes use the `upgrade` command to do so.

```sh
foxx upgrade /hello-foxx # upgrades the server with the current directory
```

## Special files

### manifest.json

The `manifest.json` or manifest file contains a service's meta-information.
See the [Foxx reference documentation](https://www.arangodb.com/docs/stable/foxx-reference-manifest.html).

The directory containing a service's `manifest.json` file is called the _root
directory_ of the service.

### foxxignore

If you want to exclude files from the service bundle that will uploaded to
ArangoDB you can create a file called `.foxxignore` in the root directory of
your service. Each line should specify one pattern you wish to ignore:

* Patterns starting with `!` will be treated as an explicit whitelist. Paths
matching these patterns will not be ignored even if they would match any of
the other patterns.

**Example**: `!index.js` will override any pattern matching a file called
`index.js`.

* Patterns starting with `/` will only match paths relative to the service's
root directory.

**Example**: `/package.json` will not match `node_modules/joi/package.json`.

* Patterns ending with `/` will match a directory and any files inside of it.

**Example**: `node_modules/` will exclude all `node_modules` directories and
all of their contents.

* A single `*` (glob) will match zero or more characters (even dots) in a file
or directory name.

**Example**: `.*` will match any files and directories with a name starting
with a dot.

* A double `**` (globstar) will match zero or more levels of nesting.

**Example**: `hello/**/world` will match `hello/world`, `hello/foo/world`,
`hello/foo/bar/world`, and so on.

* Patterns starting with `#` are considered comments and will be ignored.

For more details on the pattern matching behaviour, see the documentation of the
[minimatch](https://www.npmjs.com/package/minimatch) module (with the `dot` flag
enabled).

If no `.foxxignore` file is present in the service's root directory the
following patterns will be ignored automatically: `.git/`, `.svn/`, `.hg/`,
`*.swp`, `.DS_Store`.

Should you need to include files that match these patterns for some reason, you
can override this list by creating an empty `.foxxignore` file.

You can also create a `.foxxignore` file in the current directory using the
`ignore` command:

```sh
foxx ignore # creates a file pre-populated with the defaults

foxx ignore --force # creates an empty file
```

To add individual patterns to the `.foxxignore` file just pass them as
additional arguments:

```sh
foxx ignore .git/ .svn/ # you can pass multiple patterns at once

foxx ignore '*.swp' # make sure to escape special characters
```

### foxxrc

If you define servers using the `server` commands, a `.foxxrc` file will be
created in your `$HOME` directory, which is typically one of the following
paths:

* `/home/$USER` on Linux

* `/Users/$USER` on macOS

* `C:\Users\$USER` on Windows

This file contains sections for each server which may contain server credentials
should you decide to save them.

## Contribute

Feel free to dive in!
[Open an issue](https://github.com/arangodb/foxx-cli/issues/new) or submit PRs.

All JavaScript code should conform to [standard](http://standardjs.com) coding
style.

This README conforms to the
[standard-readme](https://github.com/RichardLitt/standard-readme) specification.

## License

The Apache License, Version 2.0. For more information, see the accompanying
LICENSE file.