128 lines
5.1 KiB
Java
Executable file
128 lines
5.1 KiB
Java
Executable file
/*
|
|
* Copyright (c) 2015 ezivkoc
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
package wa.server.page;
|
|
|
|
import wa.server.WAContext;
|
|
import wa.server.page.struct.WANavigation;
|
|
import wa.server.plugin.WAService;
|
|
import wa.server.plugin.WAServiceConfig;
|
|
import zutil.io.file.FileUtil;
|
|
import zutil.log.LogUtil;
|
|
import zutil.net.http.HttpHeader;
|
|
import zutil.parser.DataNode;
|
|
import zutil.parser.Templator;
|
|
import zutil.plugin.PluginManager;
|
|
|
|
import java.io.IOException;
|
|
import java.util.ArrayList;
|
|
import java.util.Map;
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
|
|
/**
|
|
* Created by Ziver on 2015-04-06.
|
|
*/
|
|
public class ServicePage implements WAPage {
|
|
private static final Logger log = LogUtil.getLogger();
|
|
public static final String NAVIGATION_NAME = "Services";
|
|
private static final String TMPL_FILE = "WebContent/page/ServicePage.tmpl";
|
|
|
|
private ServiceStatusPage rootStatusPage;
|
|
private ArrayList<WAService> services;
|
|
private ArrayList<ServiceStatusPage> statusPages;
|
|
private ArrayList<LogPage> logPages;
|
|
private ArrayList<ConfigPage> configPages;
|
|
|
|
public ServicePage(PluginManager pluginManager){
|
|
this.services = pluginManager.toArray(WAService.class);
|
|
this.rootStatusPage = new ServiceStatusPage(pluginManager);
|
|
this.statusPages = new ArrayList<>();
|
|
this.logPages = new ArrayList<>();
|
|
this.configPages = new ArrayList<>();
|
|
|
|
WANavigation nav = WAContext.getRootNav().createSubNav(NAVIGATION_NAME);
|
|
nav.setResource(this);
|
|
for(WAService plugin : services) {
|
|
statusPages.add(new ServiceStatusPage(plugin.getStatus()));
|
|
logPages.add(new LogPage(plugin.getLog()));
|
|
|
|
WANavigation serviceNav = nav.createSubNav(plugin.getName());
|
|
serviceNav.setResource(plugin);
|
|
for(WAServiceConfig conf : plugin.getConfigurations()){
|
|
ConfigPage page = new ConfigPage(conf);
|
|
configPages.add(page);
|
|
serviceNav.createSubNav(conf.getName())
|
|
.setResource(page);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@Override
|
|
public Templator htmlResponse(WAContext context,
|
|
HttpHeader client_info,
|
|
Map<String, Object> session,
|
|
Map<String, String> cookie,
|
|
Map<String, String> request) {
|
|
|
|
try {
|
|
Object resource = context.getBreadcrumb().get(context.getBreadcrumb().size()-1).getResource();
|
|
int index;
|
|
if((index = configPages.indexOf(resource)) >= 0){
|
|
return configPages.get(index).htmlResponse(context, client_info, session, cookie, request);
|
|
}
|
|
else if ((index = services.indexOf(resource)) >= 0) {
|
|
WAService obj = services.get(index);
|
|
ServiceStatusPage statusPage = statusPages.get(index);
|
|
LogPage logPage = logPages.get(index);
|
|
|
|
Templator tmpl = new Templator(FileUtil.find(TMPL_FILE));
|
|
if(statusPage != null)
|
|
tmpl.set("service_status",
|
|
statusPage.htmlResponse(context, client_info, session, cookie, request));
|
|
if(logPage != null)
|
|
tmpl.set("service_logs",
|
|
statusPage.htmlResponse(context, client_info, session, cookie, request));
|
|
return tmpl;
|
|
}
|
|
else{ // root page
|
|
return rootStatusPage.htmlResponse(context, client_info, session, cookie, request);
|
|
}
|
|
|
|
}catch (IOException e){
|
|
log.log(Level.SEVERE, null, e);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
public DataNode jsonResponse(WAContext context,
|
|
HttpHeader client_info,
|
|
Map<String, Object> session,
|
|
Map<String, String> cookie,
|
|
Map<String, String> request){
|
|
|
|
return null;
|
|
}
|
|
|
|
|
|
}
|