Release Notes 2026-05-11
Version Information
OpenEdge Release | Version Information |
|---|
OpenEdge Release | Version Information |
|---|---|
11.7.21, 12.2.19, 12.8.9, 12.8.11, 13.0.0 | Release 11.7 #89138@2026-05-11 |
Retirement of OpenEdge 11.7
OpenEdge 11.7 has been retired by Progress Software on April 1st 2025. In consequence we urge all customers still using OpenEdge 11 to upgrade to OpenEdge 12.2 or 12.8 as soon as possible.
We are intending to drop the official support of the SmartComponent Library for OpenEdge 11.7 during the second half of the year 2025. We will then no longer ensure that new features of the framework will be usable with OpenEdge 11.7
Customers that are concerned by this intention, should reach out to us as soon as possible, so that we can discuss about a solution.
OpenEdge 13.0 support!
We are pleased to announce that we are not aware of any issues using the SmartComponent Library on OpenEdge 13.0. We hereby declare OpenEdge 13.0 fully supported for the SmartComponent Library as of the release of February 15th 2026.
OpenEdge 12.8 support!
We are pleased to announce that we are not aware of any issues using the SmartComponent Library on OpenEdge 12.8. We hereby declare OpenEdge 12.8 fully supported for the SmartComponent Library as of the release of January 15th 2024.
OpenEdge 12.2 support!
We are pleased to announce that we are not aware of any issues using the SmartComponent Library on OpenEdge 12.2. We hereby declare OpenEdge 12.2 fully supported for the SmartComponent Library as of the release of April 09th 2020.
PASOE / OEMANAGER VS Code Extension
Our first VS Code extension is available in the VS Code marketplace: https://marketplace.visualstudio.com/items?itemName=ConsultingwerkApplicationModernizationSolutionsLtd.oemanager
The extension supports developers with PASOE related routine tasks during development:
checking agent or session status
trimming the PASOE agents
restarting a new agent vai the ping request
Introducing the SmartComponent Library developer forum
Got questions about using the SmartComponent Library? Wish to discuss feature requests with other users of the SmartComponent Library? To facilitate networking in the growing number of SmartComponent Library users and developers, we've added a developer forum on our new home-page. The developer forum can be found at: https://www.consultingwerk.com/support/forum
A login is required to participate in the forum. Don't be shy - create your account today!
Release Notes
Following the release of the OpenEdge 11.7 Release we have completed our testing of the SmartComponent Library on this release of Progress and are proud to announce formal support for the SmartComponent Library on OpenEdge 11.7 with the 2017-04-24 release of the SmartComponent Library. Generally we recommend customers on OpenEdge 11 to upgrade to OpenEdge 11.7 quickly. Starting the 2017-07-14 release we are supporting OpenEdge 11.7 Service Pack 1 (11.7.1).
Starting the 2015-10-09 release the Business Entity Designer will feature a start page with links to most recent release note articles on this site.
With SCL-751 we have adopted native Enums for OpenEdge 11.6. To activate this feature customers must add a definition to products.i. SCL-751 provides details for this.
With SCL-1113 we have modified the templates for SmartWindowForms and SmartTabFolderPages generated from the Business Entity Designer. We have removed the initialization of the viewer controls SmartTableIOState property (value was set to "NoDataSource" within the InitializeComponent method). Customers using their own set of templates should adopt the same fix to their templates.
New Versions of Proparse .NET Assemblies (30 December 2018)
We have updated proparse with further enhancements in this release (see https://github.com/consultingwerk/proparse/releases/tag/4.0.1.1177). Please download the .NET Assemblies ZIP file from our ESD and replace the proparse.net.dll in your environment with the latest one. The new assembly reference is:
|
|---|
|
|---|
As proparse is used by our Business Entity Generator, this new version of the proparse.net Assembly is also relevant for customers not doing GUI for .NET development and require support for parsing new ABL language constructs.
This version of proparse provides additional debug information when errors are thrown from proparse.net.dll.
New Version of the Consultingwerk.SmartComponents Assemly (09 January 2019)
To support the new SmartFilterControl and the "Filter" link between the SmartFilterControl/SmartDynamciFilterControl and a SmartBusinessEntityAdapter or SmartDatasetChildAdapter we have updated the Consultingwerk.SmartComponents.dll. The new Assembly reference is:
<assembly name="Consultingwerk.SmartComponents, Version=2.2.0.49856, Culture=neutral, PublicKeyToken=10603cb31df311b3"/>Customers need to update this Assembly in order to compile the latest releases of the SmartComponent Library.
Hybrid Realm now using IAuthenticationService
We've updated the SmartHybridRealm class used for http authentication to leverage the IAuthenticationService. It is therefor required that for AppServers requiring http Authentication (e.g. REST or Web) the correct IAuthenticationService implementation is registered (using service.xml files).
Customers relying on the previous behavior should ensure that the Consultingwerk.SmartFramework.Authentication.AuthenticationService is regsitered as the IAuthenticationService. This implementation will auhtenticate users against the password stored in the SmartUser database table.
When users with no Login Company set should be able to login using the SmartHybridRealm, it's required to set the Login Company Tennant Domain (similar to the field in the Login Company Maintenance) in the .restapplicationsettings / .applicationsettings, e.g.:
"DefaultAuthenticationDomain": "consultingwerk" |
|---|
"DefaultAuthenticationDomain": "consultingwerk" |
|---|
This is required as the Hydrid Realm Interface from Progress does not provide the domain name to the authentication method.
Web Handler overview
This is an overview of the web handlers supported by this release
| defaultHandler=OpenEdge.Web.CompatibilityHandler
handler1=Consultingwerk.OERA.JsdoGenericService.WebHandler.CatalogWebHandler: /Catalog/{EntityName}
handler2=Consultingwerk.OERA.JsdoGenericService.WebHandler.CatalogsWebHandler: /Catalogs/{PackageName}
handler3=Consultingwerk.OERA.JsdoGenericService.WebHandler.CountWebHandler: /Resource/{EntityName}/count
handler4=Consultingwerk.OERA.JsdoGenericService.WebHandler.ResourceSubmitWebHandler: /Resource/{EntityName}/SubmitData
handler5=Consultingwerk.OERA.JsdoGenericService.WebHandler.InvokeMethodWebHandler: /Resource/{EntityName}/{MethodName}
handler6=Consultingwerk.OERA.JsdoGenericService.WebHandler.ResourceWebHandler: /Resource/{EntityName}
handler7=Consultingwerk.OERA.JsdoGenericService.WebHandler.BusinessServicesWebHandler: /BusinessServices/{OutputFormat}/{PackageName}
handler8=Consultingwerk.Web2.WebHandler.SmartMenuWebHandler: /SmartMenu/{MenuStructureId}
handler9=Consultingwerk.Web2.WebHandler.SmartMenuStructureWebHandler: /SmartMenuStructure
handler10=Consultingwerk.Web2.WebHandler.SmartRoutesWebHandler: /SmartRoutes
handler11=Consultingwerk.Web2.Services.SmartViewsHandler.SmartGridWebHandler: /SmartViews/Grid/{EntityName}/{ViewName}/{DetailTemplate}
handler12=Consultingwerk.Web2.Services.SmartViewsHandler.SmartGridWebHandler: /SmartViews/Grid/{EntityName}/{ViewName}
handler13=Consultingwerk.Web2.Services.SmartViewsHandler.SmartGridWebHandler: /SmartViews/Grid/{CustomViewName}
handler14=Consultingwerk.Web2.Services.SmartViewsHandler.SmartViewerWebHandler: /SmartViewer/Viewer/{EntityName}/{ViewName}
handler15=Consultingwerk.Web2.Services.SmartViewsHandler.SmartViewerWebHandler: /SmartViewer/Viewer/{ObjectName}
handler16=Consultingwerk.Web2.Services.SmartViewsHandler.SmartFormWebHandler: /SmartForm/{FormTemplate}/{EntityName}/{ViewName}
handler17=Consultingwerk.Web2.Services.SmartViewsHandler.SmartFormWebHandler: /SmartForm/{FormTemplate}/{ObjectName}
handler18=Consultingwerk.Web2.WebHandler.SmartMessageWebHandler: /SmartMessage/{MessageGroup}/{MessageNumber}
handler19=Consultingwerk.Web2.WebHandler.GetImageWebHandler: /Image/{FileName}
handler20=Consultingwerk.Web2.WebHandler.SmartValueListWebHandler: /ValueList/{ValueList}
handler21=Consultingwerk.Web2.WebHandler.SmartAttachmentsWebHandler: /Attachments/{Table}/{KeyValues}
handler22=Consultingwerk.Web2.WebHandler.SmartAttachmentWebHandler: /Attachment/{Guid}
handler23=Consultingwerk.Web2.WebHandler.SessionContextWebHandler: /SessionContext
handler24=Consultingwerk.Web2.WebHandler.ContextPropertiesWebHandler: /ContextProperties/{PropertyName}
handler25=Consultingwerk.Web2.WebHandler.ContextPropertiesWebHandler: /ContextProperties
handler26=Consultingwerk.Web2.WebHandler.SessionInfoWebHandler: /SessionInfo
handler27=Consultingwerk.Web2.WebHandler.FileSearchWebHandler: /FileSearch/{FileName}
handler28=Consultingwerk.Web2.WebHandler.ExecuteAblWebHandler: /ExecuteAbl
handler29=Consultingwerk.Web2.WebHandler.SmartLanguagesWebHandler: /Languages
handler30=Consultingwerk.OERA.RestResource.RestEntitiesWebHandler: /Entities
handler31=Consultingwerk.OERA.Swagger.SwaggerWebHandler: /Swagger/{EntityName}
handler32=Consultingwerk.OERA.Swagger.SwaggerRestEntitiesWebHandler: /SwaggerEntities/{OutputType}
handler33=Consultingwerk.Web2.WebHandler.SmartTokenSecurityCheckWebHandler: /TokenSecurityCheck/{ObjectName}
handler34=Consultingwerk.Web2.WebHandler.SmartTokenSecurityCheckWebHandler: /TokenSecurityCheck
handler35=Consultingwerk.Web2.WebHandler.SmartEntityTableMappingHandler: /EntityTableMapping/{EntityName}/{TableName}/{UiTypeCodes}
handler36=Consultingwerk.Web2.WebHandler.SmartTreeRootNodeWebHandler: /SmartViews/TreeRootNode/{rootnodeid}
handler37=Consultingwerk.Web2.WebHandler.SmartTreeChildNodesWebHandler: /SmartViews/TreeChildNodes/{parentnodeid}
handler38=Consultingwerk.Web2.WebHandler.SmartSecurityCheckWebHandler: /IsRestricted/{SecurityRealmCode}/{SecurityItemGuid}
handler39=Consultingwerk.Web2.WebHandler.SmartFieldSecurityCheckWebHandler: /RestrictedFields/{TableName}
handler40=Consultingwerk.Web2.WebHandler.GetImageNamesHandler: /ImageNames
handler41=Consultingwerk.Web2.WebHandler.ExecuteQueryWebHandler: /ExecuteQuery
handler42=Consultingwerk.Web2.WebHandler.TranslationProviderWebHandler: /GetTranslation |
|---|
handler42=Consultingwerk.Web2.WebHandler.TranslationProviderWebHandler: /GetTranslation |
|---|
UTF-8 based deployments available
Starting August 14th 2016 we ship our source code also as UTF-8 encoded. The ZIP files ending with _utf8.zip contain the source code encoded with that code page. The source code in the remaining archives is still encoded in ISO8859-1. Also on Github there is a new branch containing the OpenEdge 11 based source code in UTF-8.
Related article (Progress K-Base): How to get Progress Developer Studio to save in UTF-8 encoding
New Feature Documentation
Download Link
http://esd.consultingwerkcloud.com/
https://github.com/consultingwerk/SmartComponentLibrary
Overview of included tickets
SmartLookup and SmartBusinessEntityLookup now suspend FetchDataOnNavigate and FetchDataFromKeyValueOnNavigate while not visible
The SmartLookup and SmartBusinessEntityLookup classes have been enhanced to suspend the data fetching behavior triggered by the FetchDataOnNavigate and FetchDataFromKeyValueOnNavigate properties while the lookup is not visible. Pending fetch operations are remembered internally and automatically executed when the control becomes visible via the OnVisibleChanged method override. This avoids unnecessary backend calls for hidden lookups and improves application performance. No changes required in customer code.
UiControl now supports server-driven messages and desktop notifications
UiControl has been extended to return Messages and Desktop Notifications from the backend to the client. A new payload class Consultingwerk.CommonUi.Notification (with NotificationText and NotificationType properties supporting Success, Error, Info, Warning, and Default) and its corresponding ListNotification GenericList have been introduced. The SmartUiControlHandlerBase class now processes notifications similarly to messages and displays them via the Infragistics UltraDesktopAlert component, with type-specific icons and captions translated through the SmartFramework translation service. Developers can return notifications from their UiControl server-side event handlers by adding Notification entries to the response, as demonstrated in the updated OrderPresentationService.HandleButtonClick method.
Smart Combo Editor JSON rendering now uses correct casing for key column, display and display substitute fields
The SmartBusinessEntityComboBoxWebRendering and SmartBusinessEntityLookupWebRendering classes now resolve the proper casing of field names when generating JSON output. The keyColumn, displayFields (comma-delimited list), imageField, LookupKeyField, LookupKeyValueColumn, and the entries in LookupFields are now matched against the actual Business Entity ProDataset to return the correctly cased temp-table field names via a new ResolveFieldName helper. No changes required in customer code.
JSON rendering support added for the SmartChatbot component
A new ChatbotWebRendering class has been added (in the same package as FileUploadWebRendering) to provide JSON rendering for the SmartChatbot component. The rendered componentType is 'chatbot' and exposes the configurable options mcpHostUrl, chatTitle, assistantName, and assistantAvatarUrl, with values pulled from the corresponding fields in phAttributesBuffer. Developers can now declaratively configure SmartChatbot instances via JSON, alongside other dynamically rendered form components.
Fixed: Static query generation now handles calculated temp-tables and supports datetime/datetime-tz index fields
Fixed a bug in AbstractStaticDataAccessQueryPlugin where static query generation failed with error 11385 (Indeterminate extent dimension 0 is out of range) for temp-tables without source tables (calculated temp-tables) and silently skipped indexes whose key fields used the datetime or datetime-tz datatypes. The plugin now handles empty source table lists gracefully in DefineQueryAndBuffer / GenerateFillChildTablesMethod and generates static queries for datetime and datetime-tz index fields. No changes required in customer code.
PDSOE Project Configuration converter for the VS Code ABL Language Server added
A new ABL class Consultingwerk.Studio.VsCode.PdsoeConverter and an accompanying launcher procedure convert a Progress Developer Studio for OpenEdge (PDSOE) project configuration (build.config, .propath, .dbconnections and the databaseConnection.xml from the workspace .metadata folder) into an openedge-project.json file for the VS Code ABL Language Server. The launcher provides an ABL Frame-based UI to confirm overwriting an existing openedge-project.json and to prompt for the .metadata folder when it is not located in the parent of the project folder. Developers run the converter via a batch script in Consultingwerk\Studio\bin which starts _progres interactively from the PDSOE project folder.
New SynchronizeDatasetChildQueries() method added to Table-Model for one-shot child query synchronization
The Table-Model in the Consultingwerk.OERA package now provides a new public method SynchronizeDatasetChildQueries() that performs a one-shot synchronization of child relation queries with the current parent record when the model is configured to use dataset queries. Developers can call this method on Table-Model instances where UsingDatasetQuery is TRUE to explicitly synchronize child queries without invoking the full navigation-based reopen semantics provided by ReopenDatasetChildQueries(). If called when dataset queries are not active, a dedicated typed exception in the Consultingwerk.OERA package is thrown to clearly indicate the misconfiguration.
New scl-record-count batch script and record-count.p procedure added for counting records in all connected database tables
A new batch script scl-record-count has been added to Consultingwerk\Studio\bin, which invokes the new record-count.p procedure in Consultingwerk\Studio\Database. When run against a single connected database, the procedure iterates through all non-hidden _File records, creates a dynamic preselect query for each table, and displays the table name, record count, and description. Developers can use this tool from the command line to quickly determine record counts for all tables in a database. Invocation: scl-record-count <db startup parameter>.
Fixed: Release Notes in the Business Entity Designer now render consistently
Fixed an occasional rendering issue in Consultingwerk.Studio.ReleaseNotes.ReleaseNotesControl where the links to release notes were sometimes appended at the beginning of the generated page instead of below their corresponding release block. The HTML generated from the RSS feed and the order in which link nodes are appended have been corrected, so each release block now consistently shows its heading, description, and link together. No changes required in customer code.