#!/bin/bash # --------------------- Settings SOURCE_HOST=cloud21.cvtt.vpn SOURCE_ROOT_DIR=/opt/store/cvtt/md_archive/equity/alpaca_md SYMBOL_LIST=CAN #,COIN,GBTC,HOOD,MSTR,PYPL,XYZ OUTPUT_DIR=/tmp DATE=20250514 RSYNC_TARGETS="cvtt@hs01.cvtt.vpn:/works/cvtt/md_archive/equity/test/alpaca_md/sim/" # RSYNC_TARGETS="cvtt@hs01.cvtt.vpn:/works/cvtt/md_archive/equity/alpaca_md/sim/ #cvtt@cloud21.cvtt.vpn:/opt/store/cvtt/md_archive/equity/alpaca_md/sim/" # --------------------- Settings # --------------------- Settings is_business_day() { dt=${1} date=$(date -d "${dt}" +"%Y-%m-%d") CalendarURL=https://trading-calendar.cvtt.net/api/v1/markets/hours?mic=XNYS URL="${CalendarURL}&start=${date}&end=${date}" echo "URL=${URL}" curl $URL open_time=$(curl -s "${URL}" | jq '.[] | .open_time') echo "open_time=${open_time}" if [ -n "${open_time}" ]; then return 0 else return 1 fi } export -f is_business_day if [ -z ${SYMBOL_LIST} ] ; then echo "symbols are not specified" exit fi if [ -z ${DATE} ] ; then DATE=$(date -d 'yesterday' +'%Y%m%d') fi mkdir -p ${OUTPUT_DIR} if ! is_business_day ${DATE}; then echo "${DATE} is not business day" exit fi OLD_IFS=${IFS} IFS="," read -ra Symbols <<< "${SYMBOL_LIST}" IFS=${OLD_IFS} echo "DATE=${DATE} Symbols=${Symbols[@]} OUTPUT_DIR=${OUTPUT_DIR}" echo Getting data from ${DataHost} ... year=$(date -d ${DATE} +"%Y") for sym in ${Symbols[@]}; do inst_id="STOCK-${sym}" capital=${sym:0:1} SourceDir="${SOURCE_ROOT_DIR}/${year}/${capital}/${sym}" SourceHbarFile="${SourceDir}/${DATE}.${sym}.alpaca_1m_bars.db.gz" SourceQatFile="${SourceDir}/${DATE}.${sym}.alpaca_qat.db.gz" for src_file in ${SourceHbarFile} ${SourceQatFile}; do Cmd="rsync -ahv" Cmd+=" ${SOURCE_HOST}:${src_file}" Cmd+=" $OUTPUT_DIR/" echo ${Cmd} eval ${Cmd} done done Cmd="(cd ${OUTPUT_DIR} && gunzip *.db.gz)" echo ${Cmd} eval ${Cmd} ResultDbFile="${OUTPUT_DIR}/${DATE}.alpaca_sim_md.db" echo "Creating Result Database File ${ResultDbFile}" echo "Creating table md_trades ..." sqlite3 ${ResultDbFile} <