1 | |
---|
2 | import java.awt.Frame; |
---|
3 | import java.io.IOException; |
---|
4 | import java.net.MalformedURLException; |
---|
5 | import java.net.URL; |
---|
6 | import java.security.GeneralSecurityException; |
---|
7 | import java.security.ProviderException; |
---|
8 | |
---|
9 | import javax.net.ssl.SSLHandshakeException; |
---|
10 | import javax.swing.JApplet; |
---|
11 | import javax.swing.JOptionPane; |
---|
12 | import javax.swing.SwingUtilities; |
---|
13 | import org.apache.commons.httpclient.HttpException; |
---|
14 | |
---|
15 | import netscape.javascript.JSObject; |
---|
16 | |
---|
17 | import br.gov.serpro.cert.DigitalCertificate; |
---|
18 | import br.gov.serpro.setup.Setup; |
---|
19 | import br.gov.serpro.ui.DialogBuilder; |
---|
20 | |
---|
21 | /** |
---|
22 | * GUI que realiza o login com certificados A1 e A3 ou login com usuário e senha no expresso. |
---|
23 | * Esta classe estende a classe JApplet |
---|
24 | * @author Mário César Kolling - mario.kolling@serpro.gov.br |
---|
25 | */ |
---|
26 | public class LoginApplet extends JApplet{ |
---|
27 | |
---|
28 | /** |
---|
29 | * Valor gerado aleatoriamente |
---|
30 | */ |
---|
31 | |
---|
32 | //TODO: Alterar a cor e fonte dos labels e das caixas de texto e senha. |
---|
33 | private static final long serialVersionUID = -6204158613173951516L; |
---|
34 | |
---|
35 | //private PinCodePanel pinPanel; |
---|
36 | //private LoginPanel loginPanel; |
---|
37 | //private PinCodePanel alreadyLoadedPanel; |
---|
38 | //private int useCertificate = DigitalCertificate.KEYSTORE_DETECTED; |
---|
39 | // private String uid; |
---|
40 | private DigitalCertificate dc; |
---|
41 | private Setup setup; |
---|
42 | |
---|
43 | /* (non-Javadoc) |
---|
44 | * @see java.applet.Applet#init() |
---|
45 | */ |
---|
46 | public void init() { |
---|
47 | super.init(); |
---|
48 | this.setSize(0, 0); |
---|
49 | this.setup = new Setup(this); |
---|
50 | this.setup.addLanguageResource("ExpressoCertLoginMessages"); |
---|
51 | } |
---|
52 | |
---|
53 | /* (non-Javadoc) |
---|
54 | * @see java.applet.Applet#start() |
---|
55 | */ |
---|
56 | @Override |
---|
57 | public void start() { |
---|
58 | super.start(); |
---|
59 | |
---|
60 | int useCertificate = DigitalCertificate.KEYSTORE_NOT_DETECTED; |
---|
61 | boolean tryAgain = true; |
---|
62 | |
---|
63 | do |
---|
64 | { |
---|
65 | |
---|
66 | // Cria uma instância de DigitalCertificate e a inicializa |
---|
67 | this.dc = new DigitalCertificate(this.getDocumentBase(), setup); |
---|
68 | useCertificate = dc.init(); |
---|
69 | String[] returnCode = null; |
---|
70 | |
---|
71 | try { |
---|
72 | switch (useCertificate){ |
---|
73 | case DigitalCertificate.KEYSTORE_DETECTED: |
---|
74 | // Mostra PinNeedeDialog. |
---|
75 | //tryAgain = false; |
---|
76 | String pin = DialogBuilder.showPinDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), this.setup); |
---|
77 | if (pin != null) { |
---|
78 | dc.openKeyStore(pin.toCharArray()); |
---|
79 | returnCode = dc.getCredentials(pin); |
---|
80 | |
---|
81 | // se chegou aqui, keystore foi acessada e as credenciais do usuário foram recuperadas |
---|
82 | //tryAgain = false; |
---|
83 | assert (returnCode != null): "Valor de returnCode não pode ser nulo"; |
---|
84 | |
---|
85 | //this.dc.destroy(); |
---|
86 | |
---|
87 | // Faz o login |
---|
88 | |
---|
89 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
90 | System.out.println("Código de retorno: " + returnCode[0].trim()); |
---|
91 | } |
---|
92 | |
---|
93 | if (Integer.parseInt(returnCode[0].trim()) == 0){ |
---|
94 | |
---|
95 | tryAgain = false; |
---|
96 | // Pega usuário e senha de credentials[1] e credentials[2], respectivamente |
---|
97 | // adiciona na página e faz o submit. |
---|
98 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
99 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
100 | JSObject loginField = (JSObject) loginForm.getMember("user"); |
---|
101 | loginField.setMember("value", returnCode[1].trim()); |
---|
102 | |
---|
103 | JSObject passwdField = (JSObject) loginForm.getMember("passwd"); |
---|
104 | passwdField.setMember("value", returnCode[2].trim()); |
---|
105 | |
---|
106 | loginForm.call("submit", null); |
---|
107 | Thread.yield(); |
---|
108 | |
---|
109 | } |
---|
110 | else if (Integer.parseInt(returnCode[0].trim()) == 6){ |
---|
111 | |
---|
112 | tryAgain = false; |
---|
113 | |
---|
114 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
115 | System.out.println("Mensagem de retorno: " + returnCode[1].trim()); |
---|
116 | } |
---|
117 | |
---|
118 | //JOptionPane.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), credentials[1]); |
---|
119 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), returnCode[1].trim(), this.setup); |
---|
120 | |
---|
121 | |
---|
122 | |
---|
123 | String redirect = this.getCodeBase().toExternalForm() + "login.php?cd=98&ts=202"; |
---|
124 | try { |
---|
125 | this.getAppletContext().showDocument(new URL(redirect)); |
---|
126 | } catch (MalformedURLException e) { |
---|
127 | // TODO Bloco catch gerado automaticamente |
---|
128 | if (this.setup.getParameter("debug").equalsIgnoreCase("true")){ |
---|
129 | e.printStackTrace(); |
---|
130 | } |
---|
131 | } |
---|
132 | } |
---|
133 | else { |
---|
134 | tryAgain = true; |
---|
135 | dc.destroy(); |
---|
136 | System.gc(); |
---|
137 | |
---|
138 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
139 | System.out.println("Mensagem de retorno: " + returnCode[1].trim()); |
---|
140 | } |
---|
141 | |
---|
142 | // Mostra mensagem de erro para o usuário |
---|
143 | //JOptionPane.showMessageDialog(this, credentials[1]); |
---|
144 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), returnCode[1].trim(), this.setup); |
---|
145 | Thread.yield(); |
---|
146 | } |
---|
147 | |
---|
148 | } |
---|
149 | else { |
---|
150 | |
---|
151 | tryAgain = false; |
---|
152 | String redirect = this.getCodeBase().toExternalForm() + "login.php"; |
---|
153 | try { |
---|
154 | this.getAppletContext().showDocument(new URL(redirect)); |
---|
155 | } catch (MalformedURLException e) { |
---|
156 | // TODO Bloco catch gerado automaticamente |
---|
157 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
158 | e.printStackTrace(); |
---|
159 | } |
---|
160 | } |
---|
161 | } |
---|
162 | |
---|
163 | break; |
---|
164 | /* |
---|
165 | case DigitalCertificate.KEYSTORE_ALREADY_LOADED: |
---|
166 | // Mostra PinNotNeededDialog |
---|
167 | tryAgain = false; |
---|
168 | |
---|
169 | //Verifica na página se operação anterior foi um logout |
---|
170 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
171 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
172 | JSObject loginField = (JSObject) loginForm.getMember("cd"); |
---|
173 | String cdValue = (String) loginField.getMember("value"); |
---|
174 | |
---|
175 | int cd = 0; |
---|
176 | if (cdValue.length() != 0){ |
---|
177 | cd = Integer.parseInt(cdValue); |
---|
178 | } |
---|
179 | |
---|
180 | // Se não foi logout prossegue com o login, senão pára tudo |
---|
181 | if (cd != 1 && cd != 5){ |
---|
182 | |
---|
183 | DialogBuilder.showPinNotNeededDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this)); |
---|
184 | dc.openKeyStore(null); |
---|
185 | returnCode = dc.getCredentials(""); |
---|
186 | |
---|
187 | // se chegou aqui, keystore foi acessada e as credenciais do usuário foram recuperadas |
---|
188 | assert (returnCode != null): "Valor de returnCode não pode ser nulo"; |
---|
189 | |
---|
190 | // Faz o login |
---|
191 | doLogin(returnCode); |
---|
192 | } |
---|
193 | else if (cd == 5){ |
---|
194 | JOptionPane.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
195 | "Não foi possível realizar o Logon com certificado!"); |
---|
196 | // Redireciona para a tela de login |
---|
197 | String redirect = this.getCodeBase().toExternalForm() + "login.php"; |
---|
198 | try { |
---|
199 | this.getAppletContext().showDocument(new URL(redirect)); |
---|
200 | } catch (MalformedURLException e) { |
---|
201 | // TODO Bloco catch gerado automaticamente |
---|
202 | e.printStackTrace(); |
---|
203 | } |
---|
204 | |
---|
205 | } |
---|
206 | |
---|
207 | //DialogBuilder.showPinNotNeededDialog(findParentframe()); |
---|
208 | |
---|
209 | break; |
---|
210 | */ |
---|
211 | default: |
---|
212 | |
---|
213 | // Mostra Diálogo dizendo que token não foi encontrado |
---|
214 | // ou repositório de chaves públicas não foi configurado. |
---|
215 | // Tentar carregar token/keystore novamente? / Logon sem certificado digital? |
---|
216 | |
---|
217 | tryAgain = false; |
---|
218 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
219 | System.out.println("não achou token"); |
---|
220 | } |
---|
221 | |
---|
222 | dc.destroy(); |
---|
223 | System.gc(); |
---|
224 | |
---|
225 | String redirect = this.getCodeBase().toExternalForm() + "login.php"; |
---|
226 | try { |
---|
227 | this.getAppletContext().showDocument(new URL(redirect)); |
---|
228 | } catch (MalformedURLException e) { |
---|
229 | // TODO Bloco catch gerado automaticamente |
---|
230 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
231 | e.printStackTrace(); |
---|
232 | } |
---|
233 | } |
---|
234 | |
---|
235 | //int resultado = JOptionPane.showConfirmDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
236 | // "Deseja tentar novamente?", |
---|
237 | // "Token não foi encontrado!", |
---|
238 | // JOptionPane.OK_CANCEL_OPTION, |
---|
239 | // JOptionPane.QUESTION_MESSAGE); |
---|
240 | |
---|
241 | //if (resultado == JOptionPane.OK_OPTION){ |
---|
242 | // tryAgain = true; |
---|
243 | //} |
---|
244 | //else { |
---|
245 | |
---|
246 | //} |
---|
247 | |
---|
248 | // if () { |
---|
249 | // tryAgain = true; |
---|
250 | //} |
---|
251 | } |
---|
252 | |
---|
253 | } |
---|
254 | catch (SSLHandshakeException e){ |
---|
255 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
256 | e.printStackTrace(); |
---|
257 | } |
---|
258 | dc.destroy(); |
---|
259 | System.gc(); |
---|
260 | //JOptionPane.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), "Não foi possível validar o certificado do servidor!"); |
---|
261 | //DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
262 | // "Não foi possível validar o certificado do servidor!", this.setup); |
---|
263 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
264 | this.setup.getLang("ExpressoCertLoginMessages", "LoginApplet001"), this.setup); |
---|
265 | |
---|
266 | Thread.yield(); |
---|
267 | |
---|
268 | tryAgain = true; |
---|
269 | } |
---|
270 | catch (HttpException e) { |
---|
271 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
272 | e.printStackTrace(); |
---|
273 | } |
---|
274 | |
---|
275 | tryAgain = true; |
---|
276 | Thread.yield(); |
---|
277 | } |
---|
278 | catch (GeneralSecurityException e){ |
---|
279 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
280 | e.printStackTrace(); |
---|
281 | } |
---|
282 | |
---|
283 | //DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
284 | // "Algum erro ocorreu ao realizar o logon!", this.setup); |
---|
285 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
286 | this.setup.getLang("ExpressoCertLoginMessages", "LoginApplet002"), this.setup); |
---|
287 | |
---|
288 | Thread.yield(); |
---|
289 | tryAgain = true; |
---|
290 | } |
---|
291 | catch (IOException e) { |
---|
292 | dc.destroy(); |
---|
293 | System.gc(); |
---|
294 | |
---|
295 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
296 | e.printStackTrace(); |
---|
297 | } |
---|
298 | //System.out.println("Classe que originou o erro de IO: " + e.getClass().getCanonicalName());; |
---|
299 | |
---|
300 | Throwable cause = null; |
---|
301 | if ((cause = e.getCause()) != null){ |
---|
302 | if (cause instanceof javax.security.auth.login.LoginException){ |
---|
303 | //DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), "PIN incorreto!", this.setup); |
---|
304 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), this.setup.getLang("ExpressoCertLoginMessages", "LoginApplet003"), this.setup); |
---|
305 | } else { |
---|
306 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
307 | System.out.println("Exception lançada: " + cause.getClass().getCanonicalName()); |
---|
308 | } |
---|
309 | } |
---|
310 | } |
---|
311 | else { |
---|
312 | if (e instanceof java.net.ConnectException){ |
---|
313 | //DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
314 | // "Não foi possível fazer a conexão com o servidor do Expresso.\n" + |
---|
315 | // "Verifique suas configurações de rede/proxy.", this.setup); |
---|
316 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
317 | this.setup.getLang("ExpressoCertLoginMessages", "LoginApplet004"), this.setup); |
---|
318 | } else { |
---|
319 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
320 | System.out.println("Exception lançada: " + e.getClass().getCanonicalName()); |
---|
321 | } |
---|
322 | } |
---|
323 | } |
---|
324 | |
---|
325 | Thread.yield(); |
---|
326 | tryAgain = true; |
---|
327 | } |
---|
328 | catch (ProviderException e) { |
---|
329 | // Tentar novamente / cancel |
---|
330 | //JOptionPane.showMessageDialog(this, "Token foi removido! Favor inserir seu token"); |
---|
331 | |
---|
332 | dc.destroy(); |
---|
333 | System.gc(); |
---|
334 | |
---|
335 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
336 | e.printStackTrace(); |
---|
337 | } |
---|
338 | |
---|
339 | /* |
---|
340 | JOptionPane optionPane = new JOptionPane("Token foi removido\nDeseja tentar carregá-lo novamente?", |
---|
341 | JOptionPane.QUESTION_MESSAGE, JOptionPane.OK_CANCEL_OPTION); |
---|
342 | JDialog dialog = new JDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), true); |
---|
343 | dialog.setContentPane(optionPane); |
---|
344 | //Posicionando no centro da tela. |
---|
345 | |
---|
346 | Dimension mySize = dialog.getSize(); |
---|
347 | Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize(); |
---|
348 | dialog.setLocation(screenSize.width/2 - (mySize.width/2), screenSize.height/2 - (mySize.height/2)); |
---|
349 | dialog.setVisible(true); |
---|
350 | |
---|
351 | Object selectedValue = optionPane.getValue(); |
---|
352 | |
---|
353 | if (selectedValue == null){ |
---|
354 | |
---|
355 | } |
---|
356 | else { |
---|
357 | if (selectedValue instanceof Integer){ |
---|
358 | Integer |
---|
359 | } |
---|
360 | } |
---|
361 | */ |
---|
362 | |
---|
363 | int resultado = DialogBuilder.showConfirmDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
364 | //"Deseja tentar carregá-lo novamente?", |
---|
365 | this.setup.getLang("ExpressoCertLoginMessages", "LoginApplet005"), |
---|
366 | JOptionPane.QUESTION_MESSAGE, |
---|
367 | JOptionPane.OK_CANCEL_OPTION, this.setup); |
---|
368 | |
---|
369 | /* int resultado = JOptionPane.showConfirmDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), |
---|
370 | "Deseja tentar carregá-lo novamente?", |
---|
371 | "Token foi removido!", |
---|
372 | JOptionPane.OK_CANCEL_OPTION, |
---|
373 | JOptionPane.QUESTION_MESSAGE); |
---|
374 | */ |
---|
375 | |
---|
376 | if (resultado == JOptionPane.OK_OPTION){ |
---|
377 | tryAgain = true; |
---|
378 | } |
---|
379 | else { |
---|
380 | tryAgain = false; |
---|
381 | } |
---|
382 | |
---|
383 | Thread.yield(); |
---|
384 | } |
---|
385 | |
---|
386 | } |
---|
387 | while (tryAgain); |
---|
388 | |
---|
389 | // chama o método que cria a interface na thread de lançamento de eventos (Event Dispatching Thread). |
---|
390 | //try |
---|
391 | //{ |
---|
392 | // SwingUtilities.invokeAndWait(new Runnable(){ |
---|
393 | |
---|
394 | /* (non-Javadoc) |
---|
395 | * @see java.lang.Runnable#run() |
---|
396 | */ |
---|
397 | // public void run() { |
---|
398 | // createGUI(); |
---|
399 | // } |
---|
400 | |
---|
401 | // }); |
---|
402 | //} catch (Exception e){ |
---|
403 | // System.out.println("Método createGUI não pôde ser carregado: " + e.getMessage()); |
---|
404 | //} |
---|
405 | |
---|
406 | } |
---|
407 | |
---|
408 | /* |
---|
409 | |
---|
410 | public void doLogin(String[] credentials){ |
---|
411 | |
---|
412 | if (Integer.valueOf(credentials[0]) == 0){ |
---|
413 | |
---|
414 | // Pega usuário e senha de credentials[1] e credentials[2], respectivamente |
---|
415 | // adiciona na página e faz o submit. |
---|
416 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
417 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
418 | JSObject loginField = (JSObject) loginForm.getMember("user"); |
---|
419 | loginField.setMember("value", credentials[1]); |
---|
420 | |
---|
421 | JSObject passwdField = (JSObject) loginForm.getMember("passwd"); |
---|
422 | passwdField.setMember("value", credentials[2]); |
---|
423 | |
---|
424 | loginForm.call("submit", null); |
---|
425 | |
---|
426 | } |
---|
427 | else if (Integer.valueOf(credentials[0]) == 6){ |
---|
428 | |
---|
429 | //JOptionPane.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), credentials[1]); |
---|
430 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), credentials[1]); |
---|
431 | String redirect = this.getCodeBase().toExternalForm() + "login.php?cd=98&ts=202"; |
---|
432 | try { |
---|
433 | this.getAppletContext().showDocument(new URL(redirect)); |
---|
434 | } catch (MalformedURLException e) { |
---|
435 | // TODO Bloco catch gerado automaticamente |
---|
436 | e.printStackTrace(); |
---|
437 | } |
---|
438 | } |
---|
439 | else { |
---|
440 | // Mostra mensagem de erro para o usuário |
---|
441 | //JOptionPane.showMessageDialog(this, credentials[1]); |
---|
442 | DialogBuilder.showMessageDialog((Frame) SwingUtilities.getAncestorOfClass(Frame.class, this), credentials[1]); |
---|
443 | } |
---|
444 | |
---|
445 | } |
---|
446 | |
---|
447 | */ |
---|
448 | |
---|
449 | /** |
---|
450 | * Destrói a Applet, executando códigos para desregistrar tokens, keystores, etc. |
---|
451 | */ |
---|
452 | @Override |
---|
453 | public void stop() { |
---|
454 | //super.destroy(); |
---|
455 | if (setup.getParameter("debug").equalsIgnoreCase("true")) { |
---|
456 | System.out.println("Finalizando Applet de Login!"); |
---|
457 | } |
---|
458 | |
---|
459 | this.dc.destroy(); |
---|
460 | this.dc = null; |
---|
461 | //Component[] components = this.getComponents(); |
---|
462 | //for (Component component : components){ |
---|
463 | // this.remove(component); |
---|
464 | // component = null; |
---|
465 | //} |
---|
466 | System.gc(); |
---|
467 | } |
---|
468 | |
---|
469 | /** |
---|
470 | * Cria a interface e seleciona o Painel que será exibido de acordo com o parâmetro useCertificate |
---|
471 | */ |
---|
472 | /* |
---|
473 | private void createGUI(){ |
---|
474 | |
---|
475 | this.setLayout(new FlowLayout()); |
---|
476 | this.getContentPane().setBackground(Color.WHITE); |
---|
477 | |
---|
478 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
479 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
480 | JSObject loginField = (JSObject) loginForm.getMember("user"); |
---|
481 | |
---|
482 | uid = loginField.getMember("value").toString(); |
---|
483 | |
---|
484 | pinPanel = new PinCodePanel(uid, true); // mostra pinCodeField |
---|
485 | alreadyLoadedPanel = new PinCodePanel(uid, false); // não mostra pinCodeField |
---|
486 | loginPanel = new LoginPanel(uid); |
---|
487 | |
---|
488 | switch (useCertificate){ |
---|
489 | case DigitalCertificate.KEYSTORE_NOT_DETECTED: |
---|
490 | // Mostra interface de login com usuário e senha |
---|
491 | this.getContentPane().add(loginPanel); |
---|
492 | break; |
---|
493 | case DigitalCertificate.KEYSTORE_ALREADY_LOADED: |
---|
494 | // Mostra interface de login sem pedir o pin |
---|
495 | this.getContentPane().add(alreadyLoadedPanel); |
---|
496 | break; |
---|
497 | default: |
---|
498 | // Mostra interface de login pedindo o pin |
---|
499 | this.getContentPane().add(pinPanel); |
---|
500 | |
---|
501 | } |
---|
502 | |
---|
503 | this.setVisible(true); |
---|
504 | |
---|
505 | } |
---|
506 | */ |
---|
507 | |
---|
508 | /** |
---|
509 | * Ação executada quando o Botão cancel de PinPanel for pressionado |
---|
510 | * |
---|
511 | */ |
---|
512 | /* |
---|
513 | private void cancelButtonActionPerformed(){ |
---|
514 | |
---|
515 | pinPanel.setVisible(false); |
---|
516 | this.remove(pinPanel); |
---|
517 | this.add(loginPanel); |
---|
518 | loginPanel.setVisible(true); |
---|
519 | this.setVisible(true); |
---|
520 | pinPanel.clearPasswordField(); |
---|
521 | |
---|
522 | } |
---|
523 | */ |
---|
524 | |
---|
525 | /** |
---|
526 | * Ação realizada quando o usuário pressiona o botão Ok ou Prossegir |
---|
527 | * nas telas de login com pin ou sem o pin, respectivamente |
---|
528 | * |
---|
529 | */ |
---|
530 | /* |
---|
531 | private void okButtonActionPerformed(){ |
---|
532 | // atribui o valor da senha para o atributo Pin |
---|
533 | char[] pin = pinPanel.getPin(); |
---|
534 | String[] returnCode = null; |
---|
535 | |
---|
536 | // abre a keystore com o pin e recupera as credenciais do usuário |
---|
537 | try { |
---|
538 | dc.openKeyStore(pin); |
---|
539 | |
---|
540 | returnCode = dc.getCredentials(new String(pin)); |
---|
541 | |
---|
542 | assert (returnCode != null): "Valor de returnCode não pode ser nulo"; |
---|
543 | |
---|
544 | if (Integer.valueOf(returnCode[0]) == 0){ |
---|
545 | |
---|
546 | // Pega usuário e senha de returnCode[1] e returnCode[2], respectivamente |
---|
547 | // adiciona na página e faz o submit. |
---|
548 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
549 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
550 | JSObject loginField = (JSObject) loginForm.getMember("user"); |
---|
551 | loginField.setMember("value", returnCode[1]); |
---|
552 | |
---|
553 | JSObject passwdField = (JSObject) loginForm.getMember("passwd"); |
---|
554 | passwdField.setMember("value", returnCode[2]); |
---|
555 | |
---|
556 | this.pinPanel.clearPasswordField(); |
---|
557 | loginForm.call("submit", null); |
---|
558 | |
---|
559 | } |
---|
560 | else { |
---|
561 | // Mostra mensagem de erro para o usuário |
---|
562 | showGetCredentialsError(returnCode[1]); |
---|
563 | } |
---|
564 | |
---|
565 | } catch (SSLHandshakeException e){ |
---|
566 | e.printStackTrace(); |
---|
567 | JOptionPane.showMessageDialog(this, "Não foi possível validar o certificado do servidor!"); |
---|
568 | } catch (HttpException e) { |
---|
569 | e.printStackTrace(); |
---|
570 | } catch (GeneralSecurityException e){ |
---|
571 | e.printStackTrace(); |
---|
572 | } catch (IOException e) { |
---|
573 | JOptionPane.showMessageDialog(this, "Senha não confere!"); |
---|
574 | } catch (ProviderException e) { |
---|
575 | JOptionPane.showMessageDialog(this, "Token foi removido!"); |
---|
576 | } finally { |
---|
577 | this.pinPanel.clearPasswordField(); |
---|
578 | } |
---|
579 | |
---|
580 | } |
---|
581 | */ |
---|
582 | |
---|
583 | /** |
---|
584 | * Ação realizada quando o usuário pressiona o botão acessar na |
---|
585 | * tela de login com usuário e senha |
---|
586 | * |
---|
587 | */ |
---|
588 | /* |
---|
589 | private void acessarButtonActionPerformed(){ |
---|
590 | |
---|
591 | // Pega usuário e senha dos campos tfUsername e pfPasswd, respectivamente, |
---|
592 | // adiciona na página e faz o submit. |
---|
593 | String username = this.loginPanel.tfUsername.getText(); |
---|
594 | String passwd = String.valueOf(this.loginPanel.pfPasswd.getPassword()); |
---|
595 | |
---|
596 | JSObject document = (JSObject) JSObject.getWindow( this ).getMember("document"); |
---|
597 | JSObject loginForm = (JSObject) document.getMember("flogin"); |
---|
598 | JSObject loginField = (JSObject) loginForm.getMember("user"); |
---|
599 | loginField.setMember("value", username); |
---|
600 | |
---|
601 | JSObject passwdField = (JSObject) loginForm.getMember("passwd"); |
---|
602 | passwdField.setMember("value", passwd); |
---|
603 | |
---|
604 | this.loginPanel.clearPasswordField(); |
---|
605 | loginForm.call("submit", null); |
---|
606 | |
---|
607 | } |
---|
608 | */ |
---|
609 | |
---|
610 | /** |
---|
611 | * Mostra mensagem "Campo PIN não foi preenchido!" quando o botão Ok for pressionado |
---|
612 | * e o campo pin estiver vazio |
---|
613 | * |
---|
614 | */ |
---|
615 | /* |
---|
616 | private void okButtonPinEmpty(){ |
---|
617 | JOptionPane.showMessageDialog(this, "Campo PIN não foi preenchido!"); |
---|
618 | } |
---|
619 | */ |
---|
620 | |
---|
621 | /** |
---|
622 | * Mostra mensagem de erro recebida de dc.getCredentials(); |
---|
623 | * TODO: Mudar este método para ser mais genérico... Todas as mensagens de erro devem ser passadas para este |
---|
624 | * método para serem exibidas. |
---|
625 | * @param errorMsg Mensagem de erro que deve ser exibida |
---|
626 | */ |
---|
627 | /* |
---|
628 | private void showGetCredentialsError(String errorMsg){ |
---|
629 | JOptionPane.showMessageDialog(this, errorMsg); |
---|
630 | } |
---|
631 | |
---|
632 | private final class PinCodePanel extends JPanel implements ActionListener{ |
---|
633 | */ |
---|
634 | /** |
---|
635 | * Gerado automaticamente |
---|
636 | */ |
---|
637 | /* |
---|
638 | private static final long serialVersionUID = 1003857725229120014L; |
---|
639 | |
---|
640 | JPanel pNorte, pCentro, pSul; |
---|
641 | JButton btOk, btCancel; |
---|
642 | JLabel lTitle, lPin; |
---|
643 | JPasswordField pfPin; |
---|
644 | |
---|
645 | // TODO: Implementar um construtor default (sem parâmetros); |
---|
646 | public PinCodePanel(String uid, boolean showPinField){ |
---|
647 | |
---|
648 | this.setLayout(new BorderLayout()); |
---|
649 | Dimension panelsDimension = new Dimension(300, 42); |
---|
650 | Dimension fieldsDimension = new Dimension(80, 20); |
---|
651 | |
---|
652 | pNorte = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
653 | pNorte.setBackground(Color.WHITE); |
---|
654 | pNorte.setPreferredSize(panelsDimension); |
---|
655 | |
---|
656 | pCentro = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
657 | pCentro.setBackground(Color.WHITE); |
---|
658 | pCentro.setPreferredSize(panelsDimension); |
---|
659 | |
---|
660 | pSul = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
661 | pSul.setBackground(Color.WHITE); |
---|
662 | pSul.setPreferredSize(panelsDimension); |
---|
663 | |
---|
664 | JPanel pTitle = new JPanel(new GridLayout(2, 0)); |
---|
665 | pTitle.setBackground(Color.WHITE); |
---|
666 | JLabel lTitle2 = null; |
---|
667 | |
---|
668 | |
---|
669 | if (showPinField){ |
---|
670 | lTitle = new JLabel("Entre com o seu PIN:"); |
---|
671 | lTitle.setHorizontalTextPosition(SwingConstants.CENTER); |
---|
672 | |
---|
673 | pfPin = new JPasswordField(20); |
---|
674 | pfPin.setPreferredSize(fieldsDimension); |
---|
675 | pfPin.addActionListener(this); |
---|
676 | pfPin.setActionCommand("ok"); |
---|
677 | pCentro.add(pfPin); |
---|
678 | btOk = new JButton("Ok"); |
---|
679 | btCancel = new JButton("Cancel"); |
---|
680 | } |
---|
681 | else { |
---|
682 | lTitle = new JLabel("Token inserido e desbloqueado"); |
---|
683 | lTitle.setHorizontalTextPosition(SwingConstants.CENTER); |
---|
684 | lTitle2 = new JLabel(" pelo usuário " + uid + " foi detectado:"); |
---|
685 | lTitle2.setHorizontalTextPosition(SwingConstants.CENTER); |
---|
686 | btOk = new JButton("Prossegir"); |
---|
687 | } |
---|
688 | |
---|
689 | JPanel pTitle1 = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
690 | pTitle1.setPreferredSize(new Dimension(300, 20)); |
---|
691 | pTitle1.setBackground(Color.WHITE); |
---|
692 | pTitle1.add(lTitle); |
---|
693 | pTitle.add(pTitle1); |
---|
694 | if (lTitle2 != null) { |
---|
695 | JPanel pTitle2 = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
696 | pTitle2.setPreferredSize(new Dimension(300,20)); |
---|
697 | pTitle2.setBackground(Color.WHITE); |
---|
698 | pTitle.add(pTitle2); |
---|
699 | pTitle2.add(lTitle2); |
---|
700 | } |
---|
701 | |
---|
702 | pNorte.add(pTitle); |
---|
703 | |
---|
704 | btOk.setMnemonic(KeyEvent.VK_ENTER); |
---|
705 | btOk.setActionCommand("ok"); |
---|
706 | btOk.addActionListener(this); |
---|
707 | pSul.add(btOk); |
---|
708 | |
---|
709 | if (btCancel != null){ |
---|
710 | btCancel.setActionCommand("cancel"); |
---|
711 | btCancel.addActionListener(this); |
---|
712 | pSul.add(btCancel); |
---|
713 | } |
---|
714 | |
---|
715 | this.add(pNorte, BorderLayout.NORTH); |
---|
716 | this.add(pCentro, BorderLayout.CENTER); |
---|
717 | this.add(pSul, BorderLayout.SOUTH); |
---|
718 | } |
---|
719 | |
---|
720 | // design ruim!!! azar :-S |
---|
721 | public char[] getPin() { |
---|
722 | if (pfPin == null){ |
---|
723 | return null; |
---|
724 | } |
---|
725 | return pfPin.getPassword(); |
---|
726 | } |
---|
727 | |
---|
728 | void clearPasswordField(){ |
---|
729 | if (pfPin != null){ |
---|
730 | pfPin.setText(""); |
---|
731 | } |
---|
732 | } |
---|
733 | |
---|
734 | public void actionPerformed(ActionEvent evt) { |
---|
735 | |
---|
736 | String command = evt.getActionCommand(); |
---|
737 | |
---|
738 | // Atribui o valor digitado para o campo |
---|
739 | // senha e esconde a interface e assina o certificado |
---|
740 | if (command.equals("ok")){ |
---|
741 | |
---|
742 | if (pfPin != null && pfPin.getPassword().length <= 0){ |
---|
743 | // Mostra um aviso de que o campo PIN não foi preenchido |
---|
744 | okButtonPinEmpty(); |
---|
745 | } |
---|
746 | else { |
---|
747 | okButtonActionPerformed(); |
---|
748 | } |
---|
749 | |
---|
750 | } |
---|
751 | else if (command.equals("cancel")){ |
---|
752 | cancelButtonActionPerformed(); |
---|
753 | } |
---|
754 | } |
---|
755 | |
---|
756 | |
---|
757 | } |
---|
758 | |
---|
759 | private final class LoginPanel extends JPanel implements ActionListener{ |
---|
760 | */ |
---|
761 | /** |
---|
762 | * |
---|
763 | */ |
---|
764 | /* |
---|
765 | private static final long serialVersionUID = -8604718192554937222L; |
---|
766 | JButton btAcessar; |
---|
767 | JTextField tfUsername; |
---|
768 | JPasswordField pfPasswd; |
---|
769 | |
---|
770 | public LoginPanel(String uid){ |
---|
771 | |
---|
772 | this.setLayout(new BorderLayout()); |
---|
773 | |
---|
774 | JPanel panelCredentials = new JPanel(new GridLayout(2, 0)); |
---|
775 | panelCredentials.setBackground(Color.WHITE); |
---|
776 | panelCredentials.setPreferredSize(new Dimension(280, 84)); |
---|
777 | |
---|
778 | JPanel panelUsername = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
779 | panelUsername.setBackground(Color.WHITE); |
---|
780 | panelUsername.setPreferredSize(new Dimension(300, 42)); |
---|
781 | |
---|
782 | JLabel labelUsername = new JLabel("Usuário"); |
---|
783 | panelUsername.add(labelUsername); |
---|
784 | labelUsername.setPreferredSize(new Dimension(100, 40)); |
---|
785 | |
---|
786 | tfUsername = new JTextField(15); |
---|
787 | tfUsername.setText(uid); |
---|
788 | panelUsername.add(tfUsername); |
---|
789 | |
---|
790 | JPanel panelPasswd = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
791 | panelPasswd.setPreferredSize(new Dimension(300, 42)); |
---|
792 | JLabel labelPasswd = new JLabel("Senha"); |
---|
793 | panelPasswd.add(labelPasswd); |
---|
794 | panelPasswd.setBackground(Color.WHITE); |
---|
795 | labelPasswd.setPreferredSize(new Dimension(100, 20)); |
---|
796 | |
---|
797 | pfPasswd = new JPasswordField(15); |
---|
798 | panelPasswd.add(pfPasswd); |
---|
799 | |
---|
800 | panelCredentials.add(panelUsername); |
---|
801 | panelCredentials.add(panelPasswd); |
---|
802 | this.add(panelCredentials, BorderLayout.CENTER); |
---|
803 | |
---|
804 | btAcessar = new JButton("Acessar"); |
---|
805 | btAcessar.setActionCommand("acessar"); |
---|
806 | btAcessar.addActionListener(this); |
---|
807 | JPanel panelBtAcessar = new JPanel(new FlowLayout(FlowLayout.CENTER)); |
---|
808 | panelBtAcessar.setBackground(Color.WHITE); |
---|
809 | panelBtAcessar.setPreferredSize(new Dimension(300, 42)); |
---|
810 | panelBtAcessar.add(btAcessar); |
---|
811 | |
---|
812 | this.add(panelBtAcessar, BorderLayout.SOUTH); |
---|
813 | this.setVisible(true); |
---|
814 | |
---|
815 | } |
---|
816 | |
---|
817 | public void actionPerformed(ActionEvent e) { |
---|
818 | if (e.getActionCommand().equals("acessar")){ |
---|
819 | acessarButtonActionPerformed(); |
---|
820 | } |
---|
821 | |
---|
822 | } |
---|
823 | |
---|
824 | void clearPasswordField(){ |
---|
825 | pfPasswd.setText(""); |
---|
826 | } |
---|
827 | |
---|
828 | } |
---|
829 | */ |
---|
830 | |
---|
831 | } |
---|