[
https://issues.apache.org/jira/browse/CXF-9101?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Jan Philipp updated CXF-9101:
-----------------------------
Description:
Released in 4.0.6 and 4.1.0, there was merged
[https://github.com/apache/cxf/pull/2093] which adds some functionality for
AsyncHTTPConduit.
However, this change results into following api visibility (breaking) change.
* Before CXFHttpRequest#getOutputStream() returns the public type
AsyncWrappedOutputStream (actually a class)
* After CXFHttpRequest#getOutputStream() returns the package(!) protected type
AsyncWrappedOutputStreamBase (actually an interface). Now a public api method
returns a non-public type.
For not breaking existing api signatures and not producing invalid
combinations, this (interface) should be public also. However, if the api
(method) itself should not be public at all, I would suggest a remark in the
notes and removing the public access completely. If the latter one, what would
be an alternative?
In case of asking the context: I'm using winrm4j which has implemented its
client backend with CXF. [See
usage|https://github.com/cloudsoft/winrm4j/blob/806a943a3d68f3a6ad23385375c61a53c7fbec43/client/src/main/java/io/cloudsoft/winrm4j/client/encryption/AsyncHttpEncryptionAwareConduit.java#L105].
Don't be confused, the project I linked looks to be abandoned. I have forked &
updated the project against the [4.x-line
already|https://github.com/hlsolutions/winrm4j/tree/feature/jdk17_jakarta], but
until 4.0.5 there were no issues.
was:
Released in 4.0.6 and 4.1.0, there was merged
[https://github.com/apache/cxf/pull/2093] which adds some functionality for
AsyncHTTPConduit.
However, this change results into following api visibility (breaking) change.
* Before CXFHttpRequest#getOutputStream() returns the public type
AsyncWrappedOutputStream (actually a class)
* After CXFHttpRequest#getOutputStream() returns the package(!) protected type
AsyncWrappedOutputStreamBase (actually an interface). No a public api method
returns a non-public type.
For not breaking existing api signatures and not producing invalid
combinations, this (interface) should be public also. However, if the api
(method) itself should not be public at all, I would suggest a remark in the
notes and removing the public access completely. If the latter one, what would
be an alternative?
In case of asking the context: I'm using winrm4j which has implemented its
client backend with CXF. [See
usage|https://github.com/cloudsoft/winrm4j/blob/806a943a3d68f3a6ad23385375c61a53c7fbec43/client/src/main/java/io/cloudsoft/winrm4j/client/encryption/AsyncHttpEncryptionAwareConduit.java#L105].
Don't be confused, the project I linked looks to be abandoned. I have forked &
updated the project against the [4.x-line
already|https://github.com/hlsolutions/winrm4j/tree/feature/jdk17_jakarta], but
until 4.0.5 there were no issues.
> Invalid api visibility in CXFHttpRequest
> ----------------------------------------
>
> Key: CXF-9101
> URL: https://issues.apache.org/jira/browse/CXF-9101
> Project: CXF
> Issue Type: Bug
> Components: Transports
> Affects Versions: 4.1.0, 4.0.6
> Reporter: Jan Philipp
> Priority: Major
>
> Released in 4.0.6 and 4.1.0, there was merged
> [https://github.com/apache/cxf/pull/2093] which adds some functionality for
> AsyncHTTPConduit.
> However, this change results into following api visibility (breaking) change.
> * Before CXFHttpRequest#getOutputStream() returns the public type
> AsyncWrappedOutputStream (actually a class)
> * After CXFHttpRequest#getOutputStream() returns the package(!) protected
> type AsyncWrappedOutputStreamBase (actually an interface). Now a public api
> method returns a non-public type.
>
> For not breaking existing api signatures and not producing invalid
> combinations, this (interface) should be public also. However, if the api
> (method) itself should not be public at all, I would suggest a remark in the
> notes and removing the public access completely. If the latter one, what
> would be an alternative?
>
> In case of asking the context: I'm using winrm4j which has implemented its
> client backend with CXF. [See
> usage|https://github.com/cloudsoft/winrm4j/blob/806a943a3d68f3a6ad23385375c61a53c7fbec43/client/src/main/java/io/cloudsoft/winrm4j/client/encryption/AsyncHttpEncryptionAwareConduit.java#L105].
>
> Don't be confused, the project I linked looks to be abandoned. I have forked
> & updated the project against the [4.x-line
> already|https://github.com/hlsolutions/winrm4j/tree/feature/jdk17_jakarta],
> but until 4.0.5 there were no issues.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)