/* * Copyright 2008 Federal Chancellery Austria and * Graz University of Technology * * 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. */ package at.gv.egiz.smcc.pin.gui; import at.gv.egiz.smcc.CancelledException; import at.gv.egiz.smcc.PINSpec; /** * The number of retries is not fixed and there is no way (?) to obtain this value. * A PINProvider should therefore maintain an internal retry counter or flag * to decide whether or not to warn the user (num retries passed in providePIN). * * Therefore PINProvider objects should not be reused. * * (ACOS: reload counter: between 0 and 15, where 15 meens deactivated) * * @author Clemens Orthacker */ public interface PINProvider { /** * * @param spec * @param retries num of remaining retries or -1 if unknown * (a positive value does not necessarily signify that there was * already an unsuccessful PIN verification) * @return pin != null * @throws at.gv.egiz.smcc.CancelledException * @throws java.lang.InterruptedException */ char[] providePIN(PINSpec pinSpec, int retries) throws CancelledException, InterruptedException; }