Skip to content

Commit

Permalink
LANTERN-624: Prevent populatedb script from stopping on error
Browse files Browse the repository at this point in the history
  • Loading branch information
archita-ekkirala committed Jul 31, 2024
1 parent 2a5af62 commit ca305a0
Showing 1 changed file with 128 additions and 125 deletions.
253 changes: 128 additions & 125 deletions endpointmanager/cmd/endpointpopulator/main.go
Original file line number Diff line number Diff line change
@@ -1,125 +1,128 @@
package main

import (
"context"
"fmt"
"os"
"strconv"
"time"

"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/config"
"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/fetcher"
endptQuerier "github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/fhirendpointquerier"
"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/helpers"
"github.com/onc-healthit/lantern-back-end/lanternmq/pkg/accessqueue"
log "github.com/sirupsen/logrus"
"github.com/spf13/viper"
"github.com/streadway/amqp"

"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/endpointmanager/postgresql"
)

func main() {
var endpointsFile string
var source string
var listURL string
var format string
var isChpl bool

err := config.SetupConfig()
helpers.FailOnError("Error setting up config", err)

var channel *amqp.Channel

capQName := viper.GetString("endptinfo_capquery_qname")
qUser := viper.GetString("quser")
qPassword := viper.GetString("qpassword")
qHost := viper.GetString("qhost")
qPort := viper.GetString("qport")

// setup specific queue info so we can test what's in the queue
s := fmt.Sprintf("amqp://%s:%s@%s:%s/", qUser, qPassword, qHost, qPort)
conn, err := amqp.Dial(s)
helpers.FailOnError("", err)

channel, err = conn.Channel()
helpers.FailOnError("", err)

count, err := accessqueue.QueueCount(capQName, channel)
helpers.FailOnError("", err)

if count != 0 {
log.Fatalf("There are %d messages in the queue. Queue must be empty to run the endpoint populator.", count)
}

if len(os.Args) == 5 {
endpointsFile = os.Args[1]
format = os.Args[2]
source = os.Args[3]
isChpl, err = strconv.ParseBool(os.Args[4])
helpers.FailOnError("", err)
} else if len(os.Args) == 6 {
endpointsFile = os.Args[1]
format = os.Args[2]
source = os.Args[3]
isChpl, err = strconv.ParseBool(os.Args[4])
helpers.FailOnError("", err)
listURL = os.Args[5]
} else if len(os.Args) == 3 {
log.Fatalf("ERROR: Missing endpoints list format command-line argument")
} else if len(os.Args) == 4 {
log.Fatalf("ERROR: Missing endpoints list source command-line argument")
} else {
log.Fatalf("ERROR: Endpoints list command-line arguments are not correct")
}

listOfEndpoints, err := fetcher.GetEndpointsFromFilepath(endpointsFile, format, source, listURL)
helpers.FailOnError("Endpoint List Parsing Error: ", err)

err = config.SetupConfig()
helpers.FailOnError("", err)

ctx := context.Background()
store, err := postgresql.NewStore(viper.GetString("dbhost"), viper.GetInt("dbport"), viper.GetString("dbuser"), viper.GetString("dbpassword"), viper.GetString("dbname"), viper.GetString("dbsslmode"))
helpers.FailOnError("", err)
log.Info("Successfully connected to DB!")

if len(listOfEndpoints.Entries) != 0 {
dbErr := endptQuerier.AddEndpointData(ctx, store, &listOfEndpoints)
helpers.FailOnError("Saving in fhir_endpoints database error: ", dbErr)
} else {
var listSource string
if listURL != "" {
listSource = listURL
} else {
listSource = source
}
dbErr := endptQuerier.RemoveOldEndpoints(ctx, store, time.Now().Add(time.Hour*24), listSource)
helpers.FailOnError("Deleting old endpoints in fhir_endpoints database error: ", dbErr)

dbErr = endptQuerier.RemoveOldEndpointOrganizations(ctx, store, time.Now().Add(time.Hour*24), listSource)
helpers.FailOnError("Deleting old endpoint organizations in fhir_endpoint_organizations database error: ", dbErr)

}

addListSourceStatement := `
INSERT INTO list_source_info (
list_source,
is_chpl
)
SELECT $1, $2
WHERE
NOT EXISTS (
SELECT list_source FROM list_source_info WHERE list_source = $3
);
`
var listSource string
if listURL != "" {
listSource = listURL
} else {
listSource = source
}

_, sourceErr := store.DB.ExecContext(ctx, addListSourceStatement, listSource, isChpl, listSource)
helpers.FailOnError("Adding source to list_source database error: ", sourceErr)
}
package main

import (
"context"
"fmt"
"os"
"strconv"
"time"

"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/config"
"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/fetcher"
endptQuerier "github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/fhirendpointquerier"
"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/helpers"
"github.com/onc-healthit/lantern-back-end/lanternmq/pkg/accessqueue"
log "github.com/sirupsen/logrus"
"github.com/spf13/viper"
"github.com/streadway/amqp"

"github.com/onc-healthit/lantern-back-end/endpointmanager/pkg/endpointmanager/postgresql"
)

func main() {
var endpointsFile string
var source string
var listURL string
var format string
var isChpl bool

err := config.SetupConfig()
helpers.FailOnError("Error setting up config", err)

var channel *amqp.Channel

capQName := viper.GetString("endptinfo_capquery_qname")
qUser := viper.GetString("quser")
qPassword := viper.GetString("qpassword")
qHost := viper.GetString("qhost")
qPort := viper.GetString("qport")

// setup specific queue info so we can test what's in the queue
s := fmt.Sprintf("amqp://%s:%s@%s:%s/", qUser, qPassword, qHost, qPort)
conn, err := amqp.Dial(s)
helpers.FailOnError("", err)

channel, err = conn.Channel()
helpers.FailOnError("", err)

count, err := accessqueue.QueueCount(capQName, channel)
helpers.FailOnError("", err)

if count != 0 {
log.Fatalf("There are %d messages in the queue. Queue must be empty to run the endpoint populator.", count)
}

if len(os.Args) == 5 {
endpointsFile = os.Args[1]
format = os.Args[2]
source = os.Args[3]
isChpl, err = strconv.ParseBool(os.Args[4])
helpers.FailOnError("", err)
} else if len(os.Args) == 6 {
endpointsFile = os.Args[1]
format = os.Args[2]
source = os.Args[3]
isChpl, err = strconv.ParseBool(os.Args[4])
helpers.FailOnError("", err)
listURL = os.Args[5]
} else if len(os.Args) == 3 {
log.Fatalf("ERROR: Missing endpoints list format command-line argument")
} else if len(os.Args) == 4 {
log.Fatalf("ERROR: Missing endpoints list source command-line argument")
} else {
log.Fatalf("ERROR: Endpoints list command-line arguments are not correct")
}

listOfEndpoints, err := fetcher.GetEndpointsFromFilepath(endpointsFile, format, source, listURL)
// helpers.FailOnError("Endponint List Parsing Error: ", err)
if(err!=nil){
fmt.Println("Endpoint List Parsing Error: ", err)
}

err = config.SetupConfig()
helpers.FailOnError("", err)

ctx := context.Background()
store, err := postgresql.NewStore(viper.GetString("dbhost"), viper.GetInt("dbport"), viper.GetString("dbuser"), viper.GetString("dbpassword"), viper.GetString("dbname"), viper.GetString("dbsslmode"))
helpers.FailOnError("", err)
log.Info("Successfully connected to DB!")

if len(listOfEndpoints.Entries) != 0 {
dbErr := endptQuerier.AddEndpointData(ctx, store, &listOfEndpoints)
helpers.FailOnError("Saving in fhir_endpoints database error: ", dbErr)
} else {
var listSource string
if listURL != "" {
listSource = listURL
} else {
listSource = source
}
dbErr := endptQuerier.RemoveOldEndpoints(ctx, store, time.Now().Add(time.Hour*24), listSource)
helpers.FailOnError("Deleting old endpoints in fhir_endpoints database error: ", dbErr)

dbErr = endptQuerier.RemoveOldEndpointOrganizations(ctx, store, time.Now().Add(time.Hour*24), listSource)
helpers.FailOnError("Deleting old endpoint organizations in fhir_endpoint_organizations database error: ", dbErr)

}

addListSourceStatement := `
INSERT INTO list_source_info (
list_source,
is_chpl
)
SELECT $1, $2
WHERE
NOT EXISTS (
SELECT list_source FROM list_source_info WHERE list_source = $3
);
`
var listSource string
if listURL != "" {
listSource = listURL
} else {
listSource = source
}

_, sourceErr := store.DB.ExecContext(ctx, addListSourceStatement, listSource, isChpl, listSource)
helpers.FailOnError("Adding source to list_source database error: ", sourceErr)
}

0 comments on commit ca305a0

Please sign in to comment.