Passed
Pull Request — main (#143)
by Andreas
12:11
created

BulkResponse::valid()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
/**
3
 * Licensed to CRATE Technology GmbH("Crate") under one or more contributor
4
 * license agreements.  See the NOTICE file distributed with this work for
5
 * additional information regarding copyright ownership.  Crate licenses
6
 * this file to you under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.  You may
8
 * obtain a copy of the License at
9
 *
10
 * http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
15
 * License for the specific language governing permissions and limitations
16
 * under the License.
17
 *
18
 * However, if you have executed another commercial license agreement
19
 * with Crate these terms will supersede the license and you may use the
20
 * software solely pursuant to the terms of the relevant commercial agreement.
21
 */
22
23
declare(strict_types=1);
24
25
namespace Crate\Stdlib;
26
27
final class BulkResponse implements BulkResponseInterface
28
{
29
    /**
30
     * Result object for CrateDB bulk operations.
31
     * https://crate.io/docs/crate/reference/en/latest/interfaces/http.html#bulk-operations
32
     * @var array
33
     */
34
    private $results;
35
36
    /**
37
     * @var string[]
38
     */
39
    private $columnsAsKeys;
40
41
    /**
42
     * @var string[]
43
     */
44
    private $columnsAsValues;
45
46
    /**
47
     * @var int
48
     */
49
    private $duration;
50
51
    /**
52
     * @param array    $results
53
     * @param string[] $columns
54
     * @param int      $duration
55
     */
56
    public function __construct(array $results, array $columns, $duration)
57
    {
58
        $this->results         = $results;
59
        $this->columnsAsKeys   = array_flip($columns);
60
        $this->columnsAsValues = $columns;
61
        $this->duration        = $duration;
62
    }
63
64
    /**
65
     * {@Inheritdoc}
66
     */
67
    public function map(callable $callback): array
68
    {
69
        return array_map($callback, $this->results);
70
    }
71
72
    /**
73
     * {@Inheritdoc}
74
     */
75
    public function getColumnIndex($column)
76
    {
77
        if (isset($this->columnsAsKeys[$column])) {
78
            return $this->columnsAsKeys[$column];
79
        }
80
81
        return null;
82
    }
83
84
    /**
85
     * {@Inheritdoc}
86
     */
87
    public function getColumns($columnsAsKeys = true): array
88
    {
89
        return $columnsAsKeys ? $this->columnsAsKeys : $this->columnsAsValues;
90
    }
91
92
    /**
93
     * {@Inheritdoc}
94
     */
95
    public function getResults(): array
96
    {
97
        return $this->results;
98
    }
99
100
    /**
101
     * {@Inheritdoc}
102
     */
103
    public function current(): array
104
    {
105
        return current($this->results);
106
    }
107
108
    /**
109
     * {@Inheritdoc}
110
     */
111
    public function next(): void
112
    {
113
        next($this->results);
114
    }
115
116
    /**
117
     * {@Inheritdoc}
118
     */
119
    public function key(): string
120
    {
121
        return key($this->results);
0 ignored issues
show
Bug Best Practice introduced by
The expression return key($this->results) could return the type null which is incompatible with the type-hinted return string. Consider adding an additional type-check to rule them out.
Loading history...
122
    }
123
124
    /**
125
     * {@Inheritdoc}
126
     */
127
    public function valid(): bool
128
    {
129
        return $this->key() !== null;
130
    }
131
132
    /**
133
     * {@Inheritdoc}
134
     */
135
    public function rewind(): void
136
    {
137
        reset($this->results);
138
    }
139
140
    /**
141
     * {@Inheritdoc}
142
     */
143
    public function count(): int
144
    {
145
        $count = 0;
146
        foreach ($this->results as $element) {
147
            $count += $element["rowcount"];
148
        }
149
        return $count;
150
    }
151
152
}
153