@dcl/content-validator 4.3.0 → 4.3.1-4346672765.commit-51a4f9f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +2 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -12
- package/dist/index.js.map +1 -1
- package/dist/types.d.ts +60 -24
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/validations/ADR45.d.ts +2 -2
- package/dist/validations/ADR45.d.ts.map +1 -1
- package/dist/validations/ADR45.js +3 -3
- package/dist/validations/ADR45.js.map +1 -1
- package/dist/validations/access/common/items.d.ts +10 -0
- package/dist/validations/access/common/items.d.ts.map +1 -0
- package/dist/validations/access/common/items.js +94 -0
- package/dist/validations/access/common/items.js.map +1 -0
- package/dist/validations/access/common/profiles.d.ts +3 -0
- package/dist/validations/access/common/profiles.d.ts.map +1 -0
- package/dist/validations/access/common/profiles.js +28 -0
- package/dist/validations/access/common/profiles.js.map +1 -0
- package/dist/validations/access/common/stores.d.ts +7 -0
- package/dist/validations/access/common/stores.d.ts.map +1 -0
- package/dist/validations/access/common/stores.js +35 -0
- package/dist/validations/access/common/stores.js.map +1 -0
- package/dist/validations/access/index.d.ts +8 -0
- package/dist/validations/access/index.d.ts.map +1 -0
- package/dist/validations/access/index.js +30 -0
- package/dist/validations/access/index.js.map +1 -0
- package/dist/validations/access/on-chain/client.d.ts +14 -0
- package/dist/validations/access/on-chain/client.d.ts.map +1 -0
- package/dist/validations/access/on-chain/client.js +177 -0
- package/dist/validations/access/on-chain/client.js.map +1 -0
- package/dist/validations/access/on-chain/collection-asset.d.ts +3 -0
- package/dist/validations/access/on-chain/collection-asset.d.ts.map +1 -0
- package/dist/validations/access/on-chain/collection-asset.js +66 -0
- package/dist/validations/access/on-chain/collection-asset.js.map +1 -0
- package/dist/validations/access/on-chain/index.d.ts +4 -0
- package/dist/validations/access/on-chain/index.d.ts.map +1 -0
- package/dist/validations/access/on-chain/index.js +23 -0
- package/dist/validations/access/on-chain/index.js.map +1 -0
- package/dist/validations/access/on-chain/profiles.d.ts +5 -0
- package/dist/validations/access/on-chain/profiles.d.ts.map +1 -0
- package/dist/validations/access/on-chain/profiles.js +84 -0
- package/dist/validations/access/on-chain/profiles.js.map +1 -0
- package/dist/validations/access/on-chain/scenes.d.ts +7 -0
- package/dist/validations/access/on-chain/scenes.d.ts.map +1 -0
- package/dist/validations/access/on-chain/scenes.js +53 -0
- package/dist/validations/access/on-chain/scenes.js.map +1 -0
- package/dist/validations/access/on-chain/third-party-asset.d.ts +3 -0
- package/dist/validations/access/on-chain/third-party-asset.d.ts.map +1 -0
- package/dist/validations/access/on-chain/third-party-asset.js +53 -0
- package/dist/validations/access/on-chain/third-party-asset.js.map +1 -0
- package/dist/validations/access/subgraph/collection-asset.d.ts +15 -0
- package/dist/validations/access/subgraph/collection-asset.d.ts.map +1 -0
- package/dist/validations/{access-checker/items → access/subgraph}/collection-asset.js +10 -13
- package/dist/validations/access/subgraph/collection-asset.js.map +1 -0
- package/dist/validations/access/subgraph/index.d.ts +4 -0
- package/dist/validations/access/subgraph/index.d.ts.map +1 -0
- package/dist/validations/access/subgraph/index.js +23 -0
- package/dist/validations/access/subgraph/index.js.map +1 -0
- package/dist/validations/access/subgraph/profiles.d.ts +5 -0
- package/dist/validations/access/subgraph/profiles.d.ts.map +1 -0
- package/dist/validations/access/subgraph/profiles.js +84 -0
- package/dist/validations/access/subgraph/profiles.js.map +1 -0
- package/dist/validations/access/subgraph/scenes.d.ts +7 -0
- package/dist/validations/access/subgraph/scenes.d.ts.map +1 -0
- package/dist/validations/access/subgraph/scenes.js +262 -0
- package/dist/validations/access/subgraph/scenes.js.map +1 -0
- package/dist/validations/access/subgraph/the-graph-client.d.ts +10 -0
- package/dist/validations/access/subgraph/the-graph-client.d.ts.map +1 -0
- package/dist/validations/access/subgraph/the-graph-client.js.map +1 -0
- package/dist/validations/access/subgraph/third-party-asset.d.ts +3 -0
- package/dist/validations/access/subgraph/third-party-asset.d.ts.map +1 -0
- package/dist/validations/{access-checker/items → access/subgraph}/third-party-asset.js +6 -8
- package/dist/validations/access/subgraph/third-party-asset.js.map +1 -0
- package/dist/validations/content.d.ts +6 -10
- package/dist/validations/content.d.ts.map +1 -1
- package/dist/validations/content.js +29 -24
- package/dist/validations/content.js.map +1 -1
- package/dist/validations/entity-structure.d.ts +2 -2
- package/dist/validations/entity-structure.d.ts.map +1 -1
- package/dist/validations/entity-structure.js +3 -3
- package/dist/validations/entity-structure.js.map +1 -1
- package/dist/validations/index.d.ts +2 -18
- package/dist/validations/index.d.ts.map +1 -1
- package/dist/validations/index.js +20 -15
- package/dist/validations/index.js.map +1 -1
- package/dist/validations/ipfs-hashing.d.ts +1 -2
- package/dist/validations/ipfs-hashing.d.ts.map +1 -1
- package/dist/validations/ipfs-hashing.js +2 -2
- package/dist/validations/ipfs-hashing.js.map +1 -1
- package/dist/validations/items/emotes.d.ts +4 -4
- package/dist/validations/items/emotes.d.ts.map +1 -1
- package/dist/validations/items/emotes.js +6 -6
- package/dist/validations/items/emotes.js.map +1 -1
- package/dist/validations/items/items.d.ts +4 -4
- package/dist/validations/items/items.d.ts.map +1 -1
- package/dist/validations/items/items.js +67 -52
- package/dist/validations/items/items.js.map +1 -1
- package/dist/validations/items/wearables.d.ts +3 -3
- package/dist/validations/items/wearables.d.ts.map +1 -1
- package/dist/validations/items/wearables.js +4 -4
- package/dist/validations/items/wearables.js.map +1 -1
- package/dist/validations/metadata-schema.d.ts +10 -1
- package/dist/validations/metadata-schema.d.ts.map +1 -1
- package/dist/validations/metadata-schema.js +9 -6
- package/dist/validations/metadata-schema.js.map +1 -1
- package/dist/validations/profile.d.ts +7 -10
- package/dist/validations/profile.d.ts.map +1 -1
- package/dist/validations/profile.js +57 -37
- package/dist/validations/profile.js.map +1 -1
- package/dist/validations/scene.d.ts +2 -2
- package/dist/validations/scene.d.ts.map +1 -1
- package/dist/validations/scene.js +8 -7
- package/dist/validations/scene.js.map +1 -1
- package/dist/validations/signature.d.ts +2 -2
- package/dist/validations/signature.d.ts.map +1 -1
- package/dist/validations/signature.js +8 -6
- package/dist/validations/signature.js.map +1 -1
- package/dist/validations/size.d.ts +2 -2
- package/dist/validations/size.d.ts.map +1 -1
- package/dist/validations/size.js +31 -29
- package/dist/validations/size.js.map +1 -1
- package/dist/validations/validations.d.ts.map +1 -1
- package/dist/validations/validations.js +6 -5
- package/dist/validations/validations.js.map +1 -1
- package/package.json +7 -4
- package/dist/the-graph-client/the-graph-client.d.ts +0 -10
- package/dist/the-graph-client/the-graph-client.d.ts.map +0 -1
- package/dist/the-graph-client/the-graph-client.js.map +0 -1
- package/dist/validations/access-checker/access.d.ts +0 -7
- package/dist/validations/access-checker/access.d.ts.map +0 -1
- package/dist/validations/access-checker/access.js +0 -42
- package/dist/validations/access-checker/access.js.map +0 -1
- package/dist/validations/access-checker/emotes.d.ts +0 -3
- package/dist/validations/access-checker/emotes.d.ts.map +0 -1
- package/dist/validations/access-checker/emotes.js +0 -12
- package/dist/validations/access-checker/emotes.js.map +0 -1
- package/dist/validations/access-checker/items/collection-asset.d.ts +0 -15
- package/dist/validations/access-checker/items/collection-asset.d.ts.map +0 -1
- package/dist/validations/access-checker/items/collection-asset.js.map +0 -1
- package/dist/validations/access-checker/items/items.d.ts +0 -11
- package/dist/validations/access-checker/items/items.d.ts.map +0 -1
- package/dist/validations/access-checker/items/items.js +0 -67
- package/dist/validations/access-checker/items/items.js.map +0 -1
- package/dist/validations/access-checker/items/off-chain-asset.d.ts +0 -3
- package/dist/validations/access-checker/items/off-chain-asset.d.ts.map +0 -1
- package/dist/validations/access-checker/items/off-chain-asset.js +0 -17
- package/dist/validations/access-checker/items/off-chain-asset.js.map +0 -1
- package/dist/validations/access-checker/items/third-party-asset.d.ts +0 -3
- package/dist/validations/access-checker/items/third-party-asset.d.ts.map +0 -1
- package/dist/validations/access-checker/items/third-party-asset.js.map +0 -1
- package/dist/validations/access-checker/profiles.d.ts +0 -7
- package/dist/validations/access-checker/profiles.d.ts.map +0 -1
- package/dist/validations/access-checker/profiles.js +0 -114
- package/dist/validations/access-checker/profiles.js.map +0 -1
- package/dist/validations/access-checker/scenes.d.ts +0 -7
- package/dist/validations/access-checker/scenes.d.ts.map +0 -1
- package/dist/validations/access-checker/scenes.js +0 -261
- package/dist/validations/access-checker/scenes.js.map +0 -1
- package/dist/validations/access-checker/stores.d.ts +0 -7
- package/dist/validations/access-checker/stores.d.ts.map +0 -1
- package/dist/validations/access-checker/stores.js +0 -33
- package/dist/validations/access-checker/stores.js.map +0 -1
- package/dist/validations/access-checker/wearables.d.ts +0 -3
- package/dist/validations/access-checker/wearables.d.ts.map +0 -1
- package/dist/validations/access-checker/wearables.js +0 -14
- package/dist/validations/access-checker/wearables.js.map +0 -1
- /package/dist/{the-graph-client → validations/access/subgraph}/the-graph-client.js +0 -0
|
@@ -1,261 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.scenes = void 0;
|
|
7
|
-
const ms_1 = __importDefault(require("ms"));
|
|
8
|
-
const types_1 = require("../../types");
|
|
9
|
-
/**
|
|
10
|
-
* Checks if the given address has access to the given parcel at the given timestamp.
|
|
11
|
-
* @public
|
|
12
|
-
*/
|
|
13
|
-
async function scenes(components, deployment) {
|
|
14
|
-
const { externalCalls, subGraphs, logs } = components;
|
|
15
|
-
const logger = logs.getLogger('scenes access validator');
|
|
16
|
-
const getAuthorizations = async (owner, operator, timestamp) => {
|
|
17
|
-
const query = `
|
|
18
|
-
query GetAuthorizations($owner: String!, $operator: String!, $timestamp: Int!) {
|
|
19
|
-
authorizations(
|
|
20
|
-
where: {
|
|
21
|
-
owner: $owner,
|
|
22
|
-
operator: $operator,
|
|
23
|
-
createdAt_lte: $timestamp
|
|
24
|
-
},
|
|
25
|
-
orderBy: timestamp,
|
|
26
|
-
orderDirection: desc
|
|
27
|
-
) {
|
|
28
|
-
type
|
|
29
|
-
isApproved
|
|
30
|
-
}
|
|
31
|
-
}`;
|
|
32
|
-
const variables = {
|
|
33
|
-
owner,
|
|
34
|
-
operator,
|
|
35
|
-
timestamp: Math.floor(timestamp / 1000) // js(ms) -> UNIX(s)
|
|
36
|
-
};
|
|
37
|
-
try {
|
|
38
|
-
return (await subGraphs.L1.landManager.query(query, variables)).authorizations;
|
|
39
|
-
}
|
|
40
|
-
catch (error) {
|
|
41
|
-
logger.error(`Error fetching authorizations for ${owner}`);
|
|
42
|
-
throw error;
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
const getEstate = async (estateId, timestamp) => {
|
|
46
|
-
/**
|
|
47
|
-
* You can use `owner`, `operator` and `updateOperator` to check the current value for that estate.
|
|
48
|
-
* Keep in mind that each association (owners, operators, etc) is capped to a thousand (1000) results.
|
|
49
|
-
* For more information, you can use the query explorer at https://thegraph.com/explorer/subgraph/decentraland/land-manager
|
|
50
|
-
*/
|
|
51
|
-
const query = `
|
|
52
|
-
query GetEstate($estateId: String!, $timestamp: Int!) {
|
|
53
|
-
estates(where:{ id: $estateId }) {
|
|
54
|
-
id
|
|
55
|
-
owners(
|
|
56
|
-
where: { createdAt_lte: $timestamp },
|
|
57
|
-
orderBy: timestamp,
|
|
58
|
-
orderDirection: desc,
|
|
59
|
-
first: 1
|
|
60
|
-
) {
|
|
61
|
-
address
|
|
62
|
-
}
|
|
63
|
-
operators(
|
|
64
|
-
where: { createdAt_lte: $timestamp },
|
|
65
|
-
orderBy: timestamp,
|
|
66
|
-
orderDirection: desc,
|
|
67
|
-
first: 1
|
|
68
|
-
) {
|
|
69
|
-
address
|
|
70
|
-
}
|
|
71
|
-
updateOperators(
|
|
72
|
-
where: { createdAt_lte: $timestamp },
|
|
73
|
-
orderBy: timestamp,
|
|
74
|
-
orderDirection: desc,
|
|
75
|
-
first: 1
|
|
76
|
-
) {
|
|
77
|
-
address
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}`;
|
|
81
|
-
const variables = {
|
|
82
|
-
estateId,
|
|
83
|
-
timestamp: Math.floor(timestamp / 1000) // UNIX
|
|
84
|
-
};
|
|
85
|
-
try {
|
|
86
|
-
return (await subGraphs.L1.landManager.query(query, variables)).estates[0];
|
|
87
|
-
}
|
|
88
|
-
catch (error) {
|
|
89
|
-
logger.error(`Error fetching estate (${estateId})`);
|
|
90
|
-
throw error;
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
const getParcel = async (x, y, timestamp) => {
|
|
94
|
-
/**
|
|
95
|
-
* You can use `owner`, `operator` and `updateOperator` to check the current value for that parcel.
|
|
96
|
-
* Keep in mind that each association (owners, operators, etc) is capped to a thousand (1000) results.
|
|
97
|
-
* For more information, you can use the query explorer at https://thegraph.com/explorer/subgraph/decentraland/land-manager
|
|
98
|
-
*/
|
|
99
|
-
const query = `
|
|
100
|
-
query GetParcel($x: Int!, $y: Int!, $timestamp: Int!) {
|
|
101
|
-
parcels(where:{ x: $x, y: $y }) {
|
|
102
|
-
estates(
|
|
103
|
-
where: { createdAt_lte: $timestamp },
|
|
104
|
-
orderBy: createdAt,
|
|
105
|
-
orderDirection: desc,
|
|
106
|
-
first: 1
|
|
107
|
-
) {
|
|
108
|
-
estateId
|
|
109
|
-
}
|
|
110
|
-
owners(
|
|
111
|
-
where: { createdAt_lte: $timestamp },
|
|
112
|
-
orderBy: timestamp,
|
|
113
|
-
orderDirection: desc,
|
|
114
|
-
first: 1
|
|
115
|
-
) {
|
|
116
|
-
address
|
|
117
|
-
}
|
|
118
|
-
operators(
|
|
119
|
-
where: { createdAt_lte: $timestamp },
|
|
120
|
-
orderBy: timestamp,
|
|
121
|
-
orderDirection: desc,
|
|
122
|
-
first: 1
|
|
123
|
-
) {
|
|
124
|
-
address
|
|
125
|
-
}
|
|
126
|
-
updateOperators(
|
|
127
|
-
where: { createdAt_lte: $timestamp },
|
|
128
|
-
orderBy: timestamp,
|
|
129
|
-
orderDirection: desc,
|
|
130
|
-
first: 1
|
|
131
|
-
) {
|
|
132
|
-
address
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}`;
|
|
136
|
-
const variables = {
|
|
137
|
-
x,
|
|
138
|
-
y,
|
|
139
|
-
timestamp: Math.floor(timestamp / 1000) // UNIX
|
|
140
|
-
};
|
|
141
|
-
try {
|
|
142
|
-
const r = await subGraphs.L1.landManager.query(query, variables);
|
|
143
|
-
if (r.parcels && r.parcels.length)
|
|
144
|
-
return r.parcels[0];
|
|
145
|
-
logger.error(`Error fetching parcel (${x}, ${y}, ${timestamp}): ${JSON.stringify(r)}`);
|
|
146
|
-
throw new Error(`Error fetching parcel (${x}, ${y}), ${timestamp}`);
|
|
147
|
-
}
|
|
148
|
-
catch (error) {
|
|
149
|
-
logger.error(`Error fetching parcel (${x}, ${y}, ${timestamp})`);
|
|
150
|
-
throw error;
|
|
151
|
-
}
|
|
152
|
-
};
|
|
153
|
-
const hasAccessThroughAuthorizations = async (owner, ethAddress, timestamp) => {
|
|
154
|
-
/* You also get access if you received:
|
|
155
|
-
* - an authorization with isApproved and type Operator, ApprovalForAll or UpdateManager
|
|
156
|
-
* at that time
|
|
157
|
-
*/
|
|
158
|
-
const authorizations = await getAuthorizations(owner.toLowerCase(), ethAddress.toLowerCase(), timestamp);
|
|
159
|
-
const firstOperatorAuthorization = authorizations.find((authorization) => authorization.type === 'Operator');
|
|
160
|
-
const firstApprovalForAllAuthorization = authorizations.find((authorization) => authorization.type === 'ApprovalForAll');
|
|
161
|
-
const firstUpdateManagerAuthorization = authorizations.find((authorization) => authorization.type === 'UpdateManager');
|
|
162
|
-
if (firstOperatorAuthorization?.isApproved ||
|
|
163
|
-
firstApprovalForAllAuthorization?.isApproved ||
|
|
164
|
-
firstUpdateManagerAuthorization?.isApproved) {
|
|
165
|
-
return true;
|
|
166
|
-
}
|
|
167
|
-
return false;
|
|
168
|
-
};
|
|
169
|
-
const hasAccessThroughFirstLevelAuthorities = async (target, ethAddress) => {
|
|
170
|
-
const firstLevelAuthorities = [...target.owners, ...target.operators, ...target.updateOperators]
|
|
171
|
-
.filter((addressSnapshot) => addressSnapshot.address)
|
|
172
|
-
.map((addressSnapshot) => addressSnapshot.address.toLowerCase());
|
|
173
|
-
return firstLevelAuthorities.includes(ethAddress.toLowerCase());
|
|
174
|
-
};
|
|
175
|
-
const isEstateUpdateAuthorized = async (estateId, timestamp, ethAddress) => {
|
|
176
|
-
const estate = await getEstate(estateId.toString(), timestamp);
|
|
177
|
-
if (estate) {
|
|
178
|
-
return ((await hasAccessThroughFirstLevelAuthorities(estate, ethAddress)) ||
|
|
179
|
-
(await hasAccessThroughAuthorizations(estate.owners[0].address, ethAddress, timestamp)));
|
|
180
|
-
}
|
|
181
|
-
throw new Error(`Couldn\'t find the state ${estateId}`);
|
|
182
|
-
};
|
|
183
|
-
const isParcelUpdateAuthorized = async (x, y, timestamp, ethAddress, _externalCalls) => {
|
|
184
|
-
/* You get direct access if you were the:
|
|
185
|
-
* - owner
|
|
186
|
-
* - operator
|
|
187
|
-
* - update operator
|
|
188
|
-
* at that time
|
|
189
|
-
*/
|
|
190
|
-
const parcel = await getParcel(x, y, timestamp);
|
|
191
|
-
if (parcel) {
|
|
192
|
-
const belongsToEstate = parcel.estates != undefined && parcel.estates.length > 0 && parcel.estates[0].estateId != undefined;
|
|
193
|
-
return ((await hasAccessThroughFirstLevelAuthorities(parcel, ethAddress)) ||
|
|
194
|
-
(await hasAccessThroughAuthorizations(parcel.owners[0].address, ethAddress, timestamp)) ||
|
|
195
|
-
(belongsToEstate && (await isEstateUpdateAuthorized(parcel.estates[0].estateId, timestamp, ethAddress))));
|
|
196
|
-
}
|
|
197
|
-
throw new Error(`Parcel(${x},${y},${timestamp}) not found`);
|
|
198
|
-
};
|
|
199
|
-
const checkParcelAccess = async (x, y, timestamp, ethAddress, externalCalls) => {
|
|
200
|
-
try {
|
|
201
|
-
return await retry(() => isParcelUpdateAuthorized(x, y, timestamp, ethAddress, externalCalls), 5, '0.1s');
|
|
202
|
-
}
|
|
203
|
-
catch (error) {
|
|
204
|
-
logger.error(`Error checking parcel access (${x}, ${y}, ${timestamp}, ${ethAddress}).`);
|
|
205
|
-
throw error;
|
|
206
|
-
}
|
|
207
|
-
};
|
|
208
|
-
const SCENE_LOOKBACK_TIME = (0, ms_1.default)('5m');
|
|
209
|
-
const { entity } = deployment;
|
|
210
|
-
const { pointers, timestamp } = entity;
|
|
211
|
-
const ethAddress = externalCalls.ownerAddress(deployment.auditInfo);
|
|
212
|
-
const errors = [];
|
|
213
|
-
const lowerCasePointers = pointers.map((pointer) => pointer.toLowerCase());
|
|
214
|
-
for (const pointer of lowerCasePointers) {
|
|
215
|
-
const pointerParts = pointer.split(',');
|
|
216
|
-
if (pointerParts.length === 2) {
|
|
217
|
-
const x = parseInt(pointerParts[0], 10);
|
|
218
|
-
const y = parseInt(pointerParts[1], 10);
|
|
219
|
-
try {
|
|
220
|
-
// Check that the address has access (we check both the present and the 5 min into the past to avoid synchronization issues in the blockchain)
|
|
221
|
-
const hasAccess = (await checkParcelAccess(x, y, timestamp, ethAddress, externalCalls)) ||
|
|
222
|
-
(await checkParcelAccess(x, y, timestamp - SCENE_LOOKBACK_TIME, ethAddress, externalCalls));
|
|
223
|
-
if (!hasAccess) {
|
|
224
|
-
errors.push(`The provided Eth Address does not have access to the following parcel: (${x},${y})`);
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
catch (e) {
|
|
228
|
-
errors.push(`The provided Eth Address does not have access to the following parcel: (${x},${y}). ${e}`);
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
else {
|
|
232
|
-
errors.push(`Scene pointers should only contain two integers separated by a comma, for example (10,10) or (120,-45). Invalid pointer: ${pointer}`);
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
return (0, types_1.fromErrors)(...errors);
|
|
236
|
-
}
|
|
237
|
-
exports.scenes = scenes;
|
|
238
|
-
/** @internal */
|
|
239
|
-
async function retry(execution, attempts, waitTime = '1s', failedAttemptCallback) {
|
|
240
|
-
while (attempts > 0) {
|
|
241
|
-
try {
|
|
242
|
-
return await execution();
|
|
243
|
-
// ^^^^^ never remove this "await" keyword, otherwise this function won't
|
|
244
|
-
// catch the exception and perform the retries
|
|
245
|
-
}
|
|
246
|
-
catch (error) {
|
|
247
|
-
attempts--;
|
|
248
|
-
if (attempts > 0) {
|
|
249
|
-
if (failedAttemptCallback) {
|
|
250
|
-
failedAttemptCallback(attempts);
|
|
251
|
-
}
|
|
252
|
-
await new Promise((res) => setTimeout(res, (0, ms_1.default)(waitTime)));
|
|
253
|
-
}
|
|
254
|
-
else {
|
|
255
|
-
throw error;
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
throw new Error('Please specify more than one attempt for the retry function');
|
|
260
|
-
}
|
|
261
|
-
//# sourceMappingURL=scenes.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"scenes.js","sourceRoot":"","sources":["../../../src/validations/access-checker/scenes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { ContentValidatorComponents, DeploymentToValidate } from '../../types';
|
|
2
|
-
/**
|
|
3
|
-
* Validate that the pointers are valid, and that the Ethereum address has write access to them
|
|
4
|
-
* @public
|
|
5
|
-
*/
|
|
6
|
-
export declare function stores(components: Pick<ContentValidatorComponents, 'externalCalls' | 'logs' | 'theGraphClient'>, deployment: DeploymentToValidate): Promise<import("../../types").ValidationResponse>;
|
|
7
|
-
//# sourceMappingURL=stores.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"stores.d.ts","sourceRoot":"","sources":["../../../src/validations/access-checker/stores.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,0BAA0B,EAAE,oBAAoB,EAAwB,MAAM,aAAa,CAAA;AAUpG;;;GAGG;AACH,wBAAsB,MAAM,CAC1B,UAAU,EAAE,IAAI,CAAC,0BAA0B,EAAE,eAAe,GAAG,MAAM,GAAG,gBAAgB,CAAC,EACzF,UAAU,EAAE,oBAAoB,qDAsBjC"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.stores = void 0;
|
|
4
|
-
const urn_resolver_1 = require("@dcl/urn-resolver");
|
|
5
|
-
const types_1 = require("../../types");
|
|
6
|
-
const parseUrnNoFail = async (pointer) => {
|
|
7
|
-
try {
|
|
8
|
-
const parsed = await (0, urn_resolver_1.parseUrn)(pointer);
|
|
9
|
-
if (!parsed || parsed?.type !== 'off-chain')
|
|
10
|
-
return undefined;
|
|
11
|
-
return parsed;
|
|
12
|
-
}
|
|
13
|
-
catch { }
|
|
14
|
-
};
|
|
15
|
-
/**
|
|
16
|
-
* Validate that the pointers are valid, and that the Ethereum address has write access to them
|
|
17
|
-
* @public
|
|
18
|
-
*/
|
|
19
|
-
async function stores(components, deployment) {
|
|
20
|
-
const pointers = deployment.entity.pointers;
|
|
21
|
-
const ethAddress = components.externalCalls.ownerAddress(deployment.auditInfo);
|
|
22
|
-
if (pointers.length !== 1)
|
|
23
|
-
return (0, types_1.validationFailed)(`Only one pointer is allowed when you create a Store. Received: ${pointers}`);
|
|
24
|
-
const pointer = pointers[0].toLowerCase();
|
|
25
|
-
const offchainAsset = await parseUrnNoFail(pointer);
|
|
26
|
-
if (!offchainAsset)
|
|
27
|
-
return (0, types_1.validationFailed)(`Store pointers should be a urn, for example (urn:decentraland:off-chain:marketplace-stores:{address}). Invalid pointer: ${pointer}`);
|
|
28
|
-
if (offchainAsset.id !== ethAddress)
|
|
29
|
-
return (0, types_1.validationFailed)(`You can only alter your own store. The pointer address and the signer address are different (address:${offchainAsset.id.toLowerCase()} signer: ${ethAddress.toLowerCase()}).`);
|
|
30
|
-
return types_1.OK;
|
|
31
|
-
}
|
|
32
|
-
exports.stores = stores;
|
|
33
|
-
//# sourceMappingURL=stores.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"stores.js","sourceRoot":"","sources":["../../../src/validations/access-checker/stores.ts"],"names":[],"mappings":";;;AAAA,oDAA2D;AAC3D,uCAAoG;AAEpG,MAAM,cAAc,GAAG,KAAK,EAAE,OAAe,EAAsC,EAAE;IACnF,IAAI;QACF,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAQ,EAAC,OAAO,CAAC,CAAA;QACtC,IAAI,CAAC,MAAM,IAAI,MAAM,EAAE,IAAI,KAAK,WAAW;YAAE,OAAO,SAAS,CAAA;QAC7D,OAAO,MAAM,CAAA;KACd;IAAC,MAAM,GAAE;AACZ,CAAC,CAAA;AAED;;;GAGG;AACI,KAAK,UAAU,MAAM,CAC1B,UAAyF,EACzF,UAAgC;IAEhC,MAAM,QAAQ,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAA;IAC3C,MAAM,UAAU,GAAG,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,CAAA;IAE9E,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;QACvB,OAAO,IAAA,wBAAgB,EAAC,kEAAkE,QAAQ,EAAE,CAAC,CAAA;IAEvG,MAAM,OAAO,GAAW,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;IACjD,MAAM,aAAa,GAAG,MAAM,cAAc,CAAC,OAAO,CAAC,CAAA;IAEnD,IAAI,CAAC,aAAa;QAChB,OAAO,IAAA,wBAAgB,EACrB,2HAA2H,OAAO,EAAE,CACrI,CAAA;IAEH,IAAI,aAAa,CAAC,EAAE,KAAK,UAAU;QACjC,OAAO,IAAA,wBAAgB,EACrB,wGAAwG,aAAa,CAAC,EAAE,CAAC,WAAW,EAAE,YAAY,UAAU,CAAC,WAAW,EAAE,IAAI,CAC/K,CAAA;IAEH,OAAO,UAAE,CAAA;AACX,CAAC;AAxBD,wBAwBC"}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { ContentValidatorComponents, DeploymentToValidate } from '../../types';
|
|
2
|
-
export declare function wearables(components: Pick<ContentValidatorComponents, 'externalCalls' | 'logs' | 'theGraphClient'>, deployment: DeploymentToValidate): Promise<import("../../types").ValidationResponse>;
|
|
3
|
-
//# sourceMappingURL=wearables.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"wearables.d.ts","sourceRoot":"","sources":["../../../src/validations/access-checker/wearables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAG9E,wBAAsB,SAAS,CAC7B,UAAU,EAAE,IAAI,CAAC,0BAA0B,EAAE,eAAe,GAAG,MAAM,GAAG,gBAAgB,CAAC,EACzF,UAAU,EAAE,oBAAoB,qDAQjC"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.wearables = void 0;
|
|
4
|
-
const items_1 = require("./items/items");
|
|
5
|
-
async function wearables(components, deployment) {
|
|
6
|
-
return (0, items_1.itemsValidation)(components, deployment, [
|
|
7
|
-
'off-chain',
|
|
8
|
-
'blockchain-collection-v1-asset',
|
|
9
|
-
'blockchain-collection-v2-asset',
|
|
10
|
-
'blockchain-collection-third-party'
|
|
11
|
-
]);
|
|
12
|
-
}
|
|
13
|
-
exports.wearables = wearables;
|
|
14
|
-
//# sourceMappingURL=wearables.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"wearables.js","sourceRoot":"","sources":["../../../src/validations/access-checker/wearables.ts"],"names":[],"mappings":";;;AACA,yCAA+C;AAExC,KAAK,UAAU,SAAS,CAC7B,UAAyF,EACzF,UAAgC;IAEhC,OAAO,IAAA,uBAAe,EAAC,UAAU,EAAE,UAAU,EAAE;QAC7C,WAAW;QACX,gCAAgC;QAChC,gCAAgC;QAChC,mCAAmC;KACpC,CAAC,CAAA;AACJ,CAAC;AAVD,8BAUC"}
|
|
File without changes
|