#!/bin/bash # fqt - FLAMP Queue Touch' # # Simplify matching queue ID in FLAMP by changing file's date. Help() { echo 'Usage: fqt \[OPTION\]... TIMESTAMP... FILE...' echo 'Update a file'\''s timestamp helping recreate the hash, or queue id, in FLAMP.' echo echo 'options:' echo ' -h display this help and exit' echo ' --help display longer help and exit' echo ' -v, --version output version information and exit' echo echo 'fqt is short for FLAMP Queue Touch' } LongHelp() { echo 'Example' echo ' FLAMP text shown in FLDIGI:' echo '/// BEGIN ///' echo 'QST DE N0CALL' echo echo '{D5C6}FLAMP 2.2.07' echo '{D5C6}20230610151423:flamp-file.k2s' echo ' ^^^^^^^^^^^^^^--> --> --> --> Use these numbers -->\' echo '{D5C6}N0CALL Demonstration' echo '{D5C6}45 1 64 |' echo '{D5C6:1}[b64:start]VGhpcyBpcyBhIHRlc3QuCg== v' echo '[b64:end]' echo '{D5C6:EOF} |' echo '{D5C6:EOT} v' echo echo 'QST DE N0CALL K |' echo '/// END /// v' echo ' vvvvvvvvvvvvvv <-- <-- <-- <-- <-- <-- <-- Here <-- <--/' echo ' command: fqt 20230607013934 flamp-file.k2s' echo echo 'Tips' echo ' If hash doesn'\''t match, try to' echo ' Remove and re-Add the file in FLAMP' echo ' Toggle Comp check box (usually compression, unless file is small)' echo ' Change base64 (usually base64)' echo ' Change Blk size (usually 64)' echo echo 'Information on hash in documentation' echo 'FLAMP Amateur Multicast Protocol (AMP-2) - Version 3.0' echo 'available at: ' echo echo ' 20130316010524:ShortMessage2.txt0base12896' echo echo ' Example format:' echo echo ' |20130316010524:ShortMessage2.txt|0|base128|96|' echo ' | DTS : FN |C| B |BS|' echo echo ' DTS = Date/Time Stamp' echo ' FN = File Name' echo ' C = Compression 1=ON,0=OFF' echo ' B = Base Conversion (base64, base128, or base256)' echo ' BS = Block Size, 1 or more characters' echo ' | = Field separator.' echo echo 'CRC-16/MODBUS 20230607013934:flamp-file.k2s1base6464 D5C6' echo ' needs localtime file dated 20230606213934 America/New_York.' echo echo 'Usage: fqt [OPTION]... TIMESTAMP... FILE...' echo 'Update a file'\''s timestamp helping recreate the hash, or queue id, in FLAMP.' echo echo 'TIMESTAMP is the string appearing in FLAMP header' echo 'and is formatted YYYYmmddHHMMSS ' echo echo 'A FILE argument that does not exist is created empty. (Not helpful.)' echo echo 'options:' echo ' -h display short help and exit' echo ' --help display this longer help and exit' echo ' -v, --version output version information and exit' echo echo 'This should work across timezones and across Daylight Savings times.' echo echo 'fqt is short for FLAMP Queue Touch' } Version() { echo 'fqt - FLAMP Queue Touch' echo 'Not Copyrighted' echo 'No License' echo 'This is free software: you are free to change and redistribute it.' echo 'There is NO WARRANTY, to the extent permitted by law.' echo echo 'Use at your own risk!' echo echo 'Written by a ham.' } # Note that we use "$@" to let each command-line parameter expand to a # separate word. The quotes around "$@" are essential! # We need TEMP as the 'eval set --' would nuke the return value of getopt. if ! TEMP=$(getopt -o '::hv' --long 'help,version' -n 'fqt' -- "$@") ; then echo 'Unexpected input. Terminating...' >&2 exit 1 fi # Note the quotes around "$TEMP": they are essential! eval set -- "$TEMP" unset TEMP # getopt -l "help" -a -o "" -- "$@" while true; do case "$1" in '-h') Help exit;; '--help') LongHelp exit;; '-v'|'--version') Version exit;; '--') # Useless for this file? shift break;; *) # Invalid option echo 'Error: Invalid option' exit 1;; esac done GIVEN="$1" #echo "$GIVEN" # YYYYmmddHHMMSS # 20230607013934 GIVEN_DATE=$(echo "$GIVEN" | sed 's/\(....\)\(..\)\(..\)\(..\)\(..\)\(..\)/\1-\2-\3 \4:\5:\6/') #echo "$GIVEN_DATE" # YYYY-mm-dd HH:MM:SS # 2023-06-07 01:39:34 UTC_TOUCH="$(date -d "$GIVEN_DATE"Z +%Y%m%d%H%M.%S)" #echo "$UTC_TOUCH" # YYYYmmddHHMM.SS # 202306062139.34 echo touch -mt "$UTC_TOUCH" "$2" touch -mt "$UTC_TOUCH" "$2" function calc_crc16( ) { # Modified from # https://github.com/onslauth/bash_crc16/blob/master/crc16-table.sh # poly=0x8005 declare -a crc_16_table=( 0x0000 0xC0C1 0xC181 0x0140 0xC301 0x03C0 0x0280 0xC241 0xC601 0x06C0 0x0780 0xC741 0x0500 0xC5C1 0xC481 0x0440 0xCC01 0x0CC0 0x0D80 0xCD41 0x0F00 0xCFC1 0xCE81 0x0E40 0x0A00 0xCAC1 0xCB81 0x0B40 0xC901 0x09C0 0x0880 0xC841 0xD801 0x18C0 0x1980 0xD941 0x1B00 0xDBC1 0xDA81 0x1A40 0x1E00 0xDEC1 0xDF81 0x1F40 0xDD01 0x1DC0 0x1C80 0xDC41 0x1400 0xD4C1 0xD581 0x1540 0xD701 0x17C0 0x1680 0xD641 0xD201 0x12C0 0x1380 0xD341 0x1100 0xD1C1 0xD081 0x1040 0xF001 0x30C0 0x3180 0xF141 0x3300 0xF3C1 0xF281 0x3240 0x3600 0xF6C1 0xF781 0x3740 0xF501 0x35C0 0x3480 0xF441 0x3C00 0xFCC1 0xFD81 0x3D40 0xFF01 0x3FC0 0x3E80 0xFE41 0xFA01 0x3AC0 0x3B80 0xFB41 0x3900 0xF9C1 0xF881 0x3840 0x2800 0xE8C1 0xE981 0x2940 0xEB01 0x2BC0 0x2A80 0xEA41 0xEE01 0x2EC0 0x2F80 0xEF41 0x2D00 0xEDC1 0xEC81 0x2C40 0xE401 0x24C0 0x2580 0xE541 0x2700 0xE7C1 0xE681 0x2640 0x2200 0xE2C1 0xE381 0x2340 0xE101 0x21C0 0x2080 0xE041 0xA001 0x60C0 0x6180 0xA141 0x6300 0xA3C1 0xA281 0x6240 0x6600 0xA6C1 0xA781 0x6740 0xA501 0x65C0 0x6480 0xA441 0x6C00 0xACC1 0xAD81 0x6D40 0xAF01 0x6FC0 0x6E80 0xAE41 0xAA01 0x6AC0 0x6B80 0xAB41 0x6900 0xA9C1 0xA881 0x6840 0x7800 0xB8C1 0xB981 0x7940 0xBB01 0x7BC0 0x7A80 0xBA41 0xBE01 0x7EC0 0x7F80 0xBF41 0x7D00 0xBDC1 0xBC81 0x7C40 0xB401 0x74C0 0x7580 0xB541 0x7700 0xB7C1 0xB681 0x7640 0x7200 0xB2C1 0xB381 0x7340 0xB101 0x71C0 0x7080 0xB041 0x5000 0x90C1 0x9181 0x5140 0x9301 0x53C0 0x5280 0x9241 0x9601 0x56C0 0x5780 0x9741 0x5500 0x95C1 0x9481 0x5440 0x9C01 0x5CC0 0x5D80 0x9D41 0x5F00 0x9FC1 0x9E81 0x5E40 0x5A00 0x9AC1 0x9B81 0x5B40 0x9901 0x59C0 0x5880 0x9841 0x8801 0x48C0 0x4980 0x8941 0x4B00 0x8BC1 0x8A81 0x4A40 0x4E00 0x8EC1 0x8F81 0x4F40 0x8D01 0x4DC0 0x4C80 0x8C41 0x4400 0x84C1 0x8581 0x4540 0x8701 0x47C0 0x4680 0x8641 0x8201 0x42C0 0x4380 0x8341 0x4100 0x81C1 0x8081 0x4040 ) input="$1" # crc=0 # for CRC-16/ARC crc=65535 # for CRC-16/MODBUS len=${#input} for (( i = 0; i> 8 ) )) done printf "%04X" $crc } crc16=$( calc_crc16 "123456789" ) echo "crc16 : 123456789 : $crc16" echo "CRC-16/ARC BB3D" echo "CRC-16/MODBUS 4B37" DEMO=20230610151423:flamp-file.k2s1base6464 crc16=$( calc_crc16 "$DEMO" ) echo "crc16 : $DEMO : $crc16 " echo "CRC-16/ARC D9F6" echo "CRC-16/MODBUS D5C6" echo # echo UTC_TOUCH "$UTC_TOUCH" CONVERT_BACK_TO_DATE=$(echo "$UTC_TOUCH" | sed 's/\(....\)\(..\)\(..\)\(..\)\(..\)\.\(..\)/\1-\2-\3 \4:\5:\6/') echo CONVERT_BACK_TO_DATE "$CONVERT_BACK_TO_DATE" OFFSET=$(date -d "$CONVERT_BACK_TO_DATE" +%z) echo "$OFFSET" FLAMP_DATE=$(TZ=':Zulu' date -d "$CONVERT_BACK_TO_DATE $OFFSET" +%Y%m%d%H%M%S) echo FLAMP_DATE "$FLAMP_DATE" CONVERT_BACK_TO_DATE=$(stat -c %y flamp-file.k2s) echo CONVERT_BACK_TO_DATE "$CONVERT_BACK_TO_DATE" FLAMP_DATE=$(TZ=':Zulu' date -d "$CONVERT_BACK_TO_DATE" +%Y%m%d%H%M%S) echo FLAMP_DATE "$FLAMP_DATE" DEMO1C="$FLAMP_DATE:${2}1base6464" crc16=$( calc_crc16 "$DEMO1C" ) echo "Compression On : crc16 : $DEMO1C : $crc16" DEMO1NC="$FLAMP_DATE:${2}0base6464" crc16=$( calc_crc16 "$DEMO1NC" ) echo "Compression Off : crc16 : $DEMO1NC : $crc16" echo DEMO2="${1}:${2}1base6464" crc16=$( calc_crc16 "$DEMO2" ) echo "crc16 : $DEMO2 : $crc16"