~~ Licensed to the Apache Software Foundation (ASF) under one ~~ or more contributor license agreements. See the NOTICE file ~~ distributed with this work for additional information ~~ regarding copyright ownership. The ASF licenses this file ~~ to you under the Apache License, Version 2.0 (the ~~ "License"); you may not use this file except in compliance ~~ with the License. You may obtain a copy of the License at ~~ ~~ http://www.apache.org/licenses/LICENSE-2.0 ~~ ~~ Unless required by applicable law or agreed to in writing, ~~ software distributed under the License is distributed on an ~~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY ~~ KIND, either express or implied. See the License for the ~~ specific language governing permissions and limitations ~~ under the License. ------------ Introduction ------------ wsdd-maven-plugin Historically, the recommended way to deploy Axis services was based on the following procedure: [[1]] Deploy the Axis WAR to a servlet container or application server. [[2]] Add the Web service code to the <<>> or <<>> folder in the (exploded) Axis WAR. [[3]] Create a WSDD file (or use the WSDD file generated by wsdl2java) and deploy it using the admin client. This will add the definitions contained in the submitted WSDD file to the <<>> file. This procedure is described in more details in the {{{../../install.html}Installation Guide}}. However, nowadays the preferred approach - especially for enterprise projects - is to have a build process that packages the Web service(s) together with the Axis libraries into a WAR that is then deployed to the application server. This requires that the <<>> file is constructed before the WAR is built. With Axis 1.4, developers would typically maintain that file by hand, either by editing it directly (and copying the contents of WSDD files created by wsdl2java) or by using e.g. the Axis 1.4 tooling in Eclipse. The file is then added to the project files under source control so that it is available during the build. This approach is suboptimal because in most cases the <<>> file contains content generated by wsdl2java. That content should not be under source control. Instead, the <<>> file should be assembled automatically during the build process, based on the output of wsdl2java. This is exactly what the wsdd-maven-plugin does: it takes a set of WSDD files and merges them into a single output WSDD. The input WSDD files are typically generated by {{{../wsdl2java/index.html}wsdl2java-maven-plugin}}, but the set may also contain manually created WSDD files, e.g. to configure custom handlers or to override configuration properties.