aboutsummaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to 'modules')
-rwxr-xr-xmodules/articles/main.sh11
-rw-r--r--modules/articles/version1
-rwxr-xr-xmodules/categories/main.sh11
-rw-r--r--modules/categories/version1
-rwxr-xr-xmodules/comments/main.sh9
-rw-r--r--modules/comments/version1
-rwxr-xr-xmodules/encrypted/lib.sh227
-rwxr-xr-xmodules/encrypted/main.sh59
-rw-r--r--modules/encrypted/version1
-rwxr-xr-xmodules/files/main.sh5
-rw-r--r--modules/files/version1
-rwxr-xr-xmodules/folders/main.sh9
-rw-r--r--modules/folders/version1
-rwxr-xr-xmodules/follow/lib.sh6
-rw-r--r--modules/follow/version1
-rwxr-xr-xmodules/markdown/lib.sh332
-rwxr-xr-xmodules/markdown/main.sh59
-rw-r--r--modules/markdown/version1
-rwxr-xr-xmodules/mixtapes/lib.sh144
-rwxr-xr-xmodules/mixtapes/main.sh1
-rw-r--r--modules/mixtapes/version1
-rwxr-xr-xmodules/news/lib.sh36
-rw-r--r--modules/news/version1
-rwxr-xr-xmodules/reference/main.sh15
-rw-r--r--modules/reference/version1
-rwxr-xr-xmodules/repositories/main.sh17
-rw-r--r--modules/repositories/version1
-rw-r--r--modules/roadmap/version1
-rwxr-xr-xmodules/smfiles/lib.sh13
-rw-r--r--modules/smfiles/version1
-rwxr-xr-xmodules/todos/main.sh11
-rw-r--r--modules/todos/version1
32 files changed, 907 insertions, 73 deletions
diff --git a/modules/articles/main.sh b/modules/articles/main.sh
index c142725..2fc98a5 100755
--- a/modules/articles/main.sh
+++ b/modules/articles/main.sh
@@ -31,6 +31,7 @@ descriptionString="Articles module for Arching Kaos"
source $AK_LIBDIR/_ak_log
source $AK_LIBDIR/_ak_script
+source $AK_LIBDIR/_ak_utils
source $AK_LIBDIR/_ak_ipfs
source $AK_LIBDIR/_ak_gpg
source $AK_LIBDIR/_ak_zblock
@@ -45,10 +46,10 @@ else
_ak_log_info "zarticlesdir found"
fi
-_ak_modules_articles_create(){
+function _ak_modules_articles_create(){
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
- export ARTICLES_FILE="$(date +%Y%m%d_%H%M%S)"
+ export ARTICLES_FILE="$(_ak_datetime_human)"
if [ -z $EDITOR ]
then
_ak_log_error "No $EDITOR found. Exiting..."
@@ -67,7 +68,7 @@ _ak_modules_articles_create(){
rm -rf $TEMP
}
-_ak_modules_articles_index(){
+function _ak_modules_articles_index(){
FILES="$(ls -1 $ZARTICLESDIR)"
i=0
for FILE in $FILES
@@ -79,7 +80,7 @@ _ak_modules_articles_index(){
done
}
-_ak_modules_articles_import(){
+function _ak_modules_articles_import(){
echo "#TODO"
if [ ! -z $1 ]
then
@@ -102,7 +103,7 @@ _ak_modules_articles_import(){
exit 224
}
-_ak_modules_articles_add(){
+function _ak_modules_articles_add(){
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
if [ -f $1 ]; then
diff --git a/modules/articles/version b/modules/articles/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/articles/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/categories/main.sh b/modules/categories/main.sh
index 68d3c12..30e84aa 100755
--- a/modules/categories/main.sh
+++ b/modules/categories/main.sh
@@ -34,6 +34,7 @@ source $AK_LIBDIR/_ak_script
source $AK_LIBDIR/_ak_ipfs
source $AK_LIBDIR/_ak_gpg
source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_utils
if [ ! -d $AK_CATEGORIES ]; then
mkdir $AK_CATEGORIES
@@ -43,10 +44,10 @@ else
_ak_log_info "AK_CATEGORIES found"
fi
-_ak_modules_categories_create(){
+function _ak_modules_categories_create(){
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
- export NEWS_FILE="$(date +%Y%m%d_%H%M%S)"
+ export NEWS_FILE="$(_ak_datetime_human)"
vi $NEWS_FILE
_ak_log_info "Renaming..."
TITLE="$(head -n 1 $NEWS_FILE)"
@@ -57,7 +58,7 @@ _ak_modules_categories_create(){
_ak_modules_categories_add $AK_CATEGORIES/$TO_FILE
cd $AK_CATEGORIES
}
-_ak_modules_categories_index(){
+function _ak_modules_categories_index(){
FILES="$(ls -1 $AK_CATEGORIES)"
i=0
for FILE in $FILES
@@ -69,7 +70,7 @@ _ak_modules_categories_index(){
done
}
-_ak_modules_categories_import(){
+function _ak_modules_categories_import(){
echo "#TODO"
if [ ! -z $1 ]
then
@@ -91,7 +92,7 @@ _ak_modules_categories_import(){
fi
exit 224
}
-_ak_modules_categories_add(){
+function _ak_modules_categories_add(){
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
if [ -f $1 ]; then
diff --git a/modules/categories/version b/modules/categories/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/categories/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/comments/main.sh b/modules/comments/main.sh
index 1e88a52..a140a68 100755
--- a/modules/comments/main.sh
+++ b/modules/comments/main.sh
@@ -33,6 +33,7 @@ source $AK_LIBDIR/_ak_script
source $AK_LIBDIR/_ak_ipfs
source $AK_LIBDIR/_ak_gpg
source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_utils
ZCOMMENTSDIR="$AK_WORKDIR/comments"
TEMP="/tmp/aktmp"
@@ -44,7 +45,7 @@ else
_ak_log_info "zcommentsdir found"
fi
-_ak_modules_comments_create(){
+function _ak_modules_comments_create(){
if [ ! -z $1 ]
then
REFER_TO="$1"
@@ -55,7 +56,7 @@ _ak_modules_comments_create(){
fi
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
- export COMMENTS_FILE="$(date -u +%s)"
+ export COMMENTS_FILE="$(_ak_datetime_unix)"
vi $COMMENTS_FILE
echo "Renaming..."
TO_FILE=$COMMENTS_FILE
@@ -70,7 +71,7 @@ _ak_modules_comments_create(){
fi
}
-_ak_modules_comments_index(){
+function _ak_modules_comments_index(){
FILES="$(ls -1 $ZCOMMENTSDIR)"
i=0
for FILE in $FILES
@@ -82,7 +83,7 @@ _ak_modules_comments_index(){
done
}
-_ak_modules_comments_add(){
+function _ak_modules_comments_add(){
TEMP="$(_ak_make_temp_directory)"
cd $TEMP
if [ -f "$ZCOMMENTSDIR/$1" ]; then
diff --git a/modules/comments/version b/modules/comments/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/comments/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/encrypted/lib.sh b/modules/encrypted/lib.sh
new file mode 100755
index 0000000..ed8b179
--- /dev/null
+++ b/modules/encrypted/lib.sh
@@ -0,0 +1,227 @@
+#!/usr/bin/env bash
+###
+### arching-kaos-tools
+### Tools to interact and build an Arching Kaos Infochain
+### Copyright (C) 2021 - 2025 kaotisk
+###
+### This program is free software: you can redistribute it and/or modify
+### it under the terms of the GNU General Public License as published by
+### the Free Software Foundation, either version 3 of the License, or
+### (at your option) any later version.
+###
+### This program is distributed in the hope that it will be useful,
+### but WITHOUT ANY WARRANTY; without even the implied warranty of
+### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+### GNU General Public License for more details.
+###
+### You should have received a copy of the GNU General Public License
+### along with this program. If not, see <http://www.gnu.org/licenses/>.
+###
+source $AK_LIBDIR/_ak_log
+source $AK_LIBDIR/_ak_ipfs
+source $AK_LIBDIR/_ak_gpg
+source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_zchain
+source $AK_LIBDIR/_ak_utils
+
+ZENCRYPTEDDIR="$AK_WORKDIR/encrypted"
+
+if [ ! -d $ZENCRYPTEDDIR ]
+then
+ mkdir $ZENCRYPTEDDIR
+ if [ $? -ne 0 ]
+ then
+ _ak_log_error "$ZENCRYPTEDDIR couldn't be created"
+ exit 1
+ fi
+ _ak_log_info "$ZENCRYPTEDDIR created"
+else
+ _ak_log_info "$ZENCRYPTEDDIR found"
+fi
+
+cd $ZENCRYPTEDDIR
+
+function _ak_modules_encrypted_create(){
+ TEMP="$(_ak_make_temp_directory)"
+ curpath="$(pwd)"
+ cd $TEMP
+ export ENCRYPTED_FILE="$(_ak_datetime_human)"
+ vi $ENCRYPTED_FILE
+ echo "Renaming..."
+ TITLE="$(head -n 1 $ENCRYPTED_FILE)"
+ TO_FILE=$ENCRYPTED_FILE-$(echo $TITLE | tr '[:upper:]' '[:lower:]' | sed -e 's/ /\_/g' )
+ # Encrypt!!!
+ #
+ select x in $(_ak_gpg_list_keys_long|tr ' ' ':'| sed -e '/^:$/d')
+ do
+ if [ -n "$x" ]
+ then
+ _ak_log_info "Going to encrypt for $x"
+ recipient="$(echo $x | cut -d ':' -f 1)"
+ _ak_gpg_encrypt_sign $TO_FILE $ENCRYPTED_FILE $recipient
+ break
+ else
+ _ak_log_error "You didn't choose recipient"
+ fi
+ done
+ IPFS_FILE=$(_ak_ipfs_add $TO_FILE)
+ mv $TO_FILE $ZENCRYPTEDDIR/$TO_FILE
+ _ak_modules_encrypted_add $TO_FILE
+ cd $ZENCRYPTEDDIR
+ rm -rf $TEMP
+}
+
+function _ak_modules_encrypted_index(){
+ FILES="$(ls -1 $ZENCRYPTEDDIR)"
+ i=0
+ ak-zchain-extract-cids | sort | uniq > temp
+ for FILE in $FILES
+ do
+ DATE="$(echo $FILE | cut -d - -f 1 | awk '{print $1}')"
+ TITLE="$(head -n 1 $ZENCRYPTEDDIR/$FILE)"
+ IPFS_HASH="$(ipfs add -nQ $ZENCRYPTEDDIR/$FILE)"
+ ONLINE="Not in zchain"
+ grep "$IPFS_HASH" temp > /dev/null 2>&1
+ if [ $? -eq 0 ]
+ then
+ ONLINE="On zchain"
+ fi
+ printf "%3d | %5s | %52s | %10s | %56s \n"\
+ "$i" "$ONLINE" "$IPFS_HASH" "$DATE" "$TITLE"
+ let i+=1
+ done
+ rm temp
+}
+
+function _ak_modules_encrypted_import(){
+ echo "#TODO"
+ if [ ! -z $1 ]
+ then
+ if [ ! -d "$1" ]
+ then
+ echo $1
+ echo "Folder does not exist"
+ exit 4
+ else
+ echo "Folder $1 exists"
+ fl="$(ls -1 $1)"
+ for f in $fl
+ do
+ echo $1 $f
+ _ak_modules_encrypted_add_from_file "$1/$f"
+ done
+ fi
+ else
+ echo "No value"
+ exit 6
+ fi
+ exit 224
+}
+
+function _ak_modules_encrypted_add_from_file(){
+ TEMP="$(_ak_make_temp_directory)"
+ if [ -f "$1" ]
+ then
+ FILE="$(realpath $1)"
+ cp $FILE $ZENCRYPTEDDIR
+ cp $FILE $TEMP
+ FILE="$(basename $1)"
+ cd $TEMP
+ echo "Adding encrypted from " $FILE
+ DATETIME=$(echo $FILE | cut -d - -f 1 | awk '{print $1}')
+ 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",
+ "filename":"$(basename $FILE)",
+ "ipfs":"$FILE_IPFS_HASH",
+ "detach":"$FILE_SIGNATURE"
+}
+EOF
+ else
+ _ak_log_error "File $FILE doesn't exist";
+ exit 2
+ fi
+ _ak_zblock_pack "encrypted/add" $(pwd)/data
+ if [ $? -ne 0 ]
+ then
+ _ak_log_error "Some error occured while packing"
+ exit 1
+ fi
+ _ak_log_info "Encrypted added successfully"
+ rm -rf $TEMP
+}
+
+function _ak_modules_encrypted_add(){
+ TEMP="$(_ak_make_temp_directory)"
+ cd $TEMP
+ if [ -f $ZENCRYPTEDDIR/$1 ]; then
+ FILE="$1"
+ echo "Adding encrypted from " $FILE
+ DATETIME=$(echo $FILE | cut -d - -f 1 | awk '{print $1}')
+ FILE_IPFS_HASH=$(_ak_ipfs_add $ZENCRYPTEDDIR/$FILE)
+ FILE_SIGN_FILE=$FILE".asc"
+ _ak_gpg_sign_detached $FILE_SIGN_FILE $ZENCRYPTEDDIR/$FILE
+ FILE_SIGNATURE=$(_ak_ipfs_add $FILE_SIGN_FILE)
+ cat > data <<EOF
+{
+ "datetime":"$DATETIME",
+ "filename":"$FILE",
+ "ipfs":"$FILE_IPFS_HASH",
+ "detach":"$FILE_SIGNATURE"
+}
+EOF
+ else
+ echo "File $FILE doesn't exist";
+ exit 2
+ fi
+ _ak_zblock_pack "encrypted/add" $(pwd)/data
+ if [ $? -ne 0 ]
+ then
+ _ak_log_error "Some error occured while packing"
+ exit 1
+ fi
+ _ak_log_info "Encrypted added successfully"
+ rm -rf $TEMP
+}
+
+function _ak_modules_encrypted_read(){
+ ak zchain --crawl -l 1 $1 > temp
+ if [ $? -ne 0 ]
+ then
+ echo error
+ exit 22
+ fi
+ module="`cat temp | jq -r '.[].module'`"
+ action="`cat temp | jq -r '.[].action'`"
+ data="`cat temp | jq -r '.[].data'`"
+ linkToText="`cat temp | jq -r ".[].$data.ipfs"`"
+
+ if [ "$module" == "encrypted" ] && [ "$action" == "add" ]
+ then
+
+ _ak_ipfs_cat $linkToText
+ else
+ _ak_log_error "Not a encrypted block."
+ echo "ERROR Not a encrypted block."
+ exit 1
+ fi
+ rm temp
+}
+
+function _ak_modules_encrypted_specs(){
+ datetime_mask=$(printf '^[0-9]\{8\}_[0-9]\{6\}$' | xxd -p)
+ ipfs_mask=$(printf '^Qm[a-zA-Z0-9]\{44\}$' | xxd -p)
+ text_mask=$(printf '^[a-zA-Z0-9_\-]\{1,128\}$' | xxd -p)
+ echo '
+ {
+ "datetime":"'$datetime_mask'",
+ "title": "'$text_mask'",
+ "filename": "'$text_mask'",
+ "ipfs": "'$ipfs_mask'",
+ "detach": "'$ipfs_mask'"
+ }' | jq
+}
diff --git a/modules/encrypted/main.sh b/modules/encrypted/main.sh
new file mode 100755
index 0000000..a18ce5b
--- /dev/null
+++ b/modules/encrypted/main.sh
@@ -0,0 +1,59 @@
+#!/usr/bin/env bash
+###
+### arching-kaos-tools
+### Tools to interact and build an Arching Kaos Infochain
+### Copyright (C) 2021 - 2025 kaotisk
+###
+### This program is free software: you can redistribute it and/or modify
+### it under the terms of the GNU General Public License as published by
+### the Free Software Foundation, either version 3 of the License, or
+### (at your option) any later version.
+###
+### This program is distributed in the hope that it will be useful,
+### but WITHOUT ANY WARRANTY; without even the implied warranty of
+### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+### GNU General Public License for more details.
+###
+### You should have received a copy of the GNU General Public License
+### along with this program. If not, see <http://www.gnu.org/licenses/>.
+###
+##
+## Produces and reads encrypted zblocks
+##
+## -h, --help Prints this help message
+## -l, --local-index Prints an indexed table of your encrypted files
+## -i, --import <file> #TODO
+## -a, --add <file> Creates a data file from the encrypted file you point to
+## -r, --read <zblock> Reads a zblock as a encrypted data
+## -c, --create Vim is going to pop up, you will write and save your
+## encryptedletter and it's going to be save
+## -s, --specs Print specs of data block
+##
+fullprogrampath="$(realpath $0)"
+MODULE="$(realpath $0 | rev |cut -d '/' -f 2 | rev)"
+PROGRAM="ak-module-$MODULE"
+descriptionString="Module to read, create and add 'encrypted' zblocks"
+
+source $AK_LIBDIR/_ak_script
+source $AK_MODULESDIR/$MODULE/lib.sh
+
+if [ ! -z $1 ]; then
+ case $1 in
+ -h | --help) _ak_usage; exit;;
+# -l | --local-index) _ak_modules_encrypted_index; exit;;
+ -l | --local-index) _ak_not_implemented $*; exit;;
+# -i | --import) _ak_modules_encrypted_import $2; exit;;
+ -i | --import) _ak_not_implemented $*; exit;;
+# -a | --add) _ak_modules_encrypted_add_from_file $2; exit;;
+ -a | --add) _ak_not_implemented $*; exit;;
+ -c | --create) _ak_modules_encrypted_create; exit;;
+# -c | --create) _ak_not_implemented $*; exit;;
+# -r | --read) _ak_modules_encrypted_read $2; exit;;
+ -r | --read) _ak_not_implemented $*; exit;;
+# -s | --specs) _ak_modules_encrypted_specs $2; exit;;
+ -s | --specs) _ak_not_implemented $*; exit;;
+ * ) _ak_usage;;
+ esac
+else
+ _ak_usage
+fi
diff --git a/modules/encrypted/version b/modules/encrypted/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/encrypted/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/files/main.sh b/modules/files/main.sh
index 72fb752..aac9a58 100755
--- a/modules/files/main.sh
+++ b/modules/files/main.sh
@@ -32,6 +32,7 @@ source $AK_LIBDIR/_ak_log
source $AK_LIBDIR/_ak_ipfs
source $AK_LIBDIR/_ak_gpg
source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_utils
if [ ! -d $ZFILESDIR ]; then
mkdir $ZFILESDIR
@@ -48,7 +49,7 @@ else
_ak_log_info "$ZFILESDIR found!"
fi
-_ak_modules_files_add(){
+function _ak_modules_files_add(){
CRP="$(pwd)"
FILENAME="$1"
main $FILENAME $CRP
@@ -103,7 +104,7 @@ main(){
cat > $TEMPASSIN/data <<EOF
{
- "timestamp":"$(date -u +%s)",
+ "timestamp":"$(_ak_datetime_unix)",
"filename":"$FILENAME",
"ipfs":"$FILE_IPFS_HASH",
"detach":"$SIGNATURE"
diff --git a/modules/files/version b/modules/files/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/files/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/folders/main.sh b/modules/folders/main.sh
index 4f4822a..9350eec 100755
--- a/modules/folders/main.sh
+++ b/modules/folders/main.sh
@@ -33,6 +33,7 @@ source $AK_LIBDIR/_ak_log
source $AK_LIBDIR/_ak_script
source $AK_LIBDIR/_ak_ipfs
source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_utils
if [ ! -d $ZFOLDERSDIR ]; then
mkdir $ZFOLDERSDIR
@@ -45,14 +46,14 @@ TEMPASSIN="$(_ak_make_temp_directory)"
cd $TEMPASSIN
-_ak_modules_folders_add(){
+function _ak_modules_folders_add(){
CRP="$(pwd)"
FOLDERNAME="$1"
_ak_modules_folders_main $FOLDERNAME $CRP
cat data | jq -M
}
-_ak_modules_folders_main(){
+function _ak_modules_folders_main(){
FOLDERNAME="$1"
CRP="$2"
echo "Adding $FOLDERNAME"
@@ -75,7 +76,7 @@ _ak_modules_folders_main(){
fi
_ak_log_warning "Folders are not signing..."
- printf '{"timestamp":"%s","foldername":"%s","ipfs":"%s"}' $(date -u +%s) $FOLDERNAME $FOLDER_IPFS_HASH
+ printf '{"timestamp":"%s","foldername":"%s","ipfs":"%s"}' $(_ak_datetime_unix) $FOLDERNAME $FOLDER_IPFS_HASH
echo "Printing data..."
cat data
@@ -91,7 +92,7 @@ _ak_modules_folders_main(){
fi
}
-_ak_modules_folders_title(){
+function _ak_modules_folders_title(){
echo "$PROGRAM - Folder block creator"
}
diff --git a/modules/folders/version b/modules/folders/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/folders/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/follow/lib.sh b/modules/follow/lib.sh
index 885331e..14cfab7 100755
--- a/modules/follow/lib.sh
+++ b/modules/follow/lib.sh
@@ -22,7 +22,7 @@ source $AK_LIBDIR/_ak_ipfs
FOLLOWING="$AK_WORKDIR/following"
-_ak_follow_follow(){
+function _ak_follow_follow(){
if [ ! -z $1 ]
then
grep $1 $FOLLOWING
@@ -45,7 +45,7 @@ _ak_follow_follow(){
exit 1
}
-_ak_follow_list(){
+function _ak_follow_list(){
if [ -f $FOLLOWING ]
then
cat $FOLLOWING
@@ -56,7 +56,7 @@ _ak_follow_list(){
fi
}
-_ak_follow_unfollow(){
+function _ak_follow_unfollow(){
FOLLOWING="$HOME/.arching-kaos/following"
fentries="$(cat $FOLLOWING)"
if [ ! -z $1 ]
diff --git a/modules/follow/version b/modules/follow/version
new file mode 100644
index 0000000..5eb312c
--- /dev/null
+++ b/modules/follow/version
@@ -0,0 +1 @@
+v0.0.0 \ No newline at end of file
diff --git a/modules/markdown/lib.sh b/modules/markdown/lib.sh
new file mode 100755
index 0000000..662143a
--- /dev/null
+++ b/modules/markdown/lib.sh
@@ -0,0 +1,332 @@
+#!/usr/bin/env bash
+###
+### arching-kaos-tools
+### Tools to interact and build an Arching Kaos Infochain
+### Copyright (C) 2021 - 2025 kaotisk
+###
+### This program is free software: you can redistribute it and/or modify
+### it under the terms of the GNU General Public License as published by
+### the Free Software Foundation, either version 3 of the License, or
+### (at your option) any later version.
+###
+### This program is distributed in the hope that it will be useful,
+### but WITHOUT ANY WARRANTY; without even the implied warranty of
+### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+### GNU General Public License for more details.
+###
+### You should have received a copy of the GNU General Public License
+### along with this program. If not, see <http://www.gnu.org/licenses/>.
+###
+source $AK_LIBDIR/_ak_log
+source $AK_LIBDIR/_ak_ipfs
+source $AK_LIBDIR/_ak_gpg
+source $AK_LIBDIR/_ak_zblock
+source $AK_LIBDIR/_ak_zchain
+source $AK_LIBDIR/_ak_utils
+
+ZMARKDOWNDIR="$AK_WORKDIR/markdown"
+
+if [ ! -d $ZMARKDOWNDIR ]
+then
+ mkdir $ZMARKDOWNDIR
+ if [ $? -ne 0 ]
+ then
+ _ak_log_error "$ZMARKDOWNDIR couldn't be created"
+ exit 1
+ fi
+ _ak_log_info "$ZMARKDOWNDIR created"
+else
+ _ak_log_info "$ZMARKDOWNDIR found"
+fi
+
+cd $ZMARKDOWNDIR
+
+function _ak_modules_markdown_create(){
+ TEMP="$(_ak_make_temp_directory)"
+ cd $TEMP
+ export MARKDOWN_FILE="$(_ak_datetime_human)"
+ vi $MARKDOWN_FILE
+ _ak_log_debug "Renaming..."
+ TITLE="$(head -n 1 $MARKDOWN_FILE)"
+ TO_FILE=$MARKDOWN_FILE-$(echo $TITLE | tr '[:upper:]' '[:lower:]' | sed -e 's/[[:punct:]]/\_/g;s/ /\_/g' )
+ IPFS_FILE=$(_ak_ipfs_add $MARKDOWN_FILE)
+ mv $MARKDOWN_FILE $ZMARKDOWNDIR/$TO_FILE
+ _ak_modules_markdown_add $TO_FILE
+ cd $ZMARKDOWNDIR
+ rm -rf $TEMP
+}
+
+function _ak_modules_markdown_index(){
+ FILES="$(ls -1 $ZMARKDOWNDIR)"
+ i=0
+ _ak_zchain_extract_cids | sort | uniq > temp
+ for FILE in $FILES
+ do
+ DATE="$(echo $FILE | cut -d - -f 1 | awk '{print $1}')"
+ TITLE="$(head -n 1 $ZMARKDOWNDIR/$FILE)"
+ IPFS_HASH="$(ipfs add -nQ $ZMARKDOWNDIR/$FILE)"
+ ONLINE="offzchain"
+ grep "$IPFS_HASH" temp > /dev/null 2>&1
+ if [ $? -eq 0 ]
+ then
+ ONLINE="on-zchain"
+ fi
+ printf "%3d | %5s | %52s | %10s | %56s \n"\
+ "$i" "$ONLINE" "$IPFS_HASH" "$DATE" "$TITLE"
+ let i+=1
+ done
+ rm temp
+}
+
+function _ak_modules_markdown_import(){
+ echo "#TODO"
+ if [ ! -z $1 ]
+ then
+ if [ ! -d "$1" ]
+ then
+ echo $1
+ echo "Folder does not exist"
+ exit 4
+ else
+ echo "Folder $1 exists"
+ fl="$(ls -1 $1)"
+ for f in $fl
+ do
+ echo $1 $f
+ _ak_modules_markdown_add_from_file "$1/$f"
+ done
+ fi
+ else
+ echo "No value"
+ exit 6
+ fi
+ exit 224
+}
+
+function _ak_modules_markdown_add_from_file(){
+ TEMP="$(_ak_make_temp_directory)"
+ if [ -f "$1" ]; then
+ FILE="$(realpath $1)"
+ cp $FILE $ZMARKDOWNDIR
+ cp $FILE $TEMP
+ FILE="$(basename $1)"
+ cd $TEMP
+ _ak_log_info "Adding markdown 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":"$(basename $FILE)",
+ "ipfs":"$FILE_IPFS_HASH",
+ "detach":"$FILE_SIGNATURE"
+}
+EOF
+ else
+ _ak_log_error "File $FILE doesn't exist";
+ exit 2
+ fi
+ _ak_zblock_pack "markdown/add" $(pwd)/data
+ if [ $? == 0 ]
+ then
+ _ak_log_info "Markdown added successfully"
+ else
+ _ak_log_error "Failed to pack zblock"
+ exit 1
+ fi
+ rm -rf $TEMP
+}
+
+function _ak_modules_markdown_add(){
+ TEMP="$(_ak_make_temp_directory)"
+ cd $TEMP
+ if [ ! -z $1 ] && [ -n "$1" ] && [ -f $ZMARKDOWNDIR/$1 ]
+ then
+ FILE="$1"
+ _ak_log_info "Adding markdown from " $FILE
+ DATETIME=$(echo $FILE | cut -d - -f 1 | awk '{print $1}')
+ TITLE=$(head -n 1 $ZMARKDOWNDIR/$FILE)
+ FILE_IPFS_HASH=$(_ak_ipfs_add $ZMARKDOWNDIR/$FILE)
+ FILE_SIGN_FILE=$FILE".asc"
+ _ak_gpg_sign_detached $FILE_SIGN_FILE $ZMARKDOWNDIR/$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
+ _ak_log_error "File $1 doesn't exist";
+ exit 2
+ fi
+ _ak_zblock_pack "markdown/add" $(pwd)/data
+ if [ $? == 0 ]
+ then
+ _ak_log_info "Markdown added successfully"
+ else
+ _ak_log_error "error??"
+ exit 1
+ fi
+}
+
+function _ak_modules_markdown_read(){
+ if [ ! -z $1 ] && [ -n "$1" ] && [ "$1" == "local_latest" ]
+ then
+ _ak_modules_markdown_read_latest_local_markdown
+ exit 0
+ fi
+
+ _ak_zchain_crawl -l 1 $1 > temp
+ if [ $? -ne 0 ]
+ then
+ echo error
+ exit 22
+ fi
+ module="`cat temp | jq -r '.[].module'`"
+ action="`cat temp | jq -r '.[].action'`"
+ data="`cat temp | jq -r '.[].data'`"
+ linkToText="`cat temp | jq -r ".[].$data.ipfs"`"
+
+ if [ "$module" == "markdown" ] && [ "$action" == "add" ]
+ then
+
+ _ak_ipfs_cat $linkToText
+ else
+ _ak_log_error "Not a markdown block."
+ echo "ERROR Not a markdown block."
+ exit 1
+ fi
+ rm temp
+}
+
+function _ak_modules_markdown_html(){
+ _ak_zchain_crawl -l 1 $1 > temp
+ if [ $? -ne 0 ]
+ then
+ _ak_log_error "Failed to retrieve zblock $1"
+ exit 22
+ fi
+ module="`cat temp | jq -r '.[].module'`"
+ action="`cat temp | jq -r '.[].action'`"
+ data="`cat temp | jq -r '.[].data'`"
+ linkToText="`cat temp | jq -r ".[].$data.ipfs"`"
+ zfilename="`cat temp | jq -r ".[].$data.filename"`"
+ ztitle="`cat temp | jq -r ".[].$data.title"`"
+ zdatetime="`cat temp | jq -r ".[].$data.datetime"`"
+
+ if [ "$module" == "markdown" ] && [ "$action" == "add" ]
+ then
+ echo "<table>"
+ echo " <tr>"
+ echo " <td>"
+ echo " <pre>⌚ Date/Time</pre>"
+ echo " </td>"
+ echo " <td>"
+ echo " <pre>$zdatetime</pre>"
+ echo " </td>"
+ echo " </tr>"
+ echo " <tr>"
+ echo " <td>"
+ echo " <pre>✍️ Title</pre>"
+ echo " </td>"
+ echo " <td>"
+ echo " <pre>$ztitle</pre>"
+ echo " </td>"
+ echo " </tr>"
+ echo " <tr>"
+ echo " <td>"
+ echo " <pre>📄 Filename</pre>"
+ echo " </td>"
+ echo " <td>"
+ echo " <pre>$zfilename</pre>"
+ echo " </td>"
+ echo " </tr>"
+ echo " <tr>"
+ echo " <td>"
+ echo " <pre>📄 Content</pre>"
+ echo " </td>"
+ echo " <td>"
+ echo " <style>"
+ echo " .body * {"
+ echo " border: 0;"
+ echo " margin: 0;"
+ echo " padding: 0;"
+ echo " }"
+ echo " .body a {"
+