aboutsummaryrefslogtreecommitdiffstats
path: root/modules/gnupg
diff options
context:
space:
mode:
authorNicolas Vigier <boklm@mageia.org>2011-02-02 18:11:34 +0000
committerNicolas Vigier <boklm@mageia.org>2011-02-02 18:11:34 +0000
commit1cd967ce52c5c175d5b7246f728fea50be006e6c (patch)
tree6ae4b1064b5b73e05650487cec78ce895b80ddde /modules/gnupg
parent83f2baffcc037c1ba32301c5157b5957ce0c9da7 (diff)
downloadpuppet-1cd967ce52c5c175d5b7246f728fea50be006e6c.tar
puppet-1cd967ce52c5c175d5b7246f728fea50be006e6c.tar.gz
puppet-1cd967ce52c5c175d5b7246f728fea50be006e6c.tar.bz2
puppet-1cd967ce52c5c175d5b7246f728fea50be006e6c.tar.xz
puppet-1cd967ce52c5c175d5b7246f728fea50be006e6c.zip
- allow selecting keyring directory and user
- make it possible to generate multiple keys in the same keyring
Diffstat (limited to 'modules/gnupg')
-rw-r--r--modules/gnupg/manifests/init.pp22
-rw-r--r--modules/gnupg/templates/create_gnupg_keys.sh19
2 files changed, 31 insertions, 10 deletions
diff --git a/modules/gnupg/manifests/init.pp b/modules/gnupg/manifests/init.pp
index b7f5781a..66440224 100644
--- a/modules/gnupg/manifests/init.pp
+++ b/modules/gnupg/manifests/init.pp
@@ -34,21 +34,29 @@ class gnupg {
$key_name,
$key_type = 'RSA',
$key_length = '1024',
- $expire_date = '1m'
+ $expire_date = '1m',
+ $login = 'signbot',
+ $batchdir = '/var/lib/signbot/batches',
+ $keydir = '/var/lib/signbot/keys',
) {
include gnupg::client
file { "$name.batch":
ensure => present,
- path => "/etc/gnupg/batches/$name.batch",
+ path => "$batchdir/$name.batch",
content => template("gnupg/batch")
}
- # TODO make sure the perm are good
- exec { "/usr/local/bin/create_gnupg_keys.sh $name":
- user => root,
- creates => "/etc/gnupg/keys/$name.secring",
- require => File["/etc/gnupg/batches/$name.batch"]
+ file { "$keydir":
+ ensure => directory,
+ owner => $login,
+ mode => 700,
+ }
+
+ exec { "/usr/local/bin/create_gnupg_keys.sh $batchdir/$name.batch $keydir $batchdir/$name.done":
+ user => $login,
+ creates => "$batchdir/$name.done",
+ require => [File["$keydir"], File["$batchdir/$name.batch"]],
}
}
}
diff --git a/modules/gnupg/templates/create_gnupg_keys.sh b/modules/gnupg/templates/create_gnupg_keys.sh
index fbb41277..a2caba2d 100644
--- a/modules/gnupg/templates/create_gnupg_keys.sh
+++ b/modules/gnupg/templates/create_gnupg_keys.sh
@@ -1,11 +1,24 @@
#!/bin/bash
-NAME=$1
+BATCHFILE="$1"
+HOMEDIR="$2"
+LOCK="$3"
+
+test $# -eq 3 || exit 1
+
+if [ -e "$LOCK" ]
+then
+ echo "Lock file already exist." 1>&2
+ echo "Remove $LOCK if you want to regenerate key." 1>&2
+ exit 2
+fi
+
+touch "$LOCK"
/sbin/rngd -f -r /dev/urandom &
RAND=$!
-cd /etc/gnupg/keys/
-gpg --homedir /etc/gnupg/keys/ --batch --gen-key /etc/gnupg/batches/$NAME.batch
+cd $HOMEDIR
+gpg --homedir $HOMEDIR --batch --gen-key $BATCHFILE
EXIT=$?
kill $RAND