Wiki source code of 207 - Aligned State
                  Version 215.1 by Carlijn Kokkeler on 2023/10/24 11:33
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | {{container}} | ||
| 2 | {{container layoutStyle="columns"}}((( | ||
| 3 | [[image:Main.Images.Release Blog.WebHome@release-blog-intro.png]] | ||
| 4 | |||
| 5 | **Hi there, eMagiz developers!** We have done much work for state generation, so that you can derive more information from your data! Examples are enrichment, aggregation, change detection and duplicate detection. | ||
| 6 | |||
| 7 | {{warning}}State generation functionality is only accessible for models with an add-on state generation license.{{/warning}} | ||
| 8 | |||
| 9 | Next to state generation, several improvements regarding the alignment of components have been made. Moreover, performance improvements and bug fixes have been implemented. Lastly, a change in the metrics storage duration has been performed. | ||
| 10 | |||
| 11 | == **State Generation~*~*** == | ||
| 12 | |||
| 13 | //__New components__// | ||
| 14 | The following components have been added: | ||
| 15 | * Aggregator: reverse of the splitter, used to combine multiple messages into a single one. | ||
| 16 | * Infinispan metadata outbound channel adapter: used to (temporarily) store metadata, which can be used to enrich messages, or make decisions in filters or scripts. | ||
| 17 | * Content enricher: used to add properties to the payload of messages, similar to what the header enricher can do for headers. | ||
| 18 | * Duplicate detector: support object used to detect duplicate messages for a certain key on an inbound channel of a flow component. Duplicates can be marked or discarded. | ||
| 19 | * Infinispan support objects, supporting the aggregator, metadata outbound channel adapter and content enricher. | ||
| 20 | |||
| 21 | //__SpEL functions & JSON__// | ||
| 22 | Added SpEL functions for: | ||
| 23 | * Encoding & decoding Base64, Hex and hmac. | ||
| 24 | * Date retrieval (currentDateTime, currentEpochMilli, currentEpochSecond). | ||
| 25 | * Date conversion (DateTime to Epoch, Epoch to DateTime, DateTime formatter and DateTime parser). | ||
| 26 | |||
| 27 | Added support for SpEL property accessors for XML and JSON, meaning that you can read message payloads in SpEL expressions easily. For example, to retrieve the value for 'id' in the following JSON String: `{"id":"123"}`, this SpEL expression suffices: `payload.id`. | ||
| 28 | |||
| 29 | Added support for `#JsonPath` usage in SpEL expressions. | ||
| 30 | |||
| 31 | {{info}}The components are all configurable from the Flow Designer in Create and are accompanied by a help text explaining the use cases and the various technical configurations. Note that to make the components work in your model, a new release containing the latest image (2.0.0) needs to be deployed.{{/info}} | ||
| 32 | |||
| 33 | == **Metrics Storage Duration** == | ||
| 34 | We will change the retention of monitoring data of different environments. For minute level data, it will be kept for test, acceptance and production environments for 7, 14 and 30 days respectively. Then the minute level data will be reduced to hour level data then will be stored for test, acceptance and production for 3, 6 and 12 months respectively. | ||
| 35 | |||
| 36 | [[image:Main.Images.Release Blog.WebHome@release-blog-207-aligned-state-metrics-storage.png]] | ||
| 37 | |||
| 38 | ((((% border="3" cellpadding="10" cellspacing="10" style="width:292px" %) | ||
| 39 | |=(% style="width: 100px;" %)#|=(% style="width: 100px;" %)Option|=(% style="width: 100px;" %)Option | ||
| 40 | |(% style="width:100px" %) a|(% style="width:100px" %) OAuth 2.0 - Authorization Code|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 41 | |(% style="width:100px" %) b|(% style="width:100px" %) REST - Basic Auth|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 42 | |(% style="width:100px" %) c|(% style="width:100px" %) REST - Client Certificate|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 43 | |(% style="width:100px" %) d|(% style="width:100px" %) REST - Header Mapper|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 44 | |(% style="width:100px" %) e|(% style="width:100px" %) OAuth 2.0 - Client Credentials|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 45 | |(% style="width:100px" %) f|(% style="width:100px" %) REST - SSL|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 46 | |(% style="width:100px" %) g|(% style="width:100px" %) Dynamic Token|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 47 | |(% style="width:100px" %) h|(% style="width:100px" %) No Authentication|(% style="width:100px" %) OAuth 2.0 - Authorization Code | ||
| 48 | ))) | ||
| 49 | |||
| 50 | == **Feedback Items** == | ||
| 51 | |||
| 52 | //__Import from store__// | ||
| 53 | The button 'Import from Store' in Design will directly open the store instead of showing a pop asking whether the store should be opened. | ||
| 54 | |||
| 55 | //__Save and cancel buttons placement__// | ||
| 56 | The save and cancel buttons have been placed slightly further apart from each other to avoid misclicking. | ||
| 57 | |||
| 58 | //__User session times__// | ||
| 59 | The user session times for 3rd generation runtime dashboards have been extended, so that the user is not thrown out of the model when using the Manage phase for longer than an hour. | ||
| 60 | |||
| 61 | //__Cancel and next buttons order__// | ||
| 62 | The order of the cancel and next buttons when creating a new trigger has been changed to increase alignment across the platform. Now, all cancel buttons are placed on the right of a 'next' or 'save' button. | ||
| 63 | |||
| 64 | //__Data sink page__// | ||
| 65 | The data sink page has been moved to the “Explore” tab. | ||
| 66 | |||
| 67 | //__Unused images removal__// | ||
| 68 | When a release is removed, the related unused images in the on-premises machines will be removed as well. | ||
| 69 | |||
| 70 | //__Flow Designer performance__// | ||
| 71 | Performance improvements for the Flow Designer have been implemented. | ||
| 72 | |||
| 73 | //__Properties with special characters__// | ||
| 74 | When a user would migrate to gen3 and deploy their release containing properties with special characters, certain flows could not find the correct values to properties anymore or could not find the properties altogether. With this release, special characters such as a backslash do not break properties after deployment. | ||
| 75 | |||
| 76 | //__Hidden flow fragements__// | ||
| 77 | When importing items from the store, flow fragments that are hidden in design will be listed under the versions in create. | ||
| 78 | |||
| 79 | //__Resources disappearances__// | ||
| 80 | Resources would disappear in the flow designer when pressing Cancel on selecting a new resource. With this release, resources without a name will not trigger error messages when users select components. | ||
| 81 | |||
| 82 | //__Error channel for all inbounds__// | ||
| 83 | If there is no custom error handling, Gen3 migration would set the error channel to “errorChannel” only for the first inbound in an entry flow. | ||
| 84 | We added a migration step, such that the error channel is set to “errorChannel” of all inbounds in a flow if the custom error handling is set to false. | ||
| 85 | |||
| 86 | //__Highlighting resources__// | ||
| 87 | The performance of highlighting resources of selected components is improved in Read only mode. | ||
| 88 | |||
| 89 | == **Bug Fixes** == | ||
| 90 | |||
| 91 | //__Topic and event-processor names__// | ||
| 92 | The styling of the event streaming canvas in the Create and Deploy phases has been altered slightly to make topic and event-processor names more readable. | ||
| 93 | |||
| 94 | //__System alignment__// | ||
| 95 | The positioning of Systems across Design, Create and Deploy phases are now synchronized to the position of their respective System in the Capture phase. So, systems are aligned regarding positioning across all phases. | ||
| 96 | |||
| 97 | //__Error checking__// | ||
| 98 | Besides checking error header, the error trigger is now configured to check if an error message contains a term. | ||
| 99 | |||
| 100 | //__Alerting__// | ||
| 101 | For gen3 models, you will no longer receive alert messages for every error message, every log message of 'level' ERROR, and for memory usage above 80%. | ||
| 102 | For gen3 models with event streaming, the threshold to receive the 'Topic approaching maximum size' alert has been increased from 95% of configured size used to 110%. | ||
| 103 | The gen3 configurable trigger for error messages has been extended with the option to check whether the 'last-exception' message contained a certain text. This can be combined with the header-value match. | ||
| 104 | |||
| 105 | //__Unused containers__// | ||
| 106 | Containers are set inactive when they are unused and removed in Design. | ||
| 107 | |||
| 108 | //__Error popups when promoting a release version__// | ||
| 109 | We fixed an issue that a lot of error popups were shown when you promoted a release version to a next environment. | ||
| 110 | |||
| 111 | == **Fancy Forum Answers** == | ||
| 112 | |||
| 113 | As always, this is a gentle reminder to ask questions via the Q&A forum. The Q&A forum is available in the eMagiz iPaaS portal, so we can all benefit from the knowledge within the community. For some inspiration, take a look at these forum answers: | ||
| 114 | |||
| 115 | * [[Message Redelivery blank error message>>https://my.emagiz.com/p/question/172825635703619933||target="blank"]] | ||
| 116 | * [[Timeout error kafka batch creation>>https://my.emagiz.com/p/question/172825635703620012||target="blank"]] | ||
| 117 | * [[SFTP Connectivity: Transfering a whole folder structure>>https://my.emagiz.com/p/question/172825635703632587||target="blank"]] | ||
| 118 | * [[3rd generation runtime with dynamic file pickup / filedrop>>https://my.emagiz.com/p/question/172825635703632732||target="blank"]] | ||
| 119 | |||
| 120 | |||
| 121 | == **Key takeaways** == | ||
| 122 | |||
| 123 | Thanks to all who helped build and those who tested and gave feedback to improve the product. To end this post, here are some key takeaways for you: | ||
| 124 | |||
| 125 | * If you have questions surrounding our Program Increment Planning, please get in touch with [[productmanagement@emagiz.com>>mailto:academy@emagiz.com]] | ||
| 126 | * If you have feedback or ideas for us, talk to the Platypus | ||
| 127 | * Please inform us of new additions to the store ([[productmanagement@emagiz.com>>mailto:academy@emagiz.com]]) so we can all benefit from these. | ||
| 128 | * Clear your browser cache (Ctrl + Shift + Del) | ||
| 129 | * Check out the release notes [here] | ||
| 130 | * Start thinking about how the license tracker can aid your development | ||
| 131 | * Start thinking about major, minor, and patch | ||
| 132 | * Upgrade to the latest build number | ||
| 133 | * Keep making great integrations | ||
| 134 | |||
| 135 | Let's stay in touch and till next time! | ||
| 136 | |||
| 137 | {{info}} | ||
| 138 | ~* Indicates a Beta feature. If you would like to get access to this beta feature, please contact [[productmanagement@emagiz.com>>mailto:academy@emagiz.com]] | ||
| 139 | |||
| 140 | ~*~* Indicates a next-generation-architecture only feature. | ||
| 141 | {{/info}})))((({{toc/}}))){{/container}} | ||
| 142 | {{/container}} | 
