File: Api.php

package info (click to toggle)
php-datto-json-rpc 6.1.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 248 kB
  • sloc: php: 918; makefile: 22
file content (94 lines) | stat: -rw-r--r-- 2,732 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<?php

/**
 * Copyright (C) 2015 Datto, Inc.
 *
 * This file is part of PHP JSON-RPC.
 *
 * PHP JSON-RPC is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * PHP JSON-RPC is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with PHP JSON-RPC. If not, see <http://www.gnu.org/licenses/>.
 *
 * @author Spencer Mortensen <smortensen@datto.com>
 * @license http://www.gnu.org/licenses/lgpl-3.0.html LGPL-3.0
 * @copyright 2015 Datto, Inc.
 */

namespace Datto\JsonRpc\Tests;

use Datto\JsonRpc\Evaluator;
use Datto\JsonRpc\Exceptions;

class Api implements Evaluator
{
    public function evaluate($method, $arguments)
    {
        switch ($method) {
            case 'subtract':
                return self::subtract($arguments);

            case 'implementation error':
                return self::implementationError($arguments);

            case 'invalid implementation error':
                return self::invalidImplementationError();

            case 'application error':
                return self::applicationError($arguments);

            case 'invalid application error':
                return self::invalidApplicationError();

            default:
                throw new Exceptions\MethodException();
        }
    }

    private static function subtract($arguments)
    {
        if (isset($arguments[0])) {
            @list($a, $b) = $arguments;
        } else {
            $a = @$arguments['minuend'];
            $b = @$arguments['subtrahend'];
        }

        if (!is_int($a) || !is_int($b) || (count($arguments) !== 2)) {
            throw new Exceptions\ArgumentException();
        }

        return $a - $b;
    }

    private static function implementationError($arguments)
    {
        throw new Exceptions\ImplementationException(-32099, @$arguments[0]);
    }

    private static function invalidImplementationError()
    {
        $invalid = new \StdClass();

        throw new Exceptions\ImplementationException($invalid, $invalid);
    }

    private static function applicationError($arguments)
    {
        throw new Exceptions\ApplicationException("Application error", 1, @$arguments[0]);
    }

    private static function invalidApplicationError()
    {
        $invalid = new \StdClass();

        throw new Exceptions\ApplicationException($invalid, $invalid, $invalid);
    }
}