01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: * See the License for the specific language governing permissions and
15: * limitations under the License.
16: *
17: */
18:
19: /* $Id: DelegatingAuthenticatorAction.java 42616 2004-03-03 12:56:33Z gregor $ */
20:
21: package org.apache.lenya.cms.cocoon.acting;
22:
23: import java.util.Collections;
24: import java.util.Map;
25:
26: import org.apache.avalon.framework.parameters.Parameters;
27: import org.apache.cocoon.environment.ObjectModelHelper;
28: import org.apache.cocoon.environment.Redirector;
29: import org.apache.cocoon.environment.Request;
30: import org.apache.cocoon.environment.SourceResolver;
31:
32: /**
33: * Authenticator action that delegates the authentication to an access controller.
34: */
35: public class DelegatingAuthenticatorAction extends AccessControlAction {
36:
37: /**
38: * @see org.apache.lenya.cms.cocoon.acting.AccessControlAction#doAct(org.apache.cocoon.environment.Redirector, org.apache.cocoon.environment.SourceResolver, java.util.Map, java.lang.String, org.apache.avalon.framework.parameters.Parameters)
39: */
40: protected Map doAct(Redirector redirector, SourceResolver resolver,
41: Map objectModel, String source, Parameters parameters)
42: throws Exception {
43:
44: getLogger().debug("Authenticating request");
45:
46: Request request = ObjectModelHelper.getRequest(objectModel);
47: Map result = null;
48: if (getAccessController().authenticate(request)) {
49: getLogger().debug("Authentication successful.");
50: result = Collections.EMPTY_MAP;
51: } else {
52: getLogger().debug("Authentication failed.");
53: }
54: return result;
55: }
56:
57: }
|