12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- /*=============================================================================
- Library: CTK
- Copyright (c) German Cancer Research Center,
- Division of Medical and Biological Informatics
- Licensed 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.
- =============================================================================*/
- // Qt includes
- #include <QHostAddress>
- // CTK includes
- #include "ctkDicomHostServerPrivate.h"
- #include <ctkDicomHostInterface.h>
- #include <ctkDicomAppHostingTypesHelper.h>
- #include <ctkExchangeSoapMessageProcessor.h>
- #include "ctkHostSoapMessageProcessor_p.h"
- // STD includes
- #include <stdexcept>
- //----------------------------------------------------------------------------
- ctkDicomHostServerPrivate::ctkDicomHostServerPrivate(ctkDicomHostInterface* hostInterface, int port, QString path) :
- Port(port), Path(path), HostInterface(hostInterface)
- {
- connect(&this->Server, SIGNAL(incomingSoapMessage(QtSoapMessage,QtSoapMessage*)),
- this, SLOT(incomingSoapMessage(QtSoapMessage,QtSoapMessage*)));
- connect(&this->Server, SIGNAL(incomingWSDLMessage(QString,QString*)),
- this, SLOT(incomingWSDLMessage(QString,QString*)));
- if (!this->Server.listen(QHostAddress::LocalHost, this->Port))
- {
- qCritical() << "Listening to 127.0.0.1:" << this->Port << " failed.";
- }
- ctkHostSoapMessageProcessor* hostProcessor = new ctkHostSoapMessageProcessor( hostInterface );
- this->Processors.push_back(hostProcessor);
- ctkExchangeSoapMessageProcessor* exchangeProcessor = new ctkExchangeSoapMessageProcessor( hostInterface );
- this->Processors.push_back(exchangeProcessor);
- }
- //----------------------------------------------------------------------------
- void ctkDicomHostServerPrivate::incomingWSDLMessage(
- const QString& message, QString* reply)
- {
- if (message == "?wsdl")
- {
- QFile wsdlfile(":/dah/HostService-20100825.wsdl");
- wsdlfile.open(QFile::ReadOnly | QFile::Text);
- if(wsdlfile.isOpen())
- {
- QTextStream textstream(&wsdlfile);
- *reply = textstream.readAll();
- QString actualURL="http://localhost:";
- //actualURL+=QString::number(this->Port)+"/HostInterface"; // FIXME: has to be replaced by url provided by host
- actualURL+=QString::number(this->Port)+Path;
- reply->replace("REPLACE_WITH_ACTUAL_URL",actualURL);
- reply->replace("HostService-20100825.xsd",actualURL+"?xsd=1");
- //reply->replace("<soap:body use=\"literal\"/>","<soap:body use=\"literal\"></soap:body>");
- }
- }
- else if (message == "?xsd=1")
- {
- QFile wsdlfile(":/dah/HostService-20100825.xsd");
- wsdlfile.open(QFile::ReadOnly | QFile::Text);
- if(wsdlfile.isOpen())
- {
- QTextStream textstream(&wsdlfile);
- *reply = textstream.readAll();
- }
- }
- }
- //----------------------------------------------------------------------------
- void ctkDicomHostServerPrivate::incomingSoapMessage(
- const QtSoapMessage& message, QtSoapMessage* reply)
- {
- this->Processors.process(message, reply);
- }
|