summaryrefslogtreecommitdiffstats
path: root/gearman/controllerWorker/ControllerWorker/BootWorker.java
blob: f26bf12b81fb5d9ddaaae694687600e241448ec7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package ControllerWorker;

import java.util.StringTokenizer;
import java.util.Vector;

import org.gearman.client.GearmanJobResult;
import org.gearman.client.GearmanJobResultImpl;
import org.gearman.util.ByteUtils;
import org.gearman.worker.AbstractGearmanFunction;

import org.json.simple.JSONArray;
import org.json.simple.JSONObject;
import org.json.simple.JSONValue;

import org.apache.log4j.Logger;

public class BootWorker extends AbstractGearmanFunction {
	static final Logger logger = Logger.getLogger(BootWorker.class);

	@Override
	public String getName() {
		return "boot";
	}

	@Override
	public GearmanJobResult executeFunction() {
		String data = ByteUtils.fromUTF8Bytes((byte[]) this.data);
		Vector<Client> clients = new Vector<Client>();
		JSONObject jsonObject = (JSONObject) JSONValue.parse(data);
		String event = jsonObject.get("eventName").toString();
		String eventOS = jsonObject.get("eventOS").toString();
		JSONArray jsonArray = (JSONArray) jsonObject.get("clients");

		for (Object clientObj : jsonArray) {
			JSONObject clientJsonObj = (JSONObject) clientObj;
			Client client = new Client(clientJsonObj,
					"The booting process of the client has been started.");
			clients.add(client);
		}

		String gearmanServerHost = ControllerWorkerMain.getIniFile().getString(
				"gearman.server.host");
		int gearmanServerPort = Integer.parseInt(ControllerWorkerMain
				.getIniFile().getString("gearman.server.port"));
		long waitTime = Long.parseLong(ControllerWorkerMain.getIniFile()
				.getString("gearman.worker.waitTime"));
		int updateRate = Integer.parseInt(ControllerWorkerMain.getIniFile()
				.getString("gearman.worker.updateRate"));
		String blacklist = ControllerWorkerMain.getIniFile().getString(
				"gearman.worker.ps.blacklist");
		StringTokenizer blacklistTokenizer = new StringTokenizer(blacklist, ",");
		String whitelist = ControllerWorkerMain.getIniFile().getString(
				"gearman.worker.ps.whitelist");
		StringTokenizer whitelistTokenizer = new StringTokenizer(whitelist, ",");
		Vector<String> psWhitelist = new Vector<String>();
		Vector<String> psBlacklist = new Vector<String>();
		while (whitelistTokenizer.hasMoreTokens()) {
			String whiteEntry = whitelistTokenizer.nextToken();
			psWhitelist.add(whiteEntry);
		}
		while (blacklistTokenizer.hasMoreTokens()) {
			String blackEntry = blacklistTokenizer.nextToken();
			psBlacklist.add(blackEntry);
		}

		Boot boot = new Boot(event, clients, eventOS, updateRate, waitTime,
				psWhitelist, psBlacklist, gearmanServerHost, gearmanServerPort);
		StatusWorker.BOOTTHREADS.put(event, boot);
		boot.start();
		logger.info("Booting of " + event + " started");
		String res = "Booting started";

		byte[] warnings = new byte[0];
		byte[] exceptions = new byte[0];
		int numerator = 0;
		int denominator = 0;
		GearmanJobResult gjr = new GearmanJobResultImpl(this.jobHandle, true,
				res.getBytes(), warnings, exceptions, numerator, denominator);
		return gjr;
	}
}