forked from googleapis/cloud-debug-nodejs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.ts
93 lines (81 loc) · 2.76 KB
/
index.ts
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
// Copyright 2015 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import {DebugAgentConfig, StackdriverConfig} from './agent/config';
import {Debuglet, IsReady} from './agent/debuglet';
// eslint-disable-next-line @typescript-eslint/no-var-requires
const pjson = require('../../package.json');
import * as util from 'util';
const debuglog = util.debuglog('cdbg');
// Singleton.
let debuglet: Debuglet | undefined;
/**
* Start the Debug agent that will make your application available for debugging
* with Stackdriver Debug.
*
* @param options - Authentication and agent configuration.
*
* @resource [Introductory video]{@link
* https://www.youtube.com/watch?v=tyHcK_kAOpw}
*
* @example
* ```
* debug.start();
* ```
*/
export function start(
options?: DebugAgentConfig | StackdriverConfig
): Debuglet | IsReady {
options = options || {};
const agentConfig: DebugAgentConfig = mergeConfigs(options);
// forceNewAgent_ is for testing purposes only.
if (debuglet && !agentConfig.forceNewAgent_) {
throw new Error('Debug Agent has already been started');
}
debuglog('Running with firebase backend.');
debuglet = new Debuglet(pjson, agentConfig);
debuglet.start();
return agentConfig.testMode_ ? debuglet : debuglet.isReadyManager;
}
/**
* If the given `options` object has a `debug` property
* of the same type, this function returns the union of the
* properties in `options.debug` and `options` except that
* the returned object no longer has a `debug` property.
* If a field exists in both `options` and `options.debug`,
* the value in `option.debug` takes precedence.
*/
function mergeConfigs<T>(options: T & {debug?: T}): T {
if (!options.debug) {
return options;
}
const result = Object.assign({}, options);
delete result.debug;
return Object.assign(result, options.debug);
}
/* Used to access the agent if it has been started. Returns the agent
* if the agent has been started. Otherwise, `undefined` is returned.
*/
export function get(): Debuglet | undefined {
return debuglet;
}
/**
* Cleanly shut down the debug agent.
*
* This will free up all resources. It may be necessary to call this to allow
* your process to shut down cleanly.
*/
export function stop(): void {
debuglet?.stop();
debuglet = undefined;
}