~fkooman/vpn-server-api

ref: 453cda58bae0131116fbab4e4fc686d867e87ade vpn-server-api/tests/Api/OpenVpnModuleTest.php -rw-r--r-- 4.3 KiB
453cda58François Kooman allow configuring the log format for log entries to syslog, also allow logging originating client IP 9 months ago
                                                                                
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<?php

/*
 * eduVPN - End-user friendly VPN.
 *
 * Copyright: 2016-2019, The Commons Conservancy eduVPN Programme
 * SPDX-License-Identifier: AGPL-3.0+
 */

namespace LC\Server\Tests\Api;

use DateTime;
use LC\Common\Config;
use LC\Common\Http\BasicAuthenticationHook;
use LC\Common\Http\Request;
use LC\Common\Http\Service;
use LC\Server\Api\OpenVpnModule;
use LC\Server\OpenVpn\ServerManager;
use LC\Server\Storage;
use LC\Server\Tests\TestSocket;
use PDO;
use PHPUnit\Framework\TestCase;
use Psr\Log\NullLogger;

class OpenVpnModuleTest extends TestCase
{
    /** @var \LC\Common\Http\Service */
    private $service;

    protected function setUp()
    {
        $config = Config::fromFile(sprintf('%s/data/openvpn_module_config.php', __DIR__));
        $storage = new Storage(
            new PDO('sqlite::memory:'),
            'schema',
            new DateTime()
        );
        $storage->init();

        $storage->addCertificate('foo', 'f3bb6f8efb4dc64be35e1044cf1b5e76', 'Display Name', new DateTime('@12345678'), new DateTime('@23456789'), null);
        $storage->addCertificate('foo', '78f4a3c26062a434b01892e2b23126d1', 'Display Name 2', new DateTime('@12345678'), new DateTime('@23456789'), null);

        $serverManager = new ServerManager(
            $config,
            new NullLogger(),
            new TestSocket()
        );

        $this->service = new Service();
        $this->service->addModule(
            new OpenVpnModule(
                $serverManager,
                $storage
            )
        );

        $bearerAuthentication = new BasicAuthenticationHook(
            [
                'vpn-user-portal' => 'aabbcc',
            ]
        );

        $this->service->addBeforeHook('auth', $bearerAuthentication);
    }

    public function testConnect()
    {
        $this->assertSame(
            [
                'internet' => [
                    [
                        'common_name' => 'f3bb6f8efb4dc64be35e1044cf1b5e76',
                        'virtual_address' => [
                            '10.128.7.3',
                            'fd60:4a08:2f59:ba0::1001',
                        ],
                        'user_id' => 'foo',
                        'user_is_disabled' => '0',
                        'display_name' => 'Display Name',
                        'valid_from' => '1970-05-23T21:21:18+00:00',
                        'valid_to' => '1970-09-29T11:46:29+00:00',
                        'client_id' => null,
                    ],
                    [
                        'common_name' => '78f4a3c26062a434b01892e2b23126d1',
                        'virtual_address' => [
                            '10.128.7.4',
                            'fd60:4a08:2f59:ba0::1002',
                        ],
                        'user_id' => 'foo',
                        'user_is_disabled' => '0',
                        'display_name' => 'Display Name 2',
                        'valid_from' => '1970-05-23T21:21:18+00:00',
                        'valid_to' => '1970-09-29T11:46:29+00:00',
                        'client_id' => null,
                    ],
                ],
            ],
            $this->makeRequest(
                ['vpn-user-portal', 'aabbcc'],
                'GET',
                'client_connections',
                [],
                []
            )
        );
    }

    private function makeRequest(array $basicAuth, $requestMethod, $pathInfo, array $getData = [], array $postData = [])
    {
        $response = $this->service->run(
            new Request(
                [
                    'SERVER_PORT' => 80,
                    'SERVER_NAME' => 'vpn.example',
                    'REQUEST_METHOD' => $requestMethod,
                    'SCRIPT_NAME' => '/index.php',
                    'REQUEST_URI' => sprintf('/%s', $pathInfo),
                    'PHP_AUTH_USER' => $basicAuth[0],
                    'PHP_AUTH_PW' => $basicAuth[1],
                ],
                $getData,
                $postData
            )
        );

        $responseArray = json_decode($response->getBody(), true)[$pathInfo];
        if ($responseArray['ok']) {
            if (\array_key_exists('data', $responseArray)) {
                return $responseArray['data'];
            }

            return true;
        }

        // in case of errors...
        return $responseArray;
    }
}