diff --git a/.gitignore b/.gitignore
index 267e82ff..522238a6 100644
--- a/.gitignore
+++ b/.gitignore
@@ -5,4 +5,5 @@ docs/html
.vscode/*
.nyc_output
coverage
-*.tgz
\ No newline at end of file
+*.tgz
+.DS_Store
diff --git a/.node-version b/.node-version
index e81c0260..436d5c5d 100644
--- a/.node-version
+++ b/.node-version
@@ -1 +1 @@
-14.17.0
\ No newline at end of file
+18.19.0
\ No newline at end of file
diff --git a/src/index.ts b/src/index.ts
index d797aa50..348173d8 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -74,7 +74,12 @@ export {
};
export { ERC725Config, KeyValuePair, ProviderTypes } from './types';
-export { encodeData } from './lib/utils';
+export { encodeData, encodeArrayKey } from './lib/utils';
+export { decodeData } from './lib/decodeData';
+export { encodeKeyName } from './lib/encodeKeyName';
+export { decodeMappingKey } from './lib/decodeMappingKey';
+export { decodeValueType, decodeValueContent } from './lib/encoder';
+export { getDataFromExternalSources } from './lib/getDataFromExternalSources';
/**
* This package is currently in early stages of development,
use only for testing or experimentation purposes.
diff --git a/src/lib/getDataFromExternalSources.ts b/src/lib/getDataFromExternalSources.ts
index 809d58c6..49fb121b 100644
--- a/src/lib/getDataFromExternalSources.ts
+++ b/src/lib/getDataFromExternalSources.ts
@@ -101,25 +101,40 @@ export const getDataFromExternalSources = (
// - check whether those could represent valid JSON data.
// - then validate the data as JSON
// - then verfiy the data against the verification method
- const key = String.fromCharCode(
- receivedData[0],
- receivedData[receivedData.length - 1],
- );
+
+ // Improved JSON detection. We now check the first and up to the last 3 bytes.
+ // The 3 bytes can be `]` or '}' with either SPACE, LF or CRLF at the end.
+ // When editing JSON using a text editor, a lot of time it's pretty printed
+ // and an empty line added to the end. This is a common pattern.
+ const capture: number[] = [];
+ capture.push(receivedData[0]);
+ if (receivedData.length > 3) {
+ capture.push(receivedData[receivedData.length - 3]);
+ }
+ if (receivedData.length > 2) {
+ capture.push(receivedData[receivedData.length - 2]);
+ }
+ if (receivedData.length > 1) {
+ capture.push(receivedData[receivedData.length - 1]);
+ }
+ const key = String.fromCharCode.apply(null, capture);
// Currently not supported even though they could be added and can represent valid JSON.
// " " => JSON.stringify("") NOT SUPPORTED as valid JSON
// t or f and e => JSON.stringify(true) or JSON.stringify(false) NOT SUPPORTED as valid JSON
// 0-9 => JSON.stringify(0) integer or float (note .5 is not legitimate JSON) NOT SUPPORTED as valid JSON
// if (/^(\[\]|\{\}|(tf)e|\d\d)$/.test(key)) {
-
// Check if the beginning or end are
// { and } => JSON.stringify({...}) => pretty much 100% of our JSON will be this.
// [ and ] => JSON.stringify([...])
- if (/^(\[\]|\{\})$/.test(key)) {
+ if (/^(\[.*\]|\{.*\})\s*$/.test(key)) {
const json = arrToBufArr(receivedData).toString();
const value = JSON.parse(json);
if (isDataAuthentic(value, urlDataWithHash.verification)) {
return { ...dataEntry, value };
}
+ if (isDataAuthentic(receivedData, urlDataWithHash.verification)) {
+ return { ...dataEntry, value };
+ }
throw new Error('result did not correctly validate');
}
} catch {