File size: 1,560 Bytes
19605ab
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
// Just emits "rotate" events at the right time.
// Does not know about a rotating file stream.
'use strict';

var assert = require('assert');
var EventEmitter = require('events').EventEmitter;
var _ = require('lodash');

var optionParser = require('./optionParser');
var nextRotTime = require('./nextrotationtime');

var setLongTimeout = require('./setlongtimeout');

var _DEBUG = false;

function PeriodRotateTrigger(options) {
    var base = new EventEmitter;

    var periodNum = 1;
    var periodScope = 'd';

    var rotAt = null;
    var timeout = null;


    function setupNextRotation() {
        // Only step the rotation time forward if the rotation time is passed
        if (rotAt <= Date.now()) {
            rotAt = nextRotTime(rotAt, periodScope, periodNum);
        }

        timeout = setLongTimeout(rotAt, false, function () {
            timeout = null;
            base.emit('rotate', {date: rotAt});
        });
    }

    function shutdown() {
        if (timeout) {
            timeout.clear();
        }
        timeout = null;
    }

    function newFile() {
        if (timeout) {
            timeout.clear();
        }
        setupNextRotation();
    }

    function logWrite() {
        // Do nothing
    }

    var parsed = optionParser.parsePeriod(options.period);
    periodScope = parsed.periodScope;
    periodNum = parsed.periodNum;

    setupNextRotation();

    return _.extend({}, {
        newFile: newFile,
        logWrite: logWrite,
        shutdown: shutdown
    }, base);
};

module.exports = PeriodRotateTrigger;