2 * Copyright (c) 2012, 2013 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
23 #include "SEService.h"
26 #include "APDUHelper.h"
28 using namespace smartcard_service_api;
30 typedef struct _user_context_t
32 Session *clientSession;
33 SEServiceHelper *clientService;
34 Channel *clientChannel;
39 GMainLoop *loop = NULL;
40 user_context_t user_context = { 0, };
42 void testCloseCallback(int error, void *userData);
43 void testTransmitCallback(unsigned char *buffer, unsigned int length, int error, void *userData);
44 void testOpenChannelCallback(Channel *channel, int error, void *userData);
45 void testGetATRCallback(unsigned char *atr, unsigned int length, int error, void *userData);
46 void testCloseSessionCallback(int error, void *userData);
47 void testOpenSessionCallback(SessionHelper *session, int error, void *userData);
48 void testConnectedCallback(SEServiceHelper *service, void *context);
50 class TestEventHandler : public SEServiceListener
52 void serviceConnected(SEServiceHelper *service, void *userData)
55 testConnectedCallback(service, userData);
59 void eventHandler(SEServiceHelper *service, char *seName, int event, void *userData)
61 // user_context_t *context = (user_context_t *)userData;
62 vector<ReaderHelper *> readers;
67 SCARD_DEBUG("event occured service [%p], seName[%s], event [%d], userData [%p]", service, seName, event, userData);
69 readers = service->getReaders();
71 for (i = 0; i < readers.size(); i++)
73 SCARD_DEBUG("Reader[%d] : name [%s], %s", i, readers[i]->getName(), readers[i]->isSecureElementPresent() ? "available" : "unavailable");
78 testConnectedCallback(service, userData);
84 void errorHandler(SEServiceHelper *service, int error, void *userData)
88 SCARD_DEBUG("error occured service [%p], error [%d]", service, error);
94 TestEventHandler testEventHandler;
96 void testCloseCallback(int error, void *userData)
98 user_context_t *context = (user_context_t *)userData;
100 SCARD_DEBUG("result [%d], userData [%p]", error, userData);
102 context->clientService->shutdown();
105 void testTransmitCallback(unsigned char *buffer, unsigned int length, int error, void *userData)
107 ByteArray response(buffer, length);
108 user_context_t *context = (user_context_t *)userData;
110 SCARD_DEBUG("buffer [%p], length [%d], error [%d], userData [%p]", buffer, length, error, userData);
112 context->clientChannel->close(testCloseCallback, userData);
115 void testOpenChannelCallback(Channel *channel, int error, void *userData)
117 SCARD_DEBUG("channel [%p]", channel);
119 if (error == 0 && channel != NULL)
122 ByteArray data, command;
123 int fid = 0x00003150;
124 user_context_t *context = (user_context_t *)userData;
126 context->clientChannel = channel;
128 response = channel->getSelectResponse();
130 SCARD_DEBUG("response : %s", response.toString());
132 SCARD_DEBUG("isBasicChannel() = %s", channel->isBasicChannel() ? "Basic" : "Logical");
133 SCARD_DEBUG("isClosed() = %s", channel->isClosed() ? "Closed" : "Opened");
135 data.setBuffer((unsigned char *)&fid, 2);
136 command = APDUHelper::generateAPDU(APDUHelper::COMMAND_SELECT_BY_ID, 0, data);
137 context->clientChannel->transmit(command, testTransmitCallback, userData);
141 SCARD_DEBUG_ERR("openBasicChannel failed");
145 void testGetATRCallback(unsigned char *atr, unsigned int length, int error, void *userData)
147 // unsigned char MF[] = { 0x3F, 0x00 };
148 unsigned char MF[] = { 0xA0, 0x00, 0x00, 0x00, 0x63, 0x50, 0x4B, 0x43, 0x53, 0x2D, 0x31, 0x35 };
149 ByteArray aid, result(atr, length);
150 user_context_t *context = (user_context_t *)userData;
152 SCARD_DEBUG("atr[%d] : %s", result.getLength(), result.toString());
154 aid.setBuffer(MF, sizeof(MF));
155 context->clientSession->openLogicalChannel(aid, testOpenChannelCallback, userData);
158 void testCloseSessionCallback(int error, void *userData)
163 void testOpenSessionCallback(SessionHelper *session, int error, void *userData)
165 SCARD_DEBUG("session [%p]", session);
169 user_context_t *context = (user_context_t *)userData;
171 context->clientSession = (Session *)session;
172 context->clientSession->getATR(testGetATRCallback, userData);
176 SCARD_DEBUG_ERR("openSession failed");
180 void testConnectedCallback(SEServiceHelper *service, void *userData)
182 vector<ReaderHelper *> readers;
183 user_context_t *context = (user_context_t *)userData;
189 SCARD_DEBUG("callback called, service [%p]", service);
191 context->clientService = service;
193 readers = service->getReaders();
195 if (readers.size() > 0)
197 Reader *reader = NULL;
199 reader = (Reader *)readers[0];
201 SCARD_DEBUG("reader [%p]", reader);
203 reader->openSession(testOpenSessionCallback, userData);
207 SCARD_DEBUG_ERR("reader is empty");
212 SCARD_DEBUG_ERR("service is NULL");
218 int main(int argv, char *args[])
220 SEService *service = new SEService((void *)&user_context, &testEventHandler);
222 loop = g_main_new(TRUE);
223 g_main_loop_run(loop);