001/* 002 * Stallion Core: A Modern Web Framework 003 * 004 * Copyright (C) 2015 - 2016 Stallion Software LLC. 005 * 006 * This program is free software: you can redistribute it and/or modify it under the terms of the 007 * GNU General Public License as published by the Free Software Foundation, either version 2 of 008 * the License, or (at your option) any later version. This program is distributed in the hope that 009 * it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of 010 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public 011 * License for more details. You should have received a copy of the GNU General Public License 012 * along with this program. If not, see <http://www.gnu.org/licenses/gpl-2.0.html>. 013 * 014 * 015 * 016 */ 017 018package io.stallion.boot; 019 020import io.stallion.asyncTasks.AsyncCoordinator; 021import io.stallion.jobs.JobCoordinator; 022import io.stallion.settings.Settings; 023 024import static io.stallion.utils.Literals.*; 025import static io.stallion.Context.*; 026 027 028public class WorkerCommandAction implements StallionRunAction<ServeCommandOptions> { 029 030 @Override 031 public String getActionName() { 032 return "worker"; 033 } 034 035 @Override 036 public String getHelp() { 037 return "runs specified asynchronous jobs and/or recurring jobs"; 038 } 039 040 @Override 041 public void loadApp(ServeCommandOptions options) { 042 AppContextLoader.loadCompletely(options); 043 044 AppContextLoader.instance().startAllServices(); 045 } 046 047 @Override 048 public ServeCommandOptions newCommandOptions() { 049 return new ServeCommandOptions(); 050 } 051 052 @Override 053 public void execute(ServeCommandOptions options) throws Exception { 054 055 056 057 058 059 System.out.print("-------------------------------------------------------\n"); 060 String art = "" + 061 " _,_\n" + 062 " ;'._\\\n" + 063 " ';) \\._, Stallion worker now running." + 064 " / /`-'\n" + 065 " ~~( )/\n" + 066 " )))\n" + 067 " \\\\\\"; 068 System.out.print(art); 069 System.out.print("\n-------------------------------------------------------\n"); 070 071 072 JobCoordinator.currentThread().join(); 073 074 System.out.println("Shutting down async coordinator"); 075 AsyncCoordinator.gracefulShutdown(); 076 } 077}