blob: 5868a61066198392637c6e3d20cefd18dcc9e76e (
plain)
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
|
#!/bin/bash
ZFILESDIR="$AK_WORKDIR/files"
pwd > .pwd
CRD=$(cat .pwd)
PROGRAM="$(basename $0)"
#set -xe
logit(){
ak-logthis "<$PROGRAM>" "$1" "$2"
}
if [ ! -d $ZFILESDIR ]; then
mkdir $ZFILESDIR
if [ $? == 0 ]
then
logit "[INFO]" "Folder $ZFILESDIR created!"
else
logit "[ERROR]" "Failed to create $ZFILESDIR folder"
exit 1
fi
cd $ZFILESDIR
else
logit "[INFO]" "$ZFILESDIR found!"
fi
usage(){
echo "$PROGRAM - file"
echo " add <file>"
echo " index"
echo " full-index"
echo " ls-map-files"
}
add(){
FILENAME="$1"
main $FILENAME $CRD
cat data | jq -M
}
main(){
FILENAME="$1"
CRP="$2"
TEMPASSIN="$(ak-tempassin)"
cd $TEMPASSIN
echo "Adding $FILENAME"
logit "[INFO]" "Switching to tmp folder..."
if [ $? == 0 ]; then
logit "[INFO]" "Success"
else
logit "[ERROR]" "Error with tmp folder"
exit 5
fi
logit "[INFO]" "Copying $1 to $TEMPASSIN"
cp $CRP/$FILENAME $FILENAME
if [ $? == 0 ]; then
logit "[INFO]" "Copied successfully"
else
logit "[ERROR]" "Error copying..."
fi
logit "[INFO]" "Adding $FILENAME to IPFS..."
FILE_IPFS_HASH=$(ak-ipfs-add $FILENAME)
if [ $? == 0 ]; then
logit "[INFO]" "Added $FILENAME to IPFS"
else
logit "[ERROR]" "Error in adding the $FILENAME to IPFS"
fi
logit "[INFO]" "Adding $FILE to SHAMAPSYS..."
FILEMAP_SHA512_HASH=$(ak-sm-filesplitter $FILENAME)
if [ $? == 0 ]; then
logit "[INFO]" "Added $FILENAME to SHAMAPSYS"
else
logit "[ERROR]" "Error in adding the $FILENAME to SHAMAPSYS"
fi
logit "[INFO]" "Signing..."
SIGN_FILE=$FILENAME".asc"
gpg2 --detach-sign --sign-with $AK_FINGERPRINT --armor --output $SIGN_FILE $FILENAME
if [ $? == 0 ]; then
logit "[INFO]" "Signed"
else
logit "[ERROR]" "Error while signing"
fi
logit "[INFO]" "Adding signature to IPFS"
SIGNATURE=$(ak-ipfs-add $SIGN_FILE)
if [ $? == 0 ]; then
logit "[INFO]" "Added"
else
logit "[ERROR]" "Error while adding"
fi
logit "[INFO]" "Adding signature to SHAMAPSYS"
SHAMAPSIGMAP=$(ak-sm-filesplitter $SIGN_FILE)
if [ $? == 0 ]; then
logit "[INFO]" "Added"
else
logit "[ERROR]" "Error while adding"
fi
cat > data <<EOF
{
"timestamp":"$(date -u +%s)",
"filename":"$FILENAME",
"shamap":"$FILEMAP_SHA512_HASH",
"shamapsig":"$SHAMAPSIGMAP",
"ipfs":"$FILE_IPFS_HASH",
"detach":"$SIGNATURE"
}
EOF
echo "Printing data..."
cat data
echo "Publishing..."
ak-pack_z_block sha-files/announce $(pwd)/data
if [ $? == 0 ]
then
echo "cool"
else
echo "not?"
exit 2
fi
}
index(){
tail -n1 $AK_WORKDIR/fmp/* | grep '^[abcdef1234567890]' | awk '{ print $2 }'
}
ls-mapfiles(){
cd $AK_WORKDIR/fmp
for f in `find . -type f | sed -e 's/\.\///g'`;do
FILENAME="$(tail -n1 $f | grep '^[abcdef1234567890]' | awk '{ print $2 }')"
FILEHASH="$(tail -n1 $f | grep '^[abcdef1234567890]' | awk '{ print $1 }')"
MAPFILE="$f"
printf "\nMap: %s\nFilename: %s\nSum: %s\n\n" $MAPFILE $FILENAME $FILEHASH
done
}
full-index(){
tail -n1 $AK_WORKDIR/fmp/* | grep '^[abcdef1234567890]'
}
if [ ! -z $1 ]; then
case $1 in
help) usage; exit;;
add) add $2; exit;;
index) index; exit;;
full-index) full-index; exit;;
ls-map-files) ls-mapfiles; exit;;
*) usage; exit;;
esac
else usage
fi
|