summaryrefslogtreecommitdiff
path: root/manifests/key.pp
diff options
context:
space:
mode:
authorMicah <micah@riseup.net>2016-05-17 14:25:27 +0000
committerMicah <micah@riseup.net>2016-05-17 14:25:27 +0000
commit5268a87c329f895017f8ea6c6abc377a4f9a6a77 (patch)
tree7592ee5d07f5d0e93a40d0432d6a195ecc9ccd0d /manifests/key.pp
parent497513547be79f9d3c8e96f1650ec43ee634b277 (diff)
parentf68560e7adbbbfad43f3bfc44be4423af561b0f1 (diff)
Merge branch 'lint_main_class' into 'master' HEADmaster
liniting main class, moving key() to seperate class The removal of ` $configdir = '/etc/backup.d',` was because this parameter was specified twice in the main class. See merge request !6
Diffstat (limited to 'manifests/key.pp')
-rw-r--r--manifests/key.pp41
1 files changed, 41 insertions, 0 deletions
diff --git a/manifests/key.pp b/manifests/key.pp
new file mode 100644
index 0000000..9d34cdb
--- /dev/null
+++ b/manifests/key.pp
@@ -0,0 +1,41 @@
+# generate and deploy backupninja sshkeys
+define backupninja::key(
+ $user = $name,
+ $createkey = false,
+ $keymanage = $backupninja::keymanage,
+ $keyowner = $backupninja::keyowner,
+ $keygroup = $backupninja::keygroup,
+ $keystore= $backupninja::keystore,
+ $keystorefspath = $backupninja::keystorefspath,
+ $keytype = $backupninja::keytype,
+ $keydest = $backupninja::keydest,
+ $keydestname = "id_${backupninja::keytype}" )
+{
+
+ # generate the key
+ if $createkey == true {
+ if $keystorefspath == false {
+ err('need to define a destination directory for sshkey creation!')
+ }
+ $ssh_keys = ssh_keygen("${keystorefspath}/${keydestname}")
+ }
+
+ # deploy/manage the key
+ if $keymanage == true {
+ $keydestfile = "${keydest}/${keydestname}"
+ ensure_resource('file', $keydest, {
+ 'ensure' => 'directory',
+ 'mode' => '0700',
+ 'owner' => $keyowner,
+ 'group' => $keygroup
+ })
+ ensure_resource('file', $keydestfile, {
+ 'ensure' => 'present',
+ 'source' => "${keystore}/${user}_id_${keytype}",
+ 'mode' => '0700',
+ 'owner' => $keyowner,
+ 'group' => $keygroup,
+ 'require' => File[$keydest],
+ })
+ }
+}