valico/json_schema/validators/
unique_items.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
use serde_json::{Value};

use super::super::errors;
use super::super::scope;

#[allow(missing_copy_implementations)]
pub struct UniqueItems;
impl super::Validator for UniqueItems {
    fn validate(&self, val: &Value, path: &str, _scope: &scope::Scope) -> super::ValidationState {
        let array = nonstrict_process!(val.as_array(), path);

        // TODO we need some quicker algorithm for this

        let mut unique = true;
        'main: for (idx, item_i) in array.iter().enumerate() {
            for item_j in array[..idx].iter() {
                if item_i == item_j {
                    unique = false;
                    break 'main;
                }
            }

            for item_j in array[(idx + 1)..].iter() {
                if item_i == item_j {
                    unique = false;
                    break 'main;
                }
            }
        }

        if unique {
            super::ValidationState::new()
        } else {
            val_error!(
                errors::UniqueItems {
                    path: path.to_string()
                }
            )
        }
    }
}