summaryrefslogtreecommitdiff
path: root/uristart
diff options
context:
space:
mode:
authorepoch <epoch@hacking.allowed.org>2020-01-21 10:07:05 -0600
committerepoch <epoch@hacking.allowed.org>2020-01-21 10:07:05 -0600
commitd3f5b8e73bbea0c6b40a10628e00e6cde40aeb66 (patch)
tree5bb57758f6d355e80f4e1fa604fb78f220270c18 /uristart
parentf9c00d204d42c595e740bf3b8b7e7540f3fe6afb (diff)
downloaduritools-d3f5b8e73bbea0c6b40a10628e00e6cde40aeb66.tar.gz
uritools-d3f5b8e73bbea0c6b40a10628e00e6cde40aeb66.zip
added whitespace, deleted some commented out code, added comments to make the purpose of certain blocks clearer, escaped backslashes in $line so they get passed to uriprintf right
Diffstat (limited to 'uristart')
-rwxr-xr-xuristart95
1 files changed, 44 insertions, 51 deletions
diff --git a/uristart b/uristart
index 4ff1056..3acf785 100755
--- a/uristart
+++ b/uristart
@@ -2,62 +2,55 @@
### arguments:
# $1: the URI we're starting
# $2: the "referer" of the URI we're starting.
+### requirements:
+# getsrv, urimatch, urijoin, uricut, some-way-to-ask-the-user-for-a-line (dmenu by default)
+# getsrv tries dig and host, you only need one or the other.
##might have to configure me.
ASKUSER="dmenu -p"
+
uri="${1}"
scheme="$(printf "%s\n" "$uri" | uricut -s)"
-### experimental crap.. let's comment it out for now.
-#if grep '\+' <<< "$scheme" 2>&1 >/dev/null;then
-# echo "dunno wtf yet"
-# scheme1="$(printf "%s\n" "$scheme" | cut -d+ -f1)+"
-# scheme2="+$(printf "%s\n" "$scheme" | cut -d+ -f2)"
-# echo $scheme1
-# echo $scheme2
-# line1="$(grep "^${scheme1}:"$'\t' ~/.config/uristart.conf | tr -s '\t ' | cut -f2- | sed 's/^[ \t]//g' | sed 's/\\n/\\\\n/g')"
-# line2="$(grep "^${scheme2}:"$'\t' ~/.config/uristart.conf | tr -s '\t ' | cut -f2- | sed 's/^[ \t]//g' | sed 's/\\n/\\\\n/g')"
-# echo $line1
-# echo $line2
-# pipeline1="$(printf "%s\n" "$uri" | sed 's/'\''/'\''\\'\'''\''/g' | uriprintf "$line1" )"
-# pipeline2="$(printf "%s\n" "$uri" | sed 's/'\''/'\''\\'\'''\''/g' | uriprintf "$line2" )"
-# echo "$pipeline1"
-# echo "$pipeline2"
-# mknod /tmp/p p
-# cat /tmp/p | bash -xc "$pipeline1" | bash -xc "$pipeline2" > /tmp/p
-#else
- line="$(grep "^${scheme}:" ~/.config/uristart.conf | cut -d: -f2- | sed 's/^[ \t]//g')"
- if printf "%s\n" "$uri" | urimatch nP >/dev/null;then
- proto="$(grep ^"$scheme"'[\t ]' /etc/services | tr -s '\t ' | cut -f2 | cut -d/ -f1 | head -n1)"
- if [ ! "$proto" ]; then
- proto=tcp
- fi
- uri="$(cat <(printf "%s\n" "$uri" | uricut) \
- <(getsrv $(printf "%s\n" "$uri" | uriprintf '%s '"$proto"' %d') 2>&- | tr ':' ' ' | sed 's/ /_port: /' | sed 's/^/domain: /' | tr _ '\n') \
- | urijoin)"
- printf "srv (%s) modified uri: %s\n" "$proto" "$uri" >&2
+line="$(grep "^${scheme}:" ~/.config/uristart.conf | cut -d: -f2- | sed 's/^[ \t]//g' | sed 's/\\/\\\\/g')"
+
+### if we do not have a port, we are going to try to get it from their srv records.
+if printf "%s\n" "$uri" | urimatch nP >/dev/null;then
+ proto="$(grep ^"$scheme"'[\t ]' /etc/services | tr -s '\t ' | cut -f2 | cut -d/ -f1 | head -n1)"
+ if [ ! "$proto" ]; then
+ proto=tcp
fi
- if printf "%s\n" "$uri" | urimatch nP >/dev/null;then #if we *still* don't have a port
- uri="$(cat <(printf "%s\n" "$uri" | uricut) \
- <(grep ^"$scheme"'[\t ]' /etc/services | tr -s '\t ' | cut -f2 | cut -d/ -f1 | head -n1 | sed 's/^/port: /') \
- | urijoin)"
- printf "getent modified uri: %s\n" "$uri" >&2
- fi
- echo "the uri we're using: $uri"
+ uri="$(cat <(printf "%s\n" "$uri" | uricut) \
+ <(getsrv $(printf "%s\n" "$uri" | uriprintf '%s '"$proto"' %d') 2>&- | tr ':' ' ' | sed 's/ /_port: /' | sed 's/^/domain: /' | tr _ '\n') \
+ | urijoin)"
+ printf "srv (%s) modified uri: %s\n" "$proto" "$uri" >&2
+fi
+
+### if they do not have srv records, fall-back to /etc/services
+if printf "%s\n" "$uri" | urimatch nP >/dev/null;then #if we *still* don't have a port
+ uri="$(cat <(printf "%s\n" "$uri" | uricut) \
+ <(grep ^"$scheme"'[\t ]' /etc/services | tr -s '\t ' | cut -f2 | cut -d/ -f1 | head -n1 | sed 's/^/port: /') \
+ | urijoin)"
+ printf "getent modified uri: %s\n" "$uri" >&2
+fi
+
+### ask the user for a pipeline for starting these URIs if there isn't a pipeline already in the config.
+echo "the uri we're using: $uri"
+if [ "$line" = "" ];then
+ line="$(printf "" | $ASKUSER "protocol scheme (${scheme}) not configured yet. enter new pipeline to use:")"
if [ "$line" = "" ];then
- line="$(printf "" | $ASKUSER "protocol scheme (${scheme}) not configured yet. enter new pipeline to use:")"
- if [ "$line" = "" ];then
- echo "user noped on entering new pipeline" >&2
- exit 1
- fi
- printf '%s:\t%s\n' "${scheme}" "${line}" >> ~/.config/uristart.conf
+ echo "user noped on entering new pipeline" >&2
+ exit 1
fi
- ## uri *might* contain pattern matching special characters. :/
- ## which could break things in weird and exciting ways
- if ! cut '-d ' -f1 ~/.cache/uristart.log | grep -Fx "$uri" 2>&1 >/dev/null;then #only log URIs that aren't already listed
- if [ "$2" ];then
- printf "%s %s\n" "$uri" "$2" >> ~/.cache/uristart.log
- else
- printf "%s\n" "$uri" >> ~/.cache/uristart.log
- fi
+ printf '%s:\t%s\n' "${scheme}" "${line}" >> ~/.config/uristart.conf
+fi
+
+### log the uri if it isn't logged already.
+if ! cut '-d ' -f1 ~/.cache/uristart.log | grep -Fx "$uri" 2>&1 >/dev/null;then #only log URIs that aren't already listed
+ if [ "$2" ];then
+ printf "%s %s\n" "$uri" "$2" >> ~/.cache/uristart.log
+ else
+ printf "%s\n" "$uri" >> ~/.cache/uristart.log
fi
- eval "$(printf "%s\n" "$uri" | sed 's/'\''/'\''\\'\'''\''/g' | uriprintf "$line")"
-#fi
+fi
+
+### do the magic
+eval "$(printf "%s\n" "$uri" | sed 's/'\''/'\''\\'\'''\''/g' | uriprintf "$line")"