mirror of
https://github.com/winfsp/winfsp.git
synced 2025-04-23 08:53:01 -05:00
sys: FspUnicodePathIsValid()
This commit is contained in:
parent
cc19ddcd92
commit
5d26211c38
@ -338,6 +338,7 @@ ULONG FspHashMixPointer(PVOID Pointer)
|
|||||||
/* utility */
|
/* utility */
|
||||||
PVOID FspAllocMustSucceed(SIZE_T Size);
|
PVOID FspAllocMustSucceed(SIZE_T Size);
|
||||||
PVOID FspAllocateIrpMustSucceed(CCHAR StackSize);
|
PVOID FspAllocateIrpMustSucceed(CCHAR StackSize);
|
||||||
|
BOOLEAN FspUnicodePathIsValid(PUNICODE_STRING Path, BOOLEAN AllowStreams);
|
||||||
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix);
|
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix);
|
||||||
NTSTATUS FspCreateGuid(GUID *Guid);
|
NTSTATUS FspCreateGuid(GUID *Guid);
|
||||||
NTSTATUS FspCcSetFileSizes(PFILE_OBJECT FileObject, PCC_FILE_SIZES FileSizes);
|
NTSTATUS FspCcSetFileSizes(PFILE_OBJECT FileObject, PCC_FILE_SIZES FileSizes);
|
||||||
|
@ -809,6 +809,9 @@ static NTSTATUS FspFsvolSetRenameInformation(
|
|||||||
if (FileNode->IsRootDirectory)
|
if (FileNode->IsRootDirectory)
|
||||||
/* cannot rename root directory */
|
/* cannot rename root directory */
|
||||||
return STATUS_INVALID_PARAMETER;
|
return STATUS_INVALID_PARAMETER;
|
||||||
|
if (!FspUnicodePathIsValid(&FileNode->FileName, FALSE))
|
||||||
|
/* cannot rename streams (WinFsp limitation) */
|
||||||
|
return STATUS_INVALID_PARAMETER;
|
||||||
|
|
||||||
if (0 != TargetFileNode)
|
if (0 != TargetFileNode)
|
||||||
{
|
{
|
||||||
@ -831,6 +834,13 @@ static NTSTATUS FspFsvolSetRenameInformation(
|
|||||||
if (L'\\' == Suffix.Buffer[0])
|
if (L'\\' == Suffix.Buffer[0])
|
||||||
FspUnicodePathSuffix(&Suffix, &NewFileName, &Suffix);
|
FspUnicodePathSuffix(&Suffix, &NewFileName, &Suffix);
|
||||||
|
|
||||||
|
if (!FspUnicodePathIsValid(&Remain, FALSE) || !FspUnicodePathIsValid(&Suffix, FALSE))
|
||||||
|
{
|
||||||
|
/* cannot rename streams (WinFsp limitation) */
|
||||||
|
Result = STATUS_INVALID_PARAMETER;
|
||||||
|
goto unlock_exit;
|
||||||
|
}
|
||||||
|
|
||||||
AppendBackslash = sizeof(WCHAR) < Remain.Length;
|
AppendBackslash = sizeof(WCHAR) < Remain.Length;
|
||||||
NewFileName.Length = NewFileName.MaximumLength =
|
NewFileName.Length = NewFileName.MaximumLength =
|
||||||
Remain.Length + AppendBackslash * sizeof(WCHAR) + Suffix.Length;
|
Remain.Length + AppendBackslash * sizeof(WCHAR) + Suffix.Length;
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
#include <sys/driver.h>
|
#include <sys/driver.h>
|
||||||
|
|
||||||
|
BOOLEAN FspUnicodePathIsValid(PUNICODE_STRING Path, BOOLEAN AllowStreams);
|
||||||
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix);
|
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix);
|
||||||
NTSTATUS FspCreateGuid(GUID *Guid);
|
NTSTATUS FspCreateGuid(GUID *Guid);
|
||||||
VOID FspInitializeSynchronousWorkItem(FSP_SYNCHRONOUS_WORK_ITEM *SynchronousWorkItem,
|
VOID FspInitializeSynchronousWorkItem(FSP_SYNCHRONOUS_WORK_ITEM *SynchronousWorkItem,
|
||||||
@ -18,6 +19,7 @@ VOID FspQueueDelayedWorkItem(FSP_DELAYED_WORK_ITEM *DelayedWorkItem, LARGE_INTEG
|
|||||||
static KDEFERRED_ROUTINE FspQueueDelayedWorkItemDPC;
|
static KDEFERRED_ROUTINE FspQueueDelayedWorkItemDPC;
|
||||||
|
|
||||||
#ifdef ALLOC_PRAGMA
|
#ifdef ALLOC_PRAGMA
|
||||||
|
#pragma alloc_text(PAGE, FspUnicodePathIsValid)
|
||||||
#pragma alloc_text(PAGE, FspUnicodePathSuffix)
|
#pragma alloc_text(PAGE, FspUnicodePathSuffix)
|
||||||
#pragma alloc_text(PAGE, FspCreateGuid)
|
#pragma alloc_text(PAGE, FspCreateGuid)
|
||||||
#pragma alloc_text(PAGE, FspInitializeSynchronousWorkItem)
|
#pragma alloc_text(PAGE, FspInitializeSynchronousWorkItem)
|
||||||
@ -69,6 +71,31 @@ PVOID FspAllocateIrpMustSucceed(CCHAR StackSize)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOLEAN FspUnicodePathIsValid(PUNICODE_STRING Path, BOOLEAN AllowStreams)
|
||||||
|
{
|
||||||
|
PAGED_CODE();
|
||||||
|
|
||||||
|
PWSTR PathBgn, PathEnd, PathPtr;
|
||||||
|
|
||||||
|
PathBgn = Path->Buffer;
|
||||||
|
PathEnd = (PWSTR)((PUINT8)PathBgn + Path->Length);
|
||||||
|
PathPtr = PathBgn;
|
||||||
|
|
||||||
|
while (PathEnd > PathPtr)
|
||||||
|
if (L'\\' == *PathPtr)
|
||||||
|
{
|
||||||
|
PathPtr++;
|
||||||
|
if (PathEnd > PathPtr && L'\\' == *PathPtr)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
else if (!AllowStreams && L':' == *PathPtr)
|
||||||
|
return FALSE;
|
||||||
|
else
|
||||||
|
PathPtr++;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix)
|
VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE_STRING Suffix)
|
||||||
{
|
{
|
||||||
PAGED_CODE();
|
PAGED_CODE();
|
||||||
@ -86,7 +113,7 @@ VOID FspUnicodePathSuffix(PUNICODE_STRING Path, PUNICODE_STRING Remain, PUNICODE
|
|||||||
if (L'\\' == *PathPtr)
|
if (L'\\' == *PathPtr)
|
||||||
{
|
{
|
||||||
RemainEnd = PathPtr++;
|
RemainEnd = PathPtr++;
|
||||||
for (; L'\\' == *PathPtr; PathPtr++)
|
for (; PathEnd > PathPtr && L'\\' == *PathPtr; PathPtr++)
|
||||||
;
|
;
|
||||||
SuffixBgn = PathPtr;
|
SuffixBgn = PathPtr;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user