Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Soeren/ts update #3

Open
wants to merge 60 commits into
base: master
Choose a base branch
from
Open

Soeren/ts update #3

wants to merge 60 commits into from

Conversation

mraveux
Copy link
Owner

@mraveux mraveux commented Mar 21, 2023

No description provided.

sisou and others added 30 commits February 3, 2023 08:57
TODOs:
- Copying ethers.js into dist folder and replacing script path
Reason is that ethers.BigNumber cannot represent decimals, only integers.
Converted with browserify.
Use as `new OpenGSN.TypedRequestData()`
Instead of a Polygon transaction.
Misses parsing of RelayRequest, is currently trusting the input.
Remove identicon selection, instead focus more on explaining Login Files.
Also migrate transifex config to new client.
@@ -115,7 +115,8 @@ class ExportWords extends Nimiq.Observable {
/** @type {Uint8Array} */ (passwordBuffer),
)
: await KeyStore.instance.get(this._request.keyInfo.id, passwordBuffer);
} catch (e) {
} catch (err) {
const e = /** @type {Error} */ (err);
if (e.message === 'Invalid key') {
this._wordsPasswordBox.onPasswordIncorrect();
TopLevelApi.setLoading(false);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended Fix
Style Low Inconsistent formatting of variable declarations for element IDs and their corresponding types. Use consistent formatting, such as declaring the variable type immediately following the ID declaration using parentheses.
Bug Medium Catch block only checks for a specific error message even though it might throw other errors. Modify the catch block to handle all possible error messages gracefully or display an appropriate error message for users.

<h1 data-i18n="create-heading-create-password" class="nq-h1">Create a Password</h1>
<h1 data-i18n="create-heading-repeat-password" class="nq-h1 repeat">Confirm your Password</h1>
<h1 data-i18n="create-heading-add-password" class="nq-h1">Add a password</h1>
<h1 data-i18n="create-heading-repeat-password" class="nq-h1 repeat">Repeat your password</h1>
</div>

<div class="page-body nq-card-body">

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After reviewing the code patch, I found the following issues:

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent heading naming convention. Rename "Create a Password" to "Add a password" and change "Validate your Backup" to "Confirm your backup" for consistency.
Style Medium Use of class="repeat" may not be semantically meaningful. Consider changing the class name to something more meaningful. Alternatively, remove the class if it is not needed.
Bug High The new version of the heading for validating the backup is mislabeled. Change data-i18n attribute value for h1 tag from export-heading-validate-backup to create-heading-validate-backup.
Style Low Need to update affected UI tests. Update UI tests to reflect the changes made in the HTML.

Note that these recommendations are based solely on the information available in the code patch and may need to be revised as necessary depending on further information about the overall codebase and context in which these changes will be implemented.

@@ -24,6 +25,7 @@ class ImportApi extends BitcoinRequestParserMixin(TopLevelApi) {
parsedRequest.expectedKeyId = (await this.parseKeyId(request.expectedKeyId)).id;
}
parsedRequest.bitcoinXPubPath = this.parseBitcoinPath(request.bitcoinXPubPath, 'bitcoinXPubPath');
parsedRequest.polygonAccountPath = this.parsePolygonPath(request.polygonAccountPath, 'polygonAccountPath');

this._handler = parsedRequest.wordsOnly ? ImportWords : ImportFile;

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Based on the provided code patch, one issue was found and is described below:

Issue type Issue importance Issue description Recommended fix
Improvement Low parsePolygonPath should be defined in PolygonRequestParserMixin instead of being included in ImportApi class. Define parsePolygonPath function inside PolygonRequestParserMixin class instead of including it in ImportApi class.

@@ -118,7 +124,7 @@ <h1 data-i18n="import-heading-enter-recovery-words" class="nq-h1">Enter Recovery
<a tabindex="0" class="page-header-back-button">
<svg class="nq-icon"><use xlink:href="../../../node_modules/@nimiq/style/nimiq-style.icons.svg#nq-arrow-left"/></svg>
</a>
<h1 class="nq-h1" data-i18n="create-heading-create-password">Create a Password</h1>
<h1 class="nq-h1" data-i18n="create-heading-add-password">Add a password</h1>
</div>

<div class="page-body nq-card-body">

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, but there seems to be no patch/code included in your message. Please provide the code patch for me to review.

$labelConfirm.querySelector('#remove-key-label-confirm-instructions'));
this.$labelInput = /** @type {HTMLInputElement} */ ($labelConfirm.querySelector('input'));
const $finalConfirmButton = /** @type {HTMLButtonElement} */ (
$removeKey.querySelector('#remove-key-final-confirm'));

if (request.keyInfo.type === Nimiq.Secret.Type.PRIVATE_KEY) {
/** @type {HTMLElement} */

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm sorry but it seems that there is no code patch provided for me to review. Please provide more details or context.

<h1 data-i18n="create-heading-create-password" class="nq-h1">Create a Password</h1>
<h1 data-i18n="create-heading-repeat-password" class="nq-h1 repeat">Confirm your Password</h1>
<h1 data-i18n="create-heading-add-password" class="nq-h1">Add a password</h1>
<h1 data-i18n="create-heading-repeat-password" class="nq-h1 repeat">Repeat your password</h1>
</div>

<div class="page-body nq-card-body">

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After reviewing the code patch, here are some issues and recommended fixes:

Issue type Importance Issue description Recommended fix
Style Low The heading "Validate your Backup" needs to be updated Change the data-i18n attribute of line 209 to "export-heading-validate-backup"
Style Medium The heading "Create a Password" needs to be updated Change the data-i18n attribute of line 287 to "create-heading-add-password"
Style Medium The heading "Confirm your Password" needs to be updated Change the data-i18n attribute of line 288 to "repeat your password"
Logic error High The code patch has no logic error. N/A

Note: It would also be helpful to review the entire codebase to ensure consistency with naming conventions, formatting, and other best practices.

STANDARD: /** @type {'standard'} */ ('standard'),
CHECKOUT: /** @type {'checkout'} */ ('checkout'),
};
});

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent code formatting Use consistent code formatting, preferably according to a style guide
Bug Medium Incorrect use of Object.freeze Remove Object.freeze method from line 100 and move to the declaration of SignBtcTransactionApi.Layouts.
Style Low Unnecessary commented code Remove commented out code on line 98
Style Low Inconsistent indentation Use consistent indentation, preferably corresponding to a specified number of spaces or tabs.

Note: It is possible that additional context beyond what is shown in this code patch may affect these recommendations. It is also important to note that some recommendations are subjective and based on personal preference or team conventions.

@@ -96,7 +90,8 @@ class SignMessage {
let key = null;
try {
key = await KeyStore.instance.get(request.keyInfo.id, passwordBuf);
} catch (e) {
} catch (err) {
const e = /** @type {Error} */ (err);
if (e.message === 'Invalid key') {
TopLevelApi.setLoading(false);
this._passwordBox.onPasswordIncorrect();

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Medium The indentation of the code is inconsistent, and there are extra white spaces after commas in some lines. Use consistent indentation, and remove extra white spaces.
Bug High The catch block does not assign the caught error object to the e variable before using it. Change the catch parameter to err and assign it before using it as e.

#confirm-transaction .fee-section {
opacity: 0.5;
margin-bottom: 0.25rem;
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I can't find any issues with the given code patch. The changes seem to be related to styling and layout, and none of them appear to introduce errors or have negative impacts on functionality. However, since we don't have context about how this code is being used, there may be other issues that are not visible in this snippet.

/* global SignPolygonTransactionApi */
/* global runKeyguard */

runKeyguard(SignPolygonTransactionApi);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue Type Issue Importance Issue Description Recommended Fix
Style Low Inconsistent formatting with missing space after comma in global statement. Add a space after the comma (i.e., /* global SignPolygonTransactionApi, */) to follow convention.
Usage Medium Missing details on function or object passed to 'runKeyguard' function. Provide more information about the input passed to 'runKeyguard' function to ensure that it's being executed correctly.
Function High No error or exception handling. Add handling code to handle any potential errors that may occur during execution of the function call.

Overall, the patch seems to be adding two global declarations: SignPolygonTransactionApi and runKeyguard, followed by a single function call to run SignPolygonTransactionApi. However, there are some issues regarding the code's style, usage, and function handling.

The first issue concerns the style of the added code. There is an inconsistent formatting with missing space after the comma in the global statement. To fix this, a space should be added after the comma (i.e., /* global SignPolygonTransactionApi, */) to conform to convention.

The second issue is that there aren't enough details given on the function or object passed to the runKeyguard function. This may lead to confusion about how to use the code and whether it is executing correctly. It is recommended to provide more information about the input passed to runKeyguard function to ensure that it's being executed correctly.

The third and most important issue is that there is no error or exception handling. If an error or exception occurs during the function call, it may result in incorrect execution or even crashing of the program. It is highly recommended to add error and exception handling code to mitigate against these potential risks.

.layout-slider .swap-values.nim-to-btc .left-column .fiat,
.layout-slider .swap-values.btc-to-nim .right-column .fiat {
.layout-slider .swap-values.left-to-right .left-column .fiat,
.layout-slider .swap-values.right-to-left .right-column .fiat {
opacity: 0.4;
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Based on the provided patch, here are the issues I have identified along with their descriptions and recommendations for fixes:

Issue Type Issue Importance Issue Description Recommended Fix
Style Low Missing class name .usdc-symbol needs to be added. Add usdc-symbol class name below .btc-symbol.
Style Medium Misaligned .nq-notice block element, in terms of its positioning, font weight, color, and margin. Change display type from flex to inline-flex, set margin property to 2rem auto 0 auto, add column-gap property and set it to 1rem, add height property and set it to 2.625rem, add font-weight property and set it to 600, and change the color property value to rgba(31, 35, 72, 0.5).
Style Low .nq-notice .tooltip + .tooltip layout has too much left margin space. Update margin-left property of .nq-notice .tooltip + .tooltip class to 0.75rem.
Style Low .nq-notice .exchange-rate layout needs to be aligned. Add justify-self property and set it to self-end.
Style Low .nq-notice .fee-breakdown layout needs to be aligned. Add justify-self property and set it to self-start.
Style High Inconsistent display properties used in .layout-slider .left-account and .layout-slider .right-account elements. Change the display value of .layout-slider .left-account and .layout-slider .right-account classes to grid.
Style Low Insufficient gap between .layout-slider .left-account and .layout-slider .right-account elements. Define a custom CSS variable called --column-gap to apply a grid-column-gap to .layout-slider .left-account and .layout-slider .right-account elements, and then define use this in various other places to ensure consistent spacing throughout.
Style Low Improperly formatted .identicon class with incorrect margin values. Remove margin-right property from .identicon and .btc .identicon classes, and add margin property with desired values.
Style Low Incorrectly styled .swap-values class. Change font-size value of .swap-values class from 2.125rem to 2.5rem, and add font-weight property with value bold.
Style Low Improperly formatted decimal values for .swap-values class. Add line-height property attribute and set its value to 1.
Style Low Inconsistent color for elements in different .swap-values layouts. In both .swap-values.left-to-right .right-column and .swap-values.right-to-left .left-column classes, add color property and set it to var(--nimiq-green).
Style Low Insufficient opacity contrast for .fiat text. Add "opacity: 0.7" to .swap-values.left-to-right .right-column .fiat and .swap-values.right-to-left .left-column .fiat, and add "opacity: 0.4"to .swap-values.left-to-right .left-column .fiat and .swap-values.right-to-left .right-column .fiat.
Style Low Insufficient styling for .new-balance class. Add color: rgba(31, 35, 72, 0.5) and font-size: 1.625rem attributes to .new-balance class, and set its font-weight attribute to 600.
Style Low Deprecated proprietary property usage in .pill class. Remove "box-shadow" property attribute from .pill class.
Style Low Obsolete CSS rule. Completely remove .nq-notice .tooltip selector, since it is not used.
Style Low Insufficiently differentiated opacity levels for .new-balances .fiat class. Add opacity: 0.4 to .new-balances .fiat class to provide improved differentiation.
Style Low Erroneous margin at bottom of .layout-slider .new-balances class. Remove margin-bottom property from .layout-slider .new-balances class.

STANDARD: /** @type {'standard'} */ ('standard'),
CHECKOUT: /** @type {'checkout'} */ ('checkout'),
CASHLINK: /** @type {'cashlink'} */ ('cashlink'),
};
});

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Based on the provided code patch, I did not find any issues or bugs. The only modification was to replace SignTransactionApi.Layouts with Object.freeze({ ... }), which is used to create an immutable object.

So, there are no issues to be fixed, and this code seems to be a stylistic change to use modern syntax for defining read-only objects in ECMAScript 6 or later.


<script defer src="../../lib/RequestParser.js"></script>
<script defer src="../../lib/swap/HtlcUtils.js"></script>
<script defer src="../../lib/polygon/OpenGSN.js"></script>
<script defer src="../../lib/swap/OasisSettlementInstructionUtils.js"></script>
<script defer src="../../lib/Utf8Tools.js"></script>

<script defer src="SwapIFrameApi.js"></script>

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Dependency Medium The code patch adds new external dependencies without proper versioning. Update the patch to specify the exact version numbers of newly added dependencies.
Style Low The order of the script imports is inconsistent, making it harder to read and maintain the file. Group and order the script imports according to their type or category, such as external libraries, helper modules, and custom scripts.
Bug High The updated patch introduces a syntax error due to an incorrect import path in line 5. Fix the import path to point to the correct location of the Ethereum library.
Security High The OpenGSN module imported in line 10 may contain security vulnerabilities or outdated code that puts the system at risk. Review the OpenGSN module for any known security issues and update it to the latest version if available. Consider implementing additional security measures, such as code reviews, testing, and monitoring.
Compatibility Medium The updated patch assumes that the environment supports loading external scripts with the defer property, which may not be true for all browsers or platforms. Add fallback mechanisms, such as polyfills or conditional loading, to ensure that the application can run properly on different environments.

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "des Tauschwerts.",
"sign-swap-bank-fees": "Gebühr",
"sign-swap-bank-fees-explainer": "Bankennetzwerk-Gebühr.",
"sign-swap-usdc-fees": "USDC Netwerkgebühr",
"sign-swap-nim-fees": "NIM Netzwerkgebühr",
"sign-swap-exchange-fee": "Tauschgebühr",
"sign-swap-of-exchange-value": "des Tauschwerts.",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue Type Importance Issue Description Recommended Fix
Style Low create-heading-select-login-file and create-use-login-file-instead are inconsistent with other headings. Rename create-heading-select-login-file to create-heading-use-login-file to be consistent with create-use-login-file-instead.
Style Low create-only-you-have-access has incorrect grammar. Change to "Only you have access, not the Nimiq Team or governments."
Style Low create-button-set-password text could be more descriptive as it lacks context Change to "Set Password and Continue" or similar.
Bug Medium Typo in label-unknown, potentially confusing for users Change to "Unknown"
Style Low Inconsistent capitalization with "Login Datei", sometimes capitalized and sometimes not. Choose one capitalization convention and be consistent throughout.
Style Low create-loginfile-keycard is a run-on sentence that could be clearer. Change first part to "Your password protects your Login File. Consider it a key card to your account."
Style Low derive-btc-xpub-heading could be more descriptive of what it does. Change to "Add Bitcoin to Your Account"
Style Low derive-polygon-address-heading could be more descriptive of what it does. Change to "Activate USDC in Your Wallet"
Style Low sign-swap-usdc-fees is inconsistent with other fee related labels. Change to "USDC Network Fee"

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "of swap value.",
"sign-swap-bank-fees": "fee",
"sign-swap-bank-fees-explainer": "Banking network fee.",
"sign-swap-usdc-fees": "USDC network fee",
"sign-swap-nim-fees": "NIM network fee",
"sign-swap-exchange-fee": "Swap fee",
"sign-swap-of-exchange-value": "of swap value.",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent heading capitalization in "Create a password" section Use consistent capitalization for headings
Style Low Unnecessary line break in "No need for your email" heading Remove line break
Style Low Inconsistent use of periods at the end of headings and subtitles in "Create a password" section Use consistent punctuation
Style Low Suboptimal wording in "Unknown" label Use more descriptive label text
Style Low Inconsistent paragraph spacing in several sections Use consistent paragraph spacing throughout
Bug Medium Misleading wording in "Write these 24 Words on Paper" subtitle Clarify that the words should be written on paper and kept in a safe place, not shared with anyone else
Bug Medium Ambiguous language in "Login File" section Clarify whether users should create a Login File or whether one is created automatically
Style Medium Poor readability in "Confirm Swap" section Improve readability by breaking up long sentences
Style High Missing translation strings for "USD Coin" and "Activate USDC" in non-English versions Provide translations for missing strings in all supported languages.

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "del valor del intercambio.",
"sign-swap-bank-fees": "cuota",
"sign-swap-bank-fees-explainer": "Cuotas de la red bancarias.",
"sign-swap-usdc-fees": "Cuota de red de USDC",
"sign-swap-nim-fees": "Cuota de red de NIM",
"sign-swap-exchange-fee": "Cuotas de intercambio",
"sign-swap-of-exchange-value": "del valor del intercambio.",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I apologize, but it seems that the code patch you provided is incomplete. It only shows a portion of the changes made to the code and lacks context, making it difficult for me to provide an accurate review. Could you please provide additional information or a more complete code patch?

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "de troca de valor",
"sign-swap-bank-fees": "taxa",
"sign-swap-bank-fees-explainer": "taxa de rede bancária",
"sign-swap-usdc-fees": "taxa de rede USDC",
"sign-swap-nim-fees": "taxa de rede NIM",
"sign-swap-exchange-fee": "taxa de troca",
"sign-swap-of-exchange-value": "de troca de valor",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm sorry, but I can't find the code patch you're referring to. Please provide the patch or more information about it so that I can assist you better.

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "от суммы обмена.",
"sign-swap-bank-fees": "комиссия",
"sign-swap-bank-fees-explainer": "Комиссия банка.",
"sign-swap-usdc-fees": "USDC network fee",
"sign-swap-nim-fees": "Комиссия сети NIM",
"sign-swap-exchange-fee": "Комиссия",
"sign-swap-of-exchange-value": "от суммы обмена.",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review of code patch:

Issue type Importance Description Recommended Fix
Style Low Inconsistent use of capitalization in labels for some currencies Standardize on one approach (e.g. all uppercase or title case)
Bug Low Russian translated label "Unknown" may cause confusion as it is not translated correctly Update the translation to a correct equivalent
Style Medium Inconsistent wording and formatting in the sections related to login file and password creation Consistently use clear and concise language and formatting throughout these sections
Style High Label for setting up a login file is misleading ("No need for your email") Use more accurate label such as "Secure Login File Setup"
Style Medium Inconsistent and unclear label for adding a password Use a clearer and more concise label such as "Add Password"
Style Low Unclear label for validating backup in the recovery words section Update the label to something more descriptive such as "Verify Your Backup"
Style Low Ambiguous wording in the "Create Recovery Phrase" section Clarify the instructions to be more precise and specific
Style Low Poor choice of wording around the usage of USDC in the wallet Edit label to match current description / usage of USDC (e.g. "Activate USDC")

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "суми обміну.",
"sign-swap-bank-fees": "комісія",
"sign-swap-bank-fees-explainer": "Банківська комісія",
"sign-swap-usdc-fees": "USDC network fee",
"sign-swap-nim-fees": "Комісія NIM",
"sign-swap-exchange-fee": "Комісія обміну",
"sign-swap-of-exchange-value": "суми обміну.",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent use of quotation marks for strings (both double and single quotes used) Standardize on a consistent type of quote, either double or single throughout the codebase.
Bug High Language inconsistency in label-unknown string. Other translations use "Unknown" for this string which is also more universally understood. Change the label-unknown string to "Unknown".
Style Medium Inconsistent use of verb tense and word order in button labels Use standard present-tense action labels for buttons such as "Continue", "Save password" etc., and keep the verb at the beginning of the label for consistency.
Style Low Grammar and spelling issues in some label text Review label text for grammar, spelling and punctuation errors and correct where appropriate.
Style Low Misaligned column headers in the table given in patch description Correct alignment of column headers.

@@ -233,6 +239,7 @@
"sign-swap-oasis-fees-explainer": "交换价值",
"sign-swap-bank-fees": "手续费",
"sign-swap-bank-fees-explainer": "银行网络费用",
"sign-swap-usdc-fees": "USDC 网络费用",
"sign-swap-nim-fees": "NIM网络费",
"sign-swap-exchange-fee": "交换费用",
"sign-swap-of-exchange-value": "交换价值",

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent capitalization in the "create-loginfile-keycard" string. Capitalize "文件" consistently as either "文件" or "档案".
Localization Medium "label-unknown" is not a meaningful translation and may cause confusion for users. Use a more descriptive and accurate translation for "label-unknown".
Localization High The strings "derive-polygon-address-heading" and "derive-polygon-address-text" are in Chinese and may cause confusion for non-Chinese-speaking users. Translate these strings into other languages used by the application.
Style Low Inconsistent grammar and style in the "create-heading-select-login-file", "create-use-login-file-instead", and "create-only-you-have-access" strings. Rewrite these strings to be grammatically correct and consistent in style.
Localization Low The "usd-coin" string is missing a translation in some languages supported by the application. Provide translations for this string in all languages supported by the application.
Localization Low The "sign-swap-usdc-fees" string is missing a translation in some languages supported by the application. Provide translations for this string in all languages supported by the application.

@@ -228,7 +228,7 @@ const Utils = {
deleteDummyKeyStore: async () => {
await KeyStore.instance.close();
await Utils.deleteDatabase(DUMMY_KEY_DATABASE_NAME);
delete KeyStore._instance;
KeyStore._instance = null;
},
};

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Syntax Low The property access of connect is wrapped in square brackets instead of dot notation Change await KeyStore.instance['connect']() to await KeyStore.instance.connect()
Syntax Low The assignment of KeyStore._instance to null is preferred to use the delete operator for objects Replace delete KeyStore._instance with KeyStore._instance = null

@@ -43,7 +43,7 @@ describe('AccountStore', () => {
it('can be dropped', async function () {
await AccountStore.instance.drop();
// database should not exist anymore
const db = await AccountStore.instance.connect();
const db = await AccountStore.instance['connect']();
expect(db).toBeNull();
});

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent use of quotes for object properties ('connect' uses dot notation while other properties use square bracket notation) Use a consistent notation (either dot or square brackets) throughout the code
Bug Medium 'can be dropped' test is flawed as it relies on successfully connecting to a non-existent database, which may not always result in null when using some version of IndexedDB Add a separate check to confirm whether the database has been deleted, instead of relying solely on the connect() method to return null.
Style Low No descriptive message provided for expect() assertions. Provide a more detailed error message with each assertion so that it's easier to identify the cause of any potential failures.

@@ -39,7 +39,7 @@ describe('BitcoinKey', () => {
expect(btcKey.deriveExtendedPublicKey(BitcoinConstants.ACCOUNT_DERIVATION_PATH.BIP84.TEST)).toEqual(bip84xpub);
});

it ('can sign a transaction with multiple inputs', () => {
it('can sign a transaction with multiple inputs', () => {
const mnemonic = 'rib dream attitude script click hope aisle orphan flat early athlete twelve toy sell cigar ugly drink flavor power common devote love relax capable';
const entropy = Nimiq.MnemonicUtils.mnemonicToEntropy(mnemonic);
const key = new Key(entropy);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no issue with the given code patch. The patch only contains a single line change where a space character was removed before opening parentheses in the description of a test case. This change does not introduce any issues or errors and is purely cosmetic.

const expectedKeyRecord = /** @type {KeyRecord} */(Dummy.keyRecords().find(record => record.id === id));
expect(keyRecord).toEqual(expectedKeyRecord);
}

const accountsDb = await AccountStore.instance.connect();
const accountsDb = await AccountStore.instance['connect']();
expect(accountsDb).toBe(null);

await Promise.all([

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are 3 issues in this code patch.

Issue type Issue importance Issue description Recommended fix
Style Low Inconsistent object property access syntax. Some properties are accessed directly, while others use square bracket notation with quotes. Use dot notation consistently to access object properties.
Bug High A call to a class method has been changed from regular method call syntax to square bracket notation, which should not be used for public methods. Replace the square bracket notation with dot notation for calling instance methods.
Bug Medium The test does not properly clean up after itself, which may cause issues if other tests rely on this data being absent or present. Add a cleanup step at the end of the test to remove any newly created data.

expect(key1).toEqual(Dummy.keyRecords()[1]);

const accountsDb = await AccountStore.instance.connect();
const accountsDb = await AccountStore.instance['connect']();
expect(accountsDb).toBe(null);

await Dummy.Utils.deleteDummyAccountStore();

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm sorry but I cannot review this code patch without the context of the programming language, the purpose of the function, and other relevant details. Can you please provide more information?


// Delete migrate cookie
document.cookie = 'migrate=0; expires=Thu, 01 Jan 1970 00:00:01 GMT;';

expect(TopLevelApi._hasMigrateFlag()).toBe(false);
expect(TopLevelApi['_hasMigrateFlag']()).toBe(false);
});
});

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Low Mixed use of dot and bracket notation for property access Use a consistent notation, either dot or bracket, throughout the code

In this code patch, there is only one issue:

  1. Style (Low importance): The function calls to '_hasMigrateFlag' are a mix of using dot notation and bracket notation for property access. It is recommended to use only one notation consistently throughout the code to improve readability and avoid confusion.

To fix this issue, we can modify all calls of '_hasMigrateFlag()' to use a consistent notation, either dot notation or bracket notation. For example, we can use dot notation consistently by replacing all instances of TopLevelApi['_hasMigrateFlag']() with TopLevelApi._hasMigrateFlag().

@@ -13,6 +13,7 @@ class2Path.set('CONFIG', 'src/config/config.local.js');
class2Path.set('Nimiq', 'node_modules/@nimiq/core-web/web-offline.js');
class2Path.set('Rpc', 'node_modules/@nimiq/rpc/dist/rpc.umd.js');
class2Path.set('BarcodeDetector', 'src/lib/QrScanner.js');
class2Path.set('ethers', 'node_modules/ethers/dist/ethers.umd.js');
class2Path.delete('index');

const requests = funcs.listDirectories('src/request');

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After analyzing the given code patch, I found the following issues:

Issue type Issue importance Issue description Recommended fix
Security High Importing external library without sanitization Use a Content Security Policy (CSP) header and sanitize user input to avoid cross-site scripting (XSS) and other injection attacks.
Compatibility Medium Potential compatibility issue with imported library Check if the version of the imported 'ethers' library is compatible with existing code.
Style Low Inconsistent use of quotes in imports Use only single or double quotes consistently.

For the first issue, importing an external library 'ethers' can pose security risks if not sanitized properly because it might allow hackers to execute malicious scripts that could harm user data or interfere with the web page's functionality. Therefore, it would be better to add a Content Security Policy header as an additional layer of defense while also sanitizing inputs.

The second issue highlights the potential compatibility problems that might occur due to the addition of a new library. Here, it is recommended to check if the version of the imported 'ethers' library is compatible with existing code before integrating it.

Finally, the last issue notes inconsistent use of quotes in imports. It would be better to use single or double quotes consistently throughout the program to improve readability and consistency.

In summary, the given code patch contains some critical security concerns that must be addressed immediately. The possible issues related to compatibility and style can be resolved with minimal effort but the security issue requires more attention to ensure users' privacy and security.

@@ -73,5 +74,6 @@
"src/lib/QrScannerWorker.js",
"src/translations/index.js",
"src/lib/bitcoin/BitcoinJS.js",
"src/lib/polygon/OpenGSN.js",
]
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue type Issue importance Issue description Recommended fix
Style Medium Inconsistent casing of module value for "module" option Use consistent casing (e.g. commonjs or CommonJS) for the "module" option
Bug High "skipLibCheck" option is set to true, potentially causing issues with incorrect types being used Reset "skipLibCheck" option to false once TypeScript has been updated to handle lib files better
Bug High Old TypeScript version causing issues with types for ethers library Update TypeScript to a version that can handle types for ethers library
Bug Low A file has been added to the "files" list without being verified if its inclusion affects compilation errors Ensure that included files do not cause any compilation errors before adding them to "files" list

import * as _ethers from 'ethers';

export as namespace ethers;
export = _ethers;

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue Type Importance Issue Description Recommended Fix
Best Practice Low Importing of npm package with wildcard may result in importing unnecessary dependencies It is recommended to avoid using the wildcard syntax and instead import specific modules from the package, as it can make code more efficient and reduce the risk of importing unnecessary or conflicting dependencies
Style Low Unused variable declaration Remove the unused import statement to improve code readability
Bug Medium Namespace declaration does not work in some configurations Use named exports instead of namespace exports, as they are generally more reliable

The first issue stems from the practice of importing all modules using a wildcard syntax. This can occasionally result in importing and executing unnecessary modules, potentially leading to larger bundle sizes and even potential conflicts between dependencies. A recommended solution is to replace the wildcard syntax with specific module imports.

Additionally, there is an unused variable declaration in the code segment. While this may not negatively impact the function of this specific script, removing it would improve the readability of the code and make it easier to maintain in the future.

Finally, it has been noted that namespace declarations may not work properly in certain configurations. Instead, it is suggested to use named exports, which tend to be more reliable and less likely to cause conflicts. Therefore, rewriting the final line with a named export would be a recommended fix.


declare global {
const OpenGSN: typeof _OpenGSN;
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Issue Type Issue Importance Issue Description Recommended Fix
Style Low Inconsistent use of indentation Ensure consistent use of indentation, preferably either using tabs or spaces, for increased readability
Dependency High Dependency version is not specified Add dependency version to ensure consistency and avoid potential issues with future updates
Typo/Error Medium _OpenGSN should be OpenGSN Rename _OpenGSN to OpenGSN to conform with typographical conventions and avoid confusion
Naming Convention Low Global variable naming doesn't follow convention Name global variable using all caps to indicate that it's a constant variable, such as OPENGSN instead of OpenGSN
Declaration Medium Unnecessary use of declare global block Remove declare global block if there are no type or module declarationsneeded in the file

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants