2015-12-14 14:17:18 +02:00
|
|
|
(ns uxbox.schema
|
2015-12-14 20:31:21 +02:00
|
|
|
(:refer-clojure :exclude [keyword uuid])
|
2015-12-14 14:17:18 +02:00
|
|
|
(:require [bouncer.core :as b]
|
|
|
|
[bouncer.validators :as v]))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Validators
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
2015-12-14 20:31:21 +02:00
|
|
|
(v/defvalidator keyword
|
2015-12-14 14:17:18 +02:00
|
|
|
"Validates maybe-an-int is a valid integer.
|
|
|
|
For use with validation functions such as `validate` or `valid?`"
|
|
|
|
{:default-message-format "%s must be a keyword"}
|
|
|
|
[v]
|
|
|
|
(cljs.core/keyword? v))
|
|
|
|
|
2015-12-14 20:31:21 +02:00
|
|
|
|
|
|
|
(v/defvalidator uuid
|
|
|
|
"Validates maybe-an-int is a valid integer.
|
|
|
|
For use with validation functions such as `validate` or `valid?`"
|
2015-12-24 19:33:53 +02:00
|
|
|
{:default-message-format "%s must be a uuid instance"
|
|
|
|
:optinal true}
|
2015-12-14 20:31:21 +02:00
|
|
|
[v]
|
|
|
|
(instance? cljs.core.UUID v))
|
|
|
|
|
2015-12-24 19:33:53 +02:00
|
|
|
(v/defvalidator color
|
|
|
|
"Validates if a string is a valid color."
|
|
|
|
{:default-message-format "%s must be a valid hex color"
|
|
|
|
:optional true}
|
|
|
|
[v]
|
|
|
|
(not (nil? (re-find #"^#[0-9A-Fa-f]{6}$" v))))
|
|
|
|
|
2015-12-14 14:17:18 +02:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Public Api
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(defn validate
|
|
|
|
([schema] #(validate schema %))
|
|
|
|
([schema data] (first (b/validate data schema))))
|
|
|
|
|
|
|
|
(defn validate!
|
|
|
|
([schema] #(validate! schema %))
|
|
|
|
([schema data]
|
|
|
|
(when-let [errors (validate schema data)]
|
|
|
|
(throw (ex-info "Invalid data" errors)))))
|