Compare commits
1 Commits
ride_valid
...
self-regis
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6065e4ded3 |
@@ -49,44 +49,20 @@ func (c *controller) handle(ctx echo.Context) error {
|
|||||||
return routeutils.HandleAPIError(ctx, err)
|
return routeutils.HandleAPIError(ctx, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if user.PhoneNumber == nil || len(*user.PhoneNumber) == 0 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "phonenumber is required")
|
|
||||||
}
|
|
||||||
|
|
||||||
if user.Email == nil || len(*user.Email) == 0 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "email is required")
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(user.Pass) == 0 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "password is required")
|
|
||||||
}
|
|
||||||
|
|
||||||
pass, err := b64.StdEncoding.DecodeString(user.Pass)
|
pass, err := b64.StdEncoding.DecodeString(user.Pass)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "Invalid password")
|
return routeutils.ResponseAPIValidationError(ctx, "Invalid password")
|
||||||
}
|
}
|
||||||
user.Pass = string(pass)
|
user.Pass = string(pass)
|
||||||
|
|
||||||
if passwordValidationErrors := validation.ValidatePassword(&user); len(passwordValidationErrors) > 0 {
|
if validationErrors := validation.ValidateSelfregistration(&user); len(validationErrors) > 0 {
|
||||||
return routeutils.ResponseAPICustomValidationError(ctx, "Password not strong enough", passwordValidationErrors)
|
return routeutils.ResponseAPICustomValidationError(ctx, "Self registration failed", validationErrors)
|
||||||
}
|
|
||||||
|
|
||||||
if len(user.Name) == 0 && len(user.First) == 0 && len(user.Last) == 0 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "name is required")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(user.First) != 0 && len(user.Last) != 0 {
|
if len(user.First) != 0 && len(user.Last) != 0 {
|
||||||
user.Name = fmt.Sprintf("%s %s", user.First, user.Last)
|
user.Name = fmt.Sprintf("%s %s", user.First, user.Last)
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(user.Provider.InternalID) == 0 || len(user.Provider.InternalID) > 10 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "Provider NPI is invalid")
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(user.Provider.OrganizatioName) == 0 {
|
|
||||||
return routeutils.ResponseAPIValidationError(ctx, "Provider Organization Name is invalid")
|
|
||||||
}
|
|
||||||
|
|
||||||
provider, err := c.svc.Provider.GetByNPI(user.Provider.InternalID, authUser)
|
provider, err := c.svc.Provider.GetByNPI(user.Provider.InternalID, authUser)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error to create organization", err)
|
fmt.Println("Error to create organization", err)
|
||||||
|
|||||||
111
server/validation/selfregister.go
Normal file
111
server/validation/selfregister.go
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
package validation
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"bitbucket.org/nemt/nemt-portal-api/application/viewmodel"
|
||||||
|
"bitbucket.org/nemt/nemt-portal-api/infra/errors"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
minimumPasswordLength = 8
|
||||||
|
)
|
||||||
|
|
||||||
|
func validateSelfregistrationPassword(user *viewmodel.User, result *[]errors.ValidationError) {
|
||||||
|
if len(user.Pass) < minimumPasswordLength {
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password", Message: fmt.Sprint("Password must be at least ", minimumPasswordLength, " characters.")})
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.Contains(user.Pass, user.First) {
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password", Message: "Password cannot include your First Name."})
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.Contains(user.Pass, user.Last) {
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password", Message: "Password cannot include your Last Name."})
|
||||||
|
}
|
||||||
|
|
||||||
|
containsUpperCaseLetter := false
|
||||||
|
containsLowerCaseLetter := false
|
||||||
|
containsNumber := false
|
||||||
|
|
||||||
|
for _, character := range user.Pass {
|
||||||
|
containsUpperCaseLetter = containsUpperCaseLetter || characterIsUpperCase(character)
|
||||||
|
containsLowerCaseLetter = containsLowerCaseLetter || characterIsLowerCase(character)
|
||||||
|
containsNumber = containsNumber || characterIsNumber(character)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !containsUpperCaseLetter || !containsLowerCaseLetter || !containsNumber {
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password", Message: "Password must contain one of EACH :"})
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password-tab", Message: "an uppercase letter"})
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password-tab", Message: "a lowercase letter"})
|
||||||
|
*result = append(*result, errors.ValidationError{Field: "password-tab", Message: "a number"})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func ValidateSelfregistration(user *viewmodel.User) []errors.ValidationError {
|
||||||
|
var result []errors.ValidationError
|
||||||
|
|
||||||
|
//Provider Organization Name validation
|
||||||
|
if len(user.Provider.OrganizatioName) < 1 {
|
||||||
|
result = append(result, errors.ValidationError{Field: "provider.org_name", Message: "Provider Organization Name is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//Provider NPI validation
|
||||||
|
if len(user.Provider.InternalID) != 10 || !isNumeric(user.Provider.InternalID) {
|
||||||
|
result = append(result, errors.ValidationError{Field: "provider.internal_id", Message: "Provider NPI must be 10 digit number"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//First name validation
|
||||||
|
if len(user.First) < 1 {
|
||||||
|
result = append(result, errors.ValidationError{Field: "first", Message: "First Name is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isAlphabetic(user.First) {
|
||||||
|
result = append(result, errors.ValidationError{Field: "first", Message: "First Name contains non-alphabetic characters"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(user.First) > firstNameMaxLength {
|
||||||
|
result = append(result, errors.ValidationError{Field: "first", Message: "First Name is too long"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//Last name validation
|
||||||
|
if len(user.Last) < 1 {
|
||||||
|
result = append(result, errors.ValidationError{Field: "last", Message: "Last Name is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isAlphabetic(user.Last) {
|
||||||
|
result = append(result, errors.ValidationError{Field: "last", Message: "Last Name contains non-alphabetic characters"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(user.Last) > lastNameMaxLength {
|
||||||
|
result = append(result, errors.ValidationError{Field: "last", Message: "Last Name is too long"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//Email validation
|
||||||
|
if user.Email != nil {
|
||||||
|
if len(*user.Email) < 1 {
|
||||||
|
result = append(result, errors.ValidationError{Field: "email", Message: "Email is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isEmailValid(*user.Email) {
|
||||||
|
result = append(result, errors.ValidationError{Field: "email", Message: "Email is invalid"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(*user.Email) > emailMaxLength {
|
||||||
|
result = append(result, errors.ValidationError{Field: "email", Message: "Email is too long"})
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
result = append(result, errors.ValidationError{Field: "email", Message: "Email is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//Mobile validation
|
||||||
|
if (user.PhoneNumber == nil) || len(*user.PhoneNumber) < 1 {
|
||||||
|
result = append(result, errors.ValidationError{Field: "phonenumber", Message: "Phone number is required"})
|
||||||
|
}
|
||||||
|
|
||||||
|
//Password validation
|
||||||
|
validateSelfregistrationPassword(user, &result)
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
@@ -1,34 +1,36 @@
|
|||||||
package validation
|
package validation
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"regexp"
|
|
||||||
"strconv"
|
|
||||||
"time"
|
"time"
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
"bitbucket.org/nemt/nemt-portal-api/application/viewmodel"
|
"bitbucket.org/nemt/nemt-portal-api/application/viewmodel"
|
||||||
"bitbucket.org/nemt/nemt-portal-api/infra/errors"
|
"bitbucket.org/nemt/nemt-portal-api/infra/errors"
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
tripTypeFromVisit = "from_visit"
|
tripTypeFromVisit = "from_visit"
|
||||||
tripTypeToVisit = "to_visit"
|
tripTypeToVisit = "to_visit"
|
||||||
tripTypeFromVisitWillCall = "from_visit_call"
|
tripTypeFromVisitWillCall = "from_visit_call"
|
||||||
tripTypeRoundTrip = "roundtrip"
|
tripTypeRoundTrip = "roundtrip"
|
||||||
tripTypeRountTripWillCall = "roundtrip_call"
|
tripTypeRountTripWillCall = "roundtrip_call"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
loadingTime = 30 //in minutes
|
loadingTime = 30 //in minutes
|
||||||
minimumLoadTime = 30 //in minutes
|
minimumLoadTime = 30 //in minutes
|
||||||
minimumPickupTime = 10 //in minutes
|
minimumPickupTime = 10 //in minutes
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
hoursInDay = 24
|
hoursInDay = 24
|
||||||
hoursIn180Days = 24 * 180
|
hoursIn180Days = 24*180
|
||||||
time8Hours = 8
|
time8Hours = 8
|
||||||
time10Minutes = 10
|
time10Minutes = 10
|
||||||
)
|
)
|
||||||
|
|
||||||
func isMixedIDValid(id string) bool {
|
func isMixedIDValid(id string) bool {
|
||||||
@@ -36,7 +38,7 @@ func isMixedIDValid(id string) bool {
|
|||||||
hasLowerCase := false
|
hasLowerCase := false
|
||||||
hasNumber := false
|
hasNumber := false
|
||||||
|
|
||||||
for _, character := range id {
|
for _, character := range (id) {
|
||||||
hasUpperCase = hasUpperCase || ((character >= 65) && (character <= 90))
|
hasUpperCase = hasUpperCase || ((character >= 65) && (character <= 90))
|
||||||
hasLowerCase = hasLowerCase || ((character >= 97) && (character <= 122))
|
hasLowerCase = hasLowerCase || ((character >= 97) && (character <= 122))
|
||||||
hasNumber = hasNumber || ((character >= 48) && (character <= 57))
|
hasNumber = hasNumber || ((character >= 48) && (character <= 57))
|
||||||
@@ -51,162 +53,163 @@ func ValidateRide(requestRide *viewmodel.RideRequest, user *viewmodel.User) []er
|
|||||||
|
|
||||||
//Step #1 validation
|
//Step #1 validation
|
||||||
|
|
||||||
if !validUUIDregex.MatchString(user.ID) {
|
if !validUUIDregex.MatchString(user.ID){
|
||||||
result = append(result, errors.ValidationError{Field: "user_uuid", Message: "Step #1 - Choose a Member"})
|
result = append(result, errors.ValidationError{Field : "user_uuid", Message : "Step #1 - Choose a Member" })
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println("\n\n", requestRide.Origin.ID, "\n\n")
|
fmt.Println("\n\n", requestRide.Origin.ID, "\n\n")
|
||||||
if !isMixedIDValid(requestRide.Origin.ID) {
|
if !isMixedIDValid(requestRide.Origin.ID) {
|
||||||
//it is not UUID or similar to UUID, let's try with just a number
|
//it is not UUID or similar to UUID, let's try with just a number
|
||||||
if originID, err := strconv.Atoi(requestRide.Origin.ID); err != nil || originID <= 0 {
|
if originID, err := strconv.Atoi(requestRide.Origin.ID) ; err!= nil || originID <= 0 {
|
||||||
//it is not a number
|
//it is not a number
|
||||||
result = append(result, errors.ValidationError{Field: "origin.id", Message: "Step #1 - Choose a Pickup Address"})
|
result = append (result, errors.ValidationError{Field : "origin.id", Message : "Step #1 - Choose a Pickup Address"})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if !requestRide.UserConsent {
|
if !requestRide.UserConsent {
|
||||||
result = append(result, errors.ValidationError{Field: "user_consent", Message: "Step #1 - Member must consent to Terms of Use"})
|
result = append (result, errors.ValidationError{Field : "user_consent", Message : "Step #1 - Member must consent to Terms of Use"})
|
||||||
}
|
}
|
||||||
|
|
||||||
//Step #2 validation
|
//Step #2 validation
|
||||||
|
|
||||||
fmt.Println("\n\n", requestRide.Destination.ID, "\n\n")
|
fmt.Println("\n\n", requestRide.Destination.ID, "\n\n")
|
||||||
if !isMixedIDValid(requestRide.Destination.ID) {
|
if !isMixedIDValid(requestRide.Destination.ID) {
|
||||||
//it is not UUID or similar to UUID, let's try with just a number
|
//it is not UUID or similar to UUID, let's try with just a number
|
||||||
if destinationID, err := strconv.Atoi(requestRide.Destination.ID); err != nil || destinationID <= 0 {
|
if destinationID, err := strconv.Atoi(requestRide.Destination.ID) ; err!= nil || destinationID <= 0 {
|
||||||
result = append(result, errors.ValidationError{Field: "destination.id", Message: "Step #2 - Choose a Provider"})
|
result = append (result, errors.ValidationError{Field : "destination.id", Message : "Step #2 - Choose a Provider"})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Step #3 validation
|
//Step #3 validation
|
||||||
|
|
||||||
isVisitDayToday := requestRide.VisitDate.Day() == time.Now().Day() && requestRide.VisitDate.Month() == time.Now().Month() && requestRide.VisitDate.Year() == time.Now().Year()
|
isVisitDayToday := requestRide.VisitDate.Day() == time.Now().Day() && requestRide.VisitDate.Month() == time.Now().Month() && requestRide.VisitDate.Year() == time.Now().Year()
|
||||||
before8Hours := time.Now().Add(-time.Hour * time8Hours)
|
before8Hours := time.Now().Add(-time.Hour*time8Hours)
|
||||||
|
|
||||||
if requestRide.VisitDate == nil {
|
if requestRide.VisitDate == nil {
|
||||||
result = append(result, errors.ValidationError{Field: "visit_date", Message: "Step #3 - Choose a Date for the Visit"})
|
result = append (result, errors.ValidationError{Field : "visit_date", Message : "Step #3 - Choose a Date for the Visit"})
|
||||||
} else {
|
}else{
|
||||||
dayBeforeToday := time.Now().Add(-time.Hour * hoursInDay)
|
dayBeforeToday := time.Now().Add(-time.Hour*hoursInDay)
|
||||||
if requestRide.VisitDate.Before(dayBeforeToday) {
|
if requestRide.VisitDate.Before(dayBeforeToday) {
|
||||||
result = append(result, errors.ValidationError{Field: "visit_date", Message: "Step #3 - Visit cannot occur more than one day before today"})
|
result = append (result, errors.ValidationError{Field : "visit_date", Message : "Step #3 - Visit cannot occur more than one day before today"})
|
||||||
}
|
}
|
||||||
|
|
||||||
dayAfter180Days := time.Now().Add(time.Hour * hoursIn180Days)
|
dayAfter180Days := time.Now().Add(time.Hour*hoursIn180Days)
|
||||||
if requestRide.VisitDate.After(dayAfter180Days) {
|
if requestRide.VisitDate.After(dayAfter180Days) {
|
||||||
result = append(result, errors.ValidationError{Field: "visit_date", Message: "Step #3 - Visit cannot occur more than 180 days after today"})
|
result = append (result, errors.ValidationError{Field : "visit_date", Message : "Step #3 - Visit cannot occur more than 180 days after today"})
|
||||||
}
|
}
|
||||||
|
|
||||||
if requestRide.VisitTime == nil {
|
if requestRide.VisitTime == nil {
|
||||||
result = append(result, errors.ValidationError{Field: "visit_time", Message: "Step #3 - Choose a Time for the Visit"})
|
result = append (result, errors.ValidationError{Field : "visit_time", Message : "Step #3 - Choose a Time for the Visit"})
|
||||||
} else {
|
}else{
|
||||||
if isVisitDayToday && requestRide.VisitTime.Before(before8Hours) {
|
if isVisitDayToday && requestRide.VisitTime.Before(before8Hours) {
|
||||||
result = append(result, errors.ValidationError{Field: "visit_time", Message: "Step #3 - Visit is more than 8 hours in the past"})
|
result = append (result, errors.ValidationError{Field : "visit_time", Message : "Step #3 - Visit is more than 8 hours in the past"})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Step #4 validation
|
//Step #4 validation
|
||||||
|
|
||||||
timeWithDurationAndLoadingTime := requestRide.VisitTime.Add(-time.Duration(requestRide.Duration) * time.Second).Add(-loadingTime * time.Minute)
|
timeWithDurationAndLoadingTime := requestRide.VisitTime.Add(-time.Duration(requestRide.Duration)*time.Second).Add(-loadingTime*time.Minute)
|
||||||
after10Minutes := time.Now().Add(time.Minute * time10Minutes)
|
after10Minutes := time.Now().Add(time.Minute*time10Minutes)
|
||||||
|
|
||||||
isTripTypeValid := true
|
isTripTypeValid := true
|
||||||
|
|
||||||
switch requestRide.TripType.Key {
|
switch requestRide.TripType.Key {
|
||||||
case tripTypeToVisit:
|
case tripTypeToVisit:
|
||||||
if requestRide.PickupTime == nil {
|
if requestRide.PickupTime == nil {
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Choose a Pickup Time"})
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Choose a Pickup Time"})
|
||||||
} else {
|
}else{
|
||||||
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time must occur before Visit Time"})
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time must occur before Visit Time"})
|
||||||
}
|
|
||||||
|
|
||||||
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time less than required time before Visit Time"})
|
|
||||||
}
|
|
||||||
|
|
||||||
if isVisitDayToday && requestRide.PickupTime.Before(before8Hours) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Visit cannot occour in the past"})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case tripTypeFromVisit:
|
|
||||||
if requestRide.PickupTime == nil {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Choose a Pickup Time"})
|
|
||||||
} else {
|
|
||||||
timeWithMinimumPickupTime := time.Now().Add(minimumPickupTime * time.Minute)
|
|
||||||
if isVisitDayToday && requestRide.PickupTime.Before(timeWithMinimumPickupTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: fmt.Sprint("Step #4 - Time must be more than %d minutes from now", minimumPickupTime)})
|
|
||||||
}
|
|
||||||
|
|
||||||
if requestRide.PickupTime.Before(*requestRide.VisitTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time less than required time after Visit Time"})
|
|
||||||
}
|
|
||||||
|
|
||||||
timeWithMinimumLoadTime := time.Now().Add(minimumLoadTime * time.Minute)
|
|
||||||
if requestRide.PickupTime.Before(timeWithMinimumLoadTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time less than Minimum Load Time before Visit Time"})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case tripTypeFromVisitWillCall:
|
|
||||||
//no special validation for this case
|
|
||||||
|
|
||||||
case tripTypeRoundTrip:
|
|
||||||
if requestRide.PickupTime == nil {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Choose a Pickup Time"})
|
|
||||||
} else {
|
|
||||||
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time must occur before Visit Time"})
|
|
||||||
}
|
|
||||||
|
|
||||||
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time less than required time before Visit Time"})
|
|
||||||
}
|
|
||||||
|
|
||||||
if isVisitDayToday && requestRide.PickupTime.Before(after10Minutes) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time must be at least 10 minutes from now"})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if requestRide.ReturnTime == nil {
|
|
||||||
result = append(result, errors.ValidationError{Field: "return_time", Message: "Step #4 - Choose a Pickup Time"})
|
|
||||||
} else {
|
|
||||||
if isVisitDayToday {
|
|
||||||
if requestRide.ReturnTime.Before(before8Hours) {
|
|
||||||
result = append(result, errors.ValidationError{Field: "return_time", Message: "Step #4 - Return Time is more than 8 hours after Visit Time"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if requestRide.ReturnTime.Before(after10Minutes) {
|
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
||||||
result = append(result, errors.ValidationError{Field: "return_time", Message: "Step #4 - Return Time must be at least 10 minutes from now"})
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time less than required time before Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if isVisitDayToday && requestRide.PickupTime.Before(before8Hours) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Visit cannot occour in the past"})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
case tripTypeRountTripWillCall:
|
case tripTypeFromVisit :
|
||||||
if requestRide.PickupTime == nil {
|
if requestRide.PickupTime == nil {
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Choose a Pickup Time"})
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Choose a Pickup Time"})
|
||||||
} else {
|
}else{
|
||||||
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
timeWithMinimumPickupTime := time.Now().Add(minimumPickupTime*time.Minute)
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time must occur before Visit Time"})
|
if isVisitDayToday && requestRide.PickupTime.Before(timeWithMinimumPickupTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : fmt.Sprint("Step #4 - Time must be more than %d minutes from now",minimumPickupTime)})
|
||||||
|
}
|
||||||
|
|
||||||
|
if requestRide.PickupTime.Before(*requestRide.VisitTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time less than required time after Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
timeWithMinimumLoadTime := time.Now().Add(minimumLoadTime*time.Minute)
|
||||||
|
if requestRide.PickupTime.Before(timeWithMinimumLoadTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time less than Minimum Load Time before Visit Time"})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
case tripTypeFromVisitWillCall:
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Pickup Time less than required time after Visit Time"})
|
//no special validation for this case
|
||||||
|
|
||||||
|
case tripTypeRoundTrip:
|
||||||
|
if requestRide.PickupTime == nil {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Choose a Pickup Time"})
|
||||||
|
}else{
|
||||||
|
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time must occur before Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time less than required time before Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if isVisitDayToday && requestRide.PickupTime.Before(after10Minutes) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time must be at least 10 minutes from now"})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if isVisitDayToday && requestRide.PickupTime.Before(before8Hours) {
|
if requestRide.ReturnTime == nil {
|
||||||
result = append(result, errors.ValidationError{Field: "pickup_time", Message: "Step #4 - Visit cannot occur in the past "})
|
result = append (result, errors.ValidationError{Field : "return_time", Message : "Step #4 - Choose a Pickup Time"})
|
||||||
|
}else{
|
||||||
|
if isVisitDayToday {
|
||||||
|
if requestRide.ReturnTime.Before(before8Hours) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "return_time", Message : "Step #4 - Return Time is more than 8 hours after Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if requestRide.ReturnTime.Before(after10Minutes) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "return_time", Message : "Step #4 - Return Time must be at least 10 minutes from now"})
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
case tripTypeRountTripWillCall:
|
||||||
isTripTypeValid = false
|
if requestRide.PickupTime == nil {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Choose a Pickup Time"})
|
||||||
|
}else{
|
||||||
|
if requestRide.PickupTime.After(*requestRide.VisitTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time must occur before Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if requestRide.PickupTime.After(timeWithDurationAndLoadingTime) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Pickup Time less than required time after Visit Time"})
|
||||||
|
}
|
||||||
|
|
||||||
|
if isVisitDayToday && requestRide.PickupTime.Before(before8Hours) {
|
||||||
|
result = append (result, errors.ValidationError{Field : "pickup_time", Message : "Step #4 - Visit cannot occur in the past "})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
isTripTypeValid = false
|
||||||
}
|
}
|
||||||
|
|
||||||
if !isTripTypeValid {
|
if !isTripTypeValid {
|
||||||
result = append(result, errors.ValidationError{Field: "trip_type.key", Message: "Step #4 - Choose a Trip Type"})
|
result = append (result, errors.ValidationError{Field : "trip_type.key", Message : "Step #4 - Choose a Trip Type"})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user