timetable-extension #1
@ -10,10 +10,13 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// Accepts CORPUS data as a byte array and formats it ready for database insertion
|
// Accepts CORPUS data as a byte array and formats it ready for database insertion
|
||||||
func parseCorpusData(jsonData *[]byte) ([]database.CorpusEntry, error) {
|
func parseCorpusData(jsonData *[]byte) (*[]database.CorpusEntry, error) {
|
||||||
log.Msg.Info("Unmarshalling CORPUS Data")
|
log.Msg.Debug("Starting CORPUS Data parsing")
|
||||||
|
|
||||||
|
// Initialise data structure
|
||||||
var dataMap map[string]interface{}
|
var dataMap map[string]interface{}
|
||||||
|
|
||||||
|
// Create JSON
|
||||||
err := json.Unmarshal(*jsonData, &dataMap)
|
err := json.Unmarshal(*jsonData, &dataMap)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Msg.Error("Unable to unmarshal CORPUS data", zap.Error(err))
|
log.Msg.Error("Unable to unmarshal CORPUS data", zap.Error(err))
|
||||||
@ -51,11 +54,11 @@ func parseCorpusData(jsonData *[]byte) ([]database.CorpusEntry, error) {
|
|||||||
corpusEntries = append(corpusEntries, corpusEntry)
|
corpusEntries = append(corpusEntries, corpusEntry)
|
||||||
}
|
}
|
||||||
|
|
||||||
return corpusEntries, nil
|
return &corpusEntries, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Removes empty fields from CORPUS entries
|
// Removes empty fields from CORPUS entries
|
||||||
func pruneCorpusEntries(corpusEntries []database.CorpusEntry) []database.CorpusEntry {
|
func pruneCorpusEntries(corpusEntries []database.CorpusEntry) *[]database.CorpusEntry {
|
||||||
for i := range corpusEntries {
|
for i := range corpusEntries {
|
||||||
if corpusEntries[i].CRS == " " {
|
if corpusEntries[i].CRS == " " {
|
||||||
corpusEntries[i].CRS = ""
|
corpusEntries[i].CRS = ""
|
||||||
@ -74,5 +77,5 @@ func pruneCorpusEntries(corpusEntries []database.CorpusEntry) []database.CorpusE
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return corpusEntries
|
return &corpusEntries
|
||||||
}
|
}
|
||||||
|
@ -3,10 +3,10 @@ package corpus
|
|||||||
import "git.fjla.uk/owlboard/go-types/pkg/database"
|
import "git.fjla.uk/owlboard/go-types/pkg/database"
|
||||||
|
|
||||||
// Removes non-station entities from the CORPUS Data, ready for insertion to the database (stations collection)
|
// Removes non-station entities from the CORPUS Data, ready for insertion to the database (stations collection)
|
||||||
func createStationEntries(corpusData []database.CorpusEntry) []database.StationEntry {
|
func createStationEntries(corpusData *[]database.CorpusEntry) *[]database.StationEntry {
|
||||||
var stationEntries []database.StationEntry
|
var stationEntries []database.StationEntry
|
||||||
|
|
||||||
for _, entry := range corpusData {
|
for _, entry := range *corpusData {
|
||||||
if entry.CRS != "" {
|
if entry.CRS != "" {
|
||||||
stationEntry := database.StationEntry{
|
stationEntry := database.StationEntry{
|
||||||
CRS: entry.CRS,
|
CRS: entry.CRS,
|
||||||
@ -19,5 +19,5 @@ func createStationEntries(corpusData []database.CorpusEntry) []database.StationE
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return stationEntries
|
return &stationEntries
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ func RunCorpusUpdate(cfg *helpers.Configuration) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
corpusData := pruneCorpusEntries(unsortedCorpusData)
|
corpusData := pruneCorpusEntries(*unsortedCorpusData)
|
||||||
stationData := createStationEntries(corpusData)
|
stationData := createStationEntries(corpusData)
|
||||||
|
|
||||||
if err := dbAccess.DropCollection(dbAccess.CorpusCollection); err != nil {
|
if err := dbAccess.DropCollection(dbAccess.CorpusCollection); err != nil {
|
||||||
|
@ -7,12 +7,12 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// Puts an array of Corpus Documents into the database
|
// Puts an array of Corpus Documents into the database
|
||||||
func PutManyCorpus(corpusData []database.CorpusEntry) error {
|
func PutManyCorpus(corpusData *[]database.CorpusEntry) error {
|
||||||
collection := MongoClient.Database(databaseName).Collection(CorpusCollection)
|
collection := MongoClient.Database(databaseName).Collection(CorpusCollection)
|
||||||
|
|
||||||
documents := convertCorpusToInterfaceSlice(corpusData)
|
documents := convertCorpusToInterfaceSlice(corpusData)
|
||||||
|
|
||||||
_, err := collection.InsertMany(context.Background(), documents)
|
_, err := collection.InsertMany(context.Background(), *documents)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -22,12 +22,12 @@ func PutManyCorpus(corpusData []database.CorpusEntry) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Puts an array of Stations documents into the database
|
// Puts an array of Stations documents into the database
|
||||||
func PutManyStations(stationsData []database.StationEntry) error {
|
func PutManyStations(stationsData *[]database.StationEntry) error {
|
||||||
collection := MongoClient.Database(databaseName).Collection(StationsCollection)
|
collection := MongoClient.Database(databaseName).Collection(StationsCollection)
|
||||||
|
|
||||||
documents := convertStationsToInterfaceSlice(stationsData)
|
documents := convertStationsToInterfaceSlice(stationsData)
|
||||||
|
|
||||||
_, err := collection.InsertMany(context.Background(), documents)
|
_, err := collection.InsertMany(context.Background(), *documents)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -37,19 +37,19 @@ func PutManyStations(stationsData []database.StationEntry) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Converts []database.CorpusEntry types into interface slices required to put them into the database
|
// Converts []database.CorpusEntry types into interface slices required to put them into the database
|
||||||
func convertCorpusToInterfaceSlice(corpusData []database.CorpusEntry) []interface{} {
|
func convertCorpusToInterfaceSlice(corpusData *[]database.CorpusEntry) *[]interface{} {
|
||||||
interfaceSlice := make([]interface{}, len(corpusData))
|
interfaceSlice := make([]interface{}, len(*corpusData))
|
||||||
for i, doc := range corpusData {
|
for i, doc := range *corpusData {
|
||||||
interfaceSlice[i] = doc
|
interfaceSlice[i] = doc
|
||||||
}
|
}
|
||||||
return interfaceSlice
|
return &interfaceSlice
|
||||||
}
|
}
|
||||||
|
|
||||||
// Converts []database.StationEntry types into interface slices required to put them into the database
|
// Converts []database.StationEntry types into interface slices required to put them into the database
|
||||||
func convertStationsToInterfaceSlice(stationsData []database.StationEntry) []interface{} {
|
func convertStationsToInterfaceSlice(stationsData *[]database.StationEntry) *[]interface{} {
|
||||||
interfaceSlice := make([]interface{}, len(stationsData))
|
interfaceSlice := make([]interface{}, len(*stationsData))
|
||||||
for i, doc := range stationsData {
|
for i, doc := range *stationsData {
|
||||||
interfaceSlice[i] = doc
|
interfaceSlice[i] = doc
|
||||||
}
|
}
|
||||||
return interfaceSlice
|
return &interfaceSlice
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user