HandlerBookPriceService   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 4
eloc 17
c 1
b 0
f 0
dl 0
loc 34
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
A analyze() 0 28 4
1
<?php
2
/**
3
 * amadeus-ws-client
4
 *
5
 * Copyright 2015 Amadeus Benelux NV
6
 *
7
 * Licensed under the Apache License, Version 2.0 (the "License");
8
 * you may not use this file except in compliance with the License.
9
 * You may obtain a copy of the License at
10
 *
11
 * http://www.apache.org/licenses/LICENSE-2.0
12
 *
13
 * Unless required by applicable law or agreed to in writing, software
14
 * distributed under the License is distributed on an "AS IS" BASIS,
15
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
 * See the License for the specific language governing permissions and
17
 * limitations under the License.
18
 *
19
 * @package Amadeus
20
 * @license https://opensource.org/licenses/Apache-2.0 Apache 2.0
21
 */
22
23
namespace Amadeus\Client\ResponseHandler\Service;
24
25
use Amadeus\Client\ResponseHandler\StandardResponseHandler;
26
use Amadeus\Client\Result;
27
use Amadeus\Client\Session\Handler\SendResult;
28
29
/**
30
 * HandlerBookPriceService
31
 *
32
 * @package Amadeus\Client\ResponseHandler\Service
33
 * @author Mike Hernas <[email protected]>
34
 */
35
class HandlerBookPriceService extends StandardResponseHandler
36
{
37
    /**
38
     * @param SendResult $response
39
     * @return Result
40
     */
41
    public function analyze(SendResult $response)
42
    {
43
        $analyzeResponse = new Result($response);
44
        $domXpath = $this->makeDomXpath($response->responseXml);
45
46
        $errorCodeNodeList = $domXpath->query("//ama:Error");
47
48
        if ($errorCodeNodeList->length > 0) {
49
            $analyzeResponse->status = Result::STATUS_ERROR;
50
51
            foreach (iterator_to_array($errorCodeNodeList) as $msg) {
52
                $analyzeResponse->messages[] = new Result\NotOk(
53
                    $msg->getAttribute('Code'),
54
                    trim($msg->getAttribute('ShortText'))
55
                );
56
            }
57
58
            return $analyzeResponse;
59
        }
60
61
        $success = $domXpath->query('//m:Success');
62
        if ($success->length > 0) {
63
            $analyzeResponse->status = Result::STATUS_OK;
64
            return $analyzeResponse;
65
        }
66
67
        $analyzeResponse->status = Result::STATUS_UNKNOWN;
68
        return $analyzeResponse;
69
    }
70
}
71