aboutsummaryrefslogtreecommitdiff
path: root/modules/articles/main.sh
diff options
context:
space:
mode:
authorkaotisk <kaotisk@arching-kaos.org>2024-06-09 06:52:03 +0300
committerkaotisk <kaotisk@arching-kaos.org>2024-06-09 06:52:03 +0300
commitba1173c9ec87b14a6ba6772d5ebfaafb81c7f888 (patch)
tree38c4c4972844d8616f220aa65e00b265ff7945ec /modules/articles/main.sh
parent1a572d674b2c94bbe5b094f563c4875c77575227 (diff)
downloadarching-kaos-tools-ba1173c9ec87b14a6ba6772d5ebfaafb81c7f888.tar.gz
arching-kaos-tools-ba1173c9ec87b14a6ba6772d5ebfaafb81c7f888.tar.bz2
arching-kaos-tools-ba1173c9ec87b14a6ba6772d5ebfaafb81c7f888.zip
Refactoring
Diffstat (limited to 'modules/articles/main.sh')
-rwxr-xr-xmodules/articles/main.sh132
1 files changed, 132 insertions, 0 deletions
diff --git a/modules/articles/main.sh b/modules/articles/main.sh
new file mode 100755
index 0000000..382466b
--- /dev/null
+++ b/modules/articles/main.sh
@@ -0,0 +1,132 @@
+#!/bin/bash
+##
+## -h, --help Prints this help message
+## index Prints an indexed table of your articles files
+## import <file> TODO
+## add <file> Creates a data file from the articles file you point to
+## create Vim is going to pop up, you will write and save your
+## articlesletter and it's going to be saved
+##
+fullprogrampath="$(realpath $0)"
+PROGRAM=$(basename $0)
+descriptionString="Articles module for Arching Kaos"
+
+source $AK_LIBDIR/_ak_log
+source $AK_LIBDIR/_ak_script
+source $AK_LIBDIR/_ak_ipfs
+source $AK_LIBDIR/_ak_gpg
+source $AK_LIBDIR/_ak_zblock
+
+ZARTICLESDIR="$AK_WORKDIR/articles"
+TEMP="/tmp/aktmp"
+if [ ! -d $ZARTICLESDIR ]; then
+ mkdir $ZARTICLESDIR
+ cd $ZARTICLESDIR
+ logit "INFO" "zarticlesdir created"
+else
+ logit "INFO" "zarticlesdir found"
+fi
+
+_ak_modules_articles_create(){
+ TEMP="$(ak-tempassin)"
+ cd $TEMP
+ export ARTICLES_FILE="$(date +%Y%m%d_%H%M%S)"
+ if [ -z $EDITOR ]
+ then
+ logit "ERROR" "No $EDITOR found. Exiting..."
+ exit 1
+ fi
+ $EDITOR $ARTICLES_FILE
+ logit "INFO" "Renaming..."
+ TITLE="$(head -n 1 $ARTICLES_FILE)"
+ TO_FILE=$ARTICLES_FILE-$(echo $TITLE | tr '[:upper:]' '[:lower:]' | sed -e 's/ /\_/g' )
+ IPFS_FILE=$(_ak_ipfs_add $ARTICLES_FILE)
+ mv $ARTICLES_FILE $ZARTICLESDIR/$TO_FILE
+ sed -e 's,Qm.*,'"$IPFS_FILE"',g' $ZARTICLESDIR/README
+ _ak_modules_articles_add $ZARTICLESDIR/$TO_FILE
+ logit "INFO" "Adding to git repo..."
+ cd $ZARTICLESDIR
+ rm -rf $TEMP
+}
+
+_ak_modules_articles_index(){
+ FILES="$(ls -1 $ZARTICLESDIR)"
+ i=0
+ for FILE in $FILES
+ do
+ DATE=$(echo $FILE | cut -d - -f 1 | awk '{print $1}')
+ TITLE=$(head -n 1 $ZARTICLESDIR/$FILE)
+ echo $i \| $DATE \| $TITLE
+ let i+=1
+ done
+}
+
+_ak_modules_articles_import(){
+ echo "#TODO"
+ if [ ! -z $1 ]
+ then
+ if [ ! -d $1 ]
+ then
+ echo "Folder does not exists"
+ exit 4
+ else
+ echo "Folder $1 exists"
+ fl="$(ls -1 $1)"
+ for f in $fl
+ do
+ _ak_modules_articles_add $1/$f
+ done
+ fi
+ else
+ echo "No value"
+ exit 6
+ fi
+ exit 224
+}
+
+_ak_modules_articles_add(){
+ TEMP="$(ak-tempassin)"
+ cd $TEMP
+ if [ -f $1 ]; then
+ FILE="$1"
+ echo "Adding articles from " $FILE
+ DATETIME=$(echo $FILE | cut -d - -f 1 | awk '{print $1}')
+ TITLE=$(head -n 1 $FILE)
+ FILE_IPFS_HASH=$(_ak_ipfs_add $FILE)
+ FILE_SIGN_FILE=$FILE".asc"
+ _ak_gpg_sign_detached $FILE_SIGN_FILE $FILE
+ FILE_SIGNATURE=$(_ak_ipfs_add $FILE_SIGN_FILE)
+ cat > data <<EOF
+{
+ "datetime":"$DATETIME",
+ "title":"$TITLE",
+ "filename":"$FILE",
+ "ipfs":"$FILE_IPFS_HASH",
+ "detach":"$FILE_SIGNATURE"
+}
+EOF
+ else
+ echo "File $FILE doesn't exist";
+ exit 2
+ fi
+ _ak_zblock_pack "articles/add" $(pwd)/data
+ if [ $? == 0 ]
+ then
+ echo "Articles added successfully"
+ else
+ echo "error??"
+ exit 1
+ fi
+}
+
+if [ ! -z $1 ]; then
+ case $1 in
+ -h | --help) _ak_usage; exit;;
+ index) _ak_modules_articles_index; exit;;
+ import) _ak_modules_articles_import $2; exit;;
+ add) _ak_modules_articles_add $2; exit;;
+ create) _ak_modules_articles_create; exit;;
+ * ) _ak_usage;;
+ esac
+else _ak_usage
+fi