Please see my comments inline.

From: Santiago Miguel Aranda Rojas 
Sent: Wednesday, June 17, 2009 3:02 AM
To: [email protected] ; [email protected] 
Subject: Re: Fwd: Problem with "implementation.osgi" reference


Ok. 
I have checked and I don´t need to write code in order to register SCA node. 


Tuscany is trying to register the node with both options
* With "SCA-Composite: true" in the manifest.mf 

<rfeng>The value should be a path to the composite file within the 
bundle</rfeng>

* Without SCA-Composite header but with a OSGI-INF/sca directory.


The second option has a problem using Eclipse. I have seen the source code of 
NodeManager.java and "isSCABundle" method. bundle.findEntries("OSGI-INF/sca", 
"*", false) is not working correctly in Eclipse because tries to find these 
files in /OSGI-INF/sca but they are really in /src/main/resources/OSGI-INF/sca. 
When I pack the bundle into a jar I have the right structure. But it is not 
important. I have copied this structure into the root of my Eclipse project.

<rfeng>Good catch.</rfeng>




I have a new error with both options. Tuscany recognizes the bundle as SCA 
bundle but 


17-jun-2009 11:41:01 org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl 
configureNode
INFO: Loading contribution: bundleentry://33/
Could not load resource 
META-INF/maven/es.amivital.calculatorservice2/CalculatorService3/pom.properties

<rfeng>This is really strange.</rfeng>

17-jun-2009 11:41:01 org.apache.tuscany.sca.node.osgi.impl.NodeManager 
bundleStarted
GRAVE: java.lang.NullPointerException
org.oasisopen.sca.ServiceRuntimeException: java.lang.NullPointerException
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl$NodeImpl.<init>(NodeFactoryImpl.java:579)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl$NodeImpl.<init>(NodeFactoryImpl.java:562)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl.createNode(NodeFactoryImpl.java:506)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeManager.bundleStarted(NodeManager.java:96)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeManager.bundleChanged(NodeManager.java:119)
at 
org.eclipse.osgi.framework.internal.core.BundleContextImpl.dispatchEvent(BundleContextImpl.java:1210)
at 
org.eclipse.osgi.framework.eventmgr.EventManager.dispatchEvent(EventManager.java:195)
at 
org.eclipse.osgi.framework.eventmgr.ListenerQueue.dispatchEventSynchronous(ListenerQueue.java:141)
at 
org.eclipse.osgi.framework.internal.core.Framework.publishBundleEventPrivileged(Framework.java:1558)
at 
org.eclipse.osgi.framework.internal.core.Framework.publishBundleEvent(Framework.java:1509)
at 
org.eclipse.osgi.framework.internal.core.BundleHost.startWorker(BundleHost.java:355)
at 
org.eclipse.osgi.framework.internal.core.AbstractBundle.resume(AbstractBundle.java:350)
at 
org.eclipse.osgi.framework.internal.core.Framework.resumeBundle(Framework.java:1118)
at 
org.eclipse.osgi.framework.internal.core.StartLevelManager.resumeBundles(StartLevelManager.java:634)
at 
org.eclipse.osgi.framework.internal.core.StartLevelManager.incFWSL(StartLevelManager.java:508)
at 
org.eclipse.osgi.framework.internal.core.StartLevelManager.doSetStartLevel(StartLevelManager.java:282)
at 
org.eclipse.osgi.framework.internal.core.StartLevelManager.dispatchEvent(StartLevelManager.java:468)
at 
org.eclipse.osgi.framework.eventmgr.EventManager.dispatchEvent(EventManager.java:195)
at 
org.eclipse.osgi.framework.eventmgr.EventManager$EventThread.run(EventManager.java:297)
Caused by: java.lang.NullPointerException
at 
org.apache.tuscany.sca.workspace.processor.impl.ContributionContentProcessor.read(ContributionContentProcessor.java:131)

<rfeng>This line doesn't match the latest code in 
ContributionContentProcessor.java. Can you post the lines around?</rfeng>

at 
org.apache.tuscany.sca.workspace.processor.impl.ContributionContentProcessor.read(ContributionContentProcessor.java:1)
at 
org.apache.tuscany.sca.contribution.processor.DefaultURLArtifactProcessorExtensionPoint$LazyURLArtifactProcessor.read(DefaultURLArtifactProcessorExtensionPoint.java:337)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl.configureNode(NodeFactoryImpl.java:369)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl.access$2(NodeFactoryImpl.java:351)
at 
org.apache.tuscany.sca.node.osgi.impl.NodeFactoryImpl$NodeImpl.<init>(NodeFactoryImpl.java:574)
... 18 more


When I was using code in order to register the node it was working Ok. I think 
I need something more. What is sca-contribution.xml. Do I need this file? Where 
should it be ? I don´t know why "Could not load resource 
META-INF/maven/es.amivital.calculatorservice2/CalculatorService3/pom.properties"
 if this file it is from maven and it is not from Tuscany




Thank you very much for your help
------------------------------------------------------------------------------------------------------------











2009/6/16 Raymond Feng <[email protected]>

  You don't have to write the code to start the Node. The node-impl-osgi bundle 
is watching the SCA enabled OSGi bundles and it will start the Node when the 
bundle is started. 


  Thanks,
  Raymond

  From: Santiago Miguel Aranda Rojas

  Sent: Tuesday, June 16, 2009 1:44 AM 

  To: [email protected]

  Subject: Re: Fwd: Problem with "implementation.osgi" reference 



  Sorry I forgot one question.


  I am using this code in order to register CalculatorService as SCA service.


  try {

  //Registrado el servicio SensorNetworkManagement en el dominio SCA
           NodeFactory factory = NodeFactory.newInstance();
           String url = 
ContributionLocationHelper.getContributionLocation(getClass());
           Contribution contrib = new Contribution("c1", url);
           node = factory.createNode("OSGI-INF/sca/bundle.composite", contrib);
           node.start();
       } catch (Throwable e) {
           e.printStackTrace();
       }


  Is it neccesary this??? Can I put composite and component type in 
"OSGI-INF/sca" directory only?  I mean have I to write this code? Does Tuscany 
read these files automatically?




  Does TestService need this code too?




  Thank you very much.









  2009/6/16 <[email protected]>


  So, I have to attach two files (componentType and composite) to my two 
different bundles (TestService and Calculator) and model it as 
"implementation.osgi".   I have TestService in a bundle I will add these two 
file and I will design as "implementation.osgi" .

  But Calculator Service (this is in other bundle) has three components and 
they are all "implementation.java" and it is working OK. How can I put a 
reference to TestService?? Do I need change "implementation.osgi" in 
CalculatorComponent instead "implementation.java"? and is it neccesary for 
AddServiceComponent and SubstractService??

  I will try a example I will copy my files in the email.

  Thank you very much

  Un saludo.
  Santiago Miguel Aranda Rojas
  Telvent Interactiva
  Extension: 35999
  Telefono: 955637418



  "Raymond Feng" <[email protected]>

  "Raymond Feng"
  15/06/2009 18:36
  Para: <[email protected]>, <[email protected]>
  cc:
  Asunto: Re: Fwd: Problem with "implementation.osgi" reference





  To access an OSGi service from the SCA component, you will have to provide
  SCA configurations for the OSGi bundle so that it becomes an SCA component
  using implementation.osgi and the OSGi service becomes an SCA service so
  that the Calculator component can wire to that TestService.

  There are two SCA files you to provide to model the OSGi bundle as an SCA
  component.
  * bundle.componentType to describe what OSGi services or references are used
  in the bundle (We potentially have better approach to introspect the OSGi
  bundle to build this up)
  * bundle.composite to configure the component, for example, setting the
  bindings.

  These files can be in a separate OSGi bundle than the one that owns the
  services/references.

  Thanks,
  Raymond

  From: Santiago Miguel Aranda Rojas
  Sent: Monday, June 15, 2009 4:01 AM
  To: [email protected]
  Subject: Fwd: Problem with "implementation.osgi" reference






  Hi


  I can not understand this sample because there are many new concepts for me.
  For example "bundle.componentType". There is not too much information about
  that . I think I need something more simple. I have attached a picture with
  my idea.


  ** When my SCA service was working I had a main component
  "implementacion.java" with two references to another two components
  (implementation.java). The main component could be invoked as Web Service.


  ** Now, I want another reference to a Service (TestService in the picture)
  that was registered by another different bundle. But this is a OSGi bundle,
  without SCA information, Composite file nor ComponentType file. I mean it is
  a bundle that is registering a service in the OSGi registry. I need have a
  instance wired to this OSGi service in the class of the main Component in
  order to invoke their methods.


  TestService testService;


  //I need testService is not null in order to invoke their methods.
  testService.sayHello();




  I hope you can understand my problem. You can ask me if you want.


  Thank you very mucha

















  2009/6/10 Raymond Feng <[email protected]>

  Please see:

  https://svn.apache.org/repos/asf/tuscany/java/sca/samples/dosgi-calculator/
  
https://svn.apache.org/repos/asf/tuscany/java/sca/samples/dosgi-calculator-operations/

  
http://cwiki.apache.org/confluence/display/TUSCANYWIKI/OSGi+RFC+119+Implementation

  Thanks,
  Raymond


  From: Santiago Miguel Aranda Rojas
  Sent: Wednesday, June 10, 2009 12:07 AM
  To: [email protected]
  Subject: Re: Problem with "implementation.osgi" reference


  Yes, you are right. I was doing some different tests and I copied you a
  wrong composite. I wanted to see if the change of @target made an error in
  tuscany.  But Tuscany doesn4t recognize this error because I think it
  supposes that will be a "remote Component". I can see this in the tuscany
  trace


  ADVERTENCIA: Component reference target not found, it might be a remote
  service running elsewhere in the SCA Domain: Composite =
  
{http://eclipse.org/SensorNetworkManagement/src/main/resources/SensorNetworkManagement}SensorNetworkManagement
  Service = PruebaComponent



  But it is Ok, because the component I want if an Osgi Service registered in
  the Osgi registry.
  I have fixed the error in @target and it is not working yet.


  Do you know any example when an <implementation.osgi> component is used?




  I have tried to change  "xmlns" tag, but it doesn4t work.


  <sca:component name="PruebaComponent">
       <sca:implementation.osgi
  xmlns="http://docs.oasis-open.org/ns/opencsa/sca/200903";
            bundleSymbolicName="RegistroService"
            bundleVersion="1.0.0">
           <sca:properties service="prueba.PruebaImpl">
           </sca:properties>
       </sca:implementation.osgi>
     </sca:component>


  Thank you very much.



  2009/6/10 Raymond Feng <[email protected]>

  The @target is pointing to a wrong componentName/serviceName. It should be
  "Prueba" instead of "PruebaComponent" as the component name is "Prueba".


  From: Santiago Miguel Aranda Rojas
  Sent: Tuesday, June 09, 2009 1:28 PM
  To: [email protected]
  Subject: Re: Problem with "implementation.osgi" reference


  Tuscany 2.02M. The last version I think. April 2009
  ----- Original Message ----- From: Raymond Feng
  To: [email protected]
  Sent: Tuesday, June 09, 2009 7:12 PM
  Subject: Re: Problem with "implementation.osgi" reference


  Are you using Tuscany/SCA 2.x or 1.x?


  From: [email protected]
  Sent: Tuesday, June 09, 2009 9:15 AM
  To: [email protected]
  Subject: Problem with "implementation.osgi" reference



  Hello

  I want to use an osgi service as a SCA component. But I can not access to
  their methods from other Component.  I mean I have created a wired instance
  to the Osgi Service ($Proxy25). It is not "null" but I can not invoke to one
  method because an error is happening

  --->Unable to create SCA binding invoker for local target
  SensorNetworkManagementComponent reference prueba (bindingURI=null
  operation=sayHello)

  This is my composite file. I want to have to two components. The first had a
  reference to the second and it is normal "implementation.java". The second
  is the SCA component that is representing to the Osgi Service that I want to
  recover. This Osgi Service was registered in the Osgi registry by Activator
  class in "RegistroService" bundle.

  <sca:component name="SensorNetworkManagementComponent">
   <sca:implementation.java
  
class="es.amivital.sensornetworkmanagement.sca.SensorNetworkManagementServiceImpl"/>
   <sca:service name="SensorNetworkManagementService">
    <sca:binding.ws
  uri="http://localhost:8085/SensorNetworkManagementComponent"/>
   </sca:service>
  <sca:reference name="prueba" target="PruebaComponent"/>
  </sca:component>


  <sca:component name="Prueba">
       <sca:implementation.osgi
  xmlns="http://tuscany.apache.org/xmlns/sca/1.0";
            bundleSymbolicName="RegistroService"
            bundleVersion="1.0.0">
           <sca:properties service="prueba.PruebaImpl">
           </sca:properties>
       </sca:implementation.osgi>
  </sca:component>

  ***The Java code--> The first component.

  public class SensorNetworkManagementServiceImpl  implements
  SensorNetworkManagementService {
  private Prueba prueba;
  public Prueba getPrueba() {
  return prueba;
  }
  @Reference
  public void setPrueba(Prueba prueba) {
  this.prueba = prueba;
  }
  }

  **Java code       --> The second component. It is another bundle that is
  registering one simple Osgi Service. The interface was

  public interface Prueba {
  public abstract String sayHello();

  }





  This instance (prueba) is not null when an outside client invoke to the
  first component. But if I invoke to one method of this interface, for
  example "prueba.sayHello" I obtained the previous error.

  I have read something about anottations like @AllowsPassByReference or
  @Scope, but I don4t know if they are neccesary . 

Reply via email to