Contact Free trial Login

Mule Runtime 4.3.0 Release Notes

Initial Release: April 30, 2020

Mule 4.3.0 includes enhancements, changes, fixes, and patch releases.

New Features and Enhancements

Mule 4.3.0 introduces several features and enhancements.

API Gateway

API Gateway now includes a`disable Policies` annotation. Setting it to true enables you to block the application of policies to the requestor.

In addition, the release introduces several enhancements to resiliency, including a better backoff mechanism and improvements of the policy deployer mechanism.

DataWeave

DataWeave introduces the following:

  • update operator:
    Creating modified versions of objects and arrays is now easier. The update operator enables you to select specific fields to change without changing others.

  • Streaming features and enhancements:

    • The XML reader now supports streaming.

    • The JSON reader now supports streaming for more than arrays.

  • Literal types:
    String, Boolean, and Number values can now be handled as literal types, which enables the definition of enumerations (Enums) and makes function overloading more dynamic.

  • Period and DateTime consistency:
    This feature adds an easy way to operate with periods, transform the result into different units, and decompose the period into its different parts.

  • DataWeave modules:

    • The new Types module enables type introspection at runtime.

    • DataWeave also introduces a number of new functions in existing modules.

    • Deprecated functions and replacements:
      The entrySet, keySet, nameSet, valueSet functions in the Objects module are deprecated in this release and replaced with the functions entriesOf, keysOf, namesOf, valuesOf in the Core module.

    • withMaxSize function:
      The Strings module has a new function that enables you to specify a maximum size for a given value. A value that exceeds the size limit will be truncated. If the size is no greater than the limit, the value remains the same.

    • takeWhile function:
      The Objects module has a new function that iterates over the items in an array items while a condition is true.

    • dropWhile function:
      The Objects module has a new function that iterates over and ignores the items in an array until the specified condition is true.

    • Reader and Writer properties:
      DataWeave introduces a number of new and enhanced reader and writer properties for supported DataWeave formats.

  • Custom MIME types:
    This feature adds a way to define the output MIME type separately from the output data format. It also provides a simpler way of defining output and input formats.

  • Intersection type:
    DataWeave introduces the Intersection type. The intersection type appends Object types. The type takes the form TypeA & TypeB & …​.

  • Performance:
    DataWeave performance is improved for memory usage, functions (like groupBy), and the internal execution engine. Improvements include:

    • Common Subexp Elimination
      To optimize scripts, DataWeave now eliminates common subexpressions by internally using implicit variables for them, meaning the subexpressions are only executed once regardless of how many times they are repeated.

    • Memory Service:
      Memory management is now centralized. Several memory management strategies are included, such as pooling direct memory or using heap memory exclusively.

  • Improvements to parsing error messages:
    Parsing errors now reflect more accurately missing tokens, incomplete definitions, and other common issues. Tips and examples of how to solve the issues are also included.

For more detailed information about these changes, see What’s New in Mule 4.3.

Core Components

The following Core components have new features in this release.

  • Until Successful component:
    Max Retries (maxRetries) and Milliseconds Between Retries (millisBetweenRetries) now support a number or an expression that resolves to a number.

  • Batch Aggregator component:
    This component adds the preserveMimeTypes attribute to makes it easier to handle records from a payload that is in a structured text format, such as JSON or XML.

For more detailed information about these changes, see What’s New in Mule 4.3.

Changes

  • Threading Model

    • The three main thread pools have been combined into one unique thread pool.

    • You can select between the UBER pool strategy (default) or the DEDICATED pools strategy (legacy).

    • You can still customize the thread pools' configuration if necessary.

    • If you are upgrading from earlier Mule 4.x versions, see Upgrading from Mule 4.2/4.1

For more detailed information about this change, see What’s New in Mule 4.3.

Upgrade Requirements

Issue Description

MULE-16681

Updated cipher suites for FIPS140-2 mode (check tls-fips140-2.conf file)

MULE-15596

Added support to Error Handler for "when" filtering for a certain "type". Before 4.3.0 Setting "when" and "type" simple ignores "when" expression

MULE-17800

ParseTemplateProcessor Type Inconsistencies when setting target and target variable

MULE-17472

Use of backslash before Properties escapes the evaluation of them. To have the same behavior as before (backslash being a simple character) add the system property mule.properties.correct.backslash.use=false

September 2020

Patch release version: 4.3.0-20200824

The September update addresses the following issues:

Issue Description

MULE-18694/SE-16719

Resolved an issue that caused applications to fail due to memory consumption when referencing nested subflows (using <flow-ref>).

MULE-18666

Fixed an issue that caused a StackOverflowException error when using the following DataWeave script:

#[output application/json --- message]

MULE-18689/SE-16734

Corrected a memory leak referencing the following class in the runtime logs:

org.mule.runtime.core.privileged.exception.
TemplateOnErrorHandler$
OnErrorHandlerFluxObjectFactorytransactional

MULE-18682

Fixed a problem that caused a ClassNotFoundException after a policy upgrade affecting proxy applications.

MULE-18657/SE-14959

Fixed a problem that prevented primary node initialization in Anypoint Connector for Salesforce (Salesforce Connector).

MULE-18665/SE-16278

Fixed the RegistryLifecycleCallback logger so that it no longer prints the customer’s security key.

MULE-18542/SE-15818

Resolved a thread leak when redeploying an application that uses Anypoint Connector for Database (Database Connector) and references the Oracle JDBC driver.

MULE-18628/SE-16435

Resolved a problem in which applications were unable to retrieve objects from the cache due to serialization issues.

MULE-18623/SE-16933

Corrected a memory leak that occurred when using dynamic configurations.

SE-15453

DataWeave’s XML module now includes a new property to handle escaping > characters.

SE-15249

Fixed DataWeave attribute selector not dispatching to the correct implementation.

SE-15362

Fixed NullPointerException in DataWeave’s XML module.

DW-184/SE-15834

Fixed DataWeave inferred types when the output is undefined storage to recalculate output.

SE-15894

JSON binary values are now encoded into strings consistently across DataWeave versions.

SE-16462

DataWeave now parses single key-value pairs correctly when mixed with conditionals.

SE-16539

Fixed an error that occurred in DataWeave when parsing JSON with whitespace between array elements.

SE-16167

The DataWeave Avro module now correctly converts logical types.

AGW-4287/SE-16981

Fixed an issue that caused object-store deserialization errors when upgrading the internal version of Rate Limiting policy.

SE-17193

Fix a deployment issue that occurred for apps with multiple nested function calls, such as ++, in DataWeave.

SE-17270

Fixed an issue in which the primary node in a cluster remained primary after stopping the runtime, causing applications with a pooling processor on the primary node to stop working.

MULE-18604/SE-12900

Fixed an issue in which NTLM authentication-dancing failed when performing multiple parallel requests requiring renegotiation.

August 2020

Patch release version: 4.3.0-20200727

The August update addresses the following issues:

Issue Description

MULE-18535, SE-16524

Fixed incorrect behavior in which accessing message.message.exceptionPayload.info.Element returned null instead of an error.

MULE-18528

SDK OAuth authorization code-flow references do not have a stereotype making it fail when executed from MUnit.

MULE-18579

Resolved an issue in which when an object store expired, it loaded all deserialized entries into memory, doubling memory consumption.

MULE-18564

Fixed an issue in which using inline proxy configuration in the OAuth module failed to create the requestConfig configuration.

MULE-18569, SE-16282

Resolved an issue in which the Anypoint Connector for Kafka returned the java.nio.file.InvalidPathException: Illegal char <:> exception when accessing filesystem configuration files.

MULE-18548, SE-14272

Fixed an issue in which the Cache scope in a cluster configuration did not effectively monitor the cache in the secondary node.

MULE-18545

Resolved an IndexOutOfBoundsException error that occurred when handling a backpressure error in a source policy.

MULE-16688

Fixed a problem that occurred when using a property placeholder on an import tag with deploymentProperties that caused the placeholders to not be replaced.

MULE-18513

Fixed an issue in which a connector configuration using OAuth caused metadata-resolution problems.

MULE-18504

Resolved an SDK regression in which the component reference in an operation chain was wrongly calculated.

EE-7381

Fixed an issue in which creating a scheduledThreadPool with a coreSize value of 0 could cause high CPU utilization.

SE-16468

Fixed an issue in which DataWeave skipNullOn did not behave properly because the value null was ignored in maps.

SE-16915

Removed unnecessary log messages that appeared when using dynamic objects in DataWeave.

MULE-18196, SE-16894

The fix for the SE-15056 issue causes applications that use custom policies to fail when sharing the ErrorType repository if the app and policy bundle didn’t include all dependencies.

+ You can revert the behavior by setting the mule.share.errorTypeRepository system property to true.

SE-13603

Fixed an issue in which an application using more than one salesforce:replay-channel operation failed with status code 429.

SE-13603, SE-10677, SE-16728

Upgraded the Object Store v2 plugin to version 4.0.27.

July 2020

Patch release version: 4.3.0-20200622

The July update addresses the following issues:

Issue Description

AGW-4211, SE-16370

Fixed an issue in which applications using APIkit and policies with the autodiscovery component incorrectly returned 500 instead of 404.

MULE-18454

Resolved a problem generating XML when creating an artifact declaration that contains a platform-managed OAuth connection provider.

MULE-18475, SE-16232

Fixed a NullPointerException issue on the XML SDK framework when a parameter that has both CONTENT and OPTIONAL values is empty.

MULE-18491, SE-16370

Errors without location values no longer cause policy error handling to behave like a back-pressure error.

MULE-18506, SE-16470

Reverted MULE-18370 because it caused a key collision in the ManagedCursorProvider cache management.

SE-13383

Fixed an issue that occurred while moving corrupted domain object store files to the Garbage folder.

SE-15067

DataWeave now properly handles the #[ sequence inside a String value in Mule operations, such as Logger.

MULE-18375, SE-15704

Fixed a problem in which a custom policy that applied an outbound request changed the behavior of an API by clearing attributes.

SE-15918

Added support for escaped Char sequences on DataWeave settings.

MULE-18458, SE-15925

Fixed a problem that occurred when resolving DataWeave errors and processing the flow stack.

MULE-18439, SE-15995

Fixed an application deployment failure with the loops not allowed error.

SE-16006

Fixed an issue that prevented debugging an application in Studio 7.5 and Mule runtime engine 4.3.

MULE-18462, SE-16038

Resolved an issue in which combining Cache and For Each scopes caused a java.lang.ArrayIndexOutOfBoundsException: 0 error during execution.

MULE-18501, MULE-18500, SE-16088

Fixed a regression with MUnit spy assertions (before-call and after-call) that was introduced in Mule 4.3.0.

MULE-18498, MULE-18480, SE-16095

Fixed an OutOfMemoryError: Metaspace error on applications with multiple concurrent deployments and some redeployments.

MULE-18453, SE-16119

Fixed an issue with backslash-character processing when running Studio on Windows, which caused Test Connection in Anypoint Connector for File to fail when the Configuration property was present.

MULE-18488, SE-16133

Fixed a NullPointerException error that occurred when using Anypoint Connector for Database in a Try scope and running it more than once.

MULE-18489, SE-16281

Resolved the ClassCastException: java.lang.Integer cannot be cast to java.lang.Long error when using Anypoint Connector for Kafka.

SE-16292

Fixed a JSON payload with spaces after an array value failed in DataWeave’s in-memory parser.

MULE-18490, SE-16317

Resolved a problem accessing flow.name in DataWeave transformations.

MULE-18492, SE-16365

Fixed a serialization problem with policies using the 'Rate limit SLA' policy.

SE-16379

Fixed an application start-up error NoSuchBeanDefinitionException: No qualifying bean of type 'org.mule.extensions.java.internal.cache.JavaModuleLoadingCache' available.

SE-16381

Resolved a problem processing DataWeave date expressions when calculating year differences.

SE-16389

Fixed an issue in which DataWeave nested dynamic objects skipped elements.

SE-16431

Cached DataWeave compiled expressions based on string script to avoid an out-of-memory issue on deployment.

MDM-106, SE-16066

Fixed metadata that was not generated correctly when a <ROW> tag was duplicated.

MULE-18431

Corrected problems in which threads hung when using Anypoint Connector for Virtual Machine under load.

MULE-18294

Resolved an issue in which polling source Scheduler components incorrectly restarted on reconnection.

MULE-18440

Fixed a race condition that occurred when a thread looked for policies and invalidated the cache simultaneously.

MULE-18442

Mule no longer creates a default policy manager for each applied policy.

June 2020

Patch release version: 4.3.0-20200521

This patch release consolidates fixes to Mule 4.3.0 since the initial release on April 30, 2020. The fixes extend through June 2020.

Issue Description

AGW-4199

Fixed an error that occurred when accessing Gatekeeper and Analytics policy templates.

SE-15935

Mule application threw the wrong HTTP response status code when api-gateway:autodiscovery was enabled.

MULE-18421

When using a logger to log a value, a result containing ##[ is no longer incorrectly reevaluated.

MULE-18416

Resolved ClassCastException when running an API using the Interception API.

MULE-18397

Fixed an error that occurred when an expression accessed a target-operation payload attribute.

MULE-18390

Fixed an OutOfMemory error that mentioned running out of Metaspace when running MUnit tests.

MULE-18378

When an HTTP Listener is source of the flow, trying to reference a flow variable from the flow’s error response builder, the variable could not be found if a source policy was applied to the Listener.

MULE-18371

Fixed a NullPointerException error that occurred when processing a request and all in-flight cursors were inappropriately closed.

MULE-18370

Fixed an issue that might rarely cause a key collision with the ManagedCursorProvider cache.

MULE-18369

MULE:OVERLOAD exception is thrown when first policy contains a Cache scope and second policy contains a Try scope error-handler.

MULE-18364

Fixed a problem that prevented an application from starting after stopping using Runtime Manager.

MULE-18312

A custom global error handler is no longer ignored when located after a failing flow.

MULE-18306

Fixed a race condition that occurred while disposing flows using a until-successful construct.

MULE-18284

Fixed an issue where a policy deployment failed under certain circumstances because the errorType could not be found when deploying a policy.

MULE-18264

Resolved open JAR file-leak when reading resources, such as keystore, when configuring TLS.

MULE-18255

OCSClient now supports configuring the API version of the service via system property.

MULE-18244

Fixed a classloading issue when connectors that use third-party libraries are not able to load classes if they rely on loadClass(s,b) from CompositeClassLoader.

MULE-18208

When resolving dependencies, a mule-service no longer includes the Test scope dependencies, which caused unnecessary service registrations.

MULE-18196

An application no longer fails to deploy if it has the same custom namespace as that of an applied custom policy.

MULE-18179

Resolved a possible stack overflow on RejectionCallbackExecutorServiceDecorator while trying to generate an XML response.

MULE-18102

Resolved concurrent subflow instantiation problem where the inner processors location was being corrupted.

MULE-16668

Optimized connection-pool validations to avoid excessive and costly checks.

EE-7097

Batch job summary is no longer incorrectly logged twice.

MULE-18310

Optimized application deployments, resulting in performance improvements.

MULE-18205

Optimized FlowProcessMediator#policySuccessError to now create a single router for all exceptions rather than one for each exception or error.

MULE-18172

Fixed ObjectStoreToMapAdapter thrown exceptions when used or accessed concurrently.

MULE-18202

Upgraded groovy dependency to version 3.0.2.

SE-15904

Fixed an issue in which DataWeave’s common subexpression elimination incorrectly reduced two expressions, ignoring middle nodes.

SE-13691

Fixed an issue in which the Scheduler incorrectly ran twice.

MULE-18369

Fixed an overload error that occurred when an API had a combination of two policies using caching and error-handler components.

Initial 4.3.0 Release

Release date: April 30, 2020

The initial 4.3.0 release includes the following known limitations and fixes.

Known Limitations and Workarounds

Issue Description

MULE-18369

API fails when it applies the Caching Policy before the Message Logging Policy or Header Injection Policy.

Fixed Issues

Issue Description

MULE-18305

XmlSdkConfigurationInstance does not delegate methods

MULE-18304

NPE in operations within dynamically invoked sub-flow

MULE-18299

Unexpected run/debug behavior - Flow was terminated abnormally

MULE-18295

Performance overhead in SdkInternalContext#locationSpecificContext

MULE-18286

Error mappings not honored while running application on LazyInit

MULE-18281

ArtifactAstDependencyGraph is not taking configRef parameters into account

MULE-18276

IllegalStateException cannot be cast to EventProcessingException

MULE-18269

XML SDK variables are sent as null with 4.3.0-RC2

MULE-18261

Processed wrapped in a Mono should always recognize itself with a child context

MULE-18259

Smart connector fails if http protocol is not defined for a config that contains another http config

MULE-18248

Illegal type name exception in AIX OS using JDK8

MULE-18240

Scatter Gather resulting in Exception reached PS subscriber for flow

MULE-18238

XmlSdkConfigurationProvider does not propagate Lifecycle methods

MULE-18236

Getting IndexOutOfBoundsException error for a mapping that works in 4.2.2

MULE-18234

App returns correct results, but "Test Connection" FAILS

MULE-18227

NPE with scatter-gather within parallel-foreach

MULE-18200

4.3.0: readUrl getting blocked when file resource is not present

MULE-18197

MUnit test fails when executing XML SDK module

MULE-18189

Interception API: Context Id are swapped for processors in scatter-gather

MULE-18183

Race condition on ProcessingStrategy#dispose

MULE-18178

Max Concurrency not honored in flow-ref

MULE-18177

Add current location to thread names

MULE-18164

Async scope not deploying in a policy

MULE-18161

Simple async operation not working

MULE-18157

Event modifications lost when setting a securityContext

MULE-18155

Dynamic flow-ref must explicitly expect a String on the expressionLanguage

MULE-18148

Memory leak on transactional try with error handlers

MULE-18145

Operation policies are not applied to requester when it is inside XML Connector

MULE-18140

PlatformManaged connection providers do not inject the config name to its delegate

MULE-18138

Every time a connection is created/autowired, its class is looked up in the app classloader

MULE-18129

Extensions-client times out operations after 5 seconds

MULE-18124

When an Exception is raised from a non-blocking SDK operation, an unexpected error is thrown

MULE-18123

Source not being intercepted when exception in smart connector

MULE-18115

Lazy init: Object store already defined with inline IdempotentRedeliveryPolicy

MULE-18094

Pooled Platform Managed Connection Providers fail to be created

MULE-18093

Add process id to the start up splash

MULE-18090

Flow stuck on JMS publish when connector trows an error

MULE-18089

Flow source stopped event if it was not started because of a ComponentInitialStateManager

MULE-18087

Processing strategy not propagated to chains of scopes in policies

MULE-18081

Remove scheduler warning

MULE-18078

DefaultExecutionContext constructor has too much performance overhead

MULE-18077

Performance issues with functional idioms

MULE-18076

Processing strategy not propagated to sub-flow

MULE-18073

Value is not being stored in queue

MULE-18064

Subscription context not propagated to error handlers

MULE-18059

Flow in initial state stopped is started when app is stopped and started

MULE-18040

Scatter-Gather router does not honor route order in aggregated response hashmap when there are 12 or more routes defined

MULE-18036

Error raised with incorrect type

MULE-18030

HttpPolicyPointcutParameters, only use the headers if a pointcut actually needs them

MULE-18025

OutOfMemoryError on multiple policy redeploys

MULE-18020

Fix reconnection for Paged Operations that fail after the first page.

MULE-18010

Spike: Use generated bytecode instead of reflection to invoke operations

MULE-18004

Make constants in AbstractComponent final

MULE-17994

Allow policy dispose to finish inflight events

MULE-17993

Response callback not called when source policy fails with Source policy already disposed

MULE-17992

MTF test timeout when two flow-ref are used

MULE-17987

Error when logging error for component with special characters in password

MULE-17975

Paging Provider is closed twice when it returns an empty page on the first call to getPage.

MULE-17970

Reduce verbosity of SpringRegistry

MULE-17952

Race condition when cloning a DefaultFlowCallStack

MULE-17950

For multi level metadata, same values are retrieved even when changing key parts on SOAP connectors

MULE-17942

Connection is not closed during Connection Exceptions on Paged Operations.

MULE-17939

Operation considers applied policies regarding thread switches

MULE-17933

PersistentXaTransactionContext#poll not honoring timeout

MULE-17929

Thread stucks when undeploying a failing operation policy

MULE-17917

Missing LegacyConnector class in the compatibility module.

MULE-17916

Error on returning a CoreEvent from Soapkit executor

MULE-17911

Application logging "FlowStack : <empty> " when LoggerContext.updateLoggers() is called

MULE-17908

Missing element in xsd for compatibility plugin

MULE-17906

Missing configuration for ConfigOverride parameter with implicit configuration

MULE-17905

OAuth token is not refreshed when a paged operation throws the exception when obtaining the second page.

MULE-17904

Policy execute-next throws error when inside transactional try

MULE-17903

CursorProvider not resolved for Object type parameters

MULE-17902

Version is not compliant with Semver 2.0

MULE-17901

AbstractCursorStreamProviderFactory class cast Exception

MULE-17888

ChoiceRouterObjectFactory is not aware of MuleContexts without validations

MULE-17885

DataWeave EL should not be lazy when not in tooling mode

MULE-17883

ParameterResolvers initialize a new AttributeEvaluator on each execution

MULE-17882

NoSuchBeanDefinitionException: No qualifying bean of type 'org.mule.runtime.extension.api.client.ExtensionsClient' when deploying a domain with a configuration for WSC

MULE-17874

SDK Should not reject dynamic metadata resolution when an optional key is null

MULE-17863

Avoid file leak in TlsConfiguration

MULE-17862

Avoid file leak in ParseTemplateProcessor

MULE-17856

Large overhead at ExecutionMediator

MULE-17849

Flow’s error response builder being executed twice

MULE-17845

NPE on MuleArtifactContext#resolveErrorType while resolving empty raise-error element

MULE-17843

When smart connector in a policy has a parameter with an invalid DW, it hangs

MULE-17833

Contention when instantiating a FileStoreInputStreamBuffer

MULE-17832

Flow’s error response builder being executed when a policy fails

MULE-17819

ComponentLocationVisitor creates wrong Locations for Connections

MULE-17814

Infinite Loop when setting -Dmule.classloading.verbose=true

MULE-17813

SourcePolicyContext is created and added even if no policies apply

MULE-17812

Refresh Dance not executed after TokenExpiredException

MULE-17800

ParseTemplateProcessor Type Inconsistencies when setting target and target variable

MULE-17791

Unneficient copying of variables and internal params in EventBuilder

MULE-1778]

Add a compile() method on the ExpressionLanguage

MULE-17770

Allow UTF-8 in disposition content headers for http request

MULE-17766

Race condition on recursive check in flowRef with scatterGather

MULE-17765

Validation module does not map MULE:EXPRESSION errors to custom application errors and error logging differs when error is raised in sub-flow

MULE-17763

Excesive contention on CursorManager#manage()

MULE-17762

MuleContext.getSecurityManager() accesses the registry on every invocation

MULE-17754

NoSuchElementException when using TransformationService with global errorHandler

MULE-17750

High contention on streaming ByteBuffer pool

MULE-17747

Event context termination callbacks not called on some situations

MULE-17741

FirstSuccessful implementation is blocking

MULE-17730

Fix lazyinit for email config in a domain

MULE-17726

LazyMuleArtifactContext is not disposing correctly components

MULE-17725

DomainClassLoaderFactory doesn’t remove cached class loaders on dispose

MULE-17698

OAuth 2 Client Credentials not resolving dynamic metadata

MULE-17696

Optional ParameterGroups are required to be exported

MULE-17692

TypedValue throws NPE when calling .toString() on null value.

MULE-17689

DefaultMetadataCacheManager is not reusing the ObjectStore partition

MULE-17686

NPE when stream is remanaged after previous managing decorator is collected

MULE-17671

NPE in Policy is producing mule to hang

MULE-17668

AST: Ref parameters with null values are marked as missing dependencies

MULE-17661

NPE when trying to retrieve metadata using JMS connector

MULE-17659

Custom Configuration Properties' parameters cannot depend on Deployment Properties

MULE-17588

Lazy init: <notifications ..> component not being initialized

MULE-17560

DefaultPersistentMetadataCacheManager is created per application context therefore the shared OS partitioned fails with concurrency

MULE-17541

Lazy init: <object class="…​" '/> not lazy initialized

MULE-17530

Remove flatMap from CompositeOperationPolicy#applyNextOperation

MULE-17529

Remove String.format from PolicyEventMapper

MULE-17524

Set instead of List generating inconsistencies resolving dependencies

MULE-17522

Fix case for domains in LazyInit on AST

MULE-17521

Avoid using an AutoCloseInputStream for streams

MULE-17518

Don’t generate schemas in test runner

MULE-17517

Source onTerminate callback should run on its own scheduler

MULE-17515

Create corrupted files directory before attempting to move files

MULE-17510

MetadataOutputDelegate always setting isDynamic to false for MetadataAttributes

MULE-17507

Remove unused legacy processing strategies

MULE-17505

Runtime is not starting ConnectionProviders during metadata resolution phase

MULE-17486

System.gc() called multiple times when disposing ClassLoaders

MULE-17480

Http requester can’t handle large headers in Mule 4

MULE-17472

Configuration property output not correct when prefix is escaped

MULE-17466

Maps should not be required to have getters

MULE-17451

Top level object stores should be started sooner

MULE-17449

ManagedCursors allow access to unmanaged provider

MULE-17431

ExtensionMessageSource requires FlowConstruct to be root element

MULE-17429

Workaround for MMP-499 in runtime

MULE-17426

Stacktrace is logged when undeploying a policy

MULE-17421

RoundRobin implementation is blocking

MULE-17416

ComponentModel equals/hashCode ignoring location

MULE-17415

Polling Sources fail to pick the same item multiple times (Regression)

MULE-17409

MetadataCacheIdGenerator for configuration elements is not taking into account parameters and only using DslTagId hash

MULE-17401

Scheduler source should route emitted message through FlowProcessMediator

MULE-17398

Operations that return a PagingProvider do not populate the type catalog properly

MULE-17390

MessageProcessPhase and MessageProcessTemplate are no longer used

MULE-17386

CommonSourcePolicy callback invoked twice when event is failed

MULE-17384

Extensions maven plugin not honoring extensions dependencies

MULE-17383

High CPU usage by VM Listeners with Persistent queues

MULE-17373

Final "catch-all" check for error handlers does not account for ANY matcher

MULE-17362

Top-level pojos from extensions do not have annotations

MULE-17359

CPU Light thread pool exhausted due to a testConnectivity when DynamicConfiguration is created

MULE-17346

Move ParameterDslDeclarationEnricher to extensions-api

MULE-17341

Referenced subflows are not being started after stop-start the application

MULE-17333

Missing hashCode method in TypedValueTypeAnnotation

MULE-17331

ParameterGroup with showInDsl property set and isOneRequired fails to instantiate operation

MULE-17330

Race condition when the same CursorProvider is managed twice

MULE-17322

ComponentResultJsonSerializer uses TCCL to load by SPI type annotations contributed by extensions-api

MULE-17313

Transaction began using TryScope are not switching to IO

MULE-17311

Services started by an app plugin retain app classloader after reploy/undeploy

MULE-17307

MetadataTypes from the extension model have different instances representing the same type

MULE-17300

DefaultArchiveDeployer#deployPackagedArtifact doesn’t redeploy when receives an URI

MULE-17298

Splash screen does not list odd named patches

MULE-17296

CursorProvider wrongly marked as a consumable class

MULE-17293

Stereotypes enrichment is done before all types are determined

MULE-17288

CacheId for fetching metadata keys should be broader

MULE-17277

Websockets dropped after 30 seconds idle

MULE-17267

Race condition on source shutdown and restart on connection exception

MULE-17264

Reintroduce the event buffering when dispatching to a flow

MULE-17250

POC on Remove flatMap in ModuleFlowProcessingPhase$FlowProcessor

MULE-17240

MultiMap is losing the order when converting to ImmutableMultiMap

MULE-17225

Loader constraint violation when trying to deploy application.

MULE-17223

MuleApp with Salesforce Connector leaking MuleApplicationClassLoader after undeploy or hotdeploy

MULE-17218

Mule SDK is leaking extensions configurations over the time

MULE-17210

Too many ephemeral events are created just to set a variable

MULE-17182

CursorProvider set in variables are not managed

MULE-17168

Remove softreferences for app classloaders to avoid OOM on redeploy

MULE-17166

Wrong group id for HTTP Connector in BundlePluginDependenciesResolver

MULE-17112

Internal libraries of a plugin are overridden by a sharedLib fron an app

MULE-17110

NTLM authentication with dynamic credentials is successful despite credentials changes

MULE-17105

Typo in 'secutiry' package

MULE-17096

NullPointerException when lazy initializing subflow with async scope

MULE-17091

Object streams not automatically closed if <non-repeatable-iterable> option is selected

MULE-17082

Race condition on test connectivity while deploying applications

MULE-17081

PipelineMessageNotificationListener returns a PipelineMessageNotification with null event when an exception is raised in the Mule flow.

MULE-17077

PersistentQueueTransactionContext#poll not honoring timeout

MULE-17065

Scatter gather and Parallel Foreach are not working inside error handler

MULE-17061

Optimization to avoid thread switch in PS is broken

MULE-17055

@OutputJsonType doesn’t work correctly with array operations

MULE-17051

Default Error Handler should be looked up after initialization

MULE-17050

SDK Non Blocking operation and policy is not returning a response under load

MULE-17048

Race condition when stopping a flow with an inflight event in an async block

MULE-17045

Connections are not closed when streaming operation fails

MULE-17025

ErrorHandler raising error not working

MULE-17023

Nested Try is rolling back tx created by outer try

MULE-17022

Transformation resolver failing to found transformer between byte array and inputStream

MULE-17019

Unauthorize operation does not reset ConnectionProviders

MULE-17007

@OutputJsonType does not set metadata type id

MULE-16995

Shared runtime deps in app mess up classloading

MULE-16994

Use of cache instead of WeakHashMap to avoid infinite loop in DefaultLifecycleInterceptor

MULE-16991

Race condition when invalidating cached connections

MULE-16987

Interception API: Parameters of smart connector not intercepted

MULE-16986

XA Transactions fail to rollback on ConnectionException

MULE-16983

Reconnection should not retry when resource has joined active transaction

MULE-16982

ArrayOutOfBoundException when creating custom scheduler

MULE-16979

Review choice

MULE-16974

FTP reconnection strategy repeat the "start delay" wait time

MULE-16965

MuleRuntimeException when creating namespace for custom error

MULE-16964

TryScope with no tx fails within subFlow+async

MULE-16952

Publisher returned by applyWithChildContext not completed when source is completed

MULE-16936

Mule 4 JMS Bridge (ActiveMQ) scenario stops working after a certain time

MULE-16920

"Cannot process event as 'flow' is stopped" when disposing and reinitializing source

MULE-16899

ClassCast exception when registry lookup finds no match

MULE-16896

Bound connections not released on TransactionException

MULE-16894

IllegalStateException in Polling Source when cluste node is shutting down

MULE-16892

Error handler being executed twice when flow ref is involved

MULE-16891

flowTrace OoM when using foreach with large collections

MULE-16890

AdoptJdk shown as un unsupported vendor

MULE-16889

DefaultDomainManager#getDomain should retrieve a compatible version of the required domain

MULE-16878

StringToEnum Transformer should have different names for each extensionModel

MULE-16872

Async in a transaction executes in the same thread as the transaction

MULE-16856

Starting a flow should fail when a task is rejected from scheduler.

MULE-16853

ConfigurationProperties does not honor properties hierarchy when having prop resolved with placeholder

MULE-16847

MessageProcessors.processWithChildContext must complete the EventContext

MULE-16841

Password mask regex does not consider dw and non-literal expressions.

MULE-16837

[Policy][OAuth] - Timeout and low TPS

MULE-16836

Cannot find snapshot artifact via resource loader when trying to scaffold an API

MULE-16831

Fix XA transactions with bitronix

MULE-16830

Global Properties are taking precedence over Application Properties

MULE-16824

LazyInit should initialize the Mule configuration at part of the component initializations phase

MULE-16817

Pooled connections are not removed from the pool when they should evict.

MULE-16790

Global ErrorHandler does not resolve transaction

MULE-16786

Dynamic configurations eviction should consider sources as in-flight operations

MULE-16784

MuleClassLoaderLookupPolicy wrongly assumming javax.xml.bind.attachment as system package in Java 11

MULE-16775

OnErrorPropagate in global error handler is not rollbacking tx

MULE-16758

Multithreaded sources are concurrently reconnected more than once

MULE-16753

A transaction is not available error related to execution on a cpuLight thread

MULE-16744

spring.schemas exported from runtime conflict with spring dependencies used in an app

MULE-16730

Interception API: Validation all throws NullPointerException

MULE-16725

Fix race condition in flow lifecycle handling

MULE-16633

Cool Mulesoft logo in splash screen looking bad in windows

MULE-16551

When Policy is present, Event is not serializable

MULE-16527

Remove flatMap in UntilSuccesful

MULE-16463

Remove flatMap in static <flow-ref>

MULE-16462

Remove flatMap in ModuleFlowProcessingPhase$FlowProcessor

MULE-16461

Remove concatMap in XML SDK chain execution

MULE-16285

Interception API: Smart connectors inside scopes are not skipped properly

MULE-16141

SDK is not validating input POJOs to have a default constructor

MULE-16129

Cannot deactivate streaming in operations that return lists/maps of streams.

MULE-15752

InjectParamsFromContextServiceMethodInvoker makes excessive registry lookups

MULE-15599

Serializing an artifact model constructed from serializing a JSON loses data

MULE-10702

Remove double check locking: StaticBulkQueryResolver

MULE-10347

Generics are not resolved for Map implementations

EE-7290

[IBMMQ][Bridge][Daily] TPS Degradation for all IBMMQ_Bridge apps

EE-7289

[JMS Bridge] jms_bridge_transactional app TPS lower than 1

EE-7283

OCS add system property for setting platfotm authentication url suffix

EE-7277

MuleLicenseInterrupter creates a thread named pool-n-thread-m

EE-7276

Regression on http connector

EE-7272

Cache scope storing unneeded data in the store

EE-7268

Possible memory leak when restarting batch applications

EE-7244

Getting "Cannot open a new cursor on a closed stream" error when 0 records are being processed

EE-7243

Batch Aggregator Out of Memory issue

EE-7239

Ambiguous PID when /mule start is Used

EE-7164

Batch Engine is no reinitialized in case app is restarted

EE-7135

TransactionalWrapper is not setting XAResources that are not DirectXASessions as resources to TransactionalManagerWrapper

EE-7100

BTI wrapper not returning XAConnection

EE-7061

Lingering Streaming aggregator input queue transactions while reading

EE-6927

EE version is loading mule-service-weave and mule-service-weave-ee

EE-6889

JdbcMapStore#loadAll(keys) should only load keys passed as parameter

EE-6866

When thread waiting in Hz is interrupted, InterruptedException is not thrown immediately

EE-6860

Escape table names in Microsoft SQL database store query builder strategy

EE-6857

File leak when getting dw file for transformation

EE-6852

Unlock hazelcast lock in the same thread where it was locked

EE-6834

Http Policy Module has no Extension Model

EE-6830

Tracking processors are marked as UNKNOWN instead of OPERATION

EE-6823

Automatically undeployed tooling apps are kept on memory for around an hour

EE-6804

Bitronix Proxy hides connectivity exceptions

EE-6797

Bitronix exception when redeploying an app using XA transactions

EE-6796

Dirty Bitronix transaction log

EE-6780

Corrupt patches not applied but logged as applied

EE-6779

BitronixTransactionManager built before QueueManager initialize causes NPE

EE-6774

Memory leak on com.mulesoft.mule.runtime.bti.internal.xa.QueueManagerXaResourceProducer

EE-6769

Possible race condition when registering ConnectionFactory in Bitronix

EE-6710

Batch RecordFilteringStrategy is not filtering correctly

EE-6682

Table name transforms in cluster object store are only working for postgresql

EE-6574

Organization credentials and encryption key are displayed in plain text in Cluster splash screen.

EE-6377

Batch Aggregator does not support JSON Payload

EE-6374

Sending large bodies causes OOM error in HTTP requester

EE-6338

A project using Netsuite fails with OOM after a few redeploys

EE-6108

Mule 4 Performance degradation on HTTP Proxy Scenarios

MULE-18288

Prevent memory leaks from plugins that use scala

MULE-18262

Allow to customize the default scheduler fixed frequency through a System Property

MULE-18141

Add warnings about not found classes for verbose classloading

MULE-18127

Provide a mechanism to disable log separation

MULE-18050

Improve performance of binding context

MULE-18049

Improve performance of policies lookup when no policies are applied

MULE-18047

Add the component that generated a cursor provider

MULE-18023

Remove spring repo declaration in poms

MULE-18021

Upgrade log4j to 2.13.1

MULE-18017

Improve performance of LifecycleFilterProxy

MULE-17988

Do not use Optional in Either

MULE-17985

Support policy application depending on request headers

MULE-17935

Support Platform Managed OAuth tokens in the SDK

MULE-17910

Remove distinct from child context processing

MULE-17909

Replace calls to flux.mergeWith

MULE-17889

Support repeatable streaming buffering from an existing file

MULE-17844

Remove append-string-transformer

MULE-17829

MessageProcessorNotification listeners not registered by default

MULE-17825

Group error handling internal parameters into unified pojos

MULE-17805

Remove child context used in try

MULE-17804

Remove child contexts uses in policies infrastructure

MULE-17801

Improve performance of MetadataType#hashCode

MULE-17780

Avoid creating an extra intercepting chain when there are no interceptors

MULE-17757

Migrate uses of MessagingExceptionResolver#resolve(MessagingException, MuleContext)

MULE-17743

Remove the use of the eventContext ResponsePublisher

MULE-17703

Validate preexisting config-ref parameter on ConfigRefDeclarationEnricher

MULE-17672

Make DefaultTypedComponentIdentifier#hashCode consistent across runs

MULE-17667

Automatically determine if a parameter is the ComponentId

MULE-17647

Allow domains to be redeployed without restarting its stopped applications

MULE-17536

FunctionalReadWriteLock: Provide withReadLock methods

MULE-17535

Performance improvements for MultiMap immutability

MULE-17525

Allow dynamic configuration for the proxy on the HTTP requester

MULE-17498

XML SDK: avoid container componentModel modification in config macroexpansion

MULE-17497

XML SDK: avoid container componentModel modification in operation macroexpansion

MULE-17487

Use OptionalInt instead of Optional<Integer> for building locations

MULE-17420

XML SDK: link with the inner models on the xml sdk component definition

MULE-17417

Add a method in DeploymentService interface to redeploy applications using a new URI

MULE-17334

Add missing exported/imported types in test extensions

MULE-17281

SDK needs to allow operations to obtain the effective retry policy

MULE-17257

Add more detail to FlowBackpressureException

MULE-17256

Add missing stereotypes to tls:context

MULE-17203

Properly add doc: attributes as component metadata

MULE-17185

Flowref flatmap removal leads to a notorious throughput decrease in the static-flow-ref-subflow case

MULE-17161

Allow SDK to specify that certain configs should never be used in an implicit way

MULE-17114

Add the notImported information from MULE-17112 into the plugins packager

MULE-17111

Create API to propagate a whole custom event when an error occurs in a Processor

MULE-17079

Remove flatMap from ProactorStreamProcessingStrategy#proactor

MULE-17078

Remove dependency of transactions infrastructure on the MuleContext

MULE-17066

ExecutableComponent api should provide a way to mutate the child event that is going to be created

MULE-17060

Use the default ProcessingStrategy for policies instead of a custom one

MULE-17001

Avoid unneeded message creation in source callback

MULE-16990

Improve troubleshooting logging for XA transaction

MULE-16980

Allow maven dependency resolution to always update snapshot dependencies

MULE-16954

Improve logging infrastructure performance

MULE-16937

SDK should no longer that at least one Content parameter to be primary

MULE-16928

Review and improve the change for MULE-16919

MULE-16909

Support custom parameters in OAuth Dance

MULE-16908

Support Client Credentials grant type in the SDK

MULE-16881

migrate app deployment file to 4.1

MULE-16871

Test performance improvement of backpressure check before policy execution

MULE-16861

Normalize namespace usage in ComponentIdentifier between runtime and DataSense

MULE-16860

Decouple DataSense from ComponentModel

MULE-16851

Implement CompositeConverter#toString to aid in transformers troubleshooting

MULE-16843

Move backpressure check before policy application

MULE-16838

until-successful attributes should support expressions

MULE-16755

ObjectStore expire: account for inconsistencies that may occur in cluster

MULE-16684

Make default processing strategy the same as the one for flows

MULE-16513

Perform flow backpressure check before source policies are applied

MULE-16491

pattern matching for error types in error handlers' type attribute

MULE-16215

Make infrastructure parameters to appear as not require for metadata

MULE-15645

Enable flowStack by default

MULE-15596

Error Handler: Add support for "when" filtering for a certain "type"

MULE-982

Logged error should suggest how to enable flowstack

EE-6898

Add a way to configure the hazelcast property MERGE_FIRST_RUN_DELAY_SECONDS

EE-6873

Replace slashes with underscores in TableNameNormalizer

EE-6867

HazelcastLockProvider should call MapNameNormalizer method to normalize map names

EE-6864

Escape table names in PostgresSQL database store query builder strategy

EE-6760

Make Bitronix XA connection pool configurable

AGW-3996

Operation policies are not applied to requester when it is inside XML Connector

AGW-3921

Failing to track an api might cause incomplete initialization.

AGW-3908

When an unhandled exception is thrown while deploying a policy, the deployer dies.

AGW-3816

Fix Mule OAuth authentication failure when Using Client-ID/Client-Secret of Child BG

AGW-3739

API is not getting unblocked by Gatekeeper when stopping and starting it from Runtime Manager.

AGW-3506

Analytics only being notified for one app.

AGW-3375

MapDB is corrupting and stops loading / storing contracts.

AGW-3181

Log indicating client id or secret are not provided is never shown.

AGW-3162

Stacktrace logged after redeploying offline policy with multiple api pointcuts.

AGW-3143

Fix Class Loader Issues generated by getLoggingClassLoader.

AGW-3142

Upgrading policy version is not using new policy jar.

AGW-3105

Requester policy hangs when headers in requester expression are null.

AGW-3004

Policy which does not need IdentityManagement still has it in config Data.

AGW-2215

In a policy, when using requester with url instead of request-config, it explodes.

AGW-4022

Remove runtime version from templates of default policies.

AGW-4008

Update jackson library to latest 2.10.x version

AGW-3990

Must upgrade handlebars library version to 4.5.3

AGW-3952

Added ability to ignore API’s base path when matching resource level policies.

AGW-3877

Improve performance in policies

AGW-3840

Add flow name and application name fields, when sending Analytics info to third party systems.

AGW-3749

Analytics engine improvements, data recollection.

AGW-3711

Enhance User-Agent sent by Gateway to Anypoint

AGW-3670

Enable blocking policies being applied to the requester by using "disablePolicies" annotation.

AGW-3550

Change Analytics Returning mechanism when no response is set.

AGW-2090

Add 400, 412 and 502 to the backoff status codes

DataWeave

  • Fix (SE-15642): Index based descendant selector should work as indexing from descendant selector.

  • Fix: Make error dumper include variables.

  • Fix (DW-133): Reuse instance of java when lazy value expressions.

  • Fix (DW-108): MappingCodeGenerator disregards order of arrow mappings when generating script.

  • Fix (SE-8056): Module is not correctly generated when there are recursive types.

  • Fix (SE-15159): Adding a property for security.

  • Fix (DW-126): Wrong type checking between close object and object with fields.

  • Fix: Wrong type checking when calling mapObject with null.

  • Fix (DW-104): Avoid indexWhere fo boxing and unboxing of char and booleans.

  • Fix (SE-14421): Avoid file leaks on indexed files.

  • Fix (SE-14606): Make fromBase64 and toBase64 not to propagate schema for Backwards compatibility.

  • Fix (DW-102): Substring after and Substring After Last should take into account the length of the text.

  • Fix (SE-14623): Fixing Enum Types in Avro.

  • Fix (DW-98): Selecting same part content of different types multiple times should return same content that is in the multipart.

  • Fix (SE-14561): Add support for union type of any kind in Avro.

  • Fix (SE-12726): Do not call to the get() function of a future.

  • Fix deferred mode leaving streams unclosed.

  • Fix (MDF-359): Make stack growable instead of fixed size to avoid unnecessary memory allocation.

  • Fix (MDF-358): Parsing error with single key value pair object.

  • Fix (MDF-357): Adding support for builder static methods for non interfaces.

  • Fix (SE-14264): If not content type is set then binary should be used.

  • Fix (SE-13571): Equal operator for object was affected by the change empty uri and none namespace should be the same.

  • Fix (SE-13571): Empty namespaces should be taken into account as they may be overriding default namespaces.

  • Fix (MDF-355): Avoid creating java writer settings when it is not necessary.

  • Fix: Improve string append performance.

  • Fix: Type parameters where not correctly instantiated when used inside a lambda.

  • Fix: Type resolution on dynamic return type should take into account a specified type.

  • Fix (MDF-352): Split function should take into account writer properties configuration and inferred mimeType properties.

  • Fix: Reduce object allocation in JSON String escaping also fix key length.

  • Fix: Add support for period coercion to number.

  • Fix: GC overhead issue with SeekableStream and EvaluationContext.

  • Fix (SE-13600): Avoid logging the amount of read bytes on range selector over binary.

  • Fix (SE-13440): Avoid registering InMemory DataSources as Closeables as it is not required.

  • Fix: GroupBy now keeps order and performance improvement on groupBy.

  • Fix: Improve performance of reduce array of objects into a single object.

  • Fix (SE-13334): Lower needs to say that works with Comparable types.

  • Fix (SE-13495): Output writer properties should be taken into account when expected data type is used.

  • Fix (SE-12381): Execute simple script on startup to warmup classloader.

  • Fix (SE-12381): Load DataFormats on startup and also load other modules too.

  • Fix (MDF-338): Add com.mulesoft.dw.directbuffer.disable to disable direct buffer.

  • Fix: Capture groups may return null on conditional groups.

  • Fix: Avoid memory leak when automatic coercion of operations.

  • Fix (SE-12381): Make Core to be loaded at statup time.

  • Fix (SE-13334): Fix documentation of max function.

  • Fix (SE-13172): CSV parser for files bigger than 2G.

  • Fix (SE-13071): DataWeaveTypeEmitter should escape literal strings.

This version of Mule runtime is bundled with the Runtime Manager Agent plugin version 2.4.5.

Was this article helpful?

💙 Thanks for your feedback!