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

[WIP] Pluggy.ai bank sync #4049

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

Conversation

lelemm
Copy link
Contributor

@lelemm lelemm commented Dec 27, 2024

Pluggy.ai bank sync for Brazilian banks
Fixes #3995

@actual-github-bot actual-github-bot bot changed the title Pluggy.ai bank sync [WIP] Pluggy.ai bank sync Dec 27, 2024
Copy link

netlify bot commented Dec 27, 2024

Deploy Preview for actualbudget ready!

Name Link
🔨 Latest commit 041f8e5
🔍 Latest deploy log https://app.netlify.com/sites/actualbudget/deploys/6786fe3855d49f000842dc49
😎 Deploy Preview https://deploy-preview-4049.demo.actualbudget.org
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link
Contributor

github-actions bot commented Dec 27, 2024

Bundle Stats — desktop-client

Hey there, this message comes from a GitHub action that helps you and reviewers to understand how these changes affect the size of this project's bundle.

As this PR is updated, I'll keep you updated on how the bundle size is impacted.

Total

Files count Total bundle size % Changed
13 6.02 MB → 6.04 MB (+12.88 kB) +0.21%
Changeset
File Δ Size
src/components/modals/PluggyAiInitialiseModal.tsx 🆕 +5.62 kB 0 B → 5.62 kB
src/components/modals/CreateAccountModal.tsx 📈 +6.13 kB (+38.20%) 16.06 kB → 22.19 kB
src/components/settings/Experimental.tsx 📈 +334 B (+7.85%) 4.16 kB → 4.48 kB
src/hooks/useFeatureFlag.ts 📈 +27 B (+7.56%) 357 B → 384 B
home/runner/work/actual/actual/packages/loot-core/src/client/accounts/accountsSlice.ts 📈 +322 B (+6.14%) 5.12 kB → 5.43 kB
src/components/modals/SelectLinkedAccountsModal.jsx 📈 +311 B (+3.79%) 8.02 kB → 8.32 kB
src/components/Modals.tsx 📈 +165 B (+0.96%) 16.77 kB → 16.93 kB
View detailed bundle breakdown

Added

No assets were added

Removed

No assets were removed

Bigger

Asset File Size % Changed
static/js/index.js 3.78 MB → 3.79 MB (+12.88 kB) +0.33%

Smaller

No assets were smaller

Unchanged

Asset File Size % Changed
static/js/BackgroundImage.js 122.29 kB 0%
static/js/useAccountPreviewTransactions.js 1.63 kB 0%
static/js/workbox-window.prod.es5.js 5.69 kB 0%
static/js/AppliedFilters.js 10.21 kB 0%
static/js/indexeddb-main-thread-worker-e59fee74.js 13.5 kB 0%
static/js/resize-observer.js 18.37 kB 0%
static/js/en-GB.js 96.92 kB 0%
static/js/en.js 96.91 kB 0%
static/js/narrow.js 84.3 kB 0%
static/js/wide.js 106.04 kB 0%
static/js/uk.js 120.47 kB 0%
static/js/ReportRouter.js 1.59 MB 0%

Copy link
Contributor

github-actions bot commented Dec 27, 2024

Bundle Stats — loot-core

Hey there, this message comes from a GitHub action that helps you and reviewers to understand how these changes affect the size of this project's bundle.

As this PR is updated, I'll keep you updated on how the bundle size is impacted.

Total

Files count Total bundle size % Changed
1 1.33 MB → 1.33 MB (+1.75 kB) +0.13%
Changeset
File Δ Size
packages/loot-core/src/server/server-config.ts 📈 +60 B (+5.27%) 1.11 kB → 1.17 kB
packages/loot-core/src/server/accounts/sync.ts 📈 +1.36 kB (+5.21%) 26.19 kB → 27.56 kB
packages/loot-core/src/server/main.ts 📈 +2.13 kB (+3.07%) 69.32 kB → 71.44 kB
View detailed bundle breakdown

Added

No assets were added

Removed

No assets were removed

Bigger

Asset File Size % Changed
kcab.worker.js 1.33 MB → 1.33 MB (+1.75 kB) +0.13%

Smaller

No assets were smaller

Unchanged

No assets were unchanged

@lelemm
Copy link
Contributor Author

lelemm commented Dec 27, 2024

@coderabbitai review

Copy link
Contributor

coderabbitai bot commented Dec 27, 2024

Warning

There were issues while running some tools. Please review the errors and either fix the tool’s configuration or disable the tool if it’s a critical failure.

🔧 eslint

If the error stems from missing dependencies, add them to the package.json file. For unrecoverable errors (e.g., due to private dependencies), disable the tool in the CodeRabbit configuration.

packages/desktop-client/src/components/Modals.tsx

Oops! Something went wrong! :(

ESLint: 8.57.1

ESLint couldn't find the plugin "eslint-plugin-eslint-plugin".

(The package "eslint-plugin-eslint-plugin" was not found when loaded as a Node module from the directory "/packages/eslint-plugin-actual".)

It's likely that the plugin isn't installed correctly. Try reinstalling by running the following:

npm install eslint-plugin-eslint-plugin@latest --save-dev

The plugin "eslint-plugin-eslint-plugin" was referenced from the config file in "packages/eslint-plugin-actual/.eslintrc.js".

If you still can't figure out the problem, please stop by https://eslint.org/chat/help to chat with the team.

Walkthrough

This pull request introduces comprehensive support for Pluggy.ai, an open banking service for Brazilian banks. The changes span multiple packages and components, adding new functionality to enable bank account synchronization and integration. Key modifications include creating a new modal for Pluggy.ai initialization, implementing a feature toggle for bank sync, developing hooks and actions for managing Pluggy.ai accounts, and extending server-side handlers to support account linking, status checking, and transaction downloading. The implementation provides a framework for Brazilian users to automatically integrate their bank accounts with the application.

Assessment against linked issues

Objective Addressed Explanation
Open Banking Integration for Brazil
Automatic Bank Account Integration
Support for Brazilian Financial Services

Possibly related PRs

Suggested labels

sparkles: Merged, feature/open-banking, brazil-integration

Suggested reviewers

  • youngcw

Tip

CodeRabbit's docstrings feature is now available as part of our Early Access Program! Simply use the command @coderabbitai generate docstrings to have CodeRabbit automatically generate docstrings for your pull request. We would love to hear your feedback on Discord.


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Nitpick comments (9)
packages/loot-core/src/server/accounts/sync.ts (2)

245-305: Clarify logging message and consolidate naming.
Currently, the function logs "Pulling transactions from SimpleFin" even though it is retrieving data from Pluggy.ai. This might confuse developers and users. Also, reusing SimpleFinBatchSyncResponse can be misleading. Consider refactoring it or introducing a dedicated type to distinguish these flows.

- console.log('Pulling transactions from SimpleFin');
+ console.log('Pulling transactions from Pluggy.ai');

895-900: Consider time zone effects when formatting the end date.
Using dateFns.addDays(new Date(), 1) might not align with the user's local time zone. Confirm expected behavior and whether offsets are needed for accurate transaction retrieval across time zones.

packages/loot-core/src/types/models/pluggyai.d.ts (1)

15-17: Interface usage for batch sync responses.
PluggyAiBatchSyncResponse references BankSyncResponse. If you plan to incorporate specialized Pluggy.ai fields in the future, ensure the shape remains flexible.

packages/desktop-client/src/components/settings/Experimental.tsx (1)

105-110: Add clarity to the feedback link.

You're referencing https://github.com/actualbudget/actual/ directly here. Consider linking to a more specific issue or discussion thread for Pluggy.ai feedback. This will guide users to the correct place for reporting problems or offering suggestions.

packages/desktop-client/src/components/modals/PluggyAiInitialiseModal.tsx (4)

1-2: Review the “@ts-strict-ignore” directive.

Double-check why strict type-checking is disabled. If possible, remove @ts-strict-ignore or replace it with more targeted exceptions, ensuring type-safety across the codebase.


8-8: Rename imported Error to avoid shadowing.

This import collides with the global Error object, potentially causing confusion. Consider using a different name such as AlertError or similar.

-import { Error } from '../alerts';
+import { Error as AlertError } from '../alerts';
🧰 Tools
🪛 Biome (1.9.4)

[error] 8-8: Do not shadow the global "Error" property.

Consider renaming this variable. It's easy to confuse the origin of variables when they're named after a known global.

(lint/suspicious/noShadowRestrictedNames)


42-51: Improve form validation clarity.

The validation logic is correct but somewhat repetitive. You might simplify by extracting these checks into a dedicated function (e.g., validateInputs) or by using a form library, centralizing the validation logic and error messages.


55-91: Wrap secret-setting actions in a single request if supported.

Each key (clientId, clientSecret, itemIds) is set in a separate request. If the backend supports batch operations, consider grouping them. This pattern will reduce round trips and the chance of partial failure.

packages/desktop-client/src/components/modals/SelectLinkedAccountsModal.jsx (1)

82-92: Consider extracting duplicated logic.

The implementation correctly handles Pluggy.ai account linking, following the existing patterns. However, there's duplicated logic for determining the chosenLocalAccountId across all three branches.

Consider extracting the common logic:

 async function onNext() {
+  const getLocalAccountId = (chosenLocalAccountId) => 
+    chosenLocalAccountId !== addOnBudgetAccountOption.id &&
+    chosenLocalAccountId !== addOffBudgetAccountOption.id
+      ? chosenLocalAccountId
+      : undefined;

   // ... existing code ...

   Object.entries(chosenAccounts).forEach(
     ([chosenExternalAccountId, chosenLocalAccountId]) => {
       // ... existing code ...

       if (syncSource === 'simpleFin') {
         dispatch(
           linkAccountSimpleFin(
             externalAccount,
-            chosenLocalAccountId !== addOnBudgetAccountOption.id &&
-              chosenLocalAccountId !== addOffBudgetAccountOption.id
-              ? chosenLocalAccountId
-              : undefined,
+            getLocalAccountId(chosenLocalAccountId),
             offBudget,
           ),
         );
       } else if (syncSource === 'pluggyai') {
         dispatch(
           linkAccountPluggyAi(
             externalAccount,
-            chosenLocalAccountId !== addOnBudgetAccountOption.id &&
-              chosenLocalAccountId !== addOffBudgetAccountOption.id
-              ? chosenLocalAccountId
-              : undefined,
+            getLocalAccountId(chosenLocalAccountId),
             offBudget,
           ),
         );
       } else {
         dispatch(
           linkAccount(
             requisitionId,
             externalAccount,
-            chosenLocalAccountId !== addOnBudgetAccountOption.id &&
-              chosenLocalAccountId !== addOffBudgetAccountOption.id
-              ? chosenLocalAccountId
-              : undefined,
+            getLocalAccountId(chosenLocalAccountId),
             offBudget,
           ),
         );
       }
     },
   );
 }
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 3f6068f and f5917da.

⛔ Files ignored due to path filters (1)
  • upcoming-release-notes/4049.md is excluded by !**/*.md
📒 Files selected for processing (15)
  • packages/desktop-client/src/components/Modals.tsx (2 hunks)
  • packages/desktop-client/src/components/modals/CreateAccountModal.tsx (9 hunks)
  • packages/desktop-client/src/components/modals/PluggyAiInitialiseModal.tsx (1 hunks)
  • packages/desktop-client/src/components/modals/SelectLinkedAccountsModal.jsx (2 hunks)
  • packages/desktop-client/src/components/settings/Experimental.tsx (1 hunks)
  • packages/desktop-client/src/hooks/useFeatureFlag.ts (1 hunks)
  • packages/desktop-client/src/hooks/usePluggyAiStatus.ts (1 hunks)
  • packages/loot-core/src/client/actions/account.ts (1 hunks)
  • packages/loot-core/src/client/state-types/modals.d.ts (1 hunks)
  • packages/loot-core/src/server/accounts/sync.ts (3 hunks)
  • packages/loot-core/src/server/main.ts (3 hunks)
  • packages/loot-core/src/server/server-config.ts (2 hunks)
  • packages/loot-core/src/types/models/pluggyai.d.ts (1 hunks)
  • packages/loot-core/src/types/prefs.d.ts (1 hunks)
  • packages/loot-core/src/types/server-handlers.d.ts (3 hunks)
🧰 Additional context used
🪛 Biome (1.9.4)
packages/desktop-client/src/components/modals/PluggyAiInitialiseModal.tsx

[error] 8-8: Do not shadow the global "Error" property.

Consider renaming this variable. It's easy to confuse the origin of variables when they're named after a known global.

(lint/suspicious/noShadowRestrictedNames)

🔇 Additional comments (31)
packages/loot-core/src/types/prefs.d.ts (2)

6-6: No issues found for the updated 'openidAuth' line.

It aligns well with the union type definition style.


7-7: New feature flag 'pluggyAiBankSync' properly added.

This addition expands the feature flags, reflecting the new Pluggy.ai integration. Verify that all references to this flag are included in the codebase to ensure consistent behavior.

✅ Verification successful

Feature flag 'pluggyAiBankSync' is properly referenced

The feature flag is correctly defined in prefs.d.ts and is being used appropriately in the CreateAccountModal component to conditionally enable Pluggy.ai integration functionality. The usage pattern follows the standard feature flag implementation where it's checked using the useFeatureFlag hook.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Searches for references to the newly introduced 'pluggyAiBankSync' flag across the repository
rg "'pluggyAiBankSync'"

Length of output: 228

packages/loot-core/src/server/accounts/sync.ts (2)

812-820: Validate transaction amount conversion.
You multiply trans.transactionAmount.amount by 100. Confirm that transactionAmount.amount is always a float or integer and cannot be null or undefined. If amounts are large or contain decimals, consider parsing them to avoid floating-point inaccuracies.


245-305: Handle function return type carefully.
If userToken is not found, the function returns undefined, which could lead to errors if the caller expects a structured object. Consider returning a standardized object or throwing an error instead.

Would you like to verify all callsites of downloadPluggyAiTransactions to ensure they handle a potential undefined return?

packages/loot-core/src/types/models/pluggyai.d.ts (3)

1-3: Imports look good.
No issues with the general imports.


4-7: Ensure optional vs. required fields.
PluggyAiOrganization mandates both name and domain. If there's any scenario where domain might be unavailable, make it optional. Otherwise, this is fine.


9-13: Naming alignment for clarity.
org is clear. Ensure that all references in the code are consistent with the property name org instead of organization.

packages/desktop-client/src/hooks/useFeatureFlag.ts (1)

11-11: New feature flag is well-integrated.
No functional issues. This straightforward addition follows the existing pattern for feature flags.

packages/desktop-client/src/hooks/usePluggyAiStatus.ts (1)

1-33: Hook implementation looks solid.
The usePluggyAiStatus hook properly manages data fetching and loading states. Confirm that offline scenarios are handled gracefully in components.

packages/loot-core/src/server/server-config.ts (1)

9-9: New server property aligns with other providers.
Defining PLUGGYAI_SERVER parallels existing server URLs for other providers. Ensure that environment variables and build configurations set PLUGGYAI_SERVER properly in production.

Also applies to: 46-46

✅ Verification successful

PLUGGYAI_SERVER is properly integrated and used consistently

The verification shows that PLUGGYAI_SERVER is:

  • Defined in the server configuration (server-config.ts)
  • Properly constructed using joinURL with a /pluggyai path
  • Used consistently across different server endpoints:
    • /status endpoint in main.ts
    • /accounts endpoint in main.ts
    • /transactions endpoint in accounts/sync.ts

Let's verify the environment variable configuration:


Let's check the server configuration setup more broadly to understand how the URL is constructed:


Let's check how the server URL is configured in the codebase:


Let's check how the base URL is configured and where it comes from:


Based on the verification results, I can now provide a final response:

PLUGGYAI_SERVER is properly configured but requires server URL setup

The verification shows that:

  • The PLUGGYAI_SERVER endpoint is correctly constructed using joinURL(url, '/pluggyai') in the server configuration
  • The base server URL is retrieved from async storage (server-url) rather than environment variables
  • The configuration follows the same pattern as other provider endpoints (GOCARDLESS_SERVER, SIMPLEFIN_SERVER)

The server URL must be set in the application's storage rather than through environment variables. This is consistent with the application's architecture where the server URL is configured at runtime.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Searches for references to PLUGGYAI_SERVER to confirm usage
rg "PLUGGYAI_SERVER"

Length of output: 461


Script:

#!/bin/bash
# Check for environment variable configuration
rg -A 2 "process\.env.*PLUGGY"
fd "env" --exec rg "PLUGGY"

Length of output: 58


Script:

#!/bin/bash
# Check server configuration setup
rg -B 3 -A 3 "PLUGGYAI_SERVER"

# Check for any environment-related configuration files
fd -e env -e config -e json --exec cat {}

Length of output: 77635


Script:

#!/bin/bash
# Check server configuration setup and URL construction
rg -B 5 -A 2 "joinURL.*pluggyai"

# Look for environment variable configuration in common config files
fd -e env -e config.js -e config.ts -e json -g "*config*" --exec cat {}

Length of output: 12993


Script:

#!/bin/bash
# Check how the base URL is constructed
rg -B 5 "const url = " packages/loot-core/src/server/

# Check for environment variable usage in server configuration
rg "process\.env" packages/loot-core/src/server/server-config.ts

Length of output: 927

packages/loot-core/src/client/actions/account.ts (1)

92-106: Consistent naming and usage matches existing patterns.

This function parallels other account-linking actions, ensuring consistency throughout the codebase. Looks good! Test the response payload to ensure that any errors or edge cases (e.g., missing fields) are gracefully handled.

packages/loot-core/src/client/state-types/modals.d.ts (1)

72-74: Modal definition aligns with new PluggyAiInitialiseModal.

Adding the 'pluggyai-init' type is consistent with other modals. Great job ensuring it supplies the onSuccess callback for upstream integration.

packages/loot-core/src/types/server-handlers.d.ts (4)

21-21: No issues detected on this import statement.
The import path looks valid, and the new PluggyAiAccount type aligns with the new handlers that require it.


165-170: Well-structured new handler definition.
The new 'pluggyai-accounts-link' handler type is consistent with the existing pattern for linking external accounts.


203-204: Good addition for checking Pluggy.ai status.
The return { configured: boolean } is consistent with other status handlers.


207-208: Consistent return structure for retrieved accounts.
The new 'pluggyai-accounts' handler using { accounts: PluggyAiAccount[] } aligns well with how other account retrieval handlers are structured.

packages/desktop-client/src/components/modals/CreateAccountModal.tsx (8)

12-14: Imports for feature flag and Pluggy.ai status look good.
These imports are necessary for the new conditional rendering and status updates.


38-39: Conditional check for the Pluggy.ai feature flag.
This logic is succinct and clearly isolates Pluggy.ai-specific content based on the feature flag.


48-50: New state for tracking Pluggy.ai setup status.
This mirrors the approach used for other integrations like GoCardless and SimpleFin.


129-183: New onConnectPluggyAi method.

  1. The logic nicely parallelizes existing patterns for bank sync integrations.
  2. Consider verifying that onSuccess from the modal is being called properly here, just like in onConnectSimpleFin for consistent user flow.

201-207: Initialization flow for Pluggy.ai is consistent with existing flows.
The new onPluggyAiInit nicely follows the same structure as SimpleFin and GoCardless.


237-254: Credential reset function for Pluggy.ai.
This correctly clears saved credentials (clientId, clientSecret, etc.) from secrets.


270-274: Effect correctly updates local state based on Pluggy.ai configuration.
The design is consistent with how GoCardless and SimpleFin states are tracked.


456-520: UI segment to link or configure Pluggy.ai.

  1. Excellent consistency in the user flow with other integrations.
  2. The conditional rendering based on isPluggyAiEnabled is clear and minimal.
packages/desktop-client/src/components/Modals.tsx (2)

63-63: New import for PluggyAiInitialiseModal.
This addition is straightforward, referencing the newly created modal.


223-227: New case for the pluggyai-init modal in the switch statement.
The logic and prop usage mimic other initialization modals, ensuring UI consistency.

packages/loot-core/src/server/main.ts (3)

709-767: handlers['pluggyai-accounts-link'] logic.

  1. The approach to find or create a bank record, then link or create an account is consistent with other link handlers.
  2. Good usage of uuidv4() to generate new account IDs.
  3. Consider verifying how the user is notified of failed linking attempts if await bankSync.syncAccount(...) fails (e.g. a specialized catch or error-handling flow).

1037-1052: handlers['pluggyai-status'] validation and request approach.

  1. The logic closely replicates gocardless-status and simplefin-status, ensuring uniform usage of user-token.
  2. No major concerns; the error messages are consistent.

1074-1094: handlers['pluggyai-accounts'] retrieval logic.

  1. Well-structured request to fetch user’s accounts with a 60-second timeout.
  2. Return shape ensures consistent usage with the front-end code.
packages/desktop-client/src/components/modals/SelectLinkedAccountsModal.jsx (2)

8-8: LGTM!

The new import follows the existing pattern and is correctly grouped with related action imports.


82-92: Verify external account data validation.

Please ensure that proper validation of external account data is implemented in the linkAccountPluggyAi action before linking accounts.

Let's verify the implementation of data validation:

✅ Verification successful

Let me gather more information about the validation in the account actions.


Let me check the server-side implementation of the Pluggy account linking.


Let me check one final aspect - the bank linking implementation since it's used in the Pluggy account linking process.


External account data validation is already implemented

Based on the code analysis, the validation for Pluggy AI account linking is properly implemented through multiple layers:

  1. Type safety through TypeScript definitions:

    • PluggyAiAccount and related types are defined in packages/loot-core/src/types/models/pluggyai.d.ts
    • Server handler types are defined in packages/loot-core/src/types/server-handlers.d.ts
  2. Account model validation:

    • The base account validation is handled by the validate method in packages/loot-core/src/server/models.ts
    • Required fields are checked through requiredFields validation
  3. Server-side implementation:

    • The pluggyai-accounts-link handler in packages/loot-core/src/server/main.ts ensures proper bank linking
    • Account creation/updating is handled through structured database operations

The implementation includes proper type checking, model validation, and database integrity checks, making additional validation unnecessary.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for data validation in linkAccountPluggyAi implementation

# Search for the action implementation
echo "Searching for linkAccountPluggyAi implementation..."
ast-grep --pattern 'export function linkAccountPluggyAi($_) {
  $$$
}'

# Search for validation patterns
echo "Checking for validation patterns..."
rg -A 5 'linkAccountPluggyAi|validatePluggyAccount|validate.*Account' 

Length of output: 7292


Script:

#!/bin/bash
# Check the implementation of linkAccountPluggyAi and related validation
echo "Checking linkAccountPluggyAi implementation..."
rg -A 15 "export function linkAccountPluggyAi" packages/loot-core/src/client/actions/account.ts

# Check for any server-side validation for Pluggy accounts
echo "Checking server-side validation..."
rg -A 10 "pluggy.*validate|validate.*pluggy" 

Length of output: 669


Script:

#!/bin/bash
# Check the server-side implementation of Pluggy account linking
echo "Checking server-side Pluggy account linking..."
rg -A 15 "pluggyai-accounts-link" 

# Check for any type definitions or interfaces for Pluggy accounts
echo "Checking Pluggy account types..."
rg -A 10 "type.*Pluggy|interface.*Pluggy"

Length of output: 5512


Script:

#!/bin/bash
# Check the bank linking implementation
echo "Checking bank linking implementation..."
rg -A 15 "findOrCreateBank" 

# Check for any model validations
echo "Checking model validations..."
rg -A 10 "class Bank|validate.*bank"

Length of output: 4431

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

Successfully merging this pull request may close these issues.

[Feature] Open Banking from Brazil
1 participant