Ejemplo de uso de NSAuth (Namespace M de N Authorization): asociación de particiones, verificación de sombras, autorización de sesión y restablecimiento de estado mediante tarjetas inteligentes Dinamo.
package doxy.examples;
import com.dinamonetworks.Dinamo;
import com.dinamonetworks.SvmkShadow;
import br.com.trueaccess.TacException;
import br.com.trueaccess.TacNDJavaLib;
public class NSAuthSetState {
public static void main(String[] args) throws TacException {
String ip = "127.0.0.1";
String user = "ns";
String password = "12345678";
Dinamo api = new Dinamo();
api.openSession(ip, user, password);
try {
int M = 2;
int N = 3;
SvmkShadow[] allShadows = api.generateSVMK(
TacNDJavaLib.DN_SC_M_OF_N_SHADOW_V2_TYPE, null, M, N);
System.out.printf("Shadows geradas: %d (mínimo para reconstrução: %d)%n", N, M);
SvmkShadow[] mShadows = new SvmkShadow[M];
System.arraycopy(allShadows, 0, mShadows, 0, M);
int acl = TacNDJavaLib.NSAUTH_ACL_OBJ_OPEN | TacNDJavaLib.NSAUTH_ACL_OBJ_EXPORT;
api.nsAuthSetState(acl, TacNDJavaLib.DN_S_NSAUTH_ASSOC, mShadows);
System.out.println("Partição associada (ASSOC) com ACL = " + acl);
api.nsAuthSetState(TacNDJavaLib.NSAUTH_ACL_NOP,
TacNDJavaLib.DN_S_NSAUTH_CHECK, mShadows);
System.out.println("Verificação de shadows (CHECK) concluída.");
api.nsAuthSetState(TacNDJavaLib.NSAUTH_ACL_NOP,
TacNDJavaLib.DN_S_NSAUTH_eAUTH, mShadows);
System.out.println("Sessão autorizada (eAUTH).");
api.nsAuthSetState(TacNDJavaLib.NSAUTH_ACL_NOP,
TacNDJavaLib.DN_S_NSAUTH_RESET, mShadows);
System.out.println("Estado NSAuth resetado (RESET).");
} finally {
api.closeSession();
}
}
}