@transcend-io/cli 10.0.1 → 10.1.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/README.md +16 -5
- package/dist/{RequestDataSilo-_Iv44M9u.mjs → RequestDataSilo-Rrc2dL9g.mjs} +4 -1
- package/dist/RequestDataSilo-Rrc2dL9g.mjs.map +1 -0
- package/dist/{app-BfTrk2nc.mjs → app-Cx8-4u8K.mjs} +21 -21
- package/dist/{app-BfTrk2nc.mjs.map → app-Cx8-4u8K.mjs.map} +1 -1
- package/dist/approvePrivacyRequests-Bjq5cPSI.mjs +2 -0
- package/dist/approvePrivacyRequests-Bjq5cPSI.mjs.map +1 -0
- package/dist/bin/bash-complete.mjs +1 -1
- package/dist/bin/cli.mjs +1 -1
- package/dist/bin/deprecated-command.mjs +1 -1
- package/dist/buildXdiSyncEndpoint-DWs9ImOw.mjs +9 -0
- package/dist/buildXdiSyncEndpoint-DWs9ImOw.mjs.map +1 -0
- package/dist/bulkRestartRequests-sie3tM3W.mjs +2 -0
- package/dist/bulkRestartRequests-sie3tM3W.mjs.map +1 -0
- package/dist/bulkRetryEnrichers-C1RrxiTR.mjs +2 -0
- package/dist/bulkRetryEnrichers-C1RrxiTR.mjs.map +1 -0
- package/dist/cancelPrivacyRequests-DmvFijq_.mjs +2 -0
- package/dist/cancelPrivacyRequests-DmvFijq_.mjs.map +1 -0
- package/dist/{codecs-BE3Wmoh8.mjs → codecs-CeDPaLYa.mjs} +1 -1
- package/dist/{codecs-BE3Wmoh8.mjs.map → codecs-CeDPaLYa.mjs.map} +1 -1
- package/dist/collectCsvFilesOrExit-D-csvd13.mjs +2 -0
- package/dist/collectCsvFilesOrExit-D-csvd13.mjs.map +1 -0
- package/dist/collectParquetFilesOrExit-C8qT5_57.mjs +2 -0
- package/dist/collectParquetFilesOrExit-C8qT5_57.mjs.map +1 -0
- package/dist/{command-BXxoAjFo.mjs → command-rzZKmlky.mjs} +2 -2
- package/dist/{command-BXxoAjFo.mjs.map → command-rzZKmlky.mjs.map} +1 -1
- package/dist/commands/admin/chunk-csv/worker.d.mts +48 -0
- package/dist/commands/admin/chunk-csv/worker.d.mts.map +1 -0
- package/dist/commands/admin/chunk-csv/worker.mjs +2 -0
- package/dist/commands/admin/chunk-csv/worker.mjs.map +1 -0
- package/dist/commands/admin/parquet-to-csv/worker.d.mts +25 -0
- package/dist/commands/admin/parquet-to-csv/worker.d.mts.map +1 -0
- package/dist/commands/admin/parquet-to-csv/worker.mjs +2 -0
- package/dist/commands/admin/parquet-to-csv/worker.mjs.map +1 -0
- package/dist/{consentManagersToBusinessEntities-BDgOFga7.mjs → consentManagersToBusinessEntities-D1bdBgnA.mjs} +2 -2
- package/dist/{consentManagersToBusinessEntities-BDgOFga7.mjs.map → consentManagersToBusinessEntities-D1bdBgnA.mjs.map} +1 -1
- package/dist/{constants-lIvXgkdp.mjs → constants-DYbzl8QH.mjs} +1 -1
- package/dist/{constants-lIvXgkdp.mjs.map → constants-DYbzl8QH.mjs.map} +1 -1
- package/dist/constants-XOsAW1__.mjs +2 -0
- package/dist/constants-XOsAW1__.mjs.map +1 -0
- package/dist/{constants-AFtS5Nad.mjs → constants-mjLYTIJm.mjs} +2 -2
- package/dist/{constants-AFtS5Nad.mjs.map → constants-mjLYTIJm.mjs.map} +1 -1
- package/dist/{context-CdSyuBlf.mjs → context-bkKpii_t.mjs} +1 -1
- package/dist/{context-CdSyuBlf.mjs.map → context-bkKpii_t.mjs.map} +1 -1
- package/dist/createExtraKeyHandler-Jp5XpTJi.mjs +14 -0
- package/dist/createExtraKeyHandler-Jp5XpTJi.mjs.map +1 -0
- package/dist/{dataFlowsToDataSilos-NhvBw1iy.mjs → dataFlowsToDataSilos-DUj1NhOt.mjs} +1 -1
- package/dist/dataFlowsToDataSilos-DUj1NhOt.mjs.map +1 -0
- package/dist/{dataSilo-DrFetFXw.mjs → dataSilo-Dvi8-PkH.mjs} +1 -1
- package/dist/{dataSilo-DrFetFXw.mjs.map → dataSilo-Dvi8-PkH.mjs.map} +1 -1
- package/dist/{dataSubject-y_aXI0pa.mjs → dataSubject-CF784Ug0.mjs} +1 -1
- package/dist/{dataSubject-y_aXI0pa.mjs.map → dataSubject-CF784Ug0.mjs.map} +1 -1
- package/dist/{done-input-validation-DLR0-MJ7.mjs → done-input-validation-C5rgR0Wr.mjs} +1 -1
- package/dist/{done-input-validation-DLR0-MJ7.mjs.map → done-input-validation-C5rgR0Wr.mjs.map} +1 -1
- package/dist/downloadPrivacyRequestFiles-GUbd_PRc.mjs +2 -0
- package/dist/downloadPrivacyRequestFiles-GUbd_PRc.mjs.map +1 -0
- package/dist/{extractClientError-DPjv09EH.mjs → extractClientError-X9wJVqGq.mjs} +1 -1
- package/dist/{extractClientError-DPjv09EH.mjs.map → extractClientError-X9wJVqGq.mjs.map} +1 -1
- package/dist/{fetchAllRequestEnrichers-CK-kk5eg.mjs → fetchAllRequestEnrichers-Bt97Bb7F.mjs} +5 -5
- package/dist/fetchAllRequestEnrichers-Bt97Bb7F.mjs.map +1 -0
- package/dist/fetchAllRequestIdentifiers-BXx3rSee.mjs +10 -0
- package/dist/fetchAllRequestIdentifiers-BXx3rSee.mjs.map +1 -0
- package/dist/fetchAllRequests-xGgt_STo.mjs +2 -0
- package/dist/fetchAllRequests-xGgt_STo.mjs.map +1 -0
- package/dist/fetchRequestDataSilo-0UvyeL60.mjs +2 -0
- package/dist/fetchRequestDataSilo-0UvyeL60.mjs.map +1 -0
- package/dist/{fetchRequestFilesForRequest-BbxrEKFK.mjs → fetchRequestFilesForRequest-CJH2iB-P.mjs} +4 -4
- package/dist/fetchRequestFilesForRequest-CJH2iB-P.mjs.map +1 -0
- package/dist/generateCrossAccountApiKeys-DztJoLQS.mjs +2 -0
- package/dist/generateCrossAccountApiKeys-DztJoLQS.mjs.map +1 -0
- package/dist/impl-B-PzeHxN.mjs +2 -0
- package/dist/impl-B-PzeHxN.mjs.map +1 -0
- package/dist/impl-B6TXE2oE.mjs +4 -0
- package/dist/impl-B6TXE2oE.mjs.map +1 -0
- package/dist/impl-BBKJIP0Q.mjs +2 -0
- package/dist/impl-BBKJIP0Q.mjs.map +1 -0
- package/dist/impl-BBnnC5xq.mjs +2 -0
- package/dist/impl-BBnnC5xq.mjs.map +1 -0
- package/dist/impl-BGGm947r2.mjs +2 -0
- package/dist/impl-BGGm947r2.mjs.map +1 -0
- package/dist/{impl-fqOKTw5J.mjs → impl-BKrNGF2F.mjs} +2 -2
- package/dist/{impl-fqOKTw5J.mjs.map → impl-BKrNGF2F.mjs.map} +1 -1
- package/dist/{impl-DGiPB5Vq2.mjs → impl-BMnXA_Vd.mjs} +2 -2
- package/dist/impl-BMnXA_Vd.mjs.map +1 -0
- package/dist/{impl-P_NDC3cX.mjs → impl-BRiRfzgu.mjs} +2 -2
- package/dist/{impl-P_NDC3cX.mjs.map → impl-BRiRfzgu.mjs.map} +1 -1
- package/dist/{impl-DGuwD_qz.mjs → impl-BSKl6rC6.mjs} +2 -2
- package/dist/{impl-DGuwD_qz.mjs.map → impl-BSKl6rC6.mjs.map} +1 -1
- package/dist/impl-BVHfSIVG.mjs +2 -0
- package/dist/{impl-CMmyv1cl.mjs.map → impl-BVHfSIVG.mjs.map} +1 -1
- package/dist/impl-BVnfUDUm.mjs +2 -0
- package/dist/impl-BVnfUDUm.mjs.map +1 -0
- package/dist/impl-BfeWet_F2.mjs +2 -0
- package/dist/impl-BfeWet_F2.mjs.map +1 -0
- package/dist/{impl-CSChmq_t2.mjs → impl-BffzTHKU.mjs} +2 -2
- package/dist/impl-BffzTHKU.mjs.map +1 -0
- package/dist/impl-BxOydpyJ.mjs +2 -0
- package/dist/impl-BxOydpyJ.mjs.map +1 -0
- package/dist/{impl-BUC4ZelU.mjs → impl-C-u5h8We.mjs} +2 -2
- package/dist/{impl-BUC4ZelU.mjs.map → impl-C-u5h8We.mjs.map} +1 -1
- package/dist/{impl-KDuBh4bu2.mjs → impl-C3DXXn8M.mjs} +2 -2
- package/dist/impl-C3DXXn8M.mjs.map +1 -0
- package/dist/{impl-BOUm7wly2.mjs → impl-CC0rkA9s.mjs} +2 -2
- package/dist/impl-CC0rkA9s.mjs.map +1 -0
- package/dist/impl-CODwodEc.mjs +7 -0
- package/dist/impl-CODwodEc.mjs.map +1 -0
- package/dist/impl-CPIMsZg-.mjs +2 -0
- package/dist/{impl-DEWXA_QC.mjs.map → impl-CPIMsZg-.mjs.map} +1 -1
- package/dist/{impl-c7rUQYDc2.mjs → impl-CZsYoSZQ.mjs} +2 -2
- package/dist/impl-CZsYoSZQ.mjs.map +1 -0
- package/dist/impl-CnHiD4zU.mjs +2 -0
- package/dist/impl-CnHiD4zU.mjs.map +1 -0
- package/dist/impl-CpJljZV2.mjs +2 -0
- package/dist/impl-CpJljZV2.mjs.map +1 -0
- package/dist/impl-Cpndlxar.mjs +4 -0
- package/dist/impl-Cpndlxar.mjs.map +1 -0
- package/dist/{impl-CNez1OAw.mjs → impl-CqH3YYuv.mjs} +2 -2
- package/dist/{impl-CNez1OAw.mjs.map → impl-CqH3YYuv.mjs.map} +1 -1
- package/dist/{impl-MpkLBntW.mjs → impl-CvJtt8H2.mjs} +2 -2
- package/dist/{impl-MpkLBntW.mjs.map → impl-CvJtt8H2.mjs.map} +1 -1
- package/dist/impl-Cw10WeUv.mjs +2 -0
- package/dist/impl-Cw10WeUv.mjs.map +1 -0
- package/dist/{impl-CCUsnhoW2.mjs → impl-Cy8-6_Oo2.mjs} +2 -2
- package/dist/{impl-CCUsnhoW2.mjs.map → impl-Cy8-6_Oo2.mjs.map} +1 -1
- package/dist/{impl-CNykdy3e2.mjs → impl-DJ4VCAcc.mjs} +2 -2
- package/dist/impl-DJ4VCAcc.mjs.map +1 -0
- package/dist/impl-DKAV-8XC.mjs +3 -0
- package/dist/impl-DKAV-8XC.mjs.map +1 -0
- package/dist/{impl-JThkrXiI2.mjs → impl-D_AxguFh2.mjs} +2 -2
- package/dist/{impl-JThkrXiI2.mjs.map → impl-D_AxguFh2.mjs.map} +1 -1
- package/dist/{impl-D-cp0CYr.mjs → impl-DaK9UOwL.mjs} +2 -2
- package/dist/{impl-D-cp0CYr.mjs.map → impl-DaK9UOwL.mjs.map} +1 -1
- package/dist/{impl-Cgg_bv7j.mjs → impl-DfVep2mE.mjs} +2 -2
- package/dist/{impl-Cgg_bv7j.mjs.map → impl-DfVep2mE.mjs.map} +1 -1
- package/dist/impl-DhXQb3bm.mjs +2 -0
- package/dist/impl-DhXQb3bm.mjs.map +1 -0
- package/dist/impl-DpGVNllB.mjs +2 -0
- package/dist/impl-DpGVNllB.mjs.map +1 -0
- package/dist/impl-DpwyYsfg.mjs +2 -0
- package/dist/impl-DpwyYsfg.mjs.map +1 -0
- package/dist/impl-DvrSuAJv.mjs +12 -0
- package/dist/impl-DvrSuAJv.mjs.map +1 -0
- package/dist/{impl-CqXFyvgV2.mjs → impl-Dw9uW5zy2.mjs} +2 -2
- package/dist/{impl-CqXFyvgV2.mjs.map → impl-Dw9uW5zy2.mjs.map} +1 -1
- package/dist/impl-PdIU1pLr2.mjs +2 -0
- package/dist/impl-PdIU1pLr2.mjs.map +1 -0
- package/dist/{impl-D9NjIwEi2.mjs → impl-StdJMCiM.mjs} +2 -2
- package/dist/impl-StdJMCiM.mjs.map +1 -0
- package/dist/impl-daUiLV3c.mjs +2 -0
- package/dist/impl-daUiLV3c.mjs.map +1 -0
- package/dist/{impl-Rt3C_fDF.mjs → impl-iGMjSniP.mjs} +2 -2
- package/dist/{impl-Rt3C_fDF.mjs.map → impl-iGMjSniP.mjs.map} +1 -1
- package/dist/impl-ogUHfunr.mjs +2 -0
- package/dist/impl-ogUHfunr.mjs.map +1 -0
- package/dist/impl-uwkj-RbF.mjs +2 -0
- package/dist/impl-uwkj-RbF.mjs.map +1 -0
- package/dist/{impl-DGzvE8aJ.mjs → impl-yvc0y1uO.mjs} +2 -2
- package/dist/{impl-DGzvE8aJ.mjs.map → impl-yvc0y1uO.mjs.map} +1 -1
- package/dist/index.d.mts +664 -3851
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +4 -78
- package/dist/index.mjs.map +1 -1
- package/dist/{inquirer-BgNcicZ4.mjs → inquirer-DyRwhvoh.mjs} +2 -2
- package/dist/{inquirer-BgNcicZ4.mjs.map → inquirer-DyRwhvoh.mjs.map} +1 -1
- package/dist/{listFiles-qzyQMaYH.mjs → listFiles-Odj7j2E1.mjs} +1 -1
- package/dist/{listFiles-qzyQMaYH.mjs.map → listFiles-Odj7j2E1.mjs.map} +1 -1
- package/dist/{logger-B-LXIf3U.mjs → logger-Bj782ZYD.mjs} +1 -1
- package/dist/{logger-B-LXIf3U.mjs.map → logger-Bj782ZYD.mjs.map} +1 -1
- package/dist/markRequestDataSiloIdsCompleted-DJSICILv.mjs +2 -0
- package/dist/markRequestDataSiloIdsCompleted-DJSICILv.mjs.map +1 -0
- package/dist/markSilentPrivacyRequests-ytCzpUkY.mjs +2 -0
- package/dist/markSilentPrivacyRequests-ytCzpUkY.mjs.map +1 -0
- package/dist/notifyPrivacyRequestsAdditionalTime-D8v68eAg.mjs +2 -0
- package/dist/notifyPrivacyRequestsAdditionalTime-D8v68eAg.mjs.map +1 -0
- package/dist/parquetToCsvOneFile-bgEgRoAi.mjs +6 -0
- package/dist/parquetToCsvOneFile-bgEgRoAi.mjs.map +1 -0
- package/dist/parseAttributesFromString-B8h4DudO.mjs +2 -0
- package/dist/{parseAttributesFromString-CZStzJc0.mjs.map → parseAttributesFromString-B8h4DudO.mjs.map} +1 -1
- package/dist/parseVariablesFromString-CvoeZZ75.mjs +23 -0
- package/dist/parseVariablesFromString-CvoeZZ75.mjs.map +1 -0
- package/dist/pullAllDatapoints-CqgqXRbp.mjs +45 -0
- package/dist/pullAllDatapoints-CqgqXRbp.mjs.map +1 -0
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-DaYEDZ66.mjs +2 -0
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-DaYEDZ66.mjs.map +1 -0
- package/dist/pullConsentManagerMetrics-BO0hYPDG.mjs +2 -0
- package/dist/pullConsentManagerMetrics-BO0hYPDG.mjs.map +1 -0
- package/dist/pullManualEnrichmentIdentifiersToCsv-BNuhsG20.mjs +2 -0
- package/dist/pullManualEnrichmentIdentifiersToCsv-BNuhsG20.mjs.map +1 -0
- package/dist/pullTranscendConfiguration-DSyMRyPe.mjs +58 -0
- package/dist/pullTranscendConfiguration-DSyMRyPe.mjs.map +1 -0
- package/dist/{pullUnstructuredSubDataPointRecommendations-DZd2q6S2.mjs → pullUnstructuredSubDataPointRecommendations-jE-tdoVK.mjs} +4 -4
- package/dist/pullUnstructuredSubDataPointRecommendations-jE-tdoVK.mjs.map +1 -0
- package/dist/pushCronIdentifiersFromCsv-D9Hzna0W.mjs +2 -0
- package/dist/pushCronIdentifiersFromCsv-D9Hzna0W.mjs.map +1 -0
- package/dist/pushManualEnrichmentIdentifiersFromCsv-BiR7PS_d.mjs +2 -0
- package/dist/pushManualEnrichmentIdentifiersFromCsv-BiR7PS_d.mjs.map +1 -0
- package/dist/{readCsv-CyOL7eCc.mjs → readCsv-0PIlJQCN.mjs} +1 -1
- package/dist/{readCsv-CyOL7eCc.mjs.map → readCsv-0PIlJQCN.mjs.map} +1 -1
- package/dist/{readTranscendYaml-D-J1ilS0.mjs → readTranscendYaml-DVkQL2SC.mjs} +2 -2
- package/dist/{readTranscendYaml-D-J1ilS0.mjs.map → readTranscendYaml-DVkQL2SC.mjs.map} +1 -1
- package/dist/removeUnverifiedRequestIdentifiers-B0Gx09XN.mjs +35 -0
- package/dist/removeUnverifiedRequestIdentifiers-B0Gx09XN.mjs.map +1 -0
- package/dist/{request-CAsR6CMY.mjs → request-SLqRySNU.mjs} +1 -1
- package/dist/{request-CAsR6CMY.mjs.map → request-SLqRySNU.mjs.map} +1 -1
- package/dist/retryRequestDataSilos-DFjFhhC0.mjs +2 -0
- package/dist/retryRequestDataSilos-DFjFhhC0.mjs.map +1 -0
- package/dist/skipPreflightJobs-Bm8lZZk-.mjs +2 -0
- package/dist/skipPreflightJobs-Bm8lZZk-.mjs.map +1 -0
- package/dist/skipRequestDataSilos-B5FByYTj.mjs +2 -0
- package/dist/skipRequestDataSilos-B5FByYTj.mjs.map +1 -0
- package/dist/streamPrivacyRequestsToCsv-CBzh80oQ.mjs +2 -0
- package/dist/streamPrivacyRequestsToCsv-CBzh80oQ.mjs.map +1 -0
- package/dist/syncCodePackages-BOS5foh6.mjs +2 -0
- package/dist/syncCodePackages-BOS5foh6.mjs.map +1 -0
- package/dist/syncEnrichers-C9HcWCrs.mjs +3 -0
- package/dist/syncEnrichers-C9HcWCrs.mjs.map +1 -0
- package/dist/updateConsentManagerVersionToLatest-X1HAM_IX.mjs +2 -0
- package/dist/updateConsentManagerVersionToLatest-X1HAM_IX.mjs.map +1 -0
- package/dist/uploadConsents-BP5XILuw.mjs +2 -0
- package/dist/uploadConsents-BP5XILuw.mjs.map +1 -0
- package/dist/uploadCookiesFromCsv-B42cZgYW.mjs +2 -0
- package/dist/uploadCookiesFromCsv-B42cZgYW.mjs.map +1 -0
- package/dist/uploadDataFlowsFromCsv-D2V567pP.mjs +2 -0
- package/dist/uploadDataFlowsFromCsv-D2V567pP.mjs.map +1 -0
- package/dist/uploadPrivacyRequestsFromCsv-Czc3vGfJ.mjs +2 -0
- package/dist/uploadPrivacyRequestsFromCsv-Czc3vGfJ.mjs.map +1 -0
- package/dist/{validateTranscendAuth-1W1IylqE.mjs → validateTranscendAuth-DCwAtgvh.mjs} +2 -2
- package/dist/{validateTranscendAuth-1W1IylqE.mjs.map → validateTranscendAuth-DCwAtgvh.mjs.map} +1 -1
- package/dist/{writeCsv-B51ulrVl.mjs → writeCsv-Da8NUe1V.mjs} +1 -1
- package/dist/{writeCsv-B51ulrVl.mjs.map → writeCsv-Da8NUe1V.mjs.map} +1 -1
- package/package.json +10 -7
- package/dist/RateCounter-DFL_mnk2.mjs +0 -2
- package/dist/RateCounter-DFL_mnk2.mjs.map +0 -1
- package/dist/RequestDataSilo-_Iv44M9u.mjs.map +0 -1
- package/dist/approvePrivacyRequests-CWGZR2N6.mjs +0 -2
- package/dist/approvePrivacyRequests-CWGZR2N6.mjs.map +0 -1
- package/dist/assessment-BDywVaGR.mjs +0 -284
- package/dist/assessment-BDywVaGR.mjs.map +0 -1
- package/dist/bluebird-CUitXgsY.mjs +0 -2
- package/dist/bluebird-CUitXgsY.mjs.map +0 -1
- package/dist/buildXdiSyncEndpoint-Cb-pvpak.mjs +0 -9
- package/dist/buildXdiSyncEndpoint-Cb-pvpak.mjs.map +0 -1
- package/dist/bulkRestartRequests-CKF_xpN0.mjs +0 -2
- package/dist/bulkRestartRequests-CKF_xpN0.mjs.map +0 -1
- package/dist/bulkRetryEnrichers-B-Szmin-.mjs +0 -2
- package/dist/bulkRetryEnrichers-B-Szmin-.mjs.map +0 -1
- package/dist/cancelPrivacyRequests-DNiL13E_.mjs +0 -2
- package/dist/cancelPrivacyRequests-DNiL13E_.mjs.map +0 -1
- package/dist/codecs-Dx_vGxsl.mjs +0 -2
- package/dist/codecs-Dx_vGxsl.mjs.map +0 -1
- package/dist/constants-CeMiHaHx.mjs +0 -2
- package/dist/constants-CeMiHaHx.mjs.map +0 -1
- package/dist/createExtraKeyHandler-tubeaEjA.mjs +0 -23
- package/dist/createExtraKeyHandler-tubeaEjA.mjs.map +0 -1
- package/dist/createPreferenceAccessTokens-DqmFctn3.mjs +0 -10
- package/dist/createPreferenceAccessTokens-DqmFctn3.mjs.map +0 -1
- package/dist/createSombraGotInstance-D1Il9zUE.mjs +0 -10
- package/dist/createSombraGotInstance-D1Il9zUE.mjs.map +0 -1
- package/dist/dataFlowsToDataSilos-NhvBw1iy.mjs.map +0 -1
- package/dist/downloadPrivacyRequestFiles-DlpgxqHF.mjs +0 -2
- package/dist/downloadPrivacyRequestFiles-DlpgxqHF.mjs.map +0 -1
- package/dist/extractErrorMessage-CPnTsT1S.mjs +0 -2
- package/dist/extractErrorMessage-CPnTsT1S.mjs.map +0 -1
- package/dist/fetchAllActions-BJsPdnxy.mjs +0 -832
- package/dist/fetchAllActions-BJsPdnxy.mjs.map +0 -1
- package/dist/fetchAllDataFlows-D248lO6_.mjs +0 -2
- package/dist/fetchAllDataFlows-D248lO6_.mjs.map +0 -1
- package/dist/fetchAllPreferenceTopics-ForE9GpZ.mjs +0 -36
- package/dist/fetchAllPreferenceTopics-ForE9GpZ.mjs.map +0 -1
- package/dist/fetchAllPurposes-ZdkO2fMp.mjs +0 -29
- package/dist/fetchAllPurposes-ZdkO2fMp.mjs.map +0 -1
- package/dist/fetchAllPurposesAndPreferences-DD6OyA5t.mjs +0 -2
- package/dist/fetchAllPurposesAndPreferences-DD6OyA5t.mjs.map +0 -1
- package/dist/fetchAllRequestEnrichers-CK-kk5eg.mjs.map +0 -1
- package/dist/fetchAllRequestIdentifiers-DrFFOt0m.mjs +0 -10
- package/dist/fetchAllRequestIdentifiers-DrFFOt0m.mjs.map +0 -1
- package/dist/fetchAllRequests-DNQQsY4s.mjs +0 -2
- package/dist/fetchAllRequests-DNQQsY4s.mjs.map +0 -1
- package/dist/fetchApiKeys-DjOr44xA.mjs +0 -33
- package/dist/fetchApiKeys-DjOr44xA.mjs.map +0 -1
- package/dist/fetchCatalogs-BM4FCbcS.mjs +0 -12
- package/dist/fetchCatalogs-BM4FCbcS.mjs.map +0 -1
- package/dist/fetchConsentManagerId-CFkg3-RS.mjs +0 -321
- package/dist/fetchConsentManagerId-CFkg3-RS.mjs.map +0 -1
- package/dist/fetchIdentifiers-pjQV4vUg.mjs +0 -54
- package/dist/fetchIdentifiers-pjQV4vUg.mjs.map +0 -1
- package/dist/fetchRequestDataSilo-P4yA7Lyc.mjs +0 -2
- package/dist/fetchRequestDataSilo-P4yA7Lyc.mjs.map +0 -1
- package/dist/fetchRequestFilesForRequest-BbxrEKFK.mjs.map +0 -1
- package/dist/generateCrossAccountApiKeys-Bxc_dzMG.mjs +0 -33
- package/dist/generateCrossAccountApiKeys-Bxc_dzMG.mjs.map +0 -1
- package/dist/impl-4ltdSmpl2.mjs +0 -4
- package/dist/impl-4ltdSmpl2.mjs.map +0 -1
- package/dist/impl-B19fH75P.mjs +0 -12
- package/dist/impl-B19fH75P.mjs.map +0 -1
- package/dist/impl-BBMjv5YQ.mjs +0 -2
- package/dist/impl-BBMjv5YQ.mjs.map +0 -1
- package/dist/impl-BKH3QRLi.mjs +0 -3
- package/dist/impl-BKH3QRLi.mjs.map +0 -1
- package/dist/impl-BOUm7wly2.mjs.map +0 -1
- package/dist/impl-BhTCp0kg.mjs +0 -2
- package/dist/impl-BhTCp0kg.mjs.map +0 -1
- package/dist/impl-BlHU1bbJ2.mjs +0 -2
- package/dist/impl-BlHU1bbJ2.mjs.map +0 -1
- package/dist/impl-BwjguKHC.mjs +0 -4
- package/dist/impl-BwjguKHC.mjs.map +0 -1
- package/dist/impl-C2o0eDzJ.mjs +0 -2
- package/dist/impl-C2o0eDzJ.mjs.map +0 -1
- package/dist/impl-C8HKnjw82.mjs +0 -2
- package/dist/impl-C8HKnjw82.mjs.map +0 -1
- package/dist/impl-CCc-wXqD.mjs +0 -2
- package/dist/impl-CCc-wXqD.mjs.map +0 -1
- package/dist/impl-CMmyv1cl.mjs +0 -2
- package/dist/impl-CNykdy3e2.mjs.map +0 -1
- package/dist/impl-CSChmq_t2.mjs.map +0 -1
- package/dist/impl-Ce9K4OCp.mjs +0 -2
- package/dist/impl-Ce9K4OCp.mjs.map +0 -1
- package/dist/impl-ChCqHkOc2.mjs +0 -2
- package/dist/impl-ChCqHkOc2.mjs.map +0 -1
- package/dist/impl-CqEwwWeD.mjs +0 -2
- package/dist/impl-CqEwwWeD.mjs.map +0 -1
- package/dist/impl-CxLSJk2P.mjs +0 -2
- package/dist/impl-CxLSJk2P.mjs.map +0 -1
- package/dist/impl-CzU9WTiW.mjs +0 -2
- package/dist/impl-CzU9WTiW.mjs.map +0 -1
- package/dist/impl-D9NjIwEi2.mjs.map +0 -1
- package/dist/impl-DEWXA_QC.mjs +0 -2
- package/dist/impl-DGiPB5Vq2.mjs.map +0 -1
- package/dist/impl-DTp9OQIZ.mjs +0 -7
- package/dist/impl-DTp9OQIZ.mjs.map +0 -1
- package/dist/impl-DhscnXSw.mjs +0 -2
- package/dist/impl-DhscnXSw.mjs.map +0 -1
- package/dist/impl-Dk7MdX-1.mjs +0 -2
- package/dist/impl-Dk7MdX-1.mjs.map +0 -1
- package/dist/impl-DsNPvet4.mjs +0 -2
- package/dist/impl-DsNPvet4.mjs.map +0 -1
- package/dist/impl-DxUFb0vv.mjs +0 -2
- package/dist/impl-DxUFb0vv.mjs.map +0 -1
- package/dist/impl-KDuBh4bu2.mjs.map +0 -1
- package/dist/impl-c7rUQYDc2.mjs.map +0 -1
- package/dist/impl-oiBTZqQS2.mjs +0 -2
- package/dist/impl-oiBTZqQS2.mjs.map +0 -1
- package/dist/impl-tbGnvKFm.mjs +0 -2
- package/dist/impl-tbGnvKFm.mjs.map +0 -1
- package/dist/makeGraphQLRequest-Cq26A_Lq.mjs +0 -2
- package/dist/makeGraphQLRequest-Cq26A_Lq.mjs.map +0 -1
- package/dist/markRequestDataSiloIdsCompleted-DzqJ5MNY.mjs +0 -2
- package/dist/markRequestDataSiloIdsCompleted-DzqJ5MNY.mjs.map +0 -1
- package/dist/markSilentPrivacyRequests-BKQUu6Ep.mjs +0 -2
- package/dist/markSilentPrivacyRequests-BKQUu6Ep.mjs.map +0 -1
- package/dist/mergeTranscendInputs-DGC4xUGu.mjs +0 -2
- package/dist/mergeTranscendInputs-DGC4xUGu.mjs.map +0 -1
- package/dist/notifyPrivacyRequestsAdditionalTime-TEHAJe4C.mjs +0 -2
- package/dist/notifyPrivacyRequestsAdditionalTime-TEHAJe4C.mjs.map +0 -1
- package/dist/package-C4J38oR1.mjs +0 -2
- package/dist/package-C4J38oR1.mjs.map +0 -1
- package/dist/parquetToCsvOneFile-DZVKXrjn.mjs +0 -6
- package/dist/parquetToCsvOneFile-DZVKXrjn.mjs.map +0 -1
- package/dist/parseAttributesFromString-CZStzJc0.mjs +0 -2
- package/dist/pullAllDatapoints-Cntwuzw7.mjs +0 -45
- package/dist/pullAllDatapoints-Cntwuzw7.mjs.map +0 -1
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-BT-GZpT1.mjs +0 -2
- package/dist/pullChunkedCustomSiloOutstandingIdentifiers-BT-GZpT1.mjs.map +0 -1
- package/dist/pullConsentManagerMetrics-FnhPEszu.mjs +0 -2
- package/dist/pullConsentManagerMetrics-FnhPEszu.mjs.map +0 -1
- package/dist/pullManualEnrichmentIdentifiersToCsv-B_4REnga.mjs +0 -2
- package/dist/pullManualEnrichmentIdentifiersToCsv-B_4REnga.mjs.map +0 -1
- package/dist/pullTranscendConfiguration-CqsgEf9A.mjs +0 -80
- package/dist/pullTranscendConfiguration-CqsgEf9A.mjs.map +0 -1
- package/dist/pullUnstructuredSubDataPointRecommendations-DZd2q6S2.mjs.map +0 -1
- package/dist/pushCronIdentifiersFromCsv-D2saGR5i.mjs +0 -2
- package/dist/pushCronIdentifiersFromCsv-D2saGR5i.mjs.map +0 -1
- package/dist/pushManualEnrichmentIdentifiersFromCsv-DOvAzMyt.mjs +0 -2
- package/dist/pushManualEnrichmentIdentifiersFromCsv-DOvAzMyt.mjs.map +0 -1
- package/dist/removeUnverifiedRequestIdentifiers-ChlwRmhd.mjs +0 -35
- package/dist/removeUnverifiedRequestIdentifiers-ChlwRmhd.mjs.map +0 -1
- package/dist/retryRequestDataSilos-DnwXA1YZ.mjs +0 -2
- package/dist/retryRequestDataSilos-DnwXA1YZ.mjs.map +0 -1
- package/dist/skipPreflightJobs-jK5lNlmv.mjs +0 -2
- package/dist/skipPreflightJobs-jK5lNlmv.mjs.map +0 -1
- package/dist/skipRequestDataSilos-DQGroOos.mjs +0 -2
- package/dist/skipRequestDataSilos-DQGroOos.mjs.map +0 -1
- package/dist/splitCsvToList-BRq_CIfd.mjs +0 -2
- package/dist/splitCsvToList-BRq_CIfd.mjs.map +0 -1
- package/dist/streamPrivacyRequestsToCsv-BK07Bm-T.mjs +0 -2
- package/dist/streamPrivacyRequestsToCsv-BK07Bm-T.mjs.map +0 -1
- package/dist/syncCodePackages-F-97FNjo.mjs +0 -232
- package/dist/syncCodePackages-F-97FNjo.mjs.map +0 -1
- package/dist/syncCookies-BxY36BeJ.mjs +0 -2
- package/dist/syncCookies-BxY36BeJ.mjs.map +0 -1
- package/dist/syncDataFlows-Cx5LZCen.mjs +0 -2
- package/dist/syncDataFlows-Cx5LZCen.mjs.map +0 -1
- package/dist/syncTemplates-BrH7Yr0V.mjs +0 -23
- package/dist/syncTemplates-BrH7Yr0V.mjs.map +0 -1
- package/dist/time-Bl_c3W8U.mjs +0 -2
- package/dist/time-Bl_c3W8U.mjs.map +0 -1
- package/dist/types-B4CVJCpj.mjs +0 -2
- package/dist/types-B4CVJCpj.mjs.map +0 -1
- package/dist/updateConsentManagerVersionToLatest-C221vAAw.mjs +0 -2
- package/dist/updateConsentManagerVersionToLatest-C221vAAw.mjs.map +0 -1
- package/dist/uploadConsents-BbR7_sSt.mjs +0 -2
- package/dist/uploadConsents-BbR7_sSt.mjs.map +0 -1
- package/dist/uploadCookiesFromCsv-roHWekOP.mjs +0 -2
- package/dist/uploadCookiesFromCsv-roHWekOP.mjs.map +0 -1
- package/dist/uploadDataFlowsFromCsv-DcTbrsv2.mjs +0 -2
- package/dist/uploadDataFlowsFromCsv-DcTbrsv2.mjs.map +0 -1
- package/dist/uploadPrivacyRequestsFromCsv-BUGTS-pY.mjs +0 -17
- package/dist/uploadPrivacyRequestsFromCsv-BUGTS-pY.mjs.map +0 -1
- package/dist/uploadSiloDiscoveryResults-D2fK92WR.mjs +0 -20
- package/dist/uploadSiloDiscoveryResults-D2fK92WR.mjs.map +0 -1
- package/dist/withPreferenceRetry-xLMZyTq9.mjs +0 -2
- package/dist/withPreferenceRetry-xLMZyTq9.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"command-BXxoAjFo.mjs","names":[],"sources":["../src/lib/cli/parsers.ts","../src/lib/cli/common-parameters.ts","../src/commands/inventory/pull/command.ts"],"sourcesContent":["import ms, { type StringValue as MsStringValue } from 'ms';\n\n/**\n * Validates and returns a UUID string.\n *\n * @param input - The input string to validate as UUID\n * @returns The validated UUID string\n * @throws Error if input is not a valid UUID\n */\nexport function uuidParser(input: string): string {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n if (!uuidRegex.test(input)) {\n throw new Error(`Invalid UUID format: ${input}`);\n }\n return input;\n}\n\n/**\n * Validates and returns a URL string.\n *\n * @param input - The input string to validate as URL\n * @returns The validated URL string\n * @throws Error if input is not a valid URL\n */\nexport function urlParser(input: string): string {\n try {\n const url = new URL(input);\n return url.toString().replace(/\\/$/, '');\n } catch {\n throw new Error(`Invalid URL format: ${input}`);\n }\n}\n\n/**\n * Parse a comma-separated string to array.\n * NOTE: Prefer using `variadic` for list arguments instead of this function. This should only be used for arguments which have a default value.\n *\n * @param input - The comma-separated string to parse\n * @returns Array of trimmed, non-empty strings\n */\nexport function arrayParser(input: string): string[] {\n return input\n .split(',')\n .map((s) => s.trim())\n .filter((s) => s.length > 0);\n}\n\n/**\n * Parse a date string to a Date object.\n *\n * @param input - The date string to parse\n * @returns The parsed Date object\n * @throws TypeError if input is not a valid date\n */\nexport function dateParser(input: string): Date {\n const date = new Date(input);\n if (Number.isNaN(date.getTime())) {\n throw new TypeError(\n `Invalid date: ${input}. Try using the ISO 8601 format (YYYY-MM-DDTHH:MM:SS.SSSZ)`,\n );\n }\n return date;\n}\n\n/**\n * Parse a duration string to milliseconds.\n * Accepts concise/natural-ish strings (powered by `ms`) and returns milliseconds.\n * Examples: \"3600\", \"2d\", \"1h\", \"90 minutes\", \"10s\".\n *\n * @param input - The duration to parse\n * @returns The parsed duration in milliseconds\n * @throws Error if input is not a valid duration\n */\nexport function parseDurationToMs(input: unknown): number {\n if (typeof input === 'number' && Number.isFinite(input)) {\n // backward-compat: numbers => seconds\n return Math.round(input * 1000);\n }\n\n if (typeof input === 'string') {\n const trimmed = input.trim();\n // empty string → our standardized error (avoid ms throwing its own)\n if (trimmed === '') {\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n }\n\n // bare numeric string => seconds (backward-compat)\n const asNumber = Number(trimmed);\n if (trimmed !== '' && Number.isFinite(asNumber)) {\n return Math.round(asNumber * 1000);\n }\n\n // let ms parse human strings\n let parsed: number | undefined;\n try {\n parsed = ms(trimmed as MsStringValue);\n } catch {\n // normalize ms' error to ours\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n }\n if (typeof parsed === 'number' && Number.isFinite(parsed)) {\n return parsed;\n }\n }\n\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n}\n","import type { TypedFlagParameter } from '@stricli/core';\nimport { ScopeName, TRANSCEND_SCOPES } from '@transcend-io/privacy-types';\n\nimport { DEFAULT_TRANSCEND_API, DEFAULT_TRANSCEND_CONSENT_API } from '../../constants.js';\nimport type { LocalContext } from '../../context.js';\nimport { urlParser } from './parsers.js';\n\n/**\n * Common parameter builders for CLI commands\n * These reduce duplication and ensure consistency across commands\n */\n\n/**\n * Creates a standard authentication parameter\n *\n * @param root0 - The scopes and whether it requires a silo scope\n * @returns The parameter object\n */\nexport const createAuthParameter = ({\n scopes,\n requiresSiloScope = false,\n}: {\n /** The scopes required for the command */\n scopes: ScopeName[] | 'Varies';\n /** Whether the command requires a silo scope */\n requiresSiloScope?: boolean;\n}): TypedFlagParameter<string, LocalContext> => {\n const parameter = {\n kind: 'parsed' as const,\n parse: String,\n brief: 'The Transcend API key.',\n };\n\n if (requiresSiloScope) {\n parameter.brief += ' This key must be associated with the data silo(s) being operated on.';\n }\n\n if (scopes === 'Varies') {\n return {\n ...parameter,\n brief: `${\n parameter.brief\n } The scopes required will vary depending on the operation performed. If in doubt, the ${\n TRANSCEND_SCOPES[ScopeName.FullAdmin].title\n } scope will always work.`,\n };\n }\n\n if (scopes.length === 0) {\n return {\n ...parameter,\n brief: `${parameter.brief} No scopes are required for this command.`,\n };\n }\n\n return {\n ...parameter,\n brief: `${parameter.brief} Requires scopes: ${scopes\n .map((s) => `\"${TRANSCEND_SCOPES[s].title}\"`)\n .join(', ')}`,\n };\n};\n\n/**\n * Creates a standard Transcend URL parameter\n *\n * @param defaultUrl - The default URL to use if not provided\n * @returns The parameter object\n */\nexport const createTranscendUrlParameter = (\n defaultUrl = DEFAULT_TRANSCEND_API,\n): TypedFlagParameter<string, LocalContext> => ({\n kind: 'parsed',\n parse: urlParser,\n brief: 'URL of the Transcend backend. Use https://api.us.transcend.io for US hosting',\n default: defaultUrl,\n});\n\n/**\n * Creates a standard Consent URL parameter\n *\n * @param defaultUrl - The default URL to use if not provided\n * @returns The parameter object\n */\nexport const createConsentUrlParameter = (\n defaultUrl = DEFAULT_TRANSCEND_CONSENT_API,\n): TypedFlagParameter<string, LocalContext> => ({\n kind: 'parsed',\n parse: urlParser,\n brief: 'URL of the Transcend consent backend. Use https://consent.us.transcend.io for US hosting',\n default: defaultUrl,\n});\n\n/**\n * Creates a standard Sombra authentication parameter\n *\n * @returns The parameter object\n */\nexport const createSombraAuthParameter = (): TypedFlagParameter<\n string | undefined,\n LocalContext\n> => ({\n kind: 'parsed',\n parse: String,\n brief: 'The Sombra internal key, use for additional authentication when self-hosting Sombra',\n optional: true,\n});\n","import { buildCommand, numberParser } from '@stricli/core';\nimport { ConsentTrackerStatus } from '@transcend-io/privacy-types';\n\nimport { TranscendPullResource } from '../../../enums.js';\nimport {\n createAuthParameter,\n createTranscendUrlParameter,\n} from '../../../lib/cli/common-parameters.js';\n\nexport const DEFAULT_TRANSCEND_PULL_RESOURCES = [\n TranscendPullResource.DataSilos,\n TranscendPullResource.Enrichers,\n TranscendPullResource.Templates,\n TranscendPullResource.ApiKeys,\n];\n\nexport const DEFAULT_CONSENT_TRACKER_STATUSES = Object.values(ConsentTrackerStatus);\n\nexport const pullCommand = buildCommand({\n loader: async () => {\n const { pull } = await import('./impl.js');\n return pull;\n },\n parameters: {\n flags: {\n auth: createAuthParameter({\n scopes: 'Varies',\n }),\n resources: {\n kind: 'enum',\n values: ['all', ...Object.values(TranscendPullResource)],\n brief: `The different resource types to pull in. Defaults to ${DEFAULT_TRANSCEND_PULL_RESOURCES.join(\n ',',\n )}.`,\n variadic: ',',\n optional: true,\n },\n file: {\n kind: 'parsed',\n parse: String,\n brief: 'Path to the YAML file to pull into',\n default: './transcend.yml',\n },\n transcendUrl: createTranscendUrlParameter(),\n dataSiloIds: {\n kind: 'parsed',\n parse: String,\n variadic: ',',\n brief: 'The UUIDs of the data silos that should be pulled into the YAML file',\n optional: true,\n },\n integrationNames: {\n kind: 'parsed',\n parse: String,\n variadic: ',',\n brief: 'The types of integrations to pull down',\n optional: true,\n },\n trackerStatuses: {\n kind: 'enum',\n values: Object.values(ConsentTrackerStatus),\n variadic: ',',\n brief: 'The statuses of consent manager trackers to pull down. Defaults to all statuses.',\n optional: true,\n },\n pageSize: {\n kind: 'parsed',\n parse: numberParser,\n brief: 'The page size to use when paginating over the API',\n default: '50',\n },\n skipDatapoints: {\n kind: 'boolean',\n brief: 'When true, skip pulling in datapoints alongside data silo resource',\n default: false,\n },\n skipSubDatapoints: {\n kind: 'boolean',\n brief: 'When true, skip pulling in subDatapoints alongside data silo resource',\n default: false,\n },\n includeGuessedCategories: {\n kind: 'boolean',\n brief: 'When true, included guessed data categories that came from the content classifier',\n default: false,\n },\n debug: {\n kind: 'boolean',\n brief: 'Set to true to include debug logs while pulling the configuration',\n default: false,\n },\n },\n },\n docs: {\n brief: 'Pull metadata from Transcend into transcend.yml',\n fullDescription: `Generates a transcend.yml by pulling the configuration from your Transcend instance.\n\nThe API key needs various scopes depending on the resources being pulled (see the CLI's README for more details).\n\nThis command can be helpful if you are looking to:\n\n- Copy your data into another instance\n- Generate a transcend.yml file as a starting point to maintain parts of your data inventory in code.`,\n },\n});\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"command-rzZKmlky.mjs","names":[],"sources":["../src/lib/cli/parsers.ts","../src/lib/cli/common-parameters.ts","../src/commands/inventory/pull/command.ts"],"sourcesContent":["import ms, { type StringValue as MsStringValue } from 'ms';\n\n/**\n * Validates and returns a UUID string.\n *\n * @param input - The input string to validate as UUID\n * @returns The validated UUID string\n * @throws Error if input is not a valid UUID\n */\nexport function uuidParser(input: string): string {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n if (!uuidRegex.test(input)) {\n throw new Error(`Invalid UUID format: ${input}`);\n }\n return input;\n}\n\n/**\n * Validates and returns a URL string.\n *\n * @param input - The input string to validate as URL\n * @returns The validated URL string\n * @throws Error if input is not a valid URL\n */\nexport function urlParser(input: string): string {\n try {\n const url = new URL(input);\n return url.toString().replace(/\\/$/, '');\n } catch {\n throw new Error(`Invalid URL format: ${input}`);\n }\n}\n\n/**\n * Parse a comma-separated string to array.\n * NOTE: Prefer using `variadic` for list arguments instead of this function. This should only be used for arguments which have a default value.\n *\n * @param input - The comma-separated string to parse\n * @returns Array of trimmed, non-empty strings\n */\nexport function arrayParser(input: string): string[] {\n return input\n .split(',')\n .map((s) => s.trim())\n .filter((s) => s.length > 0);\n}\n\n/**\n * Parse a date string to a Date object.\n *\n * @param input - The date string to parse\n * @returns The parsed Date object\n * @throws TypeError if input is not a valid date\n */\nexport function dateParser(input: string): Date {\n const date = new Date(input);\n if (Number.isNaN(date.getTime())) {\n throw new TypeError(\n `Invalid date: ${input}. Try using the ISO 8601 format (YYYY-MM-DDTHH:MM:SS.SSSZ)`,\n );\n }\n return date;\n}\n\n/**\n * Parse a duration string to milliseconds.\n * Accepts concise/natural-ish strings (powered by `ms`) and returns milliseconds.\n * Examples: \"3600\", \"2d\", \"1h\", \"90 minutes\", \"10s\".\n *\n * @param input - The duration to parse\n * @returns The parsed duration in milliseconds\n * @throws Error if input is not a valid duration\n */\nexport function parseDurationToMs(input: unknown): number {\n if (typeof input === 'number' && Number.isFinite(input)) {\n // backward-compat: numbers => seconds\n return Math.round(input * 1000);\n }\n\n if (typeof input === 'string') {\n const trimmed = input.trim();\n // empty string → our standardized error (avoid ms throwing its own)\n if (trimmed === '') {\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n }\n\n // bare numeric string => seconds (backward-compat)\n const asNumber = Number(trimmed);\n if (trimmed !== '' && Number.isFinite(asNumber)) {\n return Math.round(asNumber * 1000);\n }\n\n // let ms parse human strings\n let parsed: number | undefined;\n try {\n parsed = ms(trimmed as MsStringValue);\n } catch {\n // normalize ms' error to ours\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n }\n if (typeof parsed === 'number' && Number.isFinite(parsed)) {\n return parsed;\n }\n }\n\n throw new Error('Invalid duration. Examples: \"45\", \"2d\", \"1h\", \"90 minutes\", \"10s\".');\n}\n","import type { TypedFlagParameter } from '@stricli/core';\nimport { ScopeName, TRANSCEND_SCOPES } from '@transcend-io/privacy-types';\n\nimport { DEFAULT_TRANSCEND_API, DEFAULT_TRANSCEND_CONSENT_API } from '../../constants.js';\nimport type { LocalContext } from '../../context.js';\nimport { urlParser } from './parsers.js';\n\n/**\n * Common parameter builders for CLI commands\n * These reduce duplication and ensure consistency across commands\n */\n\n/**\n * Creates a standard authentication parameter\n *\n * @param root0 - The scopes and whether it requires a silo scope\n * @returns The parameter object\n */\nexport const createAuthParameter = ({\n scopes,\n requiresSiloScope = false,\n}: {\n /** The scopes required for the command */\n scopes: ScopeName[] | 'Varies';\n /** Whether the command requires a silo scope */\n requiresSiloScope?: boolean;\n}): TypedFlagParameter<string, LocalContext> => {\n const parameter = {\n kind: 'parsed' as const,\n parse: String,\n brief: 'The Transcend API key.',\n };\n\n if (requiresSiloScope) {\n parameter.brief += ' This key must be associated with the data silo(s) being operated on.';\n }\n\n if (scopes === 'Varies') {\n return {\n ...parameter,\n brief: `${\n parameter.brief\n } The scopes required will vary depending on the operation performed. If in doubt, the ${\n TRANSCEND_SCOPES[ScopeName.FullAdmin].title\n } scope will always work.`,\n };\n }\n\n if (scopes.length === 0) {\n return {\n ...parameter,\n brief: `${parameter.brief} No scopes are required for this command.`,\n };\n }\n\n return {\n ...parameter,\n brief: `${parameter.brief} Requires scopes: ${scopes\n .map((s) => `\"${TRANSCEND_SCOPES[s].title}\"`)\n .join(', ')}`,\n };\n};\n\n/**\n * Creates a standard Transcend URL parameter\n *\n * @param defaultUrl - The default URL to use if not provided\n * @returns The parameter object\n */\nexport const createTranscendUrlParameter = (\n defaultUrl = DEFAULT_TRANSCEND_API,\n): TypedFlagParameter<string, LocalContext> => ({\n kind: 'parsed',\n parse: urlParser,\n brief: 'URL of the Transcend backend. Use https://api.us.transcend.io for US hosting',\n default: defaultUrl,\n});\n\n/**\n * Creates a standard Consent URL parameter\n *\n * @param defaultUrl - The default URL to use if not provided\n * @returns The parameter object\n */\nexport const createConsentUrlParameter = (\n defaultUrl = DEFAULT_TRANSCEND_CONSENT_API,\n): TypedFlagParameter<string, LocalContext> => ({\n kind: 'parsed',\n parse: urlParser,\n brief: 'URL of the Transcend consent backend. Use https://consent.us.transcend.io for US hosting',\n default: defaultUrl,\n});\n\n/**\n * Creates a standard Sombra authentication parameter\n *\n * @returns The parameter object\n */\nexport const createSombraAuthParameter = (): TypedFlagParameter<\n string | undefined,\n LocalContext\n> => ({\n kind: 'parsed',\n parse: String,\n brief: 'The Sombra internal key, use for additional authentication when self-hosting Sombra',\n optional: true,\n});\n","import { buildCommand, numberParser } from '@stricli/core';\nimport { ConsentTrackerStatus } from '@transcend-io/privacy-types';\n\nimport { TranscendPullResource } from '../../../enums.js';\nimport {\n createAuthParameter,\n createTranscendUrlParameter,\n} from '../../../lib/cli/common-parameters.js';\n\nexport const DEFAULT_TRANSCEND_PULL_RESOURCES = [\n TranscendPullResource.DataSilos,\n TranscendPullResource.Enrichers,\n TranscendPullResource.Templates,\n TranscendPullResource.ApiKeys,\n];\n\nexport const DEFAULT_CONSENT_TRACKER_STATUSES = Object.values(ConsentTrackerStatus);\n\nexport const pullCommand = buildCommand({\n loader: async () => {\n const { pull } = await import('./impl.js');\n return pull;\n },\n parameters: {\n flags: {\n auth: createAuthParameter({\n scopes: 'Varies',\n }),\n resources: {\n kind: 'enum',\n values: ['all', ...Object.values(TranscendPullResource)],\n brief: `The different resource types to pull in. Defaults to ${DEFAULT_TRANSCEND_PULL_RESOURCES.join(\n ',',\n )}.`,\n variadic: ',',\n optional: true,\n },\n file: {\n kind: 'parsed',\n parse: String,\n brief: 'Path to the YAML file to pull into',\n default: './transcend.yml',\n },\n transcendUrl: createTranscendUrlParameter(),\n dataSiloIds: {\n kind: 'parsed',\n parse: String,\n variadic: ',',\n brief: 'The UUIDs of the data silos that should be pulled into the YAML file',\n optional: true,\n },\n integrationNames: {\n kind: 'parsed',\n parse: String,\n variadic: ',',\n brief: 'The types of integrations to pull down',\n optional: true,\n },\n trackerStatuses: {\n kind: 'enum',\n values: Object.values(ConsentTrackerStatus),\n variadic: ',',\n brief: 'The statuses of consent manager trackers to pull down. Defaults to all statuses.',\n optional: true,\n },\n pageSize: {\n kind: 'parsed',\n parse: numberParser,\n brief: 'The page size to use when paginating over the API',\n default: '50',\n },\n skipDatapoints: {\n kind: 'boolean',\n brief: 'When true, skip pulling in datapoints alongside data silo resource',\n default: false,\n },\n skipSubDatapoints: {\n kind: 'boolean',\n brief: 'When true, skip pulling in subDatapoints alongside data silo resource',\n default: false,\n },\n includeGuessedCategories: {\n kind: 'boolean',\n brief: 'When true, included guessed data categories that came from the content classifier',\n default: false,\n },\n debug: {\n kind: 'boolean',\n brief: 'Set to true to include debug logs while pulling the configuration',\n default: false,\n },\n },\n },\n docs: {\n brief: 'Pull metadata from Transcend into transcend.yml',\n fullDescription: `Generates a transcend.yml by pulling the configuration from your Transcend instance.\n\nThe API key needs various scopes depending on the resources being pulled (see the CLI's README for more details).\n\nThis command can be helpful if you are looking to:\n\n- Copy your data into another instance\n- Generate a transcend.yml file as a starting point to maintain parts of your data inventory in code.`,\n },\n});\n"],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
//#region src/commands/admin/chunk-csv/worker.d.ts
|
|
2
|
+
/**
|
|
3
|
+
* A unit of work: instructs a worker to chunk a single CSV file.
|
|
4
|
+
*/
|
|
5
|
+
type ChunkTask = {
|
|
6
|
+
/** Absolute path of the CSV file to chunk. */filePath: string; /** Options controlling output and chunk size. */
|
|
7
|
+
options: {
|
|
8
|
+
/** Optional directory where chunked output files should be written. */outputDir?: string; /** Whether to clear any pre-existing output chunks before writing new ones. */
|
|
9
|
+
clearOutputDir: boolean; /** Approximate target chunk size in MB (well under Node’s string size limits). */
|
|
10
|
+
chunkSizeMB: number;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Per-worker progress snapshot for the chunk-csv command.
|
|
15
|
+
*/
|
|
16
|
+
type ChunkProgress = {
|
|
17
|
+
/** File being processed by the worker. */filePath: string; /** Number of rows processed so far. */
|
|
18
|
+
processed: number; /** Optional total rows in the file (not always known). */
|
|
19
|
+
total?: number;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Worker result message once a file has finished processing.
|
|
23
|
+
*/
|
|
24
|
+
type ChunkResult = {
|
|
25
|
+
/** Whether the file completed successfully. */ok: boolean; /** File path for which this result applies. */
|
|
26
|
+
filePath: string; /** Optional error message if the file failed to chunk. */
|
|
27
|
+
error?: string;
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* Worker entrypoint.
|
|
31
|
+
*
|
|
32
|
+
* Lifecycle:
|
|
33
|
+
* 1) Announce readiness to the parent via `{ type: 'ready' }`.
|
|
34
|
+
* 2) Wait for `{ type: 'task' }` messages; for each, call `chunkOneCsvFile(...)`.
|
|
35
|
+
* - While chunking, forward progress to the parent via `{ type: 'progress' }`.
|
|
36
|
+
* - On completion, send `{ type: 'result', ok: true }`.
|
|
37
|
+
* - On error, send `{ type: 'result', ok: false, error }` and exit(1).
|
|
38
|
+
* 3) On `{ type: 'shutdown' }`, exit(0) gracefully.
|
|
39
|
+
*
|
|
40
|
+
* Notes:
|
|
41
|
+
* - This process is typically spawned by a pool manager that assigns file paths to workers.
|
|
42
|
+
* - The long-lived promise at the end keeps the worker alive between tasks until the parent
|
|
43
|
+
* sends an explicit shutdown.
|
|
44
|
+
*/
|
|
45
|
+
declare function runChild(): Promise<void>;
|
|
46
|
+
//#endregion
|
|
47
|
+
export { ChunkProgress, ChunkResult, ChunkTask, runChild };
|
|
48
|
+
//# sourceMappingURL=worker.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.d.mts","names":[],"sources":["../../../../src/commands/admin/chunk-csv/worker.ts"],"mappings":";;AAYA;;KAAY,SAAA;EAAS,8CAEnB,QAAA,UAEA;EAAA,OAAA;IAIE,uEAFA,SAAA,WAIW;IAFX,cAAA,WASQ;IAPR,WAAA;EAAA;AAAA;;;;KAOQ,aAAA;EAML,0CAJL,QAAA,UAUqB;EARrB,SAAA,UAQqB;EANrB,KAAA;AAAA;;;;KAMU,WAAA;EAyBkB,+CAvB5B,EAAA,WAuBgC;EArBhC,QAAA;EAEA,KAAA;AAAA;;;;;;;;;;;;;;;;;iBAmBoB,QAAA,CAAA,GAAY,OAAA"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{t as e}from"../../../logger-Bj782ZYD.mjs";import{CHILD_FLAG as t,chunkOneCsvFile as n,extractErrorMessage as r}from"@transcend-io/utils";async function i(){let t=Number(process.env.WORKER_ID||`0`);e.info(`[w${t}] ready pid=${process.pid}`),process.send?.({type:`ready`}),process.on(`message`,async i=>{if(!i||typeof i!=`object`||(i.type===`shutdown`&&process.exit(0),i.type!==`task`))return;let{filePath:a,options:o}=i.payload,{outputDir:s,clearOutputDir:c,chunkSizeMB:l}=o;try{await n({filePath:a,outputDir:s,clearOutputDir:c,chunkSizeMB:l,logger:e,onProgress:(e,t)=>process.send?.({type:`progress`,payload:{filePath:a,processed:e,total:t}})}),process.send?.({type:`result`,payload:{ok:!0,filePath:a}})}catch(n){let i=r(n);e.error(`[w${t}] ERROR ${a}: ${i}`),process.send?.({type:`result`,payload:{ok:!1,filePath:a,error:i}})}}),await new Promise(()=>{})}process.argv.includes(t)&&i().catch(t=>{e.error(t),process.exit(1)});export{i as runChild};
|
|
2
|
+
//# sourceMappingURL=worker.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.mjs","names":[],"sources":["../../../../src/commands/admin/chunk-csv/worker.ts"],"sourcesContent":["import {\n chunkOneCsvFile,\n extractErrorMessage,\n CHILD_FLAG,\n type ToWorker,\n} from '@transcend-io/utils';\n\nimport { logger } from '../../../logger.js';\n\n/**\n * A unit of work: instructs a worker to chunk a single CSV file.\n */\nexport type ChunkTask = {\n /** Absolute path of the CSV file to chunk. */\n filePath: string;\n /** Options controlling output and chunk size. */\n options: {\n /** Optional directory where chunked output files should be written. */\n outputDir?: string;\n /** Whether to clear any pre-existing output chunks before writing new ones. */\n clearOutputDir: boolean;\n /** Approximate target chunk size in MB (well under Node’s string size limits). */\n chunkSizeMB: number;\n };\n};\n\n/**\n * Per-worker progress snapshot for the chunk-csv command.\n */\nexport type ChunkProgress = {\n /** File being processed by the worker. */\n filePath: string;\n /** Number of rows processed so far. */\n processed: number;\n /** Optional total rows in the file (not always known). */\n total?: number;\n};\n\n/**\n * Worker result message once a file has finished processing.\n */\nexport type ChunkResult = {\n /** Whether the file completed successfully. */\n ok: boolean;\n /** File path for which this result applies. */\n filePath: string;\n /** Optional error message if the file failed to chunk. */\n error?: string;\n};\n\n/**\n * Worker entrypoint.\n *\n * Lifecycle:\n * 1) Announce readiness to the parent via `{ type: 'ready' }`.\n * 2) Wait for `{ type: 'task' }` messages; for each, call `chunkOneCsvFile(...)`.\n * - While chunking, forward progress to the parent via `{ type: 'progress' }`.\n * - On completion, send `{ type: 'result', ok: true }`.\n * - On error, send `{ type: 'result', ok: false, error }` and exit(1).\n * 3) On `{ type: 'shutdown' }`, exit(0) gracefully.\n *\n * Notes:\n * - This process is typically spawned by a pool manager that assigns file paths to workers.\n * - The long-lived promise at the end keeps the worker alive between tasks until the parent\n * sends an explicit shutdown.\n */\nexport async function runChild(): Promise<void> {\n const workerId = Number(process.env.WORKER_ID || '0');\n logger.info(`[w${workerId}] ready pid=${process.pid}`);\n\n // Notify the parent that the worker is ready to receive tasks.\n process.send?.({ type: 'ready' });\n\n // Main message loop: receive tasks and shutdown requests from the parent.\n process.on('message', async (msg: ToWorker<ChunkTask>) => {\n if (!msg || typeof msg !== 'object') return;\n\n // Graceful shutdown: let the parent control lifecycle.\n if (msg.type === 'shutdown') {\n process.exit(0);\n }\n\n // Only handle task messages here.\n if (msg.type !== 'task') return;\n\n const { filePath, options } = msg.payload;\n const { outputDir, clearOutputDir, chunkSizeMB } = options;\n\n try {\n // Stream the input CSV and write chunk files asynchronously.\n await chunkOneCsvFile({\n filePath,\n outputDir,\n clearOutputDir,\n chunkSizeMB,\n logger,\n onProgress: (processed, total) =>\n process.send?.({\n type: 'progress',\n payload: { filePath, processed, total },\n }),\n });\n\n // Report success to the parent.\n process.send?.({\n type: 'result',\n payload: { ok: true, filePath },\n });\n } catch (err) {\n // Log locally and report failure upstream; exit the worker with error code.\n const message = extractErrorMessage(err);\n logger.error(`[w${workerId}] ERROR ${filePath}: ${message}`);\n process.send?.({\n type: 'result',\n payload: { ok: false, filePath, error: message },\n });\n }\n });\n\n // keep alive\n await new Promise<never>(() => {\n // This promise never resolves, keeping the worker alive indefinitely\n // until the parent process instructs shutdown.\n });\n}\n\nif (process.argv.includes(CHILD_FLAG)) {\n runChild().catch((err) => {\n logger.error(err);\n process.exit(1);\n });\n}\n"],"mappings":"gJAkEA,eAAsB,GAA0B,CAC9C,IAAM,EAAW,OAAO,QAAQ,IAAI,WAAa,IAAI,CACrD,EAAO,KAAK,KAAK,EAAS,cAAc,QAAQ,MAAM,CAGtD,QAAQ,OAAO,CAAE,KAAM,QAAS,CAAC,CAGjC,QAAQ,GAAG,UAAW,KAAO,IAA6B,CASxD,GARI,CAAC,GAAO,OAAO,GAAQ,WAGvB,EAAI,OAAS,YACf,QAAQ,KAAK,EAAE,CAIb,EAAI,OAAS,QAAQ,OAEzB,GAAM,CAAE,WAAU,WAAY,EAAI,QAC5B,CAAE,YAAW,iBAAgB,eAAgB,EAEnD,GAAI,CAEF,MAAM,EAAgB,CACpB,WACA,YACA,iBACA,cACA,SACA,YAAa,EAAW,IACtB,QAAQ,OAAO,CACb,KAAM,WACN,QAAS,CAAE,WAAU,YAAW,QAAO,CACxC,CAAC,CACL,CAAC,CAGF,QAAQ,OAAO,CACb,KAAM,SACN,QAAS,CAAE,GAAI,GAAM,WAAU,CAChC,CAAC,OACK,EAAK,CAEZ,IAAM,EAAU,EAAoB,EAAI,CACxC,EAAO,MAAM,KAAK,EAAS,UAAU,EAAS,IAAI,IAAU,CAC5D,QAAQ,OAAO,CACb,KAAM,SACN,QAAS,CAAE,GAAI,GAAO,WAAU,MAAO,EAAS,CACjD,CAAC,GAEJ,CAGF,MAAM,IAAI,YAAqB,GAG7B,CAGA,QAAQ,KAAK,SAAS,EAAW,EACnC,GAAU,CAAC,MAAO,GAAQ,CACxB,EAAO,MAAM,EAAI,CACjB,QAAQ,KAAK,EAAE,EACf"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
//#region src/commands/admin/parquet-to-csv/worker.d.ts
|
|
2
|
+
type ParquetTask = {
|
|
3
|
+
/** Absolute path of the Parquet file to convert. */filePath: string;
|
|
4
|
+
options: {
|
|
5
|
+
/** Optional directory where CSV output files should be written. */outputDir?: string; /** Whether to clear any pre-existing output before writing new ones. */
|
|
6
|
+
clearOutputDir: boolean;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
type ParquetProgress = {
|
|
10
|
+
/** File being processed by the worker. */filePath: string; /** Rows processed so far. */
|
|
11
|
+
processed: number; /** Optional known total rows (not always available). */
|
|
12
|
+
total?: number;
|
|
13
|
+
};
|
|
14
|
+
type ParquetResult = {
|
|
15
|
+
ok: boolean;
|
|
16
|
+
filePath: string;
|
|
17
|
+
error?: string;
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Worker loop: convert a single Parquet file to one or more CSV files.
|
|
21
|
+
*/
|
|
22
|
+
declare function runChild(): Promise<void>;
|
|
23
|
+
//#endregion
|
|
24
|
+
export { ParquetProgress, ParquetResult, ParquetTask, runChild };
|
|
25
|
+
//# sourceMappingURL=worker.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.d.mts","names":[],"sources":["../../../../src/commands/admin/parquet-to-csv/worker.ts"],"mappings":";KAKY,WAAA;EAAA,oDAEV,QAAA;EACA,OAAA;IAHqB,mEAKnB,SAAA,WAFF;IAIE,cAAA;EAAA;AAAA;AAAA,KAIQ,eAAA;EAAA,0CAEV,QAAA;EAEA,SAAA,UAFA;EAIA,KAAA;AAAA;AAAA,KAGU,aAAA;EACV,EAAA;EACA,QAAA;EACA,KAAA;AAAA;;;;iBAMoB,QAAA,CAAA,GAAY,OAAA"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{t as e}from"../../../logger-Bj782ZYD.mjs";import{t}from"../../../parquetToCsvOneFile-bgEgRoAi.mjs";import{CHILD_FLAG as n,extractErrorMessage as r}from"@transcend-io/utils";async function i(){let n=Number(process.env.WORKER_ID||`0`);e.info(`[w${n}] ready pid=${process.pid}`),process.send?.({type:`ready`}),process.on(`message`,async i=>{if(!i||typeof i!=`object`||(i.type===`shutdown`&&process.exit(0),i.type!==`task`))return;let{filePath:a,options:o}=i.payload,{outputDir:s,clearOutputDir:c}=o;try{e.info(`[w${n}] processing ${a}`);let{DuckDBInstance:r}=await import(`@duckdb/node-api`);await t({filePath:a,outputDir:s,clearOutputDir:c,onProgress:(e,t)=>process.send?.({type:`progress`,payload:{filePath:a,processed:e,total:t}})},r),process.send?.({type:`result`,payload:{ok:!0,filePath:a}})}catch(t){let i=r(t);e.error(`[w${n}] ERROR ${a}: ${t.stack||i}`),process.send?.({type:`result`,payload:{ok:!1,filePath:a,error:i}})}}),await new Promise(()=>{})}process.argv.includes(n)&&i().catch(t=>{e.error(t),process.exit(1)});export{i as runChild};
|
|
2
|
+
//# sourceMappingURL=worker.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.mjs","names":[],"sources":["../../../../src/commands/admin/parquet-to-csv/worker.ts"],"sourcesContent":["import { extractErrorMessage, CHILD_FLAG, type ToWorker } from '@transcend-io/utils';\n\nimport { parquetToCsvOneFile } from '../../../lib/helpers/index.js';\nimport { logger } from '../../../logger.js';\n\nexport type ParquetTask = {\n /** Absolute path of the Parquet file to convert. */\n filePath: string;\n options: {\n /** Optional directory where CSV output files should be written. */\n outputDir?: string;\n /** Whether to clear any pre-existing output before writing new ones. */\n clearOutputDir: boolean;\n };\n};\n\nexport type ParquetProgress = {\n /** File being processed by the worker. */\n filePath: string;\n /** Rows processed so far. */\n processed: number;\n /** Optional known total rows (not always available). */\n total?: number;\n};\n\nexport type ParquetResult = {\n ok: boolean;\n filePath: string;\n error?: string;\n};\n\n/**\n * Worker loop: convert a single Parquet file to one or more CSV files.\n */\nexport async function runChild(): Promise<void> {\n const workerId = Number(process.env.WORKER_ID || '0');\n logger.info(`[w${workerId}] ready pid=${process.pid}`);\n process.send?.({ type: 'ready' });\n\n process.on('message', async (msg: ToWorker<ParquetTask>) => {\n if (!msg || typeof msg !== 'object') return;\n\n if (msg.type === 'shutdown') {\n process.exit(0);\n }\n if (msg.type !== 'task') return;\n\n const { filePath, options } = msg.payload;\n const { outputDir, clearOutputDir } = options;\n\n try {\n logger.info(`[w${workerId}] processing ${filePath}`);\n const { DuckDBInstance } = await import('@duckdb/node-api');\n await parquetToCsvOneFile(\n {\n filePath,\n outputDir,\n clearOutputDir,\n onProgress: (processed, total) =>\n process.send?.({\n type: 'progress',\n payload: { filePath, processed, total },\n }),\n },\n DuckDBInstance,\n );\n\n process.send?.({\n type: 'result',\n payload: { ok: true, filePath },\n });\n } catch (err) {\n const message = extractErrorMessage(err);\n logger.error(`[w${workerId}] ERROR ${filePath}: ${err.stack || message}`);\n process.send?.({\n type: 'result',\n payload: { ok: false, filePath, error: message },\n });\n }\n });\n\n // keep alive until shutdown\n await new Promise<never>(() => {\n // Do nothing\n });\n}\n\nif (process.argv.includes(CHILD_FLAG)) {\n runChild().catch((err) => {\n logger.error(err);\n process.exit(1);\n });\n}\n"],"mappings":"oLAkCA,eAAsB,GAA0B,CAC9C,IAAM,EAAW,OAAO,QAAQ,IAAI,WAAa,IAAI,CACrD,EAAO,KAAK,KAAK,EAAS,cAAc,QAAQ,MAAM,CACtD,QAAQ,OAAO,CAAE,KAAM,QAAS,CAAC,CAEjC,QAAQ,GAAG,UAAW,KAAO,IAA+B,CAM1D,GALI,CAAC,GAAO,OAAO,GAAQ,WAEvB,EAAI,OAAS,YACf,QAAQ,KAAK,EAAE,CAEb,EAAI,OAAS,QAAQ,OAEzB,GAAM,CAAE,WAAU,WAAY,EAAI,QAC5B,CAAE,YAAW,kBAAmB,EAEtC,GAAI,CACF,EAAO,KAAK,KAAK,EAAS,eAAe,IAAW,CACpD,GAAM,CAAE,kBAAmB,MAAM,OAAO,oBACxC,MAAM,EACJ,CACE,WACA,YACA,iBACA,YAAa,EAAW,IACtB,QAAQ,OAAO,CACb,KAAM,WACN,QAAS,CAAE,WAAU,YAAW,QAAO,CACxC,CAAC,CACL,CACD,EACD,CAED,QAAQ,OAAO,CACb,KAAM,SACN,QAAS,CAAE,GAAI,GAAM,WAAU,CAChC,CAAC,OACK,EAAK,CACZ,IAAM,EAAU,EAAoB,EAAI,CACxC,EAAO,MAAM,KAAK,EAAS,UAAU,EAAS,IAAI,EAAI,OAAS,IAAU,CACzE,QAAQ,OAAO,CACb,KAAM,SACN,QAAS,CAAE,GAAI,GAAO,WAAU,MAAO,EAAS,CACjD,CAAC,GAEJ,CAGF,MAAM,IAAI,YAAqB,GAE7B,CAGA,QAAQ,KAAK,SAAS,EAAW,EACnC,GAAU,CAAC,MAAO,GAAQ,CACxB,EAAO,MAAM,EAAI,CACjB,QAAQ,KAAK,EAAE,EACf"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{t as e}from"./logger-
|
|
1
|
+
import{t as e}from"./logger-Bj782ZYD.mjs";function t(t){let n=t.map(({name:e,input:t})=>({title:e.replace(`.yml`,``),attributes:[...t?.domains?[{key:`Transcend Domain List`,values:[...new Set(t.domains)]}]:[],...t?.bundleUrls?[{key:`Airgap Production URL`,values:[t.bundleUrls.PRODUCTION]},{key:`Airgap Test URL`,values:[t.bundleUrls.TEST]},{key:`Airgap XDI URL`,values:[t.bundleUrls.PRODUCTION.replace(`airgap.js`,`xdi.js`)]}]:[],...t?.partition?[{key:`Consent Partition Key`,values:[t.partition]}]:[]]}));return e.info(`
|
|
2
2
|
|
|
3
3
|
~~~~~~~~~~~
|
|
4
4
|
Airgap scripts to host:`),n.forEach(({attributes:t,title:n},r)=>{t?.find(e=>e.key===`Airgap Production URL`)?.values?.forEach(t=>{e.info(`${r}) ${n} - ${t}`)})}),n}export{t};
|
|
5
|
-
//# sourceMappingURL=consentManagersToBusinessEntities-
|
|
5
|
+
//# sourceMappingURL=consentManagersToBusinessEntities-D1bdBgnA.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consentManagersToBusinessEntities-
|
|
1
|
+
{"version":3,"file":"consentManagersToBusinessEntities-D1bdBgnA.mjs","names":[],"sources":["../src/lib/consent-manager/consentManagersToBusinessEntities.ts"],"sourcesContent":["import { BusinessEntityInput, ConsentManagerInput } from '../../codecs.js';\nimport { logger } from '../../logger.js';\n\n/**\n * Combine multiple consent manager configurations into a list of business entity configurations\n *\n * @param inputs - Consent manager configurations to combine\n * @returns Business entity configuration input\n */\nexport function consentManagersToBusinessEntities(\n inputs: {\n /** Name of business entity */\n name: string;\n /** Consent manager input */\n input?: ConsentManagerInput;\n }[],\n): BusinessEntityInput[] {\n // Construct the business entities YAML definition\n const businessEntities = inputs.map(\n ({ name, input }): BusinessEntityInput => ({\n // Title of Transcend Instance\n title: name.replace('.yml', ''),\n attributes: [\n // Sync domain list\n ...(input?.domains\n ? [\n {\n key: 'Transcend Domain List',\n values: [...new Set(input.domains)],\n },\n ]\n : []),\n // Sync bundle URLs\n ...(input?.bundleUrls\n ? [\n {\n key: 'Airgap Production URL',\n values: [input.bundleUrls.PRODUCTION],\n },\n {\n key: 'Airgap Test URL',\n values: [input.bundleUrls.TEST],\n },\n {\n key: 'Airgap XDI URL',\n values: [input.bundleUrls.PRODUCTION.replace('airgap.js', 'xdi.js')],\n },\n ]\n : []),\n // Sync partition keys\n ...(input?.partition\n ? [\n {\n key: 'Consent Partition Key',\n values: [input.partition],\n },\n ]\n : []),\n ],\n }),\n );\n\n // Log out info on airgap scripts to host\n logger.info('\\n\\n~~~~~~~~~~~\\nAirgap scripts to host:');\n businessEntities.forEach(({ attributes, title }, ind) => {\n attributes\n ?.find((attr) => attr.key === 'Airgap Production URL')\n ?.values?.forEach((url) => {\n logger.info(`${ind}) ${title} - ${url}`);\n });\n });\n\n return businessEntities;\n}\n"],"mappings":"0CASA,SAAgB,EACd,EAMuB,CAEvB,IAAM,EAAmB,EAAO,KAC7B,CAAE,OAAM,YAAkC,CAEzC,MAAO,EAAK,QAAQ,OAAQ,GAAG,CAC/B,WAAY,CAEV,GAAI,GAAO,QACP,CACE,CACE,IAAK,wBACL,OAAQ,CAAC,GAAG,IAAI,IAAI,EAAM,QAAQ,CAAC,CACpC,CACF,CACD,EAAE,CAEN,GAAI,GAAO,WACP,CACE,CACE,IAAK,wBACL,OAAQ,CAAC,EAAM,WAAW,WAAW,CACtC,CACD,CACE,IAAK,kBACL,OAAQ,CAAC,EAAM,WAAW,KAAK,CAChC,CACD,CACE,IAAK,iBACL,OAAQ,CAAC,EAAM,WAAW,WAAW,QAAQ,YAAa,SAAS,CAAC,CACrE,CACF,CACD,EAAE,CAEN,GAAI,GAAO,UACP,CACE,CACE,IAAK,wBACL,OAAQ,CAAC,EAAM,UAAU,CAC1B,CACF,CACD,EAAE,CACP,CACF,EACF,CAYD,OATA,EAAO,KAAK;;;yBAA2C,CACvD,EAAiB,SAAS,CAAE,aAAY,SAAS,IAAQ,CACvD,GACI,KAAM,GAAS,EAAK,MAAQ,wBAAwB,EACpD,QAAQ,QAAS,GAAQ,CACzB,EAAO,KAAK,GAAG,EAAI,IAAI,EAAM,KAAK,IAAM,EACxC,EACJ,CAEK"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import{CompletedRequestStatus as e,IsoCountryCode as t,IsoCountrySubdivisionCode as n,RequestAction as r}from"@transcend-io/privacy-types";import{applyEnum as i,valuesOf as a}from"@transcend-io/type-utils";import{LOCALE_KEY as o}from"@transcend-io/internationalization";import*as s from"io-ts";const c=`[NONE]`,l=`[APPLY VALUE TO ALL ROWS]`,u=`<blank>`,d=[`email`,`coreIdentifier`];let f=function(e){return e.Email=`email`,e.CoreIdentifier=`coreIdentifier`,e.RequestType=`requestType`,e.SubjectType=`subjectType`,e.Locale=`locale`,e.Country=`country`,e.CountrySubDivision=`countrySubDivision`,e.RequestStatus=`requestStatus`,e.CreatedAt=`createdAt`,e.DataSiloIds=`dataSiloIds`,e}({});const p={[f.Email]:!1,[f.CoreIdentifier]:!0,[f.RequestType]:!0,[f.SubjectType]:!0,[f.RequestStatus]:!1,[f.CreatedAt]:!1,[f.DataSiloIds]:!1,[f.Locale]:!1,[f.Country]:!1,[f.CountrySubDivision]:!1},m={[f.RequestType]:!0,[f.SubjectType]:!0},h=s.type({columnNames:s.partial(i(f,()=>s.string)),identifierNames:s.record(s.string,s.string),attributeNames:s.record(s.string,s.string),requestTypeToRequestAction:s.record(s.string,a(r)),subjectTypeToSubjectName:s.record(s.string,s.string),languageToLocale:s.record(s.string,a(o)),regionToCountry:s.record(s.string,a({...t,[c]:c})),regionToCountrySubDivision:s.record(s.string,a({...n,[c]:c})),statusToRequestStatus:s.record(s.string,a({...e,[c]:c}))}),g=s.type({id:s.string,link:s.string,rowIndex:s.number,coreIdentifier:s.string,attemptedAt:s.string}),_=s.type({failingRequests:s.array(s.record(s.string,s.any)),successfulRequests:s.array(g),duplicateRequests:s.array(s.type({rowIndex:s.number,coreIdentifier:s.string,attemptedAt:s.string}))});export{_ as a,p as c,h as i,c as l,l as n,f as o,m as r,d as s,u as t,g as u};
|
|
2
|
-
//# sourceMappingURL=constants-
|
|
2
|
+
//# sourceMappingURL=constants-DYbzl8QH.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants-
|
|
1
|
+
{"version":3,"file":"constants-DYbzl8QH.mjs","names":[],"sources":["../src/lib/requests/constants.ts"],"sourcesContent":["import { LOCALE_KEY } from '@transcend-io/internationalization';\nimport {\n CompletedRequestStatus,\n RequestAction,\n IsoCountryCode,\n IsoCountrySubdivisionCode,\n} from '@transcend-io/privacy-types';\nimport { applyEnum, valuesOf } from '@transcend-io/type-utils';\nimport * as t from 'io-ts';\n\nexport const NONE = '[NONE]' as const;\nexport const BULK_APPLY = '[APPLY VALUE TO ALL ROWS]' as const;\nexport const BLANK = '<blank>' as const;\n\n/** These are uploaded at the top level of the request */\nexport const IDENTIFIER_BLOCK_LIST = ['email', 'coreIdentifier'];\n\n/**\n * Column names to map\n */\nexport enum ColumnName {\n /** The title of the email column */\n Email = 'email',\n /** The title of the core identifier column */\n CoreIdentifier = 'coreIdentifier',\n /** The title of the requestType column */\n RequestType = 'requestType',\n /** The title of the subjectType column */\n SubjectType = 'subjectType',\n /** The title of the locale column */\n Locale = 'locale',\n /** The country */\n Country = 'country',\n /** The country sub division */\n CountrySubDivision = 'countrySubDivision',\n /** The title of the requestStatus column */\n RequestStatus = 'requestStatus',\n /** The title of the createdAt column */\n CreatedAt = 'createdAt',\n /** The title of the dataSiloIds column */\n DataSiloIds = 'dataSiloIds',\n}\n\n/** These parameters are required in the Transcend DSR API */\nexport const IS_REQUIRED: { [k in ColumnName]: boolean } = {\n [ColumnName.Email]: false,\n [ColumnName.CoreIdentifier]: true,\n [ColumnName.RequestType]: true,\n [ColumnName.SubjectType]: true,\n [ColumnName.RequestStatus]: false,\n [ColumnName.CreatedAt]: false,\n [ColumnName.DataSiloIds]: false,\n [ColumnName.Locale]: false,\n [ColumnName.Country]: false,\n [ColumnName.CountrySubDivision]: false,\n};\n\n/** These parameters can be specified for the entire CSV set if needed */\nexport const CAN_APPLY_IN_BULK: { [k in ColumnName]?: boolean } = {\n [ColumnName.RequestType]: true,\n [ColumnName.SubjectType]: true,\n};\n\n// Cache state\nexport const CachedFileState = t.type({\n /** Mapping between the default request input column names and the CSV column name for that input */\n columnNames: t.partial(applyEnum(ColumnName, () => t.string)),\n /** Mapping between the identifier names and the CSV column name for that input */\n identifierNames: t.record(t.string, t.string),\n /** Mapping between the request attribute inputs and the CSV column name for that input */\n attributeNames: t.record(t.string, t.string),\n /** Mapping between CSV request type and Transcend Request Action */\n requestTypeToRequestAction: t.record(t.string, valuesOf(RequestAction)),\n /** Mapping between CSV data subject type and the name of the data subject in Transcend */\n subjectTypeToSubjectName: t.record(t.string, t.string),\n /** Mapping between language imported and Transcend locale code */\n languageToLocale: t.record(t.string, valuesOf(LOCALE_KEY)),\n /** Mapping between region and country code */\n regionToCountry: t.record(t.string, valuesOf({ ...IsoCountryCode, [NONE]: NONE })),\n /** Mapping between region and country sub division code */\n regionToCountrySubDivision: t.record(\n t.string,\n valuesOf({ ...IsoCountrySubdivisionCode, [NONE]: NONE }),\n ),\n /** Mapping between request status in import to Transcend request status */\n statusToRequestStatus: t.record(t.string, valuesOf({ ...CompletedRequestStatus, [NONE]: NONE })),\n});\n\n/** Type override */\nexport type CachedFileState = t.TypeOf<typeof CachedFileState>;\n\n/**\n * Successfully processed request\n */\nexport const SuccessfulRequest = t.type({\n id: t.string,\n link: t.string,\n rowIndex: t.number,\n coreIdentifier: t.string,\n attemptedAt: t.string,\n});\n\n/** Type override */\nexport type SuccessfulRequest = t.TypeOf<typeof SuccessfulRequest>;\n\n// Cache state\nexport const CachedRequestState = t.type({\n /** Set of privacy requests that failed to upload */\n failingRequests: t.array(t.record(t.string, t.any)),\n /** Successfully uploaded requests */\n successfulRequests: t.array(SuccessfulRequest),\n /** Duplicate requests */\n duplicateRequests: t.array(\n t.type({\n rowIndex: t.number,\n coreIdentifier: t.string,\n attemptedAt: t.string,\n }),\n ),\n});\n\n/** Type override */\nexport type CachedRequestState = t.TypeOf<typeof CachedRequestState>;\n"],"mappings":"sSAUA,MAAa,EAAO,SACP,EAAa,4BACb,EAAQ,UAGR,EAAwB,CAAC,QAAS,iBAAiB,CAKhE,IAAY,EAAL,SAAA,EAAA,OAEL,GAAA,MAAA,QAEA,EAAA,eAAA,iBAEA,EAAA,YAAA,cAEA,EAAA,YAAA,cAEA,EAAA,OAAA,SAEA,EAAA,QAAA,UAEA,EAAA,mBAAA,qBAEA,EAAA,cAAA,gBAEA,EAAA,UAAA,YAEA,EAAA,YAAA,oBACD,CAGD,MAAa,EAA8C,EACxD,EAAW,OAAQ,IACnB,EAAW,gBAAiB,IAC5B,EAAW,aAAc,IACzB,EAAW,aAAc,IACzB,EAAW,eAAgB,IAC3B,EAAW,WAAY,IACvB,EAAW,aAAc,IACzB,EAAW,QAAS,IACpB,EAAW,SAAU,IACrB,EAAW,oBAAqB,GAClC,CAGY,EAAqD,EAC/D,EAAW,aAAc,IACzB,EAAW,aAAc,GAC3B,CAGY,EAAkB,EAAE,KAAK,CAEpC,YAAa,EAAE,QAAQ,EAAU,MAAkB,EAAE,OAAO,CAAC,CAE7D,gBAAiB,EAAE,OAAO,EAAE,OAAQ,EAAE,OAAO,CAE7C,eAAgB,EAAE,OAAO,EAAE,OAAQ,EAAE,OAAO,CAE5C,2BAA4B,EAAE,OAAO,EAAE,OAAQ,EAAS,EAAc,CAAC,CAEvE,yBAA0B,EAAE,OAAO,EAAE,OAAQ,EAAE,OAAO,CAEtD,iBAAkB,EAAE,OAAO,EAAE,OAAQ,EAAS,EAAW,CAAC,CAE1D,gBAAiB,EAAE,OAAO,EAAE,OAAQ,EAAS,CAAE,GAAG,GAAiB,GAAO,EAAM,CAAC,CAAC,CAElF,2BAA4B,EAAE,OAC5B,EAAE,OACF,EAAS,CAAE,GAAG,GAA4B,GAAO,EAAM,CAAC,CACzD,CAED,sBAAuB,EAAE,OAAO,EAAE,OAAQ,EAAS,CAAE,GAAG,GAAyB,GAAO,EAAM,CAAC,CAAC,CACjG,CAAC,CAQW,EAAoB,EAAE,KAAK,CACtC,GAAI,EAAE,OACN,KAAM,EAAE,OACR,SAAU,EAAE,OACZ,eAAgB,EAAE,OAClB,YAAa,EAAE,OAChB,CAAC,CAMW,EAAqB,EAAE,KAAK,CAEvC,gBAAiB,EAAE,MAAM,EAAE,OAAO,EAAE,OAAQ,EAAE,IAAI,CAAC,CAEnD,mBAAoB,EAAE,MAAM,EAAkB,CAE9C,kBAAmB,EAAE,MACnB,EAAE,KAAK,CACL,SAAU,EAAE,OACZ,eAAgB,EAAE,OAClB,YAAa,EAAE,OAChB,CAAC,CACH,CACF,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{o as e}from"./enums-CyFTrzXY.mjs";import{ScopeName as t,TRANSCEND_SCOPES as n}from"@transcend-io/privacy-types";import{keyBy as r}from"lodash-es";var i=`10.1.0`,a=`A command line interface for programmatic operations across Transcend.`;const o=`transcend`,s=`https://app.transcend.io`,c=`${s}/infrastructure/integrations`,l=`${s}/data-map/data-inventory/data-points`,u=process.env.TRANSCEND_API_URL||`https://api.transcend.io`,d=process.env.TRANSCEND_CONSENT_API_URL||`https://consent.transcend.io`,f={[e.ApiKeys]:[t.ViewApiKeys],[e.Templates]:[t.ManageEmailTemplates],[e.DataSilos]:[t.ManageDataMap,t.ConnectDataSilos],[e.Enrichers]:[t.ManageRequestIdentities],[e.BusinessEntities]:[t.ManageDataInventory],[e.ProcessingActivities]:[t.ManageDataMap],[e.Identifiers]:[t.ManageRequestIdentities],[e.Attributes]:[t.ManageGlobalAttributes],[e.DataFlows]:[t.ManageDataFlow],[e.Cookies]:[t.ManageDataFlow],[e.ConsentManager]:[t.ManageConsentManagerDeveloperSettings],[e.Partitions]:[t.ManageConsentManagerDeveloperSettings],[e.Actions]:[t.ManageDataSubjectRequestSettings],[e.DataSubjects]:[t.ManageDataSubjectRequestSettings],[e.Prompts]:[t.ManagePrompts],[e.PromptPartials]:[t.ManagePrompts],[e.PromptGroups]:[t.ManagePrompts],[e.Agents]:[t.ManagePathfinder],[e.AgentFunctions]:[t.ManagePathfinder],[e.AgentFiles]:[t.ManagePathfinder],[e.Vendors]:[t.ManageDataInventory],[e.DataCategories]:[t.ManageDataInventory],[e.ProcessingPurposes]:[t.ManageDataInventory],[e.ActionItems]:[t.ManageAllActionItems,t.ViewGlobalAttributes],[e.ActionItemCollections]:[t.ManageActionItemCollections],[e.Teams]:[t.ManageAccessControl],[e.Messages]:[t.ManageIntlMessages],[e.PrivacyCenters]:[t.ManagePrivacyCenter],[e.Policies]:[t.ManagePolicies],[e.Assessments]:[t.ManageAssessments],[e.AssessmentTemplates]:[t.ManageAssessments],[e.Purposes]:[t.ManageConsentManager,t.ManagePreferenceStoreSettings],[e.SystemDiscovery]:[t.ManageDataMap]},p={[e.ApiKeys]:[t.ViewApiKeys],[e.Templates]:[t.ViewEmailTemplates],[e.DataSilos]:[t.ViewDataMap,t.ViewDataSubjectRequestSettings],[e.Enrichers]:[t.ViewRequestIdentitySettings],[e.BusinessEntities]:[t.ViewDataInventory],[e.ProcessingActivities]:[t.ViewDataInventory],[e.Identifiers]:[t.ViewRequestIdentitySettings],[e.Attributes]:[t.ViewGlobalAttributes],[e.DataFlows]:[t.ViewDataFlow],[e.Cookies]:[t.ViewDataFlow],[e.ConsentManager]:[t.ViewConsentManager],[e.Partitions]:[t.ViewConsentManager],[e.Actions]:[t.ViewDataSubjectRequestSettings],[e.DataSubjects]:[t.ViewDataSubjectRequestSettings],[e.Prompts]:[t.ViewPrompts],[e.PromptPartials]:[t.ViewPrompts],[e.PromptGroups]:[t.ViewPrompts],[e.Agents]:[t.ViewPathfinder],[e.AgentFunctions]:[t.ViewPathfinder],[e.AgentFiles]:[t.ViewPathfinder],[e.Vendors]:[t.ViewDataInventory],[e.DataCategories]:[t.ViewDataInventory],[e.ProcessingPurposes]:[t.ViewDataInventory],[e.ActionItemCollections]:[t.ViewAllActionItems],[e.ActionItems]:[t.ViewAllActionItems],[e.Teams]:[t.ViewScopes],[e.Messages]:[t.ViewIntlMessages],[e.PrivacyCenters]:[t.ViewPrivacyCenter],[e.Policies]:[t.ViewPolicies],[e.Assessments]:[t.ViewAssessments],[e.AssessmentTemplates]:[t.ViewAssessments],[e.Purposes]:[t.ViewConsentManager,t.ViewPreferenceStoreSettings],[e.SystemDiscovery]:[t.ViewDataMap]},m={[e.ApiKeys]:`api-keys`,[e.Attributes]:`attributes`,[e.DataFlows]:`data-flows`,[e.Cookies]:`cookies`,[e.ConsentManager]:`consent-manager`,[e.Partitions]:`partitions`,[e.Actions]:`actions`,[e.DataSubjects]:`data-subjects`,[e.BusinessEntities]:`business-entities`,[e.ProcessingActivities]:`processing-activities`,[e.Identifiers]:`identifiers`,[e.Enrichers]:`enrichers`,[e.DataSilos]:`data-silos`,[e.Templates]:`templates`,[e.Prompts]:`prompts`,[e.PromptPartials]:`prompt-partials`,[e.PromptGroups]:`prompt-groups`,[e.Agents]:`agents`,[e.AgentFunctions]:`agent-functions`,[e.AgentFiles]:`agent-files`,[e.Vendors]:`vendors`,[e.DataCategories]:`data-categories`,[e.ProcessingPurposes]:`processing-purposes`,[e.ActionItems]:`action-items`,[e.ActionItemCollections]:`action-item-collections`,[e.Teams]:`teams`,[e.Messages]:`messages`,[e.PrivacyCenters]:`privacy-center`,[e.Policies]:`policies`,[e.Assessments]:`assessments`,[e.AssessmentTemplates]:`assessment-templates`,[e.Purposes]:`purposes`,[e.SystemDiscovery]:`system-discovery`},h=r(Object.entries(n).map(([e,t])=>({...t,name:e})),`title`),g=Object.keys(h),_=new Set([429,502,500,504,329]),v=process.env.DEBUG===`1`;export{u as a,h as c,f as d,m as f,i as h,v as i,g as l,a as m,l as n,d as o,o as p,c as r,_ as s,s as t,p as u};
|
|
2
|
+
//# sourceMappingURL=constants-XOsAW1__.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants-XOsAW1__.mjs","names":[],"sources":["../package.json","../src/constants.ts"],"sourcesContent":["","import { ScopeName, TRANSCEND_SCOPES, type ScopeDefinition } from '@transcend-io/privacy-types';\nimport { keyBy } from 'lodash-es';\n\nimport { TranscendInput } from './codecs.js';\nimport { TranscendPullResource } from './enums.js';\n\nexport { description, version } from '../package.json';\n/**\n * The name of the main binary for the CLI\n */\nexport const name = 'transcend';\n\nexport const ADMIN_DASH = 'https://app.transcend.io';\n\nexport const ADMIN_DASH_INTEGRATIONS = `${ADMIN_DASH}/infrastructure/integrations`;\nexport const ADMIN_DASH_DATAPOINTS = `${ADMIN_DASH}/data-map/data-inventory/data-points`;\n\n/**\n * Override default transcend API url using\n * TRANSCEND_API_URL=https://api.us.transcend.io transcend ...\n */\nexport const DEFAULT_TRANSCEND_API = process.env.TRANSCEND_API_URL || 'https://api.transcend.io';\n\n/**\n * Override default transcend API url using\n * TRANSCEND_CONSENT_API_URL=https://consent.us.transcend.io transcend ...\n */\nexport const DEFAULT_TRANSCEND_CONSENT_API =\n process.env.TRANSCEND_CONSENT_API_URL || 'https://consent.transcend.io';\n\n/**\n * Mapping between resource type and scopes required for cli\n */\nexport const TR_PUSH_RESOURCE_SCOPE_MAP: {\n [k in TranscendPullResource]: ScopeName[];\n} = {\n [TranscendPullResource.ApiKeys]: [ScopeName.ViewApiKeys],\n [TranscendPullResource.Templates]: [ScopeName.ManageEmailTemplates],\n [TranscendPullResource.DataSilos]: [ScopeName.ManageDataMap, ScopeName.ConnectDataSilos],\n [TranscendPullResource.Enrichers]: [ScopeName.ManageRequestIdentities],\n [TranscendPullResource.BusinessEntities]: [ScopeName.ManageDataInventory],\n [TranscendPullResource.ProcessingActivities]: [ScopeName.ManageDataMap],\n [TranscendPullResource.Identifiers]: [ScopeName.ManageRequestIdentities],\n [TranscendPullResource.Attributes]: [ScopeName.ManageGlobalAttributes],\n [TranscendPullResource.DataFlows]: [ScopeName.ManageDataFlow],\n [TranscendPullResource.Cookies]: [ScopeName.ManageDataFlow],\n [TranscendPullResource.ConsentManager]: [ScopeName.ManageConsentManagerDeveloperSettings],\n [TranscendPullResource.Partitions]: [ScopeName.ManageConsentManagerDeveloperSettings],\n [TranscendPullResource.Actions]: [ScopeName.ManageDataSubjectRequestSettings],\n [TranscendPullResource.DataSubjects]: [ScopeName.ManageDataSubjectRequestSettings],\n [TranscendPullResource.Prompts]: [ScopeName.ManagePrompts],\n [TranscendPullResource.PromptPartials]: [ScopeName.ManagePrompts],\n [TranscendPullResource.PromptGroups]: [ScopeName.ManagePrompts],\n [TranscendPullResource.Agents]: [ScopeName.ManagePathfinder],\n [TranscendPullResource.AgentFunctions]: [ScopeName.ManagePathfinder],\n [TranscendPullResource.AgentFiles]: [ScopeName.ManagePathfinder],\n [TranscendPullResource.Vendors]: [ScopeName.ManageDataInventory],\n [TranscendPullResource.DataCategories]: [ScopeName.ManageDataInventory],\n [TranscendPullResource.ProcessingPurposes]: [ScopeName.ManageDataInventory],\n [TranscendPullResource.ActionItems]: [\n ScopeName.ManageAllActionItems,\n ScopeName.ViewGlobalAttributes,\n ],\n [TranscendPullResource.ActionItemCollections]: [ScopeName.ManageActionItemCollections],\n [TranscendPullResource.Teams]: [ScopeName.ManageAccessControl],\n [TranscendPullResource.Messages]: [ScopeName.ManageIntlMessages],\n [TranscendPullResource.PrivacyCenters]: [ScopeName.ManagePrivacyCenter],\n [TranscendPullResource.Policies]: [ScopeName.ManagePolicies],\n [TranscendPullResource.Assessments]: [ScopeName.ManageAssessments],\n [TranscendPullResource.AssessmentTemplates]: [ScopeName.ManageAssessments],\n [TranscendPullResource.Purposes]: [\n ScopeName.ManageConsentManager,\n ScopeName.ManagePreferenceStoreSettings,\n ],\n [TranscendPullResource.SystemDiscovery]: [ScopeName.ManageDataMap],\n};\n\n/**\n * Mapping between resource type and scopes required for cli\n */\nexport const TR_PULL_RESOURCE_SCOPE_MAP: {\n [k in TranscendPullResource]: ScopeName[];\n} = {\n [TranscendPullResource.ApiKeys]: [ScopeName.ViewApiKeys],\n [TranscendPullResource.Templates]: [ScopeName.ViewEmailTemplates],\n [TranscendPullResource.DataSilos]: [\n ScopeName.ViewDataMap,\n ScopeName.ViewDataSubjectRequestSettings,\n ],\n [TranscendPullResource.Enrichers]: [ScopeName.ViewRequestIdentitySettings],\n [TranscendPullResource.BusinessEntities]: [ScopeName.ViewDataInventory],\n [TranscendPullResource.ProcessingActivities]: [ScopeName.ViewDataInventory],\n [TranscendPullResource.Identifiers]: [ScopeName.ViewRequestIdentitySettings],\n [TranscendPullResource.Attributes]: [ScopeName.ViewGlobalAttributes],\n [TranscendPullResource.DataFlows]: [ScopeName.ViewDataFlow],\n [TranscendPullResource.Cookies]: [ScopeName.ViewDataFlow],\n [TranscendPullResource.ConsentManager]: [ScopeName.ViewConsentManager],\n [TranscendPullResource.Partitions]: [ScopeName.ViewConsentManager],\n [TranscendPullResource.Actions]: [ScopeName.ViewDataSubjectRequestSettings],\n [TranscendPullResource.DataSubjects]: [ScopeName.ViewDataSubjectRequestSettings],\n [TranscendPullResource.Prompts]: [ScopeName.ViewPrompts],\n [TranscendPullResource.PromptPartials]: [ScopeName.ViewPrompts],\n [TranscendPullResource.PromptGroups]: [ScopeName.ViewPrompts],\n [TranscendPullResource.Agents]: [ScopeName.ViewPathfinder],\n [TranscendPullResource.AgentFunctions]: [ScopeName.ViewPathfinder],\n [TranscendPullResource.AgentFiles]: [ScopeName.ViewPathfinder],\n [TranscendPullResource.Vendors]: [ScopeName.ViewDataInventory],\n [TranscendPullResource.DataCategories]: [ScopeName.ViewDataInventory],\n [TranscendPullResource.ProcessingPurposes]: [ScopeName.ViewDataInventory],\n [TranscendPullResource.ActionItemCollections]: [ScopeName.ViewAllActionItems],\n [TranscendPullResource.ActionItems]: [ScopeName.ViewAllActionItems],\n [TranscendPullResource.Teams]: [ScopeName.ViewScopes],\n [TranscendPullResource.Messages]: [ScopeName.ViewIntlMessages],\n [TranscendPullResource.PrivacyCenters]: [ScopeName.ViewPrivacyCenter],\n [TranscendPullResource.Policies]: [ScopeName.ViewPolicies],\n [TranscendPullResource.Assessments]: [ScopeName.ViewAssessments],\n [TranscendPullResource.AssessmentTemplates]: [ScopeName.ViewAssessments],\n [TranscendPullResource.Purposes]: [\n ScopeName.ViewConsentManager,\n ScopeName.ViewPreferenceStoreSettings,\n ],\n [TranscendPullResource.SystemDiscovery]: [ScopeName.ViewDataMap],\n};\n\nexport const TR_YML_RESOURCE_TO_FIELD_NAME: Record<TranscendPullResource, keyof TranscendInput> = {\n [TranscendPullResource.ApiKeys]: 'api-keys',\n [TranscendPullResource.Attributes]: 'attributes',\n [TranscendPullResource.DataFlows]: 'data-flows',\n [TranscendPullResource.Cookies]: 'cookies',\n [TranscendPullResource.ConsentManager]: 'consent-manager',\n [TranscendPullResource.Partitions]: 'partitions',\n [TranscendPullResource.Actions]: 'actions',\n [TranscendPullResource.DataSubjects]: 'data-subjects',\n [TranscendPullResource.BusinessEntities]: 'business-entities',\n [TranscendPullResource.ProcessingActivities]: 'processing-activities',\n [TranscendPullResource.Identifiers]: 'identifiers',\n [TranscendPullResource.Enrichers]: 'enrichers',\n [TranscendPullResource.DataSilos]: 'data-silos',\n [TranscendPullResource.Templates]: 'templates',\n [TranscendPullResource.Prompts]: 'prompts',\n [TranscendPullResource.PromptPartials]: 'prompt-partials',\n [TranscendPullResource.PromptGroups]: 'prompt-groups',\n [TranscendPullResource.Agents]: 'agents',\n [TranscendPullResource.AgentFunctions]: 'agent-functions',\n [TranscendPullResource.AgentFiles]: 'agent-files',\n [TranscendPullResource.Vendors]: 'vendors',\n [TranscendPullResource.DataCategories]: 'data-categories',\n [TranscendPullResource.ProcessingPurposes]: 'processing-purposes',\n [TranscendPullResource.ActionItems]: 'action-items',\n [TranscendPullResource.ActionItemCollections]: 'action-item-collections',\n [TranscendPullResource.Teams]: 'teams',\n [TranscendPullResource.Messages]: 'messages',\n [TranscendPullResource.PrivacyCenters]: 'privacy-center',\n [TranscendPullResource.Policies]: 'policies',\n [TranscendPullResource.Assessments]: 'assessments',\n [TranscendPullResource.AssessmentTemplates]: 'assessment-templates',\n [TranscendPullResource.Purposes]: 'purposes',\n [TranscendPullResource.SystemDiscovery]: 'system-discovery',\n};\n\nexport const SCOPES_BY_TITLE = keyBy(\n Object.entries(TRANSCEND_SCOPES).map(([name, value]) => ({\n ...value,\n name,\n })),\n 'title',\n) as Record<\n string,\n ScopeDefinition & {\n /** The camelCased name which identifies the scope */\n name: ScopeName;\n }\n>;\n\nexport const SCOPE_TITLES = Object.keys(SCOPES_BY_TITLE);\n\n/**\n * HTTP statuses that should be retried *in place* without splitting.\n * 429: Rate-limited\n * 502: Upstream/edge gateway error\n * 329: Reserved for custom infra (kept defensively)\n */\nexport const RETRYABLE_BATCH_STATUSES = new Set([429, 502, 500, 504, 329] as const);\n\n/**\n * Debugging\n */\nexport const DEBUG = process.env.DEBUG === '1';\n"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{t as e}from"./listFiles-
|
|
1
|
+
import{t as e}from"./listFiles-Odj7j2E1.mjs";import{CodePackageType as t}from"@transcend-io/privacy-types";import{decodeCodec as n,findAllWithRegex as r}from"@transcend-io/type-utils";import{readFileSync as i}from"node:fs";import{dirname as a,join as o}from"node:path";import*as s from"io-ts";import c from"js-yaml";const l=/target ('|")(.*?)('|")/,u=/pod ('|")(.*?)('|")(, ('|")~> (.+?)('|")|)/,d={supportedFiles:[`Podfile`],ignoreDirs:[`Pods`,`Build`],scanFunction:e=>{let n=i(e,`utf-8`),a=r({value:new RegExp(l,`g`),matches:[`quote1`,`name`,`quote2`]},n),o=r({value:new RegExp(u,`g`),matches:[`quote1`,`name`,`quote2`,`extra`,`quote3`,`version`,`quote4`]},n);return a.map((e,n)=>({name:e.name,type:t.CocoaPods,softwareDevelopmentKits:o.filter(t=>t.matchIndex>e.matchIndex&&(!a[n+1]||t.matchIndex<a[n+1].matchIndex)).map(e=>({name:e.name,version:e.version}))}))}},f=/implementation( *)('|")(.+?):(.+?):(.+?|)('|")/,p=/apply plugin: *('|")(.+?)(:(.+?)|)('|")/,m=/implementation group:( *)('|")(.+?)('|"),( *)name:( *)('|")(.+?)('|"),( *)version:( *)('|")(.+?)('|")/,h=/applicationId( *)"(.+?)"/,g={supportedFiles:[`build.gradle**`],ignoreDirs:[`gradle-app.setting`,`gradle-wrapper.jar`,`gradle-wrapper.properties`],scanFunction:e=>{let t=i(e,`utf-8`),n=a(e),o=r({value:new RegExp(f,`g`),matches:[`space`,`quote1`,`name`,`path`,`version`,`quote2`]},t),s=r({value:new RegExp(p,`g`),matches:[`quote1`,`name`,`group`,`version`,`quote2`]},t),c=r({value:new RegExp(m,`g`),matches:[`space1`,`quote1`,`group`,`quote2`,`space2`,`space3`,`quote3`,`name`,`quote4`,`space4`,`space5`,`quote5`,`version`,`quote6`]},t),l=r({value:new RegExp(h,`g`),matches:[`space`,`name`]},t);if(l.length>1)throw Error(`Expected only one applicationId per file: ${e}`);return[{name:l[0]?.name||n.split(`/`).pop(),softwareDevelopmentKits:[...o,...c,...s].map(e=>({name:e.name,version:e.version||void 0}))}]}},_={supportedFiles:[`package.json`],ignoreDirs:[`node_modules`,`serverless-build`,`lambda-build`],scanFunction:e=>{let t=i(e,`utf-8`),n=a(e),{name:r,description:o,dependencies:s={},devDependencies:c={},optionalDependencies:l={}}=JSON.parse(t);return[{name:r||n.split(`/`).pop(),description:o,softwareDevelopmentKits:[...Object.entries(s).map(([e,t])=>({name:e,version:typeof t==`string`?t:void 0})),...Object.entries(c).map(([e,t])=>({name:e,version:typeof t==`string`?t:void 0,isDevDependency:!0})),...Object.entries(l).map(([e,t])=>({name:e,version:typeof t==`string`?t:void 0}))]}]}},v=/(.+?)(=+)(.+)/,y=/name *= *('|")(.+?)('|")/,b=/description *= *('|")(.+?)('|")/,x={supportedFiles:[`requirements.txt`],ignoreDirs:[`build`,`lib`,`lib64`],scanFunction:n=>{let s=i(n,`utf-8`),c=a(n),l=e(c).find(e=>e===`setup.py`),u=l?i(o(c,l),`utf-8`):void 0,d=u?(y.exec(u)||[])[2]:void 0,f=u?(b.exec(u)||[])[2]:void 0,p=r({value:new RegExp(v,`g`),matches:[`name`,`equals`,`version`]},s);return[{name:d||c.split(`/`).pop(),description:f||void 0,type:t.RequirementsTxt,softwareDevelopmentKits:p.map(e=>({name:e.name,version:e.version}))}]}},S=/gem *('|")(.+?)('|")(, *('|")(.+?)('|")|)/,C=/spec\.name *= *('|")(.+?)('|")/,w=/spec\.description *= *('|")(.+?)('|")/,T=/spec\.summary *= *('|")(.+?)('|")/,E={supportedFiles:[`Gemfile`],ignoreDirs:[`bin`],scanFunction:n=>{let o=i(n,`utf-8`),s=a(n),c=e(s).find(e=>e===`.gemspec`),l=c?i(c,`utf-8`):void 0,u=l?(C.exec(l)||[])[2]:void 0,d=l?(w.exec(l)||T.exec(l)||[])[1]:void 0,f=r({value:new RegExp(S,`g`),matches:[`quote1`,`name`,`quote2`,`hasVersion`,`quote3`,`version`,`quote4`]},o);return[{name:u||s.split(`/`).pop(),description:d||void 0,type:t.RequirementsTxt,softwareDevelopmentKits:f.map(e=>({name:e.name,version:e.version}))}]}};function D(e){return e.split(`
|
|
2
2
|
`).map(e=>{let t=e.indexOf(`#`);return t>-1&&!e.substring(0,t).includes(`"`)&&!e.substring(0,t).includes(`'`)?e.substring(0,t).trim():e}).filter(e=>e.length>0).join(`
|
|
3
3
|
`)}const O={supportedFiles:[`pubspec.yml`],ignoreDirs:[`build`],scanFunction:e=>{let n=a(e),r=i(e,`utf-8`),{name:o,description:s,dev_dependencies:l={},dependencies:u={}}=c.load(D(r));return[{name:o||n.split(`/`).pop(),description:s,type:t.RequirementsTxt,softwareDevelopmentKits:[...Object.entries(u).map(([e,t])=>({name:e,version:typeof t==`string`?t:typeof t==`number`?t.toString():t?.sdk})),...Object.entries(l).map(([e,t])=>({name:e,version:typeof t==`string`?t:typeof t==`number`?t.toString():t?.sdk,isDevDependency:!0}))]}]}},k={supportedFiles:[`composer.json`],ignoreDirs:[`vendor`,`node_modules`,`cache`,`build`,`dist`],scanFunction:e=>{let t=i(e,`utf-8`),n=a(e),{name:r,description:o,require:s={},"require-dev":c={}}=JSON.parse(t);return[{name:r||n.split(`/`).pop(),description:o,softwareDevelopmentKits:[...Object.entries(s).map(([e,t])=>({name:e,version:typeof t==`string`?t:void 0})),...Object.entries(c).map(([e,t])=>({name:e,version:typeof t==`string`?t:void 0,isDevDependency:!0}))]}]}},A=s.type({pins:s.array(s.type({identity:s.string,kind:s.string,location:s.string,state:s.intersection([s.type({revision:s.string}),s.partial({version:s.union([s.string,s.undefined,s.null])})])})),version:s.number}),j=s.type({object:s.type({pins:s.array(s.type({package:s.string,repositoryURL:s.string,state:s.intersection([s.type({branch:s.union([s.string,s.undefined,s.null]),revision:s.string}),s.partial({version:s.union([s.string,s.undefined,s.null])})])}))}),version:s.number}),M={supportedFiles:[`Package.resolved`],ignoreDirs:[],scanFunction:e=>{let r=i(e,`utf-8`);try{let i=n(A,r),o=a(e).split(`/`),s=o[o.length-1],c=s;return c===`swiftpm`&&(c=o[o.length-2],c===`xcshareddata`?c=o[o.length-3]:c||=s,c===`project.xcworkspace`&&(c=o[o.length-4])),[{name:c,type:t.Swift,softwareDevelopmentKits:i.pins.map(e=>({name:e.identity,version:e.state.version||void 0}))}]}catch(i){if(!i?.message?.includes(`Failed to decode codec`))throw i;try{let i=n(j,r);return[{name:a(e).split(`/`).pop()||``,type:t.Swift,softwareDevelopmentKits:i.object.pins.map(e=>({name:e.package,version:e.state.version||void 0}))}]}catch(e){throw e?.message?.includes(`Failed to decode codec`)?i:e}}}},N=`(implementation|api|kapt|ksp|debugImplementation|releaseImplementation|androidTestImplementation|testImplementation|compileOnly|runtimeOnly)`,P=RegExp(`${N}\\s*\\(\\s*["']([^"':\\s]+):([^"':\\s]+):?([^"']*)["']\\s*\\)`,`g`),F=RegExp(`${N}\\s*\\(\\s*platform\\(\\s*["']([^"':\\s]+):([^"':\\s]+):?([^"']*)["']\\s*\\)\\s*\\)`,`g`),I=RegExp(`${N}\\s*\\(\\s*libs(?:\\.[\\w\\-\\.]+|\\[["'][^"']+["']\\])\\s*\\)`,`g`),L=/id\s*\(\s*["']([^"']+)["']\s*\)(?:\s*version\s*["']([^"']+)["'])?/g,R=/apply\s*\(\s*plugin\s*=\s*["']([^"']+)["']\s*\)/g,z=/plugins\s*\{[^}]*alias\s*\(\s*libs(?:\.plugins)?(?:\.[\w\-.]+|\[["'][^"']+["']\])\s*\)[^}]*\}/g,B=/applicationId\s*=\s*["']([^"']+)["']/g,V=/applicationId\s*\(\s*["']([^"']+)["']\s*\)/g;function H(e,t){return{name:e,version:t&&t.trim().length>0&&t!==`_`?t.trim():void 0}}const U={supportedFiles:[`**/build.gradle.kts`,`**/*.gradle.kts`],ignoreDirs:[`gradle-app.setting`,`gradle-wrapper.jar`,`gradle-wrapper.properties`],scanFunction:e=>{let t=i(e,`utf-8`),n=a(e),o=[...r({value:B,matches:[`name`]},t),...r({value:V,matches:[`name`]},t)];if(o.length>1)throw Error(`Expected only one applicationId per file: ${e}`);let s=o[0]?.name||n.split(`/`).pop(),c=[];for(let e of t.matchAll(P)){let[,,t,n,r]=e;c.push(H(`${t}:${n}`,r))}for(let e of t.matchAll(F)){let[,,t,n,r]=e;c.push(H(`${t}:${n}`,r))}for(let e of t.matchAll(I)){let t=e[0].replace(/^[^(]+\(\s*/,``).replace(/\)\s*$/,``).trim();c.push(H(t))}let l=[];for(let e of t.matchAll(L)){let[,t,n]=e;l.push(H(t,n))}for(let e of t.matchAll(R)){let[,t]=e;l.push(H(t))}if(z.test(t)){let e=t.matchAll(/alias\s*\(\s*(libs(?:\.plugins)?(?:\.[\w\-.]+|\[["'][^"']+["']\]))\s*\)/g);for(let t of e)l.push(H(t[1]))}return[{name:s,softwareDevelopmentKits:[...c,...l].reduce((e,t)=>{let n=`${t.name}@@${t.version||``}`;return e.map.has(n)||(e.map.set(n,t),e.list.push(t)),e},{map:new Map,list:[]}).list}]}},W={cocoaPods:d,gradle:g,javascriptPackageJson:_,pythonRequirementsTxt:x,gemfile:E,pubspec:O,swift:M},G={[t.CocoaPods]:d,[t.Gradle]:g,[t.PackageJson]:_,[t.RequirementsTxt]:x,[t.Gemfile]:E,[t.Pubspec]:O,[t.ComposerJson]:k,[t.Swift]:M,[t.Kotlin]:U};export{W as n,G as t};
|
|
4
|
-
//# sourceMappingURL=constants-
|
|
4
|
+
//# sourceMappingURL=constants-mjLYTIJm.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants-AFtS5Nad.mjs","names":[],"sources":["../src/lib/code-scanning/integrations/cocoaPods.ts","../src/lib/code-scanning/integrations/gradle.ts","../src/lib/code-scanning/integrations/javascriptPackageJson.ts","../src/lib/code-scanning/integrations/pythonRequirementsTxt.ts","../src/lib/code-scanning/integrations/gemfile.ts","../src/lib/code-scanning/integrations/pubspec.ts","../src/lib/code-scanning/integrations/composerJson.ts","../src/lib/code-scanning/integrations/swift.ts","../src/lib/code-scanning/integrations/kotlin.ts","../src/lib/code-scanning/constants.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst POD_TARGET_REGEX = /target ('|\")(.*?)('|\")/;\nconst POD_PACKAGE_REGEX = /pod ('|\")(.*?)('|\")(, ('|\")~> (.+?)('|\")|)/;\n\nexport const cocoaPods: CodeScanningConfig = {\n supportedFiles: ['Podfile'],\n ignoreDirs: ['Pods', 'Build'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(POD_TARGET_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2'],\n },\n fileContents,\n );\n const packages = findAllWithRegex(\n {\n value: new RegExp(POD_PACKAGE_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2', 'extra', 'quote3', 'version', 'quote4'],\n },\n fileContents,\n );\n\n const deps: CodePackageSdk[] = targets.map((target, ind) => ({\n name: target.name,\n type: CodePackageType.CocoaPods,\n softwareDevelopmentKits: packages\n .filter(\n (pkg) =>\n pkg.matchIndex > target.matchIndex &&\n (!targets[ind + 1] || pkg.matchIndex < targets[ind + 1].matchIndex),\n )\n .map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n }));\n\n return deps;\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodeScanningConfig } from '../types.js';\n\nconst GRADLE_IMPLEMENTATION_REGEX = /implementation( *)('|\")(.+?):(.+?):(.+?|)('|\")/;\nconst GRADLE_PLUGIN_REGEX = /apply plugin: *('|\")(.+?)(:(.+?)|)('|\")/;\nconst GRADLE_IMPLEMENTATION_GROUP_REGEX =\n /implementation group:( *)('|\")(.+?)('|\"),( *)name:( *)('|\")(.+?)('|\"),( *)version:( *)('|\")(.+?)('|\")/;\nconst GRADLE_APPLICATION_NAME_REGEX = /applicationId( *)\"(.+?)\"/;\n\n/**\n * So far, there are three ways of defining dependencies that is supported\n * implementation group: 'org.eclipse.jdt', name: 'org.eclipse.jdt.core', version: '3.28.0'\n * or\n * implementation 'com.google.firebase:firebase-analytics:18.0.0'\n * or\n * apply plugin: 'com.google.gms.google-services'\n *\n * single and double quotes are both recognized\n */\nexport const gradle: CodeScanningConfig = {\n supportedFiles: ['build.gradle**'],\n ignoreDirs: ['gradle-app.setting', 'gradle-wrapper.jar', 'gradle-wrapper.properties'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(GRADLE_IMPLEMENTATION_REGEX, 'g'),\n matches: ['space', 'quote1', 'name', 'path', 'version', 'quote2'],\n },\n fileContents,\n );\n const targetPlugins = findAllWithRegex(\n {\n value: new RegExp(GRADLE_PLUGIN_REGEX, 'g'),\n matches: ['quote1', 'name', 'group', 'version', 'quote2'],\n },\n fileContents,\n );\n const targetGroups = findAllWithRegex(\n {\n value: new RegExp(GRADLE_IMPLEMENTATION_GROUP_REGEX, 'g'),\n matches: [\n 'space1',\n 'quote1',\n 'group',\n 'quote2',\n 'space2',\n 'space3',\n 'quote3',\n 'name',\n 'quote4',\n 'space4',\n 'space5',\n 'quote5',\n 'version',\n 'quote6',\n ],\n },\n fileContents,\n );\n const applications = findAllWithRegex(\n {\n value: new RegExp(GRADLE_APPLICATION_NAME_REGEX, 'g'),\n matches: ['space', 'name'],\n },\n fileContents,\n );\n if (applications.length > 1) {\n throw new Error(`Expected only one applicationId per file: ${filePath}`);\n }\n\n return [\n {\n name: applications[0]?.name || directory.split('/').pop()!,\n softwareDevelopmentKits: [...targets, ...targetGroups, ...targetPlugins].map((target) => ({\n name: target.name,\n version: target.version || undefined,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nexport const javascriptPackageJson: CodeScanningConfig = {\n supportedFiles: ['package.json'],\n ignoreDirs: ['node_modules', 'serverless-build', 'lambda-build'],\n scanFunction: (filePath) => {\n const file = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const asJson = JSON.parse(file);\n const {\n name,\n description,\n dependencies = {},\n devDependencies = {},\n optionalDependencies = {},\n } = asJson;\n return [\n {\n // name of the package\n name: name || directory.split('/').pop()!,\n description,\n softwareDevelopmentKits: [\n ...Object.entries(dependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ...Object.entries(devDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n isDevDependency: true,\n }),\n ),\n ...Object.entries(optionalDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname, join } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { listFiles } from '../../api-keys/index.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst REQUIREMENTS_PACKAGE_MATCH = /(.+?)(=+)(.+)/;\nconst PACKAGE_NAME = /name *= *('|\")(.+?)('|\")/;\nconst PACKAGE_DESCRIPTION = /description *= *('|\")(.+?)('|\")/;\n\nexport const pythonRequirementsTxt: CodeScanningConfig = {\n supportedFiles: ['requirements.txt'],\n ignoreDirs: ['build', 'lib', 'lib64'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const filesInFolder = listFiles(directory);\n\n // parse setup file for name\n const setupFile = filesInFolder.find((file) => file === 'setup.py');\n const setupFileContents = setupFile\n ? readFileSync(join(directory, setupFile), 'utf-8')\n : undefined;\n const packageName = setupFileContents\n ? (PACKAGE_NAME.exec(setupFileContents) || [])[2]\n : undefined;\n const packageDescription = setupFileContents\n ? (PACKAGE_DESCRIPTION.exec(setupFileContents) || [])[2]\n : undefined;\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(REQUIREMENTS_PACKAGE_MATCH, 'g'),\n matches: ['name', 'equals', 'version'],\n },\n fileContents,\n );\n\n return [\n {\n name: packageName || directory.split('/').pop()!,\n description: packageDescription || undefined,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: targets.map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { listFiles } from '../../api-keys/index.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst GEM_PACKAGE_REGEX = /gem *('|\")(.+?)('|\")(, *('|\")(.+?)('|\")|)/;\nconst GEMFILE_PACKAGE_NAME_REGEX = /spec\\.name *= *('|\")(.+?)('|\")/;\nconst GEMFILE_PACKAGE_DESCRIPTION_REGEX = /spec\\.description *= *('|\")(.+?)('|\")/;\nconst GEMFILE_PACKAGE_SUMMARY_REGEX = /spec\\.summary *= *('|\")(.+?)('|\")/;\n\nexport const gemfile: CodeScanningConfig = {\n supportedFiles: ['Gemfile'],\n ignoreDirs: ['bin'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const filesInFolder = listFiles(directory);\n\n // parse gemspec file for name\n const gemspec = filesInFolder.find((file) => file === '.gemspec');\n const gemspecContents = gemspec ? readFileSync(gemspec, 'utf-8') : undefined;\n const gemfileName = gemspecContents\n ? (GEMFILE_PACKAGE_NAME_REGEX.exec(gemspecContents) || [])[2]\n : undefined;\n const gemfileDescription = gemspecContents\n ? (GEMFILE_PACKAGE_DESCRIPTION_REGEX.exec(gemspecContents) ||\n GEMFILE_PACKAGE_SUMMARY_REGEX.exec(gemspecContents) ||\n [])[1]\n : undefined;\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(GEM_PACKAGE_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2', 'hasVersion', 'quote3', 'version', 'quote4'],\n },\n fileContents,\n );\n\n return [\n {\n name: gemfileName || directory.split('/').pop()!,\n description: gemfileDescription || undefined,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: targets.map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport yaml from 'js-yaml';\n\nimport { CodeScanningConfig } from '../types.js';\n\n/**\n * Remove YAML comments from a string\n *\n * @param yamlString - YAML string\n * @returns String without comments\n */\nfunction removeYAMLComments(yamlString: string): string {\n return yamlString\n .split('\\n')\n .map((line) => {\n // Remove inline comments\n const commentIndex = line.indexOf('#');\n if (commentIndex > -1) {\n // Check if '#' is not inside a string\n if (\n !line.substring(0, commentIndex).includes('\"') &&\n !line.substring(0, commentIndex).includes(\"'\")\n ) {\n return line.substring(0, commentIndex).trim();\n }\n }\n return line;\n })\n .filter((line) => line.length > 0)\n .join('\\n');\n}\n\nexport const pubspec: CodeScanningConfig = {\n supportedFiles: ['pubspec.yml'],\n ignoreDirs: ['build'],\n scanFunction: (filePath) => {\n const directory = dirname(filePath);\n const fileContents = readFileSync(filePath, 'utf-8');\n const {\n name,\n description,\n dev_dependencies = {},\n dependencies = {},\n } = yaml.load(removeYAMLComments(fileContents)) as {\n /** Name */\n name?: string;\n /** Description */\n description?: string;\n /** Dev dependencies */\n dev_dependencies?: { [k in string]: number | Record<string, string> };\n /** Dependencies */\n dependencies?: { [k in string]: number | Record<string, string> };\n };\n return [\n {\n name: name || directory.split('/').pop()!,\n description,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: [\n ...Object.entries(dependencies).map(([name, version]) => ({\n name,\n version:\n typeof version === 'string'\n ? version\n : typeof version === 'number'\n ? version.toString()\n : version?.sdk,\n })),\n ...Object.entries(dev_dependencies).map(([name, version]) => ({\n name,\n version:\n typeof version === 'string'\n ? version\n : typeof version === 'number'\n ? version.toString()\n : version?.sdk,\n isDevDependency: true,\n })),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nexport const composerJson: CodeScanningConfig = {\n supportedFiles: ['composer.json'],\n ignoreDirs: ['vendor', 'node_modules', 'cache', 'build', 'dist'],\n scanFunction: (filePath) => {\n const file = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const asJson = JSON.parse(file);\n const {\n name,\n description,\n require: requireDependencies = {},\n 'require-dev': requiredDevDependencies = {},\n } = asJson;\n return [\n {\n // name of the package\n name: name || directory.split('/').pop()!,\n description,\n softwareDevelopmentKits: [\n ...Object.entries(requireDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ...Object.entries(requiredDevDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n isDevDependency: true,\n }),\n ),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { decodeCodec } from '@transcend-io/type-utils';\nimport * as t from 'io-ts';\n\nimport { CodeScanningConfig } from '../types.js';\n\nconst SwiftPackage = t.type({\n pins: t.array(\n t.type({\n identity: t.string,\n kind: t.string,\n location: t.string,\n state: t.intersection([\n t.type({\n revision: t.string,\n }),\n t.partial({\n version: t.union([t.string, t.undefined, t.null]),\n }),\n ]),\n }),\n ),\n version: t.number,\n});\n\nconst SwiftPackageV1 = t.type({\n object: t.type({\n pins: t.array(\n t.type({\n package: t.string,\n repositoryURL: t.string,\n state: t.intersection([\n t.type({\n branch: t.union([t.string, t.undefined, t.null]),\n revision: t.string,\n }),\n t.partial({\n version: t.union([t.string, t.undefined, t.null]),\n }),\n ]),\n }),\n ),\n }),\n version: t.number,\n});\n\nexport const swift: CodeScanningConfig = {\n supportedFiles: ['Package.resolved'],\n ignoreDirs: [],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n\n // Attempt latest version first\n try {\n const parsed = decodeCodec(SwiftPackage, fileContents);\n const splitPath = dirname(filePath).split('/');\n const originalName = splitPath[splitPath.length - 1];\n let name = originalName;\n if (name === 'swiftpm') {\n name = splitPath[splitPath.length - 2];\n if (name === 'xcshareddata') {\n name = splitPath[splitPath.length - 3];\n } else if (!name) {\n name = originalName;\n }\n if (name === 'project.xcworkspace') {\n name = splitPath[splitPath.length - 4];\n }\n }\n return [\n {\n name,\n type: CodePackageType.Swift,\n softwareDevelopmentKits: parsed.pins.map((target) => ({\n name: target.identity,\n version: target.state.version || undefined,\n })),\n },\n ];\n } catch (e) {\n // Throw non codec errors\n if (!e?.message?.includes('Failed to decode codec')) {\n throw e;\n }\n\n // Attempt v1\n try {\n const parsed = decodeCodec(SwiftPackageV1, fileContents);\n return [\n {\n name: dirname(filePath).split('/').pop() || '', // TODO pull from Package.swift ->> name if possible\n type: CodePackageType.Swift,\n softwareDevelopmentKits: parsed.object.pins.map((target) => ({\n name: target.package,\n version: target.state.version || undefined,\n })),\n },\n ];\n } catch (e2) {\n if (!e2?.message?.includes('Failed to decode codec')) {\n throw e2;\n }\n throw e;\n }\n }\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodeScanningConfig } from '../types.js';\n\n/**\n * Kotlin DSL (build.gradle.kts) dependency & plugin parsing\n */\n\nconst KTS_DEP_CONFIGS =\n // eslint-disable-next-line max-len\n '(implementation|api|kapt|ksp|debugImplementation|releaseImplementation|androidTestImplementation|testImplementation|compileOnly|runtimeOnly)';\n\n// e.g. implementation(\"com.google.firebase:firebase-analytics:18.0.0\")\nconst KTS_DEP_STRING_COORDS_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*[\"']([^\"':\\\\s]+):([^\"':\\\\s]+):?([^\"']*)[\"']\\\\s*\\\\)`,\n 'g',\n);\n// captures: [1]=config, [2]=group, [3]=artifact, [4]=version (may be '')\n\n// e.g. implementation(platform(\"com.google.firebase:firebase-bom:33.1.2\"))\nconst KTS_DEP_PLATFORM_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*platform\\\\(\\\\s*[\"']([^\"':\\\\s]+):([^\"':\\\\s]+):?([^\"']*)[\"']\\\\s*\\\\)\\\\s*\\\\)`,\n 'g',\n);\n\n// e.g. implementation(libs.androidx.appcompat) / implementation(libs[\"androidx-core-ktx\"])\nconst KTS_DEP_LIBS_ALIAS_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*libs(?:\\\\.[\\\\w\\\\-\\\\.]+|\\\\[[\"'][^\"']+[\"']\\\\])\\\\s*\\\\)`,\n 'g',\n);\n\n// Plugins:\n// plugins { id(\"com.google.gms.google-services\") version \"4.4.2\" apply false }\n// plugins { id(\"org.jetbrains.kotlin.android\") }\n// apply(plugin = \"newrelic\")\n// plugins { alias(libs.plugins.kotlin.android) }\nconst KTS_PLUGIN_ID_REGEX = /id\\s*\\(\\s*[\"']([^\"']+)[\"']\\s*\\)(?:\\s*version\\s*[\"']([^\"']+)[\"'])?/g;\nconst KTS_PLUGIN_APPLY_REGEX = /apply\\s*\\(\\s*plugin\\s*=\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\nconst KTS_PLUGIN_ALIAS_REGEX =\n /plugins\\s*\\{[^}]*alias\\s*\\(\\s*libs(?:\\.plugins)?(?:\\.[\\w\\-.]+|\\[[\"'][^\"']+[\"']\\])\\s*\\)[^}]*\\}/g;\n\n// applicationId in Kotlin DSL:\n// applicationId = \"com.foo.bar\"\n// applicationId(\"com.foo.bar\")\nconst KTS_APPLICATION_ID_EQ_REGEX = /applicationId\\s*=\\s*[\"']([^\"']+)[\"']/g;\nconst KTS_APPLICATION_ID_CALL_REGEX = /applicationId\\s*\\(\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\n\n/**\n * Input dep entry (partial)\n */\ntype DepInput = {\n /** Name of the dependency */\n name: string;\n /** Version of the dependency */\n version?: string;\n};\n\n/**\n * Helper to normalize a parsed dep entry\n *\n * @param name - name\n * @param version - version\n * @returns normalized entry\n */\nfunction depEntry(name: string, version?: string): DepInput {\n const v = version && version.trim().length > 0 && version !== '_' ? version.trim() : undefined;\n return { name, version: v };\n}\n\nexport const kotlin: CodeScanningConfig = {\n supportedFiles: ['**/build.gradle.kts', '**/*.gradle.kts'],\n ignoreDirs: ['gradle-app.setting', 'gradle-wrapper.jar', 'gradle-wrapper.properties'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n\n // ---------- applicationId ----------\n const appIds = [\n ...findAllWithRegex({ value: KTS_APPLICATION_ID_EQ_REGEX, matches: ['name'] }, fileContents),\n ...findAllWithRegex(\n { value: KTS_APPLICATION_ID_CALL_REGEX, matches: ['name'] },\n fileContents,\n ),\n ];\n if (appIds.length > 1) {\n throw new Error(`Expected only one applicationId per file: ${filePath}`);\n }\n const appName = appIds[0]?.name || directory.split('/').pop()!;\n\n // ---------- dependencies ----------\n const deps: Array<DepInput> = [];\n\n // \"group:artifact:version\"\n for (const m of fileContents.matchAll(KTS_DEP_STRING_COORDS_REGEX)) {\n const [, , group, artifact, version] = m;\n deps.push(depEntry(`${group}:${artifact}`, version));\n }\n\n // platform(\"group:artifact:version\")\n for (const m of fileContents.matchAll(KTS_DEP_PLATFORM_REGEX)) {\n const [, , group, artifact, version] = m;\n // Record as regular coord (you may prefer to tag as BoM separately)\n deps.push(depEntry(`${group}:${artifact}`, version));\n }\n\n // libs aliases (version catalogs) — keep alias as name, unknown version\n for (const m of fileContents.matchAll(KTS_DEP_LIBS_ALIAS_REGEX)) {\n // Grab the exact token as name (best-effort)\n const token = m[0]\n .replace(/^[^(]+\\(\\s*/, '')\n .replace(/\\)\\s*$/, '')\n .trim(); // e.g., libs.androidx.appcompat or libs[\"androidx-core-ktx\"]\n deps.push(depEntry(token));\n }\n\n // ---------- plugins ----------\n const plugins: Array<DepInput> = [];\n\n for (const m of fileContents.matchAll(KTS_PLUGIN_ID_REGEX)) {\n const [, pid, pver] = m;\n plugins.push(depEntry(pid, pver));\n }\n\n for (const m of fileContents.matchAll(KTS_PLUGIN_APPLY_REGEX)) {\n const [, pid] = m;\n plugins.push(depEntry(pid));\n }\n\n // alias(libs.plugins...) — keep alias token (no version)\n if (KTS_PLUGIN_ALIAS_REGEX.test(fileContents)) {\n // Collect all alias lines to preserve identifiers; light parse:\n const aliasMatches = fileContents.matchAll(\n /alias\\s*\\(\\s*(libs(?:\\.plugins)?(?:\\.[\\w\\-.]+|\\[[\"'][^\"']+[\"']\\]))\\s*\\)/g,\n );\n for (const m of aliasMatches) {\n plugins.push(depEntry(m[1]));\n }\n }\n\n // ---------- compose final list ----------\n // Merge deps + plugins as \"softwareDevelopmentKits\"\n const softwareDevelopmentKits = [...deps, ...plugins]\n // de-dup by name+version\n .reduce(\n (acc, cur) => {\n const key = `${cur.name}@@${cur.version || ''}`;\n if (!acc.map.has(key)) {\n acc.map.set(key, cur);\n acc.list.push(cur);\n }\n return acc;\n },\n {\n map: new Map<string, DepInput>(),\n list: [] as Array<DepInput>,\n },\n ).list;\n\n return [\n {\n name: appName,\n softwareDevelopmentKits,\n },\n ];\n },\n};\n","import { CodePackageType } from '@transcend-io/privacy-types';\n\nimport {\n cocoaPods,\n gradle,\n javascriptPackageJson,\n gemfile,\n composerJson,\n pubspec,\n swift,\n kotlin,\n pythonRequirementsTxt,\n} from './integrations/index.js';\nimport { CodeScanningConfig } from './types.js';\n\n/**\n * @deprecated TODO: https://transcend.height.app/T-32325 - use code scanning instead\n */\nexport const SILO_DISCOVERY_CONFIGS: {\n [k in string]: CodeScanningConfig;\n} = {\n cocoaPods,\n gradle,\n javascriptPackageJson,\n pythonRequirementsTxt,\n gemfile,\n pubspec,\n swift,\n};\n\nexport const CODE_SCANNING_CONFIGS: {\n [k in CodePackageType]: CodeScanningConfig;\n} = {\n [CodePackageType.CocoaPods]: cocoaPods,\n [CodePackageType.Gradle]: gradle,\n [CodePackageType.PackageJson]: javascriptPackageJson,\n [CodePackageType.RequirementsTxt]: pythonRequirementsTxt,\n [CodePackageType.Gemfile]: gemfile,\n [CodePackageType.Pubspec]: pubspec,\n [CodePackageType.ComposerJson]: composerJson,\n [CodePackageType.Swift]: swift,\n [CodePackageType.Kotlin]: kotlin,\n};\n"],"mappings":"4TAQA,MAAM,EAAmB,yBACnB,EAAoB,6CAEb,EAAgC,CAC3C,eAAgB,CAAC,UAAU,CAC3B,WAAY,CAAC,OAAQ,QAAQ,CAC7B,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAE9C,EAAU,EACd,CACE,MAAO,IAAI,OAAO,EAAkB,IAAI,CACxC,QAAS,CAAC,SAAU,OAAQ,SAAS,CACtC,CACD,EACD,CACK,EAAW,EACf,CACE,MAAO,IAAI,OAAO,EAAmB,IAAI,CACzC,QAAS,CAAC,SAAU,OAAQ,SAAU,QAAS,SAAU,UAAW,SAAS,CAC9E,CACD,EACD,CAiBD,OAf+B,EAAQ,KAAK,EAAQ,KAAS,CAC3D,KAAM,EAAO,KACb,KAAM,EAAgB,UACtB,wBAAyB,EACtB,OACE,GACC,EAAI,WAAa,EAAO,aACvB,CAAC,EAAQ,EAAM,IAAM,EAAI,WAAa,EAAQ,EAAM,GAAG,YAC3D,CACA,IAAK,IAAS,CACb,KAAM,EAAI,KACV,QAAS,EAAI,QACd,EAAE,CACN,EAAE,EAIN,CC1CK,EAA8B,iDAC9B,EAAsB,0CACtB,EACJ,wGACI,EAAgC,2BAYzB,EAA6B,CACxC,eAAgB,CAAC,iBAAiB,CAClC,WAAY,CAAC,qBAAsB,qBAAsB,4BAA4B,CACrF,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAC9C,EAAY,EAAQ,EAAS,CAE7B,EAAU,EACd,CACE,MAAO,IAAI,OAAO,EAA6B,IAAI,CACnD,QAAS,CAAC,QAAS,SAAU,OAAQ,OAAQ,UAAW,SAAS,CAClE,CACD,EACD,CACK,EAAgB,EACpB,CACE,MAAO,IAAI,OAAO,EAAqB,IAAI,CAC3C,QAAS,CAAC,SAAU,OAAQ,QAAS,UAAW,SAAS,CAC1D,CACD,EACD,CACK,EAAe,EACnB,CACE,MAAO,IAAI,OAAO,EAAmC,IAAI,CACzD,QAAS,CACP,SACA,SACA,QACA,SACA,SACA,SACA,SACA,OACA,SACA,SACA,SACA,SACA,UACA,SACD,CACF,CACD,EACD,CACK,EAAe,EACnB,CACE,MAAO,IAAI,OAAO,EAA+B,IAAI,CACrD,QAAS,CAAC,QAAS,OAAO,CAC3B,CACD,EACD,CACD,GAAI,EAAa,OAAS,EACxB,MAAU,MAAM,6CAA6C,IAAW,CAG1E,MAAO,CACL,CACE,KAAM,EAAa,IAAI,MAAQ,EAAU,MAAM,IAAI,CAAC,KAAK,CACzD,wBAAyB,CAAC,GAAG,EAAS,GAAG,EAAc,GAAG,EAAc,CAAC,IAAK,IAAY,CACxF,KAAM,EAAO,KACb,QAAS,EAAO,SAAW,IAAA,GAC5B,EAAE,CACJ,CACF,EAEJ,CCjFY,EAA4C,CACvD,eAAgB,CAAC,eAAe,CAChC,WAAY,CAAC,eAAgB,mBAAoB,eAAe,CAChE,aAAe,GAAa,CAC1B,IAAM,EAAO,EAAa,EAAU,QAAQ,CACtC,EAAY,EAAQ,EAAS,CAE7B,CACJ,OACA,cACA,eAAe,EAAE,CACjB,kBAAkB,EAAE,CACpB,uBAAuB,EAAE,EANZ,KAAK,MAAM,EAAK,CAQ/B,MAAO,CACL,CAEE,KAAM,GAAQ,EAAU,MAAM,IAAI,CAAC,KAAK,CACxC,cACA,wBAAyB,CACvB,GAAG,OAAO,QAAQ,EAAa,CAAC,KAC7B,CAAC,EAAM,MAA8B,CACpC,OACA,QAAS,OAAO,GAAY,SAAW,EAAU,IAAA,GAClD,EACF,CACD,GAAG,OAAO,QAAQ,EAAgB,CAAC,KAChC,CAAC,EAAM,MAA8B,CACpC,OACA,QAAS,OAAO,GAAY,SAAW,EAAU,IAAA,GACjD,gBAAiB,GAClB,EACF,CACD,GAAG,OAAO,QAAQ,EAAqB,CAAC,KACrC,CAAC,EAAM,MAA8B,CACpC,OACA,QAAS,OAAO,GAAY,SAAW,EAAU,IAAA,GAClD,EACF,CACF,CACF,CACF,EAEJ,CCxCK,EAA6B,gBAC7B,EAAe,2BACf,EAAsB,kCAEf,EAA4C,CACvD,eAAgB,CAAC,mBAAmB,CACpC,WAAY,CAAC,QAAS,MAAO,QAAQ,CACrC,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAC9C,EAAY,EAAQ,EAAS,CAI7B,EAHgB,EAAU,EAAU,CAGV,KAAM,GAAS,IAAS,WAAW,CAC7D,EAAoB,EACtB,EAAa,EAAK,EAAW,EAAU,CAAE,QAAQ,CACjD,IAAA,GACE,EAAc,GACf,EAAa,KAAK,EAAkB,EAAI,EAAE,EAAE,GAC7C,IAAA,GACE,EAAqB,GACtB,EAAoB,KAAK,EAAkB,EAAI,EAAE,EAAE,GACpD,IAAA,GAEE,EAAU,EACd,CACE,MAAO,IAAI,OAAO,EAA4B,IAAI,CAClD,QAAS,CAAC,OAAQ,SAAU,UAAU,CACvC,CACD,EACD,CAED,MAAO,CACL,CACE,KAAM,GAAe,EAAU,MAAM,IAAI,CAAC,KAAK,CAC/C,YAAa,GAAsB,IAAA,GACnC,KAAM,EAAgB,gBACtB,wBAAyB,EAAQ,IAAK,IAAS,CAC7C,KAAM,EAAI,KACV,QAAS,EAAI,QACd,EAAE,CACJ,CACF,EAEJ,CC5CK,EAAoB,4CACpB,EAA6B,iCAC7B,EAAoC,wCACpC,EAAgC,oCAEzB,EAA8B,CACzC,eAAgB,CAAC,UAAU,CAC3B,WAAY,CAAC,MAAM,CACnB,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAC9C,EAAY,EAAQ,EAAS,CAI7B,EAHgB,EAAU,EAAU,CAGZ,KAAM,GAAS,IAAS,WAAW,CAC3D,EAAkB,EAAU,EAAa,EAAS,QAAQ,CAAG,IAAA,GAC7D,EAAc,GACf,EAA2B,KAAK,EAAgB,EAAI,EAAE,EAAE,GACzD,IAAA,GACE,EAAqB,GACtB,EAAkC,KAAK,EAAgB,EACtD,EAA8B,KAAK,EAAgB,EACnD,EAAE,EAAE,GACN,IAAA,GAEE,EAAU,EACd,CACE,MAAO,IAAI,OAAO,EAAmB,IAAI,CACzC,QAAS,CAAC,SAAU,OAAQ,SAAU,aAAc,SAAU,UAAW,SAAS,CACnF,CACD,EACD,CAED,MAAO,CACL,CACE,KAAM,GAAe,EAAU,MAAM,IAAI,CAAC,KAAK,CAC/C,YAAa,GAAsB,IAAA,GACnC,KAAM,EAAgB,gBACtB,wBAAyB,EAAQ,IAAK,IAAS,CAC7C,KAAM,EAAI,KACV,QAAS,EAAI,QACd,EAAE,CACJ,CACF,EAEJ,CCxCD,SAAS,EAAmB,EAA4B,CACtD,OAAO,EACJ,MAAM;EAAK,CACX,IAAK,GAAS,CAEb,IAAM,EAAe,EAAK,QAAQ,IAAI,CAUtC,OATI,EAAe,IAGf,CAAC,EAAK,UAAU,EAAG,EAAa,CAAC,SAAS,IAAI,EAC9C,CAAC,EAAK,UAAU,EAAG,EAAa,CAAC,SAAS,IAAI,CAEvC,EAAK,UAAU,EAAG,EAAa,CAAC,MAAM,CAG1C,GACP,CACD,OAAQ,GAAS,EAAK,OAAS,EAAE,CACjC,KAAK;EAAK,CAGf,MAAa,EAA8B,CACzC,eAAgB,CAAC,cAAc,CAC/B,WAAY,CAAC,QAAQ,CACrB,aAAe,GAAa,CAC1B,IAAM,EAAY,EAAQ,EAAS,CAC7B,EAAe,EAAa,EAAU,QAAQ,CAC9C,CACJ,OACA,cACA,mBAAmB,EAAE,CACrB,eAAe,EAAE,EACf,EAAK,KAAK,EAAmB,EAAa,CAAC,CAU/C,MAAO,CACL,CACE,KAAM,GAAQ,EAAU,MAAM,IAAI,CAAC,KAAK,CACxC,cACA,KAAM,EAAgB,gBACtB,wBAAyB,CACvB,GAAG,OAAO,QAAQ,EAAa,CAAC,KAAK,CAAC,EAAM,MAAc,CACxD,OACA,QACE,OAAO,GAAY,SACf,EACA,OAAO,GAAY,SACjB,EAAQ,UAAU,CAClB,GAAS,IAClB,EAAE,CACH,GAAG,OAAO,QAAQ,EAAiB,CAAC,KAAK,CAAC,EAAM,MAAc,CAC5D,OACA,QACE,OAAO,GAAY,SACf,EACA,OAAO,GAAY,SACjB,EAAQ,UAAU,CAClB,GAAS,IACjB,gBAAiB,GAClB,EAAE,CACJ,CACF,CACF,EAEJ,CC/EY,EAAmC,CAC9C,eAAgB,CAAC,gBAAgB,CACjC,WAAY,CAAC,SAAU,eAAgB,QAAS,QAAS,OAAO,CAChE,aAAe,GAAa,CAC1B,IAAM,EAAO,EAAa,EAAU,QAAQ,CACtC,EAAY,EAAQ,EAAS,CAE7B,CACJ,OACA,cACA,QAAS,EAAsB,EAAE,CACjC,cAAe,EAA0B,EAAE,EAL9B,KAAK,MAAM,EAAK,CAO/B,MAAO,CACL,CAEE,KAAM,GAAQ,EAAU,MAAM,IAAI,CAAC,KAAK,CACxC,cACA,wBAAyB,CACvB,GAAG,OAAO,QAAQ,EAAoB,CAAC,KACpC,CAAC,EAAM,MAA8B,CACpC,OACA,QAAS,OAAO,GAAY,SAAW,EAAU,IAAA,GAClD,EACF,CACD,GAAG,OAAO,QAAQ,EAAwB,CAAC,KACxC,CAAC,EAAM,MAA8B,CACpC,OACA,QAAS,OAAO,GAAY,SAAW,EAAU,IAAA,GACjD,gBAAiB,GAClB,EACF,CACF,CACF,CACF,EAEJ,CCjCK,EAAe,EAAE,KAAK,CAC1B,KAAM,EAAE,MACN,EAAE,KAAK,CACL,SAAU,EAAE,OACZ,KAAM,EAAE,OACR,SAAU,EAAE,OACZ,MAAO,EAAE,aAAa,CACpB,EAAE,KAAK,CACL,SAAU,EAAE,OACb,CAAC,CACF,EAAE,QAAQ,CACR,QAAS,EAAE,MAAM,CAAC,EAAE,OAAQ,EAAE,UAAW,EAAE,KAAK,CAAC,CAClD,CAAC,CACH,CAAC,CACH,CAAC,CACH,CACD,QAAS,EAAE,OACZ,CAAC,CAEI,EAAiB,EAAE,KAAK,CAC5B,OAAQ,EAAE,KAAK,CACb,KAAM,EAAE,MACN,EAAE,KAAK,CACL,QAAS,EAAE,OACX,cAAe,EAAE,OACjB,MAAO,EAAE,aAAa,CACpB,EAAE,KAAK,CACL,OAAQ,EAAE,MAAM,CAAC,EAAE,OAAQ,EAAE,UAAW,EAAE,KAAK,CAAC,CAChD,SAAU,EAAE,OACb,CAAC,CACF,EAAE,QAAQ,CACR,QAAS,EAAE,MAAM,CAAC,EAAE,OAAQ,EAAE,UAAW,EAAE,KAAK,CAAC,CAClD,CAAC,CACH,CAAC,CACH,CAAC,CACH,CACF,CAAC,CACF,QAAS,EAAE,OACZ,CAAC,CAEW,EAA4B,CACvC,eAAgB,CAAC,mBAAmB,CACpC,WAAY,EAAE,CACd,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAGpD,GAAI,CACF,IAAM,EAAS,EAAY,EAAc,EAAa,CAChD,EAAY,EAAQ,EAAS,CAAC,MAAM,IAAI,CACxC,EAAe,EAAU,EAAU,OAAS,GAC9C,EAAO,EAYX,OAXI,IAAS,YACX,EAAO,EAAU,EAAU,OAAS,GAChC,IAAS,eACX,EAAO,EAAU,EAAU,OAAS,GAEpC,IAAO,EAEL,IAAS,wBACX,EAAO,EAAU,EAAU,OAAS,KAGjC,CACL,CACE,OACA,KAAM,EAAgB,MACtB,wBAAyB,EAAO,KAAK,IAAK,IAAY,CACpD,KAAM,EAAO,SACb,QAAS,EAAO,MAAM,SAAW,IAAA,GAClC,EAAE,CACJ,CACF,OACM,EAAG,CAEV,GAAI,CAAC,GAAG,SAAS,SAAS,yBAAyB,CACjD,MAAM,EAIR,GAAI,CACF,IAAM,EAAS,EAAY,EAAgB,EAAa,CACxD,MAAO,CACL,CACE,KAAM,EAAQ,EAAS,CAAC,MAAM,IAAI,CAAC,KAAK,EAAI,GAC5C,KAAM,EAAgB,MACtB,wBAAyB,EAAO,OAAO,KAAK,IAAK,IAAY,CAC3D,KAAM,EAAO,QACb,QAAS,EAAO,MAAM,SAAW,IAAA,GAClC,EAAE,CACJ,CACF,OACM,EAAI,CAIX,MAHK,GAAI,SAAS,SAAS,yBAAyB,CAG9C,EAFE,KAMf,CClGK,EAEJ,+IAGI,EAAkC,OACtC,GAAG,EAAgB,+DACnB,IACD,CAIK,EAA6B,OACjC,GAAG,EAAgB,qFACnB,IACD,CAGK,EAA+B,OACnC,GAAG,EAAgB,gEACnB,IACD,CAOK,EAAsB,qEACtB,EAAyB,mDACzB,EACJ,iGAKI,EAA8B,wCAC9B,EAAgC,8CAmBtC,SAAS,EAAS,EAAc,EAA4B,CAE1D,MAAO,CAAE,OAAM,QADL,GAAW,EAAQ,MAAM,CAAC,OAAS,GAAK,IAAY,IAAM,EAAQ,MAAM,CAAG,IAAA,GAC1D,CAG7B,MAAa,EAA6B,CACxC,eAAgB,CAAC,sBAAuB,kBAAkB,CAC1D,WAAY,CAAC,qBAAsB,qBAAsB,4BAA4B,CACrF,aAAe,GAAa,CAC1B,IAAM,EAAe,EAAa,EAAU,QAAQ,CAC9C,EAAY,EAAQ,EAAS,CAG7B,EAAS,CACb,GAAG,EAAiB,CAAE,MAAO,EAA6B,QAAS,CAAC,OAAO,CAAE,CAAE,EAAa,CAC5F,GAAG,EACD,CAAE,MAAO,EAA+B,QAAS,CAAC,OAAO,CAAE,CAC3D,EACD,CACF,CACD,GAAI,EAAO,OAAS,EAClB,MAAU,MAAM,6CAA6C,IAAW,CAE1E,IAAM,EAAU,EAAO,IAAI,MAAQ,EAAU,MAAM,IAAI,CAAC,KAAK,CAGvD,EAAwB,EAAE,CAGhC,IAAK,IAAM,KAAK,EAAa,SAAS,EAA4B,CAAE,CAClE,GAAM,GAAK,EAAO,EAAU,GAAW,EACvC,EAAK,KAAK,EAAS,GAAG,EAAM,GAAG,IAAY,EAAQ,CAAC,CAItD,IAAK,IAAM,KAAK,EAAa,SAAS,EAAuB,CAAE,CAC7D,GAAM,GAAK,EAAO,EAAU,GAAW,EAEvC,EAAK,KAAK,EAAS,GAAG,EAAM,GAAG,IAAY,EAAQ,CAAC,CAItD,IAAK,IAAM,KAAK,EAAa,SAAS,EAAyB,CAAE,CAE/D,IAAM,EAAQ,EAAE,GACb,QAAQ,cAAe,GAAG,CAC1B,QAAQ,SAAU,GAAG,CACrB,MAAM,CACT,EAAK,KAAK,EAAS,EAAM,CAAC,CAI5B,IAAM,EAA2B,EAAE,CAEnC,IAAK,IAAM,KAAK,EAAa,SAAS,EAAoB,CAAE,CAC1D,GAAM,EAAG,EAAK,GAAQ,EACtB,EAAQ,KAAK,EAAS,EAAK,EAAK,CAAC,CAGnC,IAAK,IAAM,KAAK,EAAa,SAAS,EAAuB,CAAE,CAC7D,GAAM,EAAG,GAAO,EAChB,EAAQ,KAAK,EAAS,EAAI,CAAC,CAI7B,GAAI,EAAuB,KAAK,EAAa,CAAE,CAE7C,IAAM,EAAe,EAAa,SAChC,2EACD,CACD,IAAK,IAAM,KAAK,EACd,EAAQ,KAAK,EAAS,EAAE,GAAG,CAAC,CAuBhC,MAAO,CACL,CACE,KAAM,EACN,wBApB4B,CAAC,GAAG,EAAM,GAAG,EAAQ,CAElD,QACE,EAAK,IAAQ,CACZ,IAAM,EAAM,GAAG,EAAI,KAAK,IAAI,EAAI,SAAW,KAK3C,OAJK,EAAI,IAAI,IAAI,EAAI,GACnB,EAAI,IAAI,IAAI,EAAK,EAAI,CACrB,EAAI,KAAK,KAAK,EAAI,EAEb,GAET,CACE,IAAK,IAAI,IACT,KAAM,EAAE,CACT,CACF,CAAC,KAMD,CACF,EAEJ,CCtJY,EAET,CACF,YACA,SACA,wBACA,wBACA,UACA,UACA,QACD,CAEY,EAET,EACD,EAAgB,WAAY,GAC5B,EAAgB,QAAS,GACzB,EAAgB,aAAc,GAC9B,EAAgB,iBAAkB,GAClC,EAAgB,SAAU,GAC1B,EAAgB,SAAU,GAC1B,EAAgB,cAAe,GAC/B,EAAgB,OAAQ,GACxB,EAAgB,QAAS,EAC3B"}
|
|
1
|
+
{"version":3,"file":"constants-mjLYTIJm.mjs","names":[],"sources":["../src/lib/code-scanning/integrations/cocoaPods.ts","../src/lib/code-scanning/integrations/gradle.ts","../src/lib/code-scanning/integrations/javascriptPackageJson.ts","../src/lib/code-scanning/integrations/pythonRequirementsTxt.ts","../src/lib/code-scanning/integrations/gemfile.ts","../src/lib/code-scanning/integrations/pubspec.ts","../src/lib/code-scanning/integrations/composerJson.ts","../src/lib/code-scanning/integrations/swift.ts","../src/lib/code-scanning/integrations/kotlin.ts","../src/lib/code-scanning/constants.ts"],"sourcesContent":["import { readFileSync } from 'node:fs';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst POD_TARGET_REGEX = /target ('|\")(.*?)('|\")/;\nconst POD_PACKAGE_REGEX = /pod ('|\")(.*?)('|\")(, ('|\")~> (.+?)('|\")|)/;\n\nexport const cocoaPods: CodeScanningConfig = {\n supportedFiles: ['Podfile'],\n ignoreDirs: ['Pods', 'Build'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(POD_TARGET_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2'],\n },\n fileContents,\n );\n const packages = findAllWithRegex(\n {\n value: new RegExp(POD_PACKAGE_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2', 'extra', 'quote3', 'version', 'quote4'],\n },\n fileContents,\n );\n\n const deps: CodePackageSdk[] = targets.map((target, ind) => ({\n name: target.name,\n type: CodePackageType.CocoaPods,\n softwareDevelopmentKits: packages\n .filter(\n (pkg) =>\n pkg.matchIndex > target.matchIndex &&\n (!targets[ind + 1] || pkg.matchIndex < targets[ind + 1].matchIndex),\n )\n .map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n }));\n\n return deps;\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodeScanningConfig } from '../types.js';\n\nconst GRADLE_IMPLEMENTATION_REGEX = /implementation( *)('|\")(.+?):(.+?):(.+?|)('|\")/;\nconst GRADLE_PLUGIN_REGEX = /apply plugin: *('|\")(.+?)(:(.+?)|)('|\")/;\nconst GRADLE_IMPLEMENTATION_GROUP_REGEX =\n /implementation group:( *)('|\")(.+?)('|\"),( *)name:( *)('|\")(.+?)('|\"),( *)version:( *)('|\")(.+?)('|\")/;\nconst GRADLE_APPLICATION_NAME_REGEX = /applicationId( *)\"(.+?)\"/;\n\n/**\n * So far, there are three ways of defining dependencies that is supported\n * implementation group: 'org.eclipse.jdt', name: 'org.eclipse.jdt.core', version: '3.28.0'\n * or\n * implementation 'com.google.firebase:firebase-analytics:18.0.0'\n * or\n * apply plugin: 'com.google.gms.google-services'\n *\n * single and double quotes are both recognized\n */\nexport const gradle: CodeScanningConfig = {\n supportedFiles: ['build.gradle**'],\n ignoreDirs: ['gradle-app.setting', 'gradle-wrapper.jar', 'gradle-wrapper.properties'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(GRADLE_IMPLEMENTATION_REGEX, 'g'),\n matches: ['space', 'quote1', 'name', 'path', 'version', 'quote2'],\n },\n fileContents,\n );\n const targetPlugins = findAllWithRegex(\n {\n value: new RegExp(GRADLE_PLUGIN_REGEX, 'g'),\n matches: ['quote1', 'name', 'group', 'version', 'quote2'],\n },\n fileContents,\n );\n const targetGroups = findAllWithRegex(\n {\n value: new RegExp(GRADLE_IMPLEMENTATION_GROUP_REGEX, 'g'),\n matches: [\n 'space1',\n 'quote1',\n 'group',\n 'quote2',\n 'space2',\n 'space3',\n 'quote3',\n 'name',\n 'quote4',\n 'space4',\n 'space5',\n 'quote5',\n 'version',\n 'quote6',\n ],\n },\n fileContents,\n );\n const applications = findAllWithRegex(\n {\n value: new RegExp(GRADLE_APPLICATION_NAME_REGEX, 'g'),\n matches: ['space', 'name'],\n },\n fileContents,\n );\n if (applications.length > 1) {\n throw new Error(`Expected only one applicationId per file: ${filePath}`);\n }\n\n return [\n {\n name: applications[0]?.name || directory.split('/').pop()!,\n softwareDevelopmentKits: [...targets, ...targetGroups, ...targetPlugins].map((target) => ({\n name: target.name,\n version: target.version || undefined,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nexport const javascriptPackageJson: CodeScanningConfig = {\n supportedFiles: ['package.json'],\n ignoreDirs: ['node_modules', 'serverless-build', 'lambda-build'],\n scanFunction: (filePath) => {\n const file = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const asJson = JSON.parse(file);\n const {\n name,\n description,\n dependencies = {},\n devDependencies = {},\n optionalDependencies = {},\n } = asJson;\n return [\n {\n // name of the package\n name: name || directory.split('/').pop()!,\n description,\n softwareDevelopmentKits: [\n ...Object.entries(dependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ...Object.entries(devDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n isDevDependency: true,\n }),\n ),\n ...Object.entries(optionalDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname, join } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { listFiles } from '../../api-keys/index.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst REQUIREMENTS_PACKAGE_MATCH = /(.+?)(=+)(.+)/;\nconst PACKAGE_NAME = /name *= *('|\")(.+?)('|\")/;\nconst PACKAGE_DESCRIPTION = /description *= *('|\")(.+?)('|\")/;\n\nexport const pythonRequirementsTxt: CodeScanningConfig = {\n supportedFiles: ['requirements.txt'],\n ignoreDirs: ['build', 'lib', 'lib64'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const filesInFolder = listFiles(directory);\n\n // parse setup file for name\n const setupFile = filesInFolder.find((file) => file === 'setup.py');\n const setupFileContents = setupFile\n ? readFileSync(join(directory, setupFile), 'utf-8')\n : undefined;\n const packageName = setupFileContents\n ? (PACKAGE_NAME.exec(setupFileContents) || [])[2]\n : undefined;\n const packageDescription = setupFileContents\n ? (PACKAGE_DESCRIPTION.exec(setupFileContents) || [])[2]\n : undefined;\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(REQUIREMENTS_PACKAGE_MATCH, 'g'),\n matches: ['name', 'equals', 'version'],\n },\n fileContents,\n );\n\n return [\n {\n name: packageName || directory.split('/').pop()!,\n description: packageDescription || undefined,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: targets.map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { listFiles } from '../../api-keys/index.js';\nimport { CodeScanningConfig } from '../types.js';\n\nconst GEM_PACKAGE_REGEX = /gem *('|\")(.+?)('|\")(, *('|\")(.+?)('|\")|)/;\nconst GEMFILE_PACKAGE_NAME_REGEX = /spec\\.name *= *('|\")(.+?)('|\")/;\nconst GEMFILE_PACKAGE_DESCRIPTION_REGEX = /spec\\.description *= *('|\")(.+?)('|\")/;\nconst GEMFILE_PACKAGE_SUMMARY_REGEX = /spec\\.summary *= *('|\")(.+?)('|\")/;\n\nexport const gemfile: CodeScanningConfig = {\n supportedFiles: ['Gemfile'],\n ignoreDirs: ['bin'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const filesInFolder = listFiles(directory);\n\n // parse gemspec file for name\n const gemspec = filesInFolder.find((file) => file === '.gemspec');\n const gemspecContents = gemspec ? readFileSync(gemspec, 'utf-8') : undefined;\n const gemfileName = gemspecContents\n ? (GEMFILE_PACKAGE_NAME_REGEX.exec(gemspecContents) || [])[2]\n : undefined;\n const gemfileDescription = gemspecContents\n ? (GEMFILE_PACKAGE_DESCRIPTION_REGEX.exec(gemspecContents) ||\n GEMFILE_PACKAGE_SUMMARY_REGEX.exec(gemspecContents) ||\n [])[1]\n : undefined;\n\n const targets = findAllWithRegex(\n {\n value: new RegExp(GEM_PACKAGE_REGEX, 'g'),\n matches: ['quote1', 'name', 'quote2', 'hasVersion', 'quote3', 'version', 'quote4'],\n },\n fileContents,\n );\n\n return [\n {\n name: gemfileName || directory.split('/').pop()!,\n description: gemfileDescription || undefined,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: targets.map((pkg) => ({\n name: pkg.name,\n version: pkg.version,\n })),\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport yaml from 'js-yaml';\n\nimport { CodeScanningConfig } from '../types.js';\n\n/**\n * Remove YAML comments from a string\n *\n * @param yamlString - YAML string\n * @returns String without comments\n */\nfunction removeYAMLComments(yamlString: string): string {\n return yamlString\n .split('\\n')\n .map((line) => {\n // Remove inline comments\n const commentIndex = line.indexOf('#');\n if (commentIndex > -1) {\n // Check if '#' is not inside a string\n if (\n !line.substring(0, commentIndex).includes('\"') &&\n !line.substring(0, commentIndex).includes(\"'\")\n ) {\n return line.substring(0, commentIndex).trim();\n }\n }\n return line;\n })\n .filter((line) => line.length > 0)\n .join('\\n');\n}\n\nexport const pubspec: CodeScanningConfig = {\n supportedFiles: ['pubspec.yml'],\n ignoreDirs: ['build'],\n scanFunction: (filePath) => {\n const directory = dirname(filePath);\n const fileContents = readFileSync(filePath, 'utf-8');\n const {\n name,\n description,\n dev_dependencies = {},\n dependencies = {},\n } = yaml.load(removeYAMLComments(fileContents)) as {\n /** Name */\n name?: string;\n /** Description */\n description?: string;\n /** Dev dependencies */\n dev_dependencies?: { [k in string]: number | Record<string, string> };\n /** Dependencies */\n dependencies?: { [k in string]: number | Record<string, string> };\n };\n return [\n {\n name: name || directory.split('/').pop()!,\n description,\n type: CodePackageType.RequirementsTxt,\n softwareDevelopmentKits: [\n ...Object.entries(dependencies).map(([name, version]) => ({\n name,\n version:\n typeof version === 'string'\n ? version\n : typeof version === 'number'\n ? version.toString()\n : version?.sdk,\n })),\n ...Object.entries(dev_dependencies).map(([name, version]) => ({\n name,\n version:\n typeof version === 'string'\n ? version\n : typeof version === 'number'\n ? version.toString()\n : version?.sdk,\n isDevDependency: true,\n })),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageSdk } from '../../../codecs.js';\nimport { CodeScanningConfig } from '../types.js';\n\nexport const composerJson: CodeScanningConfig = {\n supportedFiles: ['composer.json'],\n ignoreDirs: ['vendor', 'node_modules', 'cache', 'build', 'dist'],\n scanFunction: (filePath) => {\n const file = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n const asJson = JSON.parse(file);\n const {\n name,\n description,\n require: requireDependencies = {},\n 'require-dev': requiredDevDependencies = {},\n } = asJson;\n return [\n {\n // name of the package\n name: name || directory.split('/').pop()!,\n description,\n softwareDevelopmentKits: [\n ...Object.entries(requireDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n }),\n ),\n ...Object.entries(requiredDevDependencies).map(\n ([name, version]): CodePackageSdk => ({\n name,\n version: typeof version === 'string' ? version : undefined,\n isDevDependency: true,\n }),\n ),\n ],\n },\n ];\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { CodePackageType } from '@transcend-io/privacy-types';\nimport { decodeCodec } from '@transcend-io/type-utils';\nimport * as t from 'io-ts';\n\nimport { CodeScanningConfig } from '../types.js';\n\nconst SwiftPackage = t.type({\n pins: t.array(\n t.type({\n identity: t.string,\n kind: t.string,\n location: t.string,\n state: t.intersection([\n t.type({\n revision: t.string,\n }),\n t.partial({\n version: t.union([t.string, t.undefined, t.null]),\n }),\n ]),\n }),\n ),\n version: t.number,\n});\n\nconst SwiftPackageV1 = t.type({\n object: t.type({\n pins: t.array(\n t.type({\n package: t.string,\n repositoryURL: t.string,\n state: t.intersection([\n t.type({\n branch: t.union([t.string, t.undefined, t.null]),\n revision: t.string,\n }),\n t.partial({\n version: t.union([t.string, t.undefined, t.null]),\n }),\n ]),\n }),\n ),\n }),\n version: t.number,\n});\n\nexport const swift: CodeScanningConfig = {\n supportedFiles: ['Package.resolved'],\n ignoreDirs: [],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n\n // Attempt latest version first\n try {\n const parsed = decodeCodec(SwiftPackage, fileContents);\n const splitPath = dirname(filePath).split('/');\n const originalName = splitPath[splitPath.length - 1];\n let name = originalName;\n if (name === 'swiftpm') {\n name = splitPath[splitPath.length - 2];\n if (name === 'xcshareddata') {\n name = splitPath[splitPath.length - 3];\n } else if (!name) {\n name = originalName;\n }\n if (name === 'project.xcworkspace') {\n name = splitPath[splitPath.length - 4];\n }\n }\n return [\n {\n name,\n type: CodePackageType.Swift,\n softwareDevelopmentKits: parsed.pins.map((target) => ({\n name: target.identity,\n version: target.state.version || undefined,\n })),\n },\n ];\n } catch (e) {\n // Throw non codec errors\n if (!e?.message?.includes('Failed to decode codec')) {\n throw e;\n }\n\n // Attempt v1\n try {\n const parsed = decodeCodec(SwiftPackageV1, fileContents);\n return [\n {\n name: dirname(filePath).split('/').pop() || '', // TODO pull from Package.swift ->> name if possible\n type: CodePackageType.Swift,\n softwareDevelopmentKits: parsed.object.pins.map((target) => ({\n name: target.package,\n version: target.state.version || undefined,\n })),\n },\n ];\n } catch (e2) {\n if (!e2?.message?.includes('Failed to decode codec')) {\n throw e2;\n }\n throw e;\n }\n }\n },\n};\n","import { readFileSync } from 'node:fs';\nimport { dirname } from 'node:path';\n\nimport { findAllWithRegex } from '@transcend-io/type-utils';\n\nimport { CodeScanningConfig } from '../types.js';\n\n/**\n * Kotlin DSL (build.gradle.kts) dependency & plugin parsing\n */\n\nconst KTS_DEP_CONFIGS =\n // eslint-disable-next-line max-len\n '(implementation|api|kapt|ksp|debugImplementation|releaseImplementation|androidTestImplementation|testImplementation|compileOnly|runtimeOnly)';\n\n// e.g. implementation(\"com.google.firebase:firebase-analytics:18.0.0\")\nconst KTS_DEP_STRING_COORDS_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*[\"']([^\"':\\\\s]+):([^\"':\\\\s]+):?([^\"']*)[\"']\\\\s*\\\\)`,\n 'g',\n);\n// captures: [1]=config, [2]=group, [3]=artifact, [4]=version (may be '')\n\n// e.g. implementation(platform(\"com.google.firebase:firebase-bom:33.1.2\"))\nconst KTS_DEP_PLATFORM_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*platform\\\\(\\\\s*[\"']([^\"':\\\\s]+):([^\"':\\\\s]+):?([^\"']*)[\"']\\\\s*\\\\)\\\\s*\\\\)`,\n 'g',\n);\n\n// e.g. implementation(libs.androidx.appcompat) / implementation(libs[\"androidx-core-ktx\"])\nconst KTS_DEP_LIBS_ALIAS_REGEX = new RegExp(\n `${KTS_DEP_CONFIGS}\\\\s*\\\\(\\\\s*libs(?:\\\\.[\\\\w\\\\-\\\\.]+|\\\\[[\"'][^\"']+[\"']\\\\])\\\\s*\\\\)`,\n 'g',\n);\n\n// Plugins:\n// plugins { id(\"com.google.gms.google-services\") version \"4.4.2\" apply false }\n// plugins { id(\"org.jetbrains.kotlin.android\") }\n// apply(plugin = \"newrelic\")\n// plugins { alias(libs.plugins.kotlin.android) }\nconst KTS_PLUGIN_ID_REGEX = /id\\s*\\(\\s*[\"']([^\"']+)[\"']\\s*\\)(?:\\s*version\\s*[\"']([^\"']+)[\"'])?/g;\nconst KTS_PLUGIN_APPLY_REGEX = /apply\\s*\\(\\s*plugin\\s*=\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\nconst KTS_PLUGIN_ALIAS_REGEX =\n /plugins\\s*\\{[^}]*alias\\s*\\(\\s*libs(?:\\.plugins)?(?:\\.[\\w\\-.]+|\\[[\"'][^\"']+[\"']\\])\\s*\\)[^}]*\\}/g;\n\n// applicationId in Kotlin DSL:\n// applicationId = \"com.foo.bar\"\n// applicationId(\"com.foo.bar\")\nconst KTS_APPLICATION_ID_EQ_REGEX = /applicationId\\s*=\\s*[\"']([^\"']+)[\"']/g;\nconst KTS_APPLICATION_ID_CALL_REGEX = /applicationId\\s*\\(\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\n\n/**\n * Input dep entry (partial)\n */\ntype DepInput = {\n /** Name of the dependency */\n name: string;\n /** Version of the dependency */\n version?: string;\n};\n\n/**\n * Helper to normalize a parsed dep entry\n *\n * @param name - name\n * @param version - version\n * @returns normalized entry\n */\nfunction depEntry(name: string, version?: string): DepInput {\n const v = version && version.trim().length > 0 && version !== '_' ? version.trim() : undefined;\n return { name, version: v };\n}\n\nexport const kotlin: CodeScanningConfig = {\n supportedFiles: ['**/build.gradle.kts', '**/*.gradle.kts'],\n ignoreDirs: ['gradle-app.setting', 'gradle-wrapper.jar', 'gradle-wrapper.properties'],\n scanFunction: (filePath) => {\n const fileContents = readFileSync(filePath, 'utf-8');\n const directory = dirname(filePath);\n\n // ---------- applicationId ----------\n const appIds = [\n ...findAllWithRegex({ value: KTS_APPLICATION_ID_EQ_REGEX, matches: ['name'] }, fileContents),\n ...findAllWithRegex(\n { value: KTS_APPLICATION_ID_CALL_REGEX, matches: ['name'] },\n fileContents,\n ),\n ];\n if (appIds.length > 1) {\n throw new Error(`Expected only one applicationId per file: ${filePath}`);\n }\n const appName = appIds[0]?.name || directory.split('/').pop()!;\n\n // ---------- dependencies ----------\n const deps: Array<DepInput> = [];\n\n // \"group:artifact:version\"\n for (const m of fileContents.matchAll(KTS_DEP_STRING_COORDS_REGEX)) {\n const [, , group, artifact, version] = m;\n deps.push(depEntry(`${group}:${artifact}`, version));\n }\n\n // platform(\"group:artifact:version\")\n for (const m of fileContents.matchAll(KTS_DEP_PLATFORM_REGEX)) {\n const [, , group, artifact, version] = m;\n // Record as regular coord (you may prefer to tag as BoM separately)\n deps.push(depEntry(`${group}:${artifact}`, version));\n }\n\n // libs aliases (version catalogs) — keep alias as name, unknown version\n for (const m of fileContents.matchAll(KTS_DEP_LIBS_ALIAS_REGEX)) {\n // Grab the exact token as name (best-effort)\n const token = m[0]\n .replace(/^[^(]+\\(\\s*/, '')\n .replace(/\\)\\s*$/, '')\n .trim(); // e.g., libs.androidx.appcompat or libs[\"androidx-core-ktx\"]\n deps.push(depEntry(token));\n }\n\n // ---------- plugins ----------\n const plugins: Array<DepInput> = [];\n\n for (const m of fileContents.matchAll(KTS_PLUGIN_ID_REGEX)) {\n const [, pid, pver] = m;\n plugins.push(depEntry(pid, pver));\n }\n\n for (const m of fileContents.matchAll(KTS_PLUGIN_APPLY_REGEX)) {\n const [, pid] = m;\n plugins.push(depEntry(pid));\n }\n\n // alias(libs.plugins...) — keep alias token (no version)\n if (KTS_PLUGIN_ALIAS_REGEX.test(fileContents)) {\n // Collect all alias lines to preserve identifiers; light parse:\n const aliasMatches = fileContents.matchAll(\n /alias\\s*\\(\\s*(libs(?:\\.plugins)?(?:\\.[\\w\\-.]+|\\[[\"'][^\"']+[\"']\\]))\\s*\\)/g,\n );\n for (const m of aliasMatches) {\n plugins.push(depEntry(m[1]));\n }\n }\n\n // ---------- compose final list ----------\n // Merge deps + plugins as \"softwareDevelopmentKits\"\n const softwareDevelopmentKits = [...deps, ...plugins]\n // de-dup by name+version\n .reduce(\n (acc, cur) => {\n const key = `${cur.name}@@${cur.version || ''}`;\n if (!acc.map.has(key)) {\n acc.map.set(key, cur);\n acc.list.push(cur);\n }\n return acc;\n },\n {\n map: new Map<string, DepInput>(),\n list: [] as Array<DepInput>,\n },\n ).list;\n\n return [\n {\n name: appName,\n softwareDevelopmentKits,\n },\n ];\n },\n};\n","import { CodePackageType } from '@transcend-io/privacy-types';\n\nimport {\n cocoaPods,\n gradle,\n javascriptPackageJson,\n gemfile,\n composerJson,\n pubspec,\n swift,\n kotlin,\n pythonRequirementsTxt,\n} from './integrations/index.js';\nimport { CodeScanningConfig } from './types.js';\n\n/**\n * @deprecated TODO: https://transcend.height.app/T-32325 - use code scanning instead\n */\nexport const SILO_DISCOVERY_CONFIGS: {\n [k in string]: CodeScanningConfig;\n} = {\n cocoaPods,\n gradle,\n javascriptPackageJson,\n pythonRequirementsTxt,\n gemfile,\n pubspec,\n swift,\n};\n\nexport const CODE_SCANNING_CONFIGS: {\n [k in CodePackageType]: CodeScanningConfig;\n} = {\n [CodePackageType.CocoaPods]: cocoaPods,\n [CodePackageType.Gradle]: gradle,\n [CodePackageType.PackageJson]: javascriptPackageJson,\n [CodePackageType.RequirementsTxt]: pythonRequirementsTxt,\n [CodePackageType.Gemfile]: gemfile,\n [CodePackageType.Pubspec]: pubspec,\n [CodePackageType.ComposerJson]: composerJson,\n [CodePackageType.Swift]: swift,\n [CodePackageType.Kotlin]: kotlin,\n};\n"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import e from"node:fs";import t from"node:os";import n from"node:path";function r(r){return{process:r,os:t,fs:e,path:n}}export{r as t};
|
|
2
|
-
//# sourceMappingURL=context-
|
|
2
|
+
//# sourceMappingURL=context-bkKpii_t.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-
|
|
1
|
+
{"version":3,"file":"context-bkKpii_t.mjs","names":[],"sources":["../src/context.ts"],"sourcesContent":["import fs from 'node:fs';\nimport os from 'node:os';\nimport path from 'node:path';\n\nimport type { StricliAutoCompleteContext } from '@stricli/auto-complete';\nimport type { CommandContext } from '@stricli/core';\n\nexport interface LocalContext extends CommandContext, StricliAutoCompleteContext {\n /** The Node.js process object */\n readonly process: NodeJS.Process;\n // ...\n}\n\n/**\n * Builds the context for the CLI.\n *\n * @param process - The Node.js process object.\n * @returns The context for the CLI.\n */\nexport function buildContext(process: NodeJS.Process): LocalContext {\n return {\n process,\n os,\n fs,\n path,\n };\n}\n"],"mappings":"uEAmBA,SAAgB,EAAa,EAAuC,CAClE,MAAO,CACL,UACA,KACA,KACA,OACD"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import{i as e}from"./constants-XOsAW1__.mjs";import{createReadStream as t,readFileSync as n,statSync as r}from"node:fs";import{basename as i}from"node:path";import a from"colors";import*as o from"node:readline";function s(e,t,r){process.stdout.write(`\x1B[2J\x1B[H`);let i=e=>/\b(ERROR|uncaughtException|unhandledRejection)\b/i.test(e),a=e=>/\b(WARN|WARNING)\b/i.test(e),o=[];for(let[,s]of e){if(!s)continue;let e=[];for(let n of t)n===`out`&&s.outPath&&e.push({path:s.outPath,src:`out`}),n===`err`&&s.errPath&&e.push({path:s.errPath,src:`err`}),n===`structured`&&s.structuredPath&&e.push({path:s.structuredPath,src:`structured`}),s.warnPath&&n===`warn`&&e.push({path:s.warnPath,src:`warn`}),s.infoPath&&n===`info`&&e.push({path:s.infoPath,src:`info`});for(let{path:t,src:s}of e){let e=``;try{e=n(t,`utf8`)}catch{continue}for(let t of e.split(`
|
|
2
|
+
`)){if(!t)continue;let e=t.replace(/\x1B\[[0-9;]*m/g,``);if(r===`all`){o.push(t);continue}if(r===`error`){i(e)&&o.push(t);continue}if(a(e)||s===`err`&&!i(e)){o.push(t);continue}}}}o.sort((e,t)=>{let n=e.match(/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/)?.[0]??``,r=t.match(/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/)?.[0]??``;return n.localeCompare(r)}),process.stdout.write(`${o.join(`
|
|
3
|
+
`)}\n`),process.stdout.write(`
|
|
4
|
+
Press Esc/Ctrl+] to return to dashboard.
|
|
5
|
+
`)}function c(e,t,n){if(t.ctrl&&t.name===`c`)return{type:`CTRL_C`};if(n===`dashboard`)return t.name&&/^[0-9]$/.test(t.name)?{type:`ATTACH`,id:Number(t.name)}:t.name===`tab`&&!t.shift?{type:`CYCLE`,delta:1}:t.name===`tab`&&t.shift?{type:`CYCLE`,delta:-1}:t.name===`q`?{type:`QUIT`}:null;if(t.name===`escape`||t.ctrl&&t.name===`]`)return{type:`DETACH`};if(t.ctrl&&t.name===`d`)return{type:`CTRL_D`};let r=t.sequence??e??``;return r?{type:`FORWARD`,sequence:r}:null}async function l(e,n,i){await new Promise(a=>{try{let o=r(e),s=t(e,{start:Math.max(0,o.size-n),encoding:`utf8`});s.on(`data`,e=>i(e)),s.on(`end`,()=>a()),s.on(`error`,()=>a())}catch{a()}})}function u(e){return[...e.keys()].sort((e,t)=>e-t)}function d(e,t,n){if(!e.length)return null;let r=t??e[0],i=e.indexOf(r);return i===-1&&(i=0),i=(i+n+e.length)%e.length,e[i]}function f(t){let{workers:n,onAttach:r,onDetach:i,onCtrlC:a,getLogPaths:s,replayBytes:f=200*1024,replayWhich:p=[`out`,`err`],onEnterAttachScreen:m,ports:h}=t,g=h?.stdin??process.stdin,_=h?.stdout??process.stdout,v=h?.stderr??process.stderr,y=(...t)=>{if(e)try{(h?.stderr??process.stderr).write(`[keys] ${t.map(String).join(` `)}\n`)}catch{}};if(!g.isTTY)return()=>{};o.emitKeypressEvents(g),g.setRawMode?.(!0);let b=`dashboard`,x=null,S=null,C=null;async function w(e){if(!s)return;let t=s(e);if(!t)return;let n=[];for(let e of p)e===`out`&&n.push(t.outPath),e===`err`&&n.push(t.errPath),e===`structured`&&n.push(t.structuredPath);if(n.length){_.write(`
|
|
6
|
+
------------ replay ------------
|
|
7
|
+
`);for(let e of n)_.write(`\n--- ${e} (last ~${Math.floor(f/1024)}KB) ---\n`),await l(e,f,e=>_.write(e));_.write(`
|
|
8
|
+
--------------------------------
|
|
9
|
+
|
|
10
|
+
`)}}let T=async e=>{y(`attach()`,`id=${e}`);let t=n.get(e);t&&(b===`attached`&&E(),b=`attached`,x=e,m?.(e),r?.(e),await w(e),S=e=>_.write(e),C=e=>v.write(e),t.stdout?.on(`data`,S),t.stderr?.on(`data`,C),t.once(`exit`,()=>{x===e&&E()}))},E=()=>{if(y(`detach()`,`id=${x}`),x==null)return;let e=x,t=n.get(e);t&&(S&&t.stdout?.off(`data`,S),C&&t.stderr?.off(`data`,C)),S=null,C=null,x=null,b=`dashboard`,i?.()},D=(e,t)=>{y(`keypress`,JSON.stringify({str:e,name:t.name,seq:t.sequence,ctrl:t.ctrl,meta:t.meta,shift:t.shift,mode:b}));let r=c(e,t,b);if(y(`mapped`,JSON.stringify(r)),r)switch(r.type){case`CTRL_C`:if(y(`CTRL_C`),b===`attached`&&x!=null){let e=n.get(x);try{e?.kill(`SIGINT`)}catch{}E();return}a?.();return;case`ATTACH`:if(y(`ATTACH`,`id=${r.id}`,`has=${n.has(r.id)}`),b!==`dashboard`)return;n.has(r.id)&&T(r.id);return;case`CYCLE`:{if(y(`CYCLE`,`delta=${r.delta}`),b!==`dashboard`)return;let e=d(u(n),x,r.delta);e!=null&&T(e);return}case`QUIT`:if(b!==`dashboard`)return;a?.();return;case`DETACH`:y(`DETACH`),b===`attached`&&E();return;case`CTRL_D`:if(b===`attached`&&x!=null){let e=n.get(x);try{e?.stdin?.end()}catch{}}return;case`FORWARD`:if(b===`attached`&&x!=null){let e=n.get(x);try{e?.stdin?.write(r.sequence)}catch{}}}},O=e=>{if(b===`attached`&&x!=null){let t=n.get(x);try{t?.stdin?.write(e)}catch{}}};return g.on(`keypress`,D),g.on(`data`,O),()=>{g.off(`keypress`,D),g.off(`data`,O),g.setRawMode?.(!1),_.write(`\x1B[?25h`)}}let p=``;const m=(e,t)=>{let n=Math.min(e-1,9),r=e<=1?`0`:`0-${n}`,i=e>10?` (Tab/Shift+Tab for ≥10)`:``;return t?a.dim(`Run complete — digits to view logs • Tab/Shift+Tab cycle • Esc/Ctrl+] detach • q to quit`):a.dim(`Hotkeys: [${r}] attach${i} • e=errors • w=warnings • i=info • l=logs • Tab/Shift+Tab • Esc/Ctrl+] detach • Ctrl+C exit`)};function h(e,t,n=!1){let r=[...t.renderHeader(e),``,...t.renderWorkers(e),...n?[]:[``,m(e.poolSize,e.final)],...t.renderExtras?[``].concat(t.renderExtras(e)):[]].join(`
|
|
11
|
+
`);!e.final&&r===p||(p=r,e.final?process.stdout.write(`\x1B[?25h`):(process.stdout.write(`\x1B[?25l`),o.cursorTo(process.stdout,0,0),o.clearScreenDown(process.stdout)),process.stdout.write(`${r}\n`))}function g(e){return typeof e==`number`?e.toLocaleString():`0`}function _(e,t=40){let n=Math.max(0,Math.min(100,Math.floor(e))),r=Math.floor(n/100*t);return`█`.repeat(r)+`░`.repeat(t-r)}function v(e){let t=[...e.workerState.values()].filter(e=>e.busy).length,n=e.filesCompleted+e.filesFailed;return{done:n,inProgress:t,pct:e.filesTotal===0?100:Math.floor(n/Math.max(1,e.filesTotal)*100)}}function y(e,t=[]){let{title:n,poolSize:r,cpuCount:i,filesTotal:o,filesCompleted:s,filesFailed:c,throughput:l}=e,{inProgress:u,pct:d}=v(e),f=[`${a.bold(n)} — ${r} workers ${a.dim(`(CPU avail: ${i})`)}`,`${a.dim(`Files`)} ${g(o)} ${a.dim(`Completed`)} ${g(s)} ${a.dim(`Failed`)} ${c?a.red(g(c)):g(c)} ${a.dim(`In-flight`)} ${g(u)}`,`[${_(d)}] ${d}%`];if(l){let t=l.jobsR10s>0||l.jobsR60s>0,n=Math.round((t?l.jobsR10s:l.r10s)*3600).toLocaleString(),r=Math.round((t?l.jobsR60s:l.r60s)*3600).toLocaleString(),i=t?`rec`:`files`,o=e.throughput?.successSoFar==null?``:` Newly uploaded: ${g(e.throughput.successSoFar)}`;f.push(a.cyan(`Throughput: ${n} ${i}/hr (1h: ${r} ${i}/hr)${o}`))}return t.length?f.concat(t):f}function b(e,t=e=>e?i(e):`-`){return[...e.workerState.entries()].map(([e,n])=>{let r=n.lastLevel===`error`?a.red(`ERROR `):n.lastLevel===`warn`?a.yellow(`WARN `):n.busy?a.green(`WORKING`):a.dim(`IDLE `),i=t(n.file),o=n.startedAt?`${Math.floor((Date.now()-n.startedAt)/1e3)}s`:`-`,s=n.progress?.processed??0,c=n.progress?.total??0,l=c>0?Math.floor(s/c*100):0;return` [w${e}] ${r} | ${i} | ${o} | [${c>0?_(l,18):` `.repeat(18)}] ${c>0?`${s.toLocaleString()}/${c.toLocaleString()} (${l}%)`:a.dim(`—`)}`})}function x(e){let{logsBySlot:t,repaint:n,setPaused:r,exportMgr:i,exportStatus:a,custom:o}=e,c=e=>{process.stdout.write(`${e}\n`)},l=(e,t)=>{let r=Date.now(),i=a?.[e]??{path:t};a&&(a[e]={path:t||i.path,savedAt:r,exported:!0},n())},u=!1,d=(e,i)=>{u||(u=!0,r(!0),process.stdout.write(`\x1B[2J\x1B[H`),process.stdout.write(`Combined logs viewer (press Esc or Ctrl+] to return)
|
|
12
|
+
|
|
13
|
+
`),(async()=>{try{await s(t,e,i)}catch{u=!1,r(!1),n()}})())},f=(e,n)=>{if(i)try{let r=i.exportCombinedLogs(t,e);c(`\nWrote combined ${n} logs to: ${r}`),l(e,r)}catch{c(`\nFailed to write combined ${n} logs`)}};return e=>{let t=e.toString(`utf8`);if(t===`e`){d([`err`],`error`);return}if(t===`w`){d([`warn`,`err`],`warn`);return}if(t===`i`){d([`info`],`all`);return}if(t===`l`){d([`out`,`err`,`structured`],`all`);return}if(t===`E`){f(`error`,`error`);return}if(t===`W`){f(`warn`,`warn`);return}if(t===`I`){f(`info`,`info`);return}if(t===`A`){f(`all`,`ALL`);return}let i=o?.[t];if(i){i({noteExport:l,say:c});return}(t===`\x1B`||t===``)&&(u=!1,r(!1),n())}}export{f as a,h as i,y as n,b as r,x as t};
|
|
14
|
+
//# sourceMappingURL=createExtraKeyHandler-Jp5XpTJi.mjs.map
|