00001 /* 00002 ** ClanLib SDK 00003 ** Copyright (c) 1997-2005 The ClanLib Team 00004 ** 00005 ** This software is provided 'as-is', without any express or implied 00006 ** warranty. In no event will the authors be held liable for any damages 00007 ** arising from the use of this software. 00008 ** 00009 ** Permission is granted to anyone to use this software for any purpose, 00010 ** including commercial applications, and to alter it and redistribute it 00011 ** freely, subject to the following restrictions: 00012 ** 00013 ** 1. The origin of this software must not be misrepresented; you must not 00014 ** claim that you wrote the original software. If you use this software 00015 ** in a product, an acknowledgment in the product documentation would be 00016 ** appreciated but is not required. 00017 ** 2. Altered source versions must be plainly marked as such, and must not be 00018 ** misrepresented as being the original software. 00019 ** 3. This notice may not be removed or altered from any source distribution. 00020 ** 00021 ** Note: Some of the libraries ClanLib link to may have additional 00022 ** requirements or restrictions. 00023 ** 00024 ** File Author(s): 00025 ** 00026 ** Magnus Norddahl 00027 */ 00028 00029 #include "precomp.h" 00030 #include "security_descriptor.h" 00031 00033 // CL_SecurityDescriptor construction: 00034 00035 CL_SecurityDescriptor::CL_SecurityDescriptor() 00036 : owner(CL_SecurityIdentifier::get_thread_user()), 00037 primary_group(CL_SecurityIdentifier::get_thread_group()), 00038 owner_defaulted(true), 00039 group_defaulted(true), 00040 dacl_defaulted(true) 00041 { 00042 // todo: setup dacl to u+rw, g+r, o+r rights 00043 } 00044 00045 CL_SecurityDescriptor::CL_SecurityDescriptor(const CL_SecurityDescriptor ©) 00046 : owner(copy.owner), primary_group(copy.primary_group), 00047 discretionary_acl(copy.discretionary_acl), 00048 owner_defaulted(copy.owner_defaulted), 00049 group_defaulted(copy.group_defaulted), 00050 dacl_defaulted(copy.dacl_defaulted) 00051 { 00052 } 00053 00054 CL_SecurityDescriptor::~CL_SecurityDescriptor() 00055 { 00056 } 00057 00059 // CL_SecurityDescriptor attributes: 00060 00062 // CL_SecurityDescriptor operations: 00063 00064 CL_SecurityDescriptor &CL_SecurityDescriptor::operator =(const CL_SecurityDescriptor ©) 00065 { 00066 owner = copy.owner; 00067 primary_group = copy.primary_group; 00068 discretionary_acl = copy.discretionary_acl; 00069 owner_defaulted = copy.owner_defaulted; 00070 group_defaulted = copy.group_defaulted; 00071 dacl_defaulted = copy.dacl_defaulted; 00072 return *this; 00073 } 00074 00076 // CL_SecurityDescriptor implementation:
1.4.1