]>
git.saurik.com Git - apple/security.git/blob - OSX/libsecurity_codesigning/lib/diskimagerep.h
2 * Copyright (c) 20015 Apple Inc. All Rights Reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
25 // diskimagerep - DiskRep representing a single read-only compressed disk image file
27 #ifndef _H_DISKIMAGEREP
28 #define _H_DISKIMAGEREP
30 #include "singlediskrep.h"
32 #include <DiskImages/DiskImages.h>
33 #undef check // sadness is having to live with C #defines of this kind...
34 #include <security_utilities/unix++.h>
37 namespace CodeSigning
{
41 // DiskImageRep implements a single read-only compressed disk image file.
43 class DiskImageRep
: public SingleDiskRep
{
45 DiskImageRep(const char *path
);
46 virtual ~DiskImageRep();
48 CFDataRef
identification();
49 CFDataRef
component(CodeDirectory::SpecialSlot slot
);
50 size_t signingLimit();
51 void strictValidate(const CodeDirectory
* cd
, const ToleratedErrors
& tolerated
, SecCSFlags flags
);
53 void prepareForSigning(SigningContext
& state
);
55 static bool candidate(UnixPlusPlus::FileDesc
&fd
);
56 void registerStapledTicket();
59 static CFDataRef
identificationFor(MachO
*macho
);
62 DiskRep::Writer
*writer();
68 static bool readHeader(UnixPlusPlus::FileDesc
& fd
, UDIFFileHeader
& header
);
71 UDIFFileHeader mHeader
; // disk image header (all fields NBO)
72 size_t mEndOfDataOffset
; // end of payload data (data fork + XML)
73 size_t mHeaderOffset
; // trailing header offset
74 const EmbeddedSignatureBlob
*mSigningData
; // pointer to signature SuperBlob (malloc'd memory during setup)
79 // The write side of a FileDiskRep
81 class DiskImageRep::Writer
: public SingleDiskRep::Writer
, private EmbeddedSignatureBlob::Maker
{
82 friend class FileDiskRep
;
84 Writer(DiskImageRep
*r
) : SingleDiskRep::Writer(r
, writerNoGlobal
), rep(r
), mSigningData(NULL
) { }
85 void component(CodeDirectory::SpecialSlot slot
, CFDataRef data
);
87 void addDiscretionary(CodeDirectory::Builder
&builder
);
91 EmbeddedSignatureBlob
*mSigningData
;
95 } // end namespace CodeSigning
96 } // end namespace Security
98 #endif // !_H_DISKIMAGEREP