Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/distrib/utils/embedded Add support for configuring Amazon.co...



details:   https://anonhg.NetBSD.org/src/rev/ddde288c860f
branches:  trunk
changeset: 994984:ddde288c860f
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Fri Nov 30 20:53:02 2018 +0000

description:
Add support for configuring Amazon.com EC2 SSH keys and hostnames. While
here, only set wscons=YES if a wsdisplay0 device is present.

diffstat:

 distrib/utils/embedded/conf/arm64.conf  |  10 +++++-
 distrib/utils/embedded/conf/armv7.conf  |   4 +-
 distrib/utils/embedded/conf/evbarm.conf |  10 +++++-
 distrib/utils/embedded/files/ec2_init   |  52 +++++++++++++++++++++++++++++++++
 4 files changed, 71 insertions(+), 5 deletions(-)

diffs (128 lines):

diff -r b64ab7b6147d -r ddde288c860f distrib/utils/embedded/conf/arm64.conf
--- a/distrib/utils/embedded/conf/arm64.conf    Fri Nov 30 17:53:08 2018 +0000
+++ b/distrib/utils/embedded/conf/arm64.conf    Fri Nov 30 20:53:02 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: arm64.conf,v 1.4 2018/08/27 22:36:49 jmcneill Exp $
+# $NetBSD: arm64.conf,v 1.5 2018/11/30 20:53:02 jmcneill Exp $
 # ARM64 customization script used by mkimage
 #
 board=arm64
@@ -21,12 +21,18 @@
        customize_evbarm
        cat >> "${mnt}/etc/rc.conf" << EOF
 mdnsd=YES
-wscons=YES
 devpubd=YES
+wscons=\$(dev_exists wsdisplay0)
+ec2_init=\$(dev_exists ena0)
 EOF
 }
 
 populate_common() {
+       # Add EC2 init script
+       cp ${DIR}/files/ec2_init ${mnt}/etc/rc.d/ec2_init
+       echo "./etc/rc.d/ec2_init type=file uname=root gname=wheel mode=0555" \
+           >> "$tmp/selected_sets"
+
        # Rename kernel to netbsd.img
        mv "${mnt}/boot/netbsd-${kernel_GENERIC64}.img" "${mnt}/boot/netbsd.img"
 
diff -r b64ab7b6147d -r ddde288c860f distrib/utils/embedded/conf/armv7.conf
--- a/distrib/utils/embedded/conf/armv7.conf    Fri Nov 30 17:53:08 2018 +0000
+++ b/distrib/utils/embedded/conf/armv7.conf    Fri Nov 30 20:53:02 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: armv7.conf,v 1.27 2018/11/22 21:11:37 aymeric Exp $
+# $NetBSD: armv7.conf,v 1.28 2018/11/30 20:53:02 jmcneill Exp $
 # ARMv7 customization script used by mkimage
 #
 board=armv7
@@ -26,8 +26,8 @@
        customize_evbarm
        cat >> "${mnt}/etc/rc.conf" << EOF
 mdnsd=YES
-wscons=YES
 devpubd=YES
+wscons=\$(dev_exists wsdisplay0)
 EOF
 }
 
diff -r b64ab7b6147d -r ddde288c860f distrib/utils/embedded/conf/evbarm.conf
--- a/distrib/utils/embedded/conf/evbarm.conf   Fri Nov 30 17:53:08 2018 +0000
+++ b/distrib/utils/embedded/conf/evbarm.conf   Fri Nov 30 20:53:02 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: evbarm.conf,v 1.30 2018/10/06 13:11:22 jmcneill Exp $
+# $NetBSD: evbarm.conf,v 1.31 2018/11/30 20:53:02 jmcneill Exp $
 # evbarm shared config
 #
 image=$HOME/${board}.img
@@ -127,6 +127,14 @@
        
        cp ${release}/etc/rc.conf ${mnt}/etc/rc.conf
        cat >> ${mnt}/etc/rc.conf << EOF
+dev_exists() {
+       if /sbin/drvctl -l $1 >/dev/null 2>&1 ; then
+               printf YES
+       else
+               printf NO
+       fi
+}
+
 rc_configured=YES
 hostname=${board}
 sshd=YES
diff -r b64ab7b6147d -r ddde288c860f distrib/utils/embedded/files/ec2_init
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/distrib/utils/embedded/files/ec2_init     Fri Nov 30 20:53:02 2018 +0000
@@ -0,0 +1,52 @@
+#!/bin/sh
+#
+# $NetBSD: ec2_init,v 1.1 2018/11/30 20:53:02 jmcneill Exp $
+#
+# PROVIDE: ec2_init
+# REQUIRE: NETWORKING
+# BEFORE:  LOGIN
+
+$_rc_subr_loaded . /etc/rc.subr
+
+name="ec2_init"
+rcvar=${name}
+start_cmd="ec2_init"
+stop_cmd=":"
+
+METADATA_URL="http://169.254.169.254/latest/meta-data/";
+SSH_KEY_URL="public-keys/0/openssh-key"
+HOSTNAME_URL="hostname"
+
+SSH_KEY_FILE="/root/.ssh/authorized_keys"
+
+ec2_init()
+{
+       (
+       umask 022
+       # fetch the key pair from Amazon Web Services
+       EC2_SSH_KEY=$(ftp -o - "${METADATA_URL}${SSH_KEY_URL}")
+
+       if [ -n "$EC2_SSH_KEY" ]; then
+               # A key pair is associated with this instance, add it
+               # to root 'authorized_keys' file
+               mkdir -p $(dirname "$SSH_KEY_FILE")
+               touch "$SSH_KEY_FILE"
+               cd $(dirname "$SSH_KEY_FILE")
+
+               grep -q "$EC2_SSH_KEY" "$SSH_KEY_FILE"
+               if [ $? -ne 0 ]; then
+                       echo "Setting EC2 SSH key pair: ${EC2_SSH_KEY##* }"
+                       echo "$EC2_SSH_KEY" >> "$SSH_KEY_FILE"
+               fi
+       fi
+
+       # set hostname
+       HOSTNAME=$(ftp -o - "${METADATA_URL}${HOSTNAME_URL}")
+       echo "Setting EC2 hostname: ${HOSTNAME}"
+       echo "$HOSTNAME" > /etc/myname
+       hostname "$HOSTNAME"
+       )
+}
+
+load_rc_config $name
+run_rc_command "$1"



Home | Main Index | Thread Index | Old Index