blob: 4ae57ab829cbf3aa9cba613e67871ec55089fdba [file] [log] [blame]
/*
* Copyright (C) 2017, The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* Contributed by: Giesecke & Devrient GmbH.
*/
package android.se.omapi;
import android.se.omapi.ISecureElementSession;
/** @hide */
interface ISecureElementChannel {
/**
* Closes the specified connection and frees internal resources.
* A logical channel will be closed.
*/
void close();
/**
* Tells if this channel is closed.
*
* @return <code>true</code> if the channel is closed,
* <code>false</code> otherwise.
*/
boolean isClosed();
/**
* Returns a boolean telling if this channel is the basic channel.
*
* @return <code>true</code> if this channel is a basic channel.
* <code>false</code> if this channel is a logical channel.
*/
boolean isBasicChannel();
/**
* Returns the data as received from the application select command
* inclusively the status word. The returned byte array contains the data
* bytes in the following order:
* [<first data byte>, ..., <last data byte>, <sw1>, <sw2>]
*/
byte[] getSelectResponse();
/**
* Transmits the specified command APDU and returns the response APDU.
* MANAGE channel commands are not supported.
* Selection of applets is not supported in logical channels.
*/
byte[] transmit(in byte[] command);
/**
* Performs a selection of the next Applet on this channel that matches to
* the partial AID specified in the openBasicChannel(byte[] aid) or
* openLogicalChannel(byte[] aid) method. This mechanism can be used by a
* device application to iterate through all Applets matching to the same
* partial AID.
* If selectNext() returns true a new Applet was successfully selected on
* this channel.
* If no further Applet exists with matches to the partial AID this method
* returns false and the already selected Applet stays selected.
*
* @return <code>true</code> if new Applet was successfully selected.
* <code>false</code> if no further Applet exists which matches the
* partial AID.
*/
boolean selectNext();
}