mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-09-17 17:00:27 +02:00
2022-09-20 Fred Gleason <fredg@paravelsystems.com>
* Added an appendix 'Creating and Configuring a Secure Shell Identity Key-pair for Rivendell' to the Operations Guide. Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
This commit is contained in:
parent
19370379b4
commit
0d4dd0b635
@ -23342,3 +23342,6 @@
|
||||
2022-09-19 Fred Gleason <fredg@paravelsystems.com>
|
||||
* Added support for using a ssh(1) identity file for authentication
|
||||
to the 'Upload' and 'Download' event types in rdcatch(1).
|
||||
2022-09-20 Fred Gleason <fredg@paravelsystems.com>
|
||||
* Added an appendix 'Creating and Configuring a Secure Shell Identity
|
||||
Key-pair for Rivendell' to the Operations Guide.
|
||||
|
@ -26,6 +26,7 @@ OPSGUIDE_HTML = appendix.filepath_wildcards.html\
|
||||
appendix.metadata_wildcards.html\
|
||||
appendix.rivendell_filter.html\
|
||||
appendix.wings_filter.html\
|
||||
appendix.ssh_keys.html\
|
||||
chapter.overview.html\
|
||||
chapter.pad.html\
|
||||
chapter.rdadmin.html\
|
||||
@ -291,6 +292,10 @@ OPSGUIDE_IMAGES = rdadmin.add_switcher_dialog.png\
|
||||
rdlogmanager.select_date_dialog.png\
|
||||
rdlogmanager.select_report_dates_dialog.png\
|
||||
rdlogmanager.service_association_dialog.png\
|
||||
ssh_keys.edit_host_dialog.png\
|
||||
ssh_keys.ordinary_prompt.png\
|
||||
ssh_keys.root_prompt.png\
|
||||
ssh_keys.terminal_window.png\
|
||||
utilities.rmlsend_screenshot.png\
|
||||
voicetracking.voice_tracker_button.png\
|
||||
voicetracking.voice_tracker_dialog.png\
|
||||
@ -338,6 +343,7 @@ OPSGUIDE_DEPS = $(OPSGUIDE_IMAGES) \
|
||||
rdlogin.xml\
|
||||
rdlogmanager.xml\
|
||||
rivendell_filter.xml\
|
||||
ssh_keys.xml\
|
||||
wings_filter.xml\
|
||||
rml.xml\
|
||||
utilities.xml\
|
||||
|
@ -25,6 +25,7 @@
|
||||
<!ENTITY metadata_wildcards SYSTEM "metadata_wildcards.xml">
|
||||
<!ENTITY rivendell_filter SYSTEM "rivendell_filter.xml">
|
||||
<!ENTITY wings_filter SYSTEM "wings_filter.xml">
|
||||
<!ENTITY ssh_keys SYSTEM "ssh_keys.xml">
|
||||
]>
|
||||
|
||||
<book xmlns="http://docbook.org/ns/docbook" version="5.0">
|
||||
@ -59,6 +60,7 @@
|
||||
&metadata_wildcards;
|
||||
&rivendell_filter;
|
||||
&wings_filter;
|
||||
&ssh_keys;
|
||||
</part>
|
||||
</book>
|
||||
|
||||
|
BIN
docs/opsguide/ssh_keys.edit_host_dialog.png
Normal file
BIN
docs/opsguide/ssh_keys.edit_host_dialog.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 84 KiB |
BIN
docs/opsguide/ssh_keys.ordinary_prompt.png
Normal file
BIN
docs/opsguide/ssh_keys.ordinary_prompt.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.9 KiB |
BIN
docs/opsguide/ssh_keys.root_prompt.png
Normal file
BIN
docs/opsguide/ssh_keys.root_prompt.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.8 KiB |
BIN
docs/opsguide/ssh_keys.terminal_window.png
Normal file
BIN
docs/opsguide/ssh_keys.terminal_window.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 13 KiB |
184
docs/opsguide/ssh_keys.xml
Normal file
184
docs/opsguide/ssh_keys.xml
Normal file
@ -0,0 +1,184 @@
|
||||
<appendix xmlns="http://docbook.org/ns/docbook" xml:id="appendix.ssh_keys">
|
||||
<title>Creating and Configuring a Secure Shell Identity Key-pair for
|
||||
Rivendell</title>
|
||||
<sect1 xml:id="sect.ssh_keys.overview">
|
||||
<title>Overview</title>
|
||||
<para>
|
||||
Rivendell supports the use of a public/private key pair (also referred
|
||||
to as an "identity" in the Secure Shell documentation) for
|
||||
SFTP file transfers. This appendix provides an example of how to
|
||||
generate and install such a set of key pair files so that they can be
|
||||
used by Rivendell.
|
||||
</para>
|
||||
</sect1>
|
||||
|
||||
<sect1 xml:id="sect.ssh_keys.requirements">
|
||||
<title>Requirements</title>
|
||||
<para>
|
||||
This procedure uses the
|
||||
<command>ssh-keygen</command><manvolnum>1</manvolnum> program, which
|
||||
should be already installed on any system running Rivendell. If not,
|
||||
it can be obtained most distros by installing the
|
||||
<userinput>openssh</userinput> package.
|
||||
</para>
|
||||
</sect1>
|
||||
|
||||
<sect1 xml:id="sect.ssh_keys.generating_the_keys">
|
||||
<title>Generating the Keys</title>
|
||||
<para>
|
||||
In this example, we will generate a pair of files, called
|
||||
<userinput>rivendell_key</userinput> and
|
||||
<userinput>rivendell_key.pub</userinput>. The first file
|
||||
(<userinput>rivendell_key</userinput>) is the
|
||||
<emphasis>private</emphasis> key (also known as the
|
||||
<emphasis>identity file</emphasis>), and will remain on the Rivendell
|
||||
system where it was generated,
|
||||
while the other (<userinput>rivendell_key.pub</userinput>) is the
|
||||
<emphasis>public</emphasis> key, which will be deployed to the
|
||||
remote server(s) with which Rivendell will be interacting.
|
||||
</para>
|
||||
<sect2 xml:id="sect.ssh_keys.generating_the_keys.procedure">
|
||||
<title>Procedure</title>
|
||||
<para>
|
||||
Open a command line window on the Rivendell system. (This is
|
||||
sometimes also referred to as a "Terminal" or
|
||||
a "Console" depending upon the desktop environment
|
||||
being used.
|
||||
</para>
|
||||
<para>
|
||||
<mediaobject>
|
||||
<imageobject>
|
||||
<imagedata align="center" fileref="ssh_keys.terminal_window.png" width="128mm"/>
|
||||
</imageobject>
|
||||
<caption><para>The Terminal Window</para></caption>
|
||||
</mediaobject>
|
||||
</para>
|
||||
<para>
|
||||
Enter command to become the 'root' user. On CentOS/RedHat systems,
|
||||
the command to do this is <userinput>su -</userinput>, while on
|
||||
Debian/Ubuntu-based systems it is <userinput>sudo su -</userinput>.
|
||||
In either case, you will be prompted to enter a password. Enter the
|
||||
password and then press the <userinput>ENTER</userinput> key.
|
||||
</para>
|
||||
<note>
|
||||
You may not see anything echo to the screen while entering the
|
||||
password. This is normal!
|
||||
</note>
|
||||
<para>
|
||||
You should see the prompt in the terminal change from the dollar
|
||||
sign [<computeroutput>$</computeroutput>] to a pound sign
|
||||
[<computeroutput>#</computeroutput>] to signify that the window
|
||||
now as 'root' permissions.
|
||||
</para>
|
||||
<para>
|
||||
<mediaobject>
|
||||
<imageobject>
|
||||
<imagedata align="center" fileref="ssh_keys.ordinary_prompt.png" width="50mm"/>
|
||||
</imageobject>
|
||||
<caption><para>Ordinary Prompt</para></caption>
|
||||
</mediaobject>
|
||||
</para>
|
||||
<para>
|
||||
<mediaobject>
|
||||
<imageobject>
|
||||
<imagedata align="center" fileref="ssh_keys.root_prompt.png" width="50mm"/>
|
||||
</imageobject>
|
||||
<caption><para>"Root" Prompt</para></caption>
|
||||
</mediaobject>
|
||||
</para>
|
||||
<para>
|
||||
At the root prompt, enter the following command, followed by the
|
||||
<userinput>[Enter]</userinput> key:
|
||||
<userinput>ssh-keygen -t rsa</userinput>
|
||||
</para>
|
||||
<para>
|
||||
The system will respond with:
|
||||
<computeroutput><literallayout>Generating public/private rsa key pair.
|
||||
Enter file in which to save the key (/root/.ssh/id_rsa):
|
||||
</literallayout></computeroutput>
|
||||
</para>
|
||||
<para>
|
||||
Enter the following location to save the key pair:
|
||||
<userinput>/usr/share/rivendell/keys/id_rsa_rivendell</userinput>,
|
||||
followed by the <userinput>[Enter]</userinput> key.
|
||||
</para>
|
||||
<para>
|
||||
The system will respond with:
|
||||
<computeroutput><literallayout>Enter passphrase (empty for no passphrase):
|
||||
</literallayout></computeroutput>
|
||||
Enter a passphrase, followed by the <userinput>[Enter]</userinput> key.
|
||||
The system will prompt you to repeat the passphrase:
|
||||
<computeroutput>
|
||||
<literallayout>Enter same passphrase again:</literallayout>
|
||||
</computeroutput>
|
||||
Enter the passphrase again, followed by <userinput>[Enter]</userinput>.
|
||||
You should then see output similar to:
|
||||
<computeroutput>
|
||||
<literallayout>Your identification has been saved in /usr/share/rivendell/keys/
|
||||
id_rsa_rivendell.
|
||||
Your public key has been saved in /usr/share/rivendell/keys/id_rsa_r
|
||||
ivendell.pub.
|
||||
The key fingerprint is:
|
||||
SHA256:Obdzp8PaV5D68AJULnz+XJjXUmojNqygdu2+blAuaWk root@frozone.para
|
||||
velsystems.com
|
||||
The key's randomart image is:
|
||||
+---[RSA 2048]----+
|
||||
| |
|
||||
| . |
|
||||
| . o . |
|
||||
| .= o o .|
|
||||
| S*.= . *.|
|
||||
| Eoo.O B =|
|
||||
| + =o=.X.* |
|
||||
| o . +++o* |
|
||||
| . . =*oo+ |
|
||||
+----[SHA256]-----+</literallayout>
|
||||
</computeroutput>
|
||||
</para>
|
||||
<note>
|
||||
The passphrase is your final line of defense against a malicious
|
||||
actor should they get hold of a copy of your private key. Choose
|
||||
a long phrase that is not easily guessable.
|
||||
</note>
|
||||
<caution>
|
||||
You will need to enter the passphrase each time you add an
|
||||
an RDCatch event or RSS Feed that uses this identity!
|
||||
</caution>
|
||||
<para>
|
||||
Next, set the ownership of the private key to the
|
||||
<userinput>rivendell</userinput> user and group by doing:
|
||||
<computeroutput>
|
||||
<literallayout>chown rivendell:rivendell /usr/share/rivendell/keys/id_rsa_rivendell</literallayout>
|
||||
</computeroutput>
|
||||
followed by the <userinput>[Enter]</userinput> key.
|
||||
</para>
|
||||
<para>
|
||||
The public key now resides at
|
||||
<computeroutput>/usr/share/rivendell/keys/id_rsa_rivendell.pub</computeroutput>,
|
||||
and can be deployed on remote servers. The private key (ssh identity)
|
||||
resides at
|
||||
<computeroutput>/usr/share/rivendell/keys/id_rsa_rivendell</computeroutput>.
|
||||
Open RDAdmin, touch <computeroutput>Manage Hosts</computeroutput>,
|
||||
select the name of host being configured and then touch the
|
||||
<computeroutput>Edit</computeroutput> button to open the
|
||||
<computeroutput>Edit Host</computeroutput> and enter the location
|
||||
of the private key in the
|
||||
<computeroutput>SSH Ident. File</computeroutput> field, then touch
|
||||
the <computeroutput>OK</computeroutput> button.
|
||||
</para>
|
||||
<para>
|
||||
<mediaobject>
|
||||
<imageobject>
|
||||
<imagedata align="center" fileref="ssh_keys.edit_host_dialog.png" width="90mm"/>
|
||||
</imageobject>
|
||||
<caption>
|
||||
<para>
|
||||
Populating the <computeroutput>SSH Ident. File</computeroutput>
|
||||
Field
|
||||
</para></caption>
|
||||
</mediaobject>
|
||||
</para>
|
||||
</sect2>
|
||||
</sect1>
|
||||
|
||||
</appendix>
|
Loading…
x
Reference in New Issue
Block a user