I can't think of any potential problems either, so I gave it back its default constructor and made it the Bundle-Activator for activemq-core.

many thanks
david jencks

On Feb 9, 2010, at 12:25 PM, Guillaume Nodet wrote:

I think it would make sense to make the Activator class the real osgi
activator for activemq-core.
I don't really see why we would not do that, given it's the only way
to use additional transports or other extensions afaik.

On Tue, Feb 9, 2010 at 21:05, David Jencks <[email protected]> wrote:
See AMQ-2601, rev 908182.

Plain spring recognizes the common annotations @PostConstruct and
@PreDeploy.
xbean-spring recognizes the xbean javadoc annotations InitMethod and
DestroyMethod
xbean-blueprint now recognizes both.

I did some testing to check xbean-spring still works but it wasn't very
thorough so if anyone sees a problem please speak up right away.

Also, I added a constructor to the Activator class so it can be used as a blueprint bean, and this seems to work just as well as it being an actual
BundleActivator.

thanks
david jencks

On Feb 6, 2010, at 8:01 AM, David Jencks wrote:


On Feb 6, 2010, at 2:54 AM, Hiram Chirino wrote:

On Sat, Feb 6, 2010 at 5:17 AM, Guillaume Nodet <[email protected]> wrote:

On Fri, Feb 5, 2010 at 21:01, David Jencks <[email protected]>
wrote:

For the geronimo 3 amq integration I've been working on getting amq 5.4
to
run in de-springified osgi/buleprint using the xbean-blueprint
NamespaceHandler I ported. I think I have at least a basic broker
starting
up.

I'd like to make a few changes so this will work better:

1. Several classes use what I think are obsolete spring-isms namely implementing the spring interfaces InitializingBean, DisposableBean,
and
FactoryBean to tell spring stuff. IIUC a more up-to-date technique is
to
set this in the xml or, using xbean, using InitMethod and destroyMethod annotations. For the classes that are otherwise not spring- dependent
I'd
like to switch to the xbean annotations. The classes involved are:


activemq-pool/src/main/java/org/apache/activemq/pool/ PooledConnectionFactoryBean.java

activemq-camel/src/main/java/org/apache/activemq/camel/ component/CamelEndpointLoader.java

activemq-core/src/main/java/org/apache/activemq/spring/ ActiveMQConnectionFactory.java

activemq-core/src/main/java/org/apache/activemq/spring/ SpringSslContext.java

activemq-core/src/main/java/org/apache/activemq/spring/ ActiveMQXAConnectionFactory.java
(has other spring-isms)

activemq-core/src/main/java/org/apache/activemq/broker/util/ LoggingBrokerPlugin.java

activemq-core/src/main/java/org/apache/activemq/broker/util/ CommandAgent.java

activemq-core/src/main/java/org/apache/activemq/filter/ DestinationMapEntry.java


I guess we should also annotate those methods with @PostConstruct and
@PreDestroy annotation.

Are these spring annotations? I'd rather not insert yet more spring-isms
if not really necessary.

I guess I'm slightly worried that our users configurations will jsut
stop working or behave badly without
much warning about it. Can xbean or spring automatically detect such
annotations and do the necessary
processing ?

But I'm ok with the principle.

Yeah i worry about that too.. Another approach could be to take the
class thats using spring interfaces.. lets call it X. (1) rename it to Y. (2) remove the interfaces from Y. Sub class Y and call it X and
add the interfaces back in.

That way you get a new Y class which is free from the spring
dependency yet you still have the original X class with the same
interface definition so that we can maintain a high degree of backward
compatibility.

That's certainly a possibility. However, these xbean psuedo- annotations work with xbean-spring as well as xbean-blueprint so the only people who would see a behavior change would be those who are not using xbean xml. Is
this a large enough audience to keep happy to make this additional
complexity worthwhile? If the @PostConstruct and @PreDestroy annotations are the even more up to data spring-ism would using those be adequate?




In addition, I need to expose

activemq-core/src/main/java/org/apache/activemq/broker/ BrokerService.java
to xbean.

2. To allow other bundles to interact with amq in osgi, it looks like
org.apache.activemq.util.osgi.Activator needs to be run.  One
possibility
would be to just install it as the bundle activator for activemq-core,
this
is what I've tried and appears to work OK. If this doesn't seem like a
good
idea to everyone I think I can just install it as a blueprint bean in a
geronimo bundle.

What would the activator do ?

The activator is already there. I'm not sure exactly what it does, but it
appears to result in connector objects being created using classes
consistent with the broker.

A few I was thinking about for a better activemq / osgi integration are: * make sure we use version ranges everywhere and define which range we
want to
   use for our activemq imports (in camel, we use [2.1,2.2) range
for camel imports and [2,3)
   for other imports

this seems pretty doable...

* rework the discovery mechanism for transports and such so that
it's more OSGI friendly

I haven't thought about this yet.

I guess those are quite independant on the blueprint stuff you're
working on.

I think so.

thanks
david jencks


Comments?

thanks
david jencks





--
Cheers,
Guillaume Nodet
------------------------
Blog: http://gnodet.blogspot.com/
------------------------
Open Source SOA
http://fusesource.com




--
Regards,
Hiram

Blog: http://hiramchirino.com

Open Source SOA
http://fusesource.com/






--
Cheers,
Guillaume Nodet
------------------------
Blog: http://gnodet.blogspot.com/
------------------------
Open Source SOA
http://fusesource.com

Reply via email to