| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * This file is part of the WebServiceBundle. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * (c) Christian Kerl <christian-kerl@web.de> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This source file is subject to the MIT license that is bundled | 
					
						
							|  |  |  |  * with this source code in the file LICENSE. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Bundle\WebServiceBundle\Soap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-07 15:16:56 +02:00
										 |  |  | use Bundle\WebServiceBundle\Util\Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | use Symfony\Component\HttpFoundation\Request; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  | use Zend\Mime\Mime; | 
					
						
							|  |  |  | use Zend\Mime\Message; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * SoapRequest. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @author Christian Kerl <christian-kerl@web.de> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class SoapRequest extends Request | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $rawContent; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $soapMessage; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $soapAction; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2010-10-07 15:16:56 +02:00
										 |  |  |      * @var \Bundle\WebServiceBundle\Util\Collection | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-10-07 15:16:56 +02:00
										 |  |  |     protected $soapHeaders; | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |      * @var \Bundle\WebServiceBundle\Util\Collection | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |     protected $soapAttachments; | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function __construct($rawContent = null, array $query = null, array $attributes = null, array $cookies = null, array $server = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct($query, null, $attributes, $cookies, null, $server); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->rawContent = $rawContent != null ? $rawContent : $this->loadRawContent(); | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |         $this->soapMessage = null; | 
					
						
							| 
									
										
										
										
											2010-10-07 15:16:56 +02:00
										 |  |  |         $this->soapHeaders = new Collection('getName'); | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |         $this->soapAttachments = new Collection('getId'); | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |      * Gets raw data send to the server. | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getRawContent() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->rawContent; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Gets the XML string of the SOAP message. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getSoapMessage() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if($this->soapMessage === null) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             $this->soapMessage = $this->initializeSoapMessage(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->soapMessage; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-07 15:16:56 +02:00
										 |  |  |     public function getSoapHeaders() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->soapHeaders; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |     public function getSoapAttachments() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->soapAttachments; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Loads the plain HTTP POST data. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function loadRawContent() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return isset($GLOBALS['HTTP_RAW_POST_DATA']) ? $GLOBALS['HTTP_RAW_POST_DATA'] : file_get_contents('php://input'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     protected function initializeSoapMessage() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if($this->server->has('CONTENT_TYPE')) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             $type = $this->splitContentTypeHeader($this->server->get('CONTENT_TYPE')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             switch($type['_type']) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 case 'multipart/related': | 
					
						
							|  |  |  |                     if($type['type'] == 'application/xop+xml') | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         return $this->initializeMtomSoapMessage($type, $this->rawContent); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     else | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         //log error
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                 case 'application/soap+xml': | 
					
						
							|  |  |  |                     // goto fallback
 | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                 default: | 
					
						
							|  |  |  |                     // log error
 | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // fallback
 | 
					
						
							|  |  |  |         return $this->rawContent; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function initializeMtomSoapMessage(array $contentTypeHeader, $content) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-12-30 02:13:56 +01:00
										 |  |  |         if(!isset($contentTypeHeader['start']) || !isset($contentTypeHeader['start-info']) || !isset($contentTypeHeader['boundary'])) | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             throw new \InvalidArgumentException(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mimeMessage = Message::createFromMessage($content, $contentTypeHeader['boundary']); | 
					
						
							|  |  |  |         $mimeParts = $mimeMessage->getParts(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-08 17:27:46 +02:00
										 |  |  |         $soapMimePartId = trim($contentTypeHeader['start'], '<>'); | 
					
						
							|  |  |  |         $soapMimePartType = $contentTypeHeader['start-info']; | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $rootPart = array_shift($mimeParts); | 
					
						
							|  |  |  |         $rootPartType = $this->splitContentTypeHeader($rootPart->type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TODO: add more checks to achieve full compatibility to MTOM spec
 | 
					
						
							|  |  |  |         // http://www.w3.org/TR/soap12-mtom/
 | 
					
						
							| 
									
										
										
										
											2010-10-08 17:27:46 +02:00
										 |  |  |         if($rootPart->id != $soapMimePartId || $rootPartType['_type'] != 'application/xop+xml' || $rootPartType['type'] != $soapMimePartType) | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             throw new \InvalidArgumentException(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach($mimeParts as $mimePart) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             $this->soapAttachments->add(new SoapAttachment( | 
					
						
							| 
									
										
										
										
											2010-10-08 17:27:46 +02:00
										 |  |  |                 $mimePart->id, | 
					
						
							| 
									
										
										
										
											2010-10-08 16:58:14 +02:00
										 |  |  |                 $mimePart->type, | 
					
						
							|  |  |  |                 // handle content decoding / prevent encoding
 | 
					
						
							|  |  |  |                 $mimePart->getContent() | 
					
						
							|  |  |  |             )); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // handle content decoding / prevent encoding
 | 
					
						
							|  |  |  |         return $rootPart->getContent(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function splitContentTypeHeader($header) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = array(); | 
					
						
							|  |  |  |         $parts = explode(';', strtolower($header)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $result['_type'] = array_shift($parts); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach($parts as $part) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             list($key, $value) = explode('=', trim($part), 2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result[$key] = trim($value, '"'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-10-05 21:44:30 +02:00
										 |  |  | } |