You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
190 lines
4.3 KiB
190 lines
4.3 KiB
---
|
|
title: Get DMRIDs Via Command Line
|
|
summary: This is a quick workaround to retrieve a DMRID on console or terminal.
|
|
categories: [amateur-radio]
|
|
tags: [dmr,pistar,script]
|
|
date: 2020-02-04T13:05:25+01:00
|
|
|
|
---
|
|
|
|
You want to install `w3m`. It is a text browser. Don't forget `rpi-rw` before
|
|
installing anything if you're on Pi-Star.
|
|
|
|
~~~console
|
|
$ sudo apt-get -y install w3m
|
|
~~~
|
|
|
|
## The script
|
|
|
|
The script itself does not verify the given callsign, so whatever you write as
|
|
an argument, it will be passed to the website. The script returns with `0` if
|
|
nothing is found.
|
|
|
|
~~~bash
|
|
# file: "~/bin/call"
|
|
#!/bin/bash
|
|
# Get DMR-IDs from CALLSIGN or CALLSIGN from DMR-ID or vice versa
|
|
# Author: Dominic Reich, OE7DRT
|
|
# File: ~/bin/call
|
|
#
|
|
# Last modified: 2020-04-12 13:26:36+0200
|
|
#
|
|
# Inspired from this beautiful article:
|
|
# https://pretzelhands.com/posts/command-line-flags
|
|
#
|
|
# Good DX and vy 73 de OE7DRT
|
|
|
|
command -v w3m > /dev/null 2>&1 || { echo >&2 "w3m not found"; exit 1; }
|
|
|
|
print_usage () {
|
|
echo >&2 "usage: `basename $0` [dmr_id | callsign]"
|
|
exit 1
|
|
}
|
|
|
|
if [ $# -ne 1 ]
|
|
then
|
|
print_usage
|
|
fi
|
|
|
|
getID () {
|
|
CALL=`echo $1 | tr a-z A-Z`
|
|
FILE=/tmp/$CALL
|
|
w3m "https://ham-digital.org/dmr-userreg.php?callsign=$CALL" > $FILE
|
|
c=`grep $CALL $FILE | wc -l | xargs`
|
|
|
|
while [ $c -gt 0 ]
|
|
do
|
|
OUT=`grep $CALL $FILE | head -n $c | tail -n 1 | awk '{ print $4,$5,$2,$3 }'`
|
|
echo "$OUT"
|
|
((c--))
|
|
done
|
|
rm $FILE
|
|
}
|
|
|
|
getCALLSIGN () {
|
|
ID=$1
|
|
FILE=/tmp/$ID
|
|
w3m "https://ham-digital.org/dmr-userreg.php?usrid=$ID" > $FILE
|
|
CALL=`grep $ID $FILE | awk '{ print $4 }'`
|
|
rm $FILE
|
|
if [ -z $CALL ]
|
|
then
|
|
exit 1
|
|
fi
|
|
getID $CALL
|
|
}
|
|
|
|
checkID () {
|
|
if [[ ! $1 =~ ^[0-9]{7}$ ]]
|
|
then
|
|
echo >&2 "no valid dmr_id supplied"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
if [ "$1" -eq "$1" ] 2>/dev/null
|
|
then
|
|
ID="$1"
|
|
checkID $ID
|
|
else
|
|
CALL="$1"
|
|
fi
|
|
|
|
if [ ! -z $ID ]
|
|
then
|
|
getCALLSIGN $ID
|
|
exit 0
|
|
elif [ ! -z $CALL ]
|
|
then
|
|
getID $CALL
|
|
exit 0
|
|
else
|
|
print_usage
|
|
fi
|
|
~~~
|
|
|
|
{{< alert circle-info >}}
|
|
If someone has two DMRIDS, the most recent registered callsign will appear on
|
|
the top. Feel free to modify the script to your needs if you also want to display
|
|
the date of registration. Or modify the url if you want to only display last
|
|
heard ids.
|
|
{{< /alert >}}
|
|
|
|
## Example usage
|
|
|
|
Simply get one DMRID (or two, depends on the callsign though):
|
|
|
|
~~~console
|
|
$ call OE7DRT
|
|
~~~
|
|
|
|
Now let's think a bit more complex. You can use the script in a loop. Let's fetch
|
|
some austrian callsigns only.
|
|
|
|
~~~console
|
|
$ for i in 7one 7two 1three; do call oe$i ids >>! ids; done
|
|
~~~
|
|
|
|
That would fetch 3 callsigns `OE7ONE`, `OE7TWO` and `OE1ONE` and write them
|
|
all into the file `ids`. So run `cat ids` and display them on screen. Or copy
|
|
them into clipboard (on a mac only) with `pbcopy < ids`.
|
|
|
|
~~~console
|
|
OE7ONE Username1 0007001 2018-05-12
|
|
OE7TWO Username2 0007003 2018-12-08
|
|
OE7TWO Username2 0007002 2018-11-09
|
|
OE1ONE Username3 0001001 2020-03-13
|
|
~~~
|
|
|
|
*I've been anonymizing the data a bit.*
|
|
|
|
## Partially known callsign
|
|
|
|
***I anonymized some DMR-IDs on this website.***
|
|
|
|
So you know only the three last letters of an austrian callsign and want to
|
|
know quickly what federal state it was? Run this command and you'll get a
|
|
quick answer on the command line:
|
|
|
|
~~~console
|
|
$ for i in oe{1..9}drt; do call $i; done
|
|
OE7DRT Dominic 2327180 2019-11-24
|
|
~~~
|
|
|
|
If you called your script `call` and if `call` is in your `$PATH`.
|
|
|
|
This works also if you missed one letter.
|
|
|
|
~~~console
|
|
$ for i in oe7{a..z}rt; do call $i; done
|
|
OE7BRT Rainer 2327XXX 20XX-XX-XX
|
|
OE7DRT Dominic 2327180 2019-11-24
|
|
OE7JRT Josef 2327XXX 20XX-XX-XX
|
|
~~~
|
|
|
|
This took ~10 seconds on my computer.
|
|
|
|
Or even with more letters, but this will take a while, since this will start
|
|
**676 (26x26) website lookups to ham-digital.org**---maybe they'll block
|
|
your IP address quickly, if you hammer their server with so many request in a
|
|
short period of time.
|
|
|
|
~~~console
|
|
$ for i in oe7d{a..z}{a..z}; do call $i; done
|
|
2327XXX OE7D?? Daniel
|
|
2327XXX OE7D?? Hermann
|
|
2327XXX OE7D?? Josef
|
|
2327XXX OE7D?? Dragan
|
|
2327XXX OE7D?? Peter
|
|
2327180 OE7D?? Dominic
|
|
2327XXX OE7D?? Wechselberger
|
|
2327XXX OE7D?? Gernot
|
|
~~~
|
|
|
|
And this ran for 3 minutes and 17 seconds on my computer.
|
|
|
|
{{< alert circle-info >}}
|
|
The output above was made with an older version of the script. The output now
|
|
contains also the registration date as seen in previous examples.
|
|
{{< /alert >}}
|