-
Notifications
You must be signed in to change notification settings - Fork 174
Expand file tree
/
Copy pathuuid.py
More file actions
43 lines (34 loc) · 1.07 KB
/
uuid.py
File metadata and controls
43 lines (34 loc) · 1.07 KB
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
"""UUID."""
# standard
import re
from typing import Union
from uuid import UUID
# local
from .utils import validator
@validator
def uuid(value: Union[str, UUID], /):
"""Return whether or not given value is a valid UUID-v4 string.
This validator is based on [WTForms UUID validator][1].
[1]: https://github.com/wtforms/wtforms/blob/master/src/wtforms/validators.py#L539
Examples:
>>> uuid('2bc1c94f-0deb-43e9-92a1-4775189ec9f8')
True
>>> uuid('2bc1c94f 0deb-43e9-92a1-4775189ec9f8')
ValidationError(func=uuid, args={'value': '2bc1c94f 0deb-43e9-92a1-4775189ec9f8'})
Args:
value:
UUID string or object to validate.
Returns:
(Literal[True]): If `value` is a valid UUID.
(ValidationError): If `value` is an invalid UUID.
"""
if not value:
return False
if isinstance(value, UUID):
return True
try:
return UUID(value) or re.match(
r"^[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}$", value
)
except ValueError:
return False