Upstream sync
This commit is contained in:
@@ -81,3 +81,6 @@ secret = "hK4Yc9jtBrxaZTr4UU2VsfX9"
|
|||||||
url = "https://api-cloud.bcbs.com/blue365deals-stg/v1/validatePrefix/"
|
url = "https://api-cloud.bcbs.com/blue365deals-stg/v1/validatePrefix/"
|
||||||
key = "jcn5xjxvarc96rtjxp25dctj"
|
key = "jcn5xjxvarc96rtjxp25dctj"
|
||||||
secret = "6XdEusG2w2PWWXsfXVyweQnY"
|
secret = "6XdEusG2w2PWWXsfXVyweQnY"
|
||||||
|
|
||||||
|
[eligibility]
|
||||||
|
url = "https://portal-api.dev.bcbsinstitute.com/v1/nemt/eligibility"
|
||||||
@@ -81,3 +81,6 @@ secret = "vFhNeWE8JdJpbDZQtcm6AHjX"
|
|||||||
url = "https://api-cloud.bcbs.com/blue365deals-stg/v1/validatePrefix/"
|
url = "https://api-cloud.bcbs.com/blue365deals-stg/v1/validatePrefix/"
|
||||||
key = "jcn5xjxvarc96rtjxp25dctj"
|
key = "jcn5xjxvarc96rtjxp25dctj"
|
||||||
secret = "6XdEusG2w2PWWXsfXVyweQnY"
|
secret = "6XdEusG2w2PWWXsfXVyweQnY"
|
||||||
|
|
||||||
|
[eligibility]
|
||||||
|
url = "https://portal-api.bcbsinstitute.com/v1/nemt/eligibility"
|
||||||
@@ -24,7 +24,7 @@ func (c *zipcodeRepo) getQuery() string {
|
|||||||
a.participating_zip_code_id,
|
a.participating_zip_code_id,
|
||||||
a.participating_zip_code_uuid,
|
a.participating_zip_code_uuid,
|
||||||
a.zipcode,
|
a.zipcode,
|
||||||
a.participating
|
(IFNULL(a.participating, b'0') = b'1') participating
|
||||||
FROM
|
FROM
|
||||||
tab_participating_zip_code a `
|
tab_participating_zip_code a `
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -25,6 +25,7 @@ type Config struct {
|
|||||||
Blue365 Blue365Config
|
Blue365 Blue365Config
|
||||||
Email EmailConfig
|
Email EmailConfig
|
||||||
GoogleShortener GoogleShortenerConfig
|
GoogleShortener GoogleShortenerConfig
|
||||||
|
Eligibility EligibilityConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
// AppConfig represents the configuration values about the application.
|
// AppConfig represents the configuration values about the application.
|
||||||
@@ -137,6 +138,10 @@ type GoogleShortenerConfig struct {
|
|||||||
SecretKey string
|
SecretKey string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type EligibilityConfig struct {
|
||||||
|
Url string
|
||||||
|
}
|
||||||
|
|
||||||
// Read returns the configuration values,
|
// Read returns the configuration values,
|
||||||
// based on the configuration files and environment variables.
|
// based on the configuration files and environment variables.
|
||||||
func Read() (*Config, error) {
|
func Read() (*Config, error) {
|
||||||
@@ -238,6 +243,9 @@ func Read() (*Config, error) {
|
|||||||
ClientID: viper.GetString("google-shortener.client-id"),
|
ClientID: viper.GetString("google-shortener.client-id"),
|
||||||
SecretKey: viper.GetString("google-shortener.secret-key"),
|
SecretKey: viper.GetString("google-shortener.secret-key"),
|
||||||
},
|
},
|
||||||
|
Eligibility : EligibilityConfig{
|
||||||
|
Url : viper.GetString("eligibility.url"),
|
||||||
|
},
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,10 @@ import (
|
|||||||
"math/rand"
|
"math/rand"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
"net/http"
|
||||||
|
"encoding/json"
|
||||||
|
"bytes"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"bitbucket.org/nemt/nemt-portal-api/application/applicationservice"
|
"bitbucket.org/nemt/nemt-portal-api/application/applicationservice"
|
||||||
"bitbucket.org/nemt/nemt-portal-api/application/third/eligibility/bcbsi"
|
"bitbucket.org/nemt/nemt-portal-api/application/third/eligibility/bcbsi"
|
||||||
@@ -22,6 +26,10 @@ import (
|
|||||||
"googlemaps.github.io/maps"
|
"googlemaps.github.io/maps"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
zipcodeTrimLength = 5
|
||||||
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
instance *controller
|
instance *controller
|
||||||
once sync.Once
|
once sync.Once
|
||||||
@@ -395,15 +403,52 @@ func (c *controller) handleMember(ctx echo.Context) error {
|
|||||||
eligibility.ServiceInfo.DateOfService = time.Now()
|
eligibility.ServiceInfo.DateOfService = time.Now()
|
||||||
eligibility.ServiceInfo.ServiceTypeCodes = []string{"30"}
|
eligibility.ServiceInfo.ServiceTypeCodes = []string{"30"}
|
||||||
|
|
||||||
|
/*
|
||||||
resp, err := c.bcbsi.BXE.Get271(eligibility)
|
resp, err := c.bcbsi.BXE.Get271(eligibility)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Eligibility Not Found or Error: ", err.Error())
|
fmt.Println("Eligibility Not Found or Error: ", err.Error())
|
||||||
return routeutils.ResponseAPINotEligibleError(ctx)
|
return routeutils.ResponseAPINotEligibleError(ctx)
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
//This part is emulating eligibility check for testing purposes
|
||||||
|
client := &http.Client{}
|
||||||
|
eligibilityJson, err := json.Marshal(eligibility)
|
||||||
|
if err != nil {
|
||||||
|
return routeutils.HandleAPIError(ctx, err)
|
||||||
|
}
|
||||||
|
req, _ := http.NewRequest("POST", c.cfg.Eligibility.Url, bytes.NewBuffer(eligibilityJson))
|
||||||
|
req.Header.Add("App", c.cfg.HTTP.Auth.AppKey)
|
||||||
|
req.Header.Add("Token", ctx.Request().Header.Get("Token"))
|
||||||
|
req.Header.Add("Content-Type", "application/json")
|
||||||
|
|
||||||
|
resp, err := client.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return routeutils.HandleAPIError(ctx, err)
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
if resp.StatusCode < 200 || resp.StatusCode > 300 {
|
||||||
|
return routeutils.ResponseAPINotEligibleWithMessageError(ctx, "Cannot check eligibility")
|
||||||
|
}
|
||||||
|
|
||||||
|
eligibilityResponse := viewmodel.Interchange271{}
|
||||||
|
decoder := json.NewDecoder(resp.Body)
|
||||||
|
err = decoder.Decode(&eligibilityResponse)
|
||||||
|
if err != nil {
|
||||||
|
return routeutils.ResponseAPINotEligibleWithMessageError(ctx, "Cannot check eligibility")
|
||||||
|
}
|
||||||
|
//================================================================
|
||||||
|
|
||||||
|
if len(eligibilityResponse.Division.HealthCareEligibilityResponse.LoopHL0030) < 1 {
|
||||||
|
return routeutils.ResponseAPINotEligibleWithMessageError(ctx, "Cannot check eligibility")
|
||||||
|
}
|
||||||
|
|
||||||
address := viewmodel.Address{}
|
address := viewmodel.Address{}
|
||||||
header := resp.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N3_0950
|
//header := resp.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N3_0950
|
||||||
body := resp.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N4_0960
|
//body := resp.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N4_0960
|
||||||
|
header := eligibilityResponse.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N3_0950
|
||||||
|
body := eligibilityResponse.Division.HealthCareEligibilityResponse.LoopHL0030[0].HL_0460[0].HL_0890[0].NM1_0920[0].N4_0960
|
||||||
|
|
||||||
address.AddressTypeName = "Home"
|
address.AddressTypeName = "Home"
|
||||||
address.AddressType = "home"
|
address.AddressType = "home"
|
||||||
@@ -412,21 +457,22 @@ func (c *controller) handleMember(ctx echo.Context) error {
|
|||||||
address.CreatedUserUUID = authUser.ID
|
address.CreatedUserUUID = authUser.ID
|
||||||
address.User = user
|
address.User = user
|
||||||
|
|
||||||
zipCodeFromAddress := body.N403
|
cleanZipcode := strings.TrimSpace(body.N403)
|
||||||
zipCodeObj, err := c.svc.Zipcodes.GetByParticipatingZipcode(zipCodeFromAddress)
|
trimmedZipcode := cleanZipcode
|
||||||
|
if len(cleanZipcode) > zipcodeTrimLength {
|
||||||
if err != nil{
|
trimmedZipcode = cleanZipcode[:zipcodeTrimLength]
|
||||||
return routeutils.HandleAPIError(ctx, err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if !zipCodeObj.Participating {
|
_, err = c.svc.Zipcodes.GetByParticipatingZipcode(trimmedZipcode)
|
||||||
return routeutils.ResponseAPINotEligibleWithMessageError(ctx, "Member's Home zipcode, " + zipCodeFromAddress + ", is not currently eligible for participation in this program")
|
|
||||||
|
if err != nil{
|
||||||
|
return routeutils.ResponseAPINotEligibleWithMessageError(ctx, "Member's Home zipcode, " + trimmedZipcode + ", is not currently eligible for participation in this program")
|
||||||
}
|
}
|
||||||
|
|
||||||
googleMapsAPI, err := maps.NewClient(maps.WithClientIDAndSignature("gme-bluecrossandblue1", "msqgD-jdqCyR0M_1u5C1HION5iI="))
|
googleMapsAPI, err := maps.NewClient(maps.WithClientIDAndSignature("gme-bluecrossandblue1", "msqgD-jdqCyR0M_1u5C1HION5iI="))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error to instantiate googles api: ", err.Error())
|
fmt.Println("Error to instantiate googles api: ", err.Error())
|
||||||
return routeutils.ResponseAPINotEligibleError(ctx)
|
return routeutils.HandleAPIError(ctx,err)
|
||||||
}
|
}
|
||||||
|
|
||||||
r := &maps.GeocodingRequest{
|
r := &maps.GeocodingRequest{
|
||||||
@@ -436,7 +482,7 @@ func (c *controller) handleMember(ctx echo.Context) error {
|
|||||||
result, err := googleMapsAPI.Geocode(context.Background(), r)
|
result, err := googleMapsAPI.Geocode(context.Background(), r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error to instantiate googles api: ", err.Error())
|
fmt.Println("Error to instantiate googles api: ", err.Error())
|
||||||
return routeutils.ResponseAPINotEligibleError(ctx)
|
return routeutils.HandleAPIError(ctx,err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(result) > 0 {
|
if len(result) > 0 {
|
||||||
@@ -446,7 +492,7 @@ func (c *controller) handleMember(ctx echo.Context) error {
|
|||||||
_, err := c.svc.Users.SaveAddress(address)
|
_, err := c.svc.Users.SaveAddress(address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error to save address: ", err.Error())
|
fmt.Println("Error to save address: ", err.Error())
|
||||||
return routeutils.ResponseAPINotEligibleError(ctx)
|
return routeutils.HandleAPIError(ctx,err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user