-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathserver-job-single.js
70 lines (65 loc) · 2.12 KB
/
server-job-single.js
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
"use strict";
var util = require('util');
var events = require('events');
var StreamReplay = require('./stream-replay');
var client = require('./server-connection').prototype;
var SingleJob = module.exports = function (id, func, priority, body) {
this.id = id;
this.function = func;
this.priority = priority;
this.buffer = body.pipe(new StreamReplay());
this.bufferSize = body.length;
this.worker = null;
this.complete = 0;
this.total = 0;
this.queued = new Date();
events.EventEmitter.call(this);
}
util.inherits( SingleJob, events.EventEmitter );
SingleJob.prototype.addClient = function(client) {
this.client = client;
}
SingleJob.prototype.removeClient = function(client) {
this.client = null;
this.emit('no-clients');
}
SingleJob.prototype.getBody = function () {
var body = this.buffer.spawn();
body.length = this.bufferSize;
return body;
}
// This weird bit of indirection allows us to have another class that calls
// the same method on multiple classes.
SingleJob.prototype.call = function(method,args) {
if (this.client==null) return;
method.apply(this.client,args);
}
SingleJob.prototype.sendWorkComplete = function(body) {
this.call(client.sendWorkComplete,[this.id,body]);;
this.emit('job-complete');
}
SingleJob.prototype.sendWorkData = function(body) {
this.call(client.sendWorkData,[this.id,body]);;
}
SingleJob.prototype.sendWorkWarning = function(body) {
this.call(client.sendWorkWarning,[this.id,body]);;
}
SingleJob.prototype.sendWorkException = function(body) {
this.call(client.sendWorkException,[this.id,body]);;
this.emit('job-complete');
}
SingleJob.prototype.sendWorkFail = function(body) {
this.call(client.sendWorkFail,[this.id,body]);;
this.emit('job-complete');
}
SingleJob.prototype.sendWorkStatus = function(complete,total) {
this.complete = complete;
this.total = total;
this.call(client.WorkStatus,[this.id,complete,total]);;
}
SingleJob.prototype.hasWorker = function () {
return this.worker ? true : false;
}
SingleJob.prototype.getStatus = function () {
return {complete: this.complete, total: this.total};
}