cancel
Showing results for 
Search instead for 
Did you mean: 

Getting error while reading content from alfresco repo

skorde
Champ in-the-making
Champ in-the-making
Hi
I am getting the error while reading content from alfresco repo.I have written following code to read the content and fetch the url
Reference  reference = new Reference(STORE, "8e8a8b97-120e-11de-b631-d97918971f0e", null);
Content[] readResult = contentService.read(new Predicate(new Reference[] { reference  }, STORE,
            null), Constants.PROP_CONTENT);
Content content = readResult[0];
but I am getting the following error on contentService.read method.


xisFault
faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.generalException
faultSubcode:
faultString:
faultActor:
faultNode:
faultDetail:
   {http://www.alfresco.org/ws/service/content/1.0}ContentFault:<ns1:errorCode>0</ns1:errorCode><ns1:message>Not implemented</ns1:message>
   {http://xml.apache.org/axis/}exceptionName:org.alfresco.repo.webservice.content.ContentFault
   {http://xml.apache.org/axis/}stackTrace:
   at org.alfresco.repo.webservice.content.ContentWebService.read(ContentWebService.java:113)
   at sun.reflect.GeneratedMethodAccessor706.invoke(Unknown Source)
   at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
   at java.lang.reflect.Method.invoke(Method.java:597)
   at org.apache.axis.providers.java.RPCProvider.invokeMethod(RPCProvider.java:397)
   at org.apache.axis.providers.java.RPCProvider.processMessage(RPCProvider.java:186)
   at org.apache.axis.providers.java.JavaProvider.invoke(JavaProvider.java:323)
   at org.apache.axis.strategies.InvocationStrategy.visit(InvocationStrategy.java:32)
   at org.apache.axis.SimpleChain.doVisiting(SimpleChain.java:118)
   at org.apache.axis.SimpleChain.invoke(SimpleChain.java:83)
   at org.apache.axis.handlers.soap.SOAPService.invoke(SOAPService.java:454)
   at org.apache.axis.server.AxisServer.invoke(AxisServer.java:281)
   at org.apache.axis.transport.http.AxisServlet.doPost(AxisServlet.java:699)
   at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
   at org.apache.axis.transport.http.AxisServletBase.service(AxisServletBase.java:327)
   at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
   at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269)
   at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188)
   at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:210)
   at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:174)
   at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
   at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117)
   at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108)
   at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:151)
   at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:870)
   at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665)
   at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528)
   at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81)
   at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:685)
   at java.lang.Thread.run(Thread.java:619)

   {http://xml.apache.org/axis/}hostname:MUMSOLHBDMTEST


   at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
   at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
   at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
   at java.lang.reflect.Constructor.newInstance(Constructor.java:494)
   at java.lang.Class.newInstance0(Class.java:350)
   at java.lang.Class.newInstance(Class.java:303)
   at org.apache.axis.encoding.ser.BeanDeserializer.<init>(BeanDeserializer.java:104)
   at org.apache.axis.encoding.ser.BeanDeserializer.<init>(BeanDeserializer.java:90)
   at org.alfresco.webservice.content.ContentFault.getDeserializer(ContentFault.java:146)
   at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
   at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
   at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
   at java.lang.reflect.Method.invoke(Method.java:585)
   at org.apache.axis.encoding.ser.BaseDeserializerFactory.getSpecialized(BaseDeserializerFactory.java:154)
   at org.apache.axis.encoding.ser.BaseDeserializerFactory.getDeserializerAs(BaseDeserializerFactory.java:84)
   at org.apache.axis.encoding.DeserializationContext.getDeserializer(DeserializationContext.java:464)
   at org.apache.axis.encoding.DeserializationContext.getDeserializerForType(DeserializationContext.java:547)
   at org.apache.axis.message.SOAPFaultDetailsBuilder.onStartChild(SOAPFaultDetailsBuilder.java:157)
   at org.apache.axis.encoding.DeserializationContext.startElement(DeserializationContext.java:1035)
   at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.startElement(AbstractSAXParser.java:533)
   at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanStartElement(XMLNSDocumentScannerImpl.java:330)
   at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(XMLDocumentFragmentScannerImpl.java:1693)
   at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:368)
   at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:834)
   at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:764)
   at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:148)
   at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1242)
   at weblogic.xml.jaxp.WebLogicXMLReader.parse(WebLogicXMLReader.java:133)
   at weblogic.xml.jaxp.RegistryXMLReader.parse(RegistryXMLReader.java:153)
   at javax.xml.parsers.SAXParser.parse(SAXParser.java:375)
   at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227)
   at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696)
   at org.apache.axis.Message.getSOAPEnvelope(Message.java:435)
   at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62)
   at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206)
   at org.apache.axis.client.Call.invokeEngine(Call.java:2784)
   at org.apache.axis.client.Call.invoke(Call.java:2767)
   at org.apache.axis.client.Call.invoke(Call.java:2443)
   at org.apache.axis.client.Call.invoke(Call.java:2366)
   at org.apache.axis.client.Call.invoke(Call.java:1812)
   at org.alfresco.webservice.content.ContentServiceSoapBindingStub.read(ContentServiceSoapBindingStub.java:421)
   at org.alfresco.khub.webservice.KHubWebService.createNewContent(KHubWebService.java:117)
   at com.crisil.server.KhubServiceImpl.saveContent(KhubServiceImpl.java:91)
   at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
   at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
   at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
   at java.lang.reflect.Method.invoke(Method.java:585)
   at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:527)
   at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:164)
   at com.google.gwt.user.server.rpc.RemoteServiceServlet.doPost(RemoteServiceServlet.java:86)
   at javax.servlet.http.HttpServlet.service(HttpServlet.java:763)
   at javax.servlet.http.HttpServlet.service(HttpServlet.java:856)
   at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:225)
   at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:127)
   at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283)
   at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:175)
   at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3214)
   at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
   at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
   at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:1983)
   at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:1890)
   at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1344)
   at weblogic.work.ExecuteThread.execute(ExecuteThread.java:209)
   at weblogic.work.ExecuteThread.run(ExecuteThread.java:181)

7 REPLIES 7

sisao
Champ in-the-making
Champ in-the-making
{http://www.alfresco.org/ws/service/content/1.0}ContentFault:<ns1:errorCode>0</ns1:errorCode><ns1:message>Not implemented</ns1:message>

that means that the reference you've provided is not working, how is the STORE object declared?

Reference reference = new Reference(STORE, "8e8a8b97-120e-11de-b631-d97918971f0e", null);

in the above reference the path is set to "null".

You should think about providing the full code you're trying to run.

Regards.

skorde
Champ in-the-making
Champ in-the-making
Hi
I am trying to read content already uploaded in Alfresco repo for that I have written following java class.Please have a look and suggest any changes
   public static void main(String[] args) {
      String downloadURL = null;
      try {
         // Start the session
         AuthenticationUtils.startSession("admin", "admin");
         String dir = "/app:company_home";
         String fileName = "RENT.doc";
         System.out.println("dir ::" + dir);
         System.out.println("fileName ::" + fileName);
         String ticket = AuthenticationUtils.getTicket();
         // Create a reference to the parent where we want to create content
         Store storeRef = new Store(Constants.WORKSPACE_STORE, "SpacesStore");
         // Create a new Reference to the node you want (variable path here).
         String path = dir + "/cm:" + fileName;
         Reference reference = new Reference(storeRef, null, path);
         ContentServiceSoapBindingStub contentService = WebServiceFactory.getContentService();
         // Read the content from the respository
         Content[] readResult = contentService.read(new Predicate(new Reference[] { reference }, storeRef, null),
               org.alfresco.webservice.util.Constants.PROP_CONTENT);
         Content contentRef = readResult[0];
         // Get the ticket URL as above and the downloadURL here points to
         // the url where the content is present.
         System.out.println("contentRef.getUrl() : " + contentRef.getUrl());
         String ticketURL = "?ticket=" + ticket;
         downloadURL = contentRef.getUrl() + ticketURL;
         System.out.println("downloadURL in webService(): " + downloadURL);
      } catch (Throwable e) {
         e.printStackTrace();
      } finally {
         // End the session
         AuthenticationUtils.endSession();
      }

      System.out.println(downloadURL);
   }

I am getting same error

{http://www.alfresco.org/ws/service/content/1.0}ContentFault:<ns1:errorCode>0</ns1:errorCode><ns1:message>Not implemented</ns1:message>

sisao
Champ in-the-making
Champ in-the-making
you're basically retrieving content using the wrong stub:

import org.alfresco.webservice.util.AuthenticationUtils;
import org.alfresco.webservice.util.Constants;
import org.alfresco.webservice.util.WebServiceFactory;
import org.alfresco.webservice.types.*;
import org.alfresco.webservice.content.Content;


public static void main(String[] args) throws Exception{
      String downloadURL = null;
      try {
      // Start the session
      AuthenticationUtils.startSession("admin", "admin");
      String dir = "/app:company_home";
      String fileName = "RENT.doc";
      System.out.println("dir ::" + dir);
      System.out.println("fileName ::" + fileName);
      String ticket = AuthenticationUtils.getTicket();
      // Create a reference to the parent where we want to create content
      Store storeRef = new Store(Constants.WORKSPACE_STORE, "SpacesStore");
      // Create a new Reference to the node you want (variable path here).
      String path = dir + "/cm:" + fileName;
      Reference reference = new Reference(storeRef, null, path);
      //ContentServiceSoapBindingStub contentService = WebServiceFactory.getContentService();
      // Read the content from the respository
      
      Predicate predicate = new Predicate(new Reference[] { reference },null,null);
      Content[] readResult = (Content[]) WebServiceFactory.getContentService().read(predicate,org.alfresco.webservice.util.Constants.PROP_CONTENT);
      Content contentRef = readResult[0];
      // Get the ticket URL as above and the downloadURL here points to
      // the url where the content is present.
      System.out.println("contentRef.getUrl() : " + contentRef.getUrl());
      String ticketURL = "?ticket=" + ticket;
      downloadURL = contentRef.getUrl() + ticketURL;
      System.out.println("downloadURL in webService(): " + downloadURL);
      } catch (Throwable e) {
      e.printStackTrace();
      } finally {
      // End the session
      AuthenticationUtils.endSession();
      }

      System.out.println(downloadURL);
      }
}

Regards.

skorde
Champ in-the-making
Champ in-the-making
Then What is the right.Can you please provide me the right stub for reading the content from alfresco repo.

sisao
Champ in-the-making
Champ in-the-making
i've pasted some code above  Smiley Happy

skorde
Champ in-the-making
Champ in-the-making
I have tried your code and again got the same exception

{http://www.alfresco.org/ws/service/content/1.0}ContentFault:<ns1:errorCode>0</ns1:errorCode><ns1:message>Not implemented</ns1:message>

sisao
Champ in-the-making
Champ in-the-making
where do you get that message? how do you debug it? So i can check it….i dont get any error while executing that code.