Craig,

I have just completed a similar task of hiding AXIS2 complexities for
other developers. The only difference being, I am not hand coding the
webservice part as you are doing. I have written wrapper classes around
the generated code, written ant scripts to neatly take care of code
generation and build. 

Of course I haven' answered you question but my 2 cents..it is possible
to utilize the AXIS2 code generation and still hide the AXIS2 API
complexities by building a wrapper. The other developers would just be
dealing with your API and POJOS.

Thanks
Srinivas

-----Original Message-----
From: Hickman, Craig [mailto:[EMAIL PROTECTED] 
Sent: Tuesday, May 01, 2007 4:50 PM
To: 'axis-user@ws.apache.org'
Subject: Question on getFirstChildWithName(qName) within an iterator?


Working for a company that wants to hide much of the complexity of the
Axis2
api.

I've been building some helper methods to allow the ability to use a set
of
beans to manipulate and bind the xml to the POJO's without the need for
using the code generation tools, which is something the developers at
this
company wish to refrain from using if possible.

So here is my problem:

I get the root element and then

        //GET THE FIRST ELEMENT
        OMElement root = utils.getOMRootElement(envelope);
        // SET THE PARTNER SERVICE OBJECTS
        QName serviceQN = new QName(WSConstants.SERVICE_ELEMENT);
        Iterator serviceIter =  root.getChildrenWithName(serviceQN);
        getService(serviceIter);

  //-- private method --//
   private void getService(Iterator serv) {
                Map aMap = new HashMap();
                
                //-- pass in iterator and constants for simple xml
element
parsing --//
                try {
                        aMap = utils.getSimpleOMSubElement(serv,
this.getServiceConstants()); // the utility method as seen below
                        int mapsize = aMap.size();

                        Iterator keyValuePairs1 =
aMap.entrySet().iterator();
                        for (int i = 0; i < mapsize; i++)
                        {
                          Map.Entry entry = (Map.Entry)
keyValuePairs1.next();
                          Object key = entry.getKey();
                          Object value = entry.getValue();
                          logger.debug("<<<<<<<<< map values >>>>>>>> "
+value.toString());
                          getServiceElementsSwitch(key, value);
                        }
                } catch (SOAPException e) {
                        logger.debug("getService SOAPException"
+e.getMessage());
                        e.printStackTrace();
                } catch (XMLStreamException e) {
                        logger.debug("getService XMLStreamException"
+e.getMessage());
                        e.printStackTrace();
                }
        }

I pass in a list of the binded elements as strings in a list so that I
can
iterate through them and then use the getChildWithNames iterator.
My only problem is that I can only get the first element text value even
though I loop through the list and pass I a new qName each time.
I have even tried another helper to get the text value taking in the
iterator and and the string value for the qName, but this still brings
back
only one of the text values.

Am I missing something? I've logged it to make sure I'm iterating with
the
correct elements for the binding, and have run test to make sure the
payload
of text value is correct.
    
    
       /**
         * Walk the xml tree of elements
         * get the simple element and put
         * in map object for return.
         *
         * @param serv
         * @throws XMLStreamException
         * @throws SOAPException
         * @return Map map
         */
        public Map getSimpleOMSubElement(Iterator iter, List
wsConstants)
throws SOAPException, XMLStreamException {
                int j = 1;
                String qName = "";
                String text = "";
       
                        for (j = 0; j < wsConstants.size(); j++) {
                                qName = (String)wsConstants.get(j);
                                logger.debug("qName = " +qName);
                                while (iter.hasNext()) {
                                    Object o = iter.next();
                                   
                                    if  (o instanceof OMElement) {
                                            OMElement c = (OMElement) o;
                                            OMElement element =
getOMElement(c, qName); // helpe method - takes element and constant
string
                                            text = element.getText();
                                    }
                               
                                        j++;
                                logger.debug("text = " + j + "" +text);
                                map.put(j, text);
                        }
                }
                return map;    
        }

        /**
          * Helper method to get the text elements in a type safe
fashion
          *
         * @param element
         * @param name
         * @return
         */
       public  OMElement getOMElement(OMElement result, String element)
            throws SOAPException, XMLStreamException {

            QName qName = new QName(element);
            if (qName == null) {
              throw new RuntimeException("Missing required method
element.");
            }

            Iterator i = result.getChildrenWithName(qName);
            if (! i.hasNext()) {
              throw new RuntimeException("Missing required  element.");
            }

            OMElement omElement = (OMElement) i.next();

            return omElement;
          }

As you see in the logs I can only get the first text value of the seven
entries, and the others do have text in them just unable to get it with
the
helper:

2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = partner-num
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.110 - text = 100250
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = auth-code
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = client-user
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = client-id2
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = browser-form-post
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = operation
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG utils.XMLUtils
getSimpleOMSubElement.99 - qName = client-id3
2007-05-01 17:41:19,967 [ApplicationServerThread-0] DEBUG
sso.SSOSkeleton
getService.142 - <<<<<<<<< map values >>>>>>>> 100250

I built it originally using the straight ahead manner of waliking the
elements, so why does it work below but above I cannot use the same idea
with a helper method using iteration?

while (service.hasNext()) {
                        Object o = service.next();
                        OMElement s = (OMElement) o;
                      
                        //----  test all data ----//
                        logger.debug("<<<<<  START OF SERVICE DATA >>>>>
");
                      
                        //--- use helper class for test ---//
                        //-- Test partner-num -- //
                                OMElement partnerData =
s.getFirstChildWithName(new QName(WSConstants.PARTNER_NUM));
                                logger.debug("<<<< Partner Data >>> "
+partnerData.getText());
                                assertEquals("wKsd898!iu",
partnerData.getText());
                              
                                // -- client-id --//
                                OMElement clientId =
s.getFirstChildWithName(new QName(WSConstants.CLIENT_ID));
                                logger.debug("<<<< client-id >>> "
+clientId.getText());
                                assertEquals("146", clientId.getText());
                              
                                // -- auth-code --//
                                OMElement authCode =
s.getFirstChildWithName(new QName(WSConstants.AUTH_CODE));
                                logger.debug("<<<< auth-code >>> "
+authCode.getText());
                                assertEquals("Ad897!df",
authCode.getText());
                              
                                 // -- client-user --//
                                OMElement clientUser =
s.getFirstChildWithName(new QName(WSConstants.CLIENT_USER));
                                logger.debug("<<<< client-user >>> "
+clientUser.getText());
                                assertEquals("1", clientUser.getText());
                              
                                 // -- client-id2 --//
                                OMElement clientId2 =
s.getFirstChildWithName(new QName(WSConstants.CLIENT_ID_2));
                                logger.debug("<<<< client-id2 >>> "
+clientId2.getText());
                                assertEquals("2", clientId2.getText());
                              
                                 // -- browser-form-post --//
                                OMElement browserFormPost =
s.getFirstChildWithName(new QName(WSConstants.BROWSER_FORM_POST));
                                logger.debug("<<<< browser-form-post >>>
"
+browserFormPost.getText());
                                assertEquals("text data ",
browserFormPost.getText());
                              
                                 // -- operation  --//
                                OMElement operation =
s.getFirstChildWithName(new QName(WSConstants.OPERATION));
                                logger.debug("<<<< operation >>> "
+operation.getText());
                                assertEquals("create",
operation.getText());
                              
                                 // -- client-id3 --//
                                OMElement clientId3 =
s.getFirstChildWithName(new QName(WSConstants.CLIENT_ID_3));
                                logger.debug("<<<< client-id3 >>> "
+clientId3.getText());
                                assertEquals("12345",
clientId3.getText());
                              
                                logger.debug("<<<<<  END OF SERVICE DATA
>>>>> ");






---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]


---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to