Problemas ao fazer com que o pacote OSGi do Apache httpcomponents HttpClient 4.3.x funcione no Apache Karaf 2.3.x
-
21-12-2019 - |
Pergunta
Ao tentar instalar o Pacote httpclient-osgi 4.3.2 (org.apache.httpcomponents:httpclient-osgi:bundle:4.3.2 conforme especificado no Site HC) em um Contêiner Apache Karaf OSGi, estou recebendo o seguinte relatório de erro:
karaf@root> install mvn:org.apache.httpcomponents/httpclient-osgi/4.3.2
Bundle ID: 60
karaf@root> start 60
Error executing command: Error starting bundles:
Unable to start bundle 60: Unresolved constraint in bundle
org.apache.httpcomponents.httpclient [60]: Unable to resolve 60.0:
missing requirement [60.0] osgi.wiring.package;
(&(osgi.wiring.package=org.apache.http.concurrent)(version>=4.3.0)
(!(version>=4.4.0)))
Ao inspecionar os cabeçalhos, parece que as dependências que ele tenta carregar estão marcadas como Pacote Privado e classes podem ser encontradas no pacote JAR:
karaf@root> headers 60
=>
...
Private-Package =
org.apache.commons.codec,
org.apache.commons.codec.binary,
org.apache.commons.codec.digest,
org.apache.commons.codec.language,
org.apache.commons.codec.language.bm,
org.apache.commons.codec.net,
org.apache.http,
org.apache.http.annotation,
org.apache.http.concurrent,
org.apache.http.config,
org.apache.http.entity,
org.apache.http.impl,
org.apache.http.impl.entity,
org.apache.http.impl.io,
org.apache.http.impl.pool,
org.apache.http.io,
org.apache.http.message,
org.apache.http.osgi.impl,
org.apache.http.params,
org.apache.http.pool,
org.apache.http.protocol,
org.apache.http.util
Ao mesmo tempo, o org.apache.http* também é definido como Pacote de importação pacotes:
...
Import-Package =
javax.crypto,
javax.crypto.spec,
javax.net,
javax.net.ssl,
javax.security.auth.x500,
org.ietf.jgss,
org.osgi.framework;version="[1.5,2)",
org.osgi.service.cm;version="[1.3,2)",
org.apache.commons.logging;version="[1.1.0,1.2.0)",
net.sf.ehcache;resolution:=optional,
net.spy.memcached;resolution:=optional,
org.apache.http.concurrent;version="[4.3.0,4.4.0)",
org.apache.http.message;version="[4.3.0,4.4.0)",
org.apache.http.impl.entity;version="[4.3.0,4.4.0)",
org.apache.http.entity;version="[4.3.0,4.4.0)",
org.apache.http.protocol;version="[4.3.0,4.4.0)",
org.apache.http.impl.pool;version="[4.3.0,4.4.0)",
org.apache.http;version="[4.3.0,4.4.0)",
org.apache.http.params;version="[4.3.0,4.4.0)",
org.apache.http.util;version="[4.3.0,4.4.0)",
org.apache.http.io;version="[4.3.0,4.4.0)",
org.apache.http.impl.io;version="[4.3.0,4.4.0)",
org.apache.http.config;version="[4.3.0,4.4.0)",
org.apache.http.pool;version="[4.3.0,4.4.0)",
org.apache.http.impl;version="[4.3.0,4.4.0)"
O que parece fazer com que Karaf tente encontrar exportações para os pacotes e não consiga ativar o pacote.
Há algo errado com este manifesto do pacote?Ou eu estou esquecendo de alguma coisa?
PS:Tentei versões mais antigas 4.3.xe Karaf 2.3.x - mesmo resultado.
Solução
Você precisa do pacote HttpCore OSGi e de um pacote exportando APIs do Commons Logging para satisfazer as dependências necessárias do pacote HttpClient OSGi.