GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Push — master ( 1b0f9b...f731b0 )
by Charlotte
04:44 queued 02:01
created

ErrResponseMessage   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 88
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
eloc 23
dl 0
loc 88
ccs 0
cts 27
cp 0
rs 10
c 0
b 0
f 0
wmc 7

5 Methods

Rating   Name   Duplication   Size   Complexity  
A getID() 0 2 1
A __construct() 0 2 1
A getParser() 0 2 1
A setParserState() 0 2 1
A parseMessage() 0 19 3
1
<?php
2
/**
3
 * Plasma Driver MySQL component
4
 * Copyright 2018-2019 PlasmaPHP, All Rights Reserved
5
 *
6
 * Website: https://github.com/PlasmaPHP
7
 * License: https://github.com/PlasmaPHP/driver-mysql/blob/master/LICENSE
8
*/
9
10
namespace Plasma\Drivers\MySQL\Messages;
11
12
/**
13
 * Represents an Err Response Message.
14
 * @internal
15
 */
16
class ErrResponseMessage implements \Plasma\Drivers\MySQL\Messages\MessageInterface {
17
    /**
18
     * Error code.
19
     * @var int
20
     */
21
    public $errorCode;
22
    
23
    /**
24
     * SQL State marker, if any.
25
     * @var string|null
26
     */
27
    public $sqlStateMarker;
28
    
29
    /**
30
     * SQL State, if any.
31
     * @var string|null
32
     */
33
    public $sqlState;
34
    
35
    /**
36
     * Error message.
37
     * @var string
38
     */
39
    public $errorMessage;
40
    
41
    /**
42
     * @var \Plasma\Drivers\MySQL\ProtocolParser
43
     */
44
    protected $parser;
45
    
46
    /**
47
     * Constructor.
48
     * @param \Plasma\Drivers\MySQL\ProtocolParser  $parser
49
     */
50
    function __construct(\Plasma\Drivers\MySQL\ProtocolParser $parser) {
51
        $this->parser = $parser;
52
    }
53
    
54
    /**
55
     * Get the identifier for the packet.
56
     * @return string
57
     */
58
    static function getID(): string {
59
        return "\xFF";
60
    }
61
    
62
    /**
63
     * Parses the message, once the complete string has been received.
64
     * Returns false if not enough data has been received, or the remaining buffer.
65
     * @param \Plasma\BinaryBuffer  $buffer
66
     * @return bool
67
     * @throws \Plasma\Drivers\MySQL\Messages\ParseException
68
     */
69
    function parseMessage(\Plasma\BinaryBuffer $buffer): bool {
70
        $this->errorCode = $buffer->readInt2();
71
        
72
        $handshake = $this->parser->getHandshakeMessage();
73
        if(!$handshake || $this->parser->getState() == \Plasma\Drivers\MySQL\ProtocolParser::STATE_HANDSHAKE) {
74
            $exception = new \Plasma\Drivers\MySQL\Messages\ParseException($buffer->getContents(), $this->errorCode);
75
            $exception->setState(\Plasma\Drivers\MySQL\ProtocolParser::STATE_HANDSHAKE_ERROR);
76
            $exception->setBuffer('');
77
            
78
            $buffer->clear();
79
            throw $exception;
80
        }
81
        
82
        $this->sqlStateMarker = $buffer->readStringLength(1);
83
        $this->sqlState = $buffer->readStringLength(5);
84
        $this->errorMessage = $buffer->getContents();
85
        
86
        $buffer->clear();
87
        return true;
88
    }
89
    
90
    /**
91
     * Get the parser which created this message.
92
     * @return \Plasma\Drivers\MySQL\ProtocolParser
93
     */
94
    function getParser(): \Plasma\Drivers\MySQL\ProtocolParser {
95
        return $this->parser;
96
    }
97
    
98
    /**
99
     * Sets the parser state, if necessary. If not, return `-1`.
100
     * @return int
101
     */
102
    function setParserState(): int {
103
        return \Plasma\Drivers\MySQL\ProtocolParser::STATE_OK;
104
    }
105
}
106