JsonApiDataParserInterface
last analyzed

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
dl 0
loc 44
c 0
b 0
f 0

6 Methods

Rating   Name   Duplication   Size   Complexity  
parse() 0 1 ?
assert() 0 1 ?
parseRelationship() 0 1 ?
assertRelationship() 0 1 ?
getCaptures() 0 1 ?
getErrors() 0 1 ?
1
<?php declare (strict_types = 1);
2
3
namespace Limoncello\Flute\Contracts\Validation;
4
5
/**
6
 * Copyright 2015-2019 [email protected]
7
 *
8
 * Licensed under the Apache License, Version 2.0 (the "License");
9
 * you may not use this file except in compliance with the License.
10
 * You may obtain a copy of the License at
11
 *
12
 * http://www.apache.org/licenses/LICENSE-2.0
13
 *
14
 * Unless required by applicable law or agreed to in writing, software
15
 * distributed under the License is distributed on an "AS IS" BASIS,
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
 * See the License for the specific language governing permissions and
18
 * limitations under the License.
19
 */
20
21
use Neomerx\JsonApi\Contracts\Schema\ErrorInterface;
22
23
/**
24
 * @package Limoncello\Flute
25
 */
26
interface JsonApiDataParserInterface
27
{
28
    /**
29
     * @param array $jsonData
30
     *
31
     * @return bool
32
     */
33
    public function parse(array $jsonData): bool;
34
35
    /**
36
     * @param array $jsonData
37
     *
38
     * @return self
0 ignored issues
show
Documentation introduced by
Should the return type not be \self?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
39
     */
40
    public function assert(array $jsonData): self;
41
42
    /**
43
     * @param string $index
44
     * @param string $name
45
     * @param array  $jsonData
46
     *
47
     * @return bool
48
     */
49
    public function parseRelationship(string $index, string $name, array $jsonData): bool;
50
51
    /**
52
     * @param string $index
53
     * @param string $name
54
     * @param array  $jsonData
55
     *
56
     * @return self
0 ignored issues
show
Documentation introduced by
Should the return type not be \self?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
57
     */
58
    public function assertRelationship(string $index, string $name, array $jsonData): self;
59
60
    /**
61
     * @return array
62
     */
63
    public function getCaptures(): array;
64
65
    /**
66
     * @return ErrorInterface[]
67
     */
68
    public function getErrors(): array;
69
}
70