forked from bcoe/cloud-debug-nodejs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstackdriver.ts
120 lines (107 loc) · 3.51 KB
/
stackdriver.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
// Copyright 2017 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.
export declare type Action = 'CAPTURE' | 'LOG';
export declare type Reference =
| 'UNSPECIFIED'
| 'BREAKPOINT_SOURCE_LOCATION'
| 'BREAKPOINT_CONDITION'
| 'BREAKPOINT_EXPRESSION'
| 'BREAKPOINT_AGE'
| 'VARIABLE_NAME'
| 'VARIABLE_VALUE';
export interface FormatMessage {
format: string;
// TODO: The code expects the `parameters` field to be optional.
// Verify if this aligns with the API reference.
parameters?: string[];
}
export interface StatusMessage {
isError: boolean;
refersTo: Reference;
description: FormatMessage;
}
export interface SourceLocation {
path: string;
// TODO: The code assumes a SourceLocation has a `column` attribute, but
// the API reference doesn't mention it.
// TODO: The code doesn't always set the column attribute. Is it optional?
column?: number;
line: number;
}
export declare type LogLevel = 'INFO' | 'WARNING' | 'ERROR';
export interface Variable {
// TODO: Some places in the code assume the fields below are all optional.
// Determine if that is the case.
varTableIndex?: number;
name?: string;
value?: string;
type?: string;
members?: Variable[];
status?: StatusMessage;
}
export interface StackFrame {
function: string;
location: SourceLocation;
arguments: Variable[];
locals: Variable[];
}
// TODO: This is only needed for the Breakpoint.create(d)Time attribute.
// Determine if this is actually needed or if the create(d)Time attribute
// should only be a string.
export interface Timestamp {
seconds: string; // int64
nano: string; // int32
}
export interface Breakpoint {
stackFrames: StackFrame[];
// TODO: Update the code so that `|null` is not needed.
evaluatedExpressions: Array<Variable | null>;
// TODO: Update the code so that `|null` is not needed.
variableTable: Array<Variable | null>;
id: BreakpointId;
// TODO: The debug code assumes the rest of these members
// are optional. Determine if this is correct.
action?: Action;
location?: SourceLocation;
condition?: string;
expressions?: string[];
logMessageFormat?: string;
logLevel?: LogLevel;
isFinalState?: boolean;
// TODO: The API reference says the following attribute is `createTime`
// However, the existing code is using `createdTime`.
// See:
// https://cloud.google.com/debugger/api/reference/rest/v2/debugger.debuggees.breakpoints#breakpoint
// In addtion, the API reference says the `create(d)Time` attribute
// is a string in Timestamp format, but the code assumes it is a
// Timestamp object
createdTime?: Timestamp;
finalTime?: string;
userEmail?: string;
status?: StatusMessage;
labels?: {
[key: string]: string;
};
}
export type BreakpointId = string;
export interface ListBreakpointsQuery {
waitToken?: string;
successOnTimeout?: boolean;
agentId?: string;
}
export interface ListBreakpointsResponse {
breakpoints: Breakpoint[];
nextWaitToken: string;
waitExpired: boolean;
}