-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcryptobear.sh
executable file
·127 lines (99 loc) · 2.77 KB
/
cryptobear.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#!/bin/sh
# Decrypt archived files. Take encrypted files and unzip.
cat <<'EOF'
/$$$$$$ /$$$$$$$ /$$ /$$ /$$$$$$$ /$$$$$$$$ /$$$$$$
/$$__ $$| $$__ $$| $$ /$$/| $$__ $$|__ $$__//$$__ $$
| $$ \__/| $$ \ $$ \ $$ /$$/ | $$ \ $$ | $$ | $$ \ $$
| $$ | $$$$$$$/ \ $$$$/ | $$$$$$$/ | $$ | $$ | $$
| $$ | $$__ $$ \ $$/ | $$____/ | $$ | $$ | $$
| $$ $$| $$ \ $$ | $$ | $$ | $$ | $$ | $$
| $$$$$$/| $$ | $$ | $$ | $$ | $$ | $$$$$$/
\______/ |__/ |__/ |__/ |__/ |__/ \______/
/$$$$$$$ /$$$$$$$$ /$$$$$$ /$$$$$$$
| $$__ $$| $$_____/ /$$__ $$| $$__ $$
| $$ \ $$| $$ | $$ \ $$| $$ \ $$
| $$$$$$$ | $$$$$ | $$$$$$$$| $$$$$$$/
| $$__ $$| $$__/ | $$__ $$| $$__ $$
| $$ \ $$| $$ | $$ | $$| $$ \ $$
| $$$$$$$/| $$$$$$$$| $$ | $$| $$ | $$
|_______/ |________/|__/ |__/|__/ |__/
ENCRYPT / DECRYPT FILES
EOF
RESTORE='\033[0m'
YELLOW='\033[00;33m'
GREEN='\033[00;32m'
function msg {
echo "$1"$RESTORE
}
# Common vars
hash=''YOUR PASSWORD HERE''
basedir="crypt/"
encrypted_file_dir="${basedir}decrypt/"
decrypted_file_dir="${basedir}encrypt/"
query="Encrypt or Decrypt? (e/d) "
# Env params
echo "** ENV SETUP **"
echo "Encryption paths: "
msg $GREEN$encrypted_file_dir
msg $GREEN$decrypted_file_dir
if [ -z ${hash+x} ]; then
msg $YELLOW"No hash available to encrypt/decrypt, pls add.";
else
msg $GREEN"Hash loaded."
fi
msg $GREEN"Using OPENSSL AES 256 CBC encryption"
echo ""
# Start program
msg "$GREEN$query"
read -r requested_action
if [[ "$requested_action" = "d" ]]; then
# DECRYPT FILES
function decrypt {
cd $encrypted_file_dir
for file in *
do
msg $GREEN"Decrypting file ${file}:"
openssl aes-256-cbc -d -in $file -out ${file}.zip -pass pass:$hash
echo ${file}.zip
msg $GREEN"Unzipping file into folder:"
rm $file
unzip ${file}.zip
msg $GREEN"Removing .zip file"
rm ${file}.zip
done
msg $GREEN"Done."
}
decrypt
elif [[ "$requested_action" = "e" ]]; then
# ENCRYPT FILES
function encrypt {
cd $decrypted_file_dir
# remove file spaces with dashes
for file in *
do
mv "$file" "${file// /-}"
done
# lowercase all file characters
for file in *
do
lc=`echo "$file" | tr '[:upper:]' '[:lower:]'`
mv -f $file $lc
done
for file in *
do
msg $GREEN"Compressing ${file} into .zip:"
zip -r ${file}.zip $file
rm -rf $file
msg $GREEN"Encrypting file ${file}: "
openssl aes-256-cbc -in ${file}.zip -out ${file} -pass pass:$hash
msg $GREEN"Removed .zip"
rm ${file}.zip
done
msg $GREEN"Done."
}
encrypt
else
msg $YELLOW"Oops, seems like a typo? Pls type either 'encrypt' or 'decrypt' or crypto bear will eat you."
echo "Bye!"
fi
exit 0