X-Git-Url: https://git.saurik.com/apple/security.git/blobdiff_plain/80e2389990082500d76eb566d4946be3e786c3ef..d8f41ccd20de16f8ebe2ccc84d47bf1cb2b26bbb:/securityd/src/clientid.h diff --git a/securityd/src/clientid.h b/securityd/src/clientid.h new file mode 100644 index 00000000..57d9caf7 --- /dev/null +++ b/securityd/src/clientid.h @@ -0,0 +1,84 @@ +/* + * Copyright (c) 2000-2004,2006-2007,2012 Apple Inc. All Rights Reserved. + * + * @APPLE_LICENSE_HEADER_START@ + * + * This file contains Original Code and/or Modifications of Original Code + * as defined in and that are subject to the Apple Public Source License + * Version 2.0 (the 'License'). You may not use this file except in + * compliance with the License. Please obtain a copy of the License at + * http://www.opensource.apple.com/apsl/ and read it before using this + * file. + * + * The Original Code and all software distributed under the License are + * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER + * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, + * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. + * Please see the License for the specific language governing rights and + * limitations under the License. + * + * @APPLE_LICENSE_HEADER_END@ + */ +// +// clientid - track and manage identity of securityd clients +// +#ifndef _H_CLIENTID +#define _H_CLIENTID + +#include "codesigdb.h" +#include +#include +#include + + +// +// A ClientIdentification object is a mix-in class that tracks +// the identity of associated client processes and their sub-entities +// (aka Code Signing Guest objects). +// +class ClientIdentification : public CodeSignatures::Identity { +public: + ClientIdentification(); + + SecCodeRef processCode() const; + SecCodeRef currentGuest() const; + + // CodeSignatures::Identity personality + string getPath() const; + const CssmData getHash() const; + const bool checkAppleSigned() const; + +protected: + void setup(pid_t pid); + +public: + IFDUMP(void dump()); + +private: + CFRef mClientProcess; // process-level client object + + mutable Mutex mLock; // protects everything below + + struct GuestState { + GuestState() : gotHash(false) { } + CFRef code; + mutable bool gotHash; + mutable SHA1::Digest legacyHash; + mutable bool checkedSignature; + mutable bool appleSigned; + }; + typedef std::map GuestMap; + mutable GuestMap mGuests; + + GuestState *current() const; +}; + + +// +// Bonus function +// +std::string codePath(SecStaticCodeRef code); + + +#endif //_H_CLIENTID