Enhancements + Fixes (#41)

* Signal does seem good after all.

* Add alias `here` which shows details of everything in the current location.

* Move instant messengers to consistently be at the end of the favorites bar.

* Change to single quotes so that the pwd is per-call instead of per-source.

* Specify the video codec so that the command works on openSUSE.

* Refactor so that there is a shared/common fact list.

* Add ffmpeg as a package variable.

* Reformat long comment.

* New file for installing package manager apps for workstations.

* Call the workstation package manager tasks.

* Change to parenthesis to look better.

* Explicitly add a video flag, add recursive searching, fix a bug with -f ignoring input.

* Add ability to "force" the compression, deletes old files and regenerates them. Input is now passed with i rather than f for file/folder. f is now used for force.

* Fix skipping the file if it's already compressed. Enhance readability of log text.
This commit is contained in:
Hyperling 2023-06-26 06:58:09 -07:00 committed by GitHub
parent 6d2b20aafe
commit b47183af76
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 77 additions and 38 deletions

View File

@ -2,6 +2,11 @@
# Define program names for package builtin.
# This file is for ALL systems and should not include UI components.
- name: General | Facts | Packages | Shared Defaults
set_fact:
sshfs: sshfs
tar: tar
- name: General | Facts | Packages | Parrot OS Fixes
set_fact:
ansible_pkg_mgr: "apt"
@ -10,10 +15,8 @@
- name: General | Facts | Package | apt
set_fact:
sshfs: sshfs
locate: locate
opensshd: openssh-server
tar: tar
microcode_amd: amd64-microcode
microcode_intel: intel-microcode
cron: cron
@ -21,10 +24,8 @@
- name: General | Facts | Package | pacman
set_fact:
sshfs: sshfs
locate: mlocate
opensshd: openssh
tar: tar
microcode_amd: linux-firmware
microcode_intel: intel-ucode
cron: cronie
@ -46,7 +47,6 @@
sshfs: fuse-sshfs
locate: mlocate
opensshd: openssh
tar: tar
microcode_amd: microcode_ctl
microcode_intel: microcode_ctl
cron: cronie
@ -54,10 +54,8 @@
- name: General | Facts | Package | zypper
set_fact:
sshfs: sshfs
locate: mlocate
opensshd: openssh
tar: tar
microcode_amd: ucode-amd
microcode_intel: ucode-intel
cron: cronie

View File

@ -25,6 +25,7 @@
font_awesome: fonts-font-awesome
dmenu: dmenu
sassc: sassc
ffmpeg: ffmpeg
- name: Workstation | Facts | Package | Pop_OS!

View File

@ -14,41 +14,52 @@ function usage {
cat <<- EOF
Reduce the filesize of a video file to make it stream well. It also
helps with the file size for placing the file into a backup system.
Currently only set up for libopenh264 and mp4 files.
Parameters:
-f input : The input file or folder with which to search for video files.
-i input : The input file or folder with which to search for video files.
If nothing is provided, current directory (.) is assumed.
-v bitrate : The video bitrate to convert to, defaults to 2000k.
-a bitrate : The audio bitrate to convert to, defaults to 128k.
-r : Recurse the entire directory structure, compressing all video files.
-f : Force recompressing any files by deleting it if it already exists.
-h : Display this help messaging.
EOF
exit $1
}
## Parse Input
while getopts ":f:v:a:h" opt; do
while getopts ":i:v:a:rfh" opt; do
case $opt in
f)
input="$OPTARG"
i) input="$OPTARG"
echo "input='$input'"
;;
v)
video_bitrate="$OPTARG"
v) video_bitrate="$OPTARG"
echo "video_bitrate='$video_bitrate'"
;;
a)
audio_bitrate="$OPTARG"
a) audio_bitrate="$OPTARG"
echo "audio_bitrate='$audio_bitrate'"
;;
h)
usage 0
r) recurse="Y"
search_command=find
echo "recurse='$recurse', search_command='$search_command'"
;;
f) force="Y"
echo "force='$force'"
;;
h) usage 0
;;
esac
done
if [[ -z $input && ! -z $1 ]]; then
echo "WARNING: Program was not passed a file. Using input 1."
if [[ -z "$input" ]]; then
if [[ ! -z "$1" ]]; then
echo "WARNING: Program was not passed a file. Using input $1."
input=$1
else
else
echo "WARNING: Program was not passed a file. Using current directory."
input='.'
fi
fi
if [[ -z $video_bitrate ]]; then
@ -59,14 +70,24 @@ if [[ -z $audio_bitrate ]]; then
audio_bitrate='128k'
fi
if [[ -z $recurse ]]; then
search_command=ls
fi
## Other Variables
filename_flag='compressed.'
## Main Loop
ls $input | while read file; do
## Exception Checks
if [[ $file != *'.mp4' && $file != *'.mpeg' ]]; then
echo "Skipping $file, not an MP4 or MPEG."
$search_command $input | while read file; do
echo -e "\n$file"
# Exception checks for the existing file.
if [[ $file != *'.mp4' ]]; then
echo "SKIP: Not an MP4."
continue
fi
if [[ $file == *"$filename_flag"* ]]; then
echo "SKIP: Input is already compressed."
continue
fi
@ -74,16 +95,22 @@ ls $input | while read file; do
extension=${file##*.}
newfile=${file//$extension/$filename_flag$extension}
if [[ $file == *"$filename_flag"* || -e $newfile ]]; then
echo "Skipping $file, already compressed."
# More exception checks based on the new file.
if [[ -e $newfile ]]; then
if [[ $force == "Y" ]]; then
echo "FORCE: Removing $newfile."
rm -vf $newfile
else
echo "SKIP: Already has a compressed version ($newfile)."
continue
fi
fi
# Convert the file.
echo "Converting $file to $newfile."
echo "Converting to $newfile."
ffmpeg -nostdin -hide_banner -loglevel quiet \
-i $file -b:v $video_bitrate -b:a $audio_bitrate \
$newfile
-vcodec libopenh264 -movflags +faststart $newfile
done
exit 0

View File

@ -66,6 +66,9 @@
- include_tasks: tasks/workstation/linux/software/flatpaks.yml
when: ansible_system == "Linux" and flatpak_distro
- include_tasks: tasks/workstation/linux/software/packages.yml
when: ansible_system == "Linux"
- include_tasks: tasks/workstation/linux/software/brave.yml
when: ansible_pkg_mgr in ("apt", "dnf", "zypper") and not mobile

View File

@ -279,6 +279,7 @@
echo "ERROR: Something went wrong while removing Flatpak apps!"
}
alias_vim: alias vi=vim
alias_here: alias here='ls -lh `pwd`/*'
- name: General | Account Management | Users | Files | Common Variable
set_fact:
@ -305,6 +306,7 @@
{{ function_flatpak_usage }}
{{ function_flatpak_purge }}
{{ alias_vim }}
{{ alias_here }}
- name: General | Account Management | Users | Files | .bashrc
blockinfile:

View File

@ -19,8 +19,8 @@
shell: exit 1
when: ansible_distribution == "Parrot OS" and parrotos_zypper_removed is defined and not parrotos_zypper_removed.failed
# More Parrot OS junk. They have a command called update in /usr/bin. Doesn't have sudo or anything in it either.
# Hide it in preference for .bashrc update function.
# More Parrot OS junk. They have a command called update in /usr/bin. Doesn't
# have sudo or anything in it. Hide it in preference for .bashrc update function.
- name: General | Software | Packages | Fix Parrot OS 2 (update)
shell: "mv `which update` `which update`.zz.`date +%Y%m%d`"
ignore_errors: yes

View File

@ -39,6 +39,7 @@
- { app: "io.lbry.lbry-app", name: "lbry", extra: "dbus-launch" }
- { app: "io.gitlab.librewolf-community", name: "librewolf", extra: "" }
- { app: "chat.delta.desktop", name: "deltachat", extra: "" }
- { app: "org.signal.Signal", name: "signal", extra: "" }
flatpaks_coding:
- { app: "com.vscodium.codium", name: "codium", extra: "" }
- { app: "com.google.AndroidStudio", name: "android-studio", extra: "" }
@ -63,7 +64,6 @@
- { app: "com.discordapp.Discord", name: "discord", extra: "" } # Stopped working, just spins and says Starting.
# 2022-11-20 No longer using any of these and they're taking up a lot of space. #
- { app: "im.riot.Riot", name: "element", extra: "" }
- { app: "org.signal.Signal", name: "signal", extra: "" }
- { app: "org.telegram.desktop", name: "telegram", extra: "" }
- { app: "com.jetbrains.PyCharm-Community", name: "pycharm", extra: "" }
# End 2022-11-20 #

View File

@ -0,0 +1,9 @@
---
# Packages specific to workstations.
- name: Workstation | Software | Packages | Install Software (Editing)
package:
name:
- "{{ ffmpeg }}"
state: present
when: editing == true

View File

@ -171,11 +171,10 @@
, 'org.gnome.Nautilus.desktop'
, 'io.gitlab.librewolf-community.desktop', '{{ browser }}'
, 'org.gnome.Evolution.desktop', 'chat.delta.desktop.desktop'
, 'org.signal.Signal.desktop'
, 'com.vscodium.codium.desktop', 'org.shotcut.Shotcut.desktop'
, 'org.telegram.desktop.desktop', 'com.discordapp.Discord.desktop'
, 'im.riot.Riot.desktop'
, 'io.lbry.lbry-app.desktop'
, 'org.signal.Signal.desktop', 'im.riot.Riot.desktop'
, 'org.telegram.desktop.desktop', 'com.discordapp.Discord.desktop'
, 'com.valvesoftware.Steam.desktop'
]"
state: present