AbstractGriffonController.java
01 /*
02  * Copyright 2008-2016 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 }