@grc-claw/integration-marketplace 0.8.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.
- package/dist/IntegrationMarketplace.d.ts +32 -0
- package/dist/IntegrationMarketplace.js +319 -0
- package/dist/connectors/ADPConnector.d.ts +12 -0
- package/dist/connectors/ADPConnector.js +97 -0
- package/dist/connectors/AWSCloudTrailConnector.d.ts +12 -0
- package/dist/connectors/AWSCloudTrailConnector.js +77 -0
- package/dist/connectors/AWSCloudWatchConnector.d.ts +12 -0
- package/dist/connectors/AWSCloudWatchConnector.js +70 -0
- package/dist/connectors/AWSGuardDutyConnector.d.ts +12 -0
- package/dist/connectors/AWSGuardDutyConnector.js +139 -0
- package/dist/connectors/AWSIAMConnector.d.ts +12 -0
- package/dist/connectors/AWSIAMConnector.js +90 -0
- package/dist/connectors/AWSKMSConnector.d.ts +12 -0
- package/dist/connectors/AWSKMSConnector.js +70 -0
- package/dist/connectors/AWSLambdaConnector.d.ts +12 -0
- package/dist/connectors/AWSLambdaConnector.js +84 -0
- package/dist/connectors/AWSRDSConnector.d.ts +12 -0
- package/dist/connectors/AWSRDSConnector.js +84 -0
- package/dist/connectors/AWSS3Connector.d.ts +12 -0
- package/dist/connectors/AWSS3Connector.js +112 -0
- package/dist/connectors/AkamaiConnector.d.ts +12 -0
- package/dist/connectors/AkamaiConnector.js +98 -0
- package/dist/connectors/ArgoCDConnector.d.ts +12 -0
- package/dist/connectors/ArgoCDConnector.js +93 -0
- package/dist/connectors/ArtifactoryConnector.d.ts +12 -0
- package/dist/connectors/ArtifactoryConnector.js +94 -0
- package/dist/connectors/AtlassianJiraConnector.d.ts +12 -0
- package/dist/connectors/AtlassianJiraConnector.js +134 -0
- package/dist/connectors/Auth0Connector.d.ts +12 -0
- package/dist/connectors/Auth0Connector.js +150 -0
- package/dist/connectors/AzureADConnector.d.ts +12 -0
- package/dist/connectors/AzureADConnector.js +115 -0
- package/dist/connectors/AzureDevOpsConnector.d.ts +12 -0
- package/dist/connectors/AzureDevOpsConnector.js +130 -0
- package/dist/connectors/AzureDevOpsPipelinesConnector.d.ts +12 -0
- package/dist/connectors/AzureDevOpsPipelinesConnector.js +72 -0
- package/dist/connectors/AzurePipelinesConnector.d.ts +12 -0
- package/dist/connectors/AzurePipelinesConnector.js +72 -0
- package/dist/connectors/AzurePolicyConnector.d.ts +12 -0
- package/dist/connectors/AzurePolicyConnector.js +141 -0
- package/dist/connectors/AzureReposConnector.d.ts +12 -0
- package/dist/connectors/AzureReposConnector.js +96 -0
- package/dist/connectors/AzureSentinelConnector.d.ts +12 -0
- package/dist/connectors/AzureSentinelConnector.js +88 -0
- package/dist/connectors/BambooCICDConnector.d.ts +12 -0
- package/dist/connectors/BambooCICDConnector.js +72 -0
- package/dist/connectors/BambooHRConnector.d.ts +12 -0
- package/dist/connectors/BambooHRConnector.js +84 -0
- package/dist/connectors/BeyondTrustConnector.d.ts +12 -0
- package/dist/connectors/BeyondTrustConnector.js +94 -0
- package/dist/connectors/BitbucketConnector.d.ts +12 -0
- package/dist/connectors/BitbucketConnector.js +100 -0
- package/dist/connectors/BitbucketPipelinesConnector.d.ts +12 -0
- package/dist/connectors/BitbucketPipelinesConnector.js +72 -0
- package/dist/connectors/BoxConnector.d.ts +12 -0
- package/dist/connectors/BoxConnector.js +122 -0
- package/dist/connectors/BuildkiteConnector.d.ts +12 -0
- package/dist/connectors/BuildkiteConnector.js +95 -0
- package/dist/connectors/CarbonBlackConnector.d.ts +12 -0
- package/dist/connectors/CarbonBlackConnector.js +89 -0
- package/dist/connectors/CassandraConnector.d.ts +12 -0
- package/dist/connectors/CassandraConnector.js +69 -0
- package/dist/connectors/CheckPointConnector.d.ts +12 -0
- package/dist/connectors/CheckPointConnector.js +98 -0
- package/dist/connectors/CircleCIConnector.d.ts +12 -0
- package/dist/connectors/CircleCIConnector.js +129 -0
- package/dist/connectors/CircleCIConnectorsConnector.d.ts +12 -0
- package/dist/connectors/CircleCIConnectorsConnector.js +69 -0
- package/dist/connectors/CiscoUmbrellaConnector.d.ts +12 -0
- package/dist/connectors/CiscoUmbrellaConnector.js +96 -0
- package/dist/connectors/CloudBeesJenkinsConnector.d.ts +12 -0
- package/dist/connectors/CloudBeesJenkinsConnector.js +70 -0
- package/dist/connectors/CloudflareDNSConnector.d.ts +12 -0
- package/dist/connectors/CloudflareDNSConnector.js +71 -0
- package/dist/connectors/CloudflareWAFConnector.d.ts +12 -0
- package/dist/connectors/CloudflareWAFConnector.js +98 -0
- package/dist/connectors/ConfluenceConnector.d.ts +12 -0
- package/dist/connectors/ConfluenceConnector.js +101 -0
- package/dist/connectors/ConstantContactConnector.d.ts +12 -0
- package/dist/connectors/ConstantContactConnector.js +70 -0
- package/dist/connectors/CouchDBConnector.d.ts +12 -0
- package/dist/connectors/CouchDBConnector.js +69 -0
- package/dist/connectors/CrowdStrikeConnector.d.ts +12 -0
- package/dist/connectors/CrowdStrikeConnector.js +86 -0
- package/dist/connectors/CrowdStrikeFalconConnector.d.ts +12 -0
- package/dist/connectors/CrowdStrikeFalconConnector.js +92 -0
- package/dist/connectors/CrowdStrikeSpotlightConnector.d.ts +12 -0
- package/dist/connectors/CrowdStrikeSpotlightConnector.js +139 -0
- package/dist/connectors/CyberArkConnector.d.ts +12 -0
- package/dist/connectors/CyberArkConnector.js +95 -0
- package/dist/connectors/DatabricksConnector.d.ts +12 -0
- package/dist/connectors/DatabricksConnector.js +95 -0
- package/dist/connectors/DatadogConnector.d.ts +12 -0
- package/dist/connectors/DatadogConnector.js +110 -0
- package/dist/connectors/DigitalOceanConnector.d.ts +12 -0
- package/dist/connectors/DigitalOceanConnector.js +85 -0
- package/dist/connectors/DiscordConnector.d.ts +12 -0
- package/dist/connectors/DiscordConnector.js +98 -0
- package/dist/connectors/DockerHubConnector.d.ts +12 -0
- package/dist/connectors/DockerHubConnector.js +80 -0
- package/dist/connectors/DocuSignConnector.d.ts +12 -0
- package/dist/connectors/DocuSignConnector.js +96 -0
- package/dist/connectors/DriftConnector.d.ts +12 -0
- package/dist/connectors/DriftConnector.js +69 -0
- package/dist/connectors/DropboxConnector.d.ts +12 -0
- package/dist/connectors/DropboxConnector.js +127 -0
- package/dist/connectors/ESETConnector.d.ts +12 -0
- package/dist/connectors/ESETConnector.js +70 -0
- package/dist/connectors/ElasticsearchCloudConnector.d.ts +12 -0
- package/dist/connectors/ElasticsearchCloudConnector.js +70 -0
- package/dist/connectors/FSecureConnector.d.ts +12 -0
- package/dist/connectors/FSecureConnector.js +70 -0
- package/dist/connectors/FeatureFlagConnector.d.ts +12 -0
- package/dist/connectors/FeatureFlagConnector.js +70 -0
- package/dist/connectors/FluxCDConnector.d.ts +12 -0
- package/dist/connectors/FluxCDConnector.js +94 -0
- package/dist/connectors/ForgeRockConnector.d.ts +12 -0
- package/dist/connectors/ForgeRockConnector.js +95 -0
- package/dist/connectors/FortinetConnector.d.ts +12 -0
- package/dist/connectors/FortinetConnector.js +98 -0
- package/dist/connectors/FreshdeskConnector.d.ts +12 -0
- package/dist/connectors/FreshdeskConnector.js +71 -0
- package/dist/connectors/GCPBigQueryConnector.d.ts +12 -0
- package/dist/connectors/GCPBigQueryConnector.js +71 -0
- package/dist/connectors/GCPComputeConnector.d.ts +12 -0
- package/dist/connectors/GCPComputeConnector.js +87 -0
- package/dist/connectors/GCPConfigConnector.d.ts +12 -0
- package/dist/connectors/GCPConfigConnector.js +149 -0
- package/dist/connectors/GCPFirestoreConnector.d.ts +12 -0
- package/dist/connectors/GCPFirestoreConnector.js +71 -0
- package/dist/connectors/GCPIAMConnector.d.ts +12 -0
- package/dist/connectors/GCPIAMConnector.js +98 -0
- package/dist/connectors/GCPSCCConnector.d.ts +12 -0
- package/dist/connectors/GCPSCCConnector.js +94 -0
- package/dist/connectors/GitHubActionsConnector.d.ts +12 -0
- package/dist/connectors/GitHubActionsConnector.js +104 -0
- package/dist/connectors/GitHubConnector.d.ts +12 -0
- package/dist/connectors/GitHubConnector.js +135 -0
- package/dist/connectors/GitHubCopilotConnector.d.ts +12 -0
- package/dist/connectors/GitHubCopilotConnector.js +72 -0
- package/dist/connectors/GitLabCIConnector.d.ts +12 -0
- package/dist/connectors/GitLabCIConnector.js +71 -0
- package/dist/connectors/GitLabConnector.d.ts +12 -0
- package/dist/connectors/GitLabConnector.js +101 -0
- package/dist/connectors/GitLabSASTConnector.d.ts +12 -0
- package/dist/connectors/GitLabSASTConnector.js +130 -0
- package/dist/connectors/GoogleWorkspaceConnector.d.ts +12 -0
- package/dist/connectors/GoogleWorkspaceConnector.js +136 -0
- package/dist/connectors/HelmConnector.d.ts +12 -0
- package/dist/connectors/HelmConnector.js +94 -0
- package/dist/connectors/HubSpotConnector.d.ts +12 -0
- package/dist/connectors/HubSpotConnector.js +77 -0
- package/dist/connectors/IFTTTConnector.d.ts +12 -0
- package/dist/connectors/IFTTTConnector.js +70 -0
- package/dist/connectors/ImpervaConnector.d.ts +12 -0
- package/dist/connectors/ImpervaConnector.js +94 -0
- package/dist/connectors/InfluxDBConnector.d.ts +12 -0
- package/dist/connectors/InfluxDBConnector.js +70 -0
- package/dist/connectors/IntercomConnector.d.ts +12 -0
- package/dist/connectors/IntercomConnector.js +69 -0
- package/dist/connectors/JenkinsConnector.d.ts +12 -0
- package/dist/connectors/JenkinsConnector.js +96 -0
- package/dist/connectors/JiraConnector.d.ts +12 -0
- package/dist/connectors/JiraConnector.js +103 -0
- package/dist/connectors/KafkaConnector.d.ts +12 -0
- package/dist/connectors/KafkaConnector.js +70 -0
- package/dist/connectors/KasperskyConnector.d.ts +12 -0
- package/dist/connectors/KasperskyConnector.js +70 -0
- package/dist/connectors/KubernetesConnector.d.ts +12 -0
- package/dist/connectors/KubernetesConnector.js +109 -0
- package/dist/connectors/LaceworkConnector.d.ts +13 -0
- package/dist/connectors/LaceworkConnector.js +143 -0
- package/dist/connectors/LaunchDarklyConnector.d.ts +12 -0
- package/dist/connectors/LaunchDarklyConnector.js +86 -0
- package/dist/connectors/LinodeConnector.d.ts +12 -0
- package/dist/connectors/LinodeConnector.js +70 -0
- package/dist/connectors/LookerConnector.d.ts +12 -0
- package/dist/connectors/LookerConnector.js +94 -0
- package/dist/connectors/MailchimpConnector.d.ts +12 -0
- package/dist/connectors/MailchimpConnector.js +71 -0
- package/dist/connectors/MalwarebytesConnector.d.ts +12 -0
- package/dist/connectors/MalwarebytesConnector.js +85 -0
- package/dist/connectors/McAfeeConnector.d.ts +12 -0
- package/dist/connectors/McAfeeConnector.js +85 -0
- package/dist/connectors/Microsoft365Connector.d.ts +12 -0
- package/dist/connectors/Microsoft365Connector.js +139 -0
- package/dist/connectors/MongoDBConnector.d.ts +12 -0
- package/dist/connectors/MongoDBConnector.js +86 -0
- package/dist/connectors/NamelyConnector.d.ts +12 -0
- package/dist/connectors/NamelyConnector.js +97 -0
- package/dist/connectors/Neo4jConnector.d.ts +12 -0
- package/dist/connectors/Neo4jConnector.js +70 -0
- package/dist/connectors/NetSuiteConnector.d.ts +12 -0
- package/dist/connectors/NetSuiteConnector.js +94 -0
- package/dist/connectors/NetskopeConnector.d.ts +12 -0
- package/dist/connectors/NetskopeConnector.js +98 -0
- package/dist/connectors/NexusConnector.d.ts +12 -0
- package/dist/connectors/NexusConnector.js +93 -0
- package/dist/connectors/NotionConnector.d.ts +12 -0
- package/dist/connectors/NotionConnector.js +109 -0
- package/dist/connectors/OktaConnector.d.ts +12 -0
- package/dist/connectors/OktaConnector.js +123 -0
- package/dist/connectors/OktaSystemLogConnector.d.ts +12 -0
- package/dist/connectors/OktaSystemLogConnector.js +129 -0
- package/dist/connectors/OpsgenieConnector.d.ts +12 -0
- package/dist/connectors/OpsgenieConnector.js +70 -0
- package/dist/connectors/PagerDutyConnector.d.ts +12 -0
- package/dist/connectors/PagerDutyConnector.js +106 -0
- package/dist/connectors/PalantirConnector.d.ts +12 -0
- package/dist/connectors/PalantirConnector.js +95 -0
- package/dist/connectors/PaloAltoPrismaCloudConnector.d.ts +12 -0
- package/dist/connectors/PaloAltoPrismaCloudConnector.js +110 -0
- package/dist/connectors/PingFederateConnector.d.ts +12 -0
- package/dist/connectors/PingFederateConnector.js +97 -0
- package/dist/connectors/PostgreSQLCloudConnector.d.ts +12 -0
- package/dist/connectors/PostgreSQLCloudConnector.js +70 -0
- package/dist/connectors/PowerBIConnector.d.ts +12 -0
- package/dist/connectors/PowerBIConnector.js +95 -0
- package/dist/connectors/PrismaCloudConnector.d.ts +12 -0
- package/dist/connectors/PrismaCloudConnector.js +147 -0
- package/dist/connectors/QualysConnector.d.ts +12 -0
- package/dist/connectors/QualysConnector.js +96 -0
- package/dist/connectors/QualysScannerConnector.d.ts +12 -0
- package/dist/connectors/QualysScannerConnector.js +131 -0
- package/dist/connectors/QuickBooksConnector.d.ts +12 -0
- package/dist/connectors/QuickBooksConnector.js +97 -0
- package/dist/connectors/RabbitMQConnector.d.ts +12 -0
- package/dist/connectors/RabbitMQConnector.js +69 -0
- package/dist/connectors/RadwareConnector.d.ts +12 -0
- package/dist/connectors/RadwareConnector.js +94 -0
- package/dist/connectors/RedisCloudConnector.d.ts +12 -0
- package/dist/connectors/RedisCloudConnector.js +70 -0
- package/dist/connectors/RingCentralConnector.d.ts +12 -0
- package/dist/connectors/RingCentralConnector.js +94 -0
- package/dist/connectors/SAPSuccessFactorsConnector.d.ts +12 -0
- package/dist/connectors/SAPSuccessFactorsConnector.js +103 -0
- package/dist/connectors/SailPointConnector.d.ts +12 -0
- package/dist/connectors/SailPointConnector.js +97 -0
- package/dist/connectors/SalesforceConnector.d.ts +12 -0
- package/dist/connectors/SalesforceConnector.js +91 -0
- package/dist/connectors/SendGridConnector.d.ts +12 -0
- package/dist/connectors/SendGridConnector.js +69 -0
- package/dist/connectors/SentinelOneConnector.d.ts +12 -0
- package/dist/connectors/SentinelOneConnector.js +89 -0
- package/dist/connectors/ServiceNowConnector.d.ts +12 -0
- package/dist/connectors/ServiceNowConnector.js +123 -0
- package/dist/connectors/SlackConnector.d.ts +12 -0
- package/dist/connectors/SlackConnector.js +109 -0
- package/dist/connectors/SnowflakeConnector.d.ts +12 -0
- package/dist/connectors/SnowflakeConnector.js +105 -0
- package/dist/connectors/SnykConnector.d.ts +12 -0
- package/dist/connectors/SnykConnector.js +84 -0
- package/dist/connectors/SnykMonitorConnector.d.ts +12 -0
- package/dist/connectors/SnykMonitorConnector.js +131 -0
- package/dist/connectors/SophosConnector.d.ts +12 -0
- package/dist/connectors/SophosConnector.js +87 -0
- package/dist/connectors/SpinnakerConnector.d.ts +12 -0
- package/dist/connectors/SpinnakerConnector.js +70 -0
- package/dist/connectors/SplunkConnector.d.ts +12 -0
- package/dist/connectors/SplunkConnector.js +126 -0
- package/dist/connectors/StripeConnector.d.ts +12 -0
- package/dist/connectors/StripeConnector.js +97 -0
- package/dist/connectors/TableauConnector.d.ts +12 -0
- package/dist/connectors/TableauConnector.js +101 -0
- package/dist/connectors/TaniumConnector.d.ts +12 -0
- package/dist/connectors/TaniumConnector.js +97 -0
- package/dist/connectors/TeamCityConnector.d.ts +12 -0
- package/dist/connectors/TeamCityConnector.js +71 -0
- package/dist/connectors/TeamsConnector.d.ts +12 -0
- package/dist/connectors/TeamsConnector.js +96 -0
- package/dist/connectors/TenableIOConnector.d.ts +12 -0
- package/dist/connectors/TenableIOConnector.js +130 -0
- package/dist/connectors/TerraformCloudConnector.d.ts +12 -0
- package/dist/connectors/TerraformCloudConnector.js +106 -0
- package/dist/connectors/TravisCIConnector.d.ts +12 -0
- package/dist/connectors/TravisCIConnector.js +95 -0
- package/dist/connectors/TrendMicroConnector.d.ts +12 -0
- package/dist/connectors/TrendMicroConnector.js +85 -0
- package/dist/connectors/TwilioConnector.d.ts +12 -0
- package/dist/connectors/TwilioConnector.js +70 -0
- package/dist/connectors/VercelConnector.d.ts +12 -0
- package/dist/connectors/VercelConnector.js +70 -0
- package/dist/connectors/VultrConnector.d.ts +12 -0
- package/dist/connectors/VultrConnector.js +70 -0
- package/dist/connectors/WebexConnector.d.ts +12 -0
- package/dist/connectors/WebexConnector.js +94 -0
- package/dist/connectors/WizConnector.d.ts +12 -0
- package/dist/connectors/WizConnector.js +172 -0
- package/dist/connectors/WorkdayConnector.d.ts +12 -0
- package/dist/connectors/WorkdayConnector.js +100 -0
- package/dist/connectors/XeroConnector.d.ts +12 -0
- package/dist/connectors/XeroConnector.js +96 -0
- package/dist/connectors/ZapierConnector.d.ts +12 -0
- package/dist/connectors/ZapierConnector.js +70 -0
- package/dist/connectors/ZendeskConnector.d.ts +12 -0
- package/dist/connectors/ZendeskConnector.js +71 -0
- package/dist/connectors/ZenefitsConnector.d.ts +12 -0
- package/dist/connectors/ZenefitsConnector.js +93 -0
- package/dist/connectors/ZoomConnector.d.ts +12 -0
- package/dist/connectors/ZoomConnector.js +97 -0
- package/dist/connectors/ZscalerConnector.d.ts +12 -0
- package/dist/connectors/ZscalerConnector.js +97 -0
- package/dist/connectors/index.d.ts +150 -0
- package/dist/connectors/index.js +157 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +16 -0
- package/dist/index.test.d.ts +1 -0
- package/dist/index.test.js +139 -0
- package/dist/types.d.ts +57 -0
- package/dist/types.js +8 -0
- package/package.json +33 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { describe, it } from "node:test";
|
|
2
|
+
import assert from "node:assert/strict";
|
|
3
|
+
import { IntegrationMarketplace } from "./IntegrationMarketplace.js";
|
|
4
|
+
class MockConnector {
|
|
5
|
+
id;
|
|
6
|
+
name;
|
|
7
|
+
category = "version_control";
|
|
8
|
+
authType = "api_key";
|
|
9
|
+
capabilities = [
|
|
10
|
+
{ id: "test-cap", name: "Test Capability", description: "Test", evidenceCategories: ["test"] },
|
|
11
|
+
];
|
|
12
|
+
frameworks = ["SOC2"];
|
|
13
|
+
shouldFail = false;
|
|
14
|
+
constructor(id, name, fail = false) {
|
|
15
|
+
this.id = id;
|
|
16
|
+
this.name = name;
|
|
17
|
+
this.shouldFail = fail;
|
|
18
|
+
}
|
|
19
|
+
async collectEvidence() {
|
|
20
|
+
if (this.shouldFail)
|
|
21
|
+
throw new Error("Mock failure");
|
|
22
|
+
return [
|
|
23
|
+
{
|
|
24
|
+
id: `ev-${this.id}-1`,
|
|
25
|
+
connectorId: this.id,
|
|
26
|
+
capabilityId: "test-cap",
|
|
27
|
+
timestamp: new Date().toISOString(),
|
|
28
|
+
hash: "sha256:abc123",
|
|
29
|
+
framework: "SOC2",
|
|
30
|
+
controlId: "CC6.1",
|
|
31
|
+
source: `mock/${this.id}`,
|
|
32
|
+
status: "compliant",
|
|
33
|
+
data: { test: true },
|
|
34
|
+
metadata: {},
|
|
35
|
+
},
|
|
36
|
+
];
|
|
37
|
+
}
|
|
38
|
+
async testConnection() {
|
|
39
|
+
return !this.shouldFail;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
const mockConfig = { apiToken: "test-token" };
|
|
43
|
+
describe("IntegrationMarketplace", () => {
|
|
44
|
+
it("should register built-in connectors", () => {
|
|
45
|
+
const marketplace = new IntegrationMarketplace();
|
|
46
|
+
const stats = marketplace.getStats();
|
|
47
|
+
assert.ok(stats.totalConnectors >= 25);
|
|
48
|
+
assert.ok(stats.totalCapabilities > 25);
|
|
49
|
+
});
|
|
50
|
+
it("should register a custom connector", () => {
|
|
51
|
+
const marketplace = new IntegrationMarketplace();
|
|
52
|
+
const custom = new MockConnector("custom-1", "Custom Tool");
|
|
53
|
+
marketplace.registerConnector(custom);
|
|
54
|
+
assert.ok(marketplace.getConnector("custom-1"));
|
|
55
|
+
});
|
|
56
|
+
it("should unregister a connector", () => {
|
|
57
|
+
const marketplace = new IntegrationMarketplace();
|
|
58
|
+
const custom = new MockConnector("custom-1", "Custom Tool");
|
|
59
|
+
marketplace.registerConnector(custom);
|
|
60
|
+
assert.ok(marketplace.unregisterConnector("custom-1"));
|
|
61
|
+
assert.equal(marketplace.getConnector("custom-1"), undefined);
|
|
62
|
+
});
|
|
63
|
+
it("should enable/disable connectors", () => {
|
|
64
|
+
const marketplace = new IntegrationMarketplace();
|
|
65
|
+
const total = marketplace.getStats().totalConnectors;
|
|
66
|
+
marketplace.disableConnector("github");
|
|
67
|
+
assert.equal(marketplace.getEnabledConnectors().length, total - 1);
|
|
68
|
+
marketplace.enableConnector("github");
|
|
69
|
+
assert.equal(marketplace.getEnabledConnectors().length, total);
|
|
70
|
+
});
|
|
71
|
+
it("should filter connectors by category", () => {
|
|
72
|
+
const marketplace = new IntegrationMarketplace();
|
|
73
|
+
const cloudProviders = marketplace.getConnectorsByCategory("cloud_provider");
|
|
74
|
+
assert.ok(cloudProviders.length >= 4);
|
|
75
|
+
assert.ok(cloudProviders.every((c) => c.category === "cloud_provider"));
|
|
76
|
+
});
|
|
77
|
+
it("should filter connectors by framework", () => {
|
|
78
|
+
const marketplace = new IntegrationMarketplace();
|
|
79
|
+
const hipaaConnectors = marketplace.getConnectorsByFramework("HIPAA");
|
|
80
|
+
assert.ok(hipaaConnectors.length >= 2);
|
|
81
|
+
assert.ok(hipaaConnectors.every((c) => c.frameworks.includes("HIPAA")));
|
|
82
|
+
});
|
|
83
|
+
it("should collect from a custom connector", async () => {
|
|
84
|
+
const marketplace = new IntegrationMarketplace();
|
|
85
|
+
const custom = new MockConnector("custom-1", "Custom Tool");
|
|
86
|
+
marketplace.registerConnector(custom);
|
|
87
|
+
marketplace.setConfig("custom-1", mockConfig);
|
|
88
|
+
const job = await marketplace.collectFromConnector("custom-1");
|
|
89
|
+
assert.equal(job.status, "completed");
|
|
90
|
+
assert.equal(job.artifacts.length, 1);
|
|
91
|
+
assert.equal(job.connectorId, "custom-1");
|
|
92
|
+
});
|
|
93
|
+
it("should handle collection failures gracefully", async () => {
|
|
94
|
+
const marketplace = new IntegrationMarketplace();
|
|
95
|
+
const failing = new MockConnector("fail-1", "Failing Tool", true);
|
|
96
|
+
marketplace.registerConnector(failing);
|
|
97
|
+
marketplace.setConfig("fail-1", mockConfig);
|
|
98
|
+
const job = await marketplace.collectFromConnector("fail-1");
|
|
99
|
+
assert.equal(job.status, "failed");
|
|
100
|
+
assert.ok(job.error);
|
|
101
|
+
});
|
|
102
|
+
it("should return stats correctly", () => {
|
|
103
|
+
const marketplace = new IntegrationMarketplace();
|
|
104
|
+
const stats = marketplace.getStats();
|
|
105
|
+
assert.ok(stats.totalConnectors >= 25);
|
|
106
|
+
assert.ok(Object.keys(stats.connectorsByCategory).length > 0);
|
|
107
|
+
assert.ok(stats.frameworksSupported.length > 0);
|
|
108
|
+
});
|
|
109
|
+
it("should track jobs", async () => {
|
|
110
|
+
const marketplace = new IntegrationMarketplace();
|
|
111
|
+
const custom = new MockConnector("custom-1", "Custom Tool");
|
|
112
|
+
marketplace.registerConnector(custom);
|
|
113
|
+
marketplace.setConfig("custom-1", mockConfig);
|
|
114
|
+
await marketplace.collectFromConnector("custom-1");
|
|
115
|
+
const jobs = marketplace.getJobs();
|
|
116
|
+
assert.equal(jobs.length, 1);
|
|
117
|
+
assert.equal(jobs[0].status, "completed");
|
|
118
|
+
});
|
|
119
|
+
it("should throw on collect from missing connector", async () => {
|
|
120
|
+
const marketplace = new IntegrationMarketplace();
|
|
121
|
+
await assert.rejects(() => marketplace.collectFromConnector("nonexistent"), /Connector not found/);
|
|
122
|
+
});
|
|
123
|
+
it("should throw on collect without config", async () => {
|
|
124
|
+
const marketplace = new IntegrationMarketplace();
|
|
125
|
+
const custom = new MockConnector("custom-1", "Custom Tool");
|
|
126
|
+
marketplace.registerConnector(custom);
|
|
127
|
+
await assert.rejects(() => marketplace.collectFromConnector("custom-1"), /No config/);
|
|
128
|
+
});
|
|
129
|
+
it("should test connections for enabled connectors", async () => {
|
|
130
|
+
const marketplace = new IntegrationMarketplace();
|
|
131
|
+
marketplace.registerConnector(new MockConnector("m1", "Mock1"));
|
|
132
|
+
marketplace.registerConnector(new MockConnector("m2", "Mock2", true));
|
|
133
|
+
marketplace.setConfig("m1", mockConfig);
|
|
134
|
+
marketplace.setConfig("m2", mockConfig);
|
|
135
|
+
const results = await marketplace.testAllConnections();
|
|
136
|
+
assert.equal(results.get("m1"), true);
|
|
137
|
+
assert.equal(results.get("m2"), false);
|
|
138
|
+
});
|
|
139
|
+
});
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
export type IntegrationCategory = "version_control" | "cloud_provider" | "identity" | "siem" | "project_management" | "communication" | "incident_management" | "data_warehouse" | "monitoring" | "endpoint" | "vulnerability" | "iac" | "ci_cd" | "container" | "infrastructure" | "hr" | "documentation" | "workspace" | "document_management" | "file_storage" | "finance";
|
|
2
|
+
export type AuthType = "api_key" | "oauth2" | "bearer_token" | "basic_auth" | "service_account" | "webhook";
|
|
3
|
+
export type ComplianceFramework = "SOC2" | "ISO27001" | "NIST_CSF" | "HIPAA" | "PCI_DSS" | "GDPR" | "CIS";
|
|
4
|
+
export type EvidenceStatus = "compliant" | "non_compliant" | "partial" | "unknown";
|
|
5
|
+
export interface IntegrationCapability {
|
|
6
|
+
id: string;
|
|
7
|
+
name: string;
|
|
8
|
+
description: string;
|
|
9
|
+
evidenceCategories: string[];
|
|
10
|
+
}
|
|
11
|
+
export interface EvidenceArtifact {
|
|
12
|
+
id: string;
|
|
13
|
+
connectorId: string;
|
|
14
|
+
capabilityId: string;
|
|
15
|
+
timestamp: string;
|
|
16
|
+
hash: string;
|
|
17
|
+
framework: ComplianceFramework;
|
|
18
|
+
controlId: string;
|
|
19
|
+
source: string;
|
|
20
|
+
status: EvidenceStatus;
|
|
21
|
+
data: Record<string, unknown>;
|
|
22
|
+
metadata: Record<string, string>;
|
|
23
|
+
}
|
|
24
|
+
export interface ConnectorConfig {
|
|
25
|
+
baseUrl?: string;
|
|
26
|
+
apiToken?: string;
|
|
27
|
+
clientId?: string;
|
|
28
|
+
clientSecret?: string;
|
|
29
|
+
tenantId?: string;
|
|
30
|
+
region?: string;
|
|
31
|
+
accountId?: string;
|
|
32
|
+
extra?: Record<string, string>;
|
|
33
|
+
}
|
|
34
|
+
export interface IntegrationConnector {
|
|
35
|
+
readonly id: string;
|
|
36
|
+
readonly name: string;
|
|
37
|
+
readonly category: IntegrationCategory;
|
|
38
|
+
readonly authType: AuthType;
|
|
39
|
+
readonly capabilities: IntegrationCapability[];
|
|
40
|
+
readonly frameworks: ComplianceFramework[];
|
|
41
|
+
collectEvidence(config: ConnectorConfig): Promise<EvidenceArtifact[]>;
|
|
42
|
+
testConnection(config: ConnectorConfig): Promise<boolean>;
|
|
43
|
+
}
|
|
44
|
+
export interface MarketplaceStats {
|
|
45
|
+
totalConnectors: number;
|
|
46
|
+
connectorsByCategory: Record<IntegrationCategory, number>;
|
|
47
|
+
totalCapabilities: number;
|
|
48
|
+
frameworksSupported: ComplianceFramework[];
|
|
49
|
+
}
|
|
50
|
+
export interface ConnectorRegistration {
|
|
51
|
+
connector: IntegrationConnector;
|
|
52
|
+
enabled: boolean;
|
|
53
|
+
lastCollectedAt?: string;
|
|
54
|
+
errorCount: number;
|
|
55
|
+
}
|
|
56
|
+
export declare function hashEvidence(data: Record<string, unknown>): string;
|
|
57
|
+
export declare function generateEvidenceId(): string;
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { createHash, randomUUID } from "node:crypto";
|
|
2
|
+
export function hashEvidence(data) {
|
|
3
|
+
const payload = JSON.stringify(data, Object.keys(data).sort());
|
|
4
|
+
return `sha256:${createHash("sha256").update(payload).digest("hex")}`;
|
|
5
|
+
}
|
|
6
|
+
export function generateEvidenceId() {
|
|
7
|
+
return `ev-${randomUUID()}`;
|
|
8
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@grc-claw/integration-marketplace",
|
|
3
|
+
"version": "0.8.0",
|
|
4
|
+
"description": "Marketplace of 100+ SaaS integrations for automated GRC evidence collection",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"type": "module",
|
|
7
|
+
"main": "./dist/index.js",
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": {
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"import": "./dist/index.js"
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
"scripts": {
|
|
16
|
+
"build": "tsc -p tsconfig.json",
|
|
17
|
+
"test": "node --import tsx --test src/**/*.test.ts"
|
|
18
|
+
},
|
|
19
|
+
"files": [
|
|
20
|
+
"dist"
|
|
21
|
+
],
|
|
22
|
+
"devDependencies": {
|
|
23
|
+
"typescript": "^5.7.0",
|
|
24
|
+
"tsx": "^4.19.0"
|
|
25
|
+
},
|
|
26
|
+
"publishConfig": {
|
|
27
|
+
"access": "public"
|
|
28
|
+
},
|
|
29
|
+
"repository": {
|
|
30
|
+
"type": "git",
|
|
31
|
+
"url": "https://github.com/AAH20/GRC_Claw"
|
|
32
|
+
}
|
|
33
|
+
}
|