Skip to content

Commit

Permalink
🧹 chore: make search url configurable (#937)
Browse files Browse the repository at this point in the history
  • Loading branch information
garrettladley authored May 28, 2024
1 parent f0962df commit b308e6c
Show file tree
Hide file tree
Showing 7 changed files with 25 additions and 11 deletions.
5 changes: 5 additions & 0 deletions backend/config/search.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package config

type SearchSettings struct {
URI string `env:"URI"`
}
3 changes: 3 additions & 0 deletions backend/config/settings.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ type Integrations struct {
OutlookOauth OAuthSettings
AWS AWSSettings
Resend ResendSettings
Search SearchSettings
}

type intermediateSettings struct {
Expand All @@ -32,6 +33,7 @@ type intermediateSettings struct {
calendar intermediateCalendarSettings `envPrefix:"SAC_CALENDAR_"`
googleSettings intermediateGoogleOAuthSettings `envPrefix:"SAC_GOOGLE_OAUTH"`
outlookSettings intermdeiateOutlookOAuthSettings `envPrefix:"SAC_OUTLOOK_OAUTH"`
search SearchSettings `env:"SAC_SEARCH"`
}

func (i *intermediateSettings) into() (*Settings, error) {
Expand Down Expand Up @@ -104,6 +106,7 @@ func (i *intermediateSettings) into() (*Settings, error) {
OutlookOauth: *outlook,
AWS: *aws,
Resend: *resend,
Search: i.search,
},
}, nil
}
9 changes: 5 additions & 4 deletions backend/constants/search.go
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
package constants

const (
SEARCH_URL = "http://127.0.0.1:9200"
CLUBS_INDEX = "clubs"
EVENTS_INDEX = "events"
SEARCH_QUERY_DEFAULT_MAX_MEMBERS = 16384
CLUBS_INDEX string = "clubs"
EVENTS_INDEX string = "events"
SEARCH_QUERY_DEFAULT_MAX_MEMBERS int = 16384
)

var SEARCH_URI string
3 changes: 3 additions & 0 deletions backend/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"path/filepath"

"github.com/GenerateNU/sac/backend/config"
"github.com/GenerateNU/sac/backend/constants"
"github.com/GenerateNU/sac/backend/database"
"github.com/GenerateNU/sac/backend/database/store"
_ "github.com/GenerateNU/sac/backend/docs"
Expand All @@ -32,6 +33,8 @@ func main() {
utilities.Exit("Error getting configuration: %s", err.Error())
}

constants.SEARCH_URI = config.Search.URI

err = checkServerRunning(config.Application.Host, config.Application.Port)
if err == nil {
utilities.Exit("A server is already running on %s:%d.\n", config.Application.Host, config.Application.Port)
Expand Down
6 changes: 3 additions & 3 deletions backend/search/base/transactions.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ func doSearchGetRequest[T, V any](url string, requestBody T) (*V, error) {
return nil, err
}

resp, err := utilities.Request(http.MethodGet, fmt.Sprintf("%s%s", constants.SEARCH_URL, url), payload, utilities.JSON())
resp, err := utilities.Request(http.MethodGet, fmt.Sprintf("%s%s", constants.SEARCH_URI, url), payload, utilities.JSON())
if err != nil {
return nil, err
}
Expand Down Expand Up @@ -80,7 +80,7 @@ func Upsert[T types.Searchable](db *gorm.DB, index string, uuid string, model ty
return err
}

resp, err := utilities.Request(http.MethodPost, fmt.Sprintf("%s/%s/_update/%s", constants.SEARCH_URL, index, uuid), payload, utilities.JSON())
resp, err := utilities.Request(http.MethodPost, fmt.Sprintf("%s/%s/_update/%s", constants.SEARCH_URI, index, uuid), payload, utilities.JSON())
if err != nil {
return err
}
Expand All @@ -90,7 +90,7 @@ func Upsert[T types.Searchable](db *gorm.DB, index string, uuid string, model ty
}

func Delete(db *gorm.DB, index string, uuid string) error {
resp, err := utilities.Request(http.MethodDelete, fmt.Sprintf("%s/%s/_doc/%s", constants.SEARCH_URL, index, uuid), nil, utilities.JSON())
resp, err := utilities.Request(http.MethodDelete, fmt.Sprintf("%s/%s/_doc/%s", constants.SEARCH_URI, index, uuid), nil, utilities.JSON())
if err != nil {
return err
}
Expand Down
8 changes: 4 additions & 4 deletions backend/search/seed.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ func SeedClubs(db *gorm.DB) error {
stdout := os.Stdout

stdout.WriteString("Deleting existing club index...\n")
req, err := http.NewRequest("DELETE", fmt.Sprintf("%s/clubs", constants.SEARCH_URL), nil)
req, err := http.NewRequest("DELETE", fmt.Sprintf("%s/clubs", constants.SEARCH_URI), nil)
if err != nil {
return err
}
Expand Down Expand Up @@ -58,7 +58,7 @@ func SeedClubs(db *gorm.DB) error {
requestBodyBuilder.WriteString(fmt.Sprintf("%s\n%s\n", indexJson, clubJson))
}

resp, err := utilities.Request(http.MethodPost, fmt.Sprintf("%s/_bulk", constants.SEARCH_URL), []byte(requestBodyBuilder.String()), utilities.JSON())
resp, err := utilities.Request(http.MethodPost, fmt.Sprintf("%s/_bulk", constants.SEARCH_URI), []byte(requestBodyBuilder.String()), utilities.JSON())
if err != nil {
stdout.WriteString(fmt.Sprintf("Error making _bulk request for club seeding: %s\n", err.Error()))
}
Expand All @@ -78,7 +78,7 @@ func SeedEvents(db *gorm.DB) error {
stdout := os.Stdout

stdout.WriteString("Deleting existing event index...\n")
resp, err := utilities.Request(http.MethodDelete, fmt.Sprintf("%s/events", constants.SEARCH_URL), nil, utilities.JSON())
resp, err := utilities.Request(http.MethodDelete, fmt.Sprintf("%s/events", constants.SEARCH_URI), nil, utilities.JSON())
if err != nil {
return err
}
Expand Down Expand Up @@ -109,7 +109,7 @@ func SeedEvents(db *gorm.DB) error {
requestBodyBuilder.WriteString(fmt.Sprintf("%s\n%s\n", indexJson, eventJson))
}

resp, err = utilities.Request(http.MethodPost, fmt.Sprintf("%s/_bulk", constants.SEARCH_URL), []byte(requestBodyBuilder.String()), utilities.JSON())
resp, err = utilities.Request(http.MethodPost, fmt.Sprintf("%s/_bulk", constants.SEARCH_URI), []byte(requestBodyBuilder.String()), utilities.JSON())
if err != nil {
stdout.WriteString(fmt.Sprintf("Error making _bulk request for event seeding: %s\n", err.Error()))
}
Expand Down
2 changes: 2 additions & 0 deletions config/.env.template
Original file line number Diff line number Diff line change
Expand Up @@ -55,3 +55,5 @@ SAC_GOOGLE_OAUTH_REDIRECT_URI="http://127.0.0.1:3000"
SAC_OUTLOOK_OAUTH_CLIENT_ID=test
SAC_OUTLOOK_OAUTH_CLIENT_SECRET=test
SAC_OUTLOOK_OAUTH_REDIRECT_URI="http://127.0.0.1:3000

SAC_SEARCH_URI=""http://127.0.0.1:9200"

0 comments on commit b308e6c

Please sign in to comment.