git: 6cabeb169ef4 - stable/13 - nfsd: Do not exempt NFSv3 Fsinfo from the TLS check
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 13 Apr 2022 14:58:30 UTC
The branch stable/13 has been updated by rmacklem: URL: https://cgit.FreeBSD.org/src/commit/?id=6cabeb169ef4d5cc4f824a54129186d3fdc61626 commit 6cabeb169ef4d5cc4f824a54129186d3fdc61626 Author: Rick Macklem <rmacklem@FreeBSD.org> AuthorDate: 2022-03-10 00:52:42 +0000 Commit: Rick Macklem <rmacklem@FreeBSD.org> CommitDate: 2022-04-13 14:55:45 +0000 nfsd: Do not exempt NFSv3 Fsinfo from the TLS check The Fsinfo RPC is exempt from the check for Kerberized NFS being required, as recommended by RFC2623. However, there is no reason to exempt Fsinfo from the requirement to use TLS. This patch fixes the code so that the exemption only applies to Kerberized NFS and not NFS-over-TLS. This only affects NFS-over-TLS for an NFSv3 mount when it is required, but the client does not do so. (cherry picked from commit 3fc3fe90915f02e25b4f1d5070e8e01e465e873d) --- sys/fs/nfsserver/nfs_nfsdport.c | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/sys/fs/nfsserver/nfs_nfsdport.c b/sys/fs/nfsserver/nfs_nfsdport.c index d63a788177b0..70243fa7ed2f 100644 --- a/sys/fs/nfsserver/nfs_nfsdport.c +++ b/sys/fs/nfsserver/nfs_nfsdport.c @@ -4053,16 +4053,11 @@ nfsvno_testexp(struct nfsrv_descript *nd, struct nfsexstuff *exp) { int i; - /* - * Allow NFSv3 Fsinfo per RFC2623. - */ - if (((nd->nd_flag & ND_NFSV4) != 0 || - nd->nd_procnum != NFSPROC_FSINFO) && - ((NFSVNO_EXTLS(exp) && (nd->nd_flag & ND_TLS) == 0) || - (NFSVNO_EXTLSCERT(exp) && - (nd->nd_flag & ND_TLSCERT) == 0) || - (NFSVNO_EXTLSCERTUSER(exp) && - (nd->nd_flag & ND_TLSCERTUSER) == 0))) { + if ((NFSVNO_EXTLS(exp) && (nd->nd_flag & ND_TLS) == 0) || + (NFSVNO_EXTLSCERT(exp) && + (nd->nd_flag & ND_TLSCERT) == 0) || + (NFSVNO_EXTLSCERTUSER(exp) && + (nd->nd_flag & ND_TLSCERTUSER) == 0)) { if ((nd->nd_flag & ND_NFSV4) != 0) return (NFSERR_WRONGSEC); #ifdef notnow @@ -4076,6 +4071,13 @@ nfsvno_testexp(struct nfsrv_descript *nd, struct nfsexstuff *exp) return (NFSERR_AUTHERR | AUTH_TOOWEAK); } + /* + * RFC2623 suggests that the NFSv3 Fsinfo RPC be allowed to use + * AUTH_NONE or AUTH_SYS for file systems requiring RPCSEC_GSS. + */ + if ((nd->nd_flag & ND_NFSV3) != 0 && nd->nd_procnum == NFSPROC_FSINFO) + return (0); + /* * This seems odd, but allow the case where the security flavor * list is empty. This happens when NFSv4 is traversing non-exported @@ -6721,18 +6723,15 @@ nfsm_trimtrailing(struct nfsrv_descript *nd, struct mbuf *mb, char *bpos, * Check to see if a put file handle operation should test for * NFSERR_WRONGSEC, although NFSv3 actually returns NFSERR_AUTHERR. * When Open is the next operation, NFSERR_WRONGSEC cannot be - * replied for the Open cases that use a component. Thia can + * replied for the Open cases that use a component. This can * be identified by the fact that the file handle's type is VDIR. */ bool nfsrv_checkwrongsec(struct nfsrv_descript *nd, int nextop, enum vtype vtyp) { - if ((nd->nd_flag & ND_NFSV4) == 0) { - if (nd->nd_procnum == NFSPROC_FSINFO) - return (false); + if ((nd->nd_flag & ND_NFSV4) == 0) return (true); - } if ((nd->nd_flag & ND_LASTOP) != 0) return (false);