2026-03-30 10:42:09 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"database/sql"
|
|
|
|
|
"encoding/csv"
|
|
|
|
|
"flag"
|
|
|
|
|
"fmt"
|
2026-03-30 13:58:13 -04:00
|
|
|
"log"
|
2026-03-30 10:42:09 -04:00
|
|
|
"os"
|
|
|
|
|
|
|
|
|
|
_ "github.com/go-sql-driver/mysql"
|
|
|
|
|
"github.com/stephenafamo/bob"
|
|
|
|
|
"gitlab.artefactual.com/dcosme/am-scripts/database/mcp/models"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var (
|
|
|
|
|
csvPath = flag.String("csv", "aips.csv", "Path to the CSV file containing AIP names")
|
|
|
|
|
mysqlConnString = flag.String("mysql", "root:12345@tcp(localhost:62001)/SS?parseTime=true", "mysql connection string")
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
2026-03-30 13:58:13 -04:00
|
|
|
err := server()
|
|
|
|
|
assertNoErr(err)
|
|
|
|
|
|
2026-03-30 10:42:09 -04:00
|
|
|
flag.Parse()
|
|
|
|
|
file, err := os.Open(*csvPath)
|
|
|
|
|
assertNoErr(err)
|
|
|
|
|
records, err := csv.NewReader(file).ReadAll()
|
|
|
|
|
assertNoErr(err)
|
|
|
|
|
|
2026-03-30 13:58:13 -04:00
|
|
|
db, err := openDB(*mysqlConnString)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
2026-03-30 10:42:09 -04:00
|
|
|
bobDB := bob.NewDB(db)
|
|
|
|
|
|
2026-03-30 11:14:54 -04:00
|
|
|
err = os.RemoveAll("aips-report.csv")
|
|
|
|
|
assertNoErr(err)
|
|
|
|
|
reportFile, err := os.Create("aips-report.csv")
|
|
|
|
|
assertNoErr(err)
|
|
|
|
|
reportWriter := csv.NewWriter(reportFile)
|
|
|
|
|
|
|
|
|
|
reportData := make([][]string, len(records))
|
|
|
|
|
for idx, record := range records {
|
2026-03-30 10:42:09 -04:00
|
|
|
q := models.LocationsPackages.Query()
|
2026-03-30 14:07:01 -04:00
|
|
|
like := fmt.Sprintf("%%%s%%", record[0])
|
2026-03-30 10:42:09 -04:00
|
|
|
q.Apply(models.SelectWhere.LocationsPackages.CurrentPath.Like(like))
|
|
|
|
|
res, err := q.All(context.Background(), bobDB)
|
|
|
|
|
assertNoErr(err)
|
2026-03-30 11:14:54 -04:00
|
|
|
|
|
|
|
|
row := []string{record[0]}
|
2026-03-30 10:42:09 -04:00
|
|
|
for _, r := range res {
|
|
|
|
|
fmt.Println("AIP Found: " + r.CurrentPath)
|
2026-03-30 11:14:54 -04:00
|
|
|
row = append(row, r.CurrentPath)
|
2026-03-30 10:42:09 -04:00
|
|
|
}
|
2026-03-30 11:14:54 -04:00
|
|
|
reportData[idx] = row
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, row := range reportData {
|
|
|
|
|
err = reportWriter.Write(row)
|
|
|
|
|
assertNoErr(err)
|
2026-03-30 10:42:09 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func assertNoErr(err error) {
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-30 13:58:13 -04:00
|
|
|
func openDB(connStr string) (*sql.DB, error) {
|
2026-03-30 10:42:09 -04:00
|
|
|
db, err := sql.Open("mysql", connStr)
|
2026-03-30 13:58:13 -04:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
return db, db.Ping()
|
2026-03-30 10:42:09 -04:00
|
|
|
}
|