summaryrefslogtreecommitdiffstats
path: root/install/ui/src/freeipa/phases.js
blob: 18acecc8a9110b1ab6cc103e2c7aac2c57dea531 (plain)
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*  Authors:
 *    Petr Vobornik <pvoborni@redhat.com>
 *
 * Copyright (C) 2012 Red Hat
 * see file 'COPYING' for use and warranty information
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

/**
 * Phases module provides access mainly serves as an registration point for
 * phase tasks. It also provides access to Phase controller.
 */
define([
    './_base/Phase_controller'
], function(Phase_controller) {

    /**
     * Phases specification object.
     *
     * @type String[]
     */
    var spec = {
        phases: [
            //'resource-load', // implicit phase
            'customization',
            'registration',
            'init',
            'metadata',
            'post-metadata',
            'profile',
            'runtime',
            'shutdown'
        ]
    };

    /**
     * Phases module
     */
    var phases = {
        /**
         * Phases controller
         */
        controller: new Phase_controller(spec),

        /**
         * Registers a phase task
         *
         * @param {String} Phase name
         * @param {Function} Task handler. Should return promise if async.
         * @param {Number} Priority of task. Default 10.
         */
        on: function(phase_name, handler, priority) {
            this.controller.add_task(phase_name, handler, priority);
        },

       /**
         * Adds a phase
         *
         * Possible options:
         *   before: 'name-of-phase'
         *   after: 'name-of-phase'
         *   position: 'position for new phase'
         *
         * @param {String} Phase name
         * @param {Object} Options
         */
        add: function(phase_name, options) {
            this.controller.add_phase(phase_name, null, options);
        },

        /**
         * Checks if phases with given name exists
         *
         * @param {String} Name
         * @return {Boolean}
         */
        exists: function(name) {
            return this.controller.exists(name);
        }
    };

    return phases;
});