Skip to content

Commit

Permalink
ncm-metaconfig/ganesha: Use choice type where possible
Browse files Browse the repository at this point in the history
Also use built-in validation for the long "ganesha_nfs_protocol".
  • Loading branch information
jrha committed Dec 13, 2024
1 parent ca08171 commit daf25d8
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 20 deletions.
6 changes: 3 additions & 3 deletions ncm-metaconfig/src/main/metaconfig/ganesha/pan/schema.pan
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@ declaration template metaconfig/ganesha/schema;

# the defaults are based on the GPFS FSAL

type ganesha_nfs_protocol = long with SELF == 2 || SELF == 3 || SELF == 4;
type ganesha_transport_protocol = string with SELF == 'TCP' || SELF == 'UDP';
type ganesha_sec_type = string with SELF == 'sys' || SELF == 'krb5' || SELF == 'krb5i' || SELF == 'krb5p';
type ganesha_nfs_protocol = long(2..4);
type ganesha_transport_protocol = choice('TCP', 'UDP');
type ganesha_sec_type = choice('sys', 'krb5', 'krb5i', 'krb5p');

type ganesha_export_client = {
"Root_Access" ? string[] # Grant root access to thoses nodes, networks and @netgroups. A hostname can contain wildcards (*?).
Expand Down
70 changes: 53 additions & 17 deletions ncm-metaconfig/src/main/metaconfig/ganesha/pan/schema_v2.pan
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ type ganesha_v2_export_FSAL = {
#"FSAL" ? ganesha_v2_export_FSAL
#FSAL_VFS
"pnfs" ? boolean = false
"fsid_type" ? string with match(SELF, '^(None|One64|Major64|Two64|uuid|Two32|Dev|Device)$')
"fsid_type" ? choice('None', 'One64', 'Major64', 'Two64', 'uuid', 'Two32', 'Dev', 'Device')
#FSAL_GLUSTER
"glfs_log" ? string = "/tmp/gfapi.log"
"hostname" ? string # Mandatory
Expand All @@ -71,26 +71,40 @@ type ganesha_v2_export_FSAL = {
"PNFS" ? ganesha_v2_export_FSAL_PNFS
};

type ganesha_v2_protocol = string with match(SELF, '^((NFS)?[vV]?[34]|9P)$');
type ganesha_v2_SecType = string with match(SELF, '^(none|sys|krb5[ip]?)$');
type ganesha_v2_Transports = string with match(SELF, '^(UDP|TCP)$');
type ganesha_v2_protocol = choice('3', '4', 'NFS3', 'NFS4', 'V3', 'V4', 'NFSv3', 'NFSv4', '9P');
type ganesha_v2_SecType = choice('none', 'sys', 'krb5', 'krb5i', 'krb5p');
type ganesha_v2_Transports = choice('UDP', 'TCP');
type ganesha_v2_delegations = choice('None', 'read', 'write', 'readwrite', 'r', 'w', 'rw');

@{ Ganesha Export Permissions for EXPORT_DEFAULLTS, EXPORT and CLIENT sections @}
type ganesha_v2_export_permissions = {
"Access_Type" ? string = 'None' with match(SELF, '^(None|RW|RO|MDONLY|MDONLY_RO)$')
"Access_Type" ? choice('None', 'RW', 'RO', 'MDONLY', 'MDONLY_RO') = 'None'
"Anonymous_gid" ? long = -2
"Anonymous_uid" ? long = -2
"Delegations" ? string with match(SELF, '^(None|read|write|readwrite|r|w|rw)$')
"Delegations" ? ganesha_v2_delegations
"Disable_ACL" ? boolean = false
"DisableReaddirPlus" ? boolean = false
"Manage_Gids" ? boolean = false
"NFS_Commit" ? boolean = false
"PrivilegedPort" ? boolean = false
"Protocols" ? ganesha_v2_protocol[] = list('3', '4', '9P')
"SecType" ? ganesha_v2_SecType[] = list('none', 'sys')
"Squash" ? string = "root_squash" with match(SELF,
'^((root|all)(_?squash)?|no_root_squash|none|noidsquash)$'
)
"Squash" ? choice(
'root',
'root_squash',
'rootsquash',
'rootid',
'root_id_squash',
'rootidsquash',
'all',
'all_squash',
'allsquash',
'all_anomnymous',
'allanonymous',
'no_root_squash',
'none',
'noidsquash'
) = "root_squash"
"Transports" ? ganesha_v2_Transports[] = list('UDP', 'TCP')
"Trust_Readdir_Negative_Cache" ? boolean = false
};
Expand Down Expand Up @@ -130,8 +144,19 @@ type ganesha_v2_exports = {
"UseCookieVerifier" ? boolean = true
};

type ganesha_v2_log_level = string with match(SELF,
'^(NULL|FATAL|MAJ|CRIT|WARN|EVENT|INFO|DEBUG|MID_DEBUG|M_DBG|FULL_DEBUG|F_DBG)$'
type ganesha_v2_log_level = choice(
'NULL',
'FATAL',
'MAJ',
'CRIT',
'WARN',
'EVENT',
'INFO',
'DEBUG',
'MID_DEBUG',
'M_DBG',
'FULL_DEBUG',
'F_DBG'
);

@{ Check for valid Ganesha Log Component names @}
Expand All @@ -146,8 +171,19 @@ function is_ganesha_v2_log_Components = {
};
type ganesha_v2_log_Components = ganesha_v2_log_level{} with is_ganesha_v2_log_Components(SELF);

type ganesha_v2_log_time_format = string with match(SELF,
'^(ganesha|true|local|8601|ISO-8601|ISO 8601|ISO|syslog|syslog_usec|false|none|user_defined)$'
type ganesha_v2_log_time_format = choice(
'ganesha',
'true',
'local',
'8601',
'ISO-8601',
'ISO 8601',
'ISO',
'syslog',
'syslog_usec',
'false',
'none',
'user_defined'
);

@{ Ganesha Log Format subsection @}
Expand All @@ -173,8 +209,8 @@ type ganesha_v2_log_Format = {
@{ Ganesha Log Facility subsection @}
type ganesha_v2_log_Facility = {
"destination" : string
"enable" ? string = 'idle' with match(SELF, '^(idle|active|default)$')
"headers" ? string = 'all' with match(SELF, '^(none|component|all)$')
"enable" ? choice('idle', 'active', 'default') = 'idle'
"headers" ? choice('none', 'component', 'all') = 'all'
"max_level" ? ganesha_v2_log_level = 'FULL_DEBUG'
"name" ? string
};
Expand Down Expand Up @@ -283,7 +319,7 @@ type ganesha_v2_proxy_remote_server = {
"RPC_Client_Timeout" ? long(0..) = 60
"Remote_PrincipalName" ? string
"Retry_SleepTime" ? long(0..) = 10
"Sec_Type" ? string = 'krb5' with match(SELF, '^krb5[ip]?$')
"Sec_Type" ? ganesha_v2_SecType
"Srv_Addr" ? type_ip = "127.0.0.1"
"Use_Privileged_Client_Port" ? boolean = false
};
Expand Down Expand Up @@ -314,7 +350,7 @@ type ganesha_v2_proxy = {
@{ Ganesha GPFS section @}
type ganesha_v2_GPFS = {
include ganesha_v2_fsalsettings_all
"Delegations" ? string with match(SELF, '^(None|read|write|readwrite|r|w|rw)$')
"Delegations" ? ganesha_v2_delegations
"fsal_grace" ? boolean = false
"fsal_trace" ? boolean = true
"pnfs_file" ? boolean = false
Expand Down

0 comments on commit daf25d8

Please sign in to comment.