Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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.
- Host: GitHub
- URL: https://github.com/arangodb/foxx-cli
- Owner: arangodb
- License: apache-2.0
- Created: 2016-11-17T16:38:30.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2022-11-27T13:17:48.000Z (about 2 years ago)
- Last Synced: 2024-12-31T13:12:17.484Z (13 days ago)
- Language: JavaScript
- Homepage:
- Size: 718 KB
- Stars: 44
- Watchers: 23
- Forks: 8
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-arangodb - foxx-cli - CLI for managing and developing ArangoDB Foxx services. (Uncategorized / Uncategorized)
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" commandfoxx 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 defaultsfoxx 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 oncefoxx 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.