X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=7905b54c34ad079cc1343be2f00f6fd691cfb5b9;hp=2de68b0f9462fa17e508b5d5464751ecd26be722;hb=eb9cbcb1755771257e005eb86c1225113365fae8;hpb=e476089c934e9dce5162ae9849154400b698936e
diff --git a/pb b/pb
index 2de68b0..7905b54 100755
--- a/pb
+++ b/pb
@@ -1,73 +1,112 @@
#!/bin/sh
-
# pinosaur's blog script
+data_dir="blog"
+website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/"
blog_index_file="blogindex.html"
rolling_file="rolling.html"
-template_file="template.html"
rss_file="rss.xml"
-data_dir="blog"
+blog_template="template.html"
+index_template="index_entry.html"
+rolling_template="rolling_entry.html"
+rss_template="rss_entry.html"
[ ! -z "$EDITOR" ] && EDITOR="vim"
-
init() {
- echo 1
+ read -p "Initialize blog here? [y/n] " ask
+ [ "$ask" != "y" ] && echo "Cancelled init" && exit 0
+
+ mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates" "$data_dir/backups"
+ echo '
{{TITLE}}
' >> "$data_dir/templates/$index_template"
+ echo -e '\n
{{TITLE}}
\n
{{DATE}}
\n
{{BODY}}
\n
' >> "$data_dir/templates/$rolling_template"
+ echo -e '- \n{{TITLE}}\n\n<\description>\n<\item>' \
+ >> "$data_dir/templates/$rss_template"
+
+ echo "Successfully created blog files."
}
-refresh() {
- echo 1
- # add a confirmation of sorts here
+backup() {
+ backup_name=`mktemp --tmpdir="$data_dir/backups" -d "backup_$(date +'%b-%d')_XXX"`
+ echo "Creating backup, will be placed in $backup_name"
+ cp -r "$data_dir/drafts/" "$backup_name"
+ cp -r "$data_dir/published/" "$backup_name"
}
new() {
- [ -z "$1" ] && echo "please supply a name" && exit 1
-
- # sanitize input
- sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'| sed -e 's/ /-/g'`
+ [ -z "$1" ] && echo "Please give your blog post a name (you should put it inside quotations)" && exit 1
+ sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'`
+ [ -f "$data_dir/drafts/$sanitized.draft.html" ] && echo "Blog of that name already exists." && exit 1
+ $EDITOR "$data_dir/drafts/$sanitized.draft.html"
+}
- # open in editor
- $EDITOR "$data_dir/drafts/$sanitized"
+sub() {
+ cat - |\
+ sed "1i " |\
+ sed "\$a " |\
+ sed "s|{{TITLE}}|$1|g;
+ s|{{DATE}}|`date +'%a, %b %d %H:%M'`|g;
+ s|{{URL}}|$website_url/$1|g" |\
+ sed "/{{BODY}}/r $data_dir/drafts/$1" |\
+ sed "/{{BODY}}/d"
+}
+# $1 is directory
+choose() {
+ options=`ls -1 "$1" | sed 's/\.draft\.html$//;s/\.html$//'`
+ [ -z "$options" ] && echo "No drafts to publish" && exit 0
+ echo "$options" | nl
+ read -p 'Choose an entry by number > ' choice
+ chosen=`ls -1 "$1" | sed -n "$choice p"`
+ [ -z "$chosen" ] && echo "Invalid choice" && exit 1
}
publish() {
- "Select which post to publish"
- ls -1 "$data_dir/drafts" | nl
+ choose "$data_dir/drafts"
+ to_publish=${chosen%.draft.html}
+
+ cat $blog_template | sub "$to_publish" > "$data_dir/html/$to_publish.html"
+
+ # make this part less horrendous
+ temp_index="$(mktemp)"
+ cat "$data_dir/templates/$index_template" | sub "$to_publish" >> $temp_index
+ temp_rolling="$(mktemp)"
+ cat "$data_dir/templates/$rolling_template" | sub "$to_publish" >> $temp_rolling
+ temp_rss="$(mktemp)"
+ cat "$data_dir/templates/$rss_template" | sub "$to_publish" >> $temp_rss
+
+ # Add new entry to blog index (do something about indent??)
+ sed -i "//r $temp_index" "$blog_index_file"
+ sed -i "//r $temp_rolling" "$rolling_file"
+ sed -i "//r $temp_rss" "$rss_file"
+
+ mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/"
+ echo "Successfully published $to_publish"
+}
- read -p '> ' choice
- to_publish=`ls -1 "$data_dir/drafts/" | sed -n "$choice p"`
- [ -z "$to_publish" ] && echo "Invalid choice" && exit 1
+delete() {
+ choose "$data_dir/published"
+ to_delete=${chosen%.draft.html}
+ mv "$data_dir/published/$to_delete.draft.html" "$data_dir/drafts/" &&\
+ rm "$data_dir/html/$to_delete.html"
-}
+ # remove entries from files
+ echo -e "$blog_index_file\n$rolling_file\n$rss_file" | xargs sed -i "//,// d"
-delete() {
- echo "Select which post to delete"
- ls -1 "$data_dir/published" | nl
+ echo "Successfully deleted $to_delete"
}
# check to see if all required files are present
-[ ! -f $blog_index_file ] && echo "missing $blog_index_file" && exit 1
-[ ! -f $rolling_file ] && echo "missing $rolling_file" && exit 1
-[ ! -f $template_file ] && echo "missing $template_file" && exit 1
-[ ! -f $rss_file ] && echo "missing $rss_file" && exit 1
-
-# possibly also check to see if index and rolling have the proper headers
-
+[ -f $blog_index_file ] && [ -f $rolling_file ] && [ -f $blog_template ] && [ -f $rss_file ] || { echo "You are missing a file, please check that you have $blog_index_file, $template_file, $rolling_file and $rss_file in your home directory" && exit 1; }
# check if blog dir exists
-[ ! -d $data_dir ] && echo "initing blog" &&\
- mkdir -p "$data_dir/drafts" &&\
- mkdir -p "$data_dir/published" &&\
- touch "$data_dir/database"
+[ ! -d $data_dir ] && init && exit 0
case $1 in
- i|init) echo "init";;
n|new) new "$2";;
p|publish) publish;;
- d|delete) echo "delete";;
- r|refresh) echo "refresh";;
- *) echo "helper" && exit 1;;
+ d|delete) delete;;
+ b|backup) backup;;
+ h|*) echo -e "=-=-=-=-=-=-= Pb =-=-=-=-=-=-=\nAvailable commands:\nn - new blog post\np - publish existing blog post\nd - deletes published post\nb - creates a backup";;
esac
-