This repository is a space for collaboration and documentaion of the manifest tool and its output products.
The manifest tool is used to collate scripts and configuration for a DESDL service binding. Its output is ingested by the ESDL engine to create a binding between an interface and a back-end, supplying the necessary configuration and runtime scripts.
Some of the terminology here needs a little cleanup, especially use of the terms script and transform.
In this directory are sample files showing how this could look. These files are also a suggestion for how the scripts and configurations could be stored in your repo.
File | Notes |
---|---|
manifest.xml | The main input file to the manifest tool that lists the inputs, search paths and output options |
binding-config.xml | Based on the current binding configuration of DESDL services. Can contain deployment variables that the tool substitutes with actual values defined in deploy-vars.xml file |
service-scripts.xml | Contains the service-level scripts potentially shared by all methods referenced in binding-config.xml |
deploy-vars.xml | Provides values for any of the deployment variables referenced in the binding-config.xml or any other input files |
method-script-ppasearch.xml | Example scripts for the PPA method |
method-scripts-berterniereport.xml | Example scripts for the BertErnieReport method |
method-scripts-berterniesearch.xml | Example scripts for the BertErnieSearch method |
manifest-out-binding-config.xml | Output of the manifest tool. Will be input to the ESDL engine to create and configure the binding and execute scripts (transforms) |
Repository organization is left flexible. We'll provide an example and possibly some recommendations shortly.
We'll implement the tool in several incremental phases to get some basic functionality relased now then improve subsequent releases based on our experience using it. Our intention is this will be used by DevOps to create a release package or container to hand off to the OPS team as immediately deployable.
Based on Tim's feedback, instead of using <xsdl:include/>
as originally proposed, change it so that it can be used to either include all the scripts in the referenced file:
<Binding>
<Definition>
<Script>
<Transforms>
<xsdl:EspRequest>
<xsdl:include-from file="service-scripts.xml" all="true"/>
<!--
All the transforms defined in service-scripts.xml
are included here in this element
-->
</xsdl:EspRequest>
</Transforms>
</Script>
</Definition>
</Binding>
or just include some by name:
<Binding>
<Definition>
<Script>
<Transforms>
<xsdl:EspRequest>
<xsdl:include-from file="service-scripts.xml" all="false">
<xsdl:include transform="GenericOutOfBand"/>
<xsdl:include transform="UserOutOfBand"/>
</xsdl:include-from>
</xsdl:EspRequest>
</Transforms>
</Script>
</Definition>
</Binding>
This way you can organize scripts in 'shared' files where different subsets of transforms are used by a wide variety of different bindings. Also you can put all the transforms you'd need for a given service or method in a single file and automatically include
As Tony pointed out the variable notation must be unique for each level of our scripts that does variable replacement. For deployment variables, ensure that the %xxx% notation that won't conflict with any other type of escaping or variable notation.
- Implement as esdl sub-command
- Take a manifest file as input, consisting of
- Search paths for includes
- Path to a deploy-vars file that maps variables to values for per-environment customizations (eg, Roxie URL)
- Path to service binding file
- Output specification- details on how and where the output is written
- Parse given service binding file 1. Search include paths to find transforms included 2. Compile a binding-configuration including just the transforms/scripts explicitly referenced and found in the search paths 3. Replace deploy-vars references with the values provided in the deploy-vars file
- Output
- A binding-configuration file that has only referenced transforms included 2. A log-transform file
- Possibly a shell script that would perform the binding
- The service-binding input is for the complete serivce and will replace any current service binding configurations
- No validation is done to ensure all service methods have a configuration. Some deployments legitimately do not configure all methods in a service. Future behavior can give warnings for a method with no configuration.
- Generate ERROR for name collisions found when resolving includes in a single scope: service or method-level for a single method, not between all methods.
- The ESDL engine, including hte script engine, would only need to read in the manifest-out-binding-config.xml file and possibly a log-transforms.xslt file for the entire service. This may change based on Tony's config file refactoring.
- Directly publish the changes to the binding, including logTransforms
- Option to output single binding configuration file, including logTransforms
- Keep deploy-vars a separate file
- Update engine to treat deploy-vars as variable substitution
- Update WsControl? to trigger deploy-vars update/read
- Update UI to ingest & process this single file
- Update UI with a method to ingest deploy-vars
- Update a single method?
- How to handle with inherited transforms?