Skip to content

touchlab/Blackstone-KtValidate-Fork

 
 

Repository files navigation

KtValidate

License: MIT
A validation library for Kotlin Multiplatform. This is extreamly basic at this point. I just have 3 rules, but it is a good starting point for a DSL based validation system that can easily be expanded on.

How to Add KtValidate to Your Project

Add the repository to your project's build.gradle.kts. I'm using kotlin for my gradle syntax, but groovy will be pretty similar if that's what you use

repositories {
    ...
    maven("https://repos.awhb.dev")
    ...
}

add following in your commonMain source set

sourceSets {
  val commonMain by getting {
    dependencies {
      ...
      implementation("com.blackstone:KtValidate:0.1.0")
        ...
    }
  }
}
  ...

Example usage

        val validate = Validate("aaaa") {
            fieldName = "Password"
            +Max(10)
            +Min(0, "Custome message here")
        }
        
        validate.isValid // true
        // if it's not valid validate.messages will have messages about what did not pass. 

To add a new custom validator simply implement the Rule interface and you should now be able to now do +CustomeRule or whatever you named your rule.

Feel free to submit a PR if there's not something in here that you want.

Then add this:

dependencies {
	implementation 'com.github.alexwhb:KtValidate:0.1.0'
}

About

A validation library for Kotlin Multiplatform

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Kotlin 100.0%