Skip to content

GoogleContacts - remove component duplicates #615

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

Open
wants to merge 6 commits into
base: dev
Choose a base branch
from

Conversation

ZbynekPelunek
Copy link
Contributor

@ZbynekPelunek ZbynekPelunek commented Jul 7, 2025

Summary by CodeRabbit

  • Removals

    • Removed all Google Contacts integration features, including creating, updating, deleting, and searching contacts and contact groups.
    • Removed all related components for managing and retrieving Google Contacts and contact groups.
    • Removed OAuth2 authentication module for Google Contacts.
    • Removed utility functions for output formatting and schema handling related to Google Contacts.
  • Documentation

    • Updated descriptions for core contact search and listing components to provide clearer explanations of their functionality.

Copy link
Contributor

coderabbitai bot commented Jul 7, 2025

## Walkthrough

This change removes all legacy Google Contacts components and their implementation files from the codebase. It deletes modules for creating, updating, deleting, searching, and listing contacts and contact groups, along with their respective component descriptors and the OAuth2 authentication module. Only minor description updates remain in the new "core" Google Contacts component configurations.

## Changes

| Files                                                                                       | Change Summary                                                                                           |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| src/appmixer/googleContacts/AddorRemoveContactsfromGroup/*<br>src/appmixer/googleContacts/CreateContact/*<br>src/appmixer/googleContacts/CreateContactGroup/*<br>src/appmixer/googleContacts/DeleteContact/*<br>src/appmixer/googleContacts/DeleteContactGroup/*<br>src/appmixer/googleContacts/FindContactGroups/*<br>src/appmixer/googleContacts/FindMyContacts/*<br>src/appmixer/googleContacts/FindOtherContacts/*<br>src/appmixer/googleContacts/GetContact/*<br>src/appmixer/googleContacts/GetContactGroup/*<br>src/appmixer/googleContacts/SearchContacts/*<br>src/appmixer/googleContacts/SearchDirectoryContacts/*<br>src/appmixer/googleContacts/UpdateContact/*<br>src/appmixer/googleContacts/UpdateContactGroup/* | Deleted all legacy Google Contacts modules and their respective component.json descriptors.                |
| src/appmixer/google/contacts/*                                                               | Deleted all legacy Google Contacts modules, component descriptors, OAuth2 authentication module, schemas, and utility libraries. |
| src/appmixer/googleContacts/core/FindContacts/component.json                                | Updated description to clarify search is performed using a query.                                         |
| src/appmixer/googleContacts/core/FindDirectoryContacts/component.json                       | Updated description to specify search is performed using a query.                                         |
| src/appmixer/googleContacts/core/ListOtherContacts/component.json                           | Updated description to clarify which contacts are listed as "Other contacts."                             |
| src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js                     | Added safety check before mapping contact groups to avoid errors if data is missing or malformed.         |
| src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js                           | Added safety check before mapping contacts to avoid errors if data is missing or malformed.               |
| src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js                     | Added safety check before mapping other contacts to avoid errors if data is missing or malformed.         |
| src/appmixer/googleContacts/core/ListContactGroups/component.json                           | Updated output port source URL to include "core" subdirectory in path.                                   |
| src/appmixer/googleContacts/core/ListMyContacts/component.json                             | Updated output port source URL to include "core" subdirectory in path.                                   |
| src/appmixer/googleContacts/core/ListOtherContacts/component.json                           | Updated output port source URL to include "core" subdirectory in path.                                   |
| src/appmixer/googleContacts/core/FindContacts/FindContacts.js                              | Updated API endpoint to use `searchContacts` with sources parameter; adjusted response parsing and logging. |
| src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js                            | Corrected property name from `emails` to `emailAddresses` in update payload to match API expectations.    |

## Possibly related PRs

- [clientIO/appmixer-connectors#592](https://github.com/clientIO/appmixer-connectors/pull/592): Adds the "AddorRemoveContactsfromGroup" module and its component, which are removed in this PR; directly related as inverse operations.
- [clientIO/appmixer-connectors#528](https://github.com/clientIO/appmixer-connectors/pull/528): Introduces the same add/remove contacts from group module and component that this PR deletes; directly related as inverse operations.
- [clientIO/appmixer-connectors#603](https://github.com/clientIO/appmixer-connectors/pull/603): Adds new "core" versions of the same Google Contacts components removed here, suggesting this PR deletes legacy versions replaced by those introduced in #603.

## Suggested reviewers

- vtalas

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.

npm error Exit handler never called!
npm error This is an error with npm itself. Please report this error at:
npm error https://github.com/npm/cli/issues
npm error A complete log of this run can be found in: /.npm/_logs/2025-07-11T13_40_21_587Z-debug-0.log


📜 Recent review details

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

📥 Commits

Reviewing files that changed from the base of the PR and between 690e2c1 and 9413dd5.

📒 Files selected for processing (1)
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ 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.
    • Explain this complex logic.
    • 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 explain this code block.
    • @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 explain its main purpose.
    • @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.

Support

Need help? Create a ticket on our support page for assistance with any issues or questions.

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 sequence diagram to generate a sequence diagram of the changes in this PR.
  • @coderabbitai auto-generate unit tests to generate unit tests for this PR.
  • @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: 3

🔭 Outside diff range comments (1)
src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (1)

85-86: icon must be an SVG URL, not an inline PNG

Guidelines: “icon property, if present, must be a link to an SVG icon.”
Current value is a large base-64 PNG → bloats manifest and violates spec.

-    "icon": "..."
+    "icon": "https://static.appmixer.com/icons/googleContacts.svg"
🧹 Nitpick comments (2)
src/appmixer/googleContacts/core/ListOtherContacts/component.json (1)

4-4: Minor wording polish

Consider hyphenating “auto-created” to improve readability:

-    "description": "List all \"Other contacts\", that is contacts that are not in a contact group. \"Other contacts\" are typically auto created contacts from interactions.",
+    "description": "List all \"Other contacts\" – contacts that are not in a contact group. \"Other contacts\" are typically auto-created from interactions.",
src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (1)

30-42: Non-contiguous inspector index values

query is index: 0, outputType is index: 2 (skips 1).
Not harmful but breaks visual ordering conventions and may confuse inspector rendering logic.

-        "index": 2,
+        "index": 1,
📜 Review details

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

📥 Commits

Reviewing files that changed from the base of the PR and between 7e79d0d and e40dcbc.

📒 Files selected for processing (31)
  • src/appmixer/googleContacts/AddorRemoveContactsfromGroup/AddorRemoveContactsfromGroup.js (0 hunks)
  • src/appmixer/googleContacts/AddorRemoveContactsfromGroup/component.json (0 hunks)
  • src/appmixer/googleContacts/CreateContact/CreateContact.js (0 hunks)
  • src/appmixer/googleContacts/CreateContact/component.json (0 hunks)
  • src/appmixer/googleContacts/CreateContactGroup/CreateContactGroup.js (0 hunks)
  • src/appmixer/googleContacts/CreateContactGroup/component.json (0 hunks)
  • src/appmixer/googleContacts/DeleteContact/DeleteContact.js (0 hunks)
  • src/appmixer/googleContacts/DeleteContact/component.json (0 hunks)
  • src/appmixer/googleContacts/DeleteContactGroup/DeleteContactGroup.js (0 hunks)
  • src/appmixer/googleContacts/DeleteContactGroup/component.json (0 hunks)
  • src/appmixer/googleContacts/FindContactGroups/FindContactGroups.js (0 hunks)
  • src/appmixer/googleContacts/FindContactGroups/component.json (0 hunks)
  • src/appmixer/googleContacts/FindMyContacts/FindMyContacts.js (0 hunks)
  • src/appmixer/googleContacts/FindMyContacts/component.json (0 hunks)
  • src/appmixer/googleContacts/FindOtherContacts/FindOtherContacts.js (0 hunks)
  • src/appmixer/googleContacts/FindOtherContacts/component.json (0 hunks)
  • src/appmixer/googleContacts/GetContact/GetContact.js (0 hunks)
  • src/appmixer/googleContacts/GetContact/component.json (0 hunks)
  • src/appmixer/googleContacts/GetContactGroup/GetContactGroup.js (0 hunks)
  • src/appmixer/googleContacts/GetContactGroup/component.json (0 hunks)
  • src/appmixer/googleContacts/SearchContacts/SearchContacts.js (0 hunks)
  • src/appmixer/googleContacts/SearchContacts/component.json (0 hunks)
  • src/appmixer/googleContacts/SearchDirectoryContacts/SearchDirectoryContacts.js (0 hunks)
  • src/appmixer/googleContacts/SearchDirectoryContacts/component.json (0 hunks)
  • src/appmixer/googleContacts/UpdateContact/UpdateContact.js (0 hunks)
  • src/appmixer/googleContacts/UpdateContact/component.json (0 hunks)
  • src/appmixer/googleContacts/UpdateContactGroup/UpdateContactGroup.js (0 hunks)
  • src/appmixer/googleContacts/UpdateContactGroup/component.json (0 hunks)
  • src/appmixer/googleContacts/core/FindContacts/component.json (1 hunks)
  • src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (1 hunks)
  • src/appmixer/googleContacts/core/ListOtherContacts/component.json (1 hunks)
💤 Files with no reviewable changes (28)
  • src/appmixer/googleContacts/DeleteContactGroup/DeleteContactGroup.js
  • src/appmixer/googleContacts/GetContact/component.json
  • src/appmixer/googleContacts/DeleteContact/DeleteContact.js
  • src/appmixer/googleContacts/AddorRemoveContactsfromGroup/AddorRemoveContactsfromGroup.js
  • src/appmixer/googleContacts/DeleteContactGroup/component.json
  • src/appmixer/googleContacts/FindContactGroups/component.json
  • src/appmixer/googleContacts/UpdateContactGroup/UpdateContactGroup.js
  • src/appmixer/googleContacts/UpdateContact/UpdateContact.js
  • src/appmixer/googleContacts/GetContactGroup/GetContactGroup.js
  • src/appmixer/googleContacts/FindContactGroups/FindContactGroups.js
  • src/appmixer/googleContacts/DeleteContact/component.json
  • src/appmixer/googleContacts/SearchDirectoryContacts/SearchDirectoryContacts.js
  • src/appmixer/googleContacts/GetContact/GetContact.js
  • src/appmixer/googleContacts/SearchContacts/component.json
  • src/appmixer/googleContacts/CreateContactGroup/component.json
  • src/appmixer/googleContacts/FindMyContacts/component.json
  • src/appmixer/googleContacts/UpdateContactGroup/component.json
  • src/appmixer/googleContacts/CreateContact/CreateContact.js
  • src/appmixer/googleContacts/FindMyContacts/FindMyContacts.js
  • src/appmixer/googleContacts/UpdateContact/component.json
  • src/appmixer/googleContacts/AddorRemoveContactsfromGroup/component.json
  • src/appmixer/googleContacts/FindOtherContacts/FindOtherContacts.js
  • src/appmixer/googleContacts/CreateContact/component.json
  • src/appmixer/googleContacts/FindOtherContacts/component.json
  • src/appmixer/googleContacts/SearchContacts/SearchContacts.js
  • src/appmixer/googleContacts/CreateContactGroup/CreateContactGroup.js
  • src/appmixer/googleContacts/SearchDirectoryContacts/component.json
  • src/appmixer/googleContacts/GetContactGroup/component.json
🧰 Additional context used
📓 Path-based instructions (2)
`src/appmixer/**`: Use `src/appmixer` for source code of connectors.

src/appmixer/**: Use src/appmixer for source code of connectors.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/FindDirectoryContacts/component.json
  • src/appmixer/googleContacts/core/FindContacts/component.json
  • src/appmixer/googleContacts/core/ListOtherContacts/component.json
`src/appmixer/*/core/*/component.json`: Each component must have a `component.js...

src/appmixer/*/core/*/component.json: Each component must have a component.json file in its folder under core.
If adding a new field to component.json, add the field to both schema and inspector sections in the inPorts array, following JSON schema format.
The component.json file must have a name property in the format 'vendor.connectorName.core.componentName'.
The component.json file must define the label, description, and author properties as described in the schema.
The component.json file must define inPorts and outPorts arrays according to the schema, with each port having the required structure.
The component.json file must not have additional properties beyond those defined in the schema.
The component.json file must define the version property, e.g., '1.0.0'.
The component.json file's auth property, if present, must have a service property in the format [vendor]:[service].
The component.json file's quota property, if present, must reference a quota manager and resources as described in the schema.
The component.json file's properties object, if present, must define schema and inspector according to the definitions.
The component.json file's inPorts array must define each input port with a name and configuration, allowing placeholders for variables.
The component.json file's outPorts array must define each output port with a name and optionally an options array describing output structure.
The component.json file's inspector property, if present, must follow the Rappid Inspector definition format or use a dynamic source.
The component.json file's name property must match the pattern ^[\w]+.[\w]+.[\w]+.[\w]+$.
The component.json file's icon property, if present, must be a link to an SVG icon.
The component.json file's tick property, if present and true, indicates the component will receive signals at regular intervals.
The component.json file's webhook property, if present and true, enables webhook functionality for the component.
The component.json file's state property, if present, must define a persistent boolean.
The component.json file's options property, if present, must be an array of unique objects or strings.
The component.json file's inspectorInput property, if present, must follow the defined schema for inspector inputs.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/FindDirectoryContacts/component.json
  • src/appmixer/googleContacts/core/FindContacts/component.json
  • src/appmixer/googleContacts/core/ListOtherContacts/component.json
🧠 Learnings (3)
src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (10)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `label`, `description`, and `author` properties as described in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must not have additional properties beyond those defined in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must have a `name` property in the format 'vendor.connectorName.core.componentName'.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : Each component must have a `component.json` file in its folder under core.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `version` property, e.g., '1.0.0'.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : If adding a new field to component.json, add the field to both `schema` and `inspector` sections in the `inPorts` array, following JSON schema format.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file's `name` property must match the pattern ^[\w]+\.[\w]+\.[\w]+\.[\w]+$.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file's `auth` property, if present, must have a `service` property in the format [vendor]:[service].
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file's `quota` property, if present, must reference a quota manager and resources as described in the schema.
src/appmixer/googleContacts/core/FindContacts/component.json (7)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `label`, `description`, and `author` properties as described in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must have a `name` property in the format 'vendor.connectorName.core.componentName'.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must not have additional properties beyond those defined in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `version` property, e.g., '1.0.0'.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : Each component must have a `component.json` file in its folder under core.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : If adding a new field to component.json, add the field to both `schema` and `inspector` sections in the `inPorts` array, following JSON schema format.
src/appmixer/googleContacts/core/ListOtherContacts/component.json (6)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `label`, `description`, and `author` properties as described in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must not have additional properties beyond those defined in the schema.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must have a `name` property in the format 'vendor.connectorName.core.componentName'.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : Each component must have a `component.json` file in its folder under core.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/component.json : The `component.json` file must define the `version` property, e.g., '1.0.0'.
🔇 Additional comments (2)
src/appmixer/googleContacts/core/FindContacts/component.json (1)

4-4: Description tweak looks good

The refined wording (“using query”) clarifies usage without altering behaviour.

src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (1)

68-79: Verify source.url still resolves after component clean-up

The endpoint /component/appmixer/googleContacts/FindDirectoryContacts drops the core segment.
After removing legacy modules, make sure the router still maps to the correct handler, otherwise the out-port will never emit.

@ZbynekPelunek ZbynekPelunek requested a review from vtalas July 7, 2025 15:57
@ZbynekPelunek ZbynekPelunek linked an issue Jul 7, 2025 that may be closed by this pull request
Copy link
Contributor

@vtalas vtalas left a comment

Choose a reason for hiding this comment

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

@ZbynekPelunek bundle.json

@vtalas vtalas marked this pull request as draft July 8, 2025 08:14
@ZbynekPelunek ZbynekPelunek marked this pull request as ready for review July 9, 2025 13:22
@ZbynekPelunek ZbynekPelunek requested a review from vtalas July 9, 2025 13:24
Copy link
Contributor

@vtalas vtalas left a comment

Choose a reason for hiding this comment

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

remove the google/contacts as well

@vtalas vtalas marked this pull request as draft July 9, 2025 15:35
@ZbynekPelunek ZbynekPelunek marked this pull request as ready for review July 10, 2025 09:17
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: 5

📜 Review details

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

📥 Commits

Reviewing files that changed from the base of the PR and between 1082559 and 027c9f3.

📒 Files selected for processing (8)
  • src/appmixer/googleContacts/core/FindContacts/component.json (2 hunks)
  • src/appmixer/googleContacts/core/FindDirectoryContacts/component.json (2 hunks)
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js (1 hunks)
  • src/appmixer/googleContacts/core/ListContactGroups/component.json (1 hunks)
  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js (1 hunks)
  • src/appmixer/googleContacts/core/ListMyContacts/component.json (1 hunks)
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js (1 hunks)
  • src/appmixer/googleContacts/core/ListOtherContacts/component.json (2 hunks)
✅ Files skipped from review due to trivial changes (2)
  • src/appmixer/googleContacts/core/ListMyContacts/component.json
  • src/appmixer/googleContacts/core/ListContactGroups/component.json
🚧 Files skipped from review as they are similar to previous changes (3)
  • src/appmixer/googleContacts/core/FindContacts/component.json
  • src/appmixer/googleContacts/core/FindDirectoryContacts/component.json
  • src/appmixer/googleContacts/core/ListOtherContacts/component.json
🧰 Additional context used
📓 Path-based instructions (4)
`src/appmixer/**`: Use `src/appmixer` for source code of connectors.

src/appmixer/**: Use src/appmixer for source code of connectors.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js
`src/appmixer/*/core/*/*.js`: Behavior files for components must be JavaScript f...

src/appmixer/*/core/*/*.js: Behavior files for components must be JavaScript files named after the component and located in the corresponding component folder under core.
When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in context.httpRequest calls.
Do not check for required properties in the receive function of behavior files; required properties are validated by the input schema in component.json.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js
`**/*.js`: Add one empty line after function definition. Use 4 spaces for indentation.

**/*.js: Add one empty line after function definition.
Use 4 spaces for indentation.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js
`src/appmixer/**/*.js`: Not necessary to add try/catch blocks in their `receive`...

src/appmixer/**/*.js: Not necessary to add try/catch blocks in their receive function. Appmixer engine automatically handles any exceptions that originate in these async functions.

The directive "use strict"; is desirable here

⚙️ Source: CodeRabbit Configuration File

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js
🧠 Learnings (3)
src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js (2)
Learnt from: ZbynekPelunek
PR: clientIO/appmixer-connectors#384
File: src/appmixer/airtable/records/NewRecordWebhook/NewRecordWebhook.js:75-80
Timestamp: 2025-03-10T13:32:28.895Z
Learning: In Airtable webhook responses for new records, if the payload array exists and passes the check `Array.isArray(payloads) && payloads.length > 0`, then `payloads[0].changedTablesById[tableId].createdRecordsById` will always contain at least one record, making additional empty array checks unnecessary.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : Do not check for required properties in the `receive` function of behavior files; required properties are validated by the input schema in component.json.
src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js (2)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : Do not check for required properties in the `receive` function of behavior files; required properties are validated by the input schema in component.json.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js (4)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : Do not check for required properties in the `receive` function of behavior files; required properties are validated by the input schema in component.json.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
Learnt from: ZbynekPelunek
PR: clientIO/appmixer-connectors#384
File: src/appmixer/airtable/records/NewRecordWebhook/NewRecordWebhook.js:75-80
Timestamp: 2025-03-10T13:32:28.895Z
Learning: In Airtable webhook responses for new records, if the payload array exists and passes the check `Array.isArray(payloads) && payloads.length > 0`, then `payloads[0].changedTablesById[tableId].createdRecordsById` will always contain at least one record, making additional empty array checks unnecessary.
Learnt from: sayam-nasir
PR: clientIO/appmixer-connectors#448
File: src/appmixer/github/list/GetUser/GetUser.js:12-14
Timestamp: 2025-04-28T11:22:40.693Z
Learning: Error handling for GitHub API requests in the appmixer connectors is already implemented at a different level (likely in lib.apiRequest), so additional try-catch blocks aren't needed in individual component files.
🧬 Code Graph Analysis (3)
src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js (2)
src/appmixer/googleContacts/core/FindContacts/FindContacts.js (1)
  • records (31-43)
src/appmixer/googleContacts/core/FindDirectoryContacts/FindDirectoryContacts.js (1)
  • records (32-44)
src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js (2)
src/appmixer/googleContacts/core/FindContacts/FindContacts.js (1)
  • records (31-43)
src/appmixer/googleContacts/core/FindDirectoryContacts/FindDirectoryContacts.js (1)
  • records (32-44)
src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js (4)
src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js (1)
  • records (26-26)
src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js (1)
  • records (27-27)
src/appmixer/googleContacts/core/FindContacts/FindContacts.js (1)
  • records (31-43)
src/appmixer/googleContacts/core/FindDirectoryContacts/FindDirectoryContacts.js (1)
  • records (32-44)
🔇 Additional comments (1)
src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js (1)

25-34: Add null safety checks for nested property access.

The mapping logic accesses nested properties like contactGroup.metadata?.updateTime but doesn't guard against missing required properties, which could cause runtime errors.

             records = data.contactGroups.map((contactGroup) => {
                 return {
-                    id: contactGroup.resourceName.split('/')[1],
+                    id: contactGroup.resourceName?.split('/')[1],
                     etag: contactGroup.etag ?? undefined,
                     updateTime: contactGroup.metadata?.updateTime,
                     groupType: contactGroup.groupType,
                     name: contactGroup.name,
                     formattedName: contactGroup.formattedName
                 };
             });
⛔ Skipped due to learnings
Learnt from: ZbynekPelunek
PR: clientIO/appmixer-connectors#461
File: src/appmixer/microsoft/sharepoint/FindFilesOrFolders/FindFilesOrFolders.js:54-54
Timestamp: 2025-04-22T16:36:59.075Z
Learning: Optional chaining (`?.`) in JavaScript correctly handles nullish (null or undefined) values, making additional explicit null checks unnecessary. In boolean contexts like `Array.some()`, if the referenced property is nullish, it evaluates to `undefined` which coerces to `false`.
Learnt from: ZbynekPelunek
PR: clientIO/appmixer-connectors#378
File: src/appmixer/akamai/clientlist/UpsertListEntries/UpsertListEntries.js:38-41
Timestamp: 2025-03-10T10:24:51.035Z
Learning: In the Akamai connector's UpsertListEntries component, the optional chaining operator (`?.`) is used for handling potentially undefined tag values, making additional null checks unnecessary.
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : Do not check for required properties in the `receive` function of behavior files; required properties are validated by the input schema in component.json.

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: 2

🔭 Outside diff range comments (1)
src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js (1)

53-63: Add safety checks for optional properties.

The response processing assumes certain properties exist without null checks, which could cause runtime errors if the Google API response structure varies.

Apply this diff to add safety checks:

         const betterResponse = {
             id: data.resourceName.split('/')[1],
             etag: data.etag,
             updateTime: data.metadata.sources[0].updateTime,
-            displayName: data.names[0].displayName,
-            givenName: data.names[0].givenName,
-            displayNameLastFirst: data.names[0].displayNameLastFirst,
-            unstructuredName: data.names[0].unstructuredName,
-            photoUrl: data.photos[0].url,
+            displayName: data.names?.[0]?.displayName,
+            givenName: data.names?.[0]?.givenName,
+            displayNameLastFirst: data.names?.[0]?.displayNameLastFirst,
+            unstructuredName: data.names?.[0]?.unstructuredName,
+            photoUrl: data.photos?.[0]?.url,
             memberships: data.memberships
         };
📜 Review details

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

📥 Commits

Reviewing files that changed from the base of the PR and between 027c9f3 and 690e2c1.

📒 Files selected for processing (6)
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js (1 hunks)
  • src/appmixer/googleContacts/core/FindContacts/component.json (3 hunks)
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js (1 hunks)
  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js (1 hunks)
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js (1 hunks)
  • src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (4)
  • src/appmixer/googleContacts/core/ListContactGroups/ListContactGroups.js
  • src/appmixer/googleContacts/core/FindContacts/component.json
  • src/appmixer/googleContacts/core/ListMyContacts/ListMyContacts.js
  • src/appmixer/googleContacts/core/ListOtherContacts/ListOtherContacts.js
🧰 Additional context used
📓 Path-based instructions (4)
`src/appmixer/**`: Use `src/appmixer` for source code of connectors.

src/appmixer/**: Use src/appmixer for source code of connectors.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js
`src/appmixer/*/core/*/*.js`: Behavior files for components must be JavaScript f...

src/appmixer/*/core/*/*.js: Behavior files for components must be JavaScript files named after the component and located in the corresponding component folder under core.
When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in context.httpRequest calls.
Do not check for required properties in the receive function of behavior files; required properties are validated by the input schema in component.json.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js
`**/*.js`: Add one empty line after function definition. Use 4 spaces for indentation.

**/*.js: Add one empty line after function definition.
Use 4 spaces for indentation.

📄 Source: CodeRabbit Inference Engine (.github/copilot-instructions.md)

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js
`src/appmixer/**/*.js`: Not necessary to add try/catch blocks in their `receive`...

src/appmixer/**/*.js: Not necessary to add try/catch blocks in their receive function. Appmixer engine automatically handles any exceptions that originate in these async functions.

The directive "use strict"; is desirable here

⚙️ Source: CodeRabbit Configuration File

List of files the instruction was applied to:

  • src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js
  • src/appmixer/googleContacts/core/FindContacts/FindContacts.js
🧠 Learnings (1)
src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js (1)
Learnt from: CR
PR: clientIO/appmixer-connectors#0
File: .github/copilot-instructions.md:0-0
Timestamp: 2025-06-30T09:09:52.832Z
Learning: Applies to src/appmixer/*/core/*/*.js : When adding a new field to a component, update the corresponding behavior JS file to handle the new field, especially in `context.httpRequest` calls.
🔇 Additional comments (3)
src/appmixer/googleContacts/core/UpdateContact/UpdateContact.js (1)

48-48: LGTM! Correct API field name usage.

The change from emails to emailAddresses properly aligns with the Google People API field naming conventions and uses the correctly processed variable.

src/appmixer/googleContacts/core/FindContacts/FindContacts.js (2)

23-23: LGTM: API parameter addition is correct.

The sources parameter correctly specifies the contact source type for the Google People API's searchContacts endpoint.


30-32: LGTM: Response structure update is correct.

The change from data.connections to data.results correctly reflects the updated Google People API response structure.

@ZbynekPelunek ZbynekPelunek requested a review from vtalas July 11, 2025 13:46
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.

Google Contacts (new)
2 participants
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy