[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12900574#action_12900574 ] Scott Gray commented on OFBIZ-3877: ----------------------------------- A few questions: - What has changed since my first comment, the one that you agreed with? - Why the hurry? - Do you understand the code that you plan on committing? I won't pretend that it doesn't concern me that you are deferring to others to answer questions about a contribution that you plan on committing, particularly one that affects critical part of the framework. This in itself is a "major problem" IMO, regardless of the quality of the contribution. > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12900607#action_12900607 ] Jacques Le Roux commented on OFBIZ-3877: ---------------------------------------- I second Scott's concerns. It's also great to see that Erwan cleaned the Birt Example... Thanks Erwan! (I believe I will read this) > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12900607#action_12900607 ] Jacques Le Roux edited comment on OFBIZ-3877 at 8/20/10 4:47 AM: ----------------------------------------------------------------- I second Scott's concerns. It's also great to see that Erwan cleaned the Birt Example... Thanks Erwan! (I believe he will read this) ==== TYPO ==== was (Author: jacques.le.roux): I second Scott's concerns. It's also great to see that Erwan cleaned the Birt Example... Thanks Erwan! (I believe I will read this) > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: (was: webservice.zip) > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: webservice.zip I re-attach webservice.zip file from Joonas Keturi updated: "I took out mode-parameter choices "ERROR" and "OUTERROR" and made it simpler. modes are again as previously OUT, IN, INOUT. error messages are handled in other way (with attribute "fault")." Regards, Chatree Srichart > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: (was: webservice.zip) > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: webservice.zip Joonas Keturi asked me to update attached file. "in this update are many mistakes fixed, and also web service client is improved and tested against complex external web service. i think there will no be updates for some time after this." Regards, Chatree Srichart > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12917276#action_12917276 ] Hans Bakker commented on OFBIZ-3877: ------------------------------------ Gentleman, 1. Now support to the standard service engine has been added to optionally support this extension also for internal services. 2. full junit tests exist for the new implementation. 3. i have tested the system so far that it will not create any problems for existing code. Because our (rather large) customer will continue this project using this code it is essential to commit this back into the trunk. Regards, Hans > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Description: This is a new stub for new web service style that use a normal style (not hash map [key/value]). [[ Installation ]] - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework - run ant task for apply patch in webservice directory with: ant reapply-ofbiz-patches [[ Features ]] 1.) New classes There is new important class org.ofbiz.webapp.webservice.event.WebServiceEventHandler which corresponds to earlier org.ofbiz.webapp.event.SOAPEventHandler but tries to support document style web services using SOAP with XML-format, or REST with XML and JSON-formats. This handler class uses other class: org.ofbiz.service.webservice.WebServiceModel which wraps inside class org.ofbiz.service.ModelService and contains support for WSDL-generation, WADL-generation and conversion between Java Maps and XML-object models. WSDL=Web Service Definition Language for SOAP-interface http://www.w3.org/TR/wsdl WADL=Web Application Description Language for REST-interface http://www.w3.org/Submission/wadl/ There is another new important class org.ofbiz.service.webservice.engine.WebServiceClientEngine which corresponds to earlier org.ofbiz.service.engine.SOAPClientEngine but tries to support document style web services using SOAP with XML-format. Web services can be called using their WSDL-document or messages can be specified in services.xml without using WSDL-document. engine-attribute in services description is set to "webservice". Location of WSDL-document is given in attribute wsdlLocation or it can be left out if messages are described with attribute- definitions. Name of service in WSDL is given in attribute webServiceName and name of operation to be invoked in attribute invoke. One service-definition is needed for one web service-operation pair. Example of web service definitions are in file: framework/common/servicedef/services_test.xml This engine class uses other class: org.ofbiz.service.webservice.WebServiceClientModel which extends org.ofbiz.service.webservice.WebServiceModel and contains support for filling attribute definitions in org.ofbiz.service.ModelService from WSDL-document. 2.) Service definitions Web service interface can be used only if service definition file services.xml is completed with additional definitions. Schema of this file is extended. attribute-elements can have nested attribute elements which describe structure of Java maps and lists. If attribute has type Map, it should have nested attributes which describe contents of this map. If attribute has type List, it should have nested attributes which describe element contents of this list. If List has simple elements, there must be only one nested attribute, which describes element. If List has element which is map or other list, there must be one nested attribute stating that the element is Map or List, and then this attribute should have nested attributes describing structure of Map or structure of list element. There are also two new modes for attributes ERROR which means that attribute is responded as error message OUTERROR which means that attribute is responded as error or as success message These modes are needed for web services to describe which parameters will go to detail-elements of SOAP Fault response or REST error messages. Also in WSDL- and WADL-files will be generated XML-schema for general response messages. File framework\webapp\servicedef\services_test.xml can be used as example of attribute definitions. This file is used in unit tests of web service interface. 3.) Web service requests In REST-services HTTP GET-method is used in services whose name start with words "find" or "get". These services should have input parameters in one level, so that they can be given as query parameters in URL. HTTP DELETE-method is used with services whose name start with word "remove". Other services are used with HTTP POST-method and PUT-method. Service must look itself for method name POST or PUT, if it is required to operate differently in insert or update cases. List of links to all WSDL-documents can be requested with URL: /webtools/control/WebService?wsdl Specific WSDL-document is requested with URL: /webtools/control/WebService/<service name here>?wsdl SOAP web service is called with URL: /webtools/control/WebService Notice that no service name is added to URL. Operation name in request message specifies the service name. List of links to all WADL-documents can be requested with URL: /webtools/control/WebService?wadl Specific WADL-document is requested with URL: /webtools/control/WebService/<service name here>?wadl REST web service is called with URL: /webtools/control/WebService/<service name here>[?parameter=value...] REST web service with JSON-format is called with URL: /webtools/control/WebService/<service name here>?format=json[¶meter=value...] SOAP and REST web service requests are selected by request URL, where REST web service has appended service name in URL. 4.) Unit tests Tests for web services org.ofbiz.webapp.webservice.test.WebServiceTests This has 14 different tests which are: 1. Conversion of XML-object model to Map 2. Conversion of Map to XML-object model 3. Call SOAP-web service 4. Call SOAP-web service which needs authorization 5. Call SOAP-web service with wrong credentials 6. Call SOAP-web service with wrong service name 7. Call REST-web service 8. Call REST-web service which needs authorization 9. Call REST-web service with wrong credentials 10. Call REST-web service with wrong service name 11. Call REST-web service using JSON-format 12. Call REST-web service which needs authorization using JSON-format 13. Call REST-web service with wrong credentials using JSON-format 14. Call REST-web service with wrong service name using JSON-format Junit test suite definitions are in file framework/webapp/testdef/webservicetests.xml These unit tests use test service in class org.ofbiz.webapp.webservice.test.WebServiceTestServices Service definitions are in file framework\webapp\servicedef\services_test.xml Unit tests for web service interface can be run with command: ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests Tests for web service client org.ofbiz.service.webservice.test.WebServiceClientTests This has 4 different tests which are: 1. Call SOAP-web service 2. Call SOAP-web service which needs authorization 3. Call SOAP-web service with wrong credentials 4. Call SOAP-web service without WSDL-document using service definitions Junit test suite definitions are in file framework/service/testdef/webserviceclienttests.xml These tests use same test services as tests for web services. Unit tests for web service client can be run with command: ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests Created By: Joonas Keturi was: This is a new stub for new web service style that use a normal style (not hash map [key/value]). [[ Installation ]] - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework - run ant task for apply patch in webservice directory with: ant reapply-ofbiz-patches [[ Features ]] 1.) New classes There is new important class org.ofbiz.webapp.webservice.event.WebServiceEventHandler which corresponds to earlier org.ofbiz.webapp.event.SOAPEventHandler but tries to support document style web services using SOAP with XML-format, or REST with XML and JSON-formats. This handler class uses other class: org.ofbiz.service.webservice.WebServiceModel which wraps inside class org.ofbiz.service.ModelService and contains support for WSDL-generation, WADL-generation and conversion between Java Maps and XML-object models. WSDL=Web Service Definition Language for SOAP-interface http://www.w3.org/TR/wsdl WADL=Web Application Description Language for REST-interface http://www.w3.org/Submission/wadl/ There is another new important class org.ofbiz.service.webservice.engine.WebServiceClientEngine which corresponds to earlier org.ofbiz.service.engine.SOAPClientEngine but tries to support document style web services using SOAP with XML-format. Web services can be called using their WSDL-document or messages can be specified in services.xml without using WSDL-document. engine-attribute in services description is set to "webservice". Location of WSDL-document is given in attribute wsdlLocation or it can be left out if messages are described with attribute- definitions. Name of service in WSDL is given in attribute webServiceName and name of operation to be invoked in attribute invoke. One service-definition is needed for one web service-operation pair. Example of web service definitions are in file: framework/common/servicedef/services_test.xml This engine class uses other class: org.ofbiz.service.webservice.WebServiceClientModel which extends org.ofbiz.service.webservice.WebServiceModel and contains support for filling attribute definitions in org.ofbiz.service.ModelService from WSDL-document. 2.) Service definitions Web service interface can be used only if service definition file services.xml is completed with additional definitions. Schema of this file is extended. attribute-elements can have nested attribute elements which describe structure of Java maps and lists. If attribute has type Map, it should have nested attributes which describe contents of this map. If attribute has type List, it should have nested attributes which describe element contents of this list. If List has simple elements, there must be only one nested attribute, which describes element. If List has element which is map or other list, there must be one nested attribute stating that the element is Map or List, and then this attribute should have nested attributes describing structure of Map or structure of list element. There are also two new modes for attributes ERROR which means that attribute is responded as error message OUTERROR which means that attribute is responded as error or as success message These modes are needed for web services to describe which parameters will go to detail-elements of SOAP Fault response or REST error messages. Also in WSDL- and WADL-files will be generated XML-schema for general response messages. File framework\webapp\servicedef\services_test.xml can be used as example of attribute definitions. This file is used in unit tests of web service interface. 3.) Web service requests In REST-services HTTP GET-method is used in services whose name start with words "find" or "get". These services should have input parameters in one level, so that they can be given as query parameters in URL. HTTP DELETE-method is used with services whose name start with word "remove". Other services are used with HTTP POST-method and PUT-method. Service must look itself for method name POST or PUT, if it is required to operate differently in insert or update cases. List of links to all WSDL-documents can be requested with URL: /webtools/control/WebService?wsdl Specific WSDL-document is requested with URL: /webtools/control/WebService/<service name here>?wsdl SOAP web service is called with URL: /webtools/control/WebService Notice that no service name is added to URL. Operation name in request message specifies the service name. List of links to all WADL-documents can be requested with URL: /webtools/control/WebService?wadl Specific WADL-document is requested with URL: /webtools/control/WebService/<service name here>?wadl REST web service is called with URL: /webtools/control/WebService/<service name here>[?parameter=value...] REST web service with JSON-format is called with URL: /webtools/control/WebService/<service name here>?format=json[¶meter=value...] SOAP and REST web service requests are selected by request URL, where REST web service has appended service name in URL. 4.) Unit tests Tests for web services org.ofbiz.webapp.webservice.test.WebServiceTests This has 14 different tests which are: 1. Conversion of XML-object model to Map 2. Conversion of Map to XML-object model 3. Call SOAP-web service 4. Call SOAP-web service which needs authorization 5. Call SOAP-web service with wrong credentials 6. Call SOAP-web service with wrong service name 7. Call REST-web service 8. Call REST-web service which needs authorization 9. Call REST-web service with wrong credentials 10. Call REST-web service with wrong service name 11. Call REST-web service using JSON-format 12. Call REST-web service which needs authorization using JSON-format 13. Call REST-web service with wrong credentials using JSON-format 14. Call REST-web service with wrong service name using JSON-format Junit test suite definitions are in file framework/webapp/testdef/webservicetests.xml These unit tests use test service in class org.ofbiz.webapp.webservice.test.WebServiceTestServices Service definitions are in file framework\webapp\servicedef\services_test.xml Unit tests for web service interface can be run with command: ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests Tests for web service client org.ofbiz.service.webservice.test.WebServiceClientTests This has 4 different tests which are: 1. Call SOAP-web service 2. Call SOAP-web service which needs authorization 3. Call SOAP-web service with wrong credentials 4. Call SOAP-web service without WSDL-document using service definitions Junit test suite definitions are in file framework/service/testdef/webserviceclienttests.xml These tests use same test services as tests for web services. Unit tests for web service client can be run with command: ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests Created By: Joonas Keturi > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: (was: webservice.zip) > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
In reply to this post by Nicolas Malin (Jira)
[ https://issues.apache.org/jira/browse/OFBIZ-3877?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Chatree Srichart updated OFBIZ-3877: ------------------------------------ Attachment: webservice.zip I got an updated message from Joonas Keturi: "handling of list type attributes is changed to more general way, it was not very flexible in last version. also ^M-characters (carriage returns) are removed from patch-files, they came from windows by accident." So I update webservice.zip file for that and re-attach in the issue. > New Web Service Style > --------------------- > > Key: OFBIZ-3877 > URL: https://issues.apache.org/jira/browse/OFBIZ-3877 > Project: OFBiz > Issue Type: New Feature > Components: framework > Environment: Windows, Ubuntu Linux > Reporter: Chatree Srichart > Assignee: Hans Bakker > Attachments: webservice.zip > > > This is a new stub for new web service style that use a normal style (not hash map [key/value]). > [[ Installation ]] > - Extract webservice.zip file (attached file) to hot-deploy directory of OFBiz framework > - run ant task for apply patch in webservice directory with: > ant reapply-ofbiz-patches > [[ Features ]] > 1.) New classes > There is new important class > org.ofbiz.webapp.webservice.event.WebServiceEventHandler > which corresponds to earlier > org.ofbiz.webapp.event.SOAPEventHandler > but tries to support document style web services using > SOAP with XML-format, or REST with XML and JSON-formats. > This handler class uses other class: > org.ofbiz.service.webservice.WebServiceModel > which wraps inside class > org.ofbiz.service.ModelService > and contains support for WSDL-generation, WADL-generation > and conversion between Java Maps and XML-object models. > WSDL=Web Service Definition Language for SOAP-interface > http://www.w3.org/TR/wsdl > WADL=Web Application Description Language for REST-interface > http://www.w3.org/Submission/wadl/ > There is another new important class > org.ofbiz.service.webservice.engine.WebServiceClientEngine > which corresponds to earlier > org.ofbiz.service.engine.SOAPClientEngine > but tries to support document style web services using > SOAP with XML-format. Web services can be called using > their WSDL-document or messages can be specified in > services.xml without using WSDL-document. engine-attribute > in services description is set to "webservice". Location > of WSDL-document is given in attribute wsdlLocation or > it can be left out if messages are described with attribute- > definitions. Name of service in WSDL is given in > attribute webServiceName and name of operation to be > invoked in attribute invoke. One service-definition is > needed for one web service-operation pair. > Example of web service definitions are in file: > framework/common/servicedef/services_test.xml > This engine class uses other class: > org.ofbiz.service.webservice.WebServiceClientModel > which extends org.ofbiz.service.webservice.WebServiceModel > and contains support for filling attribute definitions > in org.ofbiz.service.ModelService from WSDL-document. > 2.) Service definitions > Web service interface can be used only if service definition > file services.xml is completed with additional definitions. > Schema of this file is extended. > attribute-elements can have nested attribute elements > which describe structure of Java maps and lists. > If attribute has type Map, it should have nested attributes > which describe contents of this map. > If attribute has type List, it should have nested attributes > which describe element contents of this list. > If List has simple elements, there must be only one > nested attribute, which describes element. > If List has element which is map or other list, there > must be one nested attribute stating that the element > is Map or List, and then this attribute should have > nested attributes describing structure of Map or > structure of list element. > There are also two new modes for attributes > ERROR which means that attribute is responded as error message > OUTERROR which means that attribute is responded as error > or as success message > These modes are needed for web services to describe > which parameters will go to detail-elements of SOAP Fault response > or REST error messages. Also in WSDL- and WADL-files will be > generated XML-schema for general response messages. > File framework\webapp\servicedef\services_test.xml > can be used as example of attribute definitions. > This file is used in unit tests of web service interface. > 3.) Web service requests > In REST-services HTTP GET-method is used in services whose > name start with words "find" or "get". These services should > have input parameters in one level, so that they can be > given as query parameters in URL. HTTP DELETE-method is used > with services whose name start with word "remove". Other services > are used with HTTP POST-method and PUT-method. Service must > look itself for method name POST or PUT, if it is required > to operate differently in insert or update cases. > List of links to all WSDL-documents can be requested with URL: > /webtools/control/WebService?wsdl > Specific WSDL-document is requested with URL: > /webtools/control/WebService/<service name here>?wsdl > SOAP web service is called with URL: > /webtools/control/WebService > Notice that no service name is added to URL. Operation > name in request message specifies the service name. > List of links to all WADL-documents can be requested with URL: > /webtools/control/WebService?wadl > Specific WADL-document is requested with URL: > /webtools/control/WebService/<service name here>?wadl > REST web service is called with URL: > /webtools/control/WebService/<service name here>[?parameter=value...] > REST web service with JSON-format is called with URL: > /webtools/control/WebService/<service name here>?format=json[¶meter=value...] > SOAP and REST web service requests are selected by > request URL, where REST web service has appended > service name in URL. > 4.) Unit tests > Tests for web services > org.ofbiz.webapp.webservice.test.WebServiceTests > This has 14 different tests which are: > 1. Conversion of XML-object model to Map > 2. Conversion of Map to XML-object model > 3. Call SOAP-web service > 4. Call SOAP-web service which needs authorization > 5. Call SOAP-web service with wrong credentials > 6. Call SOAP-web service with wrong service name > 7. Call REST-web service > 8. Call REST-web service which needs authorization > 9. Call REST-web service with wrong credentials > 10. Call REST-web service with wrong service name > 11. Call REST-web service using JSON-format > 12. Call REST-web service which needs authorization using JSON-format > 13. Call REST-web service with wrong credentials using JSON-format > 14. Call REST-web service with wrong service name using JSON-format > Junit test suite definitions are in file > framework/webapp/testdef/webservicetests.xml > These unit tests use test service in class > org.ofbiz.webapp.webservice.test.WebServiceTestServices > Service definitions are in file > framework\webapp\servicedef\services_test.xml > Unit tests for web service interface can be run with command: > ant run-single-test-suite -Dtest.component=webapp -Dtest.suiteName=webservicetests > Tests for web service client > org.ofbiz.service.webservice.test.WebServiceClientTests > This has 4 different tests which are: > 1. Call SOAP-web service > 2. Call SOAP-web service which needs authorization > 3. Call SOAP-web service with wrong credentials > 4. Call SOAP-web service without WSDL-document using service definitions > Junit test suite definitions are in file > framework/service/testdef/webserviceclienttests.xml > These tests use same test services as tests for web services. > Unit tests for web service client can be run with command: > ant run-single-test-suite -Dtest.component=service -Dtest.suiteName=webserviceclienttests > Created By: Joonas Keturi -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. |
Free forum by Nabble | Edit this page |