Skip to content

feat: audit invoice nft contracts with tests and docs#159

Open
mgtmdccix-oss wants to merge 1 commit into
OpenLedger-Foundation:mainfrom
mgtmdccix-oss:feature/issue-audit-invoice-nft-contracts
Open

feat: audit invoice nft contracts with tests and docs#159
mgtmdccix-oss wants to merge 1 commit into
OpenLedger-Foundation:mainfrom
mgtmdccix-oss:feature/issue-audit-invoice-nft-contracts

Conversation

@mgtmdccix-oss
Copy link
Copy Markdown

  • Remove artificial i128::MAX/2 amount cap that rejected valid large amounts
  • Fix missing invoice_funded event emission in set_funded
  • Add missing require_not_paused check to set_repaid for consistency
  • Remove dead code: unused old_status variables in set_funded and set_repaid
  • Add TTL extension (bump_invoice_ttl) on every persistent invoice write to prevent storage expiry per ARCHITECTURE.md guidance
  • Initialize InvoiceCount to 0 explicitly in initialize()
  • Document require_not_paused stub with v1/v2 cross-contract integration notes
  • Remove duplicate test functions (merge artifact)
  • Expand test suite: specific KoraError variant assertions, new edge case tests for due_date == now, defaulted at exact due_date, wrong-status defaulted, large amounts, invoice count tracking, core field immutability, and all four risk tier boundary transitions as individual test cases
    closes Audit Invoice NFT Contracts #102

- Remove artificial i128::MAX/2 amount cap that rejected valid large amounts
- Fix missing invoice_funded event emission in set_funded
- Add missing require_not_paused check to set_repaid for consistency
- Remove dead code: unused old_status variables in set_funded and set_repaid
- Add TTL extension (bump_invoice_ttl) on every persistent invoice write
  to prevent storage expiry per ARCHITECTURE.md guidance
- Initialize InvoiceCount to 0 explicitly in initialize()
- Document require_not_paused stub with v1/v2 cross-contract integration notes
- Remove duplicate test functions (merge artifact)
- Expand test suite: specific KoraError variant assertions, new edge case
  tests for due_date == now, defaulted at exact due_date, wrong-status
  defaulted, large amounts, invoice count tracking, core field immutability,
  and all four risk tier boundary transitions as individual test cases
@drips-wave
Copy link
Copy Markdown

drips-wave Bot commented Jun 1, 2026

@mgtmdccix-oss Great news! 🎉 Based on an automated assessment of this PR, the linked Wave issue(s) no longer count against your application limits.

You can now already apply to more issues while waiting for a review of this PR. Keep up the great work! 🚀

Learn more about application limits

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.

Audit Invoice NFT Contracts

2 participants