cloudvault-mcp 1.0.0

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 (55) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +235 -0
  3. package/dist/adapters/aws.d.ts +42 -0
  4. package/dist/adapters/aws.d.ts.map +1 -0
  5. package/dist/adapters/aws.js +318 -0
  6. package/dist/adapters/aws.js.map +1 -0
  7. package/dist/adapters/types.d.ts +22 -0
  8. package/dist/adapters/types.d.ts.map +1 -0
  9. package/dist/adapters/types.js +2 -0
  10. package/dist/adapters/types.js.map +1 -0
  11. package/dist/index.d.ts +7 -0
  12. package/dist/index.d.ts.map +1 -0
  13. package/dist/index.js +51 -0
  14. package/dist/index.js.map +1 -0
  15. package/dist/lib/audit.d.ts +57 -0
  16. package/dist/lib/audit.d.ts.map +1 -0
  17. package/dist/lib/audit.js +136 -0
  18. package/dist/lib/audit.js.map +1 -0
  19. package/dist/lib/cost-estimates.d.ts +16 -0
  20. package/dist/lib/cost-estimates.d.ts.map +1 -0
  21. package/dist/lib/cost-estimates.js +101 -0
  22. package/dist/lib/cost-estimates.js.map +1 -0
  23. package/dist/lib/fetch-retry.d.ts +7 -0
  24. package/dist/lib/fetch-retry.d.ts.map +1 -0
  25. package/dist/lib/fetch-retry.js +35 -0
  26. package/dist/lib/fetch-retry.js.map +1 -0
  27. package/dist/lib/providers.d.ts +7 -0
  28. package/dist/lib/providers.d.ts.map +1 -0
  29. package/dist/lib/providers.js +37 -0
  30. package/dist/lib/providers.js.map +1 -0
  31. package/dist/premium/gate.d.ts +18 -0
  32. package/dist/premium/gate.d.ts.map +1 -0
  33. package/dist/premium/gate.js +27 -0
  34. package/dist/premium/gate.js.map +1 -0
  35. package/dist/tools/get_secrets.d.ts +16 -0
  36. package/dist/tools/get_secrets.d.ts.map +1 -0
  37. package/dist/tools/get_secrets.js +52 -0
  38. package/dist/tools/get_secrets.js.map +1 -0
  39. package/dist/tools/list_databases.d.ts +16 -0
  40. package/dist/tools/list_databases.d.ts.map +1 -0
  41. package/dist/tools/list_databases.js +42 -0
  42. package/dist/tools/list_databases.js.map +1 -0
  43. package/dist/tools/list_instances.d.ts +17 -0
  44. package/dist/tools/list_instances.d.ts.map +1 -0
  45. package/dist/tools/list_instances.js +43 -0
  46. package/dist/tools/list_instances.js.map +1 -0
  47. package/dist/tools/list_storage.d.ts +15 -0
  48. package/dist/tools/list_storage.d.ts.map +1 -0
  49. package/dist/tools/list_storage.js +40 -0
  50. package/dist/tools/list_storage.js.map +1 -0
  51. package/dist/types.d.ts +143 -0
  52. package/dist/types.d.ts.map +1 -0
  53. package/dist/types.js +2 -0
  54. package/dist/types.js.map +1 -0
  55. package/package.json +50 -0
@@ -0,0 +1,16 @@
1
+ /**
2
+ * list_databases tool — managed databases with engine, version, size, backup status.
3
+ */
4
+ import { type ProviderName } from '../lib/providers.js';
5
+ export interface ListDatabasesInput {
6
+ provider: ProviderName;
7
+ region?: string;
8
+ engine?: string;
9
+ }
10
+ export declare function list_databases(input: ListDatabasesInput): Promise<{
11
+ content: {
12
+ type: "text";
13
+ text: string;
14
+ }[];
15
+ }>;
16
+ //# sourceMappingURL=list_databases.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_databases.d.ts","sourceRoot":"","sources":["../../src/tools/list_databases.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAe,KAAK,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGrE,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,YAAY,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAsB,cAAc,CAAC,KAAK,EAAE,kBAAkB;;;;;GAqC7D"}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * list_databases tool — managed databases with engine, version, size, backup status.
3
+ */
4
+ import { getProvider } from '../lib/providers.js';
5
+ import { getAuditLog } from '../lib/audit.js';
6
+ export async function list_databases(input) {
7
+ const start = Date.now();
8
+ const audit = getAuditLog();
9
+ try {
10
+ const provider = getProvider(input.provider);
11
+ const databases = await provider.listDatabases({
12
+ region: input.region,
13
+ engine: input.engine,
14
+ });
15
+ audit.log({
16
+ tool_name: 'list_databases',
17
+ input_summary: audit.sanitize({
18
+ provider: input.provider,
19
+ region: input.region,
20
+ engine: input.engine,
21
+ }),
22
+ result_summary: JSON.stringify({ count: databases.length }),
23
+ success: true,
24
+ duration_ms: Date.now() - start,
25
+ });
26
+ return {
27
+ content: [{ type: 'text', text: JSON.stringify({ data: databases, count: databases.length }) }],
28
+ };
29
+ }
30
+ catch (err) {
31
+ const message = err instanceof Error ? err.message : String(err);
32
+ audit.log({
33
+ tool_name: 'list_databases',
34
+ input_summary: audit.sanitize({ provider: input.provider }),
35
+ result_summary: message,
36
+ success: false,
37
+ duration_ms: Date.now() - start,
38
+ });
39
+ throw err;
40
+ }
41
+ }
42
+ //# sourceMappingURL=list_databases.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_databases.js","sourceRoot":"","sources":["../../src/tools/list_databases.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAqB,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAQ9C,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,KAAyB;IAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,WAAW,EAAE,CAAC;IAE5B,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,aAAa,CAAC;YAC7C,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC,CAAC;QAEH,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,gBAAgB;YAC3B,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC;gBAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,MAAM,EAAE,KAAK,CAAC,MAAM;aACrB,CAAC;YACF,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC;YAC3D,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QAEH,OAAO;YACL,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;SACzG,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjE,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,gBAAgB;YAC3B,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC;YAC3D,cAAc,EAAE,OAAO;YACvB,OAAO,EAAE,KAAK;YACd,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QACH,MAAM,GAAG,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * list_instances tool — compute instances with state, type, IP, region, cost estimate.
3
+ */
4
+ import { type ProviderName } from '../lib/providers.js';
5
+ export interface ListInstancesInput {
6
+ provider: ProviderName;
7
+ region?: string;
8
+ state?: string;
9
+ tags?: Record<string, string>;
10
+ }
11
+ export declare function list_instances(input: ListInstancesInput): Promise<{
12
+ content: {
13
+ type: "text";
14
+ text: string;
15
+ }[];
16
+ }>;
17
+ //# sourceMappingURL=list_instances.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_instances.d.ts","sourceRoot":"","sources":["../../src/tools/list_instances.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAe,KAAK,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGrE,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,YAAY,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC/B;AAED,wBAAsB,cAAc,CAAC,KAAK,EAAE,kBAAkB;;;;;GAsC7D"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * list_instances tool — compute instances with state, type, IP, region, cost estimate.
3
+ */
4
+ import { getProvider } from '../lib/providers.js';
5
+ import { getAuditLog } from '../lib/audit.js';
6
+ export async function list_instances(input) {
7
+ const start = Date.now();
8
+ const audit = getAuditLog();
9
+ try {
10
+ const provider = getProvider(input.provider);
11
+ const instances = await provider.listInstances({
12
+ region: input.region,
13
+ state: input.state,
14
+ tags: input.tags,
15
+ });
16
+ audit.log({
17
+ tool_name: 'list_instances',
18
+ input_summary: audit.sanitize({
19
+ provider: input.provider,
20
+ region: input.region,
21
+ state: input.state,
22
+ }),
23
+ result_summary: JSON.stringify({ count: instances.length }),
24
+ success: true,
25
+ duration_ms: Date.now() - start,
26
+ });
27
+ return {
28
+ content: [{ type: 'text', text: JSON.stringify({ data: instances, count: instances.length }) }],
29
+ };
30
+ }
31
+ catch (err) {
32
+ const message = err instanceof Error ? err.message : String(err);
33
+ audit.log({
34
+ tool_name: 'list_instances',
35
+ input_summary: audit.sanitize({ provider: input.provider }),
36
+ result_summary: message,
37
+ success: false,
38
+ duration_ms: Date.now() - start,
39
+ });
40
+ throw err;
41
+ }
42
+ }
43
+ //# sourceMappingURL=list_instances.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_instances.js","sourceRoot":"","sources":["../../src/tools/list_instances.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAqB,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAS9C,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,KAAyB;IAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,WAAW,EAAE,CAAC;IAE5B,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,aAAa,CAAC;YAC7C,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,IAAI,EAAE,KAAK,CAAC,IAAI;SACjB,CAAC,CAAC;QAEH,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,gBAAgB;YAC3B,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC;gBAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,KAAK,EAAE,KAAK,CAAC,KAAK;aACnB,CAAC;YACF,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC;YAC3D,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QAEH,OAAO;YACL,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;SACzG,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjE,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,gBAAgB;YAC3B,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC;YAC3D,cAAc,EAAE,OAAO;YACvB,OAAO,EAAE,KAAK;YACd,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QACH,MAAM,GAAG,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * list_storage tool — buckets/containers with size, object count, public access.
3
+ */
4
+ import { type ProviderName } from '../lib/providers.js';
5
+ export interface ListStorageInput {
6
+ provider: ProviderName;
7
+ region?: string;
8
+ }
9
+ export declare function list_storage(input: ListStorageInput): Promise<{
10
+ content: {
11
+ type: "text";
12
+ text: string;
13
+ }[];
14
+ }>;
15
+ //# sourceMappingURL=list_storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_storage.d.ts","sourceRoot":"","sources":["../../src/tools/list_storage.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAe,KAAK,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGrE,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,YAAY,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAsB,YAAY,CAAC,KAAK,EAAE,gBAAgB;;;;;GAmCzD"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * list_storage tool — buckets/containers with size, object count, public access.
3
+ */
4
+ import { getProvider } from '../lib/providers.js';
5
+ import { getAuditLog } from '../lib/audit.js';
6
+ export async function list_storage(input) {
7
+ const start = Date.now();
8
+ const audit = getAuditLog();
9
+ try {
10
+ const provider = getProvider(input.provider);
11
+ const buckets = await provider.listStorage({
12
+ region: input.region,
13
+ });
14
+ audit.log({
15
+ tool_name: 'list_storage',
16
+ input_summary: audit.sanitize({
17
+ provider: input.provider,
18
+ region: input.region,
19
+ }),
20
+ result_summary: JSON.stringify({ count: buckets.length }),
21
+ success: true,
22
+ duration_ms: Date.now() - start,
23
+ });
24
+ return {
25
+ content: [{ type: 'text', text: JSON.stringify({ data: buckets, count: buckets.length }) }],
26
+ };
27
+ }
28
+ catch (err) {
29
+ const message = err instanceof Error ? err.message : String(err);
30
+ audit.log({
31
+ tool_name: 'list_storage',
32
+ input_summary: audit.sanitize({ provider: input.provider }),
33
+ result_summary: message,
34
+ success: false,
35
+ duration_ms: Date.now() - start,
36
+ });
37
+ throw err;
38
+ }
39
+ }
40
+ //# sourceMappingURL=list_storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_storage.js","sourceRoot":"","sources":["../../src/tools/list_storage.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAqB,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAO9C,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,KAAuB;IACxD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,WAAW,EAAE,CAAC;IAE5B,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,WAAW,CAAC;YACzC,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC,CAAC;QAEH,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,cAAc;YACzB,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC;gBAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;aACrB,CAAC;YACF,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC;YACzD,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QAEH,OAAO;YACL,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;SACrG,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjE,KAAK,CAAC,GAAG,CAAC;YACR,SAAS,EAAE,cAAc;YACzB,aAAa,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC;YAC3D,cAAc,EAAE,OAAO;YACvB,OAAO,EAAE,KAAK;YACd,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;SAChC,CAAC,CAAC;QACH,MAAM,GAAG,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,143 @@
1
+ export interface ComputeInstance {
2
+ id: string;
3
+ name: string;
4
+ type: string;
5
+ state: 'running' | 'stopped' | 'terminated' | 'pending' | 'unknown';
6
+ ip_public?: string;
7
+ ip_private?: string;
8
+ region: string;
9
+ zone?: string;
10
+ launch_time?: string;
11
+ monthly_cost_estimate?: number;
12
+ tags: Record<string, string>;
13
+ provider: string;
14
+ }
15
+ export interface ManagedDatabase {
16
+ id: string;
17
+ name: string;
18
+ engine: string;
19
+ version: string;
20
+ instance_class: string;
21
+ storage_gb: number;
22
+ storage_used_gb?: number;
23
+ status: 'available' | 'creating' | 'deleting' | 'stopped' | 'error' | 'unknown';
24
+ endpoint?: string;
25
+ backup_enabled: boolean;
26
+ backup_retention_days?: number;
27
+ region: string;
28
+ monthly_cost_estimate?: number;
29
+ tags: Record<string, string>;
30
+ provider: string;
31
+ }
32
+ export interface StorageBucket {
33
+ name: string;
34
+ region: string;
35
+ size_bytes?: number;
36
+ object_count?: number;
37
+ public_access: boolean;
38
+ encryption: boolean;
39
+ versioning: boolean;
40
+ created_at?: string;
41
+ provider: string;
42
+ }
43
+ export interface SecretInfo {
44
+ name: string;
45
+ description?: string;
46
+ created_at?: string;
47
+ last_rotated?: string;
48
+ rotation_enabled: boolean;
49
+ tags: Record<string, string>;
50
+ provider: string;
51
+ }
52
+ export interface ResourceTag {
53
+ resource_id: string;
54
+ resource_type: 'instance' | 'database' | 'storage' | 'secret' | 'other';
55
+ resource_name: string;
56
+ tags: Record<string, string>;
57
+ provider: string;
58
+ }
59
+ export interface HealthStatus {
60
+ provider: string;
61
+ instances: {
62
+ running: number;
63
+ stopped: number;
64
+ error: number;
65
+ total: number;
66
+ };
67
+ databases: {
68
+ available: number;
69
+ error: number;
70
+ total: number;
71
+ };
72
+ storage: {
73
+ total_buckets: number;
74
+ public_buckets: number;
75
+ };
76
+ pending_maintenance: string[];
77
+ overall: 'healthy' | 'warning' | 'critical';
78
+ }
79
+ export interface CostBreakdown {
80
+ provider: string;
81
+ period: string;
82
+ total_usd: number;
83
+ by_service: Array<{
84
+ service: string;
85
+ amount_usd: number;
86
+ pct: number;
87
+ }>;
88
+ vs_previous_month?: {
89
+ amount_usd: number;
90
+ change_pct: number;
91
+ };
92
+ }
93
+ export interface CostForecast {
94
+ provider: string;
95
+ scenarios: Array<{
96
+ label: 'conservative' | 'realistic' | 'optimistic';
97
+ months: Array<{
98
+ month: string;
99
+ amount_usd: number;
100
+ }>;
101
+ total_usd: number;
102
+ }>;
103
+ based_on_months: number;
104
+ }
105
+ export interface CostAnomaly {
106
+ resource_id: string;
107
+ resource_name: string;
108
+ resource_type: string;
109
+ service: string;
110
+ current_daily_usd: number;
111
+ baseline_daily_usd: number;
112
+ deviation_pct: number;
113
+ severity: Severity;
114
+ provider: string;
115
+ }
116
+ export interface IdleResource {
117
+ resource_id: string;
118
+ resource_name: string;
119
+ resource_type: 'instance' | 'volume' | 'bucket' | 'ip' | 'load-balancer';
120
+ reason: string;
121
+ monthly_savings_usd: number;
122
+ provider: string;
123
+ }
124
+ export interface SecurityFinding {
125
+ resource_id: string;
126
+ resource_name: string;
127
+ resource_type: string;
128
+ finding: 'public-bucket' | 'unencrypted-storage' | 'unrotated-secret' | 'public-database' | 'default-vpc';
129
+ severity: Severity;
130
+ description: string;
131
+ recommendation: string;
132
+ provider: string;
133
+ }
134
+ export interface ComplianceItem {
135
+ control: string;
136
+ category: string;
137
+ status: 'pass' | 'fail' | 'partial' | 'not-applicable';
138
+ evidence: string[];
139
+ resources_checked: number;
140
+ provider: string;
141
+ }
142
+ export type Severity = 'high' | 'medium' | 'low' | 'info';
143
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,50 @@
1
+ {
2
+ "name": "cloudvault-mcp",
3
+ "version": "1.0.0",
4
+ "description": "Cloud infrastructure analysis MCP server — AWS, GCP, Azure inventory and cost analysis",
5
+ "type": "module",
6
+ "main": "dist/index.js",
7
+ "bin": {
8
+ "cloudvault-mcp": "dist/index.js"
9
+ },
10
+ "files": ["dist/", "README.md", "LICENSE"],
11
+ "scripts": {
12
+ "build": "tsc",
13
+ "test": "vitest run",
14
+ "test:watch": "vitest",
15
+ "typecheck": "tsc --noEmit",
16
+ "clean": "rm -rf dist"
17
+ },
18
+ "dependencies": {
19
+ "@modelcontextprotocol/sdk": "^1.12.0",
20
+ "zod": "^3.24.0",
21
+ "better-sqlite3": "^11.0.0",
22
+ "@aws-sdk/client-ec2": "^3.600.0",
23
+ "@aws-sdk/client-rds": "^3.600.0",
24
+ "@aws-sdk/client-s3": "^3.600.0",
25
+ "@aws-sdk/client-secrets-manager": "^3.600.0",
26
+ "@aws-sdk/client-cost-explorer": "^3.600.0"
27
+ },
28
+ "devDependencies": {
29
+ "typescript": "^5.4.0",
30
+ "@types/better-sqlite3": "^7.6.0",
31
+ "@types/node": "^20.0.0",
32
+ "vitest": "^1.6.0"
33
+ },
34
+ "engines": {
35
+ "node": ">=18.0.0"
36
+ },
37
+ "keywords": [
38
+ "mcp",
39
+ "developer-tools",
40
+ "craftpipe",
41
+ "ai-tools",
42
+ "aws",
43
+ "gcp",
44
+ "azure",
45
+ "cloud",
46
+ "infrastructure",
47
+ "cost-optimization"
48
+ ],
49
+ "license": "MIT"
50
+ }