View Javadoc
1   /*
2    * Copyright (c) 2016 ingenieux Labs
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.apache.org/licenses/LICENSE-2.0
9    *
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  
17  package br.com.ingenieux.mojo.beanstalk.env;
18  
19  import com.amazonaws.services.elasticbeanstalk.model.RestartAppServerRequest;
20  
21  import org.apache.maven.plugin.MojoExecutionException;
22  import org.apache.maven.plugin.MojoFailureException;
23  import org.apache.maven.plugins.annotations.Mojo;
24  
25  import br.com.ingenieux.mojo.beanstalk.AbstractNeedsEnvironmentMojo;
26  
27  /**
28   * Restarts the Application Server
29   *
30   * See the docs for the <a href= "http://docs.amazonwebservices.com/elasticbeanstalk/latest/api/API_RestartAppServer.html"
31   * >RestartAppServer API</a> call.
32   *
33   * @author Aldrin Leal
34   * @since 0.1.0
35   */
36  @Mojo(name = "restart-application-server")
37  public class RestartAppServerMojo extends AbstractNeedsEnvironmentMojo {
38  
39    @Override
40    protected Object executeInternal() throws MojoExecutionException, MojoFailureException {
41      RestartAppServerRequest req = new RestartAppServerRequest();
42  
43      req.setEnvironmentId(curEnv.getEnvironmentId());
44      req.setEnvironmentName(curEnv.getEnvironmentName());
45  
46      getService().restartAppServer(req);
47  
48      return null;
49    }
50  }