diff options
Diffstat (limited to 'src/os-plugins/plugins/eduroam/XX_eduroam.sh')
-rw-r--r-- | src/os-plugins/plugins/eduroam/XX_eduroam.sh | 27 |
1 files changed, 17 insertions, 10 deletions
diff --git a/src/os-plugins/plugins/eduroam/XX_eduroam.sh b/src/os-plugins/plugins/eduroam/XX_eduroam.sh index fe8bcef6..d977a791 100644 --- a/src/os-plugins/plugins/eduroam/XX_eduroam.sh +++ b/src/os-plugins/plugins/eduroam/XX_eduroam.sh @@ -20,19 +20,26 @@ if [ -e /initramfs/plugin-conf/eduroam.conf ]; then [ $DEBUGLEVEL -gt 0 ] && echo "executing the 'eduroam' plugin..."; # copy files - - cp /mnt/opt/openslx/plugin-repo/eduroam/files/lib/security/pam_script.so \ - /mnt/lib/security - cp /mnt/opt/openslx/plugin-repo/eduroam/files/etc/pam_radius_auth.conf \ - /mnt/etc - cp /mnt/opt/openslx/plugin-repo/eduroam/files/etc/pam.d/radius-auth \ - /mnt/etc/pam.d - cp -r /mnt/opt/openslx/plugin-repo/eduroam/files/usr/share \ - /mnt/usr/share + cd /mnt/opt/openslx/plugin-repo/eduroam/files + # better with tar, doesn't work however... + #tar c * | tar x -C /mnt + for f in $(find . -type f); do cp $f /mnt/$f; done + + # delete old config, just to make sure there are no conflicts + pam_radius_conf=/mnt/etc/pam_radius_auth.conf + [ -f $pam_radius_conf ] && rm $pam_radius_conf + + # hack to get the actual literal string from the config file... + secret=$(cat /initramfs/plugin-conf/eduroam.conf | grep secret | \ + sed 's/eduroam_server_secret="//g' | sed 's/\(.*\)./\1/') + + # write eduroam server config + echo -n "$eduroam_server_ip $secret 3" > $pam_radius_conf # activate eduroam in kdm # TODO: for other desktop managers - sed 's/@include common-auth/@include radius-auth/g' -i /mnt/etc/pam.d/kdm + pam_kdm=/mnt/etc/pam.d/kdm + [ -f $pam_kdm ] && sed 's/@include common-auth/@include radius-auth/g' -i $pam_kdm [ $DEBUGLEVEL -gt 0 ] && echo "done with the 'eduroam' plugin..."; fi |