File: authentication.md

package info (click to toggle)
zabbix-cli 3.5.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,860 kB
  • sloc: python: 18,557; makefile: 3
file content (139 lines) | stat: -rw-r--r-- 3,618 bytes parent folder | download | duplicates (2)
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
# Authentication

Zabbix-cli provides several ways to authenticate. They are tried in the following order:

1. [API Token - Environment variables](#environment-variables)
1. [API Token - Config file](#config-file)
1. [Session file](#session-file)
1. [Password - Environment variables](#environment-variables_1)
1. [Password - Config file](#config-file_1)
1. [Password - Auth file](#auth-file)
1. [Password - Prompt](#prompt)

## API Token

The application supports authenticating with an API token. API tokens are created in the Zabbix frontend or via `zabbix-cli create_token`.

### Environment variables

The API token can be set as an environment variable:

```bash
export ZABBIX_API_TOKEN="API_TOKEN"
```

### Config file

The token can be set directly in the config file:

```toml
[api]
auth_token = "API_TOKEN"
```

## Session file

The application can store and reuse session tokens between runs. Multiple sessions can be stored at the same time, which allows for switching between different users and/or Zabbix servers seamlessly without having to re-authenticate.

This feature is enabled by default and configurable via the following options:

```toml
[app]
# Enable persistent sessions (default: true)
use_session_file = true

# Customize token file location (optional)
session_file = "/path/to/auth/token/file"

# Enforce secure file permissions (600) (default: true, no effect on Windows)
allow_insecure_auth_file = false
```

**How it works:**

- Log in once with username and password
- Token is automatically saved to the file
- Subsequent runs will use the saved token for authentication

When `allow_insecure_auth_file` is set to `false`, the application will attempt to set `600` (read/write for owner only) permissions on the token file when creating/updating it.

## Username and Password

The application supports authenticating with a username and password. The password can be set in the config file, an auth file, as environment variables, or prompted for when starting the application.

### Environment variables

The username and password can be set as environment variables:

```bash
export ZABBIX_USERNAME="Admin"
export ZABBIX_PASSWORD="zabbix"
```

### Config file

The password can be set directly in the config file:

```toml
[api]
username = "Admin"
password = "zabbix"
```

### Auth file

A file named `.zabbix-cli_auth` can be created in the user's home directory or in the application's data directory. The file should contain a single line of text in the format `USERNAME::PASSWORD`.

```bash
echo "Admin::zabbix" > ~/.zabbix-cli_auth
```

The location of the auth file file can be changed in the config file:

```toml
[app]
auth_file = "~/.zabbix-cli_auth"
```

### Prompt

When all other authentication methods fail, the application will prompt for a username and password. The default username in the prompt can be configured:

```toml
[api]
username = "Admin"
```

## URL

The URL of the Zabbix API can be set in the config file, as an environment variable, or prompted for when starting the application.

They are processed in the following order:

1. [Environment variables](#environment-variables_2)
1. [Config file](#config-file_2)
1. [Prompt](#prompt_1)

The URL should not include `/api_jsonrpc.php`.

### Environment variables

The URL can also be set as an environment variable:

```bash
export ZABBIX_URL="http://zabbix.example.com"
```

### Config file

The URL of the Zabbix API can be set in the config file:

```toml

[api]
url = "http://zabbix.example.com"
```

### Prompt

When all other methods fail, the application will prompt for the URL of the Zabbix API.