1/*
2 *  Copyright (c) 2004 Apple Computer, Inc. All Rights Reserved.
3 *
4 *  @APPLE_LICENSE_HEADER_START@
5 *
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
11 *  file.
12 *
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.
20 *
21 *  @APPLE_LICENSE_HEADER_END@
22 */
23#ifndef _H_TOKEND_SERVER
24#define _H_TOKEND_SERVER
25
26
27//
28// server - master server loop for tokend
29//
30#include "SecTokend.h"
31#include <security_utilities/logging.h>
32#include <security_utilities/pcsc++.h>
33#include <security_utilities/machserver.h>
34#include <security_utilities/alloc.h>
35
36namespace Security {
37namespace Tokend {
38
39
40//
41// The server class that drives this tokend
42//
43    class Server : public MachPlusPlus::MachServer, public SecTokendCallbacks {
44public:
45	int operator() (int argc, const char *argv[], SecTokendCallbackFlags flags);
46
47	const char *readerName() const { return mReaderName; }
48	const PCSC::ReaderState &startupReaderState() const { return mStartupReaderState; }
49
50	const char *tokenUid() const { return mTokenUid.c_str(); }
51	void tokenUid(const char *uid) { mTokenUid = uid; }
52
53	SecTokendCallbacks &callbacks() { return static_cast<SecTokendCallbacks &>(*this); }
54
55	void termination(uint32 reason, uint32 options) __attribute__((noreturn));
56
57protected:
58	boolean_t handle(mach_msg_header_t *in, mach_msg_header_t *out);
59
60private:
61	const char *mReaderName;
62	PCSC::ReaderState mStartupReaderState;
63	std::string mTokenUid;
64};
65
66
67//
68// The server singleton
69//
70extern Server *server;
71
72
73}	// namespace Tokend
74}	// namespace Security
75
76#endif //_H_TOKEND_SERVER
77