summaryrefslogtreecommitdiff
path: root/proto/wireguard/config.Y
blob: 9a4140854accb62d2d54b4155070d73ba9d66cd3 (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
/*
 *	BIRD -- Wireguard Protocol Configuration
 *
 *	(c) 1999 Martin Mares <mj@ucw.cz>
 *
 *	Can be freely distributed and used under the terms of the GNU GPL.
 */

CF_HDR

#include "proto/wireguard/wireguard.h"

CF_DEFINES

#define WG_CFG ((struct wg_config *) this_proto)

CF_DECLS

CF_KEYWORDS(WIREGUARD, PUBKEY, ENDPOINT, ALLOWED_IPS)

CF_GRAMMAR

proto: wireguard_proto '}' ;

wireguard_proto_start: proto_start WIREGUARD {
     this_proto = proto_config_new(&proto_wireguard, $1);
  }
 ;

wireguard_proto:
   wireguard_proto_start proto_name '{'
 | wireguard_proto wg_proto_channel ';'
 | wireguard_proto proto_item ';'
 | wireguard_proto INTERFACE TEXT ';' { WG_CFG->ifname = $3; }
 | wireguard_proto wg_peer ';'
 ;

wg_peer: wg_peer_start wg_peer_opt_list wg_peer_end;

wg_peer_start: PEER

wg_peer_end:
 ;

wg_peer_item:
   PUBKEY pubkey
 | ENDPOINT endpoint
 | PORT port
 | ALLOWED_IPS allowed_ips
 ;

wg_peer_opts:
  /* empty */
 | wg_peer_opts wg_peer_item ';'
 ;

wg_peer_opt_list:
  /* empty */
 | '{' wg_peer_opts '}'
 ;

pubkey: text { WG_CFG->peer.pubkey = $1; }

endpoint: ipa { WG_CFG->peer.endpoint = $1; }

port: expr { WG_CFG->peer.remote_port = $1; }

allowed_ips:
   net_or_ipa { WG_CFG->peer.allowed_ips = $1; }
 ;

wg_proto_channel: wg_channel_start channel_opt_list wg_channel_end;

wg_channel_start: net_type
{
  this_channel = channel_config_get(&channel_wg, net_label[$1], $1, this_proto);
}

wg_channel_end:
{
  this_channel = NULL;
}

CF_CODE

CF_END