2 * Copyright (c) 2008, 2009, 2010, 2011 Kernel Drivers, LLC.
3 * Copyright (c) 2009, 2010, 2011 Your File System, Inc.
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * - Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright
14 * this list of conditions and the following disclaimer in the
16 * and/or other materials provided with the distribution.
17 * - Neither the names of Kernel Drivers, LLC and Your File System, Inc.
18 * nor the names of their contributors may be used to endorse or promote
19 * products derived from this software without specific prior written
20 * permission from Kernel Drivers, LLC and Your File System, Inc.
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
25 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
26 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
27 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
28 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
29 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
30 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
31 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
32 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 // File: AFSSecurity.cpp
39 #include "AFSCommon.h"
42 AFSSetSecurity( IN PDEVICE_OBJECT DeviceObject,
46 NTSTATUS ntStatus = STATUS_NOT_SUPPORTED;
47 IO_STACK_LOCATION *pIrpSp;
48 AFSDeviceExt *pControlDeviceExt = (AFSDeviceExt *)AFSDeviceObject->DeviceExtension;
51 pIrpSp = IoGetCurrentIrpStackLocation( Irp);
56 AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING,
57 AFS_TRACE_LEVEL_VERBOSE,
58 "AFSSetSecurity Entry for FO %p\n",
61 if( DeviceObject == AFSDeviceObject)
64 ntStatus = STATUS_INVALID_DEVICE_REQUEST;
66 AFSCompleteRequest( Irp,
69 try_return( ntStatus);
72 pFcb = (AFSFcb*) pIrpSp->FileObject->FsContext;
75 pFcb->Header.NodeTypeCode == AFS_REDIRECTOR_FCB)
82 ntStatus = STATUS_INVALID_DEVICE_REQUEST;
84 AFSCompleteRequest( Irp,
87 try_return( ntStatus);
91 // Check the state of the library
94 ntStatus = AFSCheckLibraryState( Irp);
96 if( !NT_SUCCESS( ntStatus) ||
97 ntStatus == STATUS_PENDING)
100 if( ntStatus != STATUS_PENDING)
102 AFSCompleteRequest( Irp, ntStatus);
105 try_return( ntStatus);
108 IoSkipCurrentIrpStackLocation( Irp);
110 ntStatus = IoCallDriver( pControlDeviceExt->Specific.Control.LibraryDeviceObject,
114 // Indicate the library is done with the request
117 AFSClearLibraryRequest();
123 __except( AFSExceptionFilter( __FUNCTION__, GetExceptionCode(), GetExceptionInformation()) )
128 "EXCEPTION - AFSSetSecurity\n");
130 AFSDumpTraceFilesFnc();
137 AFSQuerySecurity( IN PDEVICE_OBJECT DeviceObject,
141 NTSTATUS ntStatus = STATUS_NOT_SUPPORTED;
142 IO_STACK_LOCATION *pIrpSp;
143 AFSDeviceExt *pControlDeviceExt = (AFSDeviceExt *)AFSDeviceObject->DeviceExtension;
146 pIrpSp = IoGetCurrentIrpStackLocation( Irp);
151 AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING,
152 AFS_TRACE_LEVEL_VERBOSE,
153 "AFSQuerySecurity Entry for FO %p\n",
156 if( DeviceObject == AFSDeviceObject)
159 ntStatus = STATUS_INVALID_DEVICE_REQUEST;
161 AFSCompleteRequest( Irp,
164 try_return( ntStatus);
167 pFcb = (AFSFcb*) pIrpSp->FileObject->FsContext;
170 pFcb->Header.NodeTypeCode == AFS_REDIRECTOR_FCB)
177 ntStatus = STATUS_INVALID_DEVICE_REQUEST;
179 AFSCompleteRequest( Irp,
182 try_return( ntStatus);
186 // Check the state of the library
189 ntStatus = AFSCheckLibraryState( Irp);
191 if( !NT_SUCCESS( ntStatus) ||
192 ntStatus == STATUS_PENDING)
195 if( ntStatus != STATUS_PENDING)
197 AFSCompleteRequest( Irp, ntStatus);
200 try_return( ntStatus);
203 IoSkipCurrentIrpStackLocation( Irp);
205 ntStatus = IoCallDriver( pControlDeviceExt->Specific.Control.LibraryDeviceObject,
209 // Indicate the library is done with the request
212 AFSClearLibraryRequest();
218 __except( AFSExceptionFilter( __FUNCTION__, GetExceptionCode(), GetExceptionInformation()) )
223 "EXCEPTION - AFSQuerySecurity\n");
225 AFSDumpTraceFilesFnc();