blob: 01b7ed825ab87b98f8f69e628902d1f7fefda71a (
plain)
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
|
;;; SPDX-License-Identifier: GPL-3.0-or-later
;;; SPDX-FileCopyrightText: 2026 Marek Paśnikowski <marek@marekpasnikowski.pl>
;;; COPYRIGHT NOTICE
;;;
;;; Copyright 2026, Marek Paśnikowski <marek@marekpasnikowski.pl>
;;; LICENSE NOTICE
;;;
;;; This library is free software: you can redistribute it and/or modify it under the terms of
;;; the GNU General Public License as published by the Free Software Foundation,
;;; either version 3 of the License, or (at your option) any later version.
;;;
;;; This library 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 General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License along with this library.
;;; If not, see <https://www.gnu.org/licenses/>.
(define-module (deployment services vpn)
#:export (wireguard-service-aisaka
wireguard-service-akashi
wireguard-service-giewont
wireguard-service-rakan)
#:use-module (gnu services)
#:use-module (gnu services vpn)
#:use-module (sovereign services vpn)
#:use-module ((deployment services dns)
#:prefix deployment:services:dns:))
(define wireguard-peer-aisaka
(wireguard-peer
(inherit %wireguard-peer)
(name "aisaka")
(endpoint deployment:services:dns:wireguard-endpoint)
(public-key "7B6fgIKVZs6DWN3hdDGlYI8XpvHWGCjZKh6kbY/KKg8=")))
(define wireguard-peer-akashi
(wireguard-peer
(inherit %wireguard-peer)
(name "akashi")
(public-key "p0X7zaemU0NyuJ+UiKVZ/4HfC8vj5z9kJK9j/iJDwT8=")
(allowed-ips (list "10.0.0.4/32"))))
(define wireguard-peer-giewont
(wireguard-peer
(inherit %wireguard-peer)
(name "giewont")
(public-key "/XsuEpAHX1iEc5abcmY9sYTx8qETAuSLjEmx5ekqfwM=")
(allowed-ips (list "10.0.0.2/32"))))
(define wireguard-peer-rakan
(wireguard-peer
(inherit %wireguard-peer)
(name "rakan")
(public-key "vOEJivgw9C7wZwYX3Kiqw3Ycl6wErr8N9z3BmkhF0Us=")
(allowed-ips (list "10.0.0.3/32"))))
(define wireguard-configuration-aisaka
(wireguard-configuration
(inherit %wireguard-configuration)
(peers (list wireguard-peer-akashi
wireguard-peer-giewont
wireguard-peer-rakan))))
(define wireguard-configuration-akashi
(wireguard-configuration
(inherit %wireguard-configuration)
(addresses (list "10.0.0.4/24"))
(peers (list wireguard-peer-aisaka))))
(define wireguard-configuration-giewont
(wireguard-configuration
(inherit %wireguard-configuration)
(addresses (list "10.0.0.2/24"))
(peers (list wireguard-peer-aisaka))))
(define wireguard-configuration-rakan
(wireguard-configuration
(inherit %wireguard-configuration)
(addresses (list "10.0.0.3/24"))
(peers (list wireguard-peer-aisaka))))
(define wireguard-service-aisaka
(wireguard-service wireguard-configuration-aisaka))
(define wireguard-service-akashi
(wireguard-service wireguard-configuration-akashi))
(define wireguard-service-giewont
(wireguard-service wireguard-configuration-giewont))
(define wireguard-service-rakan
(wireguard-service wireguard-configuration-rakan))
;;; EOF
|