Loading TOC...

MarkLogic Server 11.0 Product Documentation
trgr.createTrigger

trgr.createTrigger(
   trigger-name as String,
   description as String?,
   event as Node,
   module as element(trgr.module),
   enabled as Boolean,
   permissions as Sequence,
   [recursive as Boolean?],
   [task-priority as String]
) as (Number|String)

Summary

Creates a new trigger in the context database. Returns the trigger ID of the created trigger.

Parameters
trigger-name A unique name. If $trigger-name is not unique, an error is returned.
description A description of the trigger.
event The definition of an event that invokes the trigger module. Use trgr.triggerDataEvent or trgr.triggerDatabaseOnlineEvent to construct this element.
module The module to execute when the triggering event occurs. Use trgr.triggerModule to construct this element.
enabled Set to true if the trigger is enabled.
permissions A sequence of permissions for the trigger. These permissions will determine which roles are permitted to modify the trigger. When run in an XQuery context, the permissions are a sequence of XML elements (sec:permission). When importing this module into a Server-Side JavaScript context, the permissions are an array of Objects.
recursive Set to true if the trigger should be allowed to trigger itself for recursive changes on the same document. Set to false to prevent the trigger from triggering itself. If this parameter is not present, then its value is true.
task-priority The task priority for post-commit triggers. Either "normal" or "higher". If this parameter is not present, the value is "normal".

Required Privileges

http://marklogic.com/xdmp/privileges/create-trigger

Usage Notes

Triggers must be created in the triggers database associated with the content database to which the triggers apply. To determine the triggers database programatically, use xdmp:triggers-database in the evaluation context of the content database, or xdmp.database with the database name listed as the triggers database value in the Admin Interface under Databases > content_db_name.

Triggers are created in the http://marklogic.com/xdmp/triggers/ directory, with the trigger ID completing the URI. This is the ID returned by trgr.createTrigger .

If a trigger named $trigger-name already exists, the exception TRGR-TNEXISTS is raised. You must use trgr.removeTrigger to delete an existing trigger before recreating it.

Once a trigger is created, you can view it in the Admin Interface under the content database, in the Triggers Summary page (Databases > content_db_name > Triggers). If your trigger does not appear in Triggers Summary, trgr.createTrigger was probably evaluated in the wrong database context.

Example

// Run in the context of the triggers database of the content database.

declareUpdate();
const trgr = require('/MarkLogic/triggers');

trgr.createTrigger('myTrigger', 'Simple trigger example', 
  trgr.triggerDataEvent(
      trgr.directoryScope('/myDir/', '1'),
      trgr.documentContent('create'),
      trgr.postCommit()),
  trgr.triggerModule(xdmp.database('Triggers'), '/modules/', 'logCreate.xml'),
  true, Sequence.from(xdmp.defaultPermissions(null, 'elements')) );

  // The ID of the newly created trigger. This
  // trigger fires whenever a document is created in the
  // /myDir/ directory. The action module, /modules/log.xqy,
  // is stored in the modules database of the App Server
  // against which the content document is created.  When 
  // the trigger fires, a task to evaluate /modules/log.xqy 
  // is spawned on the task server queue.
   

Stack Overflow iconStack Overflow: Get the most useful answers to questions from the MarkLogic community, or ask your own question.