migrate.sh 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/bin/bash
  2. LAST_NUM_STR=`find ./support/migrate/ -maxdepth 1 -name '*.go' | sort -t_ -nk2,2 | tail -n1 | awk -F/ '{print $NF}' | awk -F. '{print $NR}'`
  3. NEXT_NUM_INT=$(($LAST_NUM_STR + 1))
  4. NEXT_NUM_STR=`printf %09d $NEXT_NUM_INT`
  5. TARGET_FILE="./support/migrate/${NEXT_NUM_STR}.go"
  6. # Create new migration file
  7. echo "package migrate" > $TARGET_FILE
  8. echo "" >> $TARGET_FILE
  9. echo "import (" >> $TARGET_FILE
  10. echo " \"golang-fave/engine/sqlw\"" >> $TARGET_FILE
  11. echo ")" >> $TARGET_FILE
  12. echo "" >> $TARGET_FILE
  13. echo "func Migrate_${NEXT_NUM_STR}(db *sqlw.DB, host string) error {" >> $TARGET_FILE
  14. echo " return nil" >> $TARGET_FILE
  15. echo "}" >> $TARGET_FILE
  16. # Update list
  17. LIST_FILE="./support/migrate/000000001.go"
  18. echo "package migrate" > $LIST_FILE
  19. echo "" >> $LIST_FILE
  20. echo "import (" >> $LIST_FILE
  21. echo " \"golang-fave/engine/sqlw\"" >> $LIST_FILE
  22. echo ")" >> $LIST_FILE
  23. echo "" >> $LIST_FILE
  24. echo "var Migrations = map[string]func(*sqlw.DB, string) error{" >> $LIST_FILE
  25. echo " \"000000000\": nil," >> $LIST_FILE
  26. echo " \"000000001\": nil," >> $LIST_FILE
  27. for i in `ls ./support/migrate/*.go | sort -V`; do
  28. IFILE=`echo "$i" | awk -F/ '{print $NF}' | awk -F. '{print $NR}'`
  29. if [ $IFILE == "000000000" ] || [ $IFILE == "000000001" ]; then
  30. continue
  31. fi
  32. echo " \"${IFILE}\": Migrate_${IFILE}," >> $LIST_FILE
  33. done
  34. echo "}" >> $LIST_FILE
  35. echo "New migration file created: ${TARGET_FILE}"