summaryrefslogtreecommitdiff
path: root/docs/tutorials/podman-install-certificate-authority.md
blob: bcd3056ba7e3afb4bf5255b62449230550a021bf (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
![PODMAN logo](../../logo/podman-logo-source.svg)

Install Certificate Authority
=============================

Organizations may create their own local certificate authority (CA) or acquire one from a third party.  This may mean more than one certificate, such as one or more intermediate certificates and a root certificate, for example.  In any case, it is necessary to add the certificate authority (CA) certificate(s) so that it can be employed for various use cases.

### Method one

Certificates may be either individual or concatenated (bundles). The following steps are one method to add such certificates to Podman.  It is assumed that Podman is running and the certificate(s) to be installed are available on an accessible server via curl.  If such access is not possible, an alternative method follows.

First, assuming a running Podman machine, ssh into the machine:
```
podman machine ssh
```

If Podman is running in the default rootless mode, an additional command is required to get to a root shell:

```
[core@localhost ~]$ sudo su -
```

After issuing the above command, the prompt should change to indicate the "root" instead of the "core" user.

Next, while in the machine, change to the directory where the certificate(s) should be installed:
```
[root@localhost ~]# cd /etc/pki/ca-trust/source/anchors
```

Then use curl to download the certificate.  Notes:
* The -k is only necessary if connecting securely to a server for which the certificate is not yet trusted
* The MY-SERVER.COM/SOME-CERTIFICATE.pem should be replaced as appropriate
```
[root@localhost anchors]# curl -k -o some-certificate.pem https://MY-SERVER.COM/SOME-CERTIFICATE.pem
```

Repeat as necessary for multiple certificates.

Once all of the certificates have been downloaded, run the command to add the certificates to the list of trusted CAs:
```
[root@localhost anchors]# update-ca-trust
```

Exit the machine:
```
[root@localhost anchors]# exit
```

If the "sudo su -" command was used to switch to a root shell as described above, an additional exit command is needed to exit the machine:

```
[core@localhost ~]$ exit
```

### Alternative Method

If the above method is for some reason not practical or desirable, the certificate may be created using vi.

As above, assuming a running Podman machine, ssh into the machine:

```
podman machine ssh
```

If the prompt starts with "core" instead of "root", switch to a root shell:

```
[core@localhost ~]$ sudo su -
```

Next, change to the directory where the certificate(s) should be installed:
```
[root@localhost ~]# cd /etc/pki/ca-trust/source/anchors
```

Then use vi to create the certificate.
```
[root@localhost ~]# vi SOME-CERTIFICATE.pem
```
After vi opens, copy the certificate to the clipboard, then in insert mode, paste the clipboard contents to vi.  Lastly, save the file and close vi.

Repeat as necessary for multiple certificates.

Once all of the certificates have been created, run the command to add the certificates to the list of trusted CAs:
```
[root@localhost anchors]# update-ca-trust
```

Exit the machine:
```
[root@localhost anchors]# exit
```

If the "sudo su -" command described above was used, an additional exit command is needed:

```
[core@localhost ~]$ exit
```

### Final Notes

The certificate installation will persist during machine restarts.  There is no need to stop and start the machine to begin using the certificate.