2006-07-01 02:14:54 +08:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: GPL - See COPYING in the top level directory
|
2015-10-04 19:54:25 +08:00
|
|
|
* FILE: ntoskrnl/io/iomgr/symlink.c
|
2006-07-01 02:14:54 +08:00
|
|
|
* PURPOSE: I/O Wrappers for Symbolic Links
|
|
|
|
* PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
|
|
|
|
* Eric Kohl
|
1998-08-25 12:27:26 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *****************************************************************/
|
|
|
|
|
2004-08-16 00:39:12 +08:00
|
|
|
#include <ntoskrnl.h>
|
1998-09-13 23:55:55 +08:00
|
|
|
#define NDEBUG
|
2008-08-31 00:31:06 +08:00
|
|
|
#include <debug.h>
|
1998-08-25 12:27:26 +08:00
|
|
|
|
2003-02-26 00:50:46 +08:00
|
|
|
/* FUNCTIONS ****************************************************************/
|
1999-08-29 14:59:11 +08:00
|
|
|
|
2006-07-01 02:14:54 +08:00
|
|
|
/*
|
2003-07-10 23:47:00 +08:00
|
|
|
* @implemented
|
1999-08-29 14:59:11 +08:00
|
|
|
*/
|
2006-07-01 02:14:54 +08:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
IoCreateSymbolicLink(IN PUNICODE_STRING SymbolicLinkName,
|
|
|
|
IN PUNICODE_STRING DeviceName)
|
1999-02-02 04:58:37 +08:00
|
|
|
{
|
2006-07-01 02:14:54 +08:00
|
|
|
OBJECT_ATTRIBUTES ObjectAttributes;
|
|
|
|
HANDLE Handle;
|
|
|
|
NTSTATUS Status;
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Initialize the object attributes and create the link */
|
|
|
|
InitializeObjectAttributes(&ObjectAttributes,
|
|
|
|
SymbolicLinkName,
|
2015-12-17 02:08:38 +08:00
|
|
|
OBJ_KERNEL_HANDLE | OBJ_PERMANENT | OBJ_CASE_INSENSITIVE,
|
2006-07-01 02:14:54 +08:00
|
|
|
NULL,
|
|
|
|
SePublicDefaultSd);
|
|
|
|
Status = ZwCreateSymbolicLinkObject(&Handle,
|
|
|
|
SYMBOLIC_LINK_ALL_ACCESS,
|
|
|
|
&ObjectAttributes,
|
|
|
|
DeviceName);
|
|
|
|
if (NT_SUCCESS(Status)) ZwClose(Handle);
|
|
|
|
|
|
|
|
/* Return status */
|
|
|
|
return Status;
|
1998-10-05 12:01:30 +08:00
|
|
|
}
|
|
|
|
|
2006-07-01 02:14:54 +08:00
|
|
|
/*
|
2003-07-10 23:47:00 +08:00
|
|
|
* @implemented
|
1999-08-29 14:59:11 +08:00
|
|
|
*/
|
2006-07-01 02:14:54 +08:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
IoCreateUnprotectedSymbolicLink(IN PUNICODE_STRING SymbolicLinkName,
|
|
|
|
IN PUNICODE_STRING DeviceName)
|
1998-09-13 23:55:55 +08:00
|
|
|
{
|
2006-07-01 02:14:54 +08:00
|
|
|
SECURITY_DESCRIPTOR SecurityDescriptor;
|
|
|
|
OBJECT_ATTRIBUTES ObjectAttributes;
|
|
|
|
HANDLE Handle;
|
|
|
|
NTSTATUS Status;
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Create an SD */
|
|
|
|
Status = RtlCreateSecurityDescriptor(&SecurityDescriptor,
|
|
|
|
SECURITY_DESCRIPTOR_REVISION);
|
|
|
|
if (!NT_SUCCESS(Status)) return Status;
|
|
|
|
|
|
|
|
/* Set the DACL */
|
|
|
|
Status = RtlSetDaclSecurityDescriptor(&SecurityDescriptor,
|
|
|
|
TRUE,
|
|
|
|
NULL,
|
|
|
|
TRUE);
|
|
|
|
if (!NT_SUCCESS(Status)) return Status;
|
|
|
|
|
|
|
|
/* Initialize the object attributes and create the link */
|
|
|
|
InitializeObjectAttributes(&ObjectAttributes,
|
|
|
|
SymbolicLinkName,
|
2015-12-17 02:08:38 +08:00
|
|
|
OBJ_KERNEL_HANDLE | OBJ_PERMANENT | OBJ_CASE_INSENSITIVE,
|
2006-07-01 02:14:54 +08:00
|
|
|
NULL,
|
|
|
|
&SecurityDescriptor);
|
|
|
|
Status = ZwCreateSymbolicLinkObject(&Handle,
|
|
|
|
SYMBOLIC_LINK_ALL_ACCESS,
|
|
|
|
&ObjectAttributes,
|
|
|
|
DeviceName);
|
|
|
|
if (NT_SUCCESS(Status)) ZwClose(Handle);
|
|
|
|
|
|
|
|
/* Return status */
|
|
|
|
return Status;
|
1998-08-25 12:27:26 +08:00
|
|
|
}
|
|
|
|
|
2006-07-01 02:14:54 +08:00
|
|
|
/*
|
2003-07-10 23:47:00 +08:00
|
|
|
* @implemented
|
1999-08-29 14:59:11 +08:00
|
|
|
*/
|
2006-07-01 02:14:54 +08:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
IoDeleteSymbolicLink(IN PUNICODE_STRING SymbolicLinkName)
|
1998-10-05 12:01:30 +08:00
|
|
|
{
|
2006-07-01 02:14:54 +08:00
|
|
|
OBJECT_ATTRIBUTES ObjectAttributes;
|
|
|
|
HANDLE Handle;
|
|
|
|
NTSTATUS Status;
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Initialize the object attributes and open the link */
|
|
|
|
InitializeObjectAttributes(&ObjectAttributes,
|
|
|
|
SymbolicLinkName,
|
2015-12-17 02:08:38 +08:00
|
|
|
OBJ_KERNEL_HANDLE | OBJ_CASE_INSENSITIVE,
|
2006-07-01 02:14:54 +08:00
|
|
|
NULL,
|
|
|
|
NULL);
|
|
|
|
Status = ZwOpenSymbolicLinkObject(&Handle, DELETE, &ObjectAttributes);
|
|
|
|
if (!NT_SUCCESS(Status)) return Status;
|
|
|
|
|
|
|
|
/* Make the link temporary and close its handle */
|
|
|
|
Status = ZwMakeTemporaryObject(Handle);
|
|
|
|
if (NT_SUCCESS(Status)) ZwClose(Handle);
|
|
|
|
|
|
|
|
/* Return status */
|
|
|
|
return Status;
|
1998-10-05 12:01:30 +08:00
|
|
|
}
|
|
|
|
|
1999-08-29 14:59:11 +08:00
|
|
|
/* EOF */
|