@transcend-io/cli 9.0.0 → 10.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.
- package/LICENSE +201 -0
- package/README.md +26 -34
- package/dist/RateCounter-DFL_mnk2.mjs +2 -0
- package/dist/RateCounter-DFL_mnk2.mjs.map +1 -0
- package/dist/RequestDataSilo-_Iv44M9u.mjs +51 -0
- package/dist/RequestDataSilo-_Iv44M9u.mjs.map +1 -0
- package/dist/app-By_zDIkK.mjs +131 -0
- package/dist/app-By_zDIkK.mjs.map +1 -0
- package/dist/approvePrivacyRequests-1cguqGqq.mjs +2 -0
- package/dist/approvePrivacyRequests-1cguqGqq.mjs.map +1 -0
- package/dist/assessment-BDywVaGR.mjs +284 -0
- package/dist/assessment-BDywVaGR.mjs.map +1 -0
- package/dist/bin/bash-complete.mjs +1 -1
- package/dist/bin/bash-complete.mjs.map +1 -1
- package/dist/bin/cli.mjs +1 -1
- package/dist/bin/cli.mjs.map +1 -1
- package/dist/bin/deprecated-command.mjs +1 -1
- package/dist/bin/deprecated-command.mjs.map +1 -1
- package/dist/bluebird-CUitXgsY.mjs +2 -0
- package/dist/bluebird-CUitXgsY.mjs.map +1 -0
- package/dist/buildXdiSyncEndpoint-BMaMHO7Z.mjs +9 -0
- package/dist/buildXdiSyncEndpoint-BMaMHO7Z.mjs.map +1 -0
- package/dist/bulkRestartRequests-DEPSHov-.mjs +2 -0
- package/dist/bulkRestartRequests-DEPSHov-.mjs.map +1 -0
- package/dist/bulkRetryEnrichers-BLkcFKXC.mjs +2 -0
- package/dist/bulkRetryEnrichers-BLkcFKXC.mjs.map +1 -0
- package/dist/cancelPrivacyRequests-C8MZQvsq.mjs +2 -0
- package/dist/cancelPrivacyRequests-C8MZQvsq.mjs.map +1 -0
- package/dist/codecs-BE3Wmoh8.mjs +2 -0
- package/dist/codecs-BE3Wmoh8.mjs.map +1 -0
- package/dist/codecs-Dx_vGxsl.mjs +2 -0
- package/dist/codecs-Dx_vGxsl.mjs.map +1 -0
- package/dist/{command-BlHM1nCd.mjs → command-BUnCUxva.mjs} +2 -2
- package/dist/command-BUnCUxva.mjs.map +1 -0
- package/dist/consentManagersToBusinessEntities-BDgOFga7.mjs +5 -0
- package/dist/consentManagersToBusinessEntities-BDgOFga7.mjs.map +1 -0
- package/dist/constants-AFtS5Nad.mjs +4 -0
- package/dist/constants-AFtS5Nad.mjs.map +1 -0
- package/dist/constants-CeMiHaHx.mjs +2 -0
- package/dist/constants-CeMiHaHx.mjs.map +1 -0
- package/dist/constants-lIvXgkdp.mjs +2 -0
- package/dist/constants-lIvXgkdp.mjs.map +1 -0
- package/dist/{context-bkKpii_t.mjs → context-CdSyuBlf.mjs} +1 -1
- package/dist/context-CdSyuBlf.mjs.map +1 -0
- package/dist/{pooling-BkZAO1Zs.mjs → createExtraKeyHandler-C_0EVj10.mjs} +5 -5
- package/dist/createExtraKeyHandler-C_0EVj10.mjs.map +1 -0
- package/dist/createPreferenceAccessTokens-6WLr6z-l.mjs +10 -0
- package/dist/createPreferenceAccessTokens-6WLr6z-l.mjs.map +1 -0
- package/dist/createSombraGotInstance-CahOgD6V.mjs +10 -0
- package/dist/createSombraGotInstance-CahOgD6V.mjs.map +1 -0
- package/dist/{dataFlowsToDataSilos-RAhfPV0l.mjs → dataFlowsToDataSilos-NhvBw1iy.mjs} +1 -1
- package/dist/dataFlowsToDataSilos-NhvBw1iy.mjs.map +1 -0
- package/dist/dataSilo-DrFetFXw.mjs +302 -0
- package/dist/dataSilo-DrFetFXw.mjs.map +1 -0
- package/dist/dataSubject-y_aXI0pa.mjs +92 -0
- package/dist/dataSubject-y_aXI0pa.mjs.map +1 -0
- package/dist/{done-input-validation-CcZtaz03.mjs → done-input-validation-DLR0-MJ7.mjs} +1 -1
- package/dist/{done-input-validation-CcZtaz03.mjs.map → done-input-validation-DLR0-MJ7.mjs.map} +1 -1
- package/dist/downloadPrivacyRequestFiles-B2yduagB.mjs +2 -0
- package/dist/downloadPrivacyRequestFiles-B2yduagB.mjs.map +1 -0
- package/dist/enums-CyFTrzXY.mjs.map +1 -1
- package/dist/extractClientError-DPjv09EH.mjs +2 -0
- package/dist/extractClientError-DPjv09EH.mjs.map +1 -0
- package/dist/extractErrorMessage-CPnTsT1S.mjs +2 -0
- package/dist/extractErrorMessage-CPnTsT1S.mjs.map +1 -0
- package/dist/fetchAllActions-C0l3wjQV.mjs +832 -0
- package/dist/fetchAllActions-C0l3wjQV.mjs.map +1 -0
- package/dist/fetchAllDataFlows-AQ9j_NRa.mjs +2 -0
- package/dist/fetchAllDataFlows-AQ9j_NRa.mjs.map +1 -0
- package/dist/fetchAllPreferenceTopics-Bn9PG-rO.mjs +36 -0
- package/dist/fetchAllPreferenceTopics-Bn9PG-rO.mjs.map +1 -0
- package/dist/fetchAllPurposes-CykSkZRY.mjs +29 -0
- package/dist/fetchAllPurposes-CykSkZRY.mjs.map +1 -0
- package/dist/fetchAllPurposesAndPreferences-Dog6N9L2.mjs +2 -0
- package/dist/fetchAllPurposesAndPreferences-Dog6N9L2.mjs.map +1 -0
- package/dist/fetchAllRequestEnrichers-q34mRuE5.mjs +42 -0
- package/dist/fetchAllRequestEnrichers-q34mRuE5.mjs.map +1 -0
- package/dist/fetchAllRequestIdentifiers-YP-geTV4.mjs +10 -0
- package/dist/fetchAllRequestIdentifiers-YP-geTV4.mjs.map +1 -0
- package/dist/fetchAllRequests-DEPTEUbi.mjs +2 -0
- package/dist/fetchAllRequests-DEPTEUbi.mjs.map +1 -0
- package/dist/fetchApiKeys-DkBco7W0.mjs +33 -0
- package/dist/fetchApiKeys-DkBco7W0.mjs.map +1 -0
- package/dist/fetchCatalogs-CBk871k6.mjs +12 -0
- package/dist/fetchCatalogs-CBk871k6.mjs.map +1 -0
- package/dist/fetchConsentManagerId-DHDA5Py9.mjs +321 -0
- package/dist/fetchConsentManagerId-DHDA5Py9.mjs.map +1 -0
- package/dist/fetchIdentifiers-DjqjUnaw.mjs +54 -0
- package/dist/fetchIdentifiers-DjqjUnaw.mjs.map +1 -0
- package/dist/fetchRequestDataSilo-CF6XOTQ-.mjs +2 -0
- package/dist/fetchRequestDataSilo-CF6XOTQ-.mjs.map +1 -0
- package/dist/fetchRequestFilesForRequest-DrHGOdih.mjs +33 -0
- package/dist/fetchRequestFilesForRequest-DrHGOdih.mjs.map +1 -0
- package/dist/generateCrossAccountApiKeys-F11uqpc5.mjs +33 -0
- package/dist/generateCrossAccountApiKeys-F11uqpc5.mjs.map +1 -0
- package/dist/impl--Lmj1RHh2.mjs +2 -0
- package/dist/impl--Lmj1RHh2.mjs.map +1 -0
- package/dist/impl-0ooudQ_J2.mjs +4 -0
- package/dist/impl-0ooudQ_J2.mjs.map +1 -0
- package/dist/{impl-BYBNi68b.mjs → impl-1U4QBT_L.mjs} +2 -2
- package/dist/impl-1U4QBT_L.mjs.map +1 -0
- package/dist/impl-2FbPcOv_2.mjs +2 -0
- package/dist/impl-2FbPcOv_2.mjs.map +1 -0
- package/dist/impl-ArGeiHuz.mjs +2 -0
- package/dist/impl-ArGeiHuz.mjs.map +1 -0
- package/dist/impl-B8iVBYdg.mjs +2 -0
- package/dist/impl-B8iVBYdg.mjs.map +1 -0
- package/dist/impl-BWjBYTQZ.mjs +2 -0
- package/dist/impl-BWjBYTQZ.mjs.map +1 -0
- package/dist/impl-Bc8Es_bT.mjs +7 -0
- package/dist/impl-Bc8Es_bT.mjs.map +1 -0
- package/dist/impl-BkyC7nnu.mjs +2 -0
- package/dist/impl-BkyC7nnu.mjs.map +1 -0
- package/dist/impl-BpUksm1b2.mjs +2 -0
- package/dist/impl-BpUksm1b2.mjs.map +1 -0
- package/dist/impl-BzupMfJi.mjs +12 -0
- package/dist/impl-BzupMfJi.mjs.map +1 -0
- package/dist/impl-C05tQHSq.mjs +2 -0
- package/dist/impl-C05tQHSq.mjs.map +1 -0
- package/dist/impl-CMX0qQr_2.mjs +2 -0
- package/dist/impl-CMX0qQr_2.mjs.map +1 -0
- package/dist/impl-CWHnw3oX.mjs +2 -0
- package/dist/impl-CWHnw3oX.mjs.map +1 -0
- package/dist/impl-CXK-D84c.mjs +4 -0
- package/dist/impl-CXK-D84c.mjs.map +1 -0
- package/dist/impl-CdoTu8TH.mjs +2 -0
- package/dist/impl-CdoTu8TH.mjs.map +1 -0
- package/dist/impl-CeLfAnyA2.mjs +2 -0
- package/dist/impl-CeLfAnyA2.mjs.map +1 -0
- package/dist/impl-Cgg_bv7j.mjs +2 -0
- package/dist/impl-Cgg_bv7j.mjs.map +1 -0
- package/dist/impl-CoLIqiH-2.mjs +2 -0
- package/dist/impl-CoLIqiH-2.mjs.map +1 -0
- package/dist/impl-Cq_RqK0_2.mjs +2 -0
- package/dist/impl-Cq_RqK0_2.mjs.map +1 -0
- package/dist/{impl-CIJ6P1GD.mjs → impl-Cwj9LeEI.mjs} +3 -3
- package/dist/impl-Cwj9LeEI.mjs.map +1 -0
- package/dist/impl-CyJBbyuF.mjs +2 -0
- package/dist/impl-CyJBbyuF.mjs.map +1 -0
- package/dist/impl-D-cp0CYr.mjs +2 -0
- package/dist/impl-D-cp0CYr.mjs.map +1 -0
- package/dist/impl-D-ldjJzl2.mjs +2 -0
- package/dist/impl-D-ldjJzl2.mjs.map +1 -0
- package/dist/impl-D6nwGrO8.mjs +2 -0
- package/dist/impl-D6nwGrO8.mjs.map +1 -0
- package/dist/impl-DGRuk3AB.mjs +2 -0
- package/dist/impl-DGRuk3AB.mjs.map +1 -0
- package/dist/impl-DXWN22xV.mjs +2 -0
- package/dist/impl-DXWN22xV.mjs.map +1 -0
- package/dist/impl-DZnSlfwn2.mjs +2 -0
- package/dist/impl-DZnSlfwn2.mjs.map +1 -0
- package/dist/impl-DcC8_dCy.mjs +2 -0
- package/dist/impl-DcC8_dCy.mjs.map +1 -0
- package/dist/impl-Dfc_yQML2.mjs +2 -0
- package/dist/impl-Dfc_yQML2.mjs.map +1 -0
- package/dist/impl-DgyjJ8RY2.mjs +2 -0
- package/dist/impl-DgyjJ8RY2.mjs.map +1 -0
- package/dist/impl-DhIyASha.mjs +2 -0
- package/dist/impl-DhIyASha.mjs.map +1 -0
- package/dist/impl-Dny1LX9A.mjs +2 -0
- package/dist/impl-Dny1LX9A.mjs.map +1 -0
- package/dist/impl-G1brwI4o.mjs +2 -0
- package/dist/impl-G1brwI4o.mjs.map +1 -0
- package/dist/impl-KV3yZaHz2.mjs +2 -0
- package/dist/impl-KV3yZaHz2.mjs.map +1 -0
- package/dist/impl-Rt3C_fDF.mjs +2 -0
- package/dist/impl-Rt3C_fDF.mjs.map +1 -0
- package/dist/impl-VHp2K2bg.mjs +2 -0
- package/dist/impl-VHp2K2bg.mjs.map +1 -0
- package/dist/impl-Zr8uLP_n.mjs +2 -0
- package/dist/impl-Zr8uLP_n.mjs.map +1 -0
- package/dist/impl-dEQtD5uE.mjs +2 -0
- package/dist/impl-dEQtD5uE.mjs.map +1 -0
- package/dist/impl-dlRlTYAQ.mjs +2 -0
- package/dist/impl-dlRlTYAQ.mjs.map +1 -0
- package/dist/impl-f4UPMoS_2.mjs +2 -0
- package/dist/impl-f4UPMoS_2.mjs.map +1 -0
- package/dist/impl-ph0q6K3i.mjs +2 -0
- package/dist/impl-ph0q6K3i.mjs.map +1 -0
- package/dist/impl-r8tHyAHB.mjs +2 -0
- package/dist/impl-r8tHyAHB.mjs.map +1 -0
- package/dist/impl-y1I9Muyc2.mjs +2 -0
- package/dist/impl-y1I9Muyc2.mjs.map +1 -0
- package/dist/index.d.mts +44 -32
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +78 -4
- package/dist/index.mjs.map +1 -1
- package/dist/inquirer-BgNcicZ4.mjs +2 -0
- package/dist/inquirer-BgNcicZ4.mjs.map +1 -0
- package/dist/listFiles-qzyQMaYH.mjs +2 -0
- package/dist/listFiles-qzyQMaYH.mjs.map +1 -0
- package/dist/{logger-Bj782ZYD.mjs → logger-B-LXIf3U.mjs} +1 -1
- package/dist/{logger-Bj782ZYD.mjs.map → logger-B-LXIf3U.mjs.map} +1 -1
- package/dist/makeGraphQLRequest-G078PsEL.mjs +2 -0
- package/dist/makeGraphQLRequest-G078PsEL.mjs.map +1 -0
- package/dist/markRequestDataSiloIdsCompleted-DmAz-R0M.mjs +2 -0
- package/dist/markRequestDataSiloIdsCompleted-DmAz-R0M.mjs.map +1 -0
- package/dist/markSilentPrivacyRequests-s7_aBROE.mjs +2 -0
- package/dist/markSilentPrivacyRequests-s7_aBROE.mjs.map +1 -0
- package/dist/mergeTranscendInputs-C64BJsse.mjs +2 -0
- package/dist/mergeTranscendInputs-C64BJsse.mjs.map +1 -0
- package/dist/notifyPrivacyRequestsAdditionalTime-BvXIXZYu.mjs +2 -0
- package/dist/notifyPrivacyRequestsAdditionalTime-BvXIXZYu.mjs.map +1 -0
- package/dist/package-BjNQxHlz.mjs +2 -0
- package/dist/package-BjNQxHlz.mjs.map +1 -0
- package/dist/parquetToCsvOneFile-DZVKXrjn.mjs +6 -0
- package/dist/parquetToCsvOneFile-DZVKXrjn.mjs.map +1 -0
- package/dist/parseAttributesFromString-CZStzJc0.mjs +2 -0
- package/dist/parseAttributesFromString-CZStzJc0.mjs.map +1 -0
- package/dist/pullAllDatapoints-DiMWp8a7.mjs +45 -0
- package/dist/pullAllDatapoints-DiMWp8a7.mjs.map +1 -0
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-DgWgggQt.mjs +2 -0
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-DgWgggQt.mjs.map +1 -0
- package/dist/pullConsentManagerMetrics-pFRPXTHJ.mjs +2 -0
- package/dist/pullConsentManagerMetrics-pFRPXTHJ.mjs.map +1 -0
- package/dist/pullManualEnrichmentIdentifiersToCsv-DA_4rIzW.mjs +2 -0
- package/dist/pullManualEnrichmentIdentifiersToCsv-DA_4rIzW.mjs.map +1 -0
- package/dist/pullTranscendConfiguration-D2cYlu6V.mjs +80 -0
- package/dist/pullTranscendConfiguration-D2cYlu6V.mjs.map +1 -0
- package/dist/pullUnstructuredSubDataPointRecommendations-C4aVhH-W.mjs +38 -0
- package/dist/pullUnstructuredSubDataPointRecommendations-C4aVhH-W.mjs.map +1 -0
- package/dist/pushCronIdentifiersFromCsv-C34TB9tG.mjs +2 -0
- package/dist/pushCronIdentifiersFromCsv-C34TB9tG.mjs.map +1 -0
- package/dist/pushManualEnrichmentIdentifiersFromCsv-CGS9E3Ft.mjs +2 -0
- package/dist/pushManualEnrichmentIdentifiersFromCsv-CGS9E3Ft.mjs.map +1 -0
- package/dist/readCsv-CyOL7eCc.mjs +2 -0
- package/dist/readCsv-CyOL7eCc.mjs.map +1 -0
- package/dist/{readTranscendYaml-DhKG1ViI.mjs → readTranscendYaml-D-J1ilS0.mjs} +2 -2
- package/dist/readTranscendYaml-D-J1ilS0.mjs.map +1 -0
- package/dist/removeUnverifiedRequestIdentifiers-pGGOFbfE.mjs +35 -0
- package/dist/removeUnverifiedRequestIdentifiers-pGGOFbfE.mjs.map +1 -0
- package/dist/request-CAsR6CMY.mjs +117 -0
- package/dist/request-CAsR6CMY.mjs.map +1 -0
- package/dist/retryRequestDataSilos-DXwN5uPw.mjs +2 -0
- package/dist/retryRequestDataSilos-DXwN5uPw.mjs.map +1 -0
- package/dist/skipPreflightJobs-BNQhuPZ8.mjs +2 -0
- package/dist/skipPreflightJobs-BNQhuPZ8.mjs.map +1 -0
- package/dist/skipRequestDataSilos-C39ji4lO.mjs +2 -0
- package/dist/skipRequestDataSilos-C39ji4lO.mjs.map +1 -0
- package/dist/splitCsvToList-BRq_CIfd.mjs +2 -0
- package/dist/splitCsvToList-BRq_CIfd.mjs.map +1 -0
- package/dist/streamPrivacyRequestsToCsv-C8lquiyd.mjs +2 -0
- package/dist/streamPrivacyRequestsToCsv-C8lquiyd.mjs.map +1 -0
- package/dist/syncCodePackages-BHgjfXCI.mjs +232 -0
- package/dist/syncCodePackages-BHgjfXCI.mjs.map +1 -0
- package/dist/syncCookies-CiLtxDFf.mjs +2 -0
- package/dist/syncCookies-CiLtxDFf.mjs.map +1 -0
- package/dist/syncDataFlows-DmBUs3G_.mjs +2 -0
- package/dist/syncDataFlows-DmBUs3G_.mjs.map +1 -0
- package/dist/syncTemplates-BNu1_dmW.mjs +23 -0
- package/dist/syncTemplates-BNu1_dmW.mjs.map +1 -0
- package/dist/time-Bl_c3W8U.mjs +2 -0
- package/dist/time-Bl_c3W8U.mjs.map +1 -0
- package/dist/types-B4CVJCpj.mjs +2 -0
- package/dist/types-B4CVJCpj.mjs.map +1 -0
- package/dist/updateConsentManagerVersionToLatest-BBMN94Hs.mjs +2 -0
- package/dist/updateConsentManagerVersionToLatest-BBMN94Hs.mjs.map +1 -0
- package/dist/uploadConsents-BbR7_sSt.mjs +2 -0
- package/dist/uploadConsents-BbR7_sSt.mjs.map +1 -0
- package/dist/uploadCookiesFromCsv-BKZx_E_2.mjs +2 -0
- package/dist/uploadCookiesFromCsv-BKZx_E_2.mjs.map +1 -0
- package/dist/uploadDataFlowsFromCsv-CJFVLvCJ.mjs +2 -0
- package/dist/uploadDataFlowsFromCsv-CJFVLvCJ.mjs.map +1 -0
- package/dist/uploadPrivacyRequestsFromCsv-BmP1JluQ.mjs +17 -0
- package/dist/uploadPrivacyRequestsFromCsv-BmP1JluQ.mjs.map +1 -0
- package/dist/uploadSiloDiscoveryResults-XpDp2u35.mjs +20 -0
- package/dist/uploadSiloDiscoveryResults-XpDp2u35.mjs.map +1 -0
- package/dist/validateTranscendAuth-1W1IylqE.mjs +2 -0
- package/dist/validateTranscendAuth-1W1IylqE.mjs.map +1 -0
- package/dist/withPreferenceRetry-Cb5S310L.mjs +2 -0
- package/dist/withPreferenceRetry-Cb5S310L.mjs.map +1 -0
- package/dist/writeCsv-B51ulrVl.mjs +6 -0
- package/dist/writeCsv-B51ulrVl.mjs.map +1 -0
- package/package.json +34 -53
- package/dist/api-keys-C7JLTDUZ.mjs +0 -2
- package/dist/api-keys-C7JLTDUZ.mjs.map +0 -1
- package/dist/app-Dti3qTxV.mjs +0 -131
- package/dist/app-Dti3qTxV.mjs.map +0 -1
- package/dist/buildAIIntegrationType-Bk0EbFKV.mjs +0 -2
- package/dist/buildAIIntegrationType-Bk0EbFKV.mjs.map +0 -1
- package/dist/code-scanning-3tLsE1W5.mjs +0 -4
- package/dist/code-scanning-3tLsE1W5.mjs.map +0 -1
- package/dist/codecs-TR6p48v3.mjs +0 -2
- package/dist/codecs-TR6p48v3.mjs.map +0 -1
- package/dist/command-BlHM1nCd.mjs.map +0 -1
- package/dist/consent-manager-BoaaMjRQ.mjs +0 -12
- package/dist/consent-manager-BoaaMjRQ.mjs.map +0 -1
- package/dist/constants-DdeeX81W.mjs +0 -2
- package/dist/constants-DdeeX81W.mjs.map +0 -1
- package/dist/context-bkKpii_t.mjs.map +0 -1
- package/dist/cron-DOicA1l8.mjs +0 -2
- package/dist/cron-DOicA1l8.mjs.map +0 -1
- package/dist/data-inventory-OeEcogPl.mjs +0 -75
- package/dist/data-inventory-OeEcogPl.mjs.map +0 -1
- package/dist/dataFlowsToDataSilos-RAhfPV0l.mjs.map +0 -1
- package/dist/impl--Ov8Om49.mjs +0 -2
- package/dist/impl--Ov8Om49.mjs.map +0 -1
- package/dist/impl-4BP7gY61.mjs +0 -2
- package/dist/impl-4BP7gY61.mjs.map +0 -1
- package/dist/impl-B0d5M861.mjs +0 -2
- package/dist/impl-B0d5M861.mjs.map +0 -1
- package/dist/impl-B40z0Aoz2.mjs +0 -2
- package/dist/impl-B40z0Aoz2.mjs.map +0 -1
- package/dist/impl-B8CoAX4t.mjs +0 -2
- package/dist/impl-B8CoAX4t.mjs.map +0 -1
- package/dist/impl-BDKBhSiG2.mjs +0 -2
- package/dist/impl-BDKBhSiG2.mjs.map +0 -1
- package/dist/impl-BEzyqD_12.mjs +0 -2
- package/dist/impl-BEzyqD_12.mjs.map +0 -1
- package/dist/impl-BI4zCNs0.mjs +0 -2
- package/dist/impl-BI4zCNs0.mjs.map +0 -1
- package/dist/impl-BJ9Ge6Wf2.mjs +0 -2
- package/dist/impl-BJ9Ge6Wf2.mjs.map +0 -1
- package/dist/impl-BPz3SpXo2.mjs +0 -2
- package/dist/impl-BPz3SpXo2.mjs.map +0 -1
- package/dist/impl-BYBNi68b.mjs.map +0 -1
- package/dist/impl-Bh04BLeU2.mjs +0 -2
- package/dist/impl-Bh04BLeU2.mjs.map +0 -1
- package/dist/impl-BhMd6_J22.mjs +0 -2
- package/dist/impl-BhMd6_J22.mjs.map +0 -1
- package/dist/impl-BiWrlucD.mjs +0 -2
- package/dist/impl-BiWrlucD.mjs.map +0 -1
- package/dist/impl-BpMKYqSR.mjs +0 -2
- package/dist/impl-BpMKYqSR.mjs.map +0 -1
- package/dist/impl-BraVBCrF2.mjs +0 -4
- package/dist/impl-BraVBCrF2.mjs.map +0 -1
- package/dist/impl-BvTvjK72.mjs +0 -2
- package/dist/impl-BvTvjK72.mjs.map +0 -1
- package/dist/impl-BvZai1Pf2.mjs +0 -2
- package/dist/impl-BvZai1Pf2.mjs.map +0 -1
- package/dist/impl-C73Uh2Ze.mjs +0 -2
- package/dist/impl-C73Uh2Ze.mjs.map +0 -1
- package/dist/impl-CIJ6P1GD.mjs.map +0 -1
- package/dist/impl-CNiEzL3_2.mjs +0 -2
- package/dist/impl-CNiEzL3_2.mjs.map +0 -1
- package/dist/impl-CTPHR7O62.mjs +0 -2
- package/dist/impl-CTPHR7O62.mjs.map +0 -1
- package/dist/impl-CU29SrJb2.mjs +0 -2
- package/dist/impl-CU29SrJb2.mjs.map +0 -1
- package/dist/impl-CaTnsoDi.mjs +0 -2
- package/dist/impl-CaTnsoDi.mjs.map +0 -1
- package/dist/impl-CiQeM677.mjs +0 -2
- package/dist/impl-CiQeM677.mjs.map +0 -1
- package/dist/impl-CkY0wfCz.mjs +0 -2
- package/dist/impl-CkY0wfCz.mjs.map +0 -1
- package/dist/impl-CoZhgLjC.mjs +0 -12
- package/dist/impl-CoZhgLjC.mjs.map +0 -1
- package/dist/impl-CvxsioT4.mjs +0 -2
- package/dist/impl-CvxsioT4.mjs.map +0 -1
- package/dist/impl-D2HalFgB2.mjs +0 -2
- package/dist/impl-D2HalFgB2.mjs.map +0 -1
- package/dist/impl-DFNq8PBe.mjs +0 -2
- package/dist/impl-DFNq8PBe.mjs.map +0 -1
- package/dist/impl-DOgLpdLw.mjs +0 -2
- package/dist/impl-DOgLpdLw.mjs.map +0 -1
- package/dist/impl-DP757pBT.mjs +0 -2
- package/dist/impl-DP757pBT.mjs.map +0 -1
- package/dist/impl-DVDN007x.mjs +0 -2
- package/dist/impl-DVDN007x.mjs.map +0 -1
- package/dist/impl-DfKI4fmI.mjs +0 -2
- package/dist/impl-DfKI4fmI.mjs.map +0 -1
- package/dist/impl-DgsWGnhH.mjs +0 -2
- package/dist/impl-DgsWGnhH.mjs.map +0 -1
- package/dist/impl-DzSmriDw.mjs +0 -2
- package/dist/impl-DzSmriDw.mjs.map +0 -1
- package/dist/impl-EhTHDCC1.mjs +0 -2
- package/dist/impl-EhTHDCC1.mjs.map +0 -1
- package/dist/impl-J-dQqTZJ2.mjs +0 -2
- package/dist/impl-J-dQqTZJ2.mjs.map +0 -1
- package/dist/impl-SxwaNC4m2.mjs +0 -2
- package/dist/impl-SxwaNC4m2.mjs.map +0 -1
- package/dist/impl-fESuqAH1.mjs +0 -2
- package/dist/impl-fESuqAH1.mjs.map +0 -1
- package/dist/impl-gYrR3kIh.mjs +0 -4
- package/dist/impl-gYrR3kIh.mjs.map +0 -1
- package/dist/impl-iwjvzA7a.mjs +0 -2
- package/dist/impl-iwjvzA7a.mjs.map +0 -1
- package/dist/impl-nKY3m-Vx.mjs +0 -2
- package/dist/impl-nKY3m-Vx.mjs.map +0 -1
- package/dist/impl-qiK6VF4F2.mjs +0 -2
- package/dist/impl-qiK6VF4F2.mjs.map +0 -1
- package/dist/manual-enrichment-CYoZNBjO.mjs +0 -2
- package/dist/manual-enrichment-CYoZNBjO.mjs.map +0 -1
- package/dist/mergeTranscendInputs-Coj_e2N3.mjs +0 -2
- package/dist/mergeTranscendInputs-Coj_e2N3.mjs.map +0 -1
- package/dist/pooling-BkZAO1Zs.mjs.map +0 -1
- package/dist/preference-management-BHj26bmE.mjs +0 -7
- package/dist/preference-management-BHj26bmE.mjs.map +0 -1
- package/dist/readTranscendYaml-DhKG1ViI.mjs.map +0 -1
- package/dist/syncConfigurationToTranscend-wWSbGVrI.mjs +0 -3010
- package/dist/syncConfigurationToTranscend-wWSbGVrI.mjs.map +0 -1
- package/dist/uploadConsents-nsjKy1I4.mjs +0 -2
- package/dist/uploadConsents-nsjKy1I4.mjs.map +0 -1
package/dist/index.mjs
CHANGED
|
@@ -1,5 +1,79 @@
|
|
|
1
|
-
import{a as e,i as t,n,o as r,r as i,t as a}from"./enums-CyFTrzXY.mjs";import{a as o,c as s,d as c,f as l,h as ee,i as te,l as ne,m as re,n as ie,o as ae,p as oe,r as se,s as ce,t as le,u as ue}from"./constants-DdeeX81W.mjs";import"./logger-Bj782ZYD.mjs";import{n as de,t as fe}from"./buildAIIntegrationType-Bk0EbFKV.mjs";import{$ as pe,A as me,B as he,C as ge,D as _e,E as ve,F as u,G as d,H as f,I as p,J as m,K as h,L as g,M as _,N as v,O as y,P as b,Q as x,R as S,S as C,T as w,U as T,V as E,W as D,X as O,Y as k,Z as A,_ as j,_t as M,a as N,at as P,b as F,c as ye,ct as be,d as xe,dt as Se,et as Ce,f as we,ft as Te,g as Ee,gt as De,h as Oe,ht as ke,i as Ae,it as je,j as Me,k as Ne,l as Pe,lt as Fe,m as Ie,mt as Le,n as Re,nt as ze,o as Be,ot as Ve,p as He,pt as Ue,q as We,r as Ge,rt as Ke,s as qe,st as Je,t as Ye,tt as Xe,u as Ze,ut as Qe,v as $e,vt as et,w as tt,x as nt,y as rt,yt as it,z as at}from"./codecs-TR6p48v3.mjs";import{a as ot,i as st,n as ct,r as lt,t as ut}from"./readTranscendYaml-DhKG1ViI.mjs";import{$ as dt,$a as ft,$i as pt,$n as mt,$o as ht,$r as gt,$t as _t,A as vt,Aa as yt,Ai as bt,An as xt,Ao as St,Ar as Ct,At as wt,B as Tt,Ba as Et,Bi as Dt,Bn as Ot,Bo as kt,Br as At,Bt as jt,C as Mt,Ca as Nt,Ci as Pt,Cn as Ft,Co as It,Cr as Lt,Cs as Rt,Ct as zt,D as Bt,Da as Vt,Di as Ht,Dn as Ut,Do as Wt,Dr as Gt,Ds as Kt,Dt as qt,E as Jt,Ea as Yt,Ei as Xt,En as Zt,Eo as Qt,Er as $t,Es as en,Et as tn,F as nn,Fa as rn,Fi as an,Fn as on,Fo as sn,Fr as cn,Ft as ln,G as un,Ga as dn,Gi as fn,Gn as pn,Go as mn,Gr as hn,Gt as gn,H as _n,Ha as vn,Hi as yn,Hn as bn,Ho as xn,Hr as Sn,Ht as Cn,I as wn,Ia as Tn,Ii as En,In as Dn,Io as On,Ir as kn,It as An,J as jn,Ja as Mn,Ji as Nn,Jn as Pn,Jo as Fn,Jr as In,Jt as Ln,K as Rn,Ka as zn,Ki as Bn,Kn as Vn,Ko as Hn,Kr as Un,Kt as Wn,L as Gn,La as Kn,Li as qn,Ln as Jn,Lo as Yn,Lr as Xn,Lt as Zn,M as Qn,Ma as $n,Mi as er,Mn as tr,Mo as nr,Mr as rr,Mt as ir,N as ar,Na as or,Ni as sr,Nn as cr,No as lr,Nr as ur,Nt as dr,O as fr,Oa as pr,Oi as mr,On as hr,Oo as gr,Or as _r,Os as vr,Ot as yr,P as br,Pa as xr,Pi as Sr,Pn as Cr,Po as wr,Pr as Tr,Pt as Er,Q as Dr,Qa as Or,Qi as kr,Qn as I,Qo as Ar,Qr as jr,Qt as Mr,R as Nr,Ra as Pr,Ri as Fr,Rn as Ir,Ro as Lr,Rr,Rt as zr,S as Br,Sa as Vr,Si as Hr,Sn as Ur,So as Wr,Sr as Gr,Ss as Kr,St as qr,T as Jr,Ta as Yr,Ti as Xr,Tn as Zr,To as Qr,Tr as $r,Ts as ei,Tt as ti,U as ni,Ua as ri,Ui as ii,Un as ai,Uo as oi,Ur as si,Ut as ci,V as li,Va as ui,Vi as di,Vn as fi,Vo as pi,Vr as mi,Vt as hi,W as gi,Wa as _i,Wi as vi,Wn as yi,Wo as bi,Wr as xi,Wt as Si,X as Ci,Xa as wi,Xi as L,Xn as R,Xo as Ti,Xr as Ei,Xt as Di,Y as Oi,Ya as ki,Yi as Ai,Yn as ji,Yo as Mi,Yr as z,Yt as Ni,Z as Pi,Za as Fi,Zi as Ii,Zn as Li,Zo as Ri,Zr as B,Zt as zi,_ as Bi,_a as Vi,_i as Hi,_n as V,_o as Ui,_r as Wi,_s as Gi,_t as Ki,a as qi,aa as Ji,ai as H,an as Yi,ao as Xi,ar as Zi,as as Qi,at as $i,b as ea,ba as ta,bi as na,bn as ra,bo as U,br as ia,bs as aa,bt as oa,c as sa,ca,ci as la,cn as ua,co as da,cr as fa,cs as pa,ct as ma,d as ha,da as ga,di as _a,dn as va,do as ya,dr as ba,ds as xa,dt as Sa,ea as Ca,ei as wa,en as Ta,eo as Ea,er as Da,es as Oa,et as ka,f as Aa,fa as ja,fi as Ma,fn as Na,fo as Pa,fr as Fa,fs as Ia,ft as La,g as Ra,ga as za,gi as Ba,gn as Va,go as Ha,gr as Ua,gs as Wa,gt as Ga,h as Ka,ha as qa,hi as Ja,hn as Ya,ho as Xa,hr as Za,hs as Qa,ht as $a,i as W,ia as eo,ii as to,in as no,io as ro,ir as io,is as ao,it as oo,j as so,ja as co,ji as lo,jn as uo,jo as fo,jr as po,js as mo,jt as ho,k as go,ka as _o,ki as vo,kn as yo,ko as bo,kr as xo,ks as So,kt as Co,l as wo,la as To,li as Eo,ln as Do,lo as Oo,lr as ko,ls as Ao,lt as jo,m as Mo,ma as No,mi as Po,mn as Fo,mo as Io,mr as Lo,ms as Ro,mt as zo,n as Bo,na as Vo,ni as Ho,nn as Uo,no as Wo,nr as Go,ns as Ko,nt as qo,o as Jo,oa as Yo,oi as Xo,on as Zo,oo as Qo,or as $o,os as es,ot as ts,p as ns,pa as rs,pi as is,pn as as,po as os,pr as ss,ps as cs,pt as ls,q as us,qa as ds,qi as fs,qn as ps,qo as ms,qr as hs,qt as gs,r as _s,ra as vs,ri as ys,rn as bs,ro as xs,rr as Ss,rs as Cs,rt as ws,s as Ts,sa as Es,si as Ds,sn as Os,so as ks,sr as As,ss as js,st as Ms,t as Ns,ta as Ps,ti as Fs,tn as Is,to as Ls,tr as Rs,ts as zs,tt as Bs,u as Vs,ua as Hs,ui as Us,un as Ws,uo as Gs,ur as Ks,us as qs,ut as Js,v as Ys,va as Xs,vi as Zs,vn as Qs,vo as $s,vr as ec,vs as tc,vt as nc,w as rc,wa as ic,wi as ac,wn as oc,wo as sc,wr as cc,ws as lc,wt as uc,x as dc,xa as fc,xi as pc,xn as mc,xo as hc,xr as gc,xs as _c,xt as vc,y as yc,ya as bc,yi as xc,yn as Sc,yo as Cc,yr as wc,ys as Tc,yt as Ec,z as Dc,za as Oc,zi as kc,zn as Ac,zo as jc,zr as Mc,zt as Nc}from"./syncConfigurationToTranscend-wWSbGVrI.mjs";import{t as Pc}from"./mergeTranscendInputs-Coj_e2N3.mjs";import{a as Fc,c as Ic,i as Lc,n as Rc,o as zc,r as Bc,s as Vc,t as Hc}from"./consent-manager-BoaaMjRQ.mjs";import{i as Uc,n as Wc,r as Gc,t as Kc}from"./uploadConsents-nsjKy1I4.mjs";import{a as qc,i as Jc,n as Yc,o as Xc,r as Zc,s as Qc,t as $c}from"./cron-DOicA1l8.mjs";import{i as el,n as tl,r as nl,t as rl}from"./api-keys-C7JLTDUZ.mjs";import{n as il,t as al}from"./data-inventory-OeEcogPl.mjs";import{i as ol,n as sl,r as cl,t as ll}from"./manual-enrichment-CYoZNBjO.mjs";import{ChatCompletionRole as G,PromptRunProductArea as K,PromptStatus as q,QueueStatus as J}from"@transcend-io/privacy-types";import{chunk as ul,difference as dl,groupBy as fl,keyBy as Y,uniq as pl}from"lodash-es";import{apply as ml,decodeCodec as X,getValues as hl}from"@transcend-io/type-utils";import{createHandlebarsWithHelpers as Z}from"@transcend-io/handlebars-utils";import gl from"fast-glob";import{execSync as Q}from"child_process";async function _l(e){let t=[],n=0,r=!1;do{let{largeLanguageModels:{nodes:i}}=await W(e,L,{first:20,offset:n});t.push(...i),n+=20,r=i.length===20}while(r);return t.sort((e,t)=>e.name.localeCompare(t.name))}function $(e){return RegExp(`<${e}>([\\s\\S]+?)<\\/${e}>`)}function vl(e){return e}const yl=e=>{try{return JSON.parse(e)}catch{return e}};var bl=class{prompts;handlebarsOptions;promptContentMap;largeLanguageModels=[];agentsByName={};agentsByAgentId={};graphQLClient;defaultVariables;variables;handlebars;transcendApiKey;transcendUrl;requireApproval;cacheDuration;lastUpdatedAt;constructor({prompts:e,handlebarsOptions:t={},transcendUrl:n=o,transcendApiKey:r,requireApproval:i=!0,cacheDuration:a,defaultVariables:s={}}){this.prompts=e,this.transcendUrl=n,this.transcendApiKey=r,this.variables=s,this.defaultVariables=s,this.graphQLClient=H(n,typeof r==`object`?r.release():r),this.requireApproval=i,this.cacheDuration=a,this.handlebarsOptions=t,this.handlebars=Z(t)}async fetchPromptsAndMetadata(){let e=hl(this.prompts),t=e.map(({id:e})=>e).filter(e=>!!e),n=e.map(({title:e})=>e).filter(e=>!!e),r=pl(e.map(({agentNames:e})=>e||[]).flat()),[i,a,o]=await Promise.all([I(this.graphQLClient,{promptIds:t,promptTitles:n}),_l(this.graphQLClient),z(this.graphQLClient,{names:r})]);this.agentsByName=Y(o,`name`),this.agentsByAgentId=Y(o,`agentId`),this.largeLanguageModels=a.filter(e=>e.isTranscendHosted===!1);let s=Y(i.prompts,`title`),c=Y(i.prompts,`id`);return this.variables={...i.calculatedVariables.reduce((e,t)=>Object.assign(e,{[t.name]:t.data?JSON.parse(t.data):t.data}),{}),...this.defaultVariables},this.handlebars=Z({...this.handlebarsOptions,templates:[...this.handlebarsOptions.templates||[],...i.promptPartials.map(e=>({name:e.slug,content:e.content}))]}),this.promptContentMap=ml(this.prompts,({id:e,title:t})=>{let n=e?c[e]:t?s[t]:void 0;if(!n)throw Error(`Failed to find prompt with title: "${t}" and id: "${e}"`);return n}),this.lastUpdatedAt=new Date,i}async getAgentByName(e){let t=this.agentsByName[e];if(t)return t;let[n]=await z(this.graphQLClient,{names:[e]});if(n)return this.agentsByName[n.name]=n,this.agentsByAgentId[n.agentId]=n,n}async getPromptThreadBySlackTs(e){let[t]=await R(this.graphQLClient,{slackMessageTs:[e]});return t}async getAgentsByName(e){if(e.length<1)throw Error(`Expected at least one name to be provided`);let{hasCache:t=[],missingCache:n=[]}=fl(e,e=>this.agentsByName[e]?`hasCache`:`missingCache`),r=t.map(e=>this.agentsByName[e]);if(n.length===0)return r;let i=ul(n,50),a=[];return await mo(i,async e=>{let t=await z(this.graphQLClient,{names:e});t.forEach(e=>{this.agentsByName[e.name]=e,this.agentsByAgentId[e.agentId]=e}),a.push(...t)}),[...r,...a]}getAgentFiles(e){return B(this.graphQLClient,e)}getLargeLanguageModel(e){let t=this.largeLanguageModels.find(t=>typeof e==`string`?t.id===e:t.name===e.name&&t.client===e.client);if(!t)throw Error(`Failed to find model matching: ${typeof e==`string`?e:JSON.stringify(e)}`);return t}async getPromptDefinition(e){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let{promptContentMap:t}=this;if(!t)throw Error(`Expected this.promptContentMap to be defined`);let n=t[e];if(!n)throw Error(`Expected this.promptContentMap[${e}] to be defined`);return n}async compilePrompt(e,t){let n=await this.getPromptDefinition(e),r=this.prompts[e];if(!r)throw Error(`Expected this.prompts[${e}] to be defined`);if(this.requireApproval&&n.status!==q.Approved)throw Error(`Assessment "${n.title}" cannot be used because its in status: "${n.status}"`);if(n.status===q.Rejected)throw Error(`Assessment "${n.title}" cannot be used because it's in status: "${n.status}"`);return X(r.paramCodec,t),this.handlebars.compile(n.content)({currentDate:new Date().toISOString(),...this.variables,...t})}parseAiResponse(e,t){let n=this.prompts[e];if(!n)throw Error(`Expected this.prompts[${e}] to be defined`);let r=n.extractFromTag&&($(n.extractFromTag).exec(t)||[])[1]||t;return X(n.outputCodec,yl(r),!1)}async reportAndParsePromptRun(e,{largeLanguageModel:t,...n}){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let r=n.name||`@transcend-io/cli-prompt-run-${new Date().toISOString()}`;if(!this.promptContentMap)throw Error(`Expected this.promptContentMap to be defined`);let i=this.promptContentMap[e];if(!i)throw Error(`Expected this.prompts[${e}] to be defined`);if(n.promptRunMessages.length===0)throw Error(`promptRunMessages is expected to have length > 0`);if(n.promptRunMessages[0].role!==G.System)throw Error(`promptRunMessages[0].role is expected to be = ${G.System}`);if(n.promptRunMessages[n.promptRunMessages.length-1].role!==G.Assistant)throw Error(`promptRunMessages[${n.promptRunMessages.length-1}].role is expected to be = ${G.Assistant}`);let a=n.promptRunMessages[n.promptRunMessages.length-1].content,o;try{o=this.parseAiResponse(e,a)}catch(e){throw await V(this.graphQLClient,{productArea:K.PromptManager,...n,name:r,error:e.message,status:J.Error,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))}),e}let s=await V(this.graphQLClient,{productArea:K.PromptManager,...n,name:r,status:J.Resolved,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))});return{result:o,promptRunId:s,promptRunUrl:`https://app.transcend.io/prompts/runs/${s}`}}async reportPromptRunError(e,{largeLanguageModel:t,...n}){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let r=n.name||`@transcend-io/cli-prompt-run-${new Date().toISOString()}`;if(!this.promptContentMap)throw Error(`Expected this.promptContentMap to be defined`);let i=this.promptContentMap[e];if(!i)throw Error(`Expected this.prompts[${e}] to be defined`);if(n.promptRunMessages.length===0)throw Error(`promptRunMessages is expected to have length > 0`);if(n.promptRunMessages[0].role!==G.System)throw Error(`promptRunMessages[0].role is expected to be = ${G.System}`);let a=await V(this.graphQLClient,{productArea:K.PromptManager,...n,name:r,status:J.Error,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))});return{promptRunId:a,promptRunUrl:`https://app.transcend.io/prompts/runs/${a}`}}};function xl(e){return e.replace(/(https?:\/\/[^\s]+)/g,`<link-omitted>`)}function Sl(e){return Object.entries(e).reduce((e,[t,n])=>n!=null&&n!==``&&!(Array.isArray(n)&&n.length===0)&&!(typeof n==`object`&&Object.keys(n).length===0)?Object.assign(e,{[t]:n}):e,{})}function Cl({baseBranch:e,rootDirectory:t,githubRepo:n,excludedGlob:r=[],fileBlockList:i=[]}){Q(`git fetch origin ${e}`);let a=Q(`git ls-remote ${n} "refs/heads/${e}" | cut -f 1`,{encoding:`utf-8`}).split(`
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
`).filter(e=>e),i),c=r.length>0?gl.sync(s,{ignore:r}):s,l={};return c.forEach(e=>{l[e]=Q(`git show ${o}:${e}`,{encoding:`utf-8`})}),{changedFiles:s,fileDiffs:l,repoName:n.split(`/`).pop().split(`.`)[0],commit:o}}export{Es as ACTIONS,ki as ADD_MESSAGES_TO_PROMPT_RUN,Mi as ADD_SILO_DISCOVERY_RESULTS,le as ADMIN_DASH,ie as ADMIN_DASH_DATAPOINTS,se as ADMIN_DASH_INTEGRATIONS,fs as AGENTS,vi as AGENT_FILES,di as AGENT_FUNCTIONS,Ar as API_KEYS,St as APPROVE_PRIVACY_REQUEST,Wr as ASSESSMENTS,It as ASSESSMENT_SECTION_FIELDS,Cc as ASSESSMENT_TEMPLATES,Ii as ASSUME_ROLE,Pr as ATTRIBUTES,mn as ATTRIBUTE_KEYS_REQUESTS,Oc as ATTRIBUTE_VALUES,Ye as ActionInput,Re as ActionItemCollectionInput,Ge as ActionItemInput,Ae as AgentFileInput,N as AgentFunctionInput,Be as AgentInput,qe as ApiKeyInput,on as AssessmentAction,ye as AssessmentAnswerOptionInput,Pe as AssessmentDisplayLogicInput,Ze as AssessmentInput,Dn as AssessmentNestedRule,xe as AssessmentNestedRuleInput,we as AssessmentResourceInput,He as AssessmentRetentionScheduleInput,cr as AssessmentRiskLogic,Jn as AssessmentRule,Ie as AssessmentRuleInput,Ir as AssessmentRuleWithOperands,Ac as AssessmentRuleWithoutOperands,Oe as AssessmentSectionInput,Ee as AssessmentSectionQuestionInput,j as AssessmentTemplateInput,$i as AttestedExtraIdentifiers,$e as AttributeInput,rt as AttributePreview,F as AttributeValueInput,Hi as BLANK,Zs as BULK_APPLY,Fi as BULK_REQUEST_FILES,To as BUSINESS_ENTITIES,nt as BusinessEntityInput,fo as CANCEL_PRIVACY_REQUEST,xc as CAN_APPLY_IN_BULK,Ia as CATALOGS,Xi as CHANGE_REQUEST_DATA_SILO_STATUS,jc as CODE_PACKAGES,ja as CONSENT_MANAGER_ANALYTICS_DATA,rs as CONSENT_PARTITIONS,No as COOKIES,eo as CREATE_ACTION_ITEMS,zn as CREATE_ACTION_ITEM_COLLECTION,Nn as CREATE_AGENT,fn as CREATE_AGENT_FILE,yn as CREATE_AGENT_FUNCTION,ht as CREATE_API_KEY,Et as CREATE_ATTRIBUTE,ui as CREATE_ATTRIBUTE_VALUES,Hs as CREATE_BUSINESS_ENTITY,kt as CREATE_CODE_PACKAGE,qa as CREATE_CONSENT_EXPERIENCE,za as CREATE_CONSENT_MANAGER,Vi as CREATE_CONSENT_PARTITION,Xs as CREATE_DATA_FLOWS,Gi as CREATE_DATA_SILOS,ao as CREATE_DATA_SUBJECT,an as CREATE_DATA_SUB_CATEGORY,cs as CREATE_ENRICHER,pa as CREATE_IDENTIFIER,Ri as CREATE_PREFERENCE_ACCESS_TOKENS,vo as CREATE_PROCESSING_ACTIVITY,er as CREATE_PROCESSING_PURPOSE_SUB_CATEGORY,Oo as CREATE_PROMPT,Gs as CREATE_PROMPT_GROUP,ya as CREATE_PROMPT_PARTIAL,zs as CREATE_REPOSITORY,xn as CREATE_SOFTWARE_DEVELOPMENT_KIT,Wo as CREATE_TEAM,ms as CREATE_TEMPLATE,Fr as CREATE_VENDOR,na as CachedFileState,pc as CachedRequestState,C as CodePackageInput,ge as CodePackageSdk,Hr as ColumnName,tt as ConsentManageExperienceInput,w as ConsentManagerInput,cn as ConsentManagerMetricBin,ve as ConsentManagerServiceMetadata,_e as ConsentPreferenceTopic,y as ConsentPreferenceTopicOptionValue,Ne as ConsentPurpose,me as CookieCsvInput,Me as CookieInput,Xc as CronIdentifier,Jc as CronIdentifierPush,Rt as DATAPOINT_EXPORT,bc as DATA_FLOWS,lc as DATA_POINTS,ei as DATA_POINT_COUNT,tc as DATA_SILOS,Tc as DATA_SILOS_ENRICHED,aa as DATA_SILO_EXPORT,Qi as DATA_SUBJECTS,En as DATA_SUB_CATEGORIES,Aa as DAY_MS,te as DEBUG,o as DEFAULT_TRANSCEND_API,ae as DEFAULT_TRANSCEND_CONSENT_API,Qs as DEFAULT_TRANSCEND_PULL_RESOURCES,Oa as DELETE_API_KEY,vn as DELETE_ATTRIBUTE_VALUE,Ca as DEPLOYED_PRIVACY_CENTER_URL,ta as DEPLOY_CONSENT_MANAGER,kr as DETERMINE_LOGIN_METHOD,_ as DataCategoryGuessInput,v as DataCategoryInput,b as DataCategoryPreviewInput,u as DataCategoryRecommendationInput,p as DataFlowCsvInput,g as DataFlowInput,S as DataSiloInput,at as DataSubjectInput,he as DatapointInput,Ti as ENABLED_PLUGINS,Ro as ENRICHERS,Kr as ENTRY_COUNT,fc as EXPERIENCES,sl as EnrichPrivacyRequest,E as EnricherInput,Vr as FETCH_CONSENT_MANAGER,Nt as FETCH_CONSENT_MANAGER_ID,ic as FETCH_CONSENT_MANAGER_THEME,Ps as FETCH_PRIVACY_CENTER_ID,ns as FIVE_MIN_MS,f as FieldInput,Ji as GLOBAL_ACTION_ITEMS,ds as GLOBAL_ACTION_ITEM_COLLECTIONS,Mo as HOUR_MS,Ao as IDENTIFIERS,Pt as IDENTIFIER_BLOCK_LIST,sc as IMPORT_ONE_TRUST_ASSESSMENT_FORMS,Qa as INITIALIZER,Rc as IP_ADDRESS_REGEX,ac as IS_REQUIRED,T as IdentifierInput,D as ImportOnetrustAssessmentsInput,Bs as IntlMessage,d as IntlMessageInput,L as LARGE_LANGUAGE_MODELS,pt as LOGIN,gr as MESSAGES,qs as NEW_IDENTIFIER_TYPES,Xr as NONE,nr as NOTIFY_ADDITIONAL_TIME,Hn as ORGANIZATION,a as OneTrustFileFormat,n as OneTrustPullResource,i as OneTrustPullSource,h as OpenAIEnabledRoute,We as OpenAIEnabledRoutes,m as OpenAIIntegration,t as OpenAIRouteName,On as POLICIES,U as PREFERENCE_TOPICS,Vo as PRIVACY_CENTER,bt as PROCESSING_ACTIVITIES,sr as PROCESSING_PURPOSE_SUB_CATEGORIES,Pa as PROMPTS,os as PROMPTS_WITH_VARIABLES,Io as PROMPT_GROUPS,Xa as PROMPT_PARTIALS,Lr as PROMPT_THREADS,hc as PURPOSES,_a as ParsedAttributeInput,k as PartitionInput,O as PathfinderPolicy,e as PathfinderPolicyName,A as PathfinderPolicyNameC,x as PathfinderPromptRunMetadata,pe as PolicyInput,Ce as PrivacyCenterInput,Fa as PrivacyRequest,ts as PrivacyRequestInput,Pi as PrivacyRequestResponse,Xe as ProcessingActivityInput,ze as ProcessingPurposeInput,Ke as ProcessingPurposePreviewInput,je as PromptAVendorEmailSettings,P as PromptGroupInput,Ve as PromptInput,Je as PromptPartialInput,Kc as PurposeMap,Qo as REDUCED_REQUESTS_FOR_DATA_SILO_COUNT,Ea as REMOVE_REQUEST_IDENTIFIERS,wi as REPORT_PROMPT_RUN,Ko as REPOSITORIES,lr as REQUESTS,wr as REQUESTS_COUNT,ks as REQUEST_DATA_SILOS,Qr as REQUEST_ENRICHERS,Or as REQUEST_FILES,Ls as REQUEST_IDENTIFIERS,ce as RETRYABLE_BATCH_STATUSES,da as RETRY_REQUEST_DATA_SILO,Qt as RETRY_REQUEST_ENRICHER,Mt as RateCounter,be as RegionInput,Fe as RepositoryInput,qo as RequestFileMetadata,ws as RequestFileMetadataResponse,Ua as RequestIdentifiersResponse,ss as RequestPurposeTrigger,Qe as RiskAssignmentInput,Se as RiskLogicInput,s as SCOPES_BY_TITLE,ne as SCOPE_TITLES,ri as SET_RESOURCE_ATTRIBUTES,Ht as SILO_DISCOVERY_RESULTS,Wt as SKIP_REQUEST_ENRICHER,oi as SOFTWARE_DEVELOPMENT_KITS,mr as SOMBRA_VERSION,en as SUB_DATA_POINTS,Kt as SUB_DATA_POINTS_COUNT,vr as SUB_DATA_POINTS_WITH_GUESSES,Sn as SYNC_ATTRIBUTE_TYPES,Te as SiloDiscoveryResultInput,Ue as SoftwareDevelopmentKitInput,Le as StoredApiKey,Xt as SuccessfulRequest,xs as TEAMS,Fn as TEMPLATES,Yr as TOGGLE_CONSENT_PRECEDENCE,es as TOGGLE_DATA_SUBJECT,Yt as TOGGLE_TELEMETRY_PARTITION_STRATEGY,Vt as TOGGLE_UNKNOWN_COOKIE_POLICY,pr as TOGGLE_UNKNOWN_REQUEST_POLICY,ue as TR_PULL_RESOURCE_SCOPE_MAP,c as TR_PUSH_RESOURCE_SCOPE_MAP,l as TR_YML_RESOURCE_TO_FIELD_NAME,ke as TeamInput,De as TemplateInput,M as TranscendInput,bl as TranscendPromptManager,r as TranscendPullResource,ca as UPDATE_ACTION,Yo as UPDATE_ACTION_ITEMS,Mn as UPDATE_ACTION_ITEM_COLLECTION,Ai as UPDATE_AGENTS,Bn as UPDATE_AGENT_FILES,ii as UPDATE_AGENT_FUNCTIONS,_i as UPDATE_ATTRIBUTE,dn as UPDATE_ATTRIBUTE_VALUES,ga as UPDATE_BUSINESS_ENTITIES,pi as UPDATE_CODE_PACKAGES,_o as UPDATE_CONSENT_EXPERIENCE,yt as UPDATE_CONSENT_MANAGER_DOMAINS,co as UPDATE_CONSENT_MANAGER_PARTITION,$n as UPDATE_CONSENT_MANAGER_THEME,or as UPDATE_CONSENT_MANAGER_TO_LATEST,xr as UPDATE_CONSENT_MANAGER_VERSION,rn as UPDATE_DATA_FLOWS,_c as UPDATE_DATA_SILOS,js as UPDATE_DATA_SUBJECT,qn as UPDATE_DATA_SUB_CATEGORIES,Wa as UPDATE_ENRICHER,xa as UPDATE_IDENTIFIER,bo as UPDATE_INTL_MESSAGES,Tn as UPDATE_LOAD_OPTIONS,Kn as UPDATE_OR_CREATE_COOKIES,So as UPDATE_OR_CREATE_DATA_POINT,Yn as UPDATE_POLICIES,vs as UPDATE_PRIVACY_CENTER,sn as UPDATE_PRIVACY_REQUEST,lo as UPDATE_PROCESSING_ACTIVITIES,Sr as UPDATE_PROCESSING_PURPOSE_SUB_CATEGORIES,Ha as UPDATE_PROMPTS,Ui as UPDATE_PROMPT_GROUPS,$s as UPDATE_PROMPT_PARTIALS,Cs as UPDATE_REPOSITORIES,bi as UPDATE_SOFTWARE_DEVELOPMENT_KITS,ro as UPDATE_TEAM,kc as UPDATE_VENDORS,ft as USERS,Wc as USP_STRING_REGEX,ut as VARIABLE_PARAMETERS_NAME,ct as VARIABLE_PARAMETERS_REGEXP,Dt as VENDORS,et as VendorInput,it as WebhookHeader,Ka as addDaysUtc,Ds as addMessagesToPromptRun,Ra as addMs,qi as appendCsvRowsOrdered,Jo as appendCsvSync,Ci as approvePrivacyRequests,ai as assumeRole,fe as buildAIIntegrationType,de as buildEnabledRouteType,H as buildTranscendGraphQLClient,Xo as buildTranscendGraphQLClientGeneric,Bc as buildXdiSyncEndpoint,_n as bulkRestartRequests,Tt as bulkRetryEnrichers,us as cancelPrivacyRequests,Bi as clampPageSize,dc as collectParquetFilesOrExit,Hc as consentManagersToBusinessEntities,Rs as convertToDataSubjectAllowlist,Go as convertToDataSubjectBlockList,va as createActionItemCollection,ua as createActionItems,_t as createAgent,Yi as createAgentFile,Uo as createAgentFunction,fi as createApiKey,Ni as createBusinessEntity,jt as createCodePackage,Uc as createConsentToken,dr as createDataCategory,wt as createDataFlows,Un as createPreferenceAccessTokens,Ec as createProcessingPurpose,Ga as createPrompt,$ as createRegexForTag,ci as createRepository,Wn as createSoftwareDevelopmentKit,to as createSombraGotInstance,ys as createTranscendConsentGotInstance,ls as createVendor,vl as defineTranscendPrompts,bn as deleteApiKey,Fs as deployConsentManager,re as description,Lc as domainToHost,dt as downloadPrivacyRequestFiles,cl as enrichPrivacyRequest,Ss as ensureAllDataSubjectsExist,un as extractClientError,fr as extractErrorMessage,wa as fetchActiveSiloDiscoPlugin,gt as fetchAllActionItems,jr as fetchAllActions,B as fetchAllAgentFiles,Ei as fetchAllAgentFunctions,z as fetchAllAgents,As as fetchAllApiKeys,hs as fetchAllAssessmentTemplates,In as fetchAllAssessments,si as fetchAllAttributeValues,xi as fetchAllAttributes,mi as fetchAllBusinessEntities,Zi as fetchAllCatalogs,Tr as fetchAllCookies,ur as fetchAllDataCategories,rr as fetchAllDataFlows,Ut as fetchAllDataPoints,hr as fetchAllDataSilos,io as fetchAllDataSubjects,Zr as fetchAllEnrichers,Bo as fetchAllIdentifiers,po as fetchAllMessages,_r as fetchAllPolicies,$t as fetchAllPreferenceTopics,$r as fetchAllPrivacyCenters,cc as fetchAllProcessingActivities,Lt as fetchAllProcessingPurposes,Da as fetchAllPromptGroups,mt as fetchAllPromptPartials,R as fetchAllPromptThreads,Li as fetchAllPrompts,Gr as fetchAllPurposes,gc as fetchAllPurposesAndPreferences,hn as fetchAllRequestAttributeKeys,ia as fetchAllRequestEnrichers,wc as fetchAllRequestIdentifierMetadata,Wi as fetchAllRequestIdentifiers,Lo as fetchAllRequests,ra as fetchAllSiloDiscoveryResults,yo as fetchAllSubDataPoints,ba as fetchAllTeams,Ft as fetchAllTemplates,Ks as fetchAllUsers,ko as fetchAllVendors,$o as fetchAndIndexCatalogs,fa as fetchApiKeys,kn as fetchConsentManager,Xn as fetchConsentManagerAnalyticsData,Rr as fetchConsentManagerExperiences,Mc as fetchConsentManagerId,At as fetchConsentManagerTheme,xt as fetchEnrichedDataSilos,_s as fetchIdentifiersAndCreateMissing,mc as fetchPartitions,xo as fetchPrivacyCenterId,Ct as fetchPrivacyCenterUrl,I as fetchPromptsWithVariables,ps as fetchRequestDataSilo,Vn as fetchRequestDataSiloActiveCount,Pn as fetchRequestDataSilos,ji as fetchRequestDataSilosCount,pn as fetchRequestFilesForRequest,Za as fetchRequestsTotalCount,Sl as filterNullishValuesFromObject,la as filterRows,Gt as formatAttributeValues,Nr as formatRequestForCsv,Ja as fuzzyMatchColumns,Ba as fuzzySearch,el as generateCrossAccountApiKeys,go as getErrorStatus,oo as getFileMetadataForPrivacyRequests,Cl as getGitFilesThatChanged,Eo as getUniqueValuesForColumn,Ts as initCsvFile,so as inquirerAutoComplete,Qn as inquirerConfirmBoolean,ar as inquirerConfirmText,rc as limitRecords,rl as listDirectories,tl as listFiles,yi as loginUser,W as makeGraphQLRequest,Rn as mapColumnsToAttributes,jn as mapColumnsToIdentifiers,Js as mapCsvColumnsToApi,Ms as mapCsvRowsToRequestInputs,Po as mapEnumValues,jo as mapRequestEnumValues,qc as markCronIdentifierCompleted,Yc as markRequestDataSiloIdsCompleted,Sa as markSilentPrivacyRequests,Pc as mergeTranscendInputs,oe as name,ma as normalizeIdentifierValue,Oi as notifyPrivacyRequestsAdditionalTime,ea as parquetToCsvOneFile,Ot as parseAssessmentDisplayLogic,Cr as parseAssessmentRiskLogic,Ma as parseAttributesFromString,sa as parseFilePath,vt as parseVariablesFromString,il as pullAllDatapoints,$c as pullChunkedCustomSiloOutstandingIdentifiers,Fc as pullConsentManagerMetrics,Qc as pullCronPageOfIdentifiers,ol as pullManualEnrichmentIdentifiersToCsv,Gn as pullPrivacyRequests,Sc as pullTranscendConfiguration,al as pullUnstructuredSubDataPointRecommendations,Zc as pushCronIdentifiersFromCsv,ll as pushManualEnrichmentIdentifiersFromCsv,Us as readCsv,Br as readSafe,lt as readTranscendYaml,xl as removeLinks,br as removeUnverifiedRequestIdentifiers,st as replaceVariablesInYaml,V as reportPromptRun,ni as restartPrivacyRequest,Dc as retryRequestDataSilos,Va as retryRequestEnricher,Jr as retrySamePromise,Ya as setResourceAttributes,li as skipPreflightJobs,nn as skipRequestDataSilos,Bt as sleepPromise,is as splitCsvToList,Jt as splitInHalf,Ys as startOfHour,yc as startOfUtcDay,ka as streamPrivacyRequestFiles,wn as streamPrivacyRequestsToCsv,Dr as submitPrivacyRequest,Fo as syncAction,Na as syncActionItemCollections,Do as syncActionItems,Zo as syncAgentFiles,bs as syncAgentFunctions,Ta as syncAgents,Mr as syncAttribute,Di as syncBusinessEntities,hi as syncCodePackages,Ns as syncConfigurationToTranscend,zr as syncConsentManager,Nc as syncConsentManagerExperiences,An as syncCookies,Er as syncDataCategories,ho as syncDataFlows,uo as syncDataSiloDependencies,tr as syncDataSilos,Co as syncDataSubject,Zt as syncEnricher,yr as syncIdentifier,tn as syncIntlMessages,Ur as syncPartitions,uc as syncPolicies,zt as syncPrivacyCenter,qr as syncProcessingActivities,oa as syncProcessingPurposes,Ki as syncPrompts,Si as syncRepositories,gs as syncSoftwareDevelopmentKits,oc as syncTemplate,zo as syncVendors,Ws as updateActionItem,as as updateActionItemCollection,Os as updateAgentFiles,no as updateAgentFunctions,Is as updateAgents,zi as updateBusinessEntities,Cn as updateCodePackages,Ho as updateConsentManagerToLatest,Ic as updateConsentManagerVersionToLatest,ln as updateDataCategories,ir as updateDataFlows,qt as updateIntlMessages,Zn as updateOrCreateCookies,ti as updatePolicies,vc as updateProcessingPurposes,nc as updatePrompts,gn as updateRepositories,Ln as updateSoftwareDevelopmentKits,$a as updateVendors,Gc as uploadConsents,zc as uploadCookiesFromCsv,Vc as uploadDataFlowsFromCsv,gi as uploadPrivacyRequestsFromCsv,La as uploadSiloDiscoveryResults,ec as validateSombraVersion,nl as validateTranscendAuth,ee as version,wo as writeCsv,Vs as writeCsvSync,ha as writeLargeCsv,ot as writeTranscendYaml};
|
|
1
|
+
import{a as e,i as t,n,o as r,r as i,t as a}from"./enums-CyFTrzXY.mjs";import{n as o,t as s}from"./package-BjNQxHlz.mjs";import{a as c,c as l,d as u,f as d,i as f,l as p,n as m,o as h,p as g,r as _,s as v,t as y,u as b}from"./constants-CeMiHaHx.mjs";import{t as x}from"./logger-B-LXIf3U.mjs";import{$ as S,A as ee,B as te,C as ne,D as re,E as ie,F as ae,G as oe,H as se,I as ce,J as le,K as ue,L as de,M as fe,N as pe,O as me,P as he,Q as ge,R as _e,S as ve,T as ye,U as be,V as xe,W as Se,X as Ce,Y as we,Z as Te,_ as Ee,_t as De,a as Oe,at as ke,b as Ae,bt as je,c as Me,ct as Ne,d as Pe,dt as Fe,et as Ie,f as Le,ft as Re,g as ze,gt as Be,h as Ve,ht as He,i as Ue,it as We,j as Ge,k as Ke,l as qe,lt as Je,m as Ye,mt as Xe,n as Ze,nt as Qe,o as $e,ot as et,p as tt,pt as nt,q as rt,r as it,rt as at,s as ot,st,t as ct,tt as lt,u as ut,ut as dt,v as ft,vt as pt,w as mt,x as ht,xt as gt,y as _t,yt as vt,z as yt}from"./codecs-BE3Wmoh8.mjs";import{a as bt,i as xt,n as St,r as Ct,t as wt}from"./readTranscendYaml-D-J1ilS0.mjs";import{n as Tt,t as C}from"./bluebird-CUitXgsY.mjs";import{a as Et,c as Dt,d as Ot,f as kt,i as At,l as jt,n as Mt,o as Nt,r as Pt,s as Ft,t as It,u as Lt}from"./dataSilo-DrFetFXw.mjs";import{n as Rt,t as zt}from"./pullUnstructuredSubDataPointRecommendations-C4aVhH-W.mjs";import{a as Bt,c as Vt,i as Ht,n as Ut,o as Wt,r as Gt,s as Kt,t as qt}from"./dataSubject-y_aXI0pa.mjs";import{n as Jt,r as Yt,t as Xt}from"./fetchCatalogs-CBk871k6.mjs";import{a as Zt,i as Qt,n as $t,o as en,r as tn,t as nn}from"./fetchIdentifiers-DjqjUnaw.mjs";import{_ as rn,a as an,c as on,d as sn,f as cn,g as ln,h as un,i as dn,l as fn,m as pn,n as mn,o as hn,p as gn,r as _n,s as vn,t as yn,u as bn,v as xn}from"./syncCodePackages-BHgjfXCI.mjs";import{a as Sn,i as Cn,n as wn,r as Tn,t as En}from"./fetchApiKeys-DkBco7W0.mjs";import{n as Dn,t as On}from"./createPreferenceAccessTokens-6WLr6z-l.mjs";import{i as kn,n as An,r as jn,t as Mn}from"./uploadSiloDiscoveryResults-XpDp2u35.mjs";import{i as Nn,n as Pn,r as Fn,t as In}from"./syncTemplates-BNu1_dmW.mjs";import{n as Ln,t as w}from"./createSombraGotInstance-CahOgD6V.mjs";import{a as Rn,c as zn,d as Bn,f as Vn,i as Hn,l as Un,m as Wn,n as Gn,o as Kn,p as qn,r as Jn,s as Yn,t as Xn,u as Zn}from"./uploadPrivacyRequestsFromCsv-BmP1JluQ.mjs";import{$ as Qn,A as $n,At as er,B as tr,Bt as nr,C as rr,Ct as ir,D as ar,Dt as or,E as sr,Et as cr,F as T,Ft as lr,G as ur,H as dr,Ht as fr,I as pr,It as mr,J as hr,K as gr,L as _r,Lt as vr,M as yr,Mt as br,N as E,Nt as xr,O as Sr,Ot as Cr,P as wr,Pt as Tr,Q as Er,R as Dr,Rt as Or,S as kr,St as Ar,T as jr,Tt as Mr,U as Nr,Ut as Pr,V as Fr,Vt as Ir,W as Lr,X as Rr,Y as zr,Z as Br,_ as Vr,_t as Hr,a as Ur,at as Wr,b as Gr,bt as Kr,c as qr,ct as Jr,d as Yr,dt as Xr,et as Zr,ft as Qr,g as $r,gt as ei,h as ti,ht as ni,i as ri,it as ii,j as ai,jt as oi,k as si,kt as ci,l as li,lt as ui,m as D,mt as di,n as fi,nt as pi,o as mi,ot as hi,p as gi,pt as _i,q as vi,r as yi,rt as bi,s as xi,st as Si,t as Ci,tt as wi,u as Ti,ut as Ei,v as Di,vt as Oi,w as ki,wt as Ai,x as ji,xt as O,y as Mi,yt as Ni,z as Pi,zt as Fi}from"./fetchAllActions-C0l3wjQV.mjs";import{a as Ii,i as Li,n as Ri,o as zi,r as Bi,t as Vi}from"./request-CAsR6CMY.mjs";import{i as Hi,n as Ui,r as Wi,t as Gi}from"./fetchAllRequestEnrichers-q34mRuE5.mjs";import{n as Ki,r as qi,t as Ji}from"./assessment-BDywVaGR.mjs";import{n as Yi,t as Xi}from"./fetchAllPurposes-CykSkZRY.mjs";import{n as Zi,t as Qi}from"./fetchAllPreferenceTopics-Bn9PG-rO.mjs";import{_ as $i,a as ea,c as ta,d as na,f as ra,g as ia,h as aa,i as oa,l as sa,m as ca,n as la,o as ua,p as da,r as fa,s as pa,t as ma,u as ha,v as ga,y as _a}from"./pullTranscendConfiguration-D2cYlu6V.mjs";import{i as va,n as ya,r as ba,t as xa}from"./RequestDataSilo-_Iv44M9u.mjs";import{i as Sa,n as Ca,r as wa,t as Ta}from"./removeUnverifiedRequestIdentifiers-pGGOFbfE.mjs";import{n as Ea,r as Da,t as Oa}from"./fetchRequestFilesForRequest-DrHGOdih.mjs";import{A as ka,C as Aa,D as ja,E as Ma,M as Na,O as Pa,S as Fa,T as Ia,_ as La,a as Ra,b as za,c as Ba,d as Va,f as Ha,g as Ua,h as Wa,i as Ga,j as Ka,k as qa,l as Ja,m as Ya,n as Xa,o as Za,p as Qa,r as $a,s as eo,t as to,u as no,v as ro,w as io,x as ao,y as oo}from"./fetchConsentManagerId-DHDA5Py9.mjs";import{a as so,c as co,i as lo,n as uo,o as fo,r as po,s as mo,t as ho}from"./generateCrossAccountApiKeys-F11uqpc5.mjs";import{i as go,n as k,r as A,t as _o}from"./fetchAllRequestIdentifiers-YP-geTV4.mjs";import{a as vo,c as yo,i as bo,l as xo,n as So,o as Co,r as wo,s as To,t as Eo,u as Do}from"./constants-lIvXgkdp.mjs";import{i as Oo,n as ko,r as Ao,t as jo}from"./parseAttributesFromString-CZStzJc0.mjs";import{t as Mo}from"./splitCsvToList-BRq_CIfd.mjs";import{t as No}from"./readCsv-CyOL7eCc.mjs";import{i as Po,n as j,r as M,t as N}from"./makeGraphQLRequest-G078PsEL.mjs";import{a as Fo,i as Io,n as Lo,r as Ro,t as zo}from"./uploadConsents-BbR7_sSt.mjs";import{n as Bo,r as Vo,t as Ho}from"./updateConsentManagerVersionToLatest-BBMN94Hs.mjs";import{t as Uo}from"./fetchAllDataFlows-AQ9j_NRa.mjs";import{t as Wo}from"./fetchAllPurposesAndPreferences-Dog6N9L2.mjs";import{i as Go,n as Ko,r as P,t as qo}from"./fetchAllRequests-DEPTEUbi.mjs";import{n as Jo,r as Yo,t as Xo}from"./fetchRequestDataSilo-CF6XOTQ-.mjs";import{i as Zo,n as Qo,r as $o,t as es}from"./pullChunkedCustomSiloOutstandingIdentifiers-DgWgggQt.mjs";import{n as ts,t as ns}from"./bulkRetryEnrichers-BLkcFKXC.mjs";import{A as rs,B as is,C as as,D as os,E as ss,F as cs,G as ls,H as us,I as ds,L as fs,M as ps,N as ms,O as hs,P as gs,R as _s,S as vs,T as ys,U as bs,V as xs,W as Ss,_ as Cs,a as ws,b as Ts,c as Es,d as Ds,f as Os,g as ks,h as As,i as js,j as Ms,k as Ns,l as Ps,m as Fs,n as Is,o as Ls,p as Rs,r as zs,s as Bs,t as Vs,u as Hs,v as Us,w as Ws,x as Gs,y as Ks,z as qs}from"./mergeTranscendInputs-C64BJsse.mjs";import{n as Js,t as Ys}from"./syncCookies-CiLtxDFf.mjs";import{n as Xs,r as Zs,t as Qs}from"./syncDataFlows-DmBUs3G_.mjs";import{t as $s}from"./markSilentPrivacyRequests-s7_aBROE.mjs";import{a as ec,i as tc,n as nc,o as rc,r as ic,t as ac}from"./downloadPrivacyRequestFiles-B2yduagB.mjs";import{n as oc,r as sc,t as cc}from"./extractClientError-DPjv09EH.mjs";import{t as lc}from"./approvePrivacyRequests-1cguqGqq.mjs";import{t as uc}from"./notifyPrivacyRequestsAdditionalTime-BvXIXZYu.mjs";import{t as dc}from"./cancelPrivacyRequests-C8MZQvsq.mjs";import{n as fc,t as pc}from"./bulkRestartRequests-DEPSHov-.mjs";import{t as mc}from"./skipPreflightJobs-BNQhuPZ8.mjs";import{t as hc}from"./retryRequestDataSilos-DXwN5uPw.mjs";import{n as F,t as gc}from"./streamPrivacyRequestsToCsv-C8lquiyd.mjs";import{t as _c}from"./skipRequestDataSilos-C39ji4lO.mjs";import{n as vc,r as yc,t as bc}from"./inquirer-BgNcicZ4.mjs";import{t as I}from"./extractErrorMessage-CPnTsT1S.mjs";import{t as xc}from"./RateCounter-DFL_mnk2.mjs";import{n as Sc,t as Cc}from"./parquetToCsvOneFile-DZVKXrjn.mjs";import{a as wc,c as Tc,i as Ec,n as Dc,o as Oc,r as kc,s as Ac,t as jc}from"./time-Bl_c3W8U.mjs";import{a as Mc,i as Nc,n as Pc,o as Fc,r as Ic,s as Lc,t as Rc}from"./writeCsv-B51ulrVl.mjs";import{t as zc}from"./uploadDataFlowsFromCsv-CJFVLvCJ.mjs";import{t as Bc}from"./uploadCookiesFromCsv-BKZx_E_2.mjs";import{t as Vc}from"./pullConsentManagerMetrics-pFRPXTHJ.mjs";import{n as Hc,r as Uc,t as Wc}from"./buildXdiSyncEndpoint-BMaMHO7Z.mjs";import{t as Gc}from"./consentManagersToBusinessEntities-BDgOFga7.mjs";import{n as Kc,r as qc,t as Jc}from"./pushCronIdentifiersFromCsv-C34TB9tG.mjs";import{t as Yc}from"./markRequestDataSiloIdsCompleted-DmAz-R0M.mjs";import{t as Xc}from"./validateTranscendAuth-1W1IylqE.mjs";import{t as Zc}from"./listFiles-qzyQMaYH.mjs";import{t as Qc}from"./pullAllDatapoints-DiMWp8a7.mjs";import{t as $c}from"./pullManualEnrichmentIdentifiersToCsv-DA_4rIzW.mjs";import{n as el,r as tl,t as nl}from"./pushManualEnrichmentIdentifiersFromCsv-CGS9E3Ft.mjs";import{ChatCompletionRole as L,PromptRunProductArea as R,PromptStatus as z,QueueStatus as B}from"@transcend-io/privacy-types";import{chunk as rl,difference as il,groupBy as al,keyBy as V,uniq as ol}from"lodash-es";import{apply as sl,decodeCodec as H,getValues as cl}from"@transcend-io/type-utils";import{readFileSync as ll,readdirSync as ul,statSync as dl}from"node:fs";import{join as fl}from"node:path";import U from"colors";import{gql as W}from"graphql-request";import{createHandlebarsWithHelpers as G}from"@transcend-io/handlebars-utils";import{execSync as K}from"child_process";import pl from"fast-glob";const q=W`
|
|
2
|
+
query TranscendCliPromptThreads(
|
|
3
|
+
$first: Int!
|
|
4
|
+
$offset: Int!
|
|
5
|
+
$filterBy: PromptThreadFiltersInput!
|
|
6
|
+
) {
|
|
7
|
+
promptThreads(first: $first, offset: $offset, filterBy: $filterBy) {
|
|
8
|
+
nodes {
|
|
9
|
+
id
|
|
10
|
+
threadId
|
|
11
|
+
slackMessageTs
|
|
12
|
+
slackTeamId
|
|
13
|
+
slackChannelId
|
|
14
|
+
slackChannelName
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
`,J=W`
|
|
19
|
+
query TranscendCliUsers($first: Int!, $offset: Int!, $input: UserFiltersInput) {
|
|
20
|
+
users(
|
|
21
|
+
first: $first
|
|
22
|
+
offset: $offset
|
|
23
|
+
filterBy: $input
|
|
24
|
+
orderBy: [{ field: createdAt, direction: ASC }, { field: name, direction: ASC }]
|
|
25
|
+
) {
|
|
26
|
+
nodes {
|
|
27
|
+
id
|
|
28
|
+
name
|
|
29
|
+
email
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
`,Y=W`
|
|
34
|
+
mutation TranscendCliReportPromptRun($input: ReportPromptRunInput!) {
|
|
35
|
+
reportPromptRun(input: $input) {
|
|
36
|
+
clientMutationId
|
|
37
|
+
promptRun {
|
|
38
|
+
id
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
`,X=W`
|
|
43
|
+
mutation TranscendCliAddMessagesToPromptRun($input: AddMessagesToPromptRunInput!) {
|
|
44
|
+
addMessagesToPromptRun(input: $input) {
|
|
45
|
+
clientMutationId
|
|
46
|
+
promptRun {
|
|
47
|
+
id
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
`,Z=W`
|
|
52
|
+
query TranscendCliLargeLanguageModels(
|
|
53
|
+
$first: Int!
|
|
54
|
+
$offset: Int!
|
|
55
|
+
$filterBy: LargeLanguageModelFiltersInput
|
|
56
|
+
) {
|
|
57
|
+
largeLanguageModels(
|
|
58
|
+
first: $first
|
|
59
|
+
orderBy: [
|
|
60
|
+
{ field: name, direction: ASC }
|
|
61
|
+
{ field: client, direction: ASC }
|
|
62
|
+
{ field: isTranscendHosted, direction: ASC }
|
|
63
|
+
]
|
|
64
|
+
offset: $offset
|
|
65
|
+
filterBy: $filterBy
|
|
66
|
+
) {
|
|
67
|
+
nodes {
|
|
68
|
+
id
|
|
69
|
+
name
|
|
70
|
+
client
|
|
71
|
+
isTranscendHosted
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
`;async function ml(e,{promptRunId:t,promptRunMessages:n=[],...r}){let{addMessagesToPromptRun:{promptRun:i}}=await N(e,X,{input:{...r,...t,promptRunMessages:n.map(({content:e,...t})=>({...t,message:e}))}});return i.id}async function hl(e){let t=[],n=0,r=!1;do{let{users:{nodes:i}}=await N(e,J,{first:20,offset:n});t.push(...i),n+=20,r=i.length===20}while(r);return t.sort((e,t)=>e.email.localeCompare(t.email))}async function Q(e,t){let n=[],r=0,i=!1;do{let{promptThreads:{nodes:a}}=await N(e,q,{first:20,offset:r,filterBy:t});n.push(...a),r+=20,i=a.length===20}while(i);return n.sort((e,t)=>e.threadId.localeCompare(t.threadId))}async function $(e,t){let{reportPromptRun:{promptRun:n}}=await N(e,Y,{input:{...t,promptRunMessages:t.promptRunMessages.map(({content:e,...t})=>({...t,message:e}))}});return n.id}async function gl(e,t){await N(e,O,{input:t})}function _l(e,t,n){let r=e.getTime(),i=t.getTime(),a=(i-r)/n;return Array.from({length:n},(e,t)=>({createdAtAfter:new Date(r+a*t),createdAtBefore:new Date(t===n-1?i:r+a*(t+1))}))}async function vl({auth:e,sombraAuth:t,actions:n=[],statuses:r=[],identifierSearch:i,pageLimit:a=100,concurrency:o=1,transcendUrl:s=c,createdAtBefore:l,skipRequestIdentifiers:u=!1,createdAtAfter:d,updatedAtBefore:f,updatedAtAfter:p,isTest:m}){let h=M(s,e),g=await w(s,e,t),_=``;l&&(_+=` before ${l.toISOString()}`),d&&(_+=`${_?`, and`:``} after ${d.toISOString()}`),x.info(U.magenta(`${n.length>0?`Pulling requests of type "${n.join(`" , "`)}"`:`Pulling all requests`}${_}`));let v=o>1&&d&&l,y=v?_l(d,l,o):[{createdAtAfter:d,createdAtBefore:l}];v&&x.info(U.magenta(`Splitting date range into ${o} parallel chunks`));let b=(await C(y,e=>P(h,{actions:n,text:i,statuses:r,createdAtBefore:e.createdAtBefore,createdAtAfter:e.createdAtAfter,updatedAtBefore:f,updatedAtAfter:p,isTest:m}),{concurrency:v?o:1})).flat();u||await A(h);let S=u?b.map(e=>({...e,requestIdentifiers:[]})):await C(b,async e=>{let t=await k(h,g,{requestId:e.id,skipSombraCheck:!0});return{...e,requestIdentifiers:t}},{concurrency:a});return x.info(U.magenta(`Pulled ${S.length} requests`)),{requestsWithRequestIdentifiers:S,requestsFormattedForCsv:S.map(F)}}function yl(e){let t=e;return t?.response?.statusCode??t?.response?.status}function bl(e){let t=Math.floor(e.length/2);return[e.slice(0,t),e.slice(t)]}async function xl(e,t,n){let r=0;for(;;)try{return await e()}catch(e){r+=1;let i=yl(e),a=I(e);if(!(r<=t.maxAttempts&&t.shouldRetry(i,a)))throw e;n(`Retrying after status=${i} attempt=${r}/${t.maxAttempts} — ${a}`),await j(t.delayMs)}}function Sl(e,t){return Object.entries(e).reduce((e,[n,r],i)=>(e[n]=i<t?r:!0,e),{})}function Cl(e){try{return e?ll(e,`utf8`):``}catch{return``}}function wl(e){return ul(e).filter(t=>dl(fl(e,t)).isDirectory())}async function Tl(e){let t=[],n=0,r=!1;do{let{largeLanguageModels:{nodes:i}}=await N(e,Z,{first:20,offset:n});t.push(...i),n+=20,r=i.length===20}while(r);return t.sort((e,t)=>e.name.localeCompare(t.name))}function El(e){return RegExp(`<${e}>([\\s\\S]+?)<\\/${e}>`)}function Dl(e){return e}const Ol=e=>{try{return JSON.parse(e)}catch{return e}};var kl=class{prompts;handlebarsOptions;promptContentMap;largeLanguageModels=[];agentsByName={};agentsByAgentId={};graphQLClient;defaultVariables;variables;handlebars;transcendApiKey;transcendUrl;requireApproval;cacheDuration;lastUpdatedAt;constructor({prompts:e,handlebarsOptions:t={},transcendUrl:n=c,transcendApiKey:r,requireApproval:i=!0,cacheDuration:a,defaultVariables:o={}}){this.prompts=e,this.transcendUrl=n,this.transcendApiKey=r,this.variables=o,this.defaultVariables=o,this.graphQLClient=M(n,typeof r==`object`?r.release():r),this.requireApproval=i,this.cacheDuration=a,this.handlebarsOptions=t,this.handlebars=G(t)}async fetchPromptsAndMetadata(){let e=cl(this.prompts),t=e.map(({id:e})=>e).filter(e=>!!e),n=e.map(({title:e})=>e).filter(e=>!!e),r=ol(e.map(({agentNames:e})=>e||[]).flat()),[i,a,o]=await Promise.all([D(this.graphQLClient,{promptIds:t,promptTitles:n}),Tl(this.graphQLClient),E(this.graphQLClient,{names:r})]);this.agentsByName=V(o,`name`),this.agentsByAgentId=V(o,`agentId`),this.largeLanguageModels=a.filter(e=>e.isTranscendHosted===!1);let s=V(i.prompts,`title`),c=V(i.prompts,`id`);return this.variables={...i.calculatedVariables.reduce((e,t)=>Object.assign(e,{[t.name]:t.data?JSON.parse(t.data):t.data}),{}),...this.defaultVariables},this.handlebars=G({...this.handlebarsOptions,templates:[...this.handlebarsOptions.templates||[],...i.promptPartials.map(e=>({name:e.slug,content:e.content}))]}),this.promptContentMap=sl(this.prompts,({id:e,title:t})=>{let n=e?c[e]:t?s[t]:void 0;if(!n)throw Error(`Failed to find prompt with title: "${t}" and id: "${e}"`);return n}),this.lastUpdatedAt=new Date,i}async getAgentByName(e){let t=this.agentsByName[e];if(t)return t;let[n]=await E(this.graphQLClient,{names:[e]});if(n)return this.agentsByName[n.name]=n,this.agentsByAgentId[n.agentId]=n,n}async getPromptThreadBySlackTs(e){let[t]=await Q(this.graphQLClient,{slackMessageTs:[e]});return t}async getAgentsByName(e){if(e.length<1)throw Error(`Expected at least one name to be provided`);let{hasCache:t=[],missingCache:n=[]}=al(e,e=>this.agentsByName[e]?`hasCache`:`missingCache`),r=t.map(e=>this.agentsByName[e]);if(n.length===0)return r;let i=rl(n,50),a=[];return await Tt(i,async e=>{let t=await E(this.graphQLClient,{names:e});t.forEach(e=>{this.agentsByName[e.name]=e,this.agentsByAgentId[e.agentId]=e}),a.push(...t)}),[...r,...a]}getAgentFiles(e){return T(this.graphQLClient,e)}getLargeLanguageModel(e){let t=this.largeLanguageModels.find(t=>typeof e==`string`?t.id===e:t.name===e.name&&t.client===e.client);if(!t)throw Error(`Failed to find model matching: ${typeof e==`string`?e:JSON.stringify(e)}`);return t}async getPromptDefinition(e){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let{promptContentMap:t}=this;if(!t)throw Error(`Expected this.promptContentMap to be defined`);let n=t[e];if(!n)throw Error(`Expected this.promptContentMap[${e}] to be defined`);return n}async compilePrompt(e,t){let n=await this.getPromptDefinition(e),r=this.prompts[e];if(!r)throw Error(`Expected this.prompts[${e}] to be defined`);if(this.requireApproval&&n.status!==z.Approved)throw Error(`Assessment "${n.title}" cannot be used because its in status: "${n.status}"`);if(n.status===z.Rejected)throw Error(`Assessment "${n.title}" cannot be used because it's in status: "${n.status}"`);return H(r.paramCodec,t),this.handlebars.compile(n.content)({currentDate:new Date().toISOString(),...this.variables,...t})}parseAiResponse(e,t){let n=this.prompts[e];if(!n)throw Error(`Expected this.prompts[${e}] to be defined`);let r=n.extractFromTag&&(El(n.extractFromTag).exec(t)||[])[1]||t;return H(n.outputCodec,Ol(r),!1)}async reportAndParsePromptRun(e,{largeLanguageModel:t,...n}){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let r=n.name||`@transcend-io/cli-prompt-run-${new Date().toISOString()}`;if(!this.promptContentMap)throw Error(`Expected this.promptContentMap to be defined`);let i=this.promptContentMap[e];if(!i)throw Error(`Expected this.prompts[${e}] to be defined`);if(n.promptRunMessages.length===0)throw Error(`promptRunMessages is expected to have length > 0`);if(n.promptRunMessages[0].role!==L.System)throw Error(`promptRunMessages[0].role is expected to be = ${L.System}`);if(n.promptRunMessages[n.promptRunMessages.length-1].role!==L.Assistant)throw Error(`promptRunMessages[${n.promptRunMessages.length-1}].role is expected to be = ${L.Assistant}`);let a=n.promptRunMessages[n.promptRunMessages.length-1].content,o;try{o=this.parseAiResponse(e,a)}catch(e){throw await $(this.graphQLClient,{productArea:R.PromptManager,...n,name:r,error:e.message,status:B.Error,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))}),e}let s=await $(this.graphQLClient,{productArea:R.PromptManager,...n,name:r,status:B.Resolved,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))});return{result:o,promptRunId:s,promptRunUrl:`https://app.transcend.io/prompts/runs/${s}`}}async reportPromptRunError(e,{largeLanguageModel:t,...n}){(!this.lastUpdatedAt||this.cacheDuration===0||this.cacheDuration&&Date.now()-this.lastUpdatedAt.getTime()>this.cacheDuration)&&await this.fetchPromptsAndMetadata();let r=n.name||`@transcend-io/cli-prompt-run-${new Date().toISOString()}`;if(!this.promptContentMap)throw Error(`Expected this.promptContentMap to be defined`);let i=this.promptContentMap[e];if(!i)throw Error(`Expected this.prompts[${e}] to be defined`);if(n.promptRunMessages.length===0)throw Error(`promptRunMessages is expected to have length > 0`);if(n.promptRunMessages[0].role!==L.System)throw Error(`promptRunMessages[0].role is expected to be = ${L.System}`);let a=await $(this.graphQLClient,{productArea:R.PromptManager,...n,name:r,status:B.Error,...typeof t==`string`?{largeLanguageModelId:t}:{largeLanguageModelName:t.name,largeLanguageModelClient:t.client},promptId:i.id,promptRunMessages:n.promptRunMessages.map((e,t)=>({...e,...t===0?{template:i.content}:{}}))});return{promptRunId:a,promptRunUrl:`https://app.transcend.io/prompts/runs/${a}`}}};function Al(e){return e.replace(/(https?:\/\/[^\s]+)/g,`<link-omitted>`)}function jl(e){return Object.entries(e).reduce((e,[t,n])=>n!=null&&n!==``&&!(Array.isArray(n)&&n.length===0)&&!(typeof n==`object`&&Object.keys(n).length===0)?Object.assign(e,{[t]:n}):e,{})}function Ml({baseBranch:e,rootDirectory:t,githubRepo:n,excludedGlob:r=[],fileBlockList:i=[]}){K(`git fetch origin ${e}`);let a=K(`git ls-remote ${n} "refs/heads/${e}" | cut -f 1`,{encoding:`utf-8`}).split(`
|
|
76
|
+
`)[0],o=K(`git rev-parse HEAD`,{encoding:`utf-8`}).split(`
|
|
77
|
+
`)[0];if(!a||!o)throw Error(`FAILED TO FIND COMMIT RANGE`);let s=il(K(`git fetch && git diff --name-only "${e||a}...${o}" -- ${t}`,{encoding:`utf-8`}).split(`
|
|
78
|
+
`).filter(e=>e),i),c=r.length>0?pl.sync(s,{ignore:r}):s,l={};return c.forEach(e=>{l[e]=K(`git show ${o}:${e}`,{encoding:`utf-8`})}),{changedFiles:s,fileDiffs:l,repoName:n.split(`/`).pop().split(`.`)[0],commit:o}}export{Xr as ACTIONS,X as ADD_MESSAGES_TO_PROMPT_RUN,jn as ADD_SILO_DISCOVERY_RESULTS,y as ADMIN_DASH,m as ADMIN_DASH_DATAPOINTS,_ as ADMIN_DASH_INTEGRATIONS,wi as AGENTS,Er as AGENT_FILES,zr as AGENT_FUNCTIONS,Tn as API_KEYS,Vi as APPROVE_PRIVACY_REQUEST,Ji as ASSESSMENTS,Ki as ASSESSMENT_SECTION_FIELDS,_a as ASSESSMENT_TEMPLATES,fo as ASSUME_ROLE,ei as ATTRIBUTES,Wn as ATTRIBUTE_KEYS_REQUESTS,Hr as ATTRIBUTE_VALUES,ct as ActionInput,Ze as ActionItemCollectionInput,it as ActionItemInput,Ue as AgentFileInput,Oe as AgentFunctionInput,$e as AgentInput,ot as ApiKeyInput,ua as AssessmentAction,Me as AssessmentAnswerOptionInput,qe as AssessmentDisplayLogicInput,ut as AssessmentInput,pa as AssessmentNestedRule,Pe as AssessmentNestedRuleInput,Le as AssessmentResourceInput,tt as AssessmentRetentionScheduleInput,oa as AssessmentRiskLogic,ta as AssessmentRule,Ye as AssessmentRuleInput,sa as AssessmentRuleWithOperands,ha as AssessmentRuleWithoutOperands,Ve as AssessmentSectionInput,ze as AssessmentSectionQuestionInput,Ee as AssessmentTemplateInput,Hn as AttestedExtraIdentifiers,ft as AttributeInput,_t as AttributePreview,Ae as AttributeValueInput,Eo as BLANK,So as BULK_APPLY,Ea as BULK_REQUEST_FILES,_i as BUSINESS_ENTITIES,ht as BusinessEntityInput,Ri as CANCEL_PRIVACY_REQUEST,wo as CAN_APPLY_IN_BULK,Yt as CATALOGS,xa as CHANGE_REQUEST_DATA_SILO_STATUS,bn as CODE_PACKAGES,eo as CONSENT_MANAGER_ANALYTICS_DATA,Ba as CONSENT_PARTITIONS,Ja as COOKIES,Jr as CREATE_ACTION_ITEMS,Ai as CREATE_ACTION_ITEM_COLLECTION,pi as CREATE_AGENT,Qn as CREATE_AGENT_FILE,Rr as CREATE_AGENT_FUNCTION,Cn as CREATE_API_KEY,Oi as CREATE_ATTRIBUTE,Ni as CREATE_ATTRIBUTE_VALUES,di as CREATE_BUSINESS_ENTITY,sn as CREATE_CODE_PACKAGE,no as CREATE_CONSENT_EXPERIENCE,Va as CREATE_CONSENT_MANAGER,Ha as CREATE_CONSENT_PARTITION,Qa as CREATE_DATA_FLOWS,It as CREATE_DATA_SILOS,qt as CREATE_DATA_SUBJECT,Nr as CREATE_DATA_SUB_CATEGORY,Bt as CREATE_ENRICHER,tn as CREATE_IDENTIFIER,Dn as CREATE_PREFERENCE_ACCESS_TOKENS,_r as CREATE_PROCESSING_ACTIVITY,tr as CREATE_PROCESSING_PURPOSE_SUB_CATEGORY,er as CREATE_PROMPT,oi as CREATE_PROMPT_GROUP,br as CREATE_PROMPT_PARTIAL,ln as CREATE_REPOSITORY,gn as CREATE_SOFTWARE_DEVELOPMENT_KIT,or as CREATE_TEAM,Fn as CREATE_TEMPLATE,gr as CREATE_VENDOR,bo as CachedFileState,vo as CachedRequestState,ve as CodePackageInput,ne as CodePackageSdk,Co as ColumnName,mt as ConsentManageExperienceInput,ye as ConsentManagerInput,to as ConsentManagerMetricBin,ie as ConsentManagerServiceMetadata,re as ConsentPreferenceTopic,me as ConsentPreferenceTopicOptionValue,Ke as ConsentPurpose,ee as CookieCsvInput,Ge as CookieInput,Qo as CronIdentifier,Kc as CronIdentifierPush,Nt as DATAPOINT_EXPORT,Ya as DATA_FLOWS,Ft as DATA_POINTS,Dt as DATA_POINT_COUNT,Mt as DATA_SILOS,Pt as DATA_SILOS_ENRICHED,At as DATA_SILO_EXPORT,Ut as DATA_SUBJECTS,Lr as DATA_SUB_CATEGORIES,jc as DAY_MS,f as DEBUG,c as DEFAULT_TRANSCEND_API,h as DEFAULT_TRANSCEND_CONSENT_API,ma as DEFAULT_TRANSCEND_PULL_RESOURCES,Sn as DELETE_API_KEY,Kr as DELETE_ATTRIBUTE_VALUE,ii as DEPLOYED_PRIVACY_CENTER_URL,Wa as DEPLOY_CONSENT_MANAGER,mo as DETERMINE_LOGIN_METHOD,fe as DataCategoryGuessInput,pe as DataCategoryInput,he as DataCategoryPreviewInput,ae as DataCategoryRecommendationInput,ce as DataFlowCsvInput,de as DataFlowInput,_e as DataSiloInput,yt as DataSubjectInput,te as DatapointInput,kn as ENABLED_PLUGINS,Wt as ENRICHERS,Rt as ENTRY_COUNT,Ua as EXPERIENCES,el as EnrichPrivacyRequest,xe as EnricherInput,La as FETCH_CONSENT_MANAGER,ro as FETCH_CONSENT_MANAGER_ID,oo as FETCH_CONSENT_MANAGER_THEME,Wr as FETCH_PRIVACY_CENTER_ID,Dc as FIVE_MIN_MS,se as FieldInput,ui as GLOBAL_ACTION_ITEMS,Mr as GLOBAL_ACTION_ITEM_COLLECTIONS,kc as HOUR_MS,Qt as IDENTIFIERS,To as IDENTIFIER_BLOCK_LIST,qi as IMPORT_ONE_TRUST_ASSESSMENT_FORMS,Kt as INITIALIZER,Wc as IP_ADDRESS_REGEX,yo as IS_REQUIRED,be as IdentifierInput,Se as ImportOnetrustAssessmentsInput,ic as IntlMessage,oe as IntlMessageInput,Z as LARGE_LANGUAGE_MODELS,co as LOGIN,nr as MESSAGES,Zt as NEW_IDENTIFIER_TYPES,xo as NONE,Bi as NOTIFY_ADDITIONAL_TIME,Ln as ORGANIZATION,a as OneTrustFileFormat,n as OneTrustPullResource,i as OneTrustPullSource,ue as OpenAIEnabledRoute,rt as OpenAIEnabledRoutes,le as OpenAIIntegration,t as OpenAIRouteName,fr as POLICIES,Zi as PREFERENCE_TOPICS,hi as PRIVACY_CENTER,Dr as PROCESSING_ACTIVITIES,Fr as PROCESSING_PURPOSE_SUB_CATEGORIES,xr as PROMPTS,Tr as PROMPTS_WITH_VARIABLES,lr as PROMPT_GROUPS,mr as PROMPT_PARTIALS,q as PROMPT_THREADS,Yi as PURPOSES,jo as ParsedAttributeInput,we as PartitionInput,Ce as PathfinderPolicy,e as PathfinderPolicyName,Te as PathfinderPolicyNameC,ge as PathfinderPromptRunMetadata,S as PolicyInput,Ie as PrivacyCenterInput,qo as PrivacyRequest,Rn as PrivacyRequestInput,oc as PrivacyRequestResponse,lt as ProcessingActivityInput,Qe as ProcessingPurposeInput,at as ProcessingPurposePreviewInput,We as PromptAVendorEmailSettings,ke as PromptGroupInput,et as PromptInput,st as PromptPartialInput,zo as PurposeMap,ya as REDUCED_REQUESTS_FOR_DATA_SILO_COUNT,wa as REMOVE_REQUEST_IDENTIFIERS,Y as REPORT_PROMPT_RUN,rn as REPOSITORIES,Li as REQUESTS,Ii as REQUESTS_COUNT,ba as REQUEST_DATA_SILOS,Ui as REQUEST_ENRICHERS,Da as REQUEST_FILES,Sa as REQUEST_IDENTIFIERS,v as RETRYABLE_BATCH_STATUSES,va as RETRY_REQUEST_DATA_SILO,Wi as RETRY_REQUEST_ENRICHER,xc as RateCounter,Ne as RegionInput,Je as RepositoryInput,tc as RequestFileMetadata,ec as RequestFileMetadataResponse,_o as RequestIdentifiersResponse,Ko as RequestPurposeTrigger,dt as RiskAssignmentInput,Fe as RiskLogicInput,l as SCOPES_BY_TITLE,p as SCOPE_TITLES,O as SET_RESOURCE_ATTRIBUTES,ga as SILO_DISCOVERY_RESULTS,Hi as SKIP_REQUEST_ENRICHER,pn as SOFTWARE_DEVELOPMENT_KITS,go as SOMBRA_VERSION,jt as SUB_DATA_POINTS,Lt as SUB_DATA_POINTS_COUNT,Ot as SUB_DATA_POINTS_WITH_GUESSES,$n as SYNC_ATTRIBUTE_TYPES,Re as SiloDiscoveryResultInput,nt as SoftwareDevelopmentKitInput,Xe as StoredApiKey,Do as SuccessfulRequest,Cr as TEAMS,Nn as TEMPLATES,za as TOGGLE_CONSENT_PRECEDENCE,Gt as TOGGLE_DATA_SUBJECT,ao as TOGGLE_TELEMETRY_PARTITION_STRATEGY,Fa as TOGGLE_UNKNOWN_COOKIE_POLICY,Aa as TOGGLE_UNKNOWN_REQUEST_POLICY,b as TR_PULL_RESOURCE_SCOPE_MAP,u as TR_PUSH_RESOURCE_SCOPE_MAP,d as TR_YML_RESOURCE_TO_FIELD_NAME,He as TeamInput,Be as TemplateInput,De as TranscendInput,kl as TranscendPromptManager,r as TranscendPullResource,Qr as UPDATE_ACTION,Ei as UPDATE_ACTION_ITEMS,cr as UPDATE_ACTION_ITEM_COLLECTION,bi as UPDATE_AGENTS,Zr as UPDATE_AGENT_FILES,Br as UPDATE_AGENT_FUNCTIONS,Ar as UPDATE_ATTRIBUTE,ir as UPDATE_ATTRIBUTE_VALUES,ni as UPDATE_BUSINESS_ENTITIES,cn as UPDATE_CODE_PACKAGES,io as UPDATE_CONSENT_EXPERIENCE,Ia as UPDATE_CONSENT_MANAGER_DOMAINS,Ma as UPDATE_CONSENT_MANAGER_PARTITION,ja as UPDATE_CONSENT_MANAGER_THEME,Pa as UPDATE_CONSENT_MANAGER_TO_LATEST,qa as UPDATE_CONSENT_MANAGER_VERSION,ka as UPDATE_DATA_FLOWS,Et as UPDATE_DATA_SILOS,Ht as UPDATE_DATA_SUBJECT,ur as UPDATE_DATA_SUB_CATEGORIES,Vt as UPDATE_ENRICHER,en as UPDATE_IDENTIFIER,Ir as UPDATE_INTL_MESSAGES,Ka as UPDATE_LOAD_OPTIONS,Na as UPDATE_OR_CREATE_COOKIES,kt as UPDATE_OR_CREATE_DATA_POINT,Pr as UPDATE_POLICIES,Si as UPDATE_PRIVACY_CENTER,zi as UPDATE_PRIVACY_REQUEST,Pi as UPDATE_PROCESSING_ACTIVITIES,dr as UPDATE_PROCESSING_PURPOSE_SUB_CATEGORIES,vr as UPDATE_PROMPTS,Or as UPDATE_PROMPT_GROUPS,Fi as UPDATE_PROMPT_PARTIALS,xn as UPDATE_REPOSITORIES,un as UPDATE_SOFTWARE_DEVELOPMENT_KITS,ci as UPDATE_TEAM,vi as UPDATE_VENDORS,J as USERS,Lo as USP_STRING_REGEX,wt as VARIABLE_PARAMETERS_NAME,St as VARIABLE_PARAMETERS_REGEXP,hr as VENDORS,pt as VendorInput,vt as WebhookHeader,Ec as addDaysUtc,ml as addMessagesToPromptRun,wc as addMs,Rc as appendCsvRowsOrdered,Pc as appendCsvSync,lc as approvePrivacyRequests,lo as assumeRole,gt as buildAIIntegrationType,je as buildEnabledRouteType,M as buildTranscendGraphQLClient,Po as buildTranscendGraphQLClientGeneric,Hc as buildXdiSyncEndpoint,pc as bulkRestartRequests,ns as bulkRetryEnrichers,dc as cancelPrivacyRequests,Oc as clampPageSize,Sc as collectParquetFilesOrExit,Gc as consentManagersToBusinessEntities,Vr as convertToDataSubjectAllowlist,Di as convertToDataSubjectBlockList,us as createActionItemCollection,qs as createActionItems,rs as createAgent,ds as createAgentFile,ms as createAgentFunction,uo as createApiKey,ss as createBusinessEntity,yn as createCodePackage,Io as createConsentToken,Gs as createDataCategory,Qs as createDataFlows,On as createPreferenceAccessTokens,Hs as createProcessingPurpose,Bs as createPrompt,El as createRegexForTag,vn as createRepository,dn as createSoftwareDevelopmentKit,w as createSombraGotInstance,Fo as createTranscendConsentGotInstance,js as createVendor,Dl as defineTranscendPrompts,po as deleteApiKey,Bo as deployConsentManager,s as description,Uc as domainToHost,ac as downloadPrivacyRequestFiles,tl as enrichPrivacyRequest,Mi as ensureAllDataSubjectsExist,cc as extractClientError,I as extractErrorMessage,An as fetchActiveSiloDiscoPlugin,pr as fetchAllActionItems,Ci as fetchAllActions,T as fetchAllAgentFiles,wr as fetchAllAgentFunctions,E as fetchAllAgents,En as fetchAllApiKeys,ia as fetchAllAssessmentTemplates,$i as fetchAllAssessments,ai as fetchAllAttributeValues,yr as fetchAllAttributes,si as fetchAllBusinessEntities,Xt as fetchAllCatalogs,aa as fetchAllCookies,Sr as fetchAllDataCategories,Uo as fetchAllDataFlows,mi as fetchAllDataPoints,xi as fetchAllDataSilos,Gr as fetchAllDataSubjects,ri as fetchAllEnrichers,nn as fetchAllIdentifiers,ca as fetchAllMessages,jr as fetchAllPolicies,Qi as fetchAllPreferenceTopics,ra as fetchAllPrivacyCenters,ki as fetchAllProcessingActivities,rr as fetchAllProcessingPurposes,$r as fetchAllPromptGroups,ti as fetchAllPromptPartials,Q as fetchAllPromptThreads,gi as fetchAllPrompts,Xi as fetchAllPurposes,Wo as fetchAllPurposesAndPreferences,Zn as fetchAllRequestAttributeKeys,Gi as fetchAllRequestEnrichers,Ca as fetchAllRequestIdentifierMetadata,k as fetchAllRequestIdentifiers,P as fetchAllRequests,fa as fetchAllSiloDiscoveryResults,qr as fetchAllSubDataPoints,kr as fetchAllTeams,In as fetchAllTemplates,hl as fetchAllUsers,ji as fetchAllVendors,Jt as fetchAndIndexCatalogs,wn as fetchApiKeys,Xa as fetchConsentManager,$a as fetchConsentManagerAnalyticsData,Ga as fetchConsentManagerExperiences,Ra as fetchConsentManagerId,Za as fetchConsentManagerTheme,li as fetchEnrichedDataSilos,$t as fetchIdentifiersAndCreateMissing,fi as fetchPartitions,sr as fetchPrivacyCenterId,ar as fetchPrivacyCenterUrl,D as fetchPromptsWithVariables,Xo as fetchRequestDataSilo,Zo as fetchRequestDataSiloActiveCount,Jo as fetchRequestDataSilos,Yo as fetchRequestDataSilosCount,Oa as fetchRequestFilesForRequest,Go as fetchRequestsTotalCount,jl as filterNullishValuesFromObject,Bn as filterRows,da as formatAttributeValues,F as formatRequestForCsv,Ao as fuzzyMatchColumns,Oo as fuzzySearch,ho as generateCrossAccountApiKeys,yl as getErrorStatus,rc as getFileMetadataForPrivacyRequests,Ml as getGitFilesThatChanged,Vn as getUniqueValuesForColumn,Ic as initCsvFile,bc as inquirerAutoComplete,vc as inquirerConfirmBoolean,yc as inquirerConfirmText,Sl as limitRecords,wl as listDirectories,Zc as listFiles,so as loginUser,N as makeGraphQLRequest,Gn as mapColumnsToAttributes,Jn as mapColumnsToIdentifiers,Un as mapCsvColumnsToApi,Kn as mapCsvRowsToRequestInputs,qn as mapEnumValues,zn as mapRequestEnumValues,qc as markCronIdentifierCompleted,Yc as markRequestDataSiloIdsCompleted,$s as markSilentPrivacyRequests,Vs as mergeTranscendInputs,g as name,Yn as normalizeIdentifierValue,uc as notifyPrivacyRequestsAdditionalTime,Cc as parquetToCsvOneFile,na as parseAssessmentDisplayLogic,ea as parseAssessmentRiskLogic,ko as parseAttributesFromString,Nc as parseFilePath,zs as parseVariablesFromString,Qc as pullAllDatapoints,es as pullChunkedCustomSiloOutstandingIdentifiers,Vc as pullConsentManagerMetrics,$o as pullCronPageOfIdentifiers,$c as pullManualEnrichmentIdentifiersToCsv,vl as pullPrivacyRequests,la as pullTranscendConfiguration,zt as pullUnstructuredSubDataPointRecommendations,Jc as pushCronIdentifiersFromCsv,nl as pushManualEnrichmentIdentifiersFromCsv,No as readCsv,Cl as readSafe,Ct as readTranscendYaml,Al as removeLinks,Ta as removeUnverifiedRequestIdentifiers,xt as replaceVariablesInYaml,$ as reportPromptRun,fc as restartPrivacyRequest,hc as retryRequestDataSilos,ts as retryRequestEnricher,xl as retrySamePromise,gl as setResourceAttributes,mc as skipPreflightJobs,_c as skipRequestDataSilos,j as sleepPromise,Mo as splitCsvToList,bl as splitInHalf,Ac as startOfHour,Tc as startOfUtcDay,nc as streamPrivacyRequestFiles,gc as streamPrivacyRequestsToCsv,sc as submitPrivacyRequest,ls as syncAction,bs as syncActionItemCollections,is as syncActionItems,fs as syncAgentFiles,gs as syncAgentFunctions,Ms as syncAgents,Ns as syncAttribute,os as syncBusinessEntities,mn as syncCodePackages,Is as syncConfigurationToTranscend,Ws as syncConsentManager,ys as syncConsentManagerExperiences,Ys as syncCookies,vs as syncDataCategories,Xs as syncDataFlows,Ti as syncDataSiloDependencies,Yr as syncDataSilos,Ts as syncDataSubject,Ur as syncEnricher,Ks as syncIdentifier,Cs as syncIntlMessages,yi as syncPartitions,As as syncPolicies,Fs as syncPrivacyCenter,Rs as syncProcessingActivities,Ds as syncProcessingPurposes,Es as syncPrompts,on as syncRepositories,an as syncSoftwareDevelopmentKits,Pn as syncTemplate,ws as syncVendors,xs as updateActionItem,Ss as updateActionItemCollection,_s as updateAgentFiles,cs as updateAgentFunctions,ps as updateAgents,hs as updateBusinessEntities,_n as updateCodePackages,Vo as updateConsentManagerToLatest,Ho as updateConsentManagerVersionToLatest,as as updateDataCategories,Zs as updateDataFlows,Us as updateIntlMessages,Js as updateOrCreateCookies,ks as updatePolicies,Os as updateProcessingPurposes,Ps as updatePrompts,fn as updateRepositories,hn as updateSoftwareDevelopmentKits,Ls as updateVendors,Ro as uploadConsents,Bc as uploadCookiesFromCsv,zc as uploadDataFlowsFromCsv,Xn as uploadPrivacyRequestsFromCsv,Mn as uploadSiloDiscoveryResults,A as validateSombraVersion,Xc as validateTranscendAuth,o as version,Mc as writeCsv,Fc as writeCsvSync,Lc as writeLargeCsv,bt as writeTranscendYaml};
|
|
5
79
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":[],"sources":["../src/lib/graphql/fetchLargeLanguageModels.ts","../src/lib/ai/TranscendPromptManager.ts","../src/lib/ai/removeLinks.ts","../src/lib/ai/filterNullishValuesFromObject.ts","../src/lib/ai/getGitFilesThatChanged.ts"],"sourcesContent":["import { GraphQLClient } from 'graphql-request';\nimport { LargeLanguageModelClient } from '@transcend-io/privacy-types';\nimport { LARGE_LANGUAGE_MODELS } from './gqls';\nimport { makeGraphQLRequest } from './makeGraphQLRequest';\n\nexport interface LargeLanguageModel {\n /** ID of prompts */\n id: string;\n /** The name of the large language model. */\n name: string;\n /** The content of the prompt template. */\n client: LargeLanguageModelClient;\n /** Whether hosted by Transcend or not */\n isTranscendHosted: boolean;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all LargeLanguageModels in the organization\n *\n * @param client - GraphQL client\n * @returns All LargeLanguageModels in the organization\n */\nexport async function fetchAllLargeLanguageModels(\n client: GraphQLClient,\n): Promise<LargeLanguageModel[]> {\n const largeLanguageModels: LargeLanguageModel[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n largeLanguageModels: { nodes },\n } = await makeGraphQLRequest<{\n /** LargeLanguageModels */\n largeLanguageModels: {\n /** List */\n nodes: LargeLanguageModel[];\n };\n }>(client, LARGE_LANGUAGE_MODELS, {\n first: PAGE_SIZE,\n offset,\n });\n largeLanguageModels.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return largeLanguageModels.sort((a, b) => a.name.localeCompare(b.name));\n}\n","/* eslint-disable max-lines */\nimport {\n Optionalize,\n Requirize,\n apply,\n decodeCodec,\n getValues,\n} from '@transcend-io/type-utils';\nimport type { Handlebars } from '@transcend-io/handlebars-utils';\nimport { Secret } from '@transcend-io/secret-value';\nimport * as t from 'io-ts';\nimport { DEFAULT_TRANSCEND_API } from '../../constants';\nimport {\n Agent,\n AgentFile,\n AgentFileFilterBy,\n ReportPromptRunInput,\n buildTranscendGraphQLClient,\n fetchAllAgentFiles,\n fetchAllAgents,\n reportPromptRun,\n} from '../graphql';\nimport {\n HandlebarsInput,\n createHandlebarsWithHelpers,\n} from '@transcend-io/handlebars-utils';\nimport {\n TranscendPromptTemplated,\n TranscendPromptsAndVariables,\n fetchPromptsWithVariables,\n} from '../graphql/fetchPrompts';\nimport { GraphQLClient } from 'graphql-request';\nimport {\n PromptStatus,\n ChatCompletionRole,\n PromptRunProductArea,\n QueueStatus,\n LargeLanguageModelClient,\n} from '@transcend-io/privacy-types';\nimport {\n LargeLanguageModel,\n fetchAllLargeLanguageModels,\n} from '../graphql/fetchLargeLanguageModels';\nimport { groupBy, keyBy, uniq, chunk } from 'lodash-es';\nimport { mapSeries } from '../bluebird';\nimport {\n PromptThread,\n fetchAllPromptThreads,\n} from '../graphql/fetchPromptThreads';\n\n/**\n * An LLM Prompt definition\n */\nexport type TranscendPrompt<\n TInputParams extends t.Any,\n TOutputCodec extends t.Any,\n> = (\n | {\n /** ID of the prompt */\n id: string;\n /** Title of the prompt */\n title?: string;\n }\n | {\n /** ID of the prompt */\n id?: string;\n /** Title of the prompt */\n title: string;\n }\n) & {\n /** The names of the agents that should be loaded along with the prompt */\n agentNames?: string[];\n /** Codec to validate runtime input shape */\n paramCodec: TInputParams;\n /** Codec to validate output response */\n outputCodec: TOutputCodec;\n /**\n * If the output that needs to be parsed is returned within a tag\n * e.g. <tag> or <json> - this is the name of the tag\n */\n extractFromTag?: string;\n};\n\nexport interface PromptRunResult {\n /** The ID of the prompt run created on Transcend */\n promptRunId: string;\n /** The URL of the prompt run on Transcend */\n promptRunUrl: string;\n}\n\n/**\n * Create a regex to extract data from a tag\n *\n * Input:\n * \"here is some data <tag>Data</tag>...\"\n *\n * @param tagName - Name of tag\n * @returns Data within the tag\n */\nexport function createRegexForTag(tagName: string): RegExp {\n return new RegExp(`<${tagName}>([\\\\s\\\\S]+?)<\\\\/${tagName}>`);\n}\n\n/**\n * Helper function to declare prompts\n *\n * @param prompts - Prompt config\n * @returns Prompts as identity function - but type enforced\n */\nexport function defineTranscendPrompts<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n>(prompts: TPrompts): TPrompts {\n return prompts;\n}\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptParamType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['paramCodec']>;\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptResponseType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n\n/**\n * Input for reporting a prompt run\n */\nexport interface ReportPromptRunOptions\n extends Optionalize<\n Omit<ReportPromptRunInput, 'status' | 'promptId' | 'largeLanguageModelId'>,\n 'name' | 'productArea'\n > {\n /** The large language model being run. Either the ID of the LLM or the client/name pairing */\n largeLanguageModel:\n | string\n | {\n /** Name of client */\n client: LargeLanguageModelClient;\n /** Name of the model */\n name: string;\n };\n}\n\nconst jsonParseSafe = (obj: string): unknown => {\n try {\n return JSON.parse(obj);\n } catch (e) {\n return obj;\n }\n};\n\n/**\n * A class that is capable of loading and insert variables into prompts from\n * Transcend's Prompt Manager\n */\nexport class TranscendPromptManager<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n> {\n /** Prompt definitions */\n public prompts: TPrompts;\n\n /** Options for configuring handlebars */\n public handlebarsOptions!: HandlebarsInput;\n\n /** Prompt name -> content map, populated by call to Transcend API */\n public promptContentMap?: { [k in TPromptNames]: TranscendPromptTemplated };\n\n /** The large language models that are registered to this organization for reporting */\n public largeLanguageModels: LargeLanguageModel[] = [];\n\n /** The agent definitions registered to this organization */\n private agentsByName: { [name in string]: Agent } = {};\n\n /** The agent definitions registered to this organization */\n private agentsByAgentId: { [id in string]: Agent } = {};\n\n /** The GraphQL client that can be used to call Transcend */\n public graphQLClient: GraphQLClient;\n\n /** The set of variables to expose in handlebars context specified at class initiation */\n public defaultVariables: { [k in string]: unknown };\n\n /**\n * The set of variables to expose in handlebars context,\n * merges defaults with calculated variables from the inventory\n */\n public variables: { [k in string]: unknown };\n\n /** Handlebars compiler */\n public handlebars: typeof Handlebars;\n\n /** The Transcend API key */\n public transcendApiKey: string | Secret<string>;\n\n /** API of Transcend to call */\n public transcendUrl: string;\n\n /** When true, throw an error if the prompt is not approved */\n public requireApproval: boolean;\n\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n public cacheDuration?: number;\n\n /**\n * The last time the metadata was fetched\n */\n public lastUpdatedAt?: Date;\n\n /**\n * Constructor\n *\n * @param options - Options\n */\n constructor({\n prompts,\n handlebarsOptions = {},\n transcendUrl = DEFAULT_TRANSCEND_API,\n transcendApiKey,\n requireApproval = true,\n cacheDuration,\n defaultVariables = {},\n }: {\n /** Prompt definitions to load */\n prompts: TPrompts;\n /** Options for configuring handlebars */\n handlebarsOptions?: HandlebarsInput;\n /** The Transcend API key */\n transcendApiKey: string | Secret<string>;\n /** API of Transcend to call */\n transcendUrl?: string;\n /** When true, throw an error if the prompt is not approved */\n requireApproval?: boolean;\n /** The set of variables to expose in handlebars context specified at class initiation */\n defaultVariables?: { [k in string]: unknown };\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n cacheDuration?: number;\n }) {\n this.prompts = prompts;\n this.transcendUrl = transcendUrl;\n this.transcendApiKey = transcendApiKey;\n this.variables = defaultVariables;\n this.defaultVariables = defaultVariables;\n this.graphQLClient = buildTranscendGraphQLClient(\n transcendUrl,\n typeof transcendApiKey === 'object'\n ? transcendApiKey.release()\n : transcendApiKey,\n );\n this.requireApproval = requireApproval;\n this.cacheDuration = cacheDuration;\n this.handlebarsOptions = handlebarsOptions;\n this.handlebars = createHandlebarsWithHelpers(handlebarsOptions);\n }\n\n /**\n * Fetch prompt metadata from Transcend and cache to the class definition\n *\n * @returns A function that can be used to call the prompt\n */\n async fetchPromptsAndMetadata(): Promise<TranscendPromptsAndVariables> {\n // Determine what to fetch\n const promptDefinitions = getValues(this.prompts) as TranscendPrompt<\n t.Any,\n t.Any\n >[];\n const promptIds = promptDefinitions\n .map(({ id }) => id)\n .filter((x): x is string => !!x);\n const promptTitles = promptDefinitions\n .map(({ title }) => title)\n .filter((x): x is string => !!x);\n const agentNames = uniq(\n promptDefinitions.map(({ agentNames }) => agentNames || []).flat(),\n );\n\n // Fetch prompts and data\n const [response, largeLanguageModels, agents] = await Promise.all([\n fetchPromptsWithVariables(this.graphQLClient, {\n promptIds,\n promptTitles,\n }),\n fetchAllLargeLanguageModels(this.graphQLClient),\n fetchAllAgents(this.graphQLClient, { names: agentNames }),\n ]);\n this.agentsByName = keyBy(agents, 'name');\n this.agentsByAgentId = keyBy(agents, 'agentId');\n this.largeLanguageModels = largeLanguageModels.filter(\n (model) => model.isTranscendHosted === false,\n );\n\n // Lookup prompts by id/title\n const promptByTitle = keyBy(response.prompts, 'title');\n const promptById = keyBy(response.prompts, 'id');\n\n // Update variables\n this.variables = {\n ...response.calculatedVariables.reduce(\n (acc, v) =>\n Object.assign(acc, {\n [v.name]: v.data ? JSON.parse(v.data) : v.data,\n }),\n {},\n ),\n ...this.defaultVariables,\n };\n\n // Update partials\n this.handlebars = createHandlebarsWithHelpers({\n ...this.handlebarsOptions,\n templates: [\n ...(this.handlebarsOptions.templates || []),\n ...response.promptPartials.map((partial) => ({\n name: partial.slug,\n content: partial.content,\n })),\n ],\n });\n\n // Create mapping from prompt to content\n this.promptContentMap = apply(this.prompts, ({ id, title }) => {\n const result = id\n ? promptById[id]\n : title\n ? promptByTitle[title]\n : undefined;\n if (!result) {\n throw new Error(\n `Failed to find prompt with title: \"${title}\" and id: \"${id}\"`,\n );\n }\n return result;\n });\n\n // For cache\n this.lastUpdatedAt = new Date();\n\n return response;\n }\n\n /**\n * Get an agent definition by name\n *\n * @param name - Name of the agent to grab\n * @returns Large language model configuration\n */\n async getAgentByName(name: string): Promise<Agent | undefined> {\n const agent = this.agentsByName[name];\n if (agent) {\n return agent;\n }\n const [remoteAgent] = await fetchAllAgents(this.graphQLClient, {\n names: [name],\n });\n if (!remoteAgent) {\n return undefined;\n }\n this.agentsByName[remoteAgent.name] = remoteAgent;\n this.agentsByAgentId[remoteAgent.agentId] = remoteAgent;\n return remoteAgent;\n }\n\n /**\n * Get a prompt thread by ts\n *\n * @param ts - the slack message timestamp to look up thread for\n * @returns Large language model configuration\n */\n async getPromptThreadBySlackTs(\n ts: string,\n ): Promise<PromptThread | undefined> {\n const [thread] = await fetchAllPromptThreads(this.graphQLClient, {\n slackMessageTs: [ts],\n });\n return thread;\n }\n\n /**\n * Get a list of agent definitions by name.\n * Pulls from cache and may return less agents\n * than requested if some are not found\n *\n * @param names - Names of agents to fetch\n * @returns The agents that were found matching the names\n */\n async getAgentsByName(names: string[]): Promise<Agent[]> {\n if (names.length < 1) {\n throw new Error('Expected at least one name to be provided');\n }\n const { hasCache = [], missingCache = [] } = groupBy(names, (name) =>\n this.agentsByName[name] ? 'hasCache' : 'missingCache',\n );\n const cachedAgents = hasCache.map((name) => this.agentsByName[name]);\n if (missingCache.length === 0) {\n return cachedAgents;\n }\n const chunkedNames = chunk(missingCache, 50);\n const remoteAgents: Agent[] = [];\n await mapSeries(chunkedNames, async (chunkedName) => {\n const pageOfAgents = await fetchAllAgents(this.graphQLClient, {\n names: chunkedName,\n });\n pageOfAgents.forEach((agent) => {\n this.agentsByName[agent.name] = agent;\n this.agentsByAgentId[agent.agentId] = agent;\n });\n remoteAgents.push(...pageOfAgents);\n });\n return [...cachedAgents, ...remoteAgents];\n }\n\n /**\n * Fetch metadata on agent files\n *\n * @param filterBy - Filter by parameters\n * @returns The files found matching the filter\n */\n getAgentFiles(filterBy: AgentFileFilterBy): Promise<AgentFile[]> {\n return fetchAllAgentFiles(this.graphQLClient, filterBy);\n }\n\n /**\n * Look up the large language model to report on\n *\n * @param largeLanguageModel - Input\n * @returns Large language model configuration\n */\n getLargeLanguageModel(\n largeLanguageModel: ReportPromptRunOptions['largeLanguageModel'],\n ): LargeLanguageModel {\n const matching = this.largeLanguageModels.find((model) =>\n typeof largeLanguageModel === 'string'\n ? model.id === largeLanguageModel\n : model.name === largeLanguageModel.name &&\n model.client === largeLanguageModel.client,\n );\n if (!matching) {\n throw new Error(\n `Failed to find model matching: ${\n typeof largeLanguageModel === 'string'\n ? largeLanguageModel\n : JSON.stringify(largeLanguageModel)\n }`,\n );\n }\n return matching;\n }\n\n /**\n * Get a prompt definition by name\n *\n * @param promptName - Prompt to compile\n * @returns Parsed content\n */\n async getPromptDefinition<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n ): Promise<TranscendPromptTemplated> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n // Lookup prompt\n const { promptContentMap } = this;\n if (!promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n const promptTemplate = promptContentMap[promptName];\n if (!promptTemplate) {\n throw new Error(\n `Expected this.promptContentMap[${promptName}] to be defined`,\n );\n }\n return promptTemplate;\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to compile\n * @param params - Runtime parameters\n * @returns Parsed content\n */\n async compilePrompt<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n params: t.TypeOf<TPrompts[TPromptName]['paramCodec']>,\n ): Promise<string> {\n // Grab the prompt\n const promptTemplate = await this.getPromptDefinition(promptName);\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure prompt is approved\n if (\n this.requireApproval &&\n promptTemplate.status !== PromptStatus.Approved\n ) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because its in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // If prompt is rejected, throw error\n if (promptTemplate.status === PromptStatus.Rejected) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because it's in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // Validate params\n decodeCodec(promptInput.paramCodec, params);\n\n // Compile prompt and template\n return this.handlebars.compile(promptTemplate.content)({\n // template in currentDate by default\n currentDate: new Date().toISOString(),\n ...this.variables,\n ...params,\n });\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to parse\n * @param response - AI response as string\n * @returns Parsed content\n */\n parseAiResponse<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n response: string,\n ): t.TypeOf<TPrompts[TPromptName]['outputCodec']> {\n // Look up prompt info\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Extract from tag if needed\n const extracted = promptInput.extractFromTag\n ? (createRegexForTag(promptInput.extractFromTag).exec(response) ||\n [])[1] || response\n : response;\n\n // Parse via codec\n return decodeCodec(\n promptInput.outputCodec,\n jsonParseSafe(extracted),\n false,\n );\n }\n\n /**\n * Parse the AI response and report back to Transcend\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportAndParsePromptRun<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n { largeLanguageModel, ...options }: ReportPromptRunOptions,\n ): Promise<\n PromptRunResult & {\n /** Resulting prompt run */\n result: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n }\n > {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n if (\n options.promptRunMessages[options.promptRunMessages.length - 1].role !==\n ChatCompletionRole.Assistant\n ) {\n throw new Error(\n `promptRunMessages[${\n options.promptRunMessages.length - 1\n }].role is expected to be = ${ChatCompletionRole.Assistant}`,\n );\n }\n const response =\n options.promptRunMessages[options.promptRunMessages.length - 1].content;\n\n let parsed: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n try {\n // Parse the response\n parsed = this.parseAiResponse(promptName, response);\n } catch (err) {\n await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n error: err.message,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n throw err;\n }\n\n // report successful run\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Resolved,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n result: parsed,\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n\n /**\n * Report an error for a particular prompt\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportPromptRunError<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n {\n largeLanguageModel,\n ...options\n }: Requirize<ReportPromptRunOptions, 'error'>,\n ): Promise<PromptRunResult> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n}\n/* eslint-enable max-lines */\n","/**\n * Remove links from a string\n *\n * @param inputString - String\n * @returns String without links\n */\nexport function removeLinks(inputString: string): string {\n const regex = /(https?:\\/\\/[^\\s]+)/g;\n return inputString.replace(regex, '<link-omitted>');\n}\n","import { ObjByString } from '@transcend-io/type-utils';\n\n/**\n * Given an object, remove all keys that are null-ish\n *\n * @param obj - Object\n * @returns Object with null-ish values removed\n */\nexport function filterNullishValuesFromObject<T extends ObjByString>(\n obj: T,\n): T {\n return Object.entries(obj).reduce(\n (acc, [k, v]) =>\n v !== null &&\n v !== undefined &&\n v !== '' &&\n !(Array.isArray(v) && v.length === 0) &&\n !(typeof v === 'object' && Object.keys(v).length === 0)\n ? Object.assign(acc, { [k]: v })\n : acc,\n {} as T,\n );\n}\n","import { difference } from 'lodash-es';\nimport fastGlob from 'fast-glob';\nimport { execSync } from 'child_process';\n\n/**\n * Function thats gets the git files that have changed\n * and returns the code\n *\n * @param options - Options\n * @returns Changes files and diffs\n */\nexport function getGitFilesThatChanged({\n baseBranch,\n rootDirectory,\n githubRepo,\n excludedGlob = [],\n fileBlockList = [],\n}: {\n /** Base branch */\n baseBranch: string;\n /** Github repo name */\n githubRepo: string;\n /** Root directory */\n rootDirectory: string;\n /** A glob that excludes files */\n excludedGlob?: string[];\n /** Block list of files to not process */\n fileBlockList?: string[];\n}): {\n /** The list of files that changed */\n changedFiles: string[];\n /** Github repo name */\n repoName: string;\n /** Current commit */\n commit: string;\n /** File diffs */\n fileDiffs: { [k in string]: string };\n} {\n // Pull base branch\n execSync(`git fetch origin ${baseBranch}`);\n\n // Latest commit on base branch. If we are on the base branch, we take the prior commit\n const latestBasedCommit = execSync(\n `git ls-remote ${githubRepo} \"refs/heads/${baseBranch}\" | cut -f 1`,\n { encoding: 'utf-8' },\n ).split('\\n')[0];\n\n // This commit\n const latestThisCommit = execSync('git rev-parse HEAD', {\n encoding: 'utf-8',\n }).split('\\n')[0];\n\n // Ensure commits are present\n if (!latestBasedCommit || !latestThisCommit) {\n throw new Error('FAILED TO FIND COMMIT RANGE');\n }\n\n // Get the diff between the given branch and base branch\n const diff = execSync(\n `git fetch && git diff --name-only \"${\n baseBranch || latestBasedCommit\n }...${latestThisCommit}\" -- ${rootDirectory}`,\n { encoding: 'utf-8' },\n );\n\n // Filter out block list\n const changedFiles = difference(\n diff.split('\\n').filter((f) => f),\n fileBlockList,\n );\n\n // Filter out globs\n const filteredChanges =\n excludedGlob.length > 0\n ? fastGlob.sync(changedFiles, { ignore: excludedGlob })\n : changedFiles;\n\n // Get the contents of only the changed files\n const fileDiffs: { [k in string]: string } = {};\n filteredChanges.forEach((file) => {\n const contents = execSync(`git show ${latestThisCommit}:${file}`, {\n encoding: 'utf-8',\n });\n fileDiffs[file] = contents;\n });\n\n // Pull the github repo name\n const repoName = githubRepo.split('/').pop()!.split('.')[0];\n\n return {\n changedFiles,\n fileDiffs,\n repoName,\n commit: latestThisCommit,\n };\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["PAGE_SIZE","PAGE_SIZE"],"sources":["../src/lib/graphql/gqls/promptThread.ts","../src/lib/graphql/gqls/user.ts","../src/lib/graphql/gqls/promptRun.ts","../src/lib/graphql/gqls/largeLanguageModel.ts","../src/lib/graphql/addMessagesToPromptRun.ts","../src/lib/graphql/fetchAllUsers.ts","../src/lib/graphql/fetchPromptThreads.ts","../src/lib/graphql/reportPromptRun.ts","../src/lib/graphql/setResourceAttributes.ts","../src/lib/requests/pullPrivacyRequests.ts","../src/lib/helpers/getErrorStatus.ts","../src/lib/helpers/splitInHalf.ts","../src/lib/helpers/retrySamePromise.ts","../src/lib/helpers/limitRecords.ts","../src/lib/helpers/readSafe.ts","../src/lib/api-keys/listDirectories.ts","../src/lib/graphql/fetchLargeLanguageModels.ts","../src/lib/ai/TranscendPromptManager.ts","../src/lib/ai/removeLinks.ts","../src/lib/ai/filterNullishValuesFromObject.ts","../src/lib/ai/getGitFilesThatChanged.ts"],"sourcesContent":["import { gql } from 'graphql-request';\n\nexport const PROMPT_THREADS = gql`\n query TranscendCliPromptThreads(\n $first: Int!\n $offset: Int!\n $filterBy: PromptThreadFiltersInput!\n ) {\n promptThreads(first: $first, offset: $offset, filterBy: $filterBy) {\n nodes {\n id\n threadId\n slackMessageTs\n slackTeamId\n slackChannelId\n slackChannelName\n }\n }\n }\n`;\n","import { gql } from 'graphql-request';\n\n// TODO: https://transcend.height.app/T-27909 - enable optimizations\n// isExportCsv: true\n// useMaster: false\nexport const USERS = gql`\n query TranscendCliUsers($first: Int!, $offset: Int!, $input: UserFiltersInput) {\n users(\n first: $first\n offset: $offset\n filterBy: $input\n orderBy: [{ field: createdAt, direction: ASC }, { field: name, direction: ASC }]\n ) {\n nodes {\n id\n name\n email\n }\n }\n }\n`;\n","import { gql } from 'graphql-request';\n\nexport const REPORT_PROMPT_RUN = gql`\n mutation TranscendCliReportPromptRun($input: ReportPromptRunInput!) {\n reportPromptRun(input: $input) {\n clientMutationId\n promptRun {\n id\n }\n }\n }\n`;\n\nexport const ADD_MESSAGES_TO_PROMPT_RUN = gql`\n mutation TranscendCliAddMessagesToPromptRun($input: AddMessagesToPromptRunInput!) {\n addMessagesToPromptRun(input: $input) {\n clientMutationId\n promptRun {\n id\n }\n }\n }\n`;\n","import { gql } from 'graphql-request';\n\n// TODO: https://transcend.height.app/T-27909 - enable optimizations\n// isExportCsv: true\n// useMaster: false\nexport const LARGE_LANGUAGE_MODELS = gql`\n query TranscendCliLargeLanguageModels(\n $first: Int!\n $offset: Int!\n $filterBy: LargeLanguageModelFiltersInput\n ) {\n largeLanguageModels(\n first: $first\n orderBy: [\n { field: name, direction: ASC }\n { field: client, direction: ASC }\n { field: isTranscendHosted, direction: ASC }\n ]\n offset: $offset\n filterBy: $filterBy\n ) {\n nodes {\n id\n name\n client\n isTranscendHosted\n }\n }\n }\n`;\n","import { QueueStatus, ChatCompletionRole } from '@transcend-io/privacy-types';\nimport { GraphQLClient } from 'graphql-request';\n\nimport { ADD_MESSAGES_TO_PROMPT_RUN } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\nexport interface AddMessagesToPromptRunInput {\n /** ID of run */\n promptRunId:\n | {\n /** Report by prompt run name */\n name: string;\n /** Don't report by ID */\n id?: undefined;\n }\n | {\n /** Don't report by name */\n name?: undefined;\n /** Report by prompt run ID */\n id: string;\n };\n /** Messages to report on */\n promptRunMessages?: {\n /** Message reported */\n content: string;\n /** Role of message */\n role: ChatCompletionRole;\n /** Template used if created from prompt */\n template?: string;\n }[];\n /** Error message (if one exists) */\n error?: string;\n /** The status of the run */\n status?: QueueStatus;\n /** Duration of time that it took to execute the prompt */\n duration?: number;\n}\n\n/**\n * Record a new prompt run\n *\n * @param client - GraphQL client\n * @param input - Prompt input\n * @returns Prompt ID\n */\nexport async function addMessagesToPromptRun(\n client: GraphQLClient,\n { promptRunId, promptRunMessages = [], ...rest }: AddMessagesToPromptRunInput,\n): Promise<string> {\n const {\n addMessagesToPromptRun: { promptRun },\n } = await makeGraphQLRequest<{\n /** addMessagesToPromptRun mutation */\n addMessagesToPromptRun: {\n /** Prompt */\n promptRun: {\n /** ID */\n id: string;\n };\n };\n }>(client, ADD_MESSAGES_TO_PROMPT_RUN, {\n input: {\n ...rest,\n ...promptRunId,\n promptRunMessages: promptRunMessages.map(({ content, ...rest }) => ({\n ...rest,\n message: content,\n })),\n },\n });\n return promptRun.id;\n}\n","import { GraphQLClient } from 'graphql-request';\n\nimport { USERS } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\nexport interface User {\n /** ID of user */\n id: string;\n /** Name of user */\n name: string;\n /** Email of user */\n email: string;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all users in the organization\n *\n * @param client - GraphQL client\n * @returns All users in the organization\n */\nexport async function fetchAllUsers(client: GraphQLClient): Promise<User[]> {\n const users: User[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n users: { nodes },\n } = await makeGraphQLRequest<{\n /** Users */\n users: {\n /** List */\n nodes: User[];\n };\n }>(client, USERS, {\n first: PAGE_SIZE,\n offset,\n });\n users.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return users.sort((a, b) => a.email.localeCompare(b.email));\n}\n","import { GraphQLClient } from 'graphql-request';\n\nimport { PROMPT_THREADS } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\nexport interface PromptThread {\n /** ID of prompts */\n id: string;\n /** Thread ID from API */\n threadId: string;\n /** Related slack message TS */\n slackMessageTs?: string;\n /** Related slack message team ID */\n slackTeamId?: string;\n /** Related slack channel ID */\n slackChannelId?: string;\n /** Related slack channel name */\n slackChannelName?: string;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all PromptThreads in the organization\n *\n * @param client - GraphQL client\n * @param filterBy - Filter options\n * @returns All PromptThreads in the organization\n */\nexport async function fetchAllPromptThreads(\n client: GraphQLClient,\n filterBy: {\n /** Thread IDs to filter on */\n threadIds?: string[];\n /** Slack message timestamps to filter on */\n slackMessageTs?: string[];\n },\n): Promise<PromptThread[]> {\n const promptThreads: PromptThread[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n promptThreads: { nodes },\n } = await makeGraphQLRequest<{\n /** PromptThreads */\n promptThreads: {\n /** List */\n nodes: PromptThread[];\n };\n }>(client, PROMPT_THREADS, {\n first: PAGE_SIZE,\n offset,\n filterBy,\n });\n promptThreads.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return promptThreads.sort((a, b) => a.threadId.localeCompare(b.threadId));\n}\n","import {\n QueueStatus,\n ChatCompletionRole,\n PromptRunProductArea,\n LargeLanguageModelClient,\n} from '@transcend-io/privacy-types';\nimport { GraphQLClient } from 'graphql-request';\n\nimport { REPORT_PROMPT_RUN } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\nexport interface ReportPromptRunInput {\n /** Name of run */\n name: string;\n /** The related product area being uploaded to */\n productArea: PromptRunProductArea;\n /** Messages reported on */\n promptRunMessages: {\n /** Message reported */\n content: string;\n /** Role of message */\n role: ChatCompletionRole;\n /** Template used if created from prompt */\n template?: string;\n }[];\n /** ID of the Transcend prompt being reported */\n promptId?: string;\n /** Title of the prompt being reported on */\n promptTitle?: string;\n /** Error message (if one exists) */\n error?: string;\n /** The status of the run */\n status?: QueueStatus;\n /** Employee email that is executing the request */\n runByEmployeeEmail?: string;\n /** Duration of time that it took to execute the prompt */\n duration?: number;\n /** Temperature used when running prompt */\n temperature?: number;\n /** TopP parameter used when running prompt */\n topP?: number;\n /** Max tokens ot sample parameter used when running prompt */\n maxTokensToSample?: number;\n /** The ID of the prompt group being reported */\n promptGroupId?: string;\n /** The title of the prompt group being reported */\n promptGroupTitle?: string;\n /** The LLM Id being reported on */\n largeLanguageModelId?: string;\n /** The name of the large language model being reported on */\n largeLanguageModelName?: string;\n /** The name of the large language model client reported on */\n largeLanguageModelClient?: LargeLanguageModelClient;\n /** ID of the application calling pathfinder */\n applicationId?: string;\n /** Name of the application calling pathfinder */\n applicationName?: string;\n /** Name of the code package calling pathfinder */\n codePackageName?: string;\n /** Name of the repository calling pathfinder */\n repositoryName?: string;\n /** ID of the pathfinder applying policies */\n pathfinderId?: string;\n /** Name of the pathfinder applying policies */\n pathfinderName?: string;\n /** Core identifier of the application user being reported on */\n applicationUserCoreIdentifier?: string;\n /** Name of the application user being reported on */\n applicationUserName?: string;\n}\n\n/**\n * Record a new prompt run\n *\n * @param client - GraphQL client\n * @param input - Prompt input\n * @returns Prompt ID\n */\nexport async function reportPromptRun(\n client: GraphQLClient,\n input: ReportPromptRunInput,\n): Promise<string> {\n const {\n reportPromptRun: { promptRun },\n } = await makeGraphQLRequest<{\n /** reportPromptRun mutation */\n reportPromptRun: {\n /** Prompt */\n promptRun: {\n /** ID */\n id: string;\n };\n };\n }>(client, REPORT_PROMPT_RUN, {\n input: {\n ...input,\n promptRunMessages: input.promptRunMessages.map(({ content, ...rest }) => ({\n ...rest,\n message: content,\n })),\n },\n });\n return promptRun.id;\n}\n","import { AttributeSupportedResourceType } from '@transcend-io/privacy-types';\nimport { GraphQLClient } from 'graphql-request';\n\nimport { SET_RESOURCE_ATTRIBUTES } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\ninterface SetResourceAttributesInput {\n /** ID of resource */\n resourceId: string;\n /** Type of resource */\n resourceType: AttributeSupportedResourceType;\n /** Attribute key ID */\n attributeKeyId: string;\n /** Attribute values by ID */\n attributeValueIds?: string[];\n /** Attribute values by name */\n attributeValueNames?: string[];\n}\n\n/**\n * Set attribute values on a particular resource\n *\n * @param client - GraphQL client\n * @param input - Input\n */\nexport async function setResourceAttributes(\n client: GraphQLClient,\n input: SetResourceAttributesInput,\n): Promise<void> {\n await makeGraphQLRequest(client, SET_RESOURCE_ATTRIBUTES, {\n input,\n });\n}\n","import { RequestAction, RequestStatus } from '@transcend-io/privacy-types';\nimport colors from 'colors';\n\nimport { DEFAULT_TRANSCEND_API } from '../../constants.js';\nimport { logger } from '../../logger.js';\nimport { map } from '../bluebird.js';\nimport {\n RequestIdentifier,\n buildTranscendGraphQLClient,\n createSombraGotInstance,\n fetchAllRequestIdentifiers,\n fetchAllRequests,\n validateSombraVersion,\n} from '../graphql/index.js';\nimport { formatRequestForCsv, CsvRow, ExportedPrivacyRequest } from './formatRequestForCsv.js';\n\n/**\n * Split a date range into N evenly-spaced chunks.\n *\n * @param after - Start of the date range\n * @param before - End of the date range\n * @param chunks - Number of chunks to split into\n * @returns Array of date range bounds\n */\nfunction splitDateRange(\n after: Date,\n before: Date,\n chunks: number,\n): {\n /** Chunk start */ createdAtAfter: Date;\n /** Chunk end */ createdAtBefore: Date;\n}[] {\n const /** Range start ms */ start = after.getTime();\n const /** Range end ms */ end = before.getTime();\n const /** Ms per chunk */ chunkSize = (end - start) / chunks;\n return Array.from({ length: chunks }, (_, i) => ({\n createdAtAfter: new Date(start + chunkSize * i),\n createdAtBefore: new Date(i === chunks - 1 ? end : start + chunkSize * (i + 1)),\n }));\n}\n\n/**\n * Pull down a list of privacy requests\n *\n * @param options - Options\n * @returns The requests with request identifiers and requests formatted for CSV\n */\nexport async function pullPrivacyRequests({\n auth,\n sombraAuth,\n actions = [],\n statuses = [],\n identifierSearch,\n pageLimit = 100,\n concurrency = 1,\n transcendUrl = DEFAULT_TRANSCEND_API,\n createdAtBefore,\n skipRequestIdentifiers = false,\n createdAtAfter,\n updatedAtBefore,\n updatedAtAfter,\n isTest,\n}: {\n /** Transcend API key authentication */\n auth: string;\n /** Search for a specific identifier */\n identifierSearch?: string;\n /** Sombra API key authentication */\n sombraAuth?: string;\n /** API URL for Transcend backend */\n transcendUrl?: string;\n /** Statuses to filter on */\n statuses?: RequestStatus[];\n /** The request action to fetch */\n actions?: RequestAction[];\n /** Page limit when fetching requests */\n pageLimit?: number;\n /** Number of parallel date-range chunks */\n concurrency?: number;\n /** Filter for requests created before this date */\n createdAtBefore?: Date;\n /** Filter for requests created after this date */\n createdAtAfter?: Date;\n /** Filter for requests updated before this date */\n updatedAtBefore?: Date;\n /** Filter for requests updated after this date */\n updatedAtAfter?: Date;\n /** Return test requests */\n isTest?: boolean;\n /** Skip fetching request identifier */\n skipRequestIdentifiers?: boolean;\n}): Promise<{\n /** All request information with attached identifiers */\n requestsWithRequestIdentifiers: ExportedPrivacyRequest[];\n /** Requests that are formatted for CSV */\n requestsFormattedForCsv: CsvRow[];\n}> {\n const client = buildTranscendGraphQLClient(transcendUrl, auth);\n const sombra = await createSombraGotInstance(transcendUrl, auth, sombraAuth);\n\n // Log date range\n let dateRange = '';\n if (createdAtBefore) {\n dateRange += ` before ${createdAtBefore.toISOString()}`;\n }\n if (createdAtAfter) {\n dateRange += `${dateRange ? ', and' : ''} after ${createdAtAfter.toISOString()}`;\n }\n logger.info(\n colors.magenta(\n `${\n actions.length > 0\n ? `Pulling requests of type \"${actions.join('\" , \"')}\"`\n : 'Pulling all requests'\n }${dateRange}`,\n ),\n );\n\n // Split into parallel date-range chunks when possible\n const useChunks = concurrency > 1 && createdAtAfter && createdAtBefore;\n const chunks = useChunks\n ? splitDateRange(createdAtAfter, createdAtBefore, concurrency)\n : [{ createdAtAfter, createdAtBefore }];\n\n if (useChunks) {\n logger.info(colors.magenta(`Splitting date range into ${concurrency} parallel chunks`));\n }\n\n // Fetch requests across all chunks in parallel\n const chunkResults = await map(\n chunks,\n (chunk) =>\n fetchAllRequests(client, {\n actions,\n text: identifierSearch,\n statuses,\n createdAtBefore: chunk.createdAtBefore,\n createdAtAfter: chunk.createdAtAfter,\n updatedAtBefore,\n updatedAtAfter,\n isTest,\n }),\n { concurrency: useChunks ? concurrency : 1 },\n );\n const requests = chunkResults.flat();\n\n // Validate Sombra version once before bulk-fetching identifiers\n if (!skipRequestIdentifiers) {\n await validateSombraVersion(client);\n }\n\n // Fetch the request identifiers for those requests\n const requestsWithRequestIdentifiers = skipRequestIdentifiers\n ? requests.map((request) => ({\n ...request,\n requestIdentifiers: [] as RequestIdentifier[],\n }))\n : await map(\n requests,\n async (request) => {\n const requestIdentifiers = await fetchAllRequestIdentifiers(client, sombra, {\n requestId: request.id,\n skipSombraCheck: true,\n });\n return {\n ...request,\n requestIdentifiers,\n };\n },\n {\n concurrency: pageLimit,\n },\n );\n\n logger.info(colors.magenta(`Pulled ${requestsWithRequestIdentifiers.length} requests`));\n\n const data = requestsWithRequestIdentifiers.map(formatRequestForCsv);\n\n return { requestsWithRequestIdentifiers, requestsFormattedForCsv: data };\n}\n","/**\n * Extract an HTTP status code from a thrown error (got compatible).\n *\n * @param err - Unknown error thrown by network call\n * @returns HTTP status code, if present\n */\nexport function getErrorStatus(err: unknown): number | undefined {\n // Swallow unknowns carefully—never throw from an error handler.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const anyErr = err as any;\n return anyErr?.response?.statusCode ?? anyErr?.response?.status;\n}\n","/**\n * Split an array roughly in half. Stable for even/odd lengths.\n *\n * @param entries - Items to split\n * @returns A tuple [left, right] halves\n */\nexport function splitInHalf<T>(entries: T[]): [T[], T[]] {\n const mid = Math.floor(entries.length / 2);\n return [entries.slice(0, mid), entries.slice(mid)];\n}\n","import { extractErrorMessage } from './extractErrorMessage.js';\nimport { getErrorStatus } from './getErrorStatus.js';\nimport { sleepPromise } from './sleepPromise.js';\n\nexport interface RetryPolicy {\n /** Maximum retry attempts (not counting the initial try) */\n maxAttempts: number;\n /** Fixed delay between attempts in milliseconds */\n delayMs: number;\n /**\n * Decide whether a given error should be retried.\n *\n * @param status - HTTP status code (if known)\n * @param message - Extracted error message (if known)\n */\n shouldRetry(status?: number, message?: string): boolean;\n}\n\n/**\n * Retry a single async operation according to the provided policy.\n * The operation is executed once initially, then up to `maxAttempts` retries.\n *\n * @param op - Operation to run\n * @param policy - Retry policy\n * @param onBackoff - Observer called before each retry (for logging/metrics)\n * @returns Result of the operation if it eventually succeeds\n * @throws The last error encountered if all retries fail\n */\nexport async function retrySamePromise<T>(\n op: () => Promise<T>,\n policy: RetryPolicy,\n onBackoff: (note: string) => void,\n): Promise<T> {\n let attempt = 0;\n\n // eslint-disable-next-line no-constant-condition\n while (true) {\n try {\n // First pass and any subsequent retries run the same op.\n return await op();\n } catch (err) {\n attempt += 1;\n\n // Use shared helpers for status + human-readable message extraction\n const status = getErrorStatus(err);\n const msg = extractErrorMessage(err);\n\n const canRetry = attempt <= policy.maxAttempts && policy.shouldRetry(status, msg);\n\n if (!canRetry) {\n // Surface the final error to the caller, which may then split/fail.\n throw err;\n }\n\n onBackoff(\n `Retrying after status=${status} attempt=${attempt}/${policy.maxAttempts} — ${msg}`,\n );\n await sleepPromise(policy.delayMs);\n // Loop to retry\n }\n }\n}\n","/**\n * Limits the number of records in the returned object to a maximum.\n * For entries beyond the max, sets their value to `true`.\n *\n * @param obj - Object\n * @param max - Maximum number of entries to retain original value.\n * @returns Object with keys mapped to their value or `true` if over the limit.\n */\nexport function limitRecords<T>(obj: Record<string, T>, max: number): Record<string, T | true> {\n return Object.entries(obj).reduce(\n (acc, [userId, value], i) => {\n acc[userId] = i < max ? value : true;\n return acc;\n },\n {} as Record<string, T | true>,\n );\n}\n","import { readFileSync } from 'node:fs';\n\n/**\n * Safely reads the contents of a file as a UTF-8 string.\n * Returns an empty string if the path is not provided or if reading fails.\n *\n * @param p - The path to the file to read.\n * @returns The file contents as a string, or an empty string on error.\n */\nexport function readSafe(p?: string): string {\n try {\n return p ? readFileSync(p, 'utf8') : '';\n } catch {\n return '';\n }\n}\n","import { readdirSync, statSync } from 'node:fs';\nimport { join } from 'node:path';\n\n/**\n * List the folders in a directory\n *\n * @param startDir - The base directory to list from\n * @returns The list of folders in that directory\n */\nexport function listDirectories(startDir: string): string[] {\n return readdirSync(startDir).filter((entryName) =>\n statSync(join(startDir, entryName)).isDirectory(),\n );\n}\n","import { LargeLanguageModelClient } from '@transcend-io/privacy-types';\nimport { GraphQLClient } from 'graphql-request';\n\nimport { LARGE_LANGUAGE_MODELS } from './gqls/index.js';\nimport { makeGraphQLRequest } from './makeGraphQLRequest.js';\n\nexport interface LargeLanguageModel {\n /** ID of prompts */\n id: string;\n /** The name of the large language model. */\n name: string;\n /** The content of the prompt template. */\n client: LargeLanguageModelClient;\n /** Whether hosted by Transcend or not */\n isTranscendHosted: boolean;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all LargeLanguageModels in the organization\n *\n * @param client - GraphQL client\n * @returns All LargeLanguageModels in the organization\n */\nexport async function fetchAllLargeLanguageModels(\n client: GraphQLClient,\n): Promise<LargeLanguageModel[]> {\n const largeLanguageModels: LargeLanguageModel[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n largeLanguageModels: { nodes },\n } = await makeGraphQLRequest<{\n /** LargeLanguageModels */\n largeLanguageModels: {\n /** List */\n nodes: LargeLanguageModel[];\n };\n }>(client, LARGE_LANGUAGE_MODELS, {\n first: PAGE_SIZE,\n offset,\n });\n largeLanguageModels.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return largeLanguageModels.sort((a, b) => a.name.localeCompare(b.name));\n}\n","import type { Handlebars } from '@transcend-io/handlebars-utils';\nimport { HandlebarsInput, createHandlebarsWithHelpers } from '@transcend-io/handlebars-utils';\nimport {\n PromptStatus,\n ChatCompletionRole,\n PromptRunProductArea,\n QueueStatus,\n LargeLanguageModelClient,\n} from '@transcend-io/privacy-types';\nimport { Secret } from '@transcend-io/secret-value';\n/* eslint-disable max-lines */\nimport { Optionalize, Requirize, apply, decodeCodec, getValues } from '@transcend-io/type-utils';\nimport { GraphQLClient } from 'graphql-request';\nimport * as t from 'io-ts';\nimport { groupBy, keyBy, uniq, chunk } from 'lodash-es';\n\nimport { DEFAULT_TRANSCEND_API } from '../../constants.js';\nimport { mapSeries } from '../bluebird.js';\nimport {\n LargeLanguageModel,\n fetchAllLargeLanguageModels,\n} from '../graphql/fetchLargeLanguageModels.js';\nimport {\n TranscendPromptTemplated,\n TranscendPromptsAndVariables,\n fetchPromptsWithVariables,\n} from '../graphql/fetchPrompts.js';\nimport { PromptThread, fetchAllPromptThreads } from '../graphql/fetchPromptThreads.js';\nimport {\n Agent,\n AgentFile,\n AgentFileFilterBy,\n ReportPromptRunInput,\n buildTranscendGraphQLClient,\n fetchAllAgentFiles,\n fetchAllAgents,\n reportPromptRun,\n} from '../graphql/index.js';\n\n/**\n * An LLM Prompt definition\n */\nexport type TranscendPrompt<TInputParams extends t.Any, TOutputCodec extends t.Any> = (\n | {\n /** ID of the prompt */\n id: string;\n /** Title of the prompt */\n title?: string;\n }\n | {\n /** ID of the prompt */\n id?: string;\n /** Title of the prompt */\n title: string;\n }\n) & {\n /** The names of the agents that should be loaded along with the prompt */\n agentNames?: string[];\n /** Codec to validate runtime input shape */\n paramCodec: TInputParams;\n /** Codec to validate output response */\n outputCodec: TOutputCodec;\n /**\n * If the output that needs to be parsed is returned within a tag\n * e.g. <tag> or <json> - this is the name of the tag\n */\n extractFromTag?: string;\n};\n\nexport interface PromptRunResult {\n /** The ID of the prompt run created on Transcend */\n promptRunId: string;\n /** The URL of the prompt run on Transcend */\n promptRunUrl: string;\n}\n\n/**\n * Create a regex to extract data from a tag\n *\n * Input:\n * \"here is some data <tag>Data</tag>...\"\n *\n * @param tagName - Name of tag\n * @returns Data within the tag\n */\nexport function createRegexForTag(tagName: string): RegExp {\n return new RegExp(`<${tagName}>([\\\\s\\\\S]+?)<\\\\/${tagName}>`);\n}\n\n/**\n * Helper function to declare prompts\n *\n * @param prompts - Prompt config\n * @returns Prompts as identity function - but type enforced\n */\nexport function defineTranscendPrompts<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n>(prompts: TPrompts): TPrompts {\n return prompts;\n}\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptParamType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['paramCodec']>;\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptResponseType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n\n/**\n * Input for reporting a prompt run\n */\nexport interface ReportPromptRunOptions extends Optionalize<\n Omit<ReportPromptRunInput, 'status' | 'promptId' | 'largeLanguageModelId'>,\n 'name' | 'productArea'\n> {\n /** The large language model being run. Either the ID of the LLM or the client/name pairing */\n largeLanguageModel:\n | string\n | {\n /** Name of client */\n client: LargeLanguageModelClient;\n /** Name of the model */\n name: string;\n };\n}\n\nconst jsonParseSafe = (obj: string): unknown => {\n try {\n return JSON.parse(obj);\n } catch (e) {\n return obj;\n }\n};\n\n/**\n * A class that is capable of loading and insert variables into prompts from\n * Transcend's Prompt Manager\n */\nexport class TranscendPromptManager<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n> {\n /** Prompt definitions */\n public prompts: TPrompts;\n\n /** Options for configuring handlebars */\n public handlebarsOptions!: HandlebarsInput;\n\n /** Prompt name -> content map, populated by call to Transcend API */\n public promptContentMap?: { [k in TPromptNames]: TranscendPromptTemplated };\n\n /** The large language models that are registered to this organization for reporting */\n public largeLanguageModels: LargeLanguageModel[] = [];\n\n /** The agent definitions registered to this organization */\n private agentsByName: { [name in string]: Agent } = {};\n\n /** The agent definitions registered to this organization */\n private agentsByAgentId: { [id in string]: Agent } = {};\n\n /** The GraphQL client that can be used to call Transcend */\n public graphQLClient: GraphQLClient;\n\n /** The set of variables to expose in handlebars context specified at class initiation */\n public defaultVariables: { [k in string]: unknown };\n\n /**\n * The set of variables to expose in handlebars context,\n * merges defaults with calculated variables from the inventory\n */\n public variables: { [k in string]: unknown };\n\n /** Handlebars compiler */\n public handlebars: typeof Handlebars;\n\n /** The Transcend API key */\n public transcendApiKey: string | Secret<string>;\n\n /** API of Transcend to call */\n public transcendUrl: string;\n\n /** When true, throw an error if the prompt is not approved */\n public requireApproval: boolean;\n\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n public cacheDuration?: number;\n\n /**\n * The last time the metadata was fetched\n */\n public lastUpdatedAt?: Date;\n\n /**\n * Constructor\n *\n * @param options - Options\n */\n constructor({\n prompts,\n handlebarsOptions = {},\n transcendUrl = DEFAULT_TRANSCEND_API,\n transcendApiKey,\n requireApproval = true,\n cacheDuration,\n defaultVariables = {},\n }: {\n /** Prompt definitions to load */\n prompts: TPrompts;\n /** Options for configuring handlebars */\n handlebarsOptions?: HandlebarsInput;\n /** The Transcend API key */\n transcendApiKey: string | Secret<string>;\n /** API of Transcend to call */\n transcendUrl?: string;\n /** When true, throw an error if the prompt is not approved */\n requireApproval?: boolean;\n /** The set of variables to expose in handlebars context specified at class initiation */\n defaultVariables?: { [k in string]: unknown };\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n cacheDuration?: number;\n }) {\n this.prompts = prompts;\n this.transcendUrl = transcendUrl;\n this.transcendApiKey = transcendApiKey;\n this.variables = defaultVariables;\n this.defaultVariables = defaultVariables;\n this.graphQLClient = buildTranscendGraphQLClient(\n transcendUrl,\n typeof transcendApiKey === 'object' ? transcendApiKey.release() : transcendApiKey,\n );\n this.requireApproval = requireApproval;\n this.cacheDuration = cacheDuration;\n this.handlebarsOptions = handlebarsOptions;\n this.handlebars = createHandlebarsWithHelpers(handlebarsOptions);\n }\n\n /**\n * Fetch prompt metadata from Transcend and cache to the class definition\n *\n * @returns A function that can be used to call the prompt\n */\n async fetchPromptsAndMetadata(): Promise<TranscendPromptsAndVariables> {\n // Determine what to fetch\n const promptDefinitions = getValues(this.prompts) as TranscendPrompt<t.Any, t.Any>[];\n const promptIds = promptDefinitions.map(({ id }) => id).filter((x): x is string => !!x);\n const promptTitles = promptDefinitions\n .map(({ title }) => title)\n .filter((x): x is string => !!x);\n const agentNames = uniq(promptDefinitions.map(({ agentNames }) => agentNames || []).flat());\n\n // Fetch prompts and data\n const [response, largeLanguageModels, agents] = await Promise.all([\n fetchPromptsWithVariables(this.graphQLClient, {\n promptIds,\n promptTitles,\n }),\n fetchAllLargeLanguageModels(this.graphQLClient),\n fetchAllAgents(this.graphQLClient, { names: agentNames }),\n ]);\n this.agentsByName = keyBy(agents, 'name');\n this.agentsByAgentId = keyBy(agents, 'agentId');\n this.largeLanguageModels = largeLanguageModels.filter(\n (model) => model.isTranscendHosted === false,\n );\n\n // Lookup prompts by id/title\n const promptByTitle = keyBy(response.prompts, 'title');\n const promptById = keyBy(response.prompts, 'id');\n\n // Update variables\n this.variables = {\n ...response.calculatedVariables.reduce(\n (acc, v) =>\n Object.assign(acc, {\n [v.name]: v.data ? JSON.parse(v.data) : v.data,\n }),\n {},\n ),\n ...this.defaultVariables,\n };\n\n // Update partials\n this.handlebars = createHandlebarsWithHelpers({\n ...this.handlebarsOptions,\n templates: [\n ...(this.handlebarsOptions.templates || []),\n ...response.promptPartials.map((partial) => ({\n name: partial.slug,\n content: partial.content,\n })),\n ],\n });\n\n // Create mapping from prompt to content\n this.promptContentMap = apply(this.prompts, ({ id, title }) => {\n const result = id ? promptById[id] : title ? promptByTitle[title] : undefined;\n if (!result) {\n throw new Error(`Failed to find prompt with title: \"${title}\" and id: \"${id}\"`);\n }\n return result;\n });\n\n // For cache\n this.lastUpdatedAt = new Date();\n\n return response;\n }\n\n /**\n * Get an agent definition by name\n *\n * @param name - Name of the agent to grab\n * @returns Large language model configuration\n */\n async getAgentByName(name: string): Promise<Agent | undefined> {\n const agent = this.agentsByName[name];\n if (agent) {\n return agent;\n }\n const [remoteAgent] = await fetchAllAgents(this.graphQLClient, {\n names: [name],\n });\n if (!remoteAgent) {\n return undefined;\n }\n this.agentsByName[remoteAgent.name] = remoteAgent;\n this.agentsByAgentId[remoteAgent.agentId] = remoteAgent;\n return remoteAgent;\n }\n\n /**\n * Get a prompt thread by ts\n *\n * @param ts - the slack message timestamp to look up thread for\n * @returns Large language model configuration\n */\n async getPromptThreadBySlackTs(ts: string): Promise<PromptThread | undefined> {\n const [thread] = await fetchAllPromptThreads(this.graphQLClient, {\n slackMessageTs: [ts],\n });\n return thread;\n }\n\n /**\n * Get a list of agent definitions by name.\n * Pulls from cache and may return less agents\n * than requested if some are not found\n *\n * @param names - Names of agents to fetch\n * @returns The agents that were found matching the names\n */\n async getAgentsByName(names: string[]): Promise<Agent[]> {\n if (names.length < 1) {\n throw new Error('Expected at least one name to be provided');\n }\n const { hasCache = [], missingCache = [] } = groupBy(names, (name) =>\n this.agentsByName[name] ? 'hasCache' : 'missingCache',\n );\n const cachedAgents = hasCache.map((name) => this.agentsByName[name]);\n if (missingCache.length === 0) {\n return cachedAgents;\n }\n const chunkedNames = chunk(missingCache, 50);\n const remoteAgents: Agent[] = [];\n await mapSeries(chunkedNames, async (chunkedName) => {\n const pageOfAgents = await fetchAllAgents(this.graphQLClient, {\n names: chunkedName,\n });\n pageOfAgents.forEach((agent) => {\n this.agentsByName[agent.name] = agent;\n this.agentsByAgentId[agent.agentId] = agent;\n });\n remoteAgents.push(...pageOfAgents);\n });\n return [...cachedAgents, ...remoteAgents];\n }\n\n /**\n * Fetch metadata on agent files\n *\n * @param filterBy - Filter by parameters\n * @returns The files found matching the filter\n */\n getAgentFiles(filterBy: AgentFileFilterBy): Promise<AgentFile[]> {\n return fetchAllAgentFiles(this.graphQLClient, filterBy);\n }\n\n /**\n * Look up the large language model to report on\n *\n * @param largeLanguageModel - Input\n * @returns Large language model configuration\n */\n getLargeLanguageModel(\n largeLanguageModel: ReportPromptRunOptions['largeLanguageModel'],\n ): LargeLanguageModel {\n const matching = this.largeLanguageModels.find((model) =>\n typeof largeLanguageModel === 'string'\n ? model.id === largeLanguageModel\n : model.name === largeLanguageModel.name && model.client === largeLanguageModel.client,\n );\n if (!matching) {\n throw new Error(\n `Failed to find model matching: ${\n typeof largeLanguageModel === 'string'\n ? largeLanguageModel\n : JSON.stringify(largeLanguageModel)\n }`,\n );\n }\n return matching;\n }\n\n /**\n * Get a prompt definition by name\n *\n * @param promptName - Prompt to compile\n * @returns Parsed content\n */\n async getPromptDefinition<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n ): Promise<TranscendPromptTemplated> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration && Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n // Lookup prompt\n const { promptContentMap } = this;\n if (!promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n const promptTemplate = promptContentMap[promptName];\n if (!promptTemplate) {\n throw new Error(`Expected this.promptContentMap[${promptName}] to be defined`);\n }\n return promptTemplate;\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to compile\n * @param params - Runtime parameters\n * @returns Parsed content\n */\n async compilePrompt<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n params: t.TypeOf<TPrompts[TPromptName]['paramCodec']>,\n ): Promise<string> {\n // Grab the prompt\n const promptTemplate = await this.getPromptDefinition(promptName);\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure prompt is approved\n if (this.requireApproval && promptTemplate.status !== PromptStatus.Approved) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because its in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // If prompt is rejected, throw error\n if (promptTemplate.status === PromptStatus.Rejected) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because it's in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // Validate params\n decodeCodec(promptInput.paramCodec, params);\n\n // Compile prompt and template\n return this.handlebars.compile(promptTemplate.content)({\n // template in currentDate by default\n currentDate: new Date().toISOString(),\n ...this.variables,\n ...params,\n });\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to parse\n * @param response - AI response as string\n * @returns Parsed content\n */\n parseAiResponse<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n response: string,\n ): t.TypeOf<TPrompts[TPromptName]['outputCodec']> {\n // Look up prompt info\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Extract from tag if needed\n const extracted = promptInput.extractFromTag\n ? (createRegexForTag(promptInput.extractFromTag).exec(response) || [])[1] || response\n : response;\n\n // Parse via codec\n return decodeCodec(promptInput.outputCodec, jsonParseSafe(extracted), false);\n }\n\n /**\n * Parse the AI response and report back to Transcend\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportAndParsePromptRun<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n { largeLanguageModel, ...options }: ReportPromptRunOptions,\n ): Promise<\n PromptRunResult & {\n /** Resulting prompt run */\n result: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n }\n > {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration && Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name = options.name || `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(`promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`);\n }\n if (\n options.promptRunMessages[options.promptRunMessages.length - 1].role !==\n ChatCompletionRole.Assistant\n ) {\n throw new Error(\n `promptRunMessages[${\n options.promptRunMessages.length - 1\n }].role is expected to be = ${ChatCompletionRole.Assistant}`,\n );\n }\n const response = options.promptRunMessages[options.promptRunMessages.length - 1].content;\n\n let parsed: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n try {\n // Parse the response\n parsed = this.parseAiResponse(promptName, response);\n } catch (err) {\n await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n error: err.message,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n throw err;\n }\n\n // report successful run\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Resolved,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n result: parsed,\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n\n /**\n * Report an error for a particular prompt\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportPromptRunError<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n { largeLanguageModel, ...options }: Requirize<ReportPromptRunOptions, 'error'>,\n ): Promise<PromptRunResult> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration && Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name = options.name || `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(`promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`);\n }\n\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n}\n/* eslint-enable max-lines */\n","/**\n * Remove links from a string\n *\n * @param inputString - String\n * @returns String without links\n */\nexport function removeLinks(inputString: string): string {\n const regex = /(https?:\\/\\/[^\\s]+)/g;\n return inputString.replace(regex, '<link-omitted>');\n}\n","import { ObjByString } from '@transcend-io/type-utils';\n\n/**\n * Given an object, remove all keys that are null-ish\n *\n * @param obj - Object\n * @returns Object with null-ish values removed\n */\nexport function filterNullishValuesFromObject<T extends ObjByString>(obj: T): T {\n return Object.entries(obj).reduce(\n (acc, [k, v]) =>\n v !== null &&\n v !== undefined &&\n v !== '' &&\n !(Array.isArray(v) && v.length === 0) &&\n !(typeof v === 'object' && Object.keys(v).length === 0)\n ? Object.assign(acc, { [k]: v })\n : acc,\n {} as T,\n );\n}\n","import { execSync } from 'child_process';\n\nimport fastGlob from 'fast-glob';\nimport { difference } from 'lodash-es';\n\n/**\n * Function thats gets the git files that have changed\n * and returns the code\n *\n * @param options - Options\n * @returns Changes files and diffs\n */\nexport function getGitFilesThatChanged({\n baseBranch,\n rootDirectory,\n githubRepo,\n excludedGlob = [],\n fileBlockList = [],\n}: {\n /** Base branch */\n baseBranch: string;\n /** Github repo name */\n githubRepo: string;\n /** Root directory */\n rootDirectory: string;\n /** A glob that excludes files */\n excludedGlob?: string[];\n /** Block list of files to not process */\n fileBlockList?: string[];\n}): {\n /** The list of files that changed */\n changedFiles: string[];\n /** Github repo name */\n repoName: string;\n /** Current commit */\n commit: string;\n /** File diffs */\n fileDiffs: { [k in string]: string };\n} {\n // Pull base branch\n execSync(`git fetch origin ${baseBranch}`);\n\n // Latest commit on base branch. If we are on the base branch, we take the prior commit\n const latestBasedCommit = execSync(\n `git ls-remote ${githubRepo} \"refs/heads/${baseBranch}\" | cut -f 1`,\n { encoding: 'utf-8' },\n ).split('\\n')[0];\n\n // This commit\n const latestThisCommit = execSync('git rev-parse HEAD', {\n encoding: 'utf-8',\n }).split('\\n')[0];\n\n // Ensure commits are present\n if (!latestBasedCommit || !latestThisCommit) {\n throw new Error('FAILED TO FIND COMMIT RANGE');\n }\n\n // Get the diff between the given branch and base branch\n const diff = execSync(\n `git fetch && git diff --name-only \"${\n baseBranch || latestBasedCommit\n }...${latestThisCommit}\" -- ${rootDirectory}`,\n { encoding: 'utf-8' },\n );\n\n // Filter out block list\n const changedFiles = difference(\n diff.split('\\n').filter((f) => f),\n fileBlockList,\n );\n\n // Filter out globs\n const filteredChanges =\n excludedGlob.length > 0 ? fastGlob.sync(changedFiles, { ignore: excludedGlob }) : changedFiles;\n\n // Get the contents of only the changed files\n const fileDiffs: { [k in string]: string } = {};\n filteredChanges.forEach((file) => {\n const contents = execSync(`git show ${latestThisCommit}:${file}`, {\n encoding: 'utf-8',\n });\n fileDiffs[file] = contents;\n });\n\n // Pull the github repo name\n const repoName = githubRepo.split('/').pop()!.split('.')[0];\n\n return {\n changedFiles,\n fileDiffs,\n repoName,\n commit: latestThisCommit,\n };\n}\n"],"mappings":"k2QAEA,MAAa,EAAiB,CAAG;;;;;;;;;;;;;;;;;ECGpB,EAAQ,CAAG;;;;;;;;;;;;;;;ECHX,EAAoB,CAAG;;;;;;;;;EAWvB,EAA6B,CAAG;;;;;;;;;ECRhC,EAAwB,CAAG;;;;;;;;;;;;;;;;;;;;;;;;ECwCxC,eAAsB,GACpB,EACA,CAAE,cAAa,oBAAoB,EAAE,CAAE,GAAG,GACzB,CACjB,GAAM,CACJ,uBAAwB,CAAE,cACxB,MAAM,EASP,EAAQ,EAA4B,CACrC,MAAO,CACL,GAAG,EACH,GAAG,EACH,kBAAmB,EAAkB,KAAK,CAAE,UAAS,GAAG,MAAY,CAClE,GAAG,EACH,QAAS,EACV,EAAE,CACJ,CACF,CAAC,CACF,OAAO,EAAU,GChDnB,eAAsB,GAAc,EAAwC,CAC1E,IAAM,EAAgB,EAAE,CACpB,EAAS,EAGT,EAAiB,GACrB,EAAG,CACD,GAAM,CACJ,MAAO,CAAE,UACP,MAAM,EAMP,EAAQ,EAAO,CAChB,MAAOA,GACP,SACD,CAAC,CACF,EAAM,KAAK,GAAG,EAAM,CACpB,GAAUA,GACV,EAAiB,EAAM,SAAWA,SAC3B,GAET,OAAO,EAAM,MAAM,EAAG,IAAM,EAAE,MAAM,cAAc,EAAE,MAAM,CAAC,CCjB7D,eAAsB,EACpB,EACA,EAMyB,CACzB,IAAM,EAAgC,EAAE,CACpC,EAAS,EAGT,EAAiB,GACrB,EAAG,CACD,GAAM,CACJ,cAAe,CAAE,UACf,MAAM,EAMP,EAAQ,EAAgB,CACzB,MAAOC,GACP,SACA,WACD,CAAC,CACF,EAAc,KAAK,GAAG,EAAM,CAC5B,GAAUA,GACV,EAAiB,EAAM,SAAWA,SAC3B,GAET,OAAO,EAAc,MAAM,EAAG,IAAM,EAAE,SAAS,cAAc,EAAE,SAAS,CAAC,CCgB3E,eAAsB,EACpB,EACA,EACiB,CACjB,GAAM,CACJ,gBAAiB,CAAE,cACjB,MAAM,EASP,EAAQ,EAAmB,CAC5B,MAAO,CACL,GAAG,EACH,kBAAmB,EAAM,kBAAkB,KAAK,CAAE,UAAS,GAAG,MAAY,CACxE,GAAG,EACH,QAAS,EACV,EAAE,CACJ,CACF,CAAC,CACF,OAAO,EAAU,GC7EnB,eAAsB,GACpB,EACA,EACe,CACf,MAAM,EAAmB,EAAQ,EAAyB,CACxD,QACD,CAAC,CCPJ,SAAS,GACP,EACA,EACA,EAIE,CACF,IAA4B,EAAQ,EAAM,SAAS,CACzB,EAAM,EAAO,SAAS,CACtB,GAAa,EAAM,GAAS,EACtD,OAAO,MAAM,KAAK,CAAE,OAAQ,EAAQ,EAAG,EAAG,KAAO,CAC/C,eAAgB,IAAI,KAAK,EAAQ,EAAY,EAAE,CAC/C,gBAAiB,IAAI,KAAK,IAAM,EAAS,EAAI,EAAM,EAAQ,GAAa,EAAI,GAAG,CAChF,EAAE,CASL,eAAsB,GAAoB,CACxC,OACA,aACA,UAAU,EAAE,CACZ,WAAW,EAAE,CACb,mBACA,YAAY,IACZ,cAAc,EACd,eAAe,EACf,kBACA,yBAAyB,GACzB,iBACA,kBACA,iBACA,UAmCC,CACD,IAAM,EAAS,EAA4B,EAAc,EAAK,CACxD,EAAS,MAAM,EAAwB,EAAc,EAAM,EAAW,CAGxE,EAAY,GACZ,IACF,GAAa,WAAW,EAAgB,aAAa,IAEnD,IACF,GAAa,GAAG,EAAY,QAAU,GAAG,SAAS,EAAe,aAAa,IAEhF,EAAO,KACL,EAAO,QACL,GACE,EAAQ,OAAS,EACb,6BAA6B,EAAQ,KAAK,QAAQ,CAAC,GACnD,yBACH,IACJ,CACF,CAGD,IAAM,EAAY,EAAc,GAAK,GAAkB,EACjD,EAAS,EACX,GAAe,EAAgB,EAAiB,EAAY,CAC5D,CAAC,CAAE,iBAAgB,kBAAiB,CAAC,CAErC,GACF,EAAO,KAAK,EAAO,QAAQ,6BAA6B,EAAY,kBAAkB,CAAC,CAmBzF,IAAM,GAfe,MAAM,EACzB,EACC,GACC,EAAiB,EAAQ,CACvB,UACA,KAAM,EACN,WACA,gBAAiB,EAAM,gBACvB,eAAgB,EAAM,eACtB,kBACA,iBACA,SACD,CAAC,CACJ,CAAE,YAAa,EAAY,EAAc,EAAG,CAC7C,EAC6B,MAAM,CAG/B,GACH,MAAM,EAAsB,EAAO,CAIrC,IAAM,EAAiC,EACnC,EAAS,IAAK,IAAa,CACzB,GAAG,EACH,mBAAoB,EAAE,CACvB,EAAE,CACH,MAAM,EACJ,EACA,KAAO,IAAY,CACjB,IAAM,EAAqB,MAAM,EAA2B,EAAQ,EAAQ,CAC1E,UAAW,EAAQ,GACnB,gBAAiB,GAClB,CAAC,CACF,MAAO,CACL,GAAG,EACH,qBACD,EAEH,CACE,YAAa,EACd,CACF,CAML,OAJA,EAAO,KAAK,EAAO,QAAQ,UAAU,EAA+B,OAAO,WAAW,CAAC,CAIhF,CAAE,iCAAgC,wBAF5B,EAA+B,IAAI,EAAoB,CAEI,CC5K1E,SAAgB,GAAe,EAAkC,CAG/D,IAAM,EAAS,EACf,OAAO,GAAQ,UAAU,YAAc,GAAQ,UAAU,OCJ3D,SAAgB,GAAe,EAA0B,CACvD,IAAM,EAAM,KAAK,MAAM,EAAQ,OAAS,EAAE,CAC1C,MAAO,CAAC,EAAQ,MAAM,EAAG,EAAI,CAAE,EAAQ,MAAM,EAAI,CAAC,CCoBpD,eAAsB,GACpB,EACA,EACA,EACY,CACZ,IAAI,EAAU,EAGd,OACE,GAAI,CAEF,OAAO,MAAM,GAAI,OACV,EAAK,CACZ,GAAW,EAGX,IAAM,EAAS,GAAe,EAAI,CAC5B,EAAM,EAAoB,EAAI,CAIpC,GAAI,EAFa,GAAW,EAAO,aAAe,EAAO,YAAY,EAAQ,EAAI,EAI/E,MAAM,EAGR,EACE,yBAAyB,EAAO,WAAW,EAAQ,GAAG,EAAO,YAAY,KAAK,IAC/E,CACD,MAAM,EAAa,EAAO,QAAQ,ECjDxC,SAAgB,GAAgB,EAAwB,EAAuC,CAC7F,OAAO,OAAO,QAAQ,EAAI,CAAC,QACxB,EAAK,CAAC,EAAQ,GAAQ,KACrB,EAAI,GAAU,EAAI,EAAM,EAAQ,GACzB,GAET,EAAE,CACH,CCNH,SAAgB,GAAS,EAAoB,CAC3C,GAAI,CACF,OAAO,EAAI,GAAa,EAAG,OAAO,CAAG,QAC/B,CACN,MAAO,ICJX,SAAgB,GAAgB,EAA4B,CAC1D,OAAO,GAAY,EAAS,CAAC,OAAQ,GACnC,GAAS,GAAK,EAAU,EAAU,CAAC,CAAC,aAAa,CAClD,CCaH,eAAsB,GACpB,EAC+B,CAC/B,IAAM,EAA4C,EAAE,CAChD,EAAS,EAGT,EAAiB,GACrB,EAAG,CACD,GAAM,CACJ,oBAAqB,CAAE,UACrB,MAAM,EAMP,EAAQ,EAAuB,CAChC,MAAO,GACP,SACD,CAAC,CACF,EAAoB,KAAK,GAAG,EAAM,CAClC,GAAU,GACV,EAAiB,EAAM,SAAW,SAC3B,GAET,OAAO,EAAoB,MAAM,EAAG,IAAM,EAAE,KAAK,cAAc,EAAE,KAAK,CAAC,CCkCzE,SAAgB,GAAkB,EAAyB,CACzD,OAAW,OAAO,IAAI,EAAQ,mBAAmB,EAAQ,GAAG,CAS9D,SAAgB,GAGd,EAA6B,CAC7B,OAAO,EAqCT,MAAM,GAAiB,GAAyB,CAC9C,GAAI,CACF,OAAO,KAAK,MAAM,EAAI,MACZ,CACV,OAAO,IAQX,IAAa,GAAb,KAGE,CAEA,QAGA,kBAGA,iBAGA,oBAAmD,EAAE,CAGrD,aAAoD,EAAE,CAGtD,gBAAqD,EAAE,CAGvD,cAGA,iBAMA,UAGA,WAGA,gBAGA,aAGA,gBAQA,cAKA,cAOA,YAAY,CACV,UACA,oBAAoB,EAAE,CACtB,eAAe,EACf,kBACA,kBAAkB,GAClB,gBACA,mBAAmB,EAAE,EAqBpB,CACD,KAAK,QAAU,EACf,KAAK,aAAe,EACpB,KAAK,gBAAkB,EACvB,KAAK,UAAY,EACjB,KAAK,iBAAmB,EACxB,KAAK,cAAgB,EACnB,EACA,OAAO,GAAoB,SAAW,EAAgB,SAAS,CAAG,EACnE,CACD,KAAK,gBAAkB,EACvB,KAAK,cAAgB,EACrB,KAAK,kBAAoB,EACzB,KAAK,WAAa,EAA4B,EAAkB,CAQlE,MAAM,yBAAiE,CAErE,IAAM,EAAoB,GAAU,KAAK,QAAQ,CAC3C,EAAY,EAAkB,KAAK,CAAE,QAAS,EAAG,CAAC,OAAQ,GAAmB,CAAC,CAAC,EAAE,CACjF,EAAe,EAClB,KAAK,CAAE,WAAY,EAAM,CACzB,OAAQ,GAAmB,CAAC,CAAC,EAAE,CAC5B,EAAa,GAAK,EAAkB,KAAK,CAAE,gBAAiB,GAAc,EAAE,CAAC,CAAC,MAAM,CAAC,CAGrF,CAAC,EAAU,EAAqB,GAAU,MAAM,QAAQ,IAAI,CAChE,EAA0B,KAAK,cAAe,CAC5C,YACA,eACD,CAAC,CACF,GAA4B,KAAK,cAAc,CAC/C,EAAe,KAAK,cAAe,CAAE,MAAO,EAAY,CAAC,CAC1D,CAAC,CACF,KAAK,aAAe,EAAM,EAAQ,OAAO,CACzC,KAAK,gBAAkB,EAAM,EAAQ,UAAU,CAC/C,KAAK,oBAAsB,EAAoB,OAC5C,GAAU,EAAM,oBAAsB,GACxC,CAGD,IAAM,EAAgB,EAAM,EAAS,QAAS,QAAQ,CAChD,EAAa,EAAM,EAAS,QAAS,KAAK,CAsChD,MAnCA,MAAK,UAAY,CACf,GAAG,EAAS,oBAAoB,QAC7B,EAAK,IACJ,OAAO,OAAO,EAAK,EAChB,EAAE,MAAO,EAAE,KAAO,KAAK,MAAM,EAAE,KAAK,CAAG,EAAE,KAC3C,CAAC,CACJ,EAAE,CACH,CACD,GAAG,KAAK,iBACT,CAGD,KAAK,WAAa,EAA4B,CAC5C,GAAG,KAAK,kBACR,UAAW,CACT,GAAI,KAAK,kBAAkB,WAAa,EAAE,CAC1C,GAAG,EAAS,eAAe,IAAK,IAAa,CAC3C,KAAM,EAAQ,KACd,QAAS,EAAQ,QAClB,EAAE,CACJ,CACF,CAAC,CAGF,KAAK,iBAAmB,GAAM,KAAK,SAAU,CAAE,KAAI,WAAY,CAC7D,IAAM,EAAS,EAAK,EAAW,GAAM,EAAQ,EAAc,GAAS,IAAA,GACpE,GAAI,CAAC,EACH,MAAU,MAAM,sCAAsC,EAAM,aAAa,EAAG,GAAG,CAEjF,OAAO,GACP,CAGF,KAAK,cAAgB,IAAI,KAElB,EAST,MAAM,eAAe,EAA0C,CAC7D,IAAM,EAAQ,KAAK,aAAa,GAChC,GAAI,EACF,OAAO,EAET,GAAM,CAAC,GAAe,MAAM,EAAe,KAAK,cAAe,CAC7D,MAAO,CAAC,EAAK,CACd,CAAC,CACG,KAKL,MAFA,MAAK,aAAa,EAAY,MAAQ,EACtC,KAAK,gBAAgB,EAAY,SAAW,EACrC,EAST,MAAM,yBAAyB,EAA+C,CAC5E,GAAM,CAAC,GAAU,MAAM,EAAsB,KAAK,cAAe,CAC/D,eAAgB,CAAC,EAAG,CACrB,CAAC,CACF,OAAO,EAWT,MAAM,gBAAgB,EAAmC,CACvD,GAAI,EAAM,OAAS,EACjB,MAAU,MAAM,4CAA4C,CAE9D,GAAM,CAAE,WAAW,EAAE,CAAE,eAAe,EAAE,EAAK,GAAQ,EAAQ,GAC3D,KAAK,aAAa,GAAQ,WAAa,eACxC,CACK,EAAe,EAAS,IAAK,GAAS,KAAK,aAAa,GAAM,CACpE,GAAI,EAAa,SAAW,EAC1B,OAAO,EAET,IAAM,EAAe,GAAM,EAAc,GAAG,CACtC,EAAwB,EAAE,CAWhC,OAVA,MAAM,GAAU,EAAc,KAAO,IAAgB,CACnD,IAAM,EAAe,MAAM,EAAe,KAAK,cAAe,CAC5D,MAAO,EACR,CAAC,CACF,EAAa,QAAS,GAAU,CAC9B,KAAK,aAAa,EAAM,MAAQ,EAChC,KAAK,gBAAgB,EAAM,SAAW,GACtC,CACF,EAAa,KAAK,GAAG,EAAa,EAClC,CACK,CAAC,GAAG,EAAc,GAAG,EAAa,CAS3C,cAAc,EAAmD,CAC/D,OAAO,EAAmB,KAAK,cAAe,EAAS,CASzD,sBACE,EACoB,CACpB,IAAM,EAAW,KAAK,oBAAoB,KAAM,GAC9C,OAAO,GAAuB,SAC1B,EAAM,KAAO,EACb,EAAM,OAAS,EAAmB,MAAQ,EAAM,SAAW,EAAmB,OACnF,CACD,GAAI,CAAC,EACH,MAAU,MACR,kCACE,OAAO,GAAuB,SAC1B,EACA,KAAK,UAAU,EAAmB,GAEzC,CAEH,OAAO,EAST,MAAM,oBACJ,EACmC,EAIjC,CAAC,KAAK,eAEN,KAAK,gBAAkB,GAEtB,KAAK,eAAiB,KAAK,KAAK,CAAG,KAAK,cAAc,SAAS,CAAG,KAAK,gBAExE,MAAM,KAAK,yBAAyB,CAItC,GAAM,CAAE,oBAAqB,KAC7B,GAAI,CAAC,EACH,MAAU,MAAM,+CAA+C,CAEjE,IAAM,EAAiB,EAAiB,GACxC,GAAI,CAAC,EACH,MAAU,MAAM,kCAAkC,EAAW,iBAAiB,CAEhF,OAAO,EAUT,MAAM,cACJ,EACA,EACiB,CAEjB,IAAM,EAAiB,MAAM,KAAK,oBAAoB,EAAW,CAC3D,EAAc,KAAK,QAAQ,GACjC,GAAI,CAAC,EACH,MAAU,MAAM,yBAAyB,EAAW,iBAAiB,CAIvE,GAAI,KAAK,iBAAmB,EAAe,SAAW,EAAa,SACjE,MAAU,MACR,eAAe,EAAe,MAAM,2CAA2C,EAAe,OAAO,GACtG,CAIH,GAAI,EAAe,SAAW,EAAa,SACzC,MAAU,MACR,eAAe,EAAe,MAAM,4CAA4C,EAAe,OAAO,GACvG,CAOH,OAHA,EAAY,EAAY,WAAY,EAAO,CAGpC,KAAK,WAAW,QAAQ,EAAe,QAAQ,CAAC,CAErD,YAAa,IAAI,MAAM,CAAC,aAAa,CACrC,GAAG,KAAK,UACR,GAAG,EACJ,CAAC,CAUJ,gBACE,EACA,EACgD,CAEhD,IAAM,EAAc,KAAK,QAAQ,GACjC,GAAI,CAAC,EACH,MAAU,MAAM,yBAAyB,EAAW,iBAAiB,CAIvE,IAAM,EAAY,EAAY,iBACzB,GAAkB,EAAY,eAAe,CAAC,KAAK,EAAS,EAAI,EAAE,EAAE,IACrE,EAGJ,OAAO,EAAY,EAAY,YAAa,GAAc,EAAU,CAAE,GAAM,CAU9E,MAAM,wBACJ,EACA,CAAE,qBAAoB,GAAG,GAMzB,EAIE,CAAC,KAAK,eAEN,KAAK,gBAAkB,GAEtB,KAAK,eAAiB,KAAK,KAAK,CAAG,KAAK,cAAc,SAAS,CAAG,KAAK,gBAExE,MAAM,KAAK,yBAAyB,CAGtC,IAAM,EAAO,EAAQ,MAAQ,gCAAgC,IAAI,MAAM,CAAC,aAAa,GAErF,GAAI,CAAC,KAAK,iBACR,MAAU,MAAM,+CAA+C,CAGjE,IAAM,EAAc,KAAK,iBAAiB,GAC1C,GAAI,CAAC,EACH,MAAU,MAAM,yBAAyB,EAAW,iBAAiB,CAIvE,GAAI,EAAQ,kBAAkB,SAAW,EACvC,MAAU,MAAM,mDAAmD,CAErE,GAAI,EAAQ,kBAAkB,GAAG,OAAS,EAAmB,OAC3D,MAAU,MAAM,iDAAiD,EAAmB,SAAS,CAE/F,GACE,EAAQ,kBAAkB,EAAQ,kBAAkB,OAAS,GAAG,OAChE,EAAmB,UAEnB,MAAU,MACR,qBACE,EAAQ,kBAAkB,OAAS,EACpC,6BAA6B,EAAmB,YAClD,CAEH,IAAM,EAAW,EAAQ,kBAAkB,EAAQ,kBAAkB,OAAS,GAAG,QAE7E,EACJ,GAAI,CAEF,EAAS,KAAK,gBAAgB,EAAY,EAAS,OAC5C,EAAK,CAmBZ,MAlBA,MAAM,EAAgB,KAAK,cAAe,CACxC,YAAa,EAAqB,cAClC,GAAG,EACH,OACA,MAAO,EAAI,QACX,OAAQ,EAAY,MACpB,GAAI,OAAO,GAAuB,SAC9B,CAAE,qBAAsB,EAAoB,CAC5C,CACE,uBAAwB,EAAmB,KAC3C,yBAA0B,EAAmB,OAC9C,CACL,SAAU,EAAY,GACtB,kBAAmB,EAAQ,kBAAkB,KAAK,EAAS,KAAS,CAClE,GAAG,EACH,GAAI,IAAQ,EAAI,CAAE,SAAU,EAAY,QAAS,CAAG,EAAE,CACvD,EAAE,CACJ,CAAC,CACI,EAIR,IAAM,EAAc,MAAM,EAAgB,KAAK,cAAe,CAC5D,YAAa,EAAqB,cAClC,GAAG,EACH,OACA,OAAQ,EAAY,SACpB,GAAI,OAAO,GAAuB,SAC9B,CAAE,qBAAsB,EAAoB,CAC5C,CACE,uBAAwB,EAAmB,KAC3C,yBAA0B,EAAmB,OAC9C,CACL,SAAU,EAAY,GACtB,kBAAmB,EAAQ,kBAAkB,KAAK,EAAS,KAAS,CAClE,GAAG,EACH,GAAI,IAAQ,EAAI,CAAE,SAAU,EAAY,QAAS,CAAG,EAAE,CACvD,EAAE,CACJ,CAAC,CAEF,MAAO,CACL,OAAQ,EACR,cACA,aAAc,yCAAyC,IACxD,CAUH,MAAM,qBACJ,EACA,CAAE,qBAAoB,GAAG,GACC,EAIxB,CAAC,KAAK,eAEN,KAAK,gBAAkB,GAEtB,KAAK,eAAiB,KAAK,KAAK,CAAG,KAAK,cAAc,SAAS,CAAG,KAAK,gBAExE,MAAM,KAAK,yBAAyB,CAGtC,IAAM,EAAO,EAAQ,MAAQ,gCAAgC,IAAI,MAAM,CAAC,aAAa,GAErF,GAAI,CAAC,KAAK,iBACR,MAAU,MAAM,+CAA+C,CAGjE,IAAM,EAAc,KAAK,iBAAiB,GAC1C,GAAI,CAAC,EACH,MAAU,MAAM,yBAAyB,EAAW,iBAAiB,CAIvE,GAAI,EAAQ,kBAAkB,SAAW,EACvC,MAAU,MAAM,mDAAmD,CAErE,GAAI,EAAQ,kBAAkB,GAAG,OAAS,EAAmB,OAC3D,MAAU,MAAM,iDAAiD,EAAmB,SAAS,CAG/F,IAAM,EAAc,MAAM,EAAgB,KAAK,cAAe,CAC5D,YAAa,EAAqB,cAClC,GAAG,EACH,OACA,OAAQ,EAAY,MACpB,GAAI,OAAO,GAAuB,SAC9B,CAAE,qBAAsB,EAAoB,CAC5C,CACE,uBAAwB,EAAmB,KAC3C,yBAA0B,EAAmB,OAC9C,CACL,SAAU,EAAY,GACtB,kBAAmB,EAAQ,kBAAkB,KAAK,EAAS,KAAS,CAClE,GAAG,EACH,GAAI,IAAQ,EAAI,CAAE,SAAU,EAAY,QAAS,CAAG,EAAE,CACvD,EAAE,CACJ,CAAC,CAEF,MAAO,CACL,cACA,aAAc,yCAAyC,IACxD,GC/rBL,SAAgB,GAAY,EAA6B,CAEvD,OAAO,EAAY,QADL,uBACoB,iBAAiB,CCArD,SAAgB,GAAqD,EAAW,CAC9E,OAAO,OAAO,QAAQ,EAAI,CAAC,QACxB,EAAK,CAAC,EAAG,KACR,GAAM,MAEN,IAAM,IACN,EAAE,MAAM,QAAQ,EAAE,EAAI,EAAE,SAAW,IACnC,EAAE,OAAO,GAAM,UAAY,OAAO,KAAK,EAAE,CAAC,SAAW,GACjD,OAAO,OAAO,EAAK,EAAG,GAAI,EAAG,CAAC,CAC9B,EACN,EAAE,CACH,CCPH,SAAgB,GAAuB,CACrC,aACA,gBACA,aACA,eAAe,EAAE,CACjB,gBAAgB,EAAE,EAqBlB,CAEA,EAAS,oBAAoB,IAAa,CAG1C,IAAM,EAAoB,EACxB,iBAAiB,EAAW,eAAe,EAAW,cACtD,CAAE,SAAU,QAAS,CACtB,CAAC,MAAM;EAAK,CAAC,GAGR,EAAmB,EAAS,qBAAsB,CACtD,SAAU,QACX,CAAC,CAAC,MAAM;EAAK,CAAC,GAGf,GAAI,CAAC,GAAqB,CAAC,EACzB,MAAU,MAAM,8BAA8B,CAYhD,IAAM,EAAe,GARR,EACX,sCACE,GAAc,EACf,KAAK,EAAiB,OAAO,IAC9B,CAAE,SAAU,QAAS,CACtB,CAIM,MAAM;EAAK,CAAC,OAAQ,GAAM,EAAE,CACjC,EACD,CAGK,EACJ,EAAa,OAAS,EAAI,GAAS,KAAK,EAAc,CAAE,OAAQ,EAAc,CAAC,CAAG,EAG9E,EAAuC,EAAE,CAW/C,OAVA,EAAgB,QAAS,GAAS,CAIhC,EAAU,GAHO,EAAS,YAAY,EAAiB,GAAG,IAAQ,CAChE,SAAU,QACX,CAAC,EAEF,CAKK,CACL,eACA,YACA,SALe,EAAW,MAAM,IAAI,CAAC,KAAK,CAAE,MAAM,IAAI,CAAC,GAMvD,OAAQ,EACT"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{i as e}from"./parseAttributesFromString-CZStzJc0.mjs";import t from"inquirer";import n from"inquirer-autocomplete-prompt";async function r({message:e}){let{response:n}=await t.prompt([{name:`response`,message:e,type:`confirm`}]);return n}async function i({message:e}){let{response:n}=await t.prompt([{name:`response`,message:e,type:`text`,validate:e=>e.trim().length>0}]);return n}async function a({defaultValue:r,values:i,message:a}){t.registerPrompt(`autocomplete`,n);let{response:o}=await t.prompt([{name:`response`,message:a,type:`autocomplete`,default:r,source:(t,n)=>n?i.filter(t=>typeof t==`string`&&e(n,t)):i}]);return o}export{r as n,i as r,a as t};
|
|
2
|
+
//# sourceMappingURL=inquirer-BgNcicZ4.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inquirer-BgNcicZ4.mjs","names":[],"sources":["../src/lib/helpers/inquirer.ts"],"sourcesContent":["import { ObjByString } from '@transcend-io/type-utils';\nimport inquirer from 'inquirer';\nimport autoCompletePrompt from 'inquirer-autocomplete-prompt';\n\nimport { fuzzySearch } from '../requests/index.js';\n\n/**\n * Inquirer confirm text\n *\n * @param options - Options\n * @returns The response\n */\nexport async function inquirerConfirmBoolean({\n message,\n}: {\n /** Message */\n message: string;\n}): Promise<boolean> {\n const { response } = await inquirer.prompt<{\n /** confirmation */\n response: boolean;\n }>([\n {\n name: 'response',\n message,\n type: 'confirm',\n },\n ]);\n return response;\n}\n\n/**\n * Inquirer confirm text\n *\n * @param options - Options\n * @returns The response\n */\nexport async function inquirerConfirmText({\n message,\n}: {\n /** Message */\n message: string;\n}): Promise<string> {\n const { response } = await inquirer.prompt<{\n /** confirmation */\n response: string;\n }>([\n {\n name: 'response',\n message,\n type: 'text',\n validate: (x) => x.trim().length > 0,\n },\n ]);\n return response;\n}\n\n/**\n * Inquirer auto complete\n *\n * @param options - Options\n * @returns The response\n */\nexport async function inquirerAutoComplete({\n defaultValue,\n values,\n message,\n}: {\n /** Default value */\n defaultValue?: string;\n /** Message */\n message: string;\n /** Values to select */\n values: string[];\n}): Promise<string> {\n inquirer.registerPrompt('autocomplete', autoCompletePrompt);\n const { response } = await inquirer.prompt<{\n /** confirmation */\n response: string;\n }>([\n {\n name: 'response',\n message,\n type: 'autocomplete',\n default: defaultValue,\n source: (answersSoFar: ObjByString, input: string) =>\n !input ? values : values.filter((x) => typeof x === 'string' && fuzzySearch(input, x)),\n },\n ]);\n return response;\n}\n"],"mappings":"iIAYA,eAAsB,EAAuB,CAC3C,WAImB,CACnB,GAAM,CAAE,YAAa,MAAM,EAAS,OAGjC,CACD,CACE,KAAM,WACN,UACA,KAAM,UACP,CACF,CAAC,CACF,OAAO,EAST,eAAsB,EAAoB,CACxC,WAIkB,CAClB,GAAM,CAAE,YAAa,MAAM,EAAS,OAGjC,CACD,CACE,KAAM,WACN,UACA,KAAM,OACN,SAAW,GAAM,EAAE,MAAM,CAAC,OAAS,EACpC,CACF,CAAC,CACF,OAAO,EAST,eAAsB,EAAqB,CACzC,eACA,SACA,WAQkB,CAClB,EAAS,eAAe,eAAgB,EAAmB,CAC3D,GAAM,CAAE,YAAa,MAAM,EAAS,OAGjC,CACD,CACE,KAAM,WACN,UACA,KAAM,eACN,QAAS,EACT,QAAS,EAA2B,IACjC,EAAiB,EAAO,OAAQ,GAAM,OAAO,GAAM,UAAY,EAAY,EAAO,EAAE,CAAC,CAA7E,EACZ,CACF,CAAC,CACF,OAAO"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{existsSync as e,readdirSync as t}from"node:fs";function n(n,r,i=!1){if(!e(n))return[];let a=t(n).filter(e=>r?r.filter(t=>e.endsWith(t)).length:!0).filter(e=>e.indexOf(`.`)>0);return i?a.map(e=>e.replace(/\.[^/.]+$/,``)):a}export{n as t};
|
|
2
|
+
//# sourceMappingURL=listFiles-qzyQMaYH.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listFiles-qzyQMaYH.mjs","names":[],"sources":["../src/lib/api-keys/listFiles.ts"],"sourcesContent":["import { existsSync, readdirSync } from 'node:fs';\n\n/**\n * List the files in a directory\n *\n * ```typescript\n * // The directory to search\n * const directory = '/User/test/transcend/my-app/app/containers';\n * // Returns ['test.js']\n * listFiles(directory);\n * ```\n *\n * @param directory - The directory to search\n * @param validExtensions - The list of valid extensions\n * @param removeExtensions - When true, remove the extensions from the listed files\n * @returns The list of files in the directory\n */\nexport function listFiles(\n directory: string,\n validExtensions?: string[],\n removeExtensions = false,\n): string[] {\n if (!existsSync(directory)) {\n return [];\n }\n\n const files = readdirSync(directory)\n .filter((fil) =>\n validExtensions ? validExtensions.filter((ext) => fil.endsWith(ext)).length : true,\n )\n .filter((fil) => fil.indexOf('.') > 0);\n\n return removeExtensions ? files.map((fil) => fil.replace(/\\.[^/.]+$/, '')) : files;\n}\n"],"mappings":"sDAiBA,SAAgB,EACd,EACA,EACA,EAAmB,GACT,CACV,GAAI,CAAC,EAAW,EAAU,CACxB,MAAO,EAAE,CAGX,IAAM,EAAQ,EAAY,EAAU,CACjC,OAAQ,GACP,EAAkB,EAAgB,OAAQ,GAAQ,EAAI,SAAS,EAAI,CAAC,CAAC,OAAS,GAC/E,CACA,OAAQ,GAAQ,EAAI,QAAQ,IAAI,CAAG,EAAE,CAExC,OAAO,EAAmB,EAAM,IAAK,GAAQ,EAAI,QAAQ,YAAa,GAAG,CAAC,CAAG"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import e from"colors";import{bootstrap as t}from"global-agent";import{ProxyAgent as n,setGlobalDispatcher as r}from"undici";import i from"yargs-parser";const a=console,{httpProxy:o=process.env.http_proxy}=i(process.argv.slice(2));o&&(a.info(e.green(`Initializing proxy: ${o}`)),process.env.GLOBAL_AGENT_HTTP_PROXY=o,t(),r(new n(o)));export{a as t};
|
|
2
|
-
//# sourceMappingURL=logger-
|
|
2
|
+
//# sourceMappingURL=logger-B-LXIf3U.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger-
|
|
1
|
+
{"version":3,"file":"logger-B-LXIf3U.mjs","names":[],"sources":["../src/logger.ts"],"sourcesContent":["import colors from 'colors';\nimport { bootstrap } from 'global-agent';\nimport { ProxyAgent, setGlobalDispatcher } from 'undici';\nimport yargs from 'yargs-parser';\n\nexport const logger = console;\n\n// When the proxy env var of flag is specified, initiate the proxy\nconst { httpProxy = process.env.http_proxy } = yargs(process.argv.slice(2));\nif (httpProxy) {\n logger.info(colors.green(`Initializing proxy: ${httpProxy}`));\n\n // Use global-agent, which overrides `request` based requests\n process.env.GLOBAL_AGENT_HTTP_PROXY = httpProxy;\n bootstrap();\n\n // Use undici, which overrides `fetch` based requests\n setGlobalDispatcher(new ProxyAgent(httpProxy));\n}\n"],"mappings":"wJAKA,MAAa,EAAS,QAGhB,CAAE,YAAY,QAAQ,IAAI,YAAe,EAAM,QAAQ,KAAK,MAAM,EAAE,CAAC,CACvE,IACF,EAAO,KAAK,EAAO,MAAM,uBAAuB,IAAY,CAAC,CAG7D,QAAQ,IAAI,wBAA0B,EACtC,GAAW,CAGX,EAAoB,IAAI,EAAW,EAAU,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{n as e}from"./package-BjNQxHlz.mjs";import{t}from"./logger-B-LXIf3U.mjs";import n from"colors";import{GraphQLClient as r}from"graphql-request";function i(t,n){return new r(`${t}/graphql`,{headers:{...n,version:e}})}function a(e,t){return i(e,{Authorization:`Bearer ${t}`})}function o(e){return new Promise(t=>{setTimeout(()=>t(e),e)})}const s=[`syntax error`,`got invalid value`,`Client error`,`cannot affect row a second time`,`GRAPHQL_VALIDATION_FAILED`];async function c(e,r,i,a,c=4){let l=0;for(;;)try{return await e.request(r,i,a)}catch(e){if(e.message.includes(`API key is invalid`)&&(t.error(n.red("API key is invalid. Please ensure that the key provided to `transcendAuth` has the proper scope and is not expired, and that `transcendUrl` corresponds to the correct backend for your organization.")),process.exit(1)),s.some(t=>e.message.includes(t)))throw e;if(e.message.startsWith(`Client error: Too many requests`)){let r=e.response.headers?.get(`x-ratelimit-reset`),i=r?new Date(r).getTime()-new Date().getTime()+100:1e3*10;t.log(n.yellow(`DETECTED RATE LIMIT: ${e.message}. Sleeping for ${i}ms`)),await o(i)}if(l>=c)throw e;l+=1,t.log(n.yellow(`Retrying failed request (${l} / ${c}): ${e.message}`))}}export{i,o as n,a as r,c as t};
|
|
2
|
+
//# sourceMappingURL=makeGraphQLRequest-G078PsEL.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"makeGraphQLRequest-G078PsEL.mjs","names":[],"sources":["../src/lib/graphql/buildTranscendGraphQLClient.ts","../src/lib/helpers/sleepPromise.ts","../src/lib/graphql/makeGraphQLRequest.ts"],"sourcesContent":["import { GraphQLClient } from 'graphql-request';\n\nimport { version } from '../../../package.json';\n\n/**\n * Create a GraphQL client\n *\n * @param transcendUrl - Transcend API URL\n * @param headers - Request headers to include in each request\n * @returns GraphQL client\n */\nexport function buildTranscendGraphQLClientGeneric(\n transcendUrl: string,\n headers: Record<string, string>,\n): GraphQLClient {\n // Create a GraphQL client\n return new GraphQLClient(`${transcendUrl}/graphql`, {\n headers: {\n ...headers,\n version,\n },\n });\n}\n\n/**\n * Create a GraphQL client capable of submitting requests with an API key\n *\n * @param transcendUrl - Transcend API URL\n * @param auth - API key to authenticate to API\n * @returns GraphQL client\n */\nexport function buildTranscendGraphQLClient(transcendUrl: string, auth: string): GraphQLClient {\n return buildTranscendGraphQLClientGeneric(transcendUrl, {\n Authorization: `Bearer ${auth}`,\n });\n}\n","/**\n * Sleep in a promise\n *\n * @param sleepTime - The time to sleep in milliseconds.\n * @returns Resolves promise\n */\nexport function sleepPromise(sleepTime: number): Promise<number> {\n return new Promise((resolve) => {\n setTimeout(() => resolve(sleepTime), sleepTime);\n });\n}\n","import colors from 'colors';\nimport type { GraphQLClient, RequestDocument, Variables } from 'graphql-request';\n\nimport { logger } from '../../logger.js';\nimport { sleepPromise } from '../helpers/index.js';\n\nconst MAX_RETRIES = 4;\n\nconst KNOWN_ERRORS = [\n 'syntax error',\n 'got invalid value',\n 'Client error',\n 'cannot affect row a second time',\n 'GRAPHQL_VALIDATION_FAILED',\n];\n\n/**\n * Make a GraphQL request with retries\n *\n * @param client - GraphQL client\n * @param document - document\n * @param variables - Variable\n * @param requestHeaders - Headers\n * @param maxRequests - Max number of requests\n * @returns Response\n */\nexport async function makeGraphQLRequest<T, V extends Variables = Variables>(\n client: GraphQLClient,\n document: RequestDocument,\n variables?: V,\n requestHeaders?: Record<string, string> | string[][] | Headers,\n maxRequests = MAX_RETRIES,\n): Promise<T> {\n let retryCount = 0;\n // eslint-disable-next-line no-constant-condition\n while (true) {\n try {\n const result = await client.request(document, variables, requestHeaders);\n return result as T;\n } catch (err) {\n if (err.message.includes('API key is invalid')) {\n logger.error(\n colors.red(\n 'API key is invalid. ' +\n 'Please ensure that the key provided to `transcendAuth` has the proper scope and is not expired, ' +\n 'and that `transcendUrl` corresponds to the correct backend for your organization.',\n ),\n );\n process.exit(1);\n }\n\n if (KNOWN_ERRORS.some((msg) => err.message.includes(msg))) {\n throw err;\n }\n\n // wait for rate limit to resolve\n if (err.message.startsWith('Client error: Too many requests')) {\n const rateLimitResetAt = err.response.headers?.get('x-ratelimit-reset');\n const sleepTime = rateLimitResetAt\n ? new Date(rateLimitResetAt).getTime() - new Date().getTime() + 100\n : 1000 * 10;\n logger.log(\n colors.yellow(`DETECTED RATE LIMIT: ${err.message}. Sleeping for ${sleepTime}ms`),\n );\n\n await sleepPromise(sleepTime);\n }\n\n if (retryCount >= maxRequests) {\n throw err;\n }\n retryCount += 1;\n logger.log(\n colors.yellow(`Retrying failed request (${retryCount} / ${maxRequests}): ${err.message}`),\n );\n }\n }\n}\n"],"mappings":"sJAWA,SAAgB,EACd,EACA,EACe,CAEf,OAAO,IAAI,EAAc,GAAG,EAAa,UAAW,CAClD,QAAS,CACP,GAAG,EACH,UACD,CACF,CAAC,CAUJ,SAAgB,EAA4B,EAAsB,EAA6B,CAC7F,OAAO,EAAmC,EAAc,CACtD,cAAe,UAAU,IAC1B,CAAC,CC5BJ,SAAgB,EAAa,EAAoC,CAC/D,OAAO,IAAI,QAAS,GAAY,CAC9B,eAAiB,EAAQ,EAAU,CAAE,EAAU,EAC/C,CCHJ,MAEM,EAAe,CACnB,eACA,oBACA,eACA,kCACA,4BACD,CAYD,eAAsB,EACpB,EACA,EACA,EACA,EACA,EAAc,EACF,CACZ,IAAI,EAAa,EAEjB,OACE,GAAI,CAEF,OADe,MAAM,EAAO,QAAQ,EAAU,EAAW,EAAe,OAEjE,EAAK,CAYZ,GAXI,EAAI,QAAQ,SAAS,qBAAqB,GAC5C,EAAO,MACL,EAAO,IACL,wMAGD,CACF,CACD,QAAQ,KAAK,EAAE,EAGb,EAAa,KAAM,GAAQ,EAAI,QAAQ,SAAS,EAAI,CAAC,CACvD,MAAM,EAIR,GAAI,EAAI,QAAQ,WAAW,kCAAkC,CAAE,CAC7D,IAAM,EAAmB,EAAI,SAAS,SAAS,IAAI,oBAAoB,CACjE,EAAY,EACd,IAAI,KAAK,EAAiB,CAAC,SAAS,CAAG,IAAI,MAAM,CAAC,SAAS,CAAG,IAC9D,IAAO,GACX,EAAO,IACL,EAAO,OAAO,wBAAwB,EAAI,QAAQ,iBAAiB,EAAU,IAAI,CAClF,CAED,MAAM,EAAa,EAAU,CAG/B,GAAI,GAAc,EAChB,MAAM,EAER,GAAc,EACd,EAAO,IACL,EAAO,OAAO,4BAA4B,EAAW,KAAK,EAAY,KAAK,EAAI,UAAU,CAC1F"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a as e}from"./constants-CeMiHaHx.mjs";import{t}from"./logger-B-LXIf3U.mjs";import{t as n}from"./bluebird-CUitXgsY.mjs";import{t as r}from"./RequestDataSilo-_Iv44M9u.mjs";import{r as i,t as a}from"./makeGraphQLRequest-G078PsEL.mjs";import{t as o}from"./fetchRequestDataSilo-CF6XOTQ-.mjs";import{RequestDataSiloStatus as s}from"@transcend-io/privacy-types";import c from"colors";import l from"cli-progress";async function u({requestIds:u,dataSiloId:d,auth:f,concurrency:p=100,status:m=s.Resolved,transcendUrl:h=e}){let g=i(h,f),_=new Date().getTime(),v=new l.SingleBar({},l.Presets.shades_classic);t.info(c.magenta(`Notifying Transcend for data silo "${d}" marking "${u.length}" requests as completed.`));let y=0;v.start(u.length,0),await n(u,async e=>{let t=await o(g,{requestId:e,dataSiloId:d});try{await a(g,r,{requestDataSiloId:t.id,status:m})}catch(e){if(!e.message.includes(`Client error: Request must be active:`)&&!e.message.includes(`Failed to find RequestDataSilo`))throw e}y+=1,v.update(y)},{concurrency:p}),v.stop();let b=new Date().getTime()-_;return t.info(c.green(`Successfully notified Transcend in "${b/1e3}" seconds!`)),u.length}export{u as t};
|
|
2
|
+
//# sourceMappingURL=markRequestDataSiloIdsCompleted-DmAz-R0M.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markRequestDataSiloIdsCompleted-DmAz-R0M.mjs","names":[],"sources":["../src/lib/cron/markRequestDataSiloIdsCompleted.ts"],"sourcesContent":["import { RequestDataSiloStatus } from '@transcend-io/privacy-types';\nimport cliProgress from 'cli-progress';\nimport colors from 'colors';\n\nimport { DEFAULT_TRANSCEND_API } from '../../constants.js';\nimport { logger } from '../../logger.js';\nimport { map } from '../bluebird.js';\nimport {\n CHANGE_REQUEST_DATA_SILO_STATUS,\n fetchRequestDataSilo,\n makeGraphQLRequest,\n buildTranscendGraphQLClient,\n} from '../graphql/index.js';\n\n/**\n * Given a CSV of Request IDs, mark associated RequestDataSilos as completed\n *\n * @param options - Options\n * @returns Number of items marked as completed\n */\nexport async function markRequestDataSiloIdsCompleted({\n requestIds,\n dataSiloId,\n auth,\n concurrency = 100,\n status = RequestDataSiloStatus.Resolved,\n transcendUrl = DEFAULT_TRANSCEND_API,\n}: {\n /** The list of request ids to mark as completed */\n requestIds: string[];\n /** Transcend API key authentication */\n auth: string;\n /** Data Silo ID to pull down jobs for */\n dataSiloId: string;\n /** Status to update requests to */\n status?: RequestDataSiloStatus;\n /** Upload concurrency */\n concurrency?: number;\n /** API URL for Transcend backend */\n transcendUrl?: string;\n}): Promise<number> {\n // Find all requests made before createdAt that are in a removing data state\n const client = buildTranscendGraphQLClient(transcendUrl, auth);\n\n // Time duration\n const t0 = new Date().getTime();\n // create a new progress bar instance and use shades_classic theme\n const progressBar = new cliProgress.SingleBar({}, cliProgress.Presets.shades_classic);\n\n // Notify Transcend\n logger.info(\n colors.magenta(\n `Notifying Transcend for data silo \"${dataSiloId}\" marking \"${requestIds.length}\" requests as completed.`,\n ),\n );\n\n let total = 0;\n progressBar.start(requestIds.length, 0);\n await map(\n requestIds,\n async (requestId) => {\n const requestDataSilo = await fetchRequestDataSilo(client, {\n requestId,\n dataSiloId,\n });\n\n try {\n await makeGraphQLRequest<{\n /** Whether we successfully uploaded the results */\n success: boolean;\n }>(client, CHANGE_REQUEST_DATA_SILO_STATUS, {\n requestDataSiloId: requestDataSilo.id,\n status,\n });\n } catch (err) {\n if (\n !err.message.includes('Client error: Request must be active:') &&\n !err.message.includes('Failed to find RequestDataSilo')\n ) {\n throw err;\n }\n }\n\n total += 1;\n progressBar.update(total);\n },\n { concurrency },\n );\n\n progressBar.stop();\n const t1 = new Date().getTime();\n const totalTime = t1 - t0;\n\n logger.info(colors.green(`Successfully notified Transcend in \"${totalTime / 1000}\" seconds!`));\n return requestIds.length;\n}\n"],"mappings":"4ZAoBA,eAAsB,EAAgC,CACpD,aACA,aACA,OACA,cAAc,IACd,SAAS,EAAsB,SAC/B,eAAe,GAcG,CAElB,IAAM,EAAS,EAA4B,EAAc,EAAK,CAGxD,EAAK,IAAI,MAAM,CAAC,SAAS,CAEzB,EAAc,IAAI,EAAY,UAAU,EAAE,CAAE,EAAY,QAAQ,eAAe,CAGrF,EAAO,KACL,EAAO,QACL,sCAAsC,EAAW,aAAa,EAAW,OAAO,0BACjF,CACF,CAED,IAAI,EAAQ,EACZ,EAAY,MAAM,EAAW,OAAQ,EAAE,CACvC,MAAM,EACJ,EACA,KAAO,IAAc,CACnB,IAAM,EAAkB,MAAM,EAAqB,EAAQ,CACzD,YACA,aACD,CAAC,CAEF,GAAI,CACF,MAAM,EAGH,EAAQ,EAAiC,CAC1C,kBAAmB,EAAgB,GACnC,SACD,CAAC,OACK,EAAK,CACZ,GACE,CAAC,EAAI,QAAQ,SAAS,wCAAwC,EAC9D,CAAC,EAAI,QAAQ,SAAS,iCAAiC,CAEvD,MAAM,EAIV,GAAS,EACT,EAAY,OAAO,EAAM,EAE3B,CAAE,cAAa,CAChB,CAED,EAAY,MAAM,CAElB,IAAM,EADK,IAAI,MAAM,CAAC,SAAS,CACR,EAGvB,OADA,EAAO,KAAK,EAAO,MAAM,uCAAuC,EAAY,IAAK,YAAY,CAAC,CACvF,EAAW"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a as e}from"./constants-CeMiHaHx.mjs";import{t}from"./logger-B-LXIf3U.mjs";import{t as n}from"./bluebird-CUitXgsY.mjs";import{o as r}from"./request-CAsR6CMY.mjs";import{r as i,t as a}from"./makeGraphQLRequest-G078PsEL.mjs";import{r as o}from"./fetchAllRequests-DEPTEUbi.mjs";import{RequestStatus as s}from"@transcend-io/privacy-types";import c from"colors";import l from"cli-progress";async function u({requestActions:u,auth:d,requestIds:f,statuses:p=[s.Compiling,s.RequestMade,s.Delayed,s.Approving,s.Secondary,s.Enriching,s.Waiting,s.SecondaryApproving],createdAtAfter:m,createdAtBefore:h,updatedAtBefore:g,updatedAtAfter:_,concurrency:v=100,transcendUrl:y=e}){let b=i(y,d),x=new Date().getTime(),S=new l.SingleBar({},l.Presets.shades_classic),C=await o(b,{actions:u,statuses:p,createdAtBefore:h,createdAtAfter:m,updatedAtBefore:g,updatedAtAfter:_,isSilent:!1,requestIds:f});t.info(c.magenta(`Marking "${C.length}" as silent mode.`));let w=0;S.start(C.length,0),await n(C,async e=>{await a(b,r,{input:{id:e.id,isSilent:!0}}),w+=1,S.update(w)},{concurrency:v}),S.stop();let T=new Date().getTime()-x;return t.info(c.green(`Successfully marked ${w} requests as silent mode in "${T/1e3}" seconds!`)),C.length}export{u as t};
|
|
2
|
+
//# sourceMappingURL=markSilentPrivacyRequests-s7_aBROE.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markSilentPrivacyRequests-s7_aBROE.mjs","names":[],"sources":["../src/lib/requests/markSilentPrivacyRequests.ts"],"sourcesContent":["import { RequestAction, RequestStatus } from '@transcend-io/privacy-types';\nimport cliProgress from 'cli-progress';\nimport colors from 'colors';\n\nimport { DEFAULT_TRANSCEND_API } from '../../constants.js';\nimport { logger } from '../../logger.js';\nimport { map } from '../bluebird.js';\nimport {\n UPDATE_PRIVACY_REQUEST,\n fetchAllRequests,\n makeGraphQLRequest,\n buildTranscendGraphQLClient,\n} from '../graphql/index.js';\n\n/**\n * Mark a set of privacy requests to be in silent mode\n *\n * @param options - Options\n * @returns The number of requests marked silent\n */\nexport async function markSilentPrivacyRequests({\n requestActions,\n auth,\n requestIds,\n statuses = [\n RequestStatus.Compiling,\n RequestStatus.RequestMade,\n RequestStatus.Delayed,\n RequestStatus.Approving,\n RequestStatus.Secondary,\n RequestStatus.Enriching,\n RequestStatus.Waiting,\n RequestStatus.SecondaryApproving,\n ],\n createdAtAfter,\n createdAtBefore,\n updatedAtBefore,\n updatedAtAfter,\n concurrency = 100,\n transcendUrl = DEFAULT_TRANSCEND_API,\n}: {\n /** The request actions that should be restarted */\n requestActions: RequestAction[];\n /** Transcend API key authentication */\n auth: string;\n /** Concurrency limit for approving */\n concurrency?: number;\n /** The request statuses to mark silent */\n statuses?: RequestStatus[];\n /** The set of privacy requests to mark silent */\n requestIds?: string[];\n /** Filter for requests created before this date */\n createdAtBefore?: Date;\n /** Filter for requests created after this date */\n createdAtAfter?: Date;\n /** Filter for requests updated before this date */\n updatedAtBefore?: Date;\n /** Filter for requests updated after this date */\n updatedAtAfter?: Date;\n /** API URL for Transcend backend */\n transcendUrl?: string;\n}): Promise<number> {\n // Find all requests made before createdAt that are in a removing data state\n const client = buildTranscendGraphQLClient(transcendUrl, auth);\n\n // Time duration\n const t0 = new Date().getTime();\n // create a new progress bar instance and use shades_classic theme\n const progressBar = new cliProgress.SingleBar({}, cliProgress.Presets.shades_classic);\n\n // Pull in the requests\n const allRequests = await fetchAllRequests(client, {\n actions: requestActions,\n statuses,\n createdAtBefore,\n createdAtAfter,\n updatedAtBefore,\n updatedAtAfter,\n isSilent: false,\n requestIds,\n });\n\n // Notify Transcend\n logger.info(colors.magenta(`Marking \"${allRequests.length}\" as silent mode.`));\n\n let total = 0;\n progressBar.start(allRequests.length, 0);\n await map(\n allRequests,\n async (requestToMarkSilent) => {\n await makeGraphQLRequest(client, UPDATE_PRIVACY_REQUEST, {\n input: {\n id: requestToMarkSilent.id,\n isSilent: true,\n },\n });\n\n total += 1;\n progressBar.update(total);\n },\n { concurrency },\n );\n\n progressBar.stop();\n const t1 = new Date().getTime();\n const totalTime = t1 - t0;\n\n logger.info(\n colors.green(\n `Successfully marked ${total} requests as silent mode in \"${totalTime / 1000}\" seconds!`,\n ),\n );\n return allRequests.length;\n}\n"],"mappings":"wYAoBA,eAAsB,EAA0B,CAC9C,iBACA,OACA,aACA,WAAW,CACT,EAAc,UACd,EAAc,YACd,EAAc,QACd,EAAc,UACd,EAAc,UACd,EAAc,UACd,EAAc,QACd,EAAc,mBACf,CACD,iBACA,kBACA,kBACA,iBACA,cAAc,IACd,eAAe,GAsBG,CAElB,IAAM,EAAS,EAA4B,EAAc,EAAK,CAGxD,EAAK,IAAI,MAAM,CAAC,SAAS,CAEzB,EAAc,IAAI,EAAY,UAAU,EAAE,CAAE,EAAY,QAAQ,eAAe,CAG/E,EAAc,MAAM,EAAiB,EAAQ,CACjD,QAAS,EACT,WACA,kBACA,iBACA,kBACA,iBACA,SAAU,GACV,aACD,CAAC,CAGF,EAAO,KAAK,EAAO,QAAQ,YAAY,EAAY,OAAO,mBAAmB,CAAC,CAE9E,IAAI,EAAQ,EACZ,EAAY,MAAM,EAAY,OAAQ,EAAE,CACxC,MAAM,EACJ,EACA,KAAO,IAAwB,CAC7B,MAAM,EAAmB,EAAQ,EAAwB,CACvD,MAAO,CACL,GAAI,EAAoB,GACxB,SAAU,GACX,CACF,CAAC,CAEF,GAAS,EACT,EAAY,OAAO,EAAM,EAE3B,CAAE,cAAa,CAChB,CAED,EAAY,MAAM,CAElB,IAAM,EADK,IAAI,MAAM,CAAC,SAAS,CACR,EAOvB,OALA,EAAO,KACL,EAAO,MACL,uBAAuB,EAAM,+BAA+B,EAAY,IAAK,YAC9E,CACF,CACM,EAAY"}
|