X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=13201c223cd9423e7c6b4580df85420e8f9c009f;hp=0f87d74386756b9c953377bf09d10b245216c124;hb=199e6e727a023bc8a8e1bd217cbfeda5874b2d1a;hpb=2bd0312dbe43e71cb47b06f851b1168054a325de diff --git a/pb b/pb index 0f87d74..13201c2 100755 --- a/pb +++ b/pb @@ -1,134 +1,56 @@ #!/bin/sh - -# pinosaur's blog script +# pinosaur's blog script v2! data_dir="blog" website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/" - -blog_index_file="blogindex.html" rolling_file="rolling.html" +blog_index_file="blogindex.html" rss_file="rss.xml" - blog_template="template.html" -index_template="index_entry.html" -rolling_template="rolling_entry.html" -rss_template="rss_entry.html" - -start_token="" -end_token="" - -[ ! -z "$EDITOR" ] && EDITOR="vim" +database_file="$data_dir/database" +index_template="$data_dir/templates/index_entry.html" +rolling_template="$data_dir/templates/rolling_entry.html" +rss_template="$data_dir/templates/rss_entry.html" init() { - read -p "Initialize blog? [y/n] " ask - [ "$ask" != "y" ] && exit 0 + read -p "Initialize blog here? [y/n] " ask + [ "$ask" != "y" ] && printf "Initialization cancelled.\n" && exit 0 mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates" - echo '

{{TITLE}}

' >> "$data_dir/templates/$index_template" - echo -e '
\n

{{TITLE}}

\n

{{DATE}}

' >> "$data_dir/templates/$rolling_template" - echo -e '\n{{TITLE}}\n\n<\description>\n<\item>' \ - >> "$data_dir/templates/$rss_template" - - echo "Created blog files" -} - -refresh() { - - read -p "Are you sure you want to refresh? [y/n] " ask - [ "$ask" != "y" ] && exit 0 - - # delete everything between tokens (remove dupe code) - sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$blog_index_file" - sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$rolling_file" - sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$rss_file" + printf '
  • {{DATE}} - {{TITLE}}
  • ' > "$index_template" + printf '
    \n

    {{TITLE}}

    \n

    {{DATE}}

    \n

    {{BODY}}

    \n
    \n' > "$rolling_template" + printf '\n{{TITLE}}\n{{URL}}\n\n{{BODY}}\n\n' > "$rss_template" + touch "$database_file" - # deletes all html files and republishes all published files - echo "Refreshed." + printf 'Successfully initialized pb.\n' } new() { - [ -z "$1" ] && echo "Please give your blog post a name (you should put it inside quotations)" && exit 1 - - # sanitize input - sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'| sed -e 's/ /-/g'` - - # open in editor - $EDITOR "$data_dir/drafts/$sanitized.draft.html" -} - -sub() { - cat - |\ - 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" + printf 'new\n' } publish() { - - drafts=`ls -1 "$data_dir/drafts" | sed -e 's/\.draft\.html$//'` - [ -z "$drafts" ] && echo "No drafts to publish" && exit 0 - - echo "Select which draft to publish" - echo "$drafts" | nl - - read -p '> ' choice - to_publish=`ls -1 "$data_dir/drafts/" | sed -n "$choice p"` - to_publish=${to_publish%.draft.html} - [ -z "$to_publish" ] && echo "Invalid choice" && exit 1 - - cat $blog_template | sub "$to_publish" \ - > "$data_dir/html/$to_publish.html" - - # Add new entry to blog index (do something about indent??) - sed -i "/$start_token/ a\ - \n`cat "$data_dir/templates/$index_template" | sub "$to_publish"`\n" "$blog_index_file" - - sed -i "/$start_token/ a\ - \n`cat "$data_dir/templates/$rolling_template" | sub "$to_publish"`\n" "$rolling_file" - - mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/" - + printf 'publish\n' } delete() { - published=`ls -1 "$data_dir/published" | sed -e 's/\.draft\.html$//'` - [ -z "$published" ] && echo "No posts to delete" && exit 0 - - echo "Select which post to delete" - echo "$published" | nl - - read -p '> ' choice - to_delete=`ls -1 "$data_dir/published/" | sed -n "$choice p"` - to_delete=${to_delete%.draft.html} - [ -z "$to_delete" ] && echo "Invalid choice" && exit 1 - - mv "$data_dir/published/$to_delete.draft.html" "$data_dir/drafts/" &&\ - rm "$data_dir/html/$to_delete.html" - - # remove entry from blog index - sed -i "//,// d" "$blog_index_file" - sed -i "//,// d" "$rolling_file" - + printf 'delete\n' } -# check to see if all required files are present -[ -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; } +[ -f $blog_index_file ] && [ -f $rolling_file ] && [ -f $rss_file ] && [ -f $blog_template ] || { echo "You are missing a file, please check that you have $blog_index_file, $blog_template, $rolling_file and $rss_file in your home directory" && exit 1; } -# possibly also check to see if index and rolling have the proper headers +[ -f $blog ] - -# check if blog dir exists -[ ! -d $data_dir ] && init +[ ! -d $data_dir ] && init && exit 0 case $1 in - i|init) init;; - n|new) new "$2";; + n|new) new;; p|publish) publish;; d|delete) delete;; - r|refresh) refresh;; - h|*) echo "helper";; + r|refresh) printf 'refresh\n';; + h|*) printf 'help\n';; esac + +