@socketsecurity/cli-with-sentry 0.14.66 → 0.14.68

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/dist/blessed/lib/alias.js +521 -0
  2. package/dist/blessed/lib/blessed.js +34 -0
  3. package/dist/blessed/lib/colors.js +492 -0
  4. package/dist/blessed/lib/events.js +197 -0
  5. package/dist/blessed/lib/gpmclient.js +247 -0
  6. package/dist/blessed/lib/helpers.js +172 -0
  7. package/dist/blessed/lib/keys.js +514 -0
  8. package/dist/blessed/lib/program.js +4532 -0
  9. package/dist/blessed/lib/tput.js +3113 -0
  10. package/dist/blessed/lib/unicode.js +914 -0
  11. package/dist/blessed/lib/widget.js +62 -0
  12. package/dist/blessed/lib/widgets/ansiimage.js +175 -0
  13. package/dist/blessed/lib/widgets/bigtext.js +172 -0
  14. package/dist/blessed/lib/widgets/box.js +36 -0
  15. package/dist/blessed/lib/widgets/button.js +64 -0
  16. package/dist/blessed/lib/widgets/checkbox.js +97 -0
  17. package/dist/blessed/lib/widgets/element.js +2873 -0
  18. package/dist/blessed/lib/widgets/filemanager.js +225 -0
  19. package/dist/blessed/lib/widgets/form.js +303 -0
  20. package/dist/blessed/lib/widgets/image.js +73 -0
  21. package/dist/blessed/lib/widgets/input.js +36 -0
  22. package/dist/blessed/lib/widgets/layout.js +251 -0
  23. package/dist/blessed/lib/widgets/line.js +61 -0
  24. package/dist/blessed/lib/widgets/list.js +654 -0
  25. package/dist/blessed/lib/widgets/listbar.js +454 -0
  26. package/dist/blessed/lib/widgets/listtable.js +267 -0
  27. package/dist/blessed/lib/widgets/loading.js +90 -0
  28. package/dist/blessed/lib/widgets/log.js +84 -0
  29. package/dist/blessed/lib/widgets/message.js +147 -0
  30. package/dist/blessed/lib/widgets/node.js +316 -0
  31. package/dist/blessed/lib/widgets/overlayimage.js +796 -0
  32. package/dist/blessed/lib/widgets/progressbar.js +168 -0
  33. package/dist/blessed/lib/widgets/prompt.js +129 -0
  34. package/dist/blessed/lib/widgets/question.js +131 -0
  35. package/dist/blessed/lib/widgets/radiobutton.js +64 -0
  36. package/dist/blessed/lib/widgets/radioset.js +38 -0
  37. package/dist/blessed/lib/widgets/screen.js +2489 -0
  38. package/dist/blessed/lib/widgets/scrollablebox.js +417 -0
  39. package/dist/blessed/lib/widgets/scrollabletext.js +37 -0
  40. package/dist/blessed/lib/widgets/table.js +385 -0
  41. package/dist/blessed/lib/widgets/terminal.js +454 -0
  42. package/dist/blessed/lib/widgets/text.js +37 -0
  43. package/dist/blessed/lib/widgets/textarea.js +378 -0
  44. package/dist/blessed/lib/widgets/textbox.js +81 -0
  45. package/dist/blessed/lib/widgets/video.js +132 -0
  46. package/dist/blessed/usr/fonts/AUTHORS +1 -0
  47. package/dist/blessed/usr/fonts/LICENSE +94 -0
  48. package/dist/blessed/usr/fonts/README +340 -0
  49. package/dist/blessed/usr/fonts/ter-u14b.json +17826 -0
  50. package/dist/blessed/usr/fonts/ter-u14n.json +17826 -0
  51. package/dist/blessed/usr/linux +0 -0
  52. package/dist/blessed/usr/windows-ansi +0 -0
  53. package/dist/blessed/usr/xterm +0 -0
  54. package/dist/blessed/usr/xterm-256color +0 -0
  55. package/dist/blessed/usr/xterm.termcap +243 -0
  56. package/dist/blessed/usr/xterm.terminfo +1977 -0
  57. package/dist/blessed/vendor/tng.js +1878 -0
  58. package/dist/constants.d.ts +271 -205
  59. package/dist/constants.js +273 -221
  60. package/dist/constants.js.map +1 -1
  61. package/dist/instrument-with-sentry.d.ts +1 -1
  62. package/dist/instrument-with-sentry.js +27 -24
  63. package/dist/instrument-with-sentry.js.map +1 -1
  64. package/dist/module-sync/artifact.d.ts +60 -26
  65. package/dist/module-sync/cli.d.ts +1 -1
  66. package/dist/module-sync/cli.js +6991 -4413
  67. package/dist/module-sync/cli.js.map +1 -1
  68. package/dist/module-sync/cmd.d.ts +4 -4
  69. package/dist/module-sync/config.d.ts +32 -0
  70. package/dist/module-sync/edge.d.ts +73 -60
  71. package/dist/module-sync/errors.d.ts +26 -11
  72. package/dist/module-sync/fs.d.ts +61 -0
  73. package/dist/module-sync/index.d.ts +31 -20
  74. package/dist/module-sync/node.d.ts +118 -83
  75. package/dist/module-sync/override-set.d.ts +39 -33
  76. package/dist/module-sync/package-environment.d.ts +83 -52
  77. package/dist/module-sync/path-resolve.d.ts +14 -9
  78. package/dist/module-sync/sdk.d.ts +9 -5
  79. package/dist/module-sync/shadow-bin.d.ts +5 -2
  80. package/dist/module-sync/shadow-bin.js +82 -66
  81. package/dist/module-sync/shadow-bin.js.map +1 -1
  82. package/dist/module-sync/shadow-npm-inject.d.ts +1 -1
  83. package/dist/module-sync/shadow-npm-inject.js +1209 -1006
  84. package/dist/module-sync/shadow-npm-inject.js.map +1 -1
  85. package/dist/module-sync/shadow-npm-paths.d.ts +28 -14
  86. package/dist/module-sync/shadow-npm-paths.js +286 -209
  87. package/dist/module-sync/shadow-npm-paths.js.map +1 -1
  88. package/dist/module-sync/socket-package-alert.d.ts +95 -39
  89. package/dist/module-sync/types.d.ts +75 -47
  90. package/dist/module-sync/vendor.js +11181 -0
  91. package/dist/{require → module-sync}/vendor.js.map +1 -1
  92. package/dist/require/cli.d.ts +1 -1
  93. package/dist/require/cli.js +6991 -4411
  94. package/dist/require/cli.js.map +1 -1
  95. package/dist/require/vendor.js +2 -9145
  96. package/package.json +49 -41
  97. package/dist/module-sync/settings.d.ts +0 -15
@@ -1,4 +1,4 @@
1
- declare function cmdFlagsToString(args: string[]): string;
2
- declare function cmdPrefixMessage(cmdName: string, text: string): string;
3
- declare function isHelpFlag(cmdArg: string): boolean;
4
- export { cmdFlagsToString, cmdPrefixMessage, isHelpFlag };
1
+ declare function cmdFlagsToString(args: string[]): string
2
+ declare function cmdPrefixMessage(cmdName: string, text: string): string
3
+ declare function isHelpFlag(cmdArg: string): boolean
4
+ export { cmdFlagsToString, cmdPrefixMessage, isHelpFlag }
@@ -0,0 +1,32 @@
1
+ import config from '@socketsecurity/config'
2
+ interface LocalConfig {
3
+ apiBaseUrl?: string | null | undefined
4
+ apiKey?: string | null | undefined
5
+ apiProxy?: string | null | undefined
6
+ apiToken?: string | null | undefined
7
+ defaultOrg?: string
8
+ enforcedOrgs?: string[] | readonly string[] | null | undefined
9
+ }
10
+ declare const supportedConfigKeys: Map<keyof LocalConfig, string>
11
+ declare const sensitiveConfigKeys: Set<keyof LocalConfig>
12
+ declare function overrideCachedConfig(config: object): void
13
+ declare function findSocketYmlSync(dir?: string): {
14
+ path: string
15
+ parsed: config.SocketYml
16
+ } | null
17
+ declare function getConfigValue<Key extends keyof LocalConfig>(
18
+ key: Key
19
+ ): LocalConfig[Key]
20
+ declare function updateConfigValue<Key extends keyof LocalConfig>(
21
+ key: keyof LocalConfig,
22
+ value: LocalConfig[Key]
23
+ ): void
24
+ export {
25
+ LocalConfig,
26
+ supportedConfigKeys,
27
+ sensitiveConfigKeys,
28
+ overrideCachedConfig,
29
+ findSocketYmlSync,
30
+ getConfigValue,
31
+ updateConfigValue
32
+ }
@@ -1,65 +1,78 @@
1
1
  /// <reference types="npmcli__arborist" />
2
- import { SafeNode } from "./node.js";
3
- import { SafeOverrideSet } from "./override-set.js";
4
- import { DependencyProblem } from '@npmcli/arborist';
5
- import { Edge as BaseEdge } from "@npmcli/arborist";
6
- type EdgeClass = Omit<BaseEdge, 'accept' | 'detach' | 'optional' | 'overrides' | 'peer' | 'peerConflicted' | 'rawSpec' | 'reload' | 'satisfiedBy' | 'spec' | 'to'> & {
7
- optional: boolean;
8
- overrides: SafeOverrideSet | undefined;
9
- peer: boolean;
10
- peerConflicted: boolean;
11
- rawSpec: string;
12
- get accept(): string | undefined;
13
- get spec(): string;
14
- get to(): SafeNode | null;
15
- new (...args: any): EdgeClass;
16
- detach(): void;
17
- reload(hard?: boolean): void;
18
- satisfiedBy(node: SafeNode): boolean;
19
- };
2
+ import { SafeNode } from './node.js'
3
+ import { SafeOverrideSet } from './override-set.js'
4
+ import { DependencyProblem } from '@npmcli/arborist'
5
+ import { Edge as BaseEdge } from '@npmcli/arborist'
6
+ type EdgeClass = Omit<
7
+ BaseEdge,
8
+ | 'accept'
9
+ | 'detach'
10
+ | 'optional'
11
+ | 'overrides'
12
+ | 'peer'
13
+ | 'peerConflicted'
14
+ | 'rawSpec'
15
+ | 'reload'
16
+ | 'satisfiedBy'
17
+ | 'spec'
18
+ | 'to'
19
+ > & {
20
+ optional: boolean
21
+ overrides: SafeOverrideSet | undefined
22
+ peer: boolean
23
+ peerConflicted: boolean
24
+ rawSpec: string
25
+ get accept(): string | undefined
26
+ get spec(): string
27
+ get to(): SafeNode | null
28
+ new (...args: any): EdgeClass
29
+ detach(): void
30
+ reload(hard?: boolean): void
31
+ satisfiedBy(node: SafeNode): boolean
32
+ }
20
33
  type EdgeOptions = {
21
- type: string;
22
- name: string;
23
- spec: string;
24
- from: SafeNode;
25
- accept?: string | undefined;
26
- overrides?: SafeOverrideSet | undefined;
27
- to?: SafeNode | undefined;
28
- };
29
- type ErrorStatus = DependencyProblem | 'OK';
34
+ type: string
35
+ name: string
36
+ spec: string
37
+ from: SafeNode
38
+ accept?: string | undefined
39
+ overrides?: SafeOverrideSet | undefined
40
+ to?: SafeNode | undefined
41
+ }
42
+ type ErrorStatus = DependencyProblem | 'OK'
30
43
  type Explanation = {
31
- type: string;
32
- name: string;
33
- spec: string;
34
- bundled: boolean;
35
- overridden: boolean;
36
- error: ErrorStatus | undefined;
37
- rawSpec: string | undefined;
38
- from: object | undefined;
39
- } | null;
40
- declare const Edge: EdgeClass;
44
+ type: string
45
+ name: string
46
+ spec: string
47
+ bundled: boolean
48
+ overridden: boolean
49
+ error: ErrorStatus | undefined
50
+ rawSpec: string | undefined
51
+ from: object | undefined
52
+ } | null
53
+ declare const Edge: EdgeClass
41
54
  declare class SafeEdge extends Edge {
42
- #private;
43
- constructor(options: EdgeOptions);
44
- get bundled(): boolean;
45
- get error(): "DETACHED" | "MISSING" | "PEER LOCAL" | "INVALID" | null;
46
- get from(): SafeNode | null;
47
- get spec(): string;
48
- get to(): SafeNode | null;
49
- detach(): void;
50
- // Return the edge data, and an explanation of how that edge came to be here.
51
- // @ts-ignore: Edge#explain is defined with an unused `seen = []` param.
52
- explain(): {
53
- type: string;
54
- name: string;
55
- spec: string;
56
- bundled: boolean;
57
- overridden: boolean;
58
- error: ErrorStatus | undefined;
59
- rawSpec: string | undefined;
60
- from: object | undefined;
61
- };
62
- reload(hard?: boolean): void;
63
- satisfiedBy(node: SafeNode): boolean;
55
+ #private
56
+ constructor(options: EdgeOptions)
57
+ get bundled(): boolean
58
+ get error(): 'DETACHED' | 'MISSING' | 'PEER LOCAL' | 'INVALID' | null
59
+ get from(): SafeNode | null
60
+ get spec(): string
61
+ get to(): SafeNode | null
62
+ detach(): void
63
+ // Return the edge data, and an explanation of how that edge came to be here.
64
+ // @ts-ignore: Edge#explain is defined with an unused `seen = []` param.
65
+ explain(): {
66
+ type: string
67
+ name: string
68
+ spec: string
69
+ bundled: boolean
70
+ overridden: boolean
71
+ error: ErrorStatus | undefined
72
+ rawSpec: string | undefined
73
+ from: object | undefined
74
+ }
75
+ reload(hard?: boolean): void
76
+ satisfiedBy(node: SafeNode): boolean
64
77
  }
65
- export { EdgeOptions, ErrorStatus, Explanation, Edge, SafeEdge };
78
+ export { EdgeOptions, ErrorStatus, Explanation, Edge, SafeEdge }
@@ -1,14 +1,29 @@
1
1
  /// <reference types="node" />
2
- type EventHintOrCaptureContext = {
3
- [key: string]: any;
4
- } | Function;
5
- declare class AuthError extends Error {
6
- }
2
+ type EventHintOrCaptureContext =
3
+ | {
4
+ [key: string]: any
5
+ }
6
+ | Function
7
+ declare class AuthError extends Error {}
7
8
  declare class InputError extends Error {
8
- body: string | undefined;
9
- constructor(message: string, body?: string);
9
+ body: string | undefined
10
+ constructor(message: string, body?: string)
11
+ }
12
+ declare function captureException(
13
+ exception: unknown,
14
+ hint?: EventHintOrCaptureContext | undefined
15
+ ): Promise<string>
16
+ declare function captureExceptionSync(
17
+ exception: unknown,
18
+ hint?: EventHintOrCaptureContext | undefined
19
+ ): string
20
+ declare function isErrnoException(
21
+ value: unknown
22
+ ): value is NodeJS.ErrnoException
23
+ export {
24
+ AuthError,
25
+ InputError,
26
+ captureException,
27
+ captureExceptionSync,
28
+ isErrnoException
10
29
  }
11
- declare function captureException(exception: unknown, hint?: EventHintOrCaptureContext | undefined): Promise<string>;
12
- declare function captureExceptionSync(exception: unknown, hint?: EventHintOrCaptureContext | undefined): string;
13
- declare function isErrnoException(value: unknown): value is NodeJS.ErrnoException;
14
- export { AuthError, InputError, captureException, captureExceptionSync, isErrnoException };
@@ -0,0 +1,61 @@
1
+ /// <reference types="node" />
2
+ import { Remap } from '@socketsecurity/registry/lib/objects'
3
+ import { Abortable } from 'node:events'
4
+ import {
5
+ ObjectEncodingOptions,
6
+ OpenMode,
7
+ PathLike,
8
+ PathOrFileDescriptor
9
+ } from 'node:fs'
10
+ import { FileHandle } from 'node:fs/promises'
11
+ type FindUpOptions = {
12
+ cwd?: string | undefined
13
+ signal?: AbortSignal | undefined
14
+ }
15
+ declare function findUp(
16
+ name: string | string[],
17
+ { cwd, signal }: FindUpOptions
18
+ ): Promise<string | undefined>
19
+ type ReadFileOptions = Remap<
20
+ ObjectEncodingOptions &
21
+ Abortable & {
22
+ flag?: OpenMode | undefined
23
+ }
24
+ >
25
+ declare function readFileBinary(
26
+ filepath: PathLike | FileHandle,
27
+ options?: ReadFileOptions | undefined
28
+ ): Promise<Buffer>
29
+ declare function readFileUtf8(
30
+ filepath: PathLike | FileHandle,
31
+ options?: ReadFileOptions | undefined
32
+ ): Promise<string>
33
+ declare function safeReadFile(
34
+ filepath: PathLike | FileHandle,
35
+ options?:
36
+ | 'utf8'
37
+ | 'utf-8'
38
+ | {
39
+ encoding: 'utf8' | 'utf-8'
40
+ }
41
+ | undefined
42
+ ): Promise<string | undefined>
43
+ declare function safeReadFileSync(
44
+ filepath: PathOrFileDescriptor,
45
+ options?:
46
+ | 'utf8'
47
+ | 'utf-8'
48
+ | {
49
+ encoding: 'utf8' | 'utf-8'
50
+ }
51
+ | undefined
52
+ ): string | undefined
53
+ export {
54
+ FindUpOptions,
55
+ findUp,
56
+ ReadFileOptions,
57
+ readFileBinary,
58
+ readFileUtf8,
59
+ safeReadFile,
60
+ safeReadFileSync
61
+ }
@@ -1,23 +1,34 @@
1
- import { ArboristClass } from "./types.js";
2
- import { SafeNode } from "./node.js";
1
+ import { ArboristClass } from './types.js'
2
+ import { SafeNode } from './node.js'
3
3
  declare const SAFE_ARBORIST_REIFY_OPTIONS_OVERRIDES: {
4
- __proto__: null;
5
- audit: boolean;
6
- dryRun: boolean;
7
- fund: boolean;
8
- ignoreScripts: boolean;
9
- progress: boolean;
10
- save: boolean;
11
- saveBundle: boolean;
12
- silent: boolean;
13
- };
14
- declare const kCtorArgs: unique symbol;
15
- declare const kRiskyReify: unique symbol;
16
- declare const Arborist: ArboristClass;
4
+ __proto__: null
5
+ audit: boolean
6
+ dryRun: boolean
7
+ fund: boolean
8
+ ignoreScripts: boolean
9
+ progress: boolean
10
+ save: boolean
11
+ saveBundle: boolean
12
+ silent: boolean
13
+ }
14
+ declare const kCtorArgs: unique symbol
15
+ declare const kRiskyReify: unique symbol
16
+ declare const Arborist: ArboristClass
17
17
  declare class SafeArborist extends Arborist {
18
- constructor(...ctorArgs: ConstructorParameters<ArboristClass>);
19
- [kRiskyReify](...args: Parameters<InstanceType<ArboristClass>['reify']>): Promise<SafeNode>;
20
- // @ts-ignore Incorrectly typed.
21
- reify(this: SafeArborist, ...args: Parameters<InstanceType<ArboristClass>['reify']>): Promise<SafeNode>;
18
+ constructor(...ctorArgs: ConstructorParameters<ArboristClass>)
19
+ [kRiskyReify](
20
+ ...args: Parameters<InstanceType<ArboristClass>['reify']>
21
+ ): Promise<SafeNode>
22
+ // @ts-ignore Incorrectly typed.
23
+ reify(
24
+ this: SafeArborist,
25
+ ...args: Parameters<InstanceType<ArboristClass>['reify']>
26
+ ): Promise<SafeNode>
27
+ }
28
+ export {
29
+ SAFE_ARBORIST_REIFY_OPTIONS_OVERRIDES,
30
+ kCtorArgs,
31
+ kRiskyReify,
32
+ Arborist,
33
+ SafeArborist
22
34
  }
23
- export { SAFE_ARBORIST_REIFY_OPTIONS_OVERRIDES, kCtorArgs, kRiskyReify, Arborist, SafeArborist };
@@ -1,86 +1,121 @@
1
1
  /// <reference types="npmcli__arborist" />
2
- import { SafeOverrideSet } from "./override-set.js";
3
- import { SafeEdge } from "./edge.js";
4
- import { Link } from '@npmcli/arborist';
5
- import { Node as BaseNode } from "@npmcli/arborist";
6
- type NodeClass = Omit<BaseNode, 'addEdgeIn' | 'addEdgeOut' | 'canDedupe' | 'canReplace' | 'canReplaceWith' | 'children' | 'deleteEdgeIn' | 'edgesIn' | 'edgesOut' | 'from' | 'hasShrinkwrap' | 'inDepBundle' | 'inShrinkwrap' | 'integrity' | 'isTop' | 'matches' | 'meta' | 'name' | 'overrides' | 'packageName' | 'parent' | 'recalculateOutEdgesOverrides' | 'resolve' | 'resolveParent' | 'root' | 'updateOverridesEdgeInAdded' | 'updateOverridesEdgeInRemoved' | 'version' | 'versions'> & {
7
- name: string;
8
- version: string;
9
- children: Map<string, SafeNode | Link>;
10
- edgesIn: Set<SafeEdge>;
11
- edgesOut: Map<string, SafeEdge>;
12
- from: SafeNode | null;
13
- hasShrinkwrap: boolean;
14
- inShrinkwrap: boolean | undefined;
15
- integrity?: string | null;
16
- isTop: boolean | undefined;
17
- meta: BaseNode['meta'] & {
18
- addEdge(edge: SafeEdge): void;
19
- };
20
- overrides: SafeOverrideSet | undefined;
21
- versions: string[];
22
- get inDepBundle(): boolean;
23
- get packageName(): string | null;
24
- get parent(): SafeNode | null;
25
- set parent(value: SafeNode | null);
26
- get resolveParent(): SafeNode | null;
27
- get root(): SafeNode | null;
28
- set root(value: SafeNode | null);
29
- new (...args: any): NodeClass;
30
- addEdgeIn(edge: SafeEdge): void;
31
- addEdgeOut(edge: SafeEdge): void;
32
- canDedupe(preferDedupe?: boolean): boolean;
33
- canReplace(node: SafeNode, ignorePeers?: string[]): boolean;
34
- canReplaceWith(node: SafeNode, ignorePeers?: string[]): boolean;
35
- deleteEdgeIn(edge: SafeEdge): void;
36
- matches(node: SafeNode): boolean;
37
- recalculateOutEdgesOverrides(): void;
38
- resolve(name: string): SafeNode;
39
- updateOverridesEdgeInAdded(otherOverrideSet: SafeOverrideSet | undefined): boolean;
40
- updateOverridesEdgeInRemoved(otherOverrideSet: SafeOverrideSet): boolean;
41
- };
42
- declare const Node: NodeClass;
2
+ import { SafeOverrideSet } from './override-set.js'
3
+ import { SafeEdge } from './edge.js'
4
+ import { Link } from '@npmcli/arborist'
5
+ import { Node as BaseNode } from '@npmcli/arborist'
6
+ type NodeClass = Omit<
7
+ BaseNode,
8
+ | 'addEdgeIn'
9
+ | 'addEdgeOut'
10
+ | 'canDedupe'
11
+ | 'canReplace'
12
+ | 'canReplaceWith'
13
+ | 'children'
14
+ | 'deleteEdgeIn'
15
+ | 'edgesIn'
16
+ | 'edgesOut'
17
+ | 'from'
18
+ | 'hasShrinkwrap'
19
+ | 'inDepBundle'
20
+ | 'inShrinkwrap'
21
+ | 'integrity'
22
+ | 'isTop'
23
+ | 'matches'
24
+ | 'meta'
25
+ | 'name'
26
+ | 'overrides'
27
+ | 'packageName'
28
+ | 'parent'
29
+ | 'recalculateOutEdgesOverrides'
30
+ | 'resolve'
31
+ | 'resolveParent'
32
+ | 'root'
33
+ | 'updateOverridesEdgeInAdded'
34
+ | 'updateOverridesEdgeInRemoved'
35
+ | 'version'
36
+ | 'versions'
37
+ > & {
38
+ name: string
39
+ version: string
40
+ children: Map<string, SafeNode | Link>
41
+ edgesIn: Set<SafeEdge>
42
+ edgesOut: Map<string, SafeEdge>
43
+ from: SafeNode | null
44
+ hasShrinkwrap: boolean
45
+ inShrinkwrap: boolean | undefined
46
+ integrity?: string | null
47
+ isTop: boolean | undefined
48
+ meta: BaseNode['meta'] & {
49
+ addEdge(edge: SafeEdge): void
50
+ }
51
+ overrides: SafeOverrideSet | undefined
52
+ versions: string[]
53
+ get inDepBundle(): boolean
54
+ get packageName(): string | null
55
+ get parent(): SafeNode | null
56
+ set parent(value: SafeNode | null)
57
+ get resolveParent(): SafeNode | null
58
+ get root(): SafeNode | null
59
+ set root(value: SafeNode | null)
60
+ new (...args: any): NodeClass
61
+ addEdgeIn(edge: SafeEdge): void
62
+ addEdgeOut(edge: SafeEdge): void
63
+ canDedupe(preferDedupe?: boolean): boolean
64
+ canReplace(node: SafeNode, ignorePeers?: string[]): boolean
65
+ canReplaceWith(node: SafeNode, ignorePeers?: string[]): boolean
66
+ deleteEdgeIn(edge: SafeEdge): void
67
+ matches(node: SafeNode): boolean
68
+ recalculateOutEdgesOverrides(): void
69
+ resolve(name: string): SafeNode
70
+ updateOverridesEdgeInAdded(
71
+ otherOverrideSet: SafeOverrideSet | undefined
72
+ ): boolean
73
+ updateOverridesEdgeInRemoved(otherOverrideSet: SafeOverrideSet): boolean
74
+ }
75
+ declare const Node: NodeClass
43
76
  declare class SafeNode extends Node {
44
- // Return true if it's safe to remove this node, because anything that is
45
- // depending on it would be fine with the thing that they would resolve to if
46
- // it was removed, or nothing is depending on it in the first place.
47
- canDedupe(preferDedupe?: boolean): boolean;
48
- // Is it safe to replace one node with another? check the edges to
49
- // make sure no one will get upset. Note that the node might end up
50
- // having its own unmet dependencies, if the new node has new deps.
51
- // Note that there are cases where Arborist will opt to insert a node
52
- // into the tree even though this function returns false! This is
53
- // necessary when a root dependency is added or updated, or when a
54
- // root dependency brings peer deps along with it. In that case, we
55
- // will go ahead and create the invalid state, and then try to resolve
56
- // it with more tree construction, because it's a user request.
57
- canReplaceWith(node: SafeNode, ignorePeers?: string[]): boolean;
58
- // Patch adding deleteEdgeIn is based on https://github.com/npm/cli/pull/8089.
59
- deleteEdgeIn(edge: SafeEdge): void;
60
- addEdgeIn(edge: SafeEdge): void;
61
- get overridden(): boolean;
62
- set parent(newParent: SafeNode);
63
- // Patch adding recalculateOutEdgesOverrides is based on
64
- // https://github.com/npm/cli/pull/8089.
65
- recalculateOutEdgesOverrides(): void;
66
- set root(newRoot: SafeNode);
67
- // Patch adding updateOverridesEdgeInAdded is based on
68
- // https://github.com/npm/cli/pull/7025.
69
- //
70
- // This logic isn't perfect either. When we have two edges in that have
71
- // different override sets, then we have to decide which set is correct. This
72
- // function assumes the more specific override set is applicable, so if we have
73
- // dependencies A->B->C and A->C and an override set that specifies what happens
74
- // for C under A->B, this will work even if the new A->C edge comes along and
75
- // tries to change the override set. The strictly correct logic is not to allow
76
- // two edges with different overrides to point to the same node, because even
77
- // if this node can satisfy both, one of its dependencies might need to be
78
- // different depending on the edge leading to it. However, this might cause a
79
- // lot of duplication, because the conflict in the dependencies might never
80
- // actually happen.
81
- updateOverridesEdgeInAdded(otherOverrideSet: SafeOverrideSet | undefined): boolean;
82
- // Patch adding updateOverridesEdgeInRemoved is based on
83
- // https://github.com/npm/cli/pull/7025.
84
- updateOverridesEdgeInRemoved(otherOverrideSet: SafeOverrideSet): boolean;
77
+ // Return true if it's safe to remove this node, because anything that is
78
+ // depending on it would be fine with the thing that they would resolve to if
79
+ // it was removed, or nothing is depending on it in the first place.
80
+ canDedupe(preferDedupe?: boolean): boolean
81
+ // Is it safe to replace one node with another? check the edges to
82
+ // make sure no one will get upset. Note that the node might end up
83
+ // having its own unmet dependencies, if the new node has new deps.
84
+ // Note that there are cases where Arborist will opt to insert a node
85
+ // into the tree even though this function returns false! This is
86
+ // necessary when a root dependency is added or updated, or when a
87
+ // root dependency brings peer deps along with it. In that case, we
88
+ // will go ahead and create the invalid state, and then try to resolve
89
+ // it with more tree construction, because it's a user request.
90
+ canReplaceWith(node: SafeNode, ignorePeers?: string[]): boolean
91
+ // Patch adding deleteEdgeIn is based on https://github.com/npm/cli/pull/8089.
92
+ deleteEdgeIn(edge: SafeEdge): void
93
+ addEdgeIn(edge: SafeEdge): void
94
+ get overridden(): boolean
95
+ set parent(newParent: SafeNode)
96
+ // Patch adding recalculateOutEdgesOverrides is based on
97
+ // https://github.com/npm/cli/pull/8089.
98
+ recalculateOutEdgesOverrides(): void
99
+ set root(newRoot: SafeNode)
100
+ // Patch adding updateOverridesEdgeInAdded is based on
101
+ // https://github.com/npm/cli/pull/7025.
102
+ //
103
+ // This logic isn't perfect either. When we have two edges in that have
104
+ // different override sets, then we have to decide which set is correct. This
105
+ // function assumes the more specific override set is applicable, so if we have
106
+ // dependencies A->B->C and A->C and an override set that specifies what happens
107
+ // for C under A->B, this will work even if the new A->C edge comes along and
108
+ // tries to change the override set. The strictly correct logic is not to allow
109
+ // two edges with different overrides to point to the same node, because even
110
+ // if this node can satisfy both, one of its dependencies might need to be
111
+ // different depending on the edge leading to it. However, this might cause a
112
+ // lot of duplication, because the conflict in the dependencies might never
113
+ // actually happen.
114
+ updateOverridesEdgeInAdded(
115
+ otherOverrideSet: SafeOverrideSet | undefined
116
+ ): boolean
117
+ // Patch adding updateOverridesEdgeInRemoved is based on
118
+ // https://github.com/npm/cli/pull/7025.
119
+ updateOverridesEdgeInRemoved(otherOverrideSet: SafeOverrideSet): boolean
85
120
  }
86
- export { SafeNode };
121
+ export { SafeNode }
@@ -1,37 +1,43 @@
1
- import { SafeEdge } from "./edge.js";
2
- import { SafeNode } from "./node.js";
1
+ import { SafeEdge } from './edge.js'
2
+ import { SafeNode } from './node.js'
3
3
  interface OverrideSetClass {
4
- children: Map<string, SafeOverrideSet>;
5
- key: string | undefined;
6
- keySpec: string | undefined;
7
- name: string | undefined;
8
- parent: SafeOverrideSet | undefined;
9
- value: string | undefined;
10
- version: string | undefined;
11
- new (...args: any[]): OverrideSetClass;
12
- get isRoot(): boolean;
13
- get ruleset(): Map<string, SafeOverrideSet>;
14
- ancestry(): Generator<SafeOverrideSet>;
15
- childrenAreEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean;
16
- getEdgeRule(edge: SafeEdge): SafeOverrideSet;
17
- getNodeRule(node: SafeNode): SafeOverrideSet;
18
- getMatchingRule(node: SafeNode): SafeOverrideSet | null;
19
- isEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean;
4
+ children: Map<string, SafeOverrideSet>
5
+ key: string | undefined
6
+ keySpec: string | undefined
7
+ name: string | undefined
8
+ parent: SafeOverrideSet | undefined
9
+ value: string | undefined
10
+ version: string | undefined
11
+ new (...args: any[]): OverrideSetClass
12
+ get isRoot(): boolean
13
+ get ruleset(): Map<string, SafeOverrideSet>
14
+ ancestry(): Generator<SafeOverrideSet>
15
+ childrenAreEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean
16
+ getEdgeRule(edge: SafeEdge): SafeOverrideSet
17
+ getNodeRule(node: SafeNode): SafeOverrideSet
18
+ getMatchingRule(node: SafeNode): SafeOverrideSet | null
19
+ isEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean
20
20
  }
21
- declare const OverrideSet: OverrideSetClass;
21
+ declare const OverrideSet: OverrideSetClass
22
22
  declare class SafeOverrideSet extends OverrideSet {
23
- // Patch adding doOverrideSetsConflict is based on
24
- // https://github.com/npm/cli/pull/8089.
25
- static doOverrideSetsConflict(first: SafeOverrideSet | undefined, second: SafeOverrideSet | undefined): boolean;
26
- // Patch adding findSpecificOverrideSet is based on
27
- // https://github.com/npm/cli/pull/8089.
28
- static findSpecificOverrideSet(first: SafeOverrideSet | undefined, second: SafeOverrideSet | undefined): SafeOverrideSet | undefined;
29
- // Patch adding childrenAreEqual is based on
30
- // https://github.com/npm/cli/pull/8089.
31
- childrenAreEqual(otherOverrideSet: SafeOverrideSet): boolean;
32
- getEdgeRule(edge: SafeEdge): SafeOverrideSet;
33
- // Patch adding isEqual is based on
34
- // https://github.com/npm/cli/pull/8089.
35
- isEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean;
23
+ // Patch adding doOverrideSetsConflict is based on
24
+ // https://github.com/npm/cli/pull/8089.
25
+ static doOverrideSetsConflict(
26
+ first: SafeOverrideSet | undefined,
27
+ second: SafeOverrideSet | undefined
28
+ ): boolean
29
+ // Patch adding findSpecificOverrideSet is based on
30
+ // https://github.com/npm/cli/pull/8089.
31
+ static findSpecificOverrideSet(
32
+ first: SafeOverrideSet | undefined,
33
+ second: SafeOverrideSet | undefined
34
+ ): SafeOverrideSet | undefined
35
+ // Patch adding childrenAreEqual is based on
36
+ // https://github.com/npm/cli/pull/8089.
37
+ childrenAreEqual(otherOverrideSet: SafeOverrideSet): boolean
38
+ getEdgeRule(edge: SafeEdge): SafeOverrideSet
39
+ // Patch adding isEqual is based on
40
+ // https://github.com/npm/cli/pull/8089.
41
+ isEqual(otherOverrideSet: SafeOverrideSet | undefined): boolean
36
42
  }
37
- export { SafeOverrideSet };
43
+ export { SafeOverrideSet }