/* * Proyecto CCIDroid. Driver para utilizacion de tarjetas CCID en el sistema operativo * Android. * * El proyecto CCIDroid es un conector para la comunicacion entre sistemas Android y * lectores de SmartCard USB segun el estandar CCID. Diseno inicial desarrollado para * su integracion con el Controlador Java de la Secretaria de Estado de Administraciones * Publicas para el DNI electronico. * * Copyright (C) 2012 Instituto Nacional de las Tecnologias de la Comunicacion (INTECO) * * Este programa es software libre y utiliza un licenciamiento dual (LGPL 2.1+ * o EUPL 1.1+), lo cual significa que los usuarios podran elegir bajo cual de las * licencias desean utilizar el codigo fuente. Su eleccion debera reflejarse * en las aplicaciones que integren o distribuyan el Controlador, ya que determinara * su compatibilidad con otros componentes. * * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la * Lesser GNU General Public License publicada por la Free Software Foundation, * tanto en la version 2.1 de la Licencia, o en una version posterior. * * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la * European Union Public License publicada por la Comision Europea, * tanto en la version 1.1 de la Licencia, o en una version posterior. * * Deberia recibir una copia de la GNU Lesser General Public License, si aplica, junto * con este programa. Si no, consultelo en <http://www.gnu.org/licenses/>. * * Deberia recibir una copia de la European Union Public License, si aplica, junto * con este programa. Si no, consultelo en <http://joinup.ec.europa.eu/software/page/eupl>. * * Este programa es distribuido con la esperanza de que sea util, pero * SIN NINGUNA GARANTIA; incluso sin la garantia implicita de comercializacion * o idoneidad para un proposito particular. */ package es.inteco.labs.android.usb.device.ccid.instruction; /** Factoría de comandos USB. * @author Jose Luis Escanciano Garcia */ public final class UsbInstructionFactory { private static UsbInstructionFactory instance = null; private byte instructionCount; /** Constructor. */ private UsbInstructionFactory() { super(); this.instructionCount = (byte) 0x00; } /** Devuelve la instancia <i>singleton</i> de la factoría de comandos USB. * @return Instancia <i>singleton</i> de la factoría de comandos USB */ public static UsbInstructionFactory getInstance(){ if(instance == null){ instance = new UsbInstructionFactory(); } return instance; } /** Obtiene un comando de tipo <i>SlotStatus</i>. * @return Comando de tipo <i>SlotStatus</i> */ public UsbCommand getSlotStatusCommand(){ return new GetSlotStatus(this.instructionCount++); } /** Obtiene un comando de tipo <i>IccPowerOff</i>. * @return Comando de tipo <i>IccPowerOff</i> */ public UsbCommand getIccPowerOnCommand(){ return new IccPowerOn(this.instructionCount++); } /** Obtiene un comando de tipo <i>IccPowerOff</i>. * @return Comando de tipo <i>IccPowerOff</i> */ public UsbCommand getIccPowerOffCommand(){ return new IccPowerOff(this.instructionCount++); } /** Obtiene un comando de tipo <i>XfrBlock</i> que encapsula una APDU completa. * @param apdu APDU que se encapsulará en este comando USB * @return Comando de tipo <i>XfrBlock</i> */ public UsbCommand getXfrBlockCommand(final byte[] apdu){ return new XfrBlock(this.instructionCount++, apdu, XfrBlock.APDU_BEGIN_AND_END); } /** Obtiene un comando de tipo <i>XfrBlock</i> que encapsula una APDU completa. * @param apdu APDU que se encapsulará en este comando USB * @param type Tipo * @return Comando de tipo <i>XfrBlock</i> */ public UsbCommand getXfrBlockCommand(final byte[] apdu, final byte[] type){ return new XfrBlock(this.instructionCount++, apdu, type); } /** Obtiene un comando de tipo <i>T0ApduCommand</i>. * @return Comando de tipo <i>T0ApduCommand</i> */ public UsbCommand getT0ApduCommand(){ return new T0APDU(this.instructionCount++); } /** Obtiene un comando de tipo <i>GetParameters</i>. * @return Comando de tipo <i>GetParameters</i> */ public UsbCommand getParametersCommand(){ return new GetParameters(this.instructionCount++); } /** Obtiene un comando de tipo <i>GetParameters</i>. * @param parameters Parámetros * @return Comando de tipo <i>GetParameters</i> */ public UsbCommand getSetParametersCommand(final byte[] parameters){ return new SetParameters(this.instructionCount++, parameters); } }