Various thoughts and to-dos are listed here. Some are resolved and already included in the prototype.
- How to configure for Proxied methods. Check example in HPCCSystems- /opt/HPCCSystems/examples or esdl examples.
- Should the tool manage pushing out interface definitions and creating bindings also? I'm going to assume no for now
- How do we tell where the transforms from an included script belong in the output - service vs. method level?
- Do we require the to be located in the scope where it belongs? Then what if one file is included in both service and method- call it an error during manifest-time?
- Do we require the contents of each included file to have an attribute identifying its intended scope?
- Is there some way we could automatically determine this by where it's referenced?
- Manifest should be a monolithic state for the entire service binding. We won't have a way to generate a manifest for a single service because:
- What about shared dependencies? Meaning- service level transforms it may call or inherit from.
- Can we maintain any guarantees about stability of overall service if we want to update just one method?
- In the future add capability to update one + method, with these understandings:
- Method scripts may refer to existing service level scripts without changing them
- Maybe will be able to add new service level scripts. But even then would we need to do manifest-time name collision checking? What if a new service transform is the same name as another transform used in another method?
- Manifest file will need to have name of process, name of binding.
- When parsing the included scripts
- store as text
- keep pointers to original source?
- keep pointers to where they are referenced?
- keep tabs on the transforms each contains as a list that has char* pointer & length & name instead of parsing each out into another separate object?
- Create a dict for the deploy-vars and use that to see if vars in the service-binding need to be replaced.
- Use xml namespaces for specifying/scoping included scripts. Use namespaces in file fragments, and also in final blob.
- Extend esdl tool with manifest functionality?
- Esdl tool + UI for publishing manifest
- Will the UI have a way to take the entire blob?
- Can the UI update separate sections or just the whole thing
- Blob will contain what?
- all info currently in service binding?
- all info that is stored outside that scope too?
- Separate file, referenced in manifest, that will include the per-environment values to substitute in. This would be the file OPS would switch out in each environment.
- Manifest itself will just give paths to files to use, and those files will have 'includes' and namespaces to limit scope and uniquely identify which bits to include
- What is syntax for manifest itself? Research other similar tools
- CMAKE
- ANT
- ecl
- Could tool automatically generate some unique identifier for each statement that can be used in debugging output to identify where you are in the code.
Tim's preferred solution is to just keep pTree. He will check each node
- if Child nodes then serialize in whatever order comes out and work with it
- if a text node (then it is a serialized XML) assumption is that it's not wrapped in a parent (aka <Script>) node.
- Tony wants people to be able to edit the config as XML
- He doesn't want us to have any special attribute marker in the XML that marks something to be stored as blob
- Tim thinks it should all be contained inside a <Script> element
- All blobs will be contained in non-blob elements
- Tim will go through pTree, if he has content (value aka blob) he'll assemble document (preserving order) to parse with xpp
- Current 'legacy' CustomRequestTransforms could have order preserved, but maybe not required.
- Tim would not want the esdl_store to compile all the scripts for a service into a single object that he then needs to understand where all parts are from.
- Otherwise he would want a way to query the esdl_store for the blobs at each level, but that is a pain