Single View Key Configuration
The Single View Key is a configuration file used by the Single View Creator part to identify the Single View document that needs to be updated (or if a new document must be created) as a consequence of an event that the service has consumed.
Overview
The Single View Creator updates Single View documents every time a Projection Changes document is received via Kafka or found in the MongoDB Projection Changes collection, depending on the service configuration. The content of the identifier property includes the list of fields and their values to be matched to the Single View document found.
In case the following Projection Changes document has been received:
{
    "type": "sv_customer",
    "identifier": {
        "ID_USER": "123",
    },
    "changes": [{
        "state": "NEW",
        "topic": "my-topic.development.my-system.my-projection.ingestion",
        "partition": 0,
        "timestamp": "2021-11-19T16:22:07.031Z",
        "offset": "14",
        "key": {
            "ID_USER": "123",
        },
    }],
}
The Service understands that a projection with the identifier ID_USER with the value 123 must be updated by performing an aggregation because one or more values inside the Single View have been updated. However, the Single View might have fields with different names, therefore a configuration to understand which field of the Single View should be compared with the 123 value to understand the document to update. This configuration is the Config Map named Single View Key.
The Single View Key can be a JavaScript file, which must be named singleViewKey.js and will perform customized logic to retrieve the document to update, or a JSON file named singleViewKey.json with a predefined structure to simplify the relationship between the fields of the Projection Changes and the Single View.
When a Single View Creator is created from Mia Marketplace it will automatically include a singleViewKey.json file. If you prefer to use a JavaScript function, that file should be deleted and a singleViewKey.js file must be created in its place.
Using a JavaScript function
The JavaScript file takes as input the identifier of the Projection change and returns the key object used to select the document of the Single View collection that needs to be updated. This key corresponds to the query object fed to MongoDB, therefore you can return any legal Mongo query.
In the example below, we expect to have the field myId as the primary key of the Single View collection.
const get = require('lodash.get')
module.exports = function singleViewKeyGenerator(logger, projectionChangeIdentifier) {
  const IDENTIFIER_KEY = 'UNIQUE_ID'
  
  // get the single view id from the identifier
  const myId = projectionChangeIdentifier[IDENTIFIER_KEY]
  return {
    myId,
  }
}
While the file must be created in the Single View Creator page inside the Microservices section, it can be modified inside the Single View page (selecting the tab Single View Creators and selecting the service that contains said file).
Using a JSON definition
When creating a Single View Creator from the Mia Marketplace, a singleViewKey.json file will be automatically created. The aforementioned file can be modified right away or inside the Single View page (selecting the tab Single View Creators and selecting the service that contains said file).
An example of a defined JSON file is the following:
{
  "version": "1.0.0",
  "config": {
    "sv_id": "ID_USER"
  }
}
where:
- sv_idis the name of the Single View field (ideally the primary key defined in the Single View Data model page)
- ID_USERis the field name expected inside the Projection Changes document that triggers the update of the Single View. Most of the time this field will be the same name as the field inside the projection from which will start the aggregation of the Single View, but it might differ in case a Projection Changes Schema with customized names has been created.
It is possible to include more relationships between fields
{
  "version": "1.0.0",
  "config": {
    "first_name": "FIRST_NAME",
    "last_name": "LAST_NAME"
  }
}
Using the No Code
Your Project might be enabled to configure the Single View Key with the No Code feature included in the Single View section. This feature allows the selection of the fields from the available fields defined in the Single View data model and the fields available from the Base Projection.
The feature is included in the Single View section. After selecting the Single View and then the Single View Creator attached, the Settings tab will contain a card that recaps the information regarding the current Single View Key configured.

Before to configure the Single View Key, the ER Schema and the Aggregation must be configured as well.
A click on the Edit button will open a modal that allows the user to add more relationships with the help of two fields:
- the first field, to the left, can be populated with one of the available fields defined in the Single View data model.
- the second field, to the right, can be populated with one of the available fields defined in the data model of the projection defined as "Base Projection" in the Aggregation or a custom value (in case the Projection Changes Schema includes customized names).
In case there is no Single View Key configured, a placeholder will inform the user that a new Single View Key must be created. A click on the attached button will automatically create an empty singleViewKey.json that will be automatically attached to the config maps of your Single View Creator.
Choose between JSON and JavaScript format in Advanced Mode
In Single View key configuration modal, there is a toggle button, at the bottom left, that moves to the Advanced Mode of the Single View Key. Here it is possible to manually modify the JSON of the Single View Key in case the user wants to review the content of the config map.
Moreover, user can choose to configure Single View Key as a JavaScript file. Viceversa, in case the Single View Key is configured as a JavaScript file, from this advanced mode user can switch to JSON format.
