01 /*
02 * Copyright 2008-2015 the original author or authors.
03 *
04 * Licensed under the Apache License, Version 2.0 (the "License");
05 * you may not use this file except in compliance with the License.
06 * You may obtain a copy of the License at
07 *
08 * http://www.apache.org/licenses/LICENSE-2.0
09 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16 package org.codehaus.griffon.runtime.core.artifact;
17
18 import griffon.core.GriffonApplication;
19 import griffon.core.artifact.GriffonController;
20 import griffon.core.artifact.GriffonControllerClass;
21 import griffon.core.controller.Action;
22 import griffon.core.controller.ActionManager;
23
24 import javax.annotation.Nonnull;
25 import javax.annotation.Nullable;
26 import javax.inject.Inject;
27
28 import static griffon.util.GriffonNameUtils.requireNonBlank;
29
30 /**
31 * Base implementation of the GriffonController interface.
32 *
33 * @author Andres Almiray
34 * @since 2.0.0
35 */
36 public abstract class AbstractGriffonController extends AbstractGriffonMvcArtifact implements GriffonController {
37 public AbstractGriffonController() {
38
39 }
40
41 /**
42 * Creates a new instance of this class.
43 *
44 * @param application the GriffonApplication that holds this artifact.
45 * @deprecated Griffon prefers field injection over constructor injector for artifacts as of 2.1.0
46 */
47 @Inject
48 @Deprecated
49 public AbstractGriffonController(@Nonnull GriffonApplication application) {
50 super(application);
51 }
52
53 @Nonnull
54 @Override
55 protected String getArtifactType() {
56 return GriffonControllerClass.TYPE;
57 }
58
59 @Nonnull
60 protected ActionManager getActionManager() {
61 return getApplication().getActionManager();
62 }
63
64 public void invokeAction(@Nonnull String name, Object... args) {
65 getActionManager().invokeAction(this, requireNonBlank(name, "Argument 'name' must not be blank"), args);
66 }
67
68 @Nullable
69 protected Action actionFor(@Nonnull String actionName) {
70 return getActionManager().actionFor(this, actionName);
71 }
72 }
|