The coreBOS-ElasticSearch integration works on the idea that ES (Elastic Search) is more than capable of handling ALL the information we have in our CRM, so we directly send it all over for you to analyze.
The integration will continuously send to Elastic:
So, once setup, you will be able to plugin Kibana to your ES server and start analyzing and visualizing all your information.
The information will be saved in three indexes:
This index contains one type per each module in the CRM and inside all the records of that module in their current state in the CRM. Even the deleted ones, which will be marked with their "deleted" field set to 1.
As with the special "deleted" field, each record also contains a few other common fields:
This index contains a list of each individual change occurred on any record in the crm. The structure is like this:
| Field | Type | Contains | 
| record_module | string | Name of the module affected by the change | 
| record_id | long | Internal CRMID of the record affected | 
| userid | long | Internal USERID of the user who made the change | 
| changedon | date | Date of the change | 
| operation | string | Action executed: CREATED or UPDATED | 
| field | string | Name of the field affected by the change | 
| prevalue | string | Value prior to the change | 
| postvalue | string | Value after the change | 
This index contains a list of each individual action occurred in the application by the users in their daily use. The structure is like this:
| Field | Type | Contains | 
| operation | string | Action executed: login, login portal, logout, detailview, webservice, … | 
| record_module | string | Name of the module affected by the action | 
| record_id | long | Internal CRMID of the record affected | 
| userid | long | Internal USERID of the user who made the change | 
| doneon | date | Date of the action | 
| donefrom | ip | IP from which the action was requested | 
| moreinfo | string | A bucket of variable information related to the action | 

This is, by far, the most important part of the setup. For Elastic to properly index our information it is fundamental that we give it a mapping of the information we have. We must define the type and the way we want each of our fields to be analyzed and indexed in order to be able to get the best out of our data.
We have a process that will generate a default mapping based on the different types of fields supported by coreBOS. With this and the fantastic job Elastic does by default, we are in a pretty good situation to answer the questions we have about our business but there is still royom for improvement. Data analysis is a complex subject and really depends on the questions you need to answer and the things you want to study so the default mapping generated may need some special tuning for your exact data. Don't hesitate to contact us for help.
You will need an Elastic Search server installed
Go to the command line of your install and execute:
php modules/cbElasticSearch/generateESMap.php {version}> cbesmap.jsonwhere {version} is a string that will be used to create the aliases for the indexes
Open cbesmap.json in an editor. You will see the complete set of commands you need to send to your elastic server to get all the indexes defined. You can fine tune as necessary and the copy and paste those commands into your ES server.
Elastic is now ready to receive your information
As soon as you installed the coreBOS-ES integration extension it started picking up information about everything that is happening, but it won't be able to send it all until ES has the current state of our data. For this to happen we have to execute the import process which will pickup all the information in our CRM and send it to ES.
The information sent is:
Due to the amount of information that can be sent I would recommend doing this from the command line to avoid unnecessary timeouts. In any case the import process is prepared to stop and continue where it left off so you can just continue to execute it until you have all your information there.
php modules/cbElasticSearch/cbesimport.phpAmong other things that can be done I paste here ideas generated by team at in Albania.
One way is to represent the changes of the normal index as lines of a related list inside the record that we want to explore.
Evolutivo created a json "de-compiler" of another project called angular block inside the application itself. It produces a representation inside the detail view of the record. The Ajax technology used is an Angular.js grid.
The best thing related to this approach of showing data, is the possibility to add actions related to that specific log, for example it would be possible to revert to a previous state.

Another approach would be creating a search client directly as an extension in the application. There can also be found some ready to install clients using opensource software in order to embed them in the application, without having to re-create the whole thing from scratch.

One intelligent approach would be also store the URL of the entity in the ES Document in order to directly access from the search
Another approach is the possibility to create an extension inside coreBOS and then show in that the search done by some super-user in the Kibana Application.
This would help in order to improve some restrictions on security.
Next | Chapter 2: coreBOSCRM GeoLocalization Map extension