From f549911027417cdb4fbacfc8deaa8bd664d1651f Mon Sep 17 00:00:00 2001 From: Jeffrey Altman Date: Fri, 13 Jan 2012 23:57:10 -0500 Subject: [PATCH] Windows: AFSParseName edge cases If the input path is \afs\ behave as if the path is \afs. If the input path is \afs\*\ detect the wildcard and return STATUS_OBJECT_NAME_INVALID. Change-Id: I0ef4f30fb3b6245a52160b5e7f9233bc5f599485 Reviewed-on: http://gerrit.openafs.org/6553 Reviewed-by: Peter Scott Tested-by: BuildBot Reviewed-by: Jeffrey Altman Tested-by: Jeffrey Altman --- .../afsrdr/kernel/lib/AFSNameSupport.cpp | 27 ++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/src/WINNT/afsrdr/kernel/lib/AFSNameSupport.cpp b/src/WINNT/afsrdr/kernel/lib/AFSNameSupport.cpp index 2adf59ee6b..1c8b2610ce 100644 --- a/src/WINNT/afsrdr/kernel/lib/AFSNameSupport.cpp +++ b/src/WINNT/afsrdr/kernel/lib/AFSNameSupport.cpp @@ -3097,6 +3097,18 @@ AFSParseName( IN PIRP Irp, } } + if( FsRtlDoesNameContainWildCards( &uniFullName)) + { + + AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING, + AFS_TRACE_LEVEL_ERROR, + "AFSParseName (%08lX) Component %wZ contains wild cards\n", + Irp, + &uniFullName); + + try_return( ntStatus = STATUS_OBJECT_NAME_INVALID); + } + AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING, AFS_TRACE_LEVEL_VERBOSE_2, "AFSParseName (%08lX) Processing full name %wZ\n", @@ -3246,11 +3258,24 @@ AFSParseName( IN PIRP Irp, &uniComponentName, &uniRemainingPath); + if( FsRtlDoesNameContainWildCards( &uniFullName)) + { + + AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING, + AFS_TRACE_LEVEL_ERROR, + "AFSParseName (%08lX) Component %wZ contains wild cards\n", + Irp, + &uniComponentName); + + try_return( ntStatus = STATUS_OBJECT_NAME_INVALID); + } + // // If this is the ALL access then perform some additional processing // - if( RtlCompareUnicodeString( &uniComponentName, + if( uniComponentName.Length == 0 || + RtlCompareUnicodeString( &uniComponentName, &AFSGlobalRootName, TRUE) == 0) {