mirror of
				https://git.dn42.dev/dn42/registry.git
				synced 2025-10-26 09:15:10 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| schema:             SCHEMA-SCHEMA
 | |
| ref:                dn42.schema
 | |
| key:                schema   required  single    primary schema > [name]
 | |
| key:                ref      required  single    > [schema]
 | |
| key:                key      required  multiple  > [key-name]
 | |
|                     {required|optional|recommend|deprecate}
 | |
|                     {single|multiple} {primary|} {schema|}
 | |
|                     lookup=str '>' [spec]...
 | |
| key:                mnt-by   required  multiple    lookup=dn42.mntner > [mntner]
 | |
| key:                remarks  optional  multiple  > [text]...
 | |
| mnt-by:             DN42-MNT
 | |
| remarks:            # option descriptions
 | |
|                     Attribute names must match /[a-zA-Z]([a-zA-Z0-9_\-]*[a-zA-Z0-9])?/.
 | |
| +
 | |
|                     required
 | |
|                     :    object required to have at least one
 | |
|                     optional
 | |
|                     :    object not required to have at least one
 | |
| +
 | |
|                     single
 | |
|                     :    only one of this type allowed
 | |
|                     multiple
 | |
|                     :    more than one of this type allowed
 | |
| +
 | |
|                     primary
 | |
|                     :    use field as lookup key for lookup
 | |
|                     * only one allowed per schema
 | |
|                     * does not allow newlines
 | |
| +
 | |
|                     schema
 | |
|                     :    use field name as the name of the schema
 | |
|                     * only one allowed per schema
 | |
|                     * does not allow newlines
 | |
| +
 | |
|                     lookup
 | |
|                     :    schema match to use for related record
 | |
| +
 | |
|                     \> option specs
 | |
|                     :    defines the option specifications for the key.
 | |
|                     * must come last in option list
 | |
| +
 | |
|                     [label] string value. A positional string argument required.
 | |
|                     Text inside brackets represent a label for the string and must match the same rules as attribute names.
 | |
|                     If follwed by '...' values are gathered as an array.
 | |
| +
 | |
|                     {enum1|enum2|} enumeration. One option in pipe('|') deliniation is allowed.
 | |
|                     If there is a trailing pipe it means the enum is optional. Enum values must match the same rules as attribute names.
 | |
| +
 | |
|                     label=str keyword argument. Label for value with type 'str', 'int', or 'decimal'. The label must match the same rules as attribute names.
 | |
| +
 | |
|                     'literal' Literal value. literal text value which must not contain any whitespace or single quotes.
 | 
