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

Mail

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;