@tantainnovative/ndpr-toolkit 3.4.0 → 3.5.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/CHANGELOG.md +25 -0
- package/README.md +80 -38
- package/dist/adapters.d.mts +34 -25
- package/dist/adapters.d.ts +34 -25
- package/dist/breach.d.mts +803 -44
- package/dist/breach.d.ts +803 -44
- package/dist/breach.js +2 -1
- package/dist/breach.mjs +2 -1
- package/dist/{chunk-2WH4DLV5.js → chunk-3EGQWLJ6.js} +3 -3
- package/dist/chunk-B4Z5MBUC.mjs +2 -0
- package/dist/{chunk-LSCMXAPY.mjs → chunk-CKGJK4D7.mjs} +3 -3
- package/dist/{chunk-XSEZDQLB.js → chunk-CKJAECGV.js} +2 -2
- package/dist/{chunk-AHSMDPG5.js → chunk-CPK5D5FY.js} +2 -2
- package/dist/{chunk-DCJK5OZT.mjs → chunk-CWHBCQGT.mjs} +2 -2
- package/dist/{chunk-KSERBMXW.mjs → chunk-F5TXUA4O.mjs} +3 -3
- package/dist/{chunk-BN77GP4W.mjs → chunk-GN5C32JB.mjs} +2 -2
- package/dist/{chunk-ZLSWOFAY.mjs → chunk-GRLIPT5V.mjs} +2 -2
- package/dist/{chunk-DUY6F3GT.mjs → chunk-H3EYBSVP.mjs} +3 -3
- package/dist/{chunk-MG73MOZC.mjs → chunk-I557S566.mjs} +2 -2
- package/dist/{chunk-QVULSG6J.mjs → chunk-ID2NYIVE.mjs} +3 -3
- package/dist/chunk-J5WCPZLW.js +2 -0
- package/dist/{chunk-4R42ZNO7.mjs → chunk-JFFOPHU3.mjs} +57 -57
- package/dist/{chunk-P2YV6DR3.js → chunk-LIM64IV2.js} +3 -3
- package/dist/chunk-LU7PKE7Y.mjs +2 -0
- package/dist/{chunk-HQSU7LGM.js → chunk-LWXZMKC2.js} +4 -4
- package/dist/{chunk-XMBSJJ5U.js → chunk-ORFC66EA.js} +3 -3
- package/dist/{chunk-VTITKWGX.mjs → chunk-QSVVAZVT.mjs} +2 -2
- package/dist/chunk-SCWNM4PC.mjs +2 -0
- package/dist/{chunk-EHAZIKDX.js → chunk-SKKOMFXH.js} +2 -2
- package/dist/{chunk-WH6ZMUOS.mjs → chunk-TUNQUVHU.mjs} +2 -2
- package/dist/chunk-TV4U6AIS.js +2 -0
- package/dist/{chunk-ZYLDLGFL.js → chunk-VIQUXWJC.js} +2 -2
- package/dist/{chunk-SUEGUY35.js → chunk-XIM7KMD6.js} +2 -2
- package/dist/{chunk-P6QAFBCV.js → chunk-XNSZ7KUH.js} +2 -2
- package/dist/{chunk-RNTNHVKZ.js → chunk-YPKUHSK4.js} +2 -2
- package/dist/{chunk-UFPSUO52.js → chunk-Z73T6MWY.js} +57 -57
- package/dist/consent.d.mts +648 -84
- package/dist/consent.d.ts +648 -84
- package/dist/consent.js +2 -1
- package/dist/consent.mjs +2 -1
- package/dist/core.d.mts +2049 -23
- package/dist/core.d.ts +2049 -23
- package/dist/core.js +1 -1
- package/dist/core.mjs +1 -1
- package/dist/cross-border.d.mts +470 -99
- package/dist/cross-border.d.ts +470 -99
- package/dist/cross-border.js +1 -0
- package/dist/cross-border.mjs +1 -0
- package/dist/dpia.d.mts +591 -37
- package/dist/dpia.d.ts +591 -37
- package/dist/dpia.js +1 -0
- package/dist/dpia.mjs +1 -0
- package/dist/dsr.d.mts +654 -37
- package/dist/dsr.d.ts +654 -37
- package/dist/dsr.js +2 -1
- package/dist/dsr.mjs +2 -1
- package/dist/hooks.d.mts +2174 -30
- package/dist/hooks.d.ts +2174 -30
- package/dist/hooks.js +2 -1
- package/dist/hooks.mjs +2 -1
- package/dist/index.d.mts +4428 -43
- package/dist/index.d.ts +4428 -43
- package/dist/index.js +2 -1
- package/dist/index.mjs +2 -1
- package/dist/lawful-basis.d.mts +368 -32
- package/dist/lawful-basis.d.ts +368 -32
- package/dist/lawful-basis.js +1 -0
- package/dist/lawful-basis.mjs +1 -0
- package/dist/policy.d.mts +1178 -83
- package/dist/policy.d.ts +1178 -83
- package/dist/policy.js +2 -1
- package/dist/policy.mjs +2 -1
- package/dist/presets.d.mts +1020 -114
- package/dist/presets.d.ts +1020 -114
- package/dist/presets.js +2 -1
- package/dist/presets.mjs +2 -1
- package/dist/ropa.d.mts +396 -31
- package/dist/ropa.d.ts +396 -31
- package/dist/ropa.js +2 -1
- package/dist/ropa.mjs +2 -1
- package/dist/server.d.mts +2133 -24
- package/dist/server.d.ts +2133 -24
- package/dist/server.js +1 -1
- package/dist/server.mjs +1 -1
- package/dist/unstyled.d.mts +523 -55
- package/dist/unstyled.d.ts +523 -55
- package/dist/unstyled.js +2 -1
- package/dist/unstyled.mjs +2 -1
- package/package.json +3 -3
- package/dist/BreachReportForm-DpRrBoxU.d.ts +0 -158
- package/dist/BreachReportForm-yJ2Zl6gz.d.mts +0 -158
- package/dist/ConsentBanner-F5ayys5K.d.mts +0 -156
- package/dist/ConsentBanner-VqIPophc.d.ts +0 -156
- package/dist/ConsentManager-C7I3PDe8.d.mts +0 -105
- package/dist/ConsentManager-CQ2IZtUU.d.ts +0 -105
- package/dist/CrossBorderTransferManager-D5Lc0e46.d.ts +0 -90
- package/dist/CrossBorderTransferManager-DkZhv9vD.d.mts +0 -90
- package/dist/DPIAQuestionnaire-VXBoWFMC.d.ts +0 -123
- package/dist/DPIAQuestionnaire-jkt1Veb6.d.mts +0 -123
- package/dist/DSRRequestForm-D8rPTNmU.d.ts +0 -146
- package/dist/DSRRequestForm-DRouEr9j.d.mts +0 -146
- package/dist/DSRTracker-Bl__d4df.d.ts +0 -163
- package/dist/DSRTracker-CSVDfgQQ.d.mts +0 -163
- package/dist/LawfulBasisTracker-CBqOxX1D.d.mts +0 -85
- package/dist/LawfulBasisTracker-Cg30NbDA.d.ts +0 -85
- package/dist/NDPRDashboard-CLJpEg0X.d.mts +0 -44
- package/dist/NDPRDashboard-DDWNd2Ah.d.ts +0 -44
- package/dist/NDPRProvider-DYFb8xEl.d.ts +0 -68
- package/dist/NDPRProvider-U3QNu6MA.d.mts +0 -68
- package/dist/PolicyExporter-Bgi6nz82.d.mts +0 -291
- package/dist/PolicyExporter-BnvuFncj.d.ts +0 -291
- package/dist/ROPAManager-BS4eB8Hw.d.mts +0 -79
- package/dist/ROPAManager-qxTrXLkD.d.ts +0 -79
- package/dist/RegulatoryReportGenerator-BUYgzTTT.d.ts +0 -282
- package/dist/RegulatoryReportGenerator-DwcHcEFp.d.mts +0 -282
- package/dist/StepIndicator-CgrlokSV.d.ts +0 -171
- package/dist/StepIndicator-W8S_QjgO.d.mts +0 -171
- package/dist/breach-B_-6lDqS.d.mts +0 -17
- package/dist/breach-CzXqSsaY.d.ts +0 -17
- package/dist/breach-Eu9byel8.d.mts +0 -185
- package/dist/breach-Eu9byel8.d.ts +0 -185
- package/dist/chunk-5X32J5IA.mjs +0 -2
- package/dist/chunk-7D2OIPHH.mjs +0 -2
- package/dist/chunk-JKKRPS4P.js +0 -2
- package/dist/chunk-NCOZB2WU.mjs +0 -2
- package/dist/chunk-RGNP45VR.js +0 -2
- package/dist/compliance-score-racQe_E_.d.mts +0 -115
- package/dist/compliance-score-racQe_E_.d.ts +0 -115
- package/dist/consent-CmVzqZUk.d.mts +0 -99
- package/dist/consent-CmVzqZUk.d.ts +0 -99
- package/dist/consent-audit-BdByjYlM.d.mts +0 -65
- package/dist/consent-audit-DhbfMR0n.d.ts +0 -65
- package/dist/cross-border-BBi9rZyO.d.mts +0 -54
- package/dist/cross-border-Dy-U9Hu6.d.ts +0 -54
- package/dist/cross-border-UyT00llA.d.mts +0 -141
- package/dist/cross-border-UyT00llA.d.ts +0 -141
- package/dist/docx-BxKascXN.d.ts +0 -64
- package/dist/docx-CV7Vsry_.d.mts +0 -64
- package/dist/dpia-D82hUrJe.d.ts +0 -15
- package/dist/dpia-DQDFw2_l.d.mts +0 -15
- package/dist/dpia-c9GiiOq0.d.mts +0 -137
- package/dist/dpia-c9GiiOq0.d.ts +0 -137
- package/dist/dsr-CIx5sd7e.d.ts +0 -14
- package/dist/dsr-XZ_HqTlA.d.mts +0 -14
- package/dist/dsr-yKbqX531.d.mts +0 -128
- package/dist/dsr-yKbqX531.d.ts +0 -128
- package/dist/lawful-basis-BEyI0kGg.d.ts +0 -57
- package/dist/lawful-basis-C2eGaoHM.d.mts +0 -57
- package/dist/lawful-basis-Cv1VmDLn.d.mts +0 -112
- package/dist/lawful-basis-Cv1VmDLn.d.ts +0 -112
- package/dist/locale-CxJx2tzn.d.mts +0 -25
- package/dist/locale-DSkrtf-c.d.ts +0 -25
- package/dist/policy-engine-CCUCud2T.d.ts +0 -154
- package/dist/policy-engine-fYSqEqSW.d.mts +0 -154
- package/dist/policy-sections-BYx6fEFk.d.ts +0 -56
- package/dist/policy-sections-Dm97Nq8m.d.mts +0 -56
- package/dist/policy-templates-DhLwq4R-.d.ts +0 -43
- package/dist/policy-templates-DwYl2329.d.mts +0 -43
- package/dist/privacy-Ca6te9Ir.d.mts +0 -138
- package/dist/privacy-Ca6te9Ir.d.ts +0 -138
- package/dist/ropa-BDTM06tr.d.ts +0 -152
- package/dist/ropa-CFHuT7jE.d.mts +0 -152
- package/dist/ropa-CyynscU6.d.ts +0 -51
- package/dist/ropa-NIgxd8uP.d.mts +0 -51
- package/dist/sanitize-CxxwKxAx.d.mts +0 -94
- package/dist/sanitize-CxxwKxAx.d.ts +0 -94
- package/dist/styling-BMDGQDgS.d.mts +0 -64
- package/dist/styling-BaoQtV06.d.ts +0 -64
- package/dist/types-DK2CoKOC.d.mts +0 -10
- package/dist/types-DK2CoKOC.d.ts +0 -10
- package/dist/useAdaptivePolicyWizard-BnjW4OR4.d.mts +0 -52
- package/dist/useAdaptivePolicyWizard-sb3m4-Zk.d.ts +0 -52
- package/dist/useBreach-CPr86Yan.d.mts +0 -115
- package/dist/useBreach-DkVXvtJK.d.ts +0 -115
- package/dist/useConsent-DCNkIJHR.d.mts +0 -75
- package/dist/useConsent-dOcELSfX.d.ts +0 -75
- package/dist/useCrossBorderTransfer-DixjLjN1.d.mts +0 -78
- package/dist/useCrossBorderTransfer-DvSq06lv.d.ts +0 -78
- package/dist/useDPIA-B6180UQn.d.mts +0 -109
- package/dist/useDPIA-CTqbNbww.d.ts +0 -109
- package/dist/useDSR-WvHk8_iu.d.mts +0 -85
- package/dist/useDSR-wH4H6hSM.d.ts +0 -85
- package/dist/useDefaultPrivacyPolicy-Cs2WQSYQ.d.mts +0 -162
- package/dist/useDefaultPrivacyPolicy-DkOqMg2e.d.ts +0 -162
- package/dist/useLawfulBasis-CKJ-kw84.d.mts +0 -79
- package/dist/useLawfulBasis-DFTmu1ca.d.ts +0 -79
- package/dist/useROPA-BSSU1rfx.d.ts +0 -76
- package/dist/useROPA-C2hjaBTz.d.mts +0 -76
package/dist/cross-border.d.ts
CHANGED
|
@@ -1,99 +1,470 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
export
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
*
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
*
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
*
|
|
48
|
-
*
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
*
|
|
53
|
-
*
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
*
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
declare
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
1
|
+
import * as React_2 from 'react';
|
|
2
|
+
import React__default from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Adequacy status of a destination country
|
|
6
|
+
*/
|
|
7
|
+
export declare type AdequacyStatus = 'adequate' | 'inadequate' | 'pending_review' | 'unknown';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Performs a basic risk assessment of a cross-border transfer based on adequacy status,
|
|
11
|
+
* transfer mechanism, and data sensitivity.
|
|
12
|
+
*
|
|
13
|
+
* @param transfer The cross-border transfer to assess
|
|
14
|
+
* @returns Risk assessment result with score, factors, and recommendations
|
|
15
|
+
*/
|
|
16
|
+
export declare function assessTransferRisk(transfer: CrossBorderTransfer): TransferRiskResult;
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Database of country adequacy determinations for cross-border data transfers.
|
|
20
|
+
*
|
|
21
|
+
* This map is keyed by ISO 3166-1 alpha-2 country code (uppercase).
|
|
22
|
+
* Statuses reflect general assessments based on each country's data protection
|
|
23
|
+
* framework and are provided for guidance purposes. Organizations should verify
|
|
24
|
+
* current NDPC guidance before relying on these determinations.
|
|
25
|
+
*/
|
|
26
|
+
export declare const COUNTRY_ADEQUACY_MAP: Record<string, CountryAdequacy>;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Represents a country's adequacy determination for cross-border data transfers.
|
|
30
|
+
*/
|
|
31
|
+
export declare interface CountryAdequacy {
|
|
32
|
+
/** Full country name */
|
|
33
|
+
country: string;
|
|
34
|
+
/** ISO 3166-1 alpha-2 country code */
|
|
35
|
+
isoCode: string;
|
|
36
|
+
/** Adequacy status for data protection purposes */
|
|
37
|
+
adequacyStatus: CountryAdequacyStatus;
|
|
38
|
+
/** Authority or framework that recognized the adequacy (e.g. 'NDPC', 'EU') */
|
|
39
|
+
recognizedBy: string;
|
|
40
|
+
/** Additional notes about the adequacy determination */
|
|
41
|
+
notes: string;
|
|
42
|
+
/** Date the adequacy determination was last reviewed */
|
|
43
|
+
lastUpdated: string;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Country adequacy determinations for cross-border data transfers
|
|
48
|
+
* under the Nigeria Data Protection Act (NDPA).
|
|
49
|
+
*
|
|
50
|
+
* This module provides a reference database of adequacy statuses for countries
|
|
51
|
+
* that Nigerian businesses commonly transfer personal data to, along with
|
|
52
|
+
* helper functions for querying adequacy and determining whether NDPC approval
|
|
53
|
+
* is required for a given destination.
|
|
54
|
+
*/
|
|
55
|
+
/**
|
|
56
|
+
* Adequacy status of a country for cross-border data transfers.
|
|
57
|
+
*/
|
|
58
|
+
export declare type CountryAdequacyStatus = 'adequate' | 'partially_adequate' | 'not_adequate' | 'pending';
|
|
59
|
+
|
|
60
|
+
export declare const CrossBorder: {
|
|
61
|
+
Provider: React_2.FC<CrossBorderProviderProps>;
|
|
62
|
+
Manager: React_2.FC<CrossBorderTransferManagerProps>;
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
declare type CrossBorderContextValue = UseCrossBorderTransferReturn;
|
|
66
|
+
|
|
67
|
+
export declare const CrossBorderProvider: React__default.FC<CrossBorderProviderProps>;
|
|
68
|
+
|
|
69
|
+
export declare interface CrossBorderProviderProps {
|
|
70
|
+
adapter?: StorageAdapter<CrossBorderTransfer[]>;
|
|
71
|
+
storageKey?: string;
|
|
72
|
+
useLocalStorage?: boolean;
|
|
73
|
+
initialTransfers?: CrossBorderTransfer[];
|
|
74
|
+
onAdd?: (transfer: CrossBorderTransfer) => void;
|
|
75
|
+
onUpdate?: (transfer: CrossBorderTransfer) => void;
|
|
76
|
+
onRemove?: (id: string) => void;
|
|
77
|
+
children: React__default.ReactNode;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Summary of cross-border transfer compliance
|
|
82
|
+
*/
|
|
83
|
+
export declare interface CrossBorderSummary {
|
|
84
|
+
/** Total number of active transfers */
|
|
85
|
+
totalActiveTransfers: number;
|
|
86
|
+
/** Breakdown by transfer mechanism */
|
|
87
|
+
byMechanism: Record<TransferMechanism, number>;
|
|
88
|
+
/** Breakdown by adequacy status */
|
|
89
|
+
byAdequacy: Record<AdequacyStatus, number>;
|
|
90
|
+
/** Transfers pending NDPC approval */
|
|
91
|
+
pendingApproval: CrossBorderTransfer[];
|
|
92
|
+
/** Transfers due for review */
|
|
93
|
+
dueForReview: CrossBorderTransfer[];
|
|
94
|
+
/** Transfers missing TIA */
|
|
95
|
+
missingTIA: CrossBorderTransfer[];
|
|
96
|
+
/** High-risk transfers */
|
|
97
|
+
highRiskTransfers: CrossBorderTransfer[];
|
|
98
|
+
/** Last updated timestamp */
|
|
99
|
+
lastUpdated: number;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Represents a cross-border data transfer record
|
|
104
|
+
*/
|
|
105
|
+
export declare interface CrossBorderTransfer {
|
|
106
|
+
/** Unique identifier */
|
|
107
|
+
id: string;
|
|
108
|
+
/** Destination country or territory */
|
|
109
|
+
destinationCountry: string;
|
|
110
|
+
/** ISO country code */
|
|
111
|
+
destinationCountryCode?: string;
|
|
112
|
+
/** Adequacy status of the destination */
|
|
113
|
+
adequacyStatus: AdequacyStatus;
|
|
114
|
+
/** The transfer mechanism being relied upon */
|
|
115
|
+
transferMechanism: TransferMechanism;
|
|
116
|
+
/** Categories of personal data being transferred */
|
|
117
|
+
dataCategories: string[];
|
|
118
|
+
/** Whether sensitive personal data is included */
|
|
119
|
+
includesSensitiveData: boolean;
|
|
120
|
+
/** Estimated number of data subjects whose data is transferred */
|
|
121
|
+
estimatedDataSubjects?: number;
|
|
122
|
+
/** Name of the recipient organization */
|
|
123
|
+
recipientOrganization: string;
|
|
124
|
+
/** Contact details of the recipient */
|
|
125
|
+
recipientContact: {
|
|
126
|
+
name: string;
|
|
127
|
+
email: string;
|
|
128
|
+
phone?: string;
|
|
129
|
+
address?: string;
|
|
130
|
+
};
|
|
131
|
+
/** Purpose of the data transfer */
|
|
132
|
+
purpose: string;
|
|
133
|
+
/** Safeguards in place to protect the data */
|
|
134
|
+
safeguards: string[];
|
|
135
|
+
/** Risk assessment summary */
|
|
136
|
+
riskAssessment: string;
|
|
137
|
+
/** Risk level of the transfer */
|
|
138
|
+
riskLevel: 'low' | 'medium' | 'high';
|
|
139
|
+
/** NDPC approval details (required for some transfer mechanisms) */
|
|
140
|
+
ndpcApproval?: {
|
|
141
|
+
required: boolean;
|
|
142
|
+
applied: boolean;
|
|
143
|
+
approved?: boolean;
|
|
144
|
+
referenceNumber?: string;
|
|
145
|
+
appliedAt?: number;
|
|
146
|
+
approvedAt?: number;
|
|
147
|
+
};
|
|
148
|
+
/** Whether a Transfer Impact Assessment has been conducted */
|
|
149
|
+
tiaCompleted: boolean;
|
|
150
|
+
/** Reference to the TIA document */
|
|
151
|
+
tiaReference?: string;
|
|
152
|
+
/** Frequency of the transfer */
|
|
153
|
+
frequency: 'one_time' | 'periodic' | 'continuous';
|
|
154
|
+
/** Start date of the transfer */
|
|
155
|
+
startDate: number;
|
|
156
|
+
/** End date of the transfer (if applicable) */
|
|
157
|
+
endDate?: number;
|
|
158
|
+
/** Status of the transfer */
|
|
159
|
+
status: 'active' | 'suspended' | 'terminated' | 'pending_approval';
|
|
160
|
+
/** Timestamp when the record was created */
|
|
161
|
+
createdAt: number;
|
|
162
|
+
/** Timestamp when the record was last updated */
|
|
163
|
+
updatedAt: number;
|
|
164
|
+
/** Next review date */
|
|
165
|
+
reviewDate?: number;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Cross-border data transfer management component. Implements NDPA Sections 41-45 requirements
|
|
170
|
+
* for managing international data transfers, including adequacy decisions, standard contractual
|
|
171
|
+
* clauses, and NDPC authorization.
|
|
172
|
+
*/
|
|
173
|
+
export declare const CrossBorderTransferManager: React__default.FC<CrossBorderTransferManagerProps>;
|
|
174
|
+
|
|
175
|
+
declare interface CrossBorderTransferManagerClassNames {
|
|
176
|
+
root?: string;
|
|
177
|
+
header?: string;
|
|
178
|
+
title?: string;
|
|
179
|
+
summary?: string;
|
|
180
|
+
summaryCard?: string;
|
|
181
|
+
transferList?: string;
|
|
182
|
+
transferItem?: string;
|
|
183
|
+
form?: string;
|
|
184
|
+
input?: string;
|
|
185
|
+
select?: string;
|
|
186
|
+
submitButton?: string;
|
|
187
|
+
/** Alias for submitButton */
|
|
188
|
+
primaryButton?: string;
|
|
189
|
+
riskBadge?: string;
|
|
190
|
+
statusBadge?: string;
|
|
191
|
+
detailPanel?: string;
|
|
192
|
+
approvalStatus?: string;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
declare interface CrossBorderTransferManagerProps {
|
|
196
|
+
/**
|
|
197
|
+
* List of cross-border transfers to display
|
|
198
|
+
*/
|
|
199
|
+
transfers: CrossBorderTransfer[];
|
|
200
|
+
/**
|
|
201
|
+
* Callback when a new transfer is added
|
|
202
|
+
*/
|
|
203
|
+
onAddTransfer?: (transfer: Omit<CrossBorderTransfer, 'id' | 'createdAt' | 'updatedAt'>) => void;
|
|
204
|
+
/**
|
|
205
|
+
* Callback when a transfer is updated
|
|
206
|
+
*/
|
|
207
|
+
onUpdateTransfer?: (id: string, updates: Partial<CrossBorderTransfer>) => void;
|
|
208
|
+
/**
|
|
209
|
+
* Callback when a transfer is removed
|
|
210
|
+
*/
|
|
211
|
+
onRemoveTransfer?: (id: string) => void;
|
|
212
|
+
/**
|
|
213
|
+
* Compliance summary data
|
|
214
|
+
*/
|
|
215
|
+
summary?: CrossBorderSummary;
|
|
216
|
+
/**
|
|
217
|
+
* Title displayed on the manager
|
|
218
|
+
* @default "Cross-Border Data Transfer Manager"
|
|
219
|
+
*/
|
|
220
|
+
title?: string;
|
|
221
|
+
/**
|
|
222
|
+
* Description text displayed on the manager
|
|
223
|
+
* @default "Manage and document cross-border personal data transfers in compliance with NDPA 2023 Part VI (Sections 41-45)."
|
|
224
|
+
*/
|
|
225
|
+
description?: string;
|
|
226
|
+
/**
|
|
227
|
+
* Custom CSS class for the manager container
|
|
228
|
+
*/
|
|
229
|
+
className?: string;
|
|
230
|
+
/**
|
|
231
|
+
* Custom CSS class for buttons
|
|
232
|
+
*/
|
|
233
|
+
buttonClassName?: string;
|
|
234
|
+
/**
|
|
235
|
+
* Whether to show the compliance summary section
|
|
236
|
+
* @default true
|
|
237
|
+
*/
|
|
238
|
+
showSummary?: boolean;
|
|
239
|
+
/**
|
|
240
|
+
* Whether to show the TIA section in the form
|
|
241
|
+
* @default true
|
|
242
|
+
*/
|
|
243
|
+
showTIA?: boolean;
|
|
244
|
+
/**
|
|
245
|
+
* Override class names for individual sections of the component.
|
|
246
|
+
* Takes priority over className / buttonClassName.
|
|
247
|
+
*/
|
|
248
|
+
classNames?: CrossBorderTransferManagerClassNames;
|
|
249
|
+
/**
|
|
250
|
+
* When true, all default styling is removed so consumers
|
|
251
|
+
* can style from scratch using classNames.
|
|
252
|
+
*/
|
|
253
|
+
unstyled?: boolean;
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
/**
|
|
257
|
+
* Returns all countries that are considered adequate for cross-border data transfers.
|
|
258
|
+
*
|
|
259
|
+
* @returns Array of CountryAdequacy entries with adequacyStatus === 'adequate'
|
|
260
|
+
*/
|
|
261
|
+
export declare function getAdequateCountries(): CountryAdequacy[];
|
|
262
|
+
|
|
263
|
+
/**
|
|
264
|
+
* Look up the adequacy determination for a country by name or ISO code.
|
|
265
|
+
*
|
|
266
|
+
* The search is case-insensitive and matches against both the `country` field
|
|
267
|
+
* and the `isoCode` field.
|
|
268
|
+
*
|
|
269
|
+
* @param countryOrCode A country name (e.g. "Germany") or ISO 3166-1 alpha-2 code (e.g. "DE")
|
|
270
|
+
* @returns The matching CountryAdequacy entry, or undefined if not found
|
|
271
|
+
*/
|
|
272
|
+
export declare function getCountryAdequacy(countryOrCode: string): CountryAdequacy | undefined;
|
|
273
|
+
|
|
274
|
+
/**
|
|
275
|
+
* Returns a human-readable description of a transfer mechanism with its NDPA section reference.
|
|
276
|
+
*
|
|
277
|
+
* @param mechanism The transfer mechanism
|
|
278
|
+
* @returns Description including the relevant NDPA section
|
|
279
|
+
*/
|
|
280
|
+
export declare function getTransferMechanismDescription(mechanism: TransferMechanism): string;
|
|
281
|
+
|
|
282
|
+
/**
|
|
283
|
+
* Returns whether NDPC approval is required for a given transfer mechanism.
|
|
284
|
+
* Approval is required for standard contractual clauses (Section 42),
|
|
285
|
+
* binding corporate rules (Section 43), and specific NDPC authorization (Section 44).
|
|
286
|
+
*
|
|
287
|
+
* @param mechanism The transfer mechanism
|
|
288
|
+
* @returns Whether NDPC approval is required
|
|
289
|
+
*/
|
|
290
|
+
export declare function isNDPCApprovalRequired(mechanism: TransferMechanism): boolean;
|
|
291
|
+
|
|
292
|
+
/**
|
|
293
|
+
* Determines whether a transfer to the specified country requires NDPC approval.
|
|
294
|
+
*
|
|
295
|
+
* Countries that are not in the adequacy database or that have a status other
|
|
296
|
+
* than 'adequate' require NDPC approval (or an alternative transfer mechanism
|
|
297
|
+
* such as standard contractual clauses or binding corporate rules).
|
|
298
|
+
*
|
|
299
|
+
* @param countryOrCode A country name or ISO 3166-1 alpha-2 code
|
|
300
|
+
* @returns true if NDPC approval is likely required for transfers to this country
|
|
301
|
+
*/
|
|
302
|
+
export declare function requiresNDPCApproval(countryOrCode: string): boolean;
|
|
303
|
+
|
|
304
|
+
export declare interface StorageAdapter<T = unknown> {
|
|
305
|
+
/** Load persisted data. Called once on hook mount. */
|
|
306
|
+
load(): T | null | Promise<T | null>;
|
|
307
|
+
/** Persist data. Called on every state change. */
|
|
308
|
+
save(data: T): void | Promise<void>;
|
|
309
|
+
/** Clear persisted data. Called on reset. */
|
|
310
|
+
remove(): void | Promise<void>;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
/**
|
|
314
|
+
* Transfer Impact Assessment (TIA) for cross-border transfers
|
|
315
|
+
*/
|
|
316
|
+
export declare interface TransferImpactAssessment {
|
|
317
|
+
/** Unique identifier */
|
|
318
|
+
id: string;
|
|
319
|
+
/** ID of the associated cross-border transfer */
|
|
320
|
+
transferId: string;
|
|
321
|
+
/** Date the assessment was conducted */
|
|
322
|
+
assessmentDate: number;
|
|
323
|
+
/** Person who conducted the assessment */
|
|
324
|
+
assessor: {
|
|
325
|
+
name: string;
|
|
326
|
+
role: string;
|
|
327
|
+
email: string;
|
|
328
|
+
};
|
|
329
|
+
/** Analysis of the destination country's legal framework */
|
|
330
|
+
destinationLegalFramework: string;
|
|
331
|
+
/** Whether the destination has data protection legislation */
|
|
332
|
+
hasDataProtectionLaw: boolean;
|
|
333
|
+
/** Whether the destination has an independent supervisory authority */
|
|
334
|
+
hasIndependentAuthority: boolean;
|
|
335
|
+
/** Risk of government access to the data */
|
|
336
|
+
governmentAccessRisk: 'low' | 'medium' | 'high';
|
|
337
|
+
/** Overall assessment of data protection level */
|
|
338
|
+
dataProtectionLevel: 'adequate' | 'partially_adequate' | 'inadequate';
|
|
339
|
+
/** Supplementary measures to address gaps */
|
|
340
|
+
supplementaryMeasures: string[];
|
|
341
|
+
/** Technical measures (encryption, pseudonymization, etc.) */
|
|
342
|
+
technicalMeasures: string[];
|
|
343
|
+
/** Contractual measures */
|
|
344
|
+
contractualMeasures: string[];
|
|
345
|
+
/** Organizational measures */
|
|
346
|
+
organizationalMeasures: string[];
|
|
347
|
+
/** Overall conclusion */
|
|
348
|
+
conclusion: string;
|
|
349
|
+
/** Whether the transfer can proceed based on the assessment */
|
|
350
|
+
approved: boolean;
|
|
351
|
+
/** Conditions for the transfer (if approved with conditions) */
|
|
352
|
+
conditions?: string[];
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
/**
|
|
356
|
+
* Cross-Border Data Transfer types aligned with NDPA 2023 Part VI (Sections 41-45)
|
|
357
|
+
* Personal data may only be transferred outside Nigeria under specific conditions
|
|
358
|
+
*/
|
|
359
|
+
/**
|
|
360
|
+
* Transfer mechanisms recognized under the NDPA
|
|
361
|
+
*/
|
|
362
|
+
export declare type TransferMechanism = 'adequacy_decision' | 'standard_clauses' | 'binding_corporate_rules' | 'ndpc_authorization' | 'explicit_consent' | 'contract_performance' | 'public_interest' | 'legal_claims' | 'vital_interests';
|
|
363
|
+
|
|
364
|
+
/**
|
|
365
|
+
* Risk assessment result for a cross-border transfer
|
|
366
|
+
*/
|
|
367
|
+
export declare interface TransferRiskResult {
|
|
368
|
+
riskLevel: 'low' | 'medium' | 'high';
|
|
369
|
+
riskScore: number;
|
|
370
|
+
factors: string[];
|
|
371
|
+
recommendations: string[];
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
/**
|
|
375
|
+
* Validation result for a cross-border transfer
|
|
376
|
+
*/
|
|
377
|
+
export declare interface TransferValidationResult {
|
|
378
|
+
isValid: boolean;
|
|
379
|
+
errors: string[];
|
|
380
|
+
warnings: string[];
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
export declare function useCrossBorderCompound(): CrossBorderContextValue;
|
|
384
|
+
|
|
385
|
+
/**
|
|
386
|
+
* Hook for managing cross-border data transfers in compliance with NDPA Part VI (Sections 41-45)
|
|
387
|
+
*/
|
|
388
|
+
export declare function useCrossBorderTransfer({ initialTransfers, adapter, storageKey, useLocalStorage, onAdd, onUpdate, onRemove, }?: UseCrossBorderTransferOptions): UseCrossBorderTransferReturn;
|
|
389
|
+
|
|
390
|
+
declare interface UseCrossBorderTransferOptions {
|
|
391
|
+
/**
|
|
392
|
+
* Initial transfers to load
|
|
393
|
+
*/
|
|
394
|
+
initialTransfers?: CrossBorderTransfer[];
|
|
395
|
+
/**
|
|
396
|
+
* Pluggable storage adapter. When provided, takes precedence over storageKey/useLocalStorage.
|
|
397
|
+
*/
|
|
398
|
+
adapter?: StorageAdapter<CrossBorderTransfer[]>;
|
|
399
|
+
/**
|
|
400
|
+
* Storage key for transfer data
|
|
401
|
+
* @default "ndpr_cross_border_transfers"
|
|
402
|
+
* @deprecated Use adapter instead
|
|
403
|
+
*/
|
|
404
|
+
storageKey?: string;
|
|
405
|
+
/**
|
|
406
|
+
* Whether to use local storage to persist transfers
|
|
407
|
+
* @default true
|
|
408
|
+
* @deprecated Use adapter instead
|
|
409
|
+
*/
|
|
410
|
+
useLocalStorage?: boolean;
|
|
411
|
+
/**
|
|
412
|
+
* Callback function called when a transfer is added
|
|
413
|
+
*/
|
|
414
|
+
onAdd?: (transfer: CrossBorderTransfer) => void;
|
|
415
|
+
/**
|
|
416
|
+
* Callback function called when a transfer is updated
|
|
417
|
+
*/
|
|
418
|
+
onUpdate?: (transfer: CrossBorderTransfer) => void;
|
|
419
|
+
/**
|
|
420
|
+
* Callback function called when a transfer is removed
|
|
421
|
+
*/
|
|
422
|
+
onRemove?: (id: string) => void;
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
export declare interface UseCrossBorderTransferReturn {
|
|
426
|
+
/**
|
|
427
|
+
* All cross-border transfers
|
|
428
|
+
*/
|
|
429
|
+
transfers: CrossBorderTransfer[];
|
|
430
|
+
/**
|
|
431
|
+
* Add a new cross-border transfer
|
|
432
|
+
*/
|
|
433
|
+
addTransfer: (transfer: Omit<CrossBorderTransfer, 'id' | 'createdAt' | 'updatedAt'>) => CrossBorderTransfer;
|
|
434
|
+
/**
|
|
435
|
+
* Update an existing cross-border transfer
|
|
436
|
+
*/
|
|
437
|
+
updateTransfer: (id: string, updates: Partial<CrossBorderTransfer>) => CrossBorderTransfer | null;
|
|
438
|
+
/**
|
|
439
|
+
* Remove a cross-border transfer
|
|
440
|
+
*/
|
|
441
|
+
removeTransfer: (id: string) => void;
|
|
442
|
+
/**
|
|
443
|
+
* Get a cross-border transfer by ID
|
|
444
|
+
*/
|
|
445
|
+
getTransfer: (id: string) => CrossBorderTransfer | null;
|
|
446
|
+
/**
|
|
447
|
+
* Get a compliance summary of all cross-border transfers
|
|
448
|
+
*/
|
|
449
|
+
getSummary: () => CrossBorderSummary;
|
|
450
|
+
/**
|
|
451
|
+
* Validate a cross-border transfer
|
|
452
|
+
*/
|
|
453
|
+
validateTransfer: (transfer: CrossBorderTransfer) => TransferValidationResult;
|
|
454
|
+
/**
|
|
455
|
+
* Whether the adapter is still loading data (relevant for async adapters)
|
|
456
|
+
*/
|
|
457
|
+
isLoading: boolean;
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
/**
|
|
461
|
+
* Validates a cross-border transfer record for completeness and compliance.
|
|
462
|
+
* Checks required fields, verifies that NDPC approval is documented when required,
|
|
463
|
+
* and ensures safeguards are in place.
|
|
464
|
+
*
|
|
465
|
+
* @param transfer The cross-border transfer to validate
|
|
466
|
+
* @returns Validation result with errors and warnings
|
|
467
|
+
*/
|
|
468
|
+
export declare function validateTransfer(transfer: CrossBorderTransfer): TransferValidationResult;
|
|
469
|
+
|
|
470
|
+
export { }
|
package/dist/cross-border.js
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
+
"use client";
|
|
1
2
|
'use strict';var chunkNQNFS3QI_js=require('./chunk-NQNFS3QI.js'),chunkMCWV7S2G_js=require('./chunk-MCWV7S2G.js'),chunkC4YM4UMI_js=require('./chunk-C4YM4UMI.js');require('./chunk-E64TU6IU.js'),require('./chunk-ELKB2AFZ.js'),require('./chunk-MQFZHA2D.js');var react=require('react'),jsxRuntime=require('react/jsx-runtime');var t=react.createContext(null);function A(){let r=react.useContext(t);if(!r)throw new Error("CrossBorder compound components must be wrapped in <CrossBorder.Provider>. Example: <CrossBorder.Provider><CrossBorder.Manager /></CrossBorder.Provider>");return r}var e=({adapter:r,storageKey:d,useLocalStorage:a,initialTransfers:n,onAdd:p,onUpdate:C,onRemove:f,children:i})=>{let m=chunkMCWV7S2G_js.a({adapter:r,storageKey:d,useLocalStorage:a,initialTransfers:n,onAdd:p,onUpdate:C,onRemove:f});return jsxRuntime.jsx(t.Provider,{value:m,children:i})};var q={Provider:e,Manager:chunkNQNFS3QI_js.a};Object.defineProperty(exports,"CrossBorderTransferManager",{enumerable:true,get:function(){return chunkNQNFS3QI_js.a}});Object.defineProperty(exports,"useCrossBorderTransfer",{enumerable:true,get:function(){return chunkMCWV7S2G_js.a}});Object.defineProperty(exports,"COUNTRY_ADEQUACY_MAP",{enumerable:true,get:function(){return chunkC4YM4UMI_js.a}});Object.defineProperty(exports,"assessTransferRisk",{enumerable:true,get:function(){return chunkC4YM4UMI_js.h}});Object.defineProperty(exports,"getAdequateCountries",{enumerable:true,get:function(){return chunkC4YM4UMI_js.c}});Object.defineProperty(exports,"getCountryAdequacy",{enumerable:true,get:function(){return chunkC4YM4UMI_js.b}});Object.defineProperty(exports,"getTransferMechanismDescription",{enumerable:true,get:function(){return chunkC4YM4UMI_js.f}});Object.defineProperty(exports,"isNDPCApprovalRequired",{enumerable:true,get:function(){return chunkC4YM4UMI_js.e}});Object.defineProperty(exports,"requiresNDPCApproval",{enumerable:true,get:function(){return chunkC4YM4UMI_js.d}});Object.defineProperty(exports,"validateTransfer",{enumerable:true,get:function(){return chunkC4YM4UMI_js.g}});exports.CrossBorder=q;exports.CrossBorderProvider=e;exports.useCrossBorderCompound=A;//# sourceMappingURL=cross-border.js.map
|
|
2
3
|
//# sourceMappingURL=cross-border.js.map
|
package/dist/cross-border.mjs
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
+
"use client";
|
|
1
2
|
import {a}from'./chunk-SYMQJO2W.mjs';export{a as CrossBorderTransferManager}from'./chunk-SYMQJO2W.mjs';import {a as a$1}from'./chunk-Z6IIMLZU.mjs';export{a as useCrossBorderTransfer}from'./chunk-Z6IIMLZU.mjs';export{a as COUNTRY_ADEQUACY_MAP,h as assessTransferRisk,c as getAdequateCountries,b as getCountryAdequacy,f as getTransferMechanismDescription,e as isNDPCApprovalRequired,d as requiresNDPCApproval,g as validateTransfer}from'./chunk-75TJPK2N.mjs';import'./chunk-AYKLAEOU.mjs';import'./chunk-6WIP33TW.mjs';import'./chunk-WWT2ZSNU.mjs';import {createContext,useContext}from'react';import {jsx}from'react/jsx-runtime';var t=createContext(null);function A(){let r=useContext(t);if(!r)throw new Error("CrossBorder compound components must be wrapped in <CrossBorder.Provider>. Example: <CrossBorder.Provider><CrossBorder.Manager /></CrossBorder.Provider>");return r}var e=({adapter:r,storageKey:d,useLocalStorage:a,initialTransfers:n,onAdd:p,onUpdate:C,onRemove:f,children:i})=>{let m=a$1({adapter:r,storageKey:d,useLocalStorage:a,initialTransfers:n,onAdd:p,onUpdate:C,onRemove:f});return jsx(t.Provider,{value:m,children:i})};var q={Provider:e,Manager:a};export{q as CrossBorder,e as CrossBorderProvider,A as useCrossBorderCompound};//# sourceMappingURL=cross-border.mjs.map
|
|
2
3
|
//# sourceMappingURL=cross-border.mjs.map
|