fix: lightning node transaction list bug in Nostr clients
Description
Please enter a description and screenshots, if appropriate, of the work covered in this PR
This pull request is categorized as a:
- [ ] New feature
- [x] Bug fix
- [ ] Code refactor
- [ ] Configuration change
- [ ] Locales update
- [ ] Quality assurance
- [ ] Other
Checklist
- [ ] I’ve run
yarn run tscand made sure my code compiles correctly - [ ] I’ve run
yarn run lintand made sure my code didn’t contain any problematic patterns - [ ] I’ve run
yarn run prettierand made sure my code is formatted correctly - [ ] I’ve run
yarn run testand made sure all of the tests pass
Testing
If you modified or added a utility file, did you add new unit tests?
- [ ] No, I’m a fool
- [ ] Yes
- [ ] N/A
I have tested this PR on the following platforms (please specify OS version and phone model/VM):
- [ ] Android
- [ ] iOS
I have tested this PR with the following types of nodes (please specify node version and API version where appropriate):
- [ ] Embedded LND
- [ ] LND (REST)
- [ ] LND (Lightning Node Connect)
- [ ] Core Lightning (CLNRest)
- [ ] Nostr Wallet Connect
- [ ] LndHub
Locales
- [ ] I’ve added new locale text that requires translations
- [ ] I’m aware that new translations should be made on the ZEUS Transfix page and not directly to this repo
Third Party Dependencies and Packages
- [ ] Contributors will need to run
yarnafter this PR is merged in - [ ] 3rd party dependencies have been modified:
- verify that
package.jsonandyarn.lockhave been properly updated - verify that dependencies are installed for both iOS and Android platforms
- verify that
Other:
- [ ] Changes were made that require an update to the README
- [ ] Changes were made that require an update to onboarding
Summary of Changes
Hello @ajaysehwal, I'm Gemini Code Assist[^1]! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!
This pull request addresses a bug related to how Lightning node transaction lists are handled and displayed within Nostr clients. The core of the fix involves refactoring the NostrWalletConnectStore to utilize a dedicated Payment data model and integrate with a PaymentsStore, moving away from a generic Transaction model. This change ensures that Lightning payment data is fetched and processed more accurately and consistently for Nostr-enabled applications.
Highlights
- Transaction Model Update: The
NostrWalletConnectStorehas been updated to use a more specificPaymentmodel instead of the genericTransactionmodel for handling Lightning node transactions, improving data accuracy. - PaymentsStore Integration: The
PaymentsStorehas been integrated intoNostrWalletConnectStoreto manage and retrieve payment data, replacing the previous dependency onTransactionsStore. - NIP-47 Transaction Mapping: The logic for mapping internal transaction objects to NIP-47 compatible formats has been revised to leverage properties from the new
Paymentmodel, ensuring correct representation for Nostr clients. - Relay Configuration Adjustment: The
wss://relay.snort.socialentry has been temporarily commented out from theDEFAULT_NOSTR_RELAYSlist inNostrWalletConnectStore.ts.
Using Gemini Code Assist
The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.
Invoking Gemini
You can request assistance from Gemini at any point by creating a comment using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands on the current page.
| Feature | Command | Description |
|---|---|---|
| Code Review | /gemini review |
Performs a code review for the current pull request in its current state. |
| Pull Request Summary | /gemini summary |
Provides a summary of the current pull request in its current state. |
| Comment | @gemini-code-assist | Responds in comments when explicitly tagged, both in pull request comments and review comments. |
| Help | /gemini help |
Displays a list of available commands. |
Customization
To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.
Limitations & Feedback
Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with :thumbsup: and :thumbsdown: on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here.
You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension.
[^1]: Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution.
@gemini-code-assist review
@gemini-code-assist review