Skip to content

Minimal + composable validations in Swift. BYOBusiness Logic

License

Notifications You must be signed in to change notification settings

sweetmandm/Validate

Repository files navigation

Validate

Build Status

Inspired by Result, but a little more specialized for building data and user input validations.

Create a validation:

func validateIsOn(toggle: UISwitch) -> ValidationResult<String, OnField> {
    switch toggle.isOn {
    case true:
        return .valid("The switch is A-OK")
    case false:
        return .invalid(OnField(reason: "The switch should be on.", field: toggle))
    }
}

Use the validation:

let toggle = UISwitch()
let toggleMessageLabel = UILabel()

func updateToggleMessage() {
    switch validateIsOn(toggle: toggle) {
    case .valid(let message):
        toggleMessageLabel.text = message
    case .invalid(let error):
        toggleMessageLabel.text = error.reason
    }
}

Compose multiple results into a single validation:

struct Inputs {
  let message: String
  let value: Int
}

let textField = UITextField()

func validateIntegerInput() -> ValidationResult<Int, OnField> {
    guard let int = Int(textField.text ?? "") else {
        return .invalid(OnField(reason: "Please input an integer.", field: textField))
    }
    return .valid(int)
}

func validateInputs() -> ValidationResult<Inputs, OnMultiple> {
  let messageInput = validateSwitchIsOn()
  let integerInput = validateIntegerInput()

  switch (messageInput, integerInput) {
    case (.valid(let message), .valid(let value)):
      return .valid(Inputs(message: message,  value: value))
    default:
      return .invalid(OnMultiple(integerInput.errors + messageInput.errors))
  }
}

About

Minimal + composable validations in Swift. BYOBusiness Logic

Resources

License

Stars

Watchers

Forks

Packages

No packages published