/* * 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. */ /* $Rev$ $Date$ */ #ifndef tuscany_sca_extension_ws_model_wsreferencebinding_h #define tuscany_sca_extension_ws_model_wsreferencebinding_h #include #include "tuscany/sca/ws/export.h" #include "tuscany/sca/model/ReferenceBinding.h" namespace tuscany { namespace sca { namespace ws { /** * Information about a web service binding for service or a reference. */ class WSReferenceBinding : public tuscany::sca::model::ReferenceBinding { public: /** * Constructor. * @param uri The uri of the binding. * @param endpoint The definition of the endpoint to which the entrypoint * or external service is to be bound. This is of the form * "namespace"#endpoint("service"/"endpoint") */ SCA_WS_SERVICE_API WSReferenceBinding(tuscany::sca::model::Reference* reference, const std::string&uri, const std::string& endpoint, const std::string& version); /** * Destructor. */ SCA_WS_SERVICE_API virtual ~WSReferenceBinding(); /** * Returns the type of binding. */ virtual std::string getType() { return "http://www.osoa.org/xmlns/sca/1.0#WebServiceBinding"; }; /** * Configure this binding from a service binding. */ SCA_WS_SERVICE_API virtual void configure(tuscany::sca::model::ServiceBinding* serviceBinding); /** * Create a proxy representing the reference to the * client component. */ SCA_WS_SERVICE_API virtual ServiceProxy* getServiceProxy(); /** * Return the part of the endpoint definition describing the wsdl * namespace. * @return The wsdl namespace. */ std::string getWSDLNamespaceURL() const { return wsdlNamespaceURL; }; /** * Return the service part of the endpoint definition. * @return The service to use. */ std::string getServiceName() const { return serviceName; }; /** * Return the endpoint name part of the endpoint definition. * @return The endpoint name to use. */ std::string getEndpointName() const { return endpointName; }; /** * Return the SOAP version. * @return The SOAP version to use. */ std::string getSOAPVersion() const { return soapVersion; }; /** * Returns the target service binding. */ tuscany::sca::model::ServiceBinding* getTargetServiceBinding() const { return targetServiceBinding; }; private: /** * Parse the endpoint specification. */ void parseEndpoint(); /** * The full endpoint string. */ std::string endpoint; /** * Namespace from the endpoint. */ std::string wsdlNamespaceURL; /** * Service name from the endpoint. */ std::string serviceName; /** * Endpoint name from the endpoint. */ std::string endpointName; /** * SOAP version. */ std::string soapVersion; /** * The proxy representing the reference to the client * component. */ ServiceProxy* serviceProxy; /** * The service binding of the target */ tuscany::sca::model::ServiceBinding* targetServiceBinding; }; } // End namespace ws } // End namespace sca } // End namespace tuscany #endif // tuscany_sca_extension_ws_model_wsreferencebinding_h