Node.js API
Modules
- cicero-engine
Clause Engine
- cicero-core
Cicero Core - defines the core data types for Cicero.
Classes
- AmountFormatParser
Parses an amount format string
- Clause
A Clause is executable business logic, linked to a natural language (legally enforceable) template. A Clause must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the clause (an instance of the template model) by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
- Contract
A Contract is executable business logic, linked to a natural language (legally enforceable) template. A Clause must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the clause (an instance of the template model) by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
- DateTimeFormatParser
Parses a date/time format string
- FormatParser
Parses a format string
- Metadata
Defines the metadata for a Template, including the name, version, README markdown.
- MonetaryAmountFormatParser
Parses a monetary/amount format string
- ParserManager
Generates and manages a Nearley parser for a template.
- Template
A template for a legal clause or contract. A Template has a template model, request/response transaction types, a template grammar (natural language for the template) as well as Ergo code for the business logic of the template.
- TemplateInstance
A TemplateInstance is an instance of a Clause or Contract template. It is executable business logic, linked to a natural language (legally enforceable) template. A TemplateInstance must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the TemplateInstance by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
- CompositeArchiveLoader
Manages a set of archive loaders, delegating to the first archive loader that accepts a URL.
Functions
- locationOfError(error) ⇒
object
Extract the file location from the parse error
- isPNG(buffer) ⇒
Boolean
Checks whether the file is PNG
- getMimeType(buffer) ⇒
Object
Returns the mime-type of the file
cicero-engine
Clause Engine
- cicero-engine
- ~Engine
- new Engine()
- .trigger(clause, request, state, currentTime) ⇒
Promise
- .invoke(clause, clauseName, params, state, currentTime) ⇒
Promise
- .init(clause, currentTime) ⇒
Promise
- .draft(clause, [options], currentTime) ⇒
Promise
- .getErgoEngine() ⇒
ErgoEngine
- ~Engine
cicero-engine~Engine
Engine class. Stateless execution of clauses against a request object, returning a response to the caller.
Kind: inner class of cicero-engine
Access: public
- ~Engine
- new Engine()
- .trigger(clause, request, state, currentTime) ⇒
Promise
- .invoke(clause, clauseName, params, state, currentTime) ⇒
Promise
- .init(clause, currentTime) ⇒
Promise
- .draft(clause, [options], currentTime) ⇒
Promise
- .getErgoEngine() ⇒
ErgoEngine
new Engine()
Create the Engine.
Promise
engine.trigger(clause, request, state, currentTime) ⇒ Send a request to a clause for execution
Kind: instance method of Engine
Returns: Promise
- a promise that resolves to a result for the clause
Param | Type | Description |
---|---|---|
clause | Clause | the clause |
request | object | the request, a JS object that can be deserialized using the Composer serializer. |
state | object | the contract state, a JS object that can be deserialized using the Composer serializer. |
currentTime | string | the definition of 'now' |
Promise
engine.invoke(clause, clauseName, params, state, currentTime) ⇒ Invoke a specific clause for execution
Kind: instance method of Engine
Returns: Promise
- a promise that resolves to a result for the clause
Param | Type | Description |
---|---|---|
clause | Clause | the clause |
clauseName | string | the clause name |
params | object | the clause parameters, a JS object whose fields that can be deserialized using the Composer serializer. |
state | object | the contract state, a JS object that can be deserialized using the Composer serializer. |
currentTime | string | the definition of 'now' |
Promise
engine.init(clause, currentTime) ⇒ Initialize a clause
Kind: instance method of Engine
Returns: Promise
- a promise that resolves to a result for the clause initialization
Param | Type | Description |
---|---|---|
clause | Clause | the clause |
currentTime | string | the definition of 'now' |
Promise
engine.draft(clause, [options], currentTime) ⇒ Generate Text for a clause
Kind: instance method of Engine
Returns: Promise
- a promise that resolves to a result for the clause initialization
Param | Type | Description |
---|---|---|
clause | Clause | the clause |
[options] | * | text generation options. options.wrapVariables encloses variables and editable sections in '<variable ...' and '/>' |
currentTime | string | the definition of 'now' |
ErgoEngine
engine.getErgoEngine() ⇒ Provides access to the underlying Ergo engine.
Kind: instance method of Engine
Returns: ErgoEngine
- the Ergo Engine for this Engine
cicero-core
Cicero Core - defines the core data types for Cicero.
AmountFormatParser
Parses an amount format string
Kind: global class
Access: public
- AmountFormatParser
- instance
- static
- .parseAmountFormatField(field) ⇒
string
- .amountFormatField(field) ⇒
string
- .parseAmountFormatField(field) ⇒
amountFormatParser.addGrammars(grammars, field)
Given current grammar parts, add necessary grammars parts for the format.
Kind: instance method of AmountFormatParser
Param | Type | Description |
---|---|---|
grammars | Array.<object> | the current grammar parts |
field | string | grammar field |
Object
amountFormatParser.buildFormatRules(formatString) ⇒ Converts a format string to a Nearley action
Kind: instance method of AmountFormatParser
Returns: Object
- the tokens and action and name to use for the Nearley rule
Param | Type | Description |
---|---|---|
formatString | string | the input format string |
string
AmountFormatParser.parseAmountFormatField(field) ⇒ Given a format field (like 0,0.0) this method returns a logical name for the field. Note the logical names have been picked to align with the moment constructor that takes an object.
Kind: static method of AmountFormatParser
Returns: string
- the field designator
Param | Type | Description |
---|---|---|
field | string | the input format field |
string
AmountFormatParser.amountFormatField(field) ⇒ Given a double format field (like 0,0.0) this method returns a new unique field name
Kind: static method of AmountFormatParser
Returns: string
- the field designator
Param | Type | Description |
---|---|---|
field | string | the input format field |
Clause
A Clause is executable business logic, linked to a natural language (legally enforceable) template. A Clause must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the clause (an instance of the template model) by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
Kind: global class
Access: public
Contract
A Contract is executable business logic, linked to a natural language (legally enforceable) template. A Clause must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the clause (an instance of the template model) by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
Kind: global class
Access: public
DateTimeFormatParser
Parses a date/time format string
Kind: global class
Access: public
- DateTimeFormatParser
- instance
- static
- .parseDateTimeFormatField(field) ⇒
string
- .parseDateTimeFormatField(field) ⇒
dateTimeFormatParser.addGrammars(grammars, field)
Given current grammar parts, add necessary grammars parts for the format.
Kind: instance method of DateTimeFormatParser
Param | Type | Description |
---|---|---|
grammars | Array.<object> | the current grammar parts |
field | string | grammar field |
Object
dateTimeFormatParser.buildFormatRules(formatString) ⇒ Converts a format string to a Nearley action
Kind: instance method of DateTimeFormatParser
Returns: Object
- the tokens and action and name to use for the Nearley rule
Param | Type | Description |
---|---|---|
formatString | string | the input format string |
string
DateTimeFormatParser.parseDateTimeFormatField(field) ⇒ Given a format field (like HH or D) this method returns a logical name for the field. Note the logical names have been picked to align with the moment constructor that takes an object.
Kind: static method of DateTimeFormatParser
Returns: string
- the field designator
Param | Type | Description |
---|---|---|
field | string | the input format field |
FormatParser
Parses a format string
Kind: global class
Access: public
- FormatParser
- instance
- static
formatParser.addGrammars(grammars, field)
Given current grammar parts, add necessary grammars parts for the format.
Kind: instance method of FormatParser
Param | Type | Description |
---|---|---|
grammars | Array.<object> | the current grammar parts |
field | string | grammar field |
FormatParser.buildFormatRules(format)
Given a format, returns grammar rules to parse that format
Kind: static method of FormatParser
Param | Type | Description |
---|---|---|
format | string | the format |
Array.<object> | grammar rules for the format |
Metadata
Defines the metadata for a Template, including the name, version, README markdown.
Kind: global class
Access: public
- Metadata
- new Metadata(packageJson, readme, samples, request, logo)
- instance
- .getTemplateType() ⇒
number
- .getLogo() ⇒
Buffer
- .getAuthor() ⇒
*
- .getRuntime() ⇒
string
- .getCiceroVersion() ⇒
string
- .satisfiesCiceroVersion(version) ⇒
string
- .getSamples() ⇒
object
- .getRequest() ⇒
object
- .getSample(locale) ⇒
string
- .getREADME() ⇒
String
- .getPackageJson() ⇒
object
- .getName() ⇒
string
- .getDisplayName() ⇒
string
- .getKeywords() ⇒
Array
- .getDescription() ⇒
string
- .getVersion() ⇒
string
- .getIdentifier() ⇒
string
- .createTargetMetadata(runtimeName) ⇒
object
- .toJSON() ⇒
object
- .getTemplateType() ⇒
- static
new Metadata(packageJson, readme, samples, request, logo)
Create the Metadata.
Note: Only to be called by framework code. Applications should retrieve instances from [Template](#Template)
Param | Type | Description |
---|---|---|
packageJson | object | the JS object for package.json (required) |
readme | String | the README.md for the template (may be null) |
samples | object | the sample markdown for the template in different locales, |
request | object | the JS object for the sample request |
logo | Buffer | the bytes data for the image represented as an object whose keys are the locales and whose values are the sample markdown. For example: { default: 'default sample markdown', en: 'sample text in english', fr: 'exemple de texte français' } Locale keys (with the exception of default) conform to the IETF Language Tag specification (BCP 47). THe default key represents sample template text in a non-specified language, stored in a file called sample.md . |
number
metadata.getTemplateType() ⇒ Returns either a 0 (for a contract template), or 1 (for a clause template)
Kind: instance method of Metadata
Returns: number
- the template type
Buffer
metadata.getLogo() ⇒ Returns the logo at the root of the template
Kind: instance method of Metadata
Returns: Buffer
- the bytes data of logo
*
metadata.getAuthor() ⇒ Returns the author for this template.
Kind: instance method of Metadata
Returns: *
- the author information
string
metadata.getRuntime() ⇒ Returns the name of the runtime target for this template, or null if this template has not been compiled for a specific runtime.
Kind: instance method of Metadata
Returns: string
- the name of the runtime
string
metadata.getCiceroVersion() ⇒ Returns the version of Cicero that this template is compatible with. i.e. which version of the runtime was this template built for? The version string conforms to the semver definition
Kind: instance method of Metadata
Returns: string
- the semantic version
string
metadata.satisfiesCiceroVersion(version) ⇒ Only returns true if the current cicero version satisfies the target version of this template
Kind: instance method of Metadata
Returns: string
- the semantic version
Param | Type | Description |
---|---|---|
version | string | the cicero version to check against |
object
metadata.getSamples() ⇒ Returns the samples for this template.
Kind: instance method of Metadata
Returns: object
- the sample files for the template
object
metadata.getRequest() ⇒ Returns the sample request for this template.
Kind: instance method of Metadata
Returns: object
- the sample request for the template
string
metadata.getSample(locale) ⇒ Returns the sample for this template in the given locale. This may be null. If no locale is specified returns the default sample if it has been specified.
Kind: instance method of Metadata
Returns: string
- the sample file for the template in the given locale or null
Param | Type | Default | Description |
---|---|---|---|
locale | string | null | the IETF language code for the language. |
String
metadata.getREADME() ⇒ Returns the README.md for this template. This may be null if the template does not have a README.md
Kind: instance method of Metadata
Returns: String
- the README.md file for the template or null
object
metadata.getPackageJson() ⇒ Returns the package.json for this template.
Kind: instance method of Metadata
Returns: object
- the Javascript object for package.json
string
metadata.getName() ⇒ Returns the name for this template.
Kind: instance method of Metadata
Returns: string
- the name of the template
string
metadata.getDisplayName() ⇒ Returns the display name for this template.
Kind: instance method of Metadata
Returns: string
- the display name of the template
Array
metadata.getKeywords() ⇒ Returns the keywords for this template.
Kind: instance method of Metadata
Returns: Array
- the keywords of the template
string
metadata.getDescription() ⇒ Returns the description for this template.
Kind: instance method of Metadata
Returns: string
- the description of the template
string
metadata.getVersion() ⇒ Returns the version for this template.
Kind: instance method of Metadata
Returns: string
- the description of the template
string
metadata.getIdentifier() ⇒ Returns the identifier for this template, formed from name@version.
Kind: instance method of Metadata
Returns: string
- the identifier of the template
object
metadata.createTargetMetadata(runtimeName) ⇒ Return new Metadata for a target runtime
Kind: instance method of Metadata
Returns: object
- the new Metadata
Param | Type | Description |
---|---|---|
runtimeName | string | the target runtime name |
object
metadata.toJSON() ⇒ Return the whole metadata content, for hashing
Kind: instance method of Metadata
Returns: object
- the content of the metadata object
Metadata.checkImage(buffer)
Check the buffer is a png file with the right size
Kind: static method of Metadata
Param | Type | Description |
---|---|---|
buffer | Buffer | the buffer object |
Metadata.checkImageDimensions(buffer, mimeType)
Checks if dimensions for the image are correct.
Kind: static method of Metadata
Param | Type | Description |
---|---|---|
buffer | Buffer | the buffer object |
mimeType | string | the mime type of the object |
MonetaryAmountFormatParser
Parses a monetary/amount format string
Kind: global class
Access: public
- MonetaryAmountFormatParser
- instance
- static
monetaryAmountFormatParser.addGrammars(grammars, field)
Given current grammar parts, add necessary grammars parts for the format.
Kind: instance method of MonetaryAmountFormatParser
Param | Type | Description |
---|---|---|
grammars | Array.<object> | the current grammar parts |
field | string | grammar field |
Object
monetaryAmountFormatParser.buildFormatRules(formatString) ⇒ Converts a format string to a Nearley action
Kind: instance method of MonetaryAmountFormatParser
Returns: Object
- the tokens and action and name to use for the Nearley rule
Param | Type | Description |
---|---|---|
formatString | string | the input format string |
string
MonetaryAmountFormatParser.parseMonetaryAmountFormatField(field) ⇒ Given a format field (like CCC or 0,0.0) this method returns a logical name for the field. Note the logical names have been picked to align with the moment constructor that takes an object.
Kind: static method of MonetaryAmountFormatParser
Returns: string
- the field designator
Param | Type | Description |
---|---|---|
field | string | the input format field |
ParserManager
Generates and manages a Nearley parser for a template.
Kind: global class
- ParserManager
- new ParserManager(template)
- instance
- .getParser() ⇒
object
- .getTemplateAst() ⇒
object
- .setGrammar(grammar)
- .buildGrammar(templatizedGrammar)
- .buildGrammarRules(ast, templateModel, prefix, parts)
- .handleBinding(templateModel, parts, inputRule, element)
- .cleanChunk(input) ⇒
string
- .findFirstBinding(propertyName, elements) ⇒
int
- .getGrammar() ⇒
String
- .getTemplatizedGrammar() ⇒
String
- .roundtripMarkdown(text) ⇒
string
- .formatText(text, options, format) ⇒
string
- .getParser() ⇒
- static
new ParserManager(template)
Create the ParserManager.
Param | Type | Description |
---|---|---|
template | object | the template instance |
object
parserManager.getParser() ⇒ Gets a parser object for this template
Kind: instance method of ParserManager
Returns: object
- the parser for this template
object
parserManager.getTemplateAst() ⇒ Gets the AST for the template
Kind: instance method of ParserManager
Returns: object
- the AST for the template
parserManager.setGrammar(grammar)
Set the grammar for the template
Kind: instance method of ParserManager
Param | Type | Description |
---|---|---|
grammar | String | the grammar for the template |
parserManager.buildGrammar(templatizedGrammar)
Build a grammar from a template
Kind: instance method of ParserManager
Param | Type | Description |
---|---|---|
templatizedGrammar | String | the annotated template using the markdown parser |
parserManager.buildGrammarRules(ast, templateModel, prefix, parts)
Build grammar rules from a template
Kind: instance method of ParserManager
Param | Type | Description |
---|---|---|
ast | object | the AST from which to build the grammar |
templateModel | ClassDeclaration | the type of the parent class for this AST |
prefix | String | A unique prefix for the grammar rules |
parts | Object | Result object to acculumate rules and required sub-grammars |
parserManager.handleBinding(templateModel, parts, inputRule, element)
Utility method to generate a grammar rule for a variable binding
Kind: instance method of ParserManager
Param | Type | Description |
---|---|---|
templateModel | ClassDeclaration | the current template model |
parts | * | the parts, where the rule will be added |
inputRule | * | the rule we are processing in the AST |
element | * | the current element in the AST |
string
parserManager.cleanChunk(input) ⇒ Cleans a chunk of text to make it safe to include as a grammar rule. We need to remove linefeeds and escape any '"' characters.
Kind: instance method of ParserManager
Returns: string
- cleaned text
Param | Type | Description |
---|---|---|
input | string | the input text from the template |
int
parserManager.findFirstBinding(propertyName, elements) ⇒ Finds the first binding for the given property
Kind: instance method of ParserManager
Returns: int
- the index of the element or -1
Param | Type | Description |
---|---|---|
propertyName | string | the name of the property |
elements | Array.<object> | the result of parsing the template_txt. |
String
parserManager.getGrammar() ⇒ Get the (compiled) grammar for the template
Kind: instance method of ParserManager
Returns: String
- - the grammar for the template
String
parserManager.getTemplatizedGrammar() ⇒ Returns the templatized grammar
Kind: instance method of ParserManager
Returns: String
- the contents of the templatized grammar
string
parserManager.roundtripMarkdown(text) ⇒ Round-trip markdown
Kind: instance method of ParserManager
Returns: string
- the result of parsing and printing back the text
Param | Type | Description |
---|---|---|
text | string | the markdown text |
string
parserManager.formatText(text, options, format) ⇒ Format text
Kind: instance method of ParserManager
Returns: string
- the result of parsing and printing back the text
Param | Type | Description |
---|---|---|
text | string | the markdown text |
options | object | parameters to the formatting |
format | string | to the text generation |
object
ParserManager.adjustListBlock(x, separator) ⇒ Adjust the template for list blocks
Kind: static method of ParserManager
Returns: object
- the new template AST node
Param | Type | Description |
---|---|---|
x | object | The current template AST node |
separator | String | The list separator |
*
ParserManager.getProperty(templateModel, element) ⇒ Throws an error if a template variable doesn't exist on the model.
Kind: static method of ParserManager
Returns: *
- the property
Param | Type | Description |
---|---|---|
templateModel | * | the model for the template |
element | * | the current element in the AST |
ParserManager._throwTemplateExceptionForElement(message, element)
Throw a template exception for the element
Kind: static method of ParserManager
Throws:
TemplateException
Param | Type | Description |
---|---|---|
message | string | the error message |
element | object | the AST |
object
ParserManager.compileGrammar(sourceCode) ⇒ Compiles a Nearley grammar to its AST
Kind: static method of ParserManager
Returns: object
- the AST for the grammar
Param | Type | Description |
---|---|---|
sourceCode | string | the source text for the grammar |
Template
A template for a legal clause or contract. A Template has a template model, request/response transaction types, a template grammar (natural language for the template) as well as Ergo code for the business logic of the template.
Kind: global abstract class
Access: public
- Template
- new Template(packageJson, readme, samples, request, logo, options)
- instance
- .validate()
- .getTemplateModel() ⇒
ClassDeclaration
- .getIdentifier() ⇒
String
- .getMetadata() ⇒
Metadata
- .getName() ⇒
String
- .getDisplayName() ⇒
string
- .getVersion() ⇒
String
- .getDescription() ⇒
String
- .getHash() ⇒
string
- .toArchive([language], [options], logo) ⇒
Promise.<Buffer>
- .getParserManager() ⇒
ParserManager
- .getLogicManager() ⇒
LogicManager
- .getIntrospector() ⇒
Introspector
- .getFactory() ⇒
Factory
- .getSerializer() ⇒
Serializer
- .getRequestTypes() ⇒
Array
- .getResponseTypes() ⇒
Array
- .getEmitTypes() ⇒
Array
- .getStateTypes() ⇒
Array
- .hasLogic() ⇒
boolean
- .grammarHasErgoExpression() ⇒
boolean
- static
new Template(packageJson, readme, samples, request, logo, options)
Create the Template. Note: Only to be called by framework code. Applications should retrieve instances from fromArchive or fromDirectory.
Param | Type | Description |
---|---|---|
packageJson | object | the JS object for package.json |
readme | String | the readme in markdown for the template (optional) |
samples | object | the sample text for the template in different locales |
request | object | the JS object for the sample request |
logo | Buffer | the bytes data of logo |
options | Object | e.g., { warnings: true } |
template.validate()
Verifies that the template is well formed. Throws an exception with the details of any validation errors.
Kind: instance method of Template
ClassDeclaration
template.getTemplateModel() ⇒ Returns the template model for the template
Kind: instance method of Template
Returns: ClassDeclaration
- the template model for the template
Throws:
Error
if no template model is found, or multiple template models are found
String
template.getIdentifier() ⇒ Returns the identifier for this template
Kind: instance method of Template
Returns: String
- the identifier of this template
Metadata
template.getMetadata() ⇒ Returns the metadata for this template
Kind: instance method of Template
Returns: Metadata
- the metadata for this template
String
template.getName() ⇒ Returns the name for this template
Kind: instance method of Template
Returns: String
- the name of this template
string
template.getDisplayName() ⇒ Returns the display name for this template.
Kind: instance method of Template
Returns: string
- the display name of the template
String
template.getVersion() ⇒ Returns the version for this template
Kind: instance method of Template
Returns: String
- the version of this template. Use semver module
to parse.
String
template.getDescription() ⇒ Returns the description for this template
Kind: instance method of Template
Returns: String
- the description of this template
string
template.getHash() ⇒ Gets a content based SHA-256 hash for this template. Hash is based on the metadata for the template plus the contents of all the models and all the script files.
Kind: instance method of Template
Returns: string
- the SHA-256 hash in hex format
Promise.<Buffer>
template.toArchive([language], [options], logo) ⇒ Persists this template to a Cicero Template Archive (cta) file.
Kind: instance method of Template
Returns: Promise.<Buffer>
- the zlib buffer
Param | Type | Description |
---|---|---|
[language] | string | target language for the archive (should be 'ergo') |
[options] | Object | JSZip options |
logo | Buffer | Bytes data of the PNG file |
ParserManager
template.getParserManager() ⇒ Provides access to the parser manager for this template. The parser manager can convert template data to and from natural language text.
Kind: instance method of Template
Returns: ParserManager
- the ParserManager for this template
LogicManager
template.getLogicManager() ⇒ Provides access to the template logic for this template. The template logic encapsulate the code necessary to execute the clause or contract.
Kind: instance method of Template
Returns: LogicManager
- the LogicManager for this template
Introspector
template.getIntrospector() ⇒ Provides access to the Introspector for this template. The Introspector is used to reflect on the types defined within this template.
Kind: instance method of Template
Returns: Introspector
- the Introspector for this template
Factory
template.getFactory() ⇒ Provides access to the Factory for this template. The Factory is used to create the types defined in this template.
Kind: instance method of Template
Returns: Factory
- the Factory for this template
Serializer
template.getSerializer() ⇒ Provides access to the Serializer for this template. The Serializer is used to serialize instances of the types defined within this template.
Kind: instance method of Template
Returns: Serializer
- the Serializer for this template
Array
template.getRequestTypes() ⇒ Provides a list of the input types that are accepted by this Template. Types use the fully-qualified form.
Kind: instance method of Template
Returns: Array
- a list of the request types
Array
template.getResponseTypes() ⇒ Provides a list of the response types that are returned by this Template. Types use the fully-qualified form.
Kind: instance method of Template
Returns: Array
- a list of the response types
Array
template.getEmitTypes() ⇒ Provides a list of the emit types that are emitted by this Template. Types use the fully-qualified form.
Kind: instance method of Template
Returns: Array
- a list of the emit types
Array
template.getStateTypes() ⇒ Provides a list of the state types that are expected by this Template. Types use the fully-qualified form.
Kind: instance method of Template
Returns: Array
- a list of the state types
boolean
template.hasLogic() ⇒ Returns true if the template has logic, i.e. has more than one script file.
Kind: instance method of Template
Returns: boolean
- true if the template has logic
boolean
template.grammarHasErgoExpression() ⇒ Checks whether the template grammar has computer (Ergo) expressions
Kind: instance method of Template
Returns: boolean
- True if the template grammar has Ergo expressions ({{% ... %}}
)
Promise.<Template>
Template.fromDirectory(path, [options]) ⇒ Builds a Template from the contents of a directory. The directory must include a package.json in the root (used to specify the name, version and description of the template).
Kind: static method of Template
Returns: Promise.<Template>
- a Promise to the instantiated template
Param | Type | Default | Description |
---|---|---|---|
path | String | to a local directory | |
[options] | Object |
| an optional set of options to configure the instance. |
Promise.<Template>
Template.fromArchive(buffer, [options]) ⇒ Create a template from an archive.
Kind: static method of Template
Returns: Promise.<Template>
- a Promise to the template
Param | Type | Default | Description |
---|---|---|---|
buffer | Buffer | the buffer to a Cicero Template Archive (cta) file | |
[options] | Object |
| an optional set of options to configure the instance. |
Promise
Template.fromUrl(url, [options]) ⇒ Create a template from an URL.
Kind: static method of Template
Returns: Promise
- a Promise to the template
Param | Type | Default | Description |
---|---|---|---|
url | String | the URL to a Cicero Template Archive (cta) file | |
[options] | Object |
| an optional set of options to configure the instance. |
boolean
Template.instanceOf(classDeclaration, fqt) ⇒ Check to see if a ClassDeclaration is an instance of the specified fully qualified type name.
Kind: static method of Template
Returns: boolean
- True if classDeclaration an instance of the specified fully
qualified type name, false otherwise.
Internal:
Param | Type | Description |
---|---|---|
classDeclaration | ClassDeclaration | The class to test |
fqt | String | The fully qualified type name. |
TemplateInstance
A TemplateInstance is an instance of a Clause or Contract template. It is executable business logic, linked to a natural language (legally enforceable) template. A TemplateInstance must be constructed with a template and then prior to execution the data for the clause must be set. Set the data for the TemplateInstance by either calling the setData method or by calling the parse method and passing in natural language text that conforms to the template grammar.
Kind: global abstract class
Access: public
- TemplateInstance
- new TemplateInstance(template)
- instance
- .setData(data)
- .getData() ⇒
object
- .getEngine() ⇒
object
- .getDataAsConcertoObject() ⇒
object
- .parse(input, [currentTime], [fileName])
- .draft([options], currentTime) ⇒
string
- .getIdentifier() ⇒
String
- .getTemplate() ⇒
Template
- .getLogicManager() ⇒
LogicManager
- .toJSON() ⇒
object
- static
new TemplateInstance(template)
Create the Clause and link it to a Template.
Param | Type | Description |
---|---|---|
template | Template | the template for the clause |
templateInstance.setData(data)
Set the data for the clause
Kind: instance method of TemplateInstance
Param | Type | Description |
---|---|---|
data | object | the data for the clause, must be an instance of the template model for the clause's template. This should be a plain JS object and will be deserialized and validated into the Concerto object before assignment. |
object
templateInstance.getData() ⇒ Get the data for the clause. This is a plain JS object. To retrieve the Concerto object call getConcertoData().
Kind: instance method of TemplateInstance
Returns: object
- - the data for the clause, or null if it has not been set
object
templateInstance.getEngine() ⇒ Get the current Ergo engine
Kind: instance method of TemplateInstance
Returns: object
- - the data for the clause, or null if it has not been set
object
templateInstance.getDataAsConcertoObject() ⇒ Get the data for the clause. This is a Concerto object. To retrieve the
plain JS object suitable for serialization call toJSON() and retrieve the data
property.
Kind: instance method of TemplateInstance
Returns: object
- - the data for the clause, or null if it has not been set
templateInstance.parse(input, [currentTime], [fileName])
Set the data for the clause by parsing natural language text.
Kind: instance method of TemplateInstance
Param | Type | Description |
---|---|---|
input | string | the text for the clause |
[currentTime] | string | the definition of 'now' (optional) |
[fileName] | string | the fileName for the text (optional) |
string
templateInstance.draft([options], currentTime) ⇒ Generates the natural language text for a contract or clause clause; combining the text from the template and the instance data.
Kind: instance method of TemplateInstance
Returns: string
- the natural language text for the contract or clause; created by combining the structure of
the template with the JSON data for the clause.
Param | Type | Description |
---|---|---|
[options] | * | text generation options. options.wrapVariables encloses variables and editable sections in '<variable ...' and '/>' |
currentTime | string | the definition of 'now' (optional) |
String
templateInstance.getIdentifier() ⇒ Returns the identifier for this clause. The identifier is the identifier of the template plus '-' plus a hash of the data for the clause (if set).
Kind: instance method of TemplateInstance
Returns: String
- the identifier of this clause
Template
templateInstance.getTemplate() ⇒ Returns the template for this clause
Kind: instance method of TemplateInstance
Returns: Template
- the template for this clause
LogicManager
templateInstance.getLogicManager() ⇒ Returns the template logic for this clause
Kind: instance method of TemplateInstance
Returns: LogicManager
- the template for this clause
object
templateInstance.toJSON() ⇒ Returns a JSON representation of the clause
Kind: instance method of TemplateInstance
Returns: object
- the JS object for serialization
*
TemplateInstance.convertFormattedParsed(obj, utcOffset) ⇒ Recursive function that converts all instances of Formated objects (ParsedDateTime or ParsedMonetaryAmount) to a Moment.
Kind: static method of TemplateInstance
Returns: *
- the converted object
Param | Type | Description |
---|---|---|
obj | * | the input object |
utcOffset | number | the default utcOffset |
CompositeArchiveLoader
Manages a set of archive loaders, delegating to the first archive loader that accepts a URL.
Kind: global class
new CompositeArchiveLoader()
Create the CompositeArchiveLoader. Used to delegate to a set of ArchiveLoaders.
compositeArchiveLoader.addArchiveLoader(archiveLoader)
Adds a ArchiveLoader implemenetation to the ArchiveLoader
Kind: instance method of CompositeArchiveLoader
Param | Type | Description |
---|---|---|
archiveLoader | ArchiveLoader | The archive to add to the CompositeArchiveLoader |
compositeArchiveLoader.clearArchiveLoaders()
Remove all registered ArchiveLoaders
Kind: instance method of CompositeArchiveLoader
boolean
compositeArchiveLoader.accepts(url) ⇒ Returns true if this ArchiveLoader can process the URL
Kind: instance abstract method of CompositeArchiveLoader
Returns: boolean
- true if this ArchiveLoader accepts the URL
Param | Type | Description |
---|---|---|
url | string | the URL |
Promise
compositeArchiveLoader.load(url, options) ⇒ Load a Archive from a URL and return it
Kind: instance method of CompositeArchiveLoader
Returns: Promise
- a promise to the Archive
Param | Type | Description |
---|---|---|
url | string | the url to get |
options | object | additional options |
object
locationOfError(error) ⇒ Extract the file location from the parse error
Kind: global function
Returns: object
- - the file location information
Param | Type | Description |
---|---|---|
error | object | the error object |
Boolean
isPNG(buffer) ⇒ Checks whether the file is PNG
Kind: global function
Returns: Boolean
- whether the file in PNG
Param | Type | Description |
---|---|---|
buffer | Buffer | buffer of the file |
Object
getMimeType(buffer) ⇒ Returns the mime-type of the file
Kind: global function
Returns: Object
- the mime-type of the file
Param | Type | Description |
---|---|---|
buffer | Buffer | buffer of the file |