diff options
Diffstat (limited to 'modules')
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 {" + |