summaryrefslogtreecommitdiffstats
path: root/collectors/charts.d.plugin/libreswan/metadata.yaml
blob: 77cb254505ec92c14c9a742bf531a21a7a86435e (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
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
140
141
142
143
144
145
146
plugin_name: charts.d.plugin
modules:
  - meta:
      plugin_name: charts.d.plugin
      module_name: libreswan
      monitored_instance:
        name: Libreswan
        link: "https://libreswan.org/"
        categories:
          - data-collection.vpns
        icon_filename: "libreswan.png"
      related_resources:
        integrations:
          list: []
      info_provided_to_referring_integrations:
        description: ""
      keywords:
        - vpn
        - libreswan
        - network
        - ipsec
      most_popular: false
    overview:
      data_collection:
        metrics_description: "Monitor Libreswan performance for optimal IPsec VPN operations. Improve your VPN operations with Netdata''s real-time metrics and built-in alerts."
        method_description: "The collector uses the `ipsec` command to collect the information it needs."
      supported_platforms:
        include: []
        exclude: []
      multi_instance: true
      additional_permissions:
        description: ""
      default_behavior:
        auto_detection:
          description: ""
        limits:
          description: ""
        performance_impact:
          description: ""
    setup:
      prerequisites:
        list:
          - title: "Install charts.d plugin"
            description: |
              If [using our official native DEB/RPM packages](https://github.com/netdata/netdata/blob/master/packaging/installer/UPDATE.md#determine-which-installation-method-you-used), make sure `netdata-plugin-chartsd` is installed.
          - title: "Permissions to execute `ipsec`"
            description: |
              The plugin executes 2 commands to collect all the information it needs:
              
              ```sh
              ipsec whack --status
              ipsec whack --trafficstatus
              ```
              
              The first command is used to extract the currently established tunnels, their IDs and their names.
              The second command is used to extract the current uptime and traffic.
              
              Most probably user `netdata` will not be able to query libreswan, so the `ipsec` commands will be denied.
              The plugin attempts to run `ipsec` as `sudo ipsec ...`, to get access to libreswan statistics.
              
              To allow user `netdata` execute `sudo ipsec ...`, create the file `/etc/sudoers.d/netdata` with this content:
              
              ```
              netdata ALL = (root) NOPASSWD: /sbin/ipsec whack --status
              netdata ALL = (root) NOPASSWD: /sbin/ipsec whack --trafficstatus
              ```
              
              Make sure the path `/sbin/ipsec` matches your setup (execute `which ipsec` to find the right path).
      configuration:
        file:
          name: charts.d/libreswan.conf
        options:
          description: |
            The config file is sourced by the charts.d plugin. It's a standard bash file.
            
            The following collapsed table contains all the options that can be configured for the libreswan collector.
          folding:
            title: "Config options"
            enabled: true
          list:
            - name: libreswan_update_every
              description: The data collection frequency. If unset, will inherit the netdata update frequency.
              default_value: 1
              required: false
            - name: libreswan_priority
              description: The charts priority on the dashboard
              default_value: 90000
              required: false
            - name: libreswan_retries
              description: The number of retries to do in case of failure before disabling the collector.
              default_value: 10
              required: false
            - name: libreswan_sudo
              description: Whether to run `ipsec` with `sudo` or not.
              default_value: 1
              required: false
        examples:
          folding:
            enabled: false
            title: "Config"
          list:
            - name: Run `ipsec` without sudo
              description: Run the `ipsec` utility without sudo
              config: |
                # the data collection frequency
                # if unset, will inherit the netdata update frequency
                #libreswan_update_every=1
                
                # the charts priority on the dashboard
                #libreswan_priority=90000
                
                # the number of retries to do in case of failure
                # before disabling the module
                #libreswan_retries=10
                
                # set to 1, to run ipsec with sudo (the default)
                # set to 0, to run ipsec without sudo
                libreswan_sudo=0
    troubleshooting:
      problems:
        list: []
    alerts: []
    metrics:
      folding:
        title: Metrics
        enabled: false
      description: ""
      availability: []
      scopes:
        - name: IPSEC tunnel
          description: "Metrics related to IPSEC tunnels. Each tunnel provides its own set of the following metrics."
          labels: []
          metrics:
            - name: libreswan.net
              description: LibreSWAN Tunnel ${name} Traffic
              unit: "kilobits/s"
              chart_type: area
              dimensions:
                - name: in
                - name: out
            - name: libreswan.uptime
              description: LibreSWAN Tunnel ${name} Uptime
              unit: "seconds"
              chart_type: line
              dimensions:
                - name: uptime