Linux:Scripts
From Cheatsheet
Jump to navigationJump to search
Template
#!/usr/bin/env bash
set -o errexit # Exit on error, do not continue running the script
set -o nounset # Trying to access a variable that has not been set generates an error
set -o pipefail # When a pipe fails generate an error
if [[ "${1-}" =~ ^-*h(elp)?$ ]] || [[ "${1}" == "" ]] ; then
echo ""
echo 'Usage: myscript.sh value1
This is the description of my script.
'
exit
echo ""
fi
Testing - []
# Use the test functionality [] to compare values and types, using expressions man test if [ -d "$MyDirectoryVariable" ]
https://stackoverflow.com/questions/638975/how-do-i-tell-if-a-file-does-not-exist-in-bash FILE=/home/javier/wopper.txt [ -b "$FILE" ] = Block special file [ -c "$FILE" ] = Special character file [ -d "$FILE" ] = If file exists [ -e "$FILE" ] = Check for file existence, regardless of type (node, directory, socket, etc.) [ -f "$FILE" ] = Check for regular file existence not a directory [ -G "$FILE" ] = Check if file exists and is owned by effective group ID [ -G "$FILE" ] = set-group-id - True if file exists and is set-group-id [ -k "$FILE" ] = Sticky bit [ -L "$FILE" ] = Symbolic link [ -O "$FILE" ] = True if file exists and is owned by the effective user id [ -r "$FILE" ] = Check if file is a readable [ -S "$FILE" ] = Check if file is socket [ -s "$FILE" ] = Check if file is nonzero size [ -u "$FILE" ] = Check if file set-user-id bit is set [ -w "$FILE" ] = Check if file is writable [ -x "$FILE" ] = Check if file is executable FOLDER=/home/javier/ [ -f "$FOLDER" ] = If directory exists
Common syntax
for
# Execute a command for all objects within this folder and all subdirectories for i in *; do du -h "$i" ; done # Execute a command x amount of times based on $i for((i=1;i<=5;++i)); do dd if=/dev/zero of=myshare/file-$i bs=1M count=1; done # Shell script version - Execute a command x amount of times based on $i for((i=1;i<=5;++i)) do echo $i done
if
Examples
FILE=~/todo.txt if [ -f "$FILE" ]; then cat "~/todo.txt" else echo "You don't have the file, so you should make it." fi
USER=$(whoami) FILE=~/todo.txt if [ "$USER" != "root" -a -f "$FILE" ]; then echo "You're a normal user, you do have the file and this is its output:" cat "$FILE" elif [ "$USER" != "root" -a ! -f "$FILE" ]; then echo "You're a normal user, you don't have the file, so you should make it." fi
Scripts
SSH
centos-create-user.sh
#!/bin/bash
# Execute as root
# Usage: ./centos-create-user.sh USER
USER="$1"
echo "Creating user ${USER}"
useradd -m ${USER} -G wheel
echo "Creating authorized keys file and settings rights for ${USER} user"
mkdir -p /home/${USER}/.ssh
cat << 'EOF' >> /home/${USER}/.ssh/authorized_keys
# PUT ANY KEYS IN HERE
# KEY-1
# KEY-2
# KEY-3
EOF
chown -R ${USER}:${USER} /home/${USER}/.ssh
chmod 700 /home/${USER}/.ssh
chmod 600 /home/${USER}/.ssh/authorized_keys
# EOF
ubuntu-create-user.sh
#!/bin/bash
# Execute as root
# Usage: ./ubuntu-create-user.sh USER
USER="$1"
echo "Creating user ${USER}"
adduser ${USER} --disabled-password
echo "Adding ${USER} to the sudo group"
usermod -aG sudo ${USER}
echo "Creating authorized keys file and settings rights for ${USER} user"
mkdir -p /home/${USER}/.ssh
cat << 'EOF' >> /home/${USER}/.ssh/authorized_keys
# PUT ANY KEYS IN HERE
# KEY-1
# KEY-2
# KEY-3
EOF
chown -R ${USER}:${USER} /home/${USER}/.ssh
chmod 700 /home/${USER}/.ssh
chmod 600 /home/${USER}/.ssh/authorized_keys
# EOF
Automatic sendmail
#!/bin/bash
#requires: date,sendmail
function fappend {
echo "$2">>$1;
}
YYYYMMDD=`date +%Y%m%d`
# CHANGE THESE
TOEMAIL="ADMINISTRATOR@MYDOMAIN.COM";
FREMAIL="FROMNOREPLY@MYDOMAIN.com";
SUBJECT="E-mail Subject";
MSGBODY=$(Command);
# DON'T CHANGE ANYTHING BELOW
TMP=`mktemp`
rm -rf $TMP;
fappend $TMP "From: $FREMAIL";
fappend $TMP "To: $TOEMAIL";
fappend $TMP "Reply-To: $FREMAIL";
fappend $TMP "Subject: $SUBJECT";
fappend $TMP "";
fappend $TMP "$MSGBODY";
fappend $TMP "";
fappend $TMP "";
cat $TMP|/usr/sbin/sendmail -t;
rm $TMP;