The AtlasMap Data Mapper UI is a visual integration tool that simplifies configuring integrations between Java, XML, and JSON data sources. It is designed to work within the Syndesis UI.
The easiest way to install and run the Data Mapper UI is to install and run the Syndesis UI. Simply follow the Syndesis UI's installation instructions, and run the Syndesis UI. You will find the Data Mapper UI under the integrations panel after selecting or adding an integration with a data mapping step involved in the integration.
The Data Mapper features a stand-alone development mode which allows developers to run the Data Mapper UI on their local machine outside of the Syndesis UI.
Running the Data Mapper in stand alone mode will require installing the Data Mapper and the Atlas Map Services on your machine.
Installation
-
Install and run the Atlas Map Services as directed in the services' installation instructions. Running the services will require installing a Java Development Kit and Maven.
-
Create a directory for the Data Mapper UI, we'll refer to this directory as ${atlas.ui.home} for the remainder of these instructions.
-
Clone the Data Mapper UI in ${atlas.ui.home} with
git clone https://github.com/atlasmap/atlasmap-ui.git ${atlas.ui.home}
. -
Install the Data Mapper's dependencies by running
npm install
in ${atlas.ui.home}. -
Start the Atlas Map Services if you have not already done so.
-
Start the Data Mapper UI by running
npm start
in ${atlas.ui.home}. -
The npm start command will attempt to automatically open your browser window, but if it doesn't, open it directy with this URL: [http://localhost:3000].
Troubleshooting Installation
-
Compile errors: If the UI doesn't run, check the terminal window where you ran
npm start
, there may be compilation errors reported there even if it attempts to run the UI successfully without exiting with error. -
Check the console window of chrome's developer tools window for errors, this is found via the chrome "view->developer->developer tools" menu, the javascript console will be on the bottom of the tab you've opened the tools in.
Reference Documents For Installation Guide
The Data Mapper UI is referenced by Syndesis as a dependency here. When the Syndesis UI's dependencies are installed during the yarn install step, the Data Mapper UI will be cloned from the public github master branch into the ${syndesis.ui.home}/node_modules/atlasmap_data_mapper directory.
You can point your local Syndesis UI's Data Mapper UI reference to your working copy of the Data Mapper by changing the src directory in the node_modules folder to point to your code. You'll do something like this:
# save the original data mapper library contents for syndesis in case we want to use that version again later.
# ${syndesis.ui.home} is your local syndesis ui directory.
> mv ${syndesis.ui.home}/node_modules/atlasmap_data_mapper/src ${syndesis.ui.home}/node_modules/atlasmap_data_mapper/src.old
# ${atlas.ui.home} is your local data mapper ui directory
> ln -s ${atlas.ui.home}/src ${syndesis.ui.home}/node_modules/atlasmap_data_mapper/src
After making this change, restart the Syndesis UI with yarn start.
Note that running yarn install
in the Syndesis UI directory will remove and redownload the ${syndesis.ui.home}/node_modules/atlasmap_data_mapper directory. For this reason, do not make changes within the ${syndesis.ui.home}/node_modules/atlasmap_data_mapper directory. Instead, make changes in another directory and use the soft link (ln -s
) command shown above to point the Syndesis UI dependency to your code.
The Data Mapper UI features several developer-friendly debug configuration options. These configuration fields are specified on the ConfigModel class.
** Service Endpoint Configuration**
- baseJavaInspectionServiceUrl - URL for the Java Inspection Service provided by the AtlasMap Services.
- baseXMLInspectionServiceUrl - URL for the XML Inspection Service provided by the AtlasMap Services.
- baseJSONInspectionServiceUrl - URL for the JSON Inspection Service provided by the AtlasMap Services.
- baseMappingServiceUrl - URL for the Mapping Service provided by the AtlasMap Services.
** Mock Source/Target Document Configuration**
These flags control the UI automatically adding the specified mock documents to the system when the UI initializes.
- addMockJavaSingleSource - Add single Java source document.
- addMockJavaSources - Add multiple Java source documents.
- addMockXMLInstanceSources - Add multiple XML instance-based source documents.
- addMockXMLSchemaSources - Add multiple XML schema-based source documents.
- addMockJSONSources - Add multiple JSON source documents.
- addMockJavaTarget - Add a Java target document.
- addMockXMLInstanceTarget - Add a XML instance target document.
- addMockXMLSchemaTarget - Add a XML schema target document.
- addMockJSONTarget - Add a JSON target document.
The code that initializes these mock documents is in the Initialization Service. That service calls various static methods in the Document Management Service to create example XML instance, XML schema, and JSON documents. Mock Java documents referenced are from the AtlasMap Services' Atlas Java Test Model Maven Module.
** Additional Debug Configuration**
- discardNonMockSources - Automatically discard all user-specified (or Syndesis UI-specified) source/target documents before initializing. This is helpful if you're trying to test with mock documents alone.
- addMockJSONMappings - This flag bootstraps the UI's mappings from the provided JSON mapping definition. Useful for repeatedly debugging a particular scenario.
- debugClassPathServiceCalls - Log details about JSON request/responses to/from the class path resolution service.
- debugDocumentServiceCalls - Log details about JSON request/responses to/from the Java/XML/JSON inspection services.
- debugMappingServiceCalls - Log details about JSON request/responses to/from the mapping service.
- debugValidationServiceCalls - Log details about JSON request/responses to/from the mapping validation service.
- debugFieldActionServiceCalls - Log details about JSON request/responses to/from the mapping field action configuration service.
- debugDocumentParsing - Log details about parsing JSON responses from the inspection services.
Data Mapper Debug Configuration within the Syndesis UI is defined within your ${syndesis.ui.home}/src/config.json file's data mapper section:
{
"apiEndpoint": "https://syndesis-staging.b6ff.rh-idev.openshiftapps.com/api/v1",
"title": "Syndesis",
"datamapper": {
"baseJavaInspectionServiceUrl": "http://localhost:8585/v2/atlas/java/",
"baseXMLInspectionServiceUrl": "http://localhost:8585/v2/atlas/xml/",
"baseJSONInspectionServiceUrl": "http://localhost:8585/v2/atlas/json/",
"baseMappingServiceUrl": "http://localhost:8585/v2/atlas/",
"discardNonMockSources": true,
"addMockJSONMappings": false,
"addMockJavaSingleSource": true,
"addMockJavaSources": false,
"addMockXMLInstanceSources": true,
"addMockXMLSchemaSources": true,
"addMockJSONSources": true,
"addMockJavaTarget": false,
"addMockXMLInstanceTarget": false,
"addMockXMLSchemaTarget": false,
"addMockJSONTarget": true,
"debugDocumentServiceCalls": true,
"debugMappingServiceCalls": true,
"debugClassPathServiceCalls": false,
"debugValidationServiceCalls": false,
"debugFieldActionServiceCalls": false,
"debugDocumentParsing": false
},
"oauth": {
"clientId": "syndesis-ui",
"scopes": ["openid"],
"oidc": true,
"hybrid": true,
"issuer": "https://syndesis-staging.b6ff.rh-idev.openshiftapps.com/auth/realms/syndesis",
"auto-link-github": true
}
}
If you're running the Data Mapper UI locally outside of the Syndesis UI, the debug configuration is specified within the DataMapperAppExampleHostComponent.
//todo: list of project files w/ brief descriptions for each
//todo: brief overview of bootstrapping process
//TODO: brief high level overview of what the ui does (service calls made, etc)
[BOOTSTRAPPING OVERVIEW]
Bootstrapping the Data Mapper UI requires a bit of configuration. An example bootstrapping component is provided within the project:
src/app/lib/atlasmap-data-mapper/components/data.mapper.example.host.component.ts
MODEL OVERVIEW
All application data and configuration is stored in a centralized ConfigModel object.
The ConfigModel contains:
- initialization data such as service URLs and source/target document information
- references to our angular2 services that manage retrieving and saving our documents and mapping data
- document / mapping model objects
There are two document models contained within the ConfigModel object, both of type DocumentDefinition. A DocumentDefinition contains information about a source or target document such as the document's name, and fields for that document. Fields are represented by our Field model.
A single MappingDefinition model in the ConfigModel object stores information about field mappings and related lookup tables. Individual mappings are represented in instances of MappingModel, and lookup tables are represented by the LookupTable model.
SERVICE OVERVIEW
When the Data Mapper UI Bootstraps, a series of service calls are made to the mapping service (MappingManagementService) and document service (DocumentManagementService).
The document service is used to fetch our source/target document information (name of doc, fields). After these are parsed from the service, they are stored in the ConfigModel's inputDoc and outputDoc DocumentDefinition models.
The mapping service is used to fetch our mappings for the fields mapped from the source to the target document. These mappings (and related lookup tables) are parsed by the management service and stored in the ConfigModel's mappings MappingDefinition model.
//TODO:
//TODO: