Skip to content
dmcassel edited this page May 8, 2012 · 20 revisions

Roxy Deployer is a command line tool for scaffolding and deploying XQuery applications to MarkLogic Server. Help is available by running the ml command with no parameters:

> ml

##Bootstrap Roxy Deployer can automatically create all your forests, databases, app servers, users, and roles for you. You provide the settings via property files. Roxy deployer uses these values to create the necessary configuration on one or more servers.

Example of bootstrapping to your local box

> ml local bootstrap

You can also deploy to a cluster.

##Wipe You can "uninstall" your application from a MarkLogic server with Roxy Deployer. All traces of your application will be removed from the server.

Example of wiping your application from the dev box

> ml dev wipe

##Deploying source code You can deploy your XQuery modules to a MarkLogic modules database. By default, all files under $roxy/src are deployed except for test files. Test files are only deployed if you have a test environment configured and only for non-production environments.

Example of deploying source code to your development box

> ml dev deploy modules

You can substitute for some special values in your source code when you deploy modules.

##Erasing deployed source code You can remove all the code from your modules database with a single command. Be warned that this is potentially destructive in the wrong hands.

Example of wiping clean your modules database

> ml local clean modules

##Deploying content You can deploy content to your content database. By default, all files under $roxy/data are deployed.

Example of deploying content to your local database

> ml local deploy content

##Erasing deployed content You can remove all the data from your content database with a single command. Be warned that this is potentially destructive in the wrong hands.

Example of wiping clean your content database

> ml local clean content

##Unit Testing You can invoke your Roxy Unit Tests with the Deployer.

Example of invoking unit tests on your local ML instance

> ml local test

#Scaffolding The Roxy Deployer allows you to easily create code via a handful of scaffolding methods.

##Create Controller and View You can create a controller and view with Roxy Deployer.

The syntax is as follows:

> ml create controller/function format

Both function and format are optional. If no view is provided Roxy will default to main. If no format is provided then Roxy will default to html. You can skip view creation by specifying format as none

A controller will be created at $roxy/src/app/controllers/$controller.xqy A function matching the name your provided will be created inside of the controller file. A view to render the output in the provided format will be created in $roxy/src/app/views/$controller/$function.$format.xqy

This command is non-destructive. If any of the specified pieces already exist they will be left alone.

Typical example

> ml create search/facets html

creates:
$roxy/src/app/controllers/search.xqy with a facets() function
$roxy/src/app/views/users/facets.html.xqy

Using default format

> ml create search/facets

creates:
$roxy/src/app/controllers/search.xqy with a facets() function
$roxy/src/app/views/users/facets.html.xqy

Using default function and format

> ml create search

creates:
$roxy/src/app/controllers/search.xqy with a main() function
$roxy/src/app/views/users/main.html.xqy

Example with no view

> ml create search/main none

creates:
$roxy/src/app/controllers/search.xqy with a main function

Example of creating a json view

> ml create users/new json

creates:
$roxy/src/app/controllers/users.xqy with a new() function
$roxy/src/app/views/users/new.json.xqy

##Create a Model You can create a model with Roxy Deployer.

The syntax is as follows:

> ml create model name

This command is non-destructive. If any of the specified pieces already exist they will be left alone.

A model file will be created at $roxy/src/app/models/$name.xqy

Example

> ml create model users-lib

creates:
$roxy/src/app/models/user-lib.xqy
Clone this wiki locally