cedar_policy/api/err/
validation_warnings.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
 * Copyright Cedar Contributors
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

use miette::Diagnostic;
use ref_cast::RefCast;
use thiserror::Error;

use crate::PolicyId;

// Required for doc link to `ValidationWarning` without qualifying it with
// `crate`, but not used otherwise, so non-doc builds warned about unused
// imports.
#[cfg(doc)]
use crate::ValidationWarning;

// Generates a public struct wrapping a core validator warning struct. The core
// and external struct will have exactly the same name. This name _must_ be the
// same as the name of the corresponding `ValidationWarning` variant in `err.rs`
// (`cargo doc` will fail otherwise). This macro generates a basic doc-string
// linking back to the `ValidationWarning` enum variant where the primary
// documentation should be written.
macro_rules! wrap_core_warning {
    ($s:ident) => {
        #[derive(Debug, Clone, Error, Diagnostic)]
        #[error(transparent)]
        #[diagnostic(transparent)]
        #[doc=concat!("Structure containing details about a [`ValidationWarning::", stringify!($s), "`].")]
        pub struct $s(cedar_policy_validator::validation_warnings::$s);

        impl $s {
            /// Access the [`PolicyId`] for the policy where this warning was found.
            pub fn policy_id(&self) -> &PolicyId {
                PolicyId::ref_cast(&self.0.policy_id)
            }
        }

        #[doc(hidden)]
        impl From<cedar_policy_validator::validation_warnings::$s> for $s {
            fn from(e: cedar_policy_validator::validation_warnings::$s) -> Self {
                Self(e)
            }
        }
    };
}

wrap_core_warning!(MixedScriptString);
wrap_core_warning!(BidiCharsInString);
wrap_core_warning!(BidiCharsInIdentifier);
wrap_core_warning!(MixedScriptIdentifier);
wrap_core_warning!(ConfusableIdentifier);
wrap_core_warning!(ImpossiblePolicy);