Commit 0a8b63041025674e8689fc6df0b7cd13056bcda7
1 parent
459726a3
Exists in
master
Colocando as mensagens no resource bundle
Showing
3 changed files
with
76 additions
and
3 deletions
Show diff stats
impl/extension/jaas/src/main/java/br/gov/frameworkdemoiselle/security/JAASAuthenticator.java
@@ -54,6 +54,9 @@ import javax.security.auth.login.LoginException; | @@ -54,6 +54,9 @@ import javax.security.auth.login.LoginException; | ||
54 | 54 | ||
55 | import br.gov.frameworkdemoiselle.annotation.Priority; | 55 | import br.gov.frameworkdemoiselle.annotation.Priority; |
56 | import br.gov.frameworkdemoiselle.internal.configuration.JAASConfig; | 56 | import br.gov.frameworkdemoiselle.internal.configuration.JAASConfig; |
57 | +import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | ||
58 | +import br.gov.frameworkdemoiselle.util.ResourceBundle; | ||
59 | +import br.gov.frameworkdemoiselle.util.Strings; | ||
57 | 60 | ||
58 | @SessionScoped | 61 | @SessionScoped |
59 | @Priority(EXTENSIONS_L1_PRIORITY) | 62 | @Priority(EXTENSIONS_L1_PRIORITY) |
@@ -61,6 +64,8 @@ public class JAASAuthenticator implements Authenticator { | @@ -61,6 +64,8 @@ public class JAASAuthenticator implements Authenticator { | ||
61 | 64 | ||
62 | private static final long serialVersionUID = 1L; | 65 | private static final long serialVersionUID = 1L; |
63 | 66 | ||
67 | + private ResourceBundle bundle; | ||
68 | + | ||
64 | private User user; | 69 | private User user; |
65 | 70 | ||
66 | private final Subject subject; | 71 | private final Subject subject; |
@@ -136,7 +141,13 @@ public class JAASAuthenticator implements Authenticator { | @@ -136,7 +141,13 @@ public class JAASAuthenticator implements Authenticator { | ||
136 | } | 141 | } |
137 | 142 | ||
138 | public LoginContext createLoginContext() throws LoginException { | 143 | public LoginContext createLoginContext() throws LoginException { |
139 | - return new LoginContext(config.getLoginModuleName(), this.subject, createCallbackHandler()); | 144 | + String name = config.getLoginModuleName(); |
145 | + | ||
146 | + if (Strings.isEmpty(name)) { | ||
147 | + throw new SecurityException(getBundle().getString("required-login-module-name")); | ||
148 | + } | ||
149 | + | ||
150 | + return new LoginContext(name, this.subject, createCallbackHandler()); | ||
140 | } | 151 | } |
141 | 152 | ||
142 | private CallbackHandler createCallbackHandler() { | 153 | private CallbackHandler createCallbackHandler() { |
@@ -151,10 +162,20 @@ public class JAASAuthenticator implements Authenticator { | @@ -151,10 +162,20 @@ public class JAASAuthenticator implements Authenticator { | ||
151 | ((PasswordCallback) callbacks[i]).setPassword(credentials.getPassword().toCharArray()); | 162 | ((PasswordCallback) callbacks[i]).setPassword(credentials.getPassword().toCharArray()); |
152 | 163 | ||
153 | } else { | 164 | } else { |
154 | - System.out.println("XXXXXXXXXXXXXXXXXXXXXXXXXXXX Unsupported callback " + callbacks[i]); | 165 | + // TODO Utilizar o logger... |
166 | + | ||
167 | + System.out.println(getBundle().getString("unsupported-callback", callbacks[i])); | ||
155 | } | 168 | } |
156 | } | 169 | } |
157 | } | 170 | } |
158 | }; | 171 | }; |
159 | } | 172 | } |
173 | + | ||
174 | + private ResourceBundle getBundle() { | ||
175 | + if (this.bundle == null) { | ||
176 | + this.bundle = ResourceBundleProducer.create("demoiselle-jaas-bundle"); | ||
177 | + } | ||
178 | + | ||
179 | + return this.bundle; | ||
180 | + } | ||
160 | } | 181 | } |
impl/extension/jaas/src/main/java/br/gov/frameworkdemoiselle/security/JAASAuthorizer.java
@@ -44,14 +44,19 @@ import java.util.Enumeration; | @@ -44,14 +44,19 @@ import java.util.Enumeration; | ||
44 | 44 | ||
45 | import javax.security.auth.Subject; | 45 | import javax.security.auth.Subject; |
46 | 46 | ||
47 | +import br.gov.frameworkdemoiselle.DemoiselleException; | ||
47 | import br.gov.frameworkdemoiselle.annotation.Priority; | 48 | import br.gov.frameworkdemoiselle.annotation.Priority; |
49 | +import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | ||
48 | import br.gov.frameworkdemoiselle.util.Beans; | 50 | import br.gov.frameworkdemoiselle.util.Beans; |
51 | +import br.gov.frameworkdemoiselle.util.ResourceBundle; | ||
49 | 52 | ||
50 | @Priority(EXTENSIONS_L1_PRIORITY) | 53 | @Priority(EXTENSIONS_L1_PRIORITY) |
51 | public class JAASAuthorizer implements Authorizer { | 54 | public class JAASAuthorizer implements Authorizer { |
52 | 55 | ||
53 | private static final long serialVersionUID = 1L; | 56 | private static final long serialVersionUID = 1L; |
54 | 57 | ||
58 | + private ResourceBundle bundle; | ||
59 | + | ||
55 | @Override | 60 | @Override |
56 | public boolean hasRole(String role) { | 61 | public boolean hasRole(String role) { |
57 | boolean result = false; | 62 | boolean result = false; |
@@ -83,6 +88,15 @@ public class JAASAuthorizer implements Authorizer { | @@ -83,6 +88,15 @@ public class JAASAuthorizer implements Authorizer { | ||
83 | 88 | ||
84 | @Override | 89 | @Override |
85 | public boolean hasPermission(String resource, String operation) { | 90 | public boolean hasPermission(String resource, String operation) { |
86 | - return true; | 91 | + throw new DemoiselleException(getBundle().getString("has-permission-not-supported", |
92 | + RequiredPermission.class.getSimpleName())); | ||
93 | + } | ||
94 | + | ||
95 | + private ResourceBundle getBundle() { | ||
96 | + if (this.bundle == null) { | ||
97 | + this.bundle = ResourceBundleProducer.create("demoiselle-jaas-bundle"); | ||
98 | + } | ||
99 | + | ||
100 | + return this.bundle; | ||
87 | } | 101 | } |
88 | } | 102 | } |
impl/extension/jaas/src/main/resources/demoiselle-jaas-bundle.properties
0 → 100644
@@ -0,0 +1,38 @@ | @@ -0,0 +1,38 @@ | ||
1 | +# Demoiselle Framework | ||
2 | +# Copyright (C) 2010 SERPRO | ||
3 | +# ---------------------------------------------------------------------------- | ||
4 | +# This file is part of Demoiselle Framework. | ||
5 | +# | ||
6 | +# Demoiselle Framework is free software; you can redistribute it and/or | ||
7 | +# modify it under the terms of the GNU Lesser General Public License version 3 | ||
8 | +# as published by the Free Software Foundation. | ||
9 | +# | ||
10 | +# This program is distributed in the hope that it will be useful, | ||
11 | +# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | +# GNU General Public License for more details. | ||
14 | +# | ||
15 | +# You should have received a copy of the GNU Lesser General Public License version 3 | ||
16 | +# along with this program; if not, see <http://www.gnu.org/licenses/> | ||
17 | +# or write to the Free Software Foundation, Inc., 51 Franklin Street, | ||
18 | +# Fifth Floor, Boston, MA 02110-1301, USA. | ||
19 | +# ---------------------------------------------------------------------------- | ||
20 | +# Este arquivo é parte do Framework Demoiselle. | ||
21 | +# | ||
22 | +# O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | ||
23 | +# modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | ||
24 | +# do Software Livre (FSF). | ||
25 | +# | ||
26 | +# Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | ||
27 | +# GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | ||
28 | +# APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | ||
29 | +# para maiores detalhes. | ||
30 | +# | ||
31 | +# Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | ||
32 | +# "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | ||
33 | +# ou escreva para a Fundação do Software Livre (FSF) Inc., | ||
34 | +# 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | ||
35 | + | ||
36 | +has-permission-not-supported=N\u00E3o \u00E9 poss\u00EDvel utilizar @{0}, pois esta funcionalidade n\u00E3o \u00E9 suportada pelo JAAS | ||
37 | +unsupported-callback=Callback n\u00E3o suportado\: {0} | ||
38 | +required-login-module-name=\u00C9 preciso definir a propriedade frameworkdemoiselle.security.login.module.name no arquivo demoiselle.properties |