Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

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

# This file is part of Ansible 

# 

# Ansible is free software: you can redistribute it and/or modify 

# it under the terms of the GNU General Public License as published by 

# the Free Software Foundation, either version 3 of the License, or 

# (at your option) any later version. 

# 

# Ansible is distributed in the hope that it will be useful, 

# but WITHOUT ANY WARRANTY; without even the implied warranty of 

# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 

# GNU General Public License for more details. 

# 

# You should have received a copy of the GNU General Public License 

# along with Ansible. If not, see <http://www.gnu.org/licenses/>. 

 

from __future__ import (absolute_import, division, print_function) 

__metaclass__ = type 

 

from ansible.module_utils.facts.utils import get_file_content 

 

from ansible.module_utils.facts.collector import BaseFactCollector 

 

 

class SshPubKeyFactCollector(BaseFactCollector): 

name = 'ssh_pub_keys' 

_fact_ids = set(['ssh_host_pub_keys', 

'ssh_host_key_dsa_public', 

'ssh_host_key_rsa_public', 

'ssh_host_key_ecdsa_public', 

'ssh_host_key_ed25519_public']) 

 

def collect(self, module=None, collected_facts=None): 

ssh_pub_key_facts = {} 

keytypes = ('dsa', 'rsa', 'ecdsa', 'ed25519') 

 

# list of directories to check for ssh keys 

# used in the order listed here, the first one with keys is used 

keydirs = ['/etc/ssh', '/etc/openssh', '/etc'] 

 

for keydir in keydirs: 

for type_ in keytypes: 

factname = 'ssh_host_key_%s_public' % type_ 

if factname in ssh_pub_key_facts: 

# a previous keydir was already successful, stop looking 

# for keys 

return ssh_pub_key_facts 

key_filename = '%s/ssh_host_%s_key.pub' % (keydir, type_) 

keydata = get_file_content(key_filename) 

if keydata is not None: 

ssh_pub_key_facts[factname] = keydata.split()[1] 

 

return ssh_pub_key_facts