凌云实验室推出的ARM Linux物联网网关开发板IGKBoard(IoT Gateway Kit Board)项目源码
guowenxue
2021-12-30 88700c0fc909f6051241232a0bd7277781619d53
update buildroot to fix debian sudo bug
3 files modified
29 ■■■■ changed files
bsp/images/build.sh 3 ●●●●● patch | view | raw | blame | history
bsp/rootfs/build.sh 22 ●●●● patch | view | raw | blame | history
bsp/rootfs/extra_apps.json 4 ●●●● patch | view | raw | blame | history
bsp/images/build.sh
@@ -167,7 +167,10 @@
    mount -t ext4 /dev/mapper/${LOOP_DEV}p2 ${MNT_POINT}
    tar -xjf ${ROOTFS_TAR} -C ${MNT_POINT} && sync
    if [ $SYSTEM != debian ] ;then
    chown -R root.root ${MNT_POINT} && sync
    fi
    umount ${MNT_POINT}
}
bsp/rootfs/build.sh
@@ -14,6 +14,7 @@
TAR_PATH=${PRJ_PATH}/../tarball
# rootfs configuration
DEBIAN_URL=http://ftp.cn.debian.org/debian/
ARCH=armhf
DEF_USER=lingyun
DEF_PASSWD=12345
@@ -87,8 +88,8 @@
    export LANG=C
    printf "\n\n -- debootstrap fetch start --\n\n"
    echo "debootstrap --arch=${ARCH} --foreign ${DISTRO} ${ROOTFS_DIR} http://ftp.cn.debian.org/debian/"
    debootstrap --arch=${ARCH} --foreign ${DISTRO} ${ROOTFS_DIR} http://ftp.cn.debian.org/debian/
    echo "debootstrap --arch=${ARCH} --foreign ${DISTRO} ${ROOTFS_DIR} ${DEBIAN_URL}"
    debootstrap --arch=${ARCH} --foreign ${DISTRO} ${ROOTFS_DIR} ${DEBIAN_URL}
    chroot ${ROOTFS_DIR} debootstrap/debootstrap --second-stage
    printf "\n\n -- debootstrap config start --\n\n"
@@ -98,6 +99,10 @@
    # Clear the MD5 value to install extra apps
    sed -i -e "s|.*md5apt.*|\t\"md5apt\":\"MD5_Auto_Generate_Here\"|g" $APPS_CONF
    cd ${ROOTFS_DIR}
    tar -cjf ../${ROOTFS_DIR}.orig.tar.bz2 *
    cd -
}
@@ -134,6 +139,7 @@
    chroot ${ROOTFS_DIR} apt update
    chroot ${ROOTFS_DIR} apt install -y ${extra_apps}
    chroot ${ROOTFS_DIR} apt autoremove
    umount ${ROOTFS_DIR}/{sys,proc,dev/pts,dev}
@@ -144,15 +150,14 @@
    # modify root password
    chroot ${ROOTFS_DIR} sh -c "echo root:${DEF_PASSWD} | chpasswd"
    # add extra user account
    # add default user account
    set +e
    grep "$DEF_USER" ${ROOTFS_DIR}/etc/passwd > /dev/null 2>&1
    if [ $? != 0 ] ; then
        printf "\n\n -- setup default user account --\n\n"
        chroot ${ROOTFS_DIR} sh -c "useradd -m -s /bin/bash ${DEF_USER}"
        chroot ${ROOTFS_DIR} sh -c "echo ${DEF_USER}:${DEF_PASSWD} | chpasswd"
        chroot ${ROOTFS_DIR} sh -c "usermod -G video,audio,sudo avnet"
        echo "${DEF_USER}    ALL=(ALL:ALL) NOPASSWD:ALL" >> ${ROOTFS_DIR}/etc/sudoers
        chroot ${ROOTFS_DIR} sh -c "usermod -aG video,audio,sudo ${DEF_USER}"
    fi
    set -e
}
@@ -236,7 +241,7 @@
    # update profile
    sed -i "s|PS1='# '|PS1='\\\u@\\\h:\\\w# '|g" ${ROOTFS_DIR}/etc/profile
    sed -i "s|PS1='$ '|PS1='\\\u@\\\h:\\\w$ '|g" ${ROOTFS_DIR}/etc/profile
    sed -i 's|PATH=.*|PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"|g' ${ROOTFS_DIR}/etc/profile
    # add ls alias for display with color
    grep "^alias ls=" ${ROOTFS_DIR}/etc/profile > /dev/null 2>&1
@@ -244,6 +249,11 @@
       echo "alias ls='ls --color=auto'" >> ${ROOTFS_DIR}/etc/profile
    fi
    # update sudo without passwd for yocto and debian
    if [ $SYSTEM != buildroot ]  ; then
        sed -i "s|^%sudo.*|%sudo   ALL=(ALL:ALL) NOPASSWD:ALL|g" ${ROOTFS_DIR}/etc/sudoers
    fi
    # permit root ssh login
    sed -i "s|^#PermitRootLogin.*|PermitRootLogin yes|g" ${ROOTFS_DIR}/etc/ssh/sshd_config
    sed -i "s|^#PasswordAuthentication.*|PasswordAuthentication yes|g" ${ROOTFS_DIR}/etc/ssh/sshd_config
bsp/rootfs/extra_apps.json
@@ -17,9 +17,9 @@
    },
    "extra_debian_apps": {
        "basic": "wget curl vim tree file parted locales lsb-release tzdata",
        "basic": "wget curl sudo tree file parted locales lsb-release tzdata",
        "admin": "net-tools network-manager wireless-tools openssh-server",
        "dev": "v4l-utils"
        "dev": "v4l-utils vim"
    },
    "md5apt":"MD5_Auto_Generate_Here"