Xslt::transform()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 7
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 1

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 7
rs 9.4285
ccs 4
cts 4
cp 1
cc 1
eloc 4
nc 1
nop 1
crap 1
1
<?php
2
/*
3
 * Copyright 2016 Jan Eichhorn <[email protected]>
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 */
17
18
namespace ApaiIO\ResponseTransformer;
19
20
/**
21
 * A responsetransformer transforming an xml via xslt
22
 *
23
 * @author Jan Eichhorn <[email protected]>
24
 */
25
class Xslt implements ResponseTransformerInterface
26
{
27
    /**
28
     * XSLTProcessor object
29
     *
30
     * @var \XSLTProcessor
31
     */
32
    protected $xsl;
33
34
    /**
35
     * Constructor
36
     *
37
     * @param string $xslt
38
     */
39 1
    public function __construct($xslt)
40
    {
41 1
        $xsl = new \XSLTProcessor();
42 1
        $xsldoc = new \DOMDocument();
43
44 1
        $xsldoc->loadXML($xslt);
45 1
        $xsl->importStyleSheet($xsldoc);
46
47 1
        $this->xsl = $xsl;
48 1
    }
49
50
    /**
51
     * {@inheritdoc}
52
     */
53 1
    public function transform($response)
54
    {
55 1
        $document = new \DOMDocument('1.0', 'UTF-8');
56 1
        $document->loadXML($response);
57
58 1
        return $this->xsl->transformToXml($document);
59
    }
60
}
61