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

Record business_platform_id not partner_id in remaining cases #5138

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

amcaplan
Copy link
Contributor

@amcaplan amcaplan commented Dec 22, 2024

WHY are these changes introduced?

Fixes https://github.com/Shopify/develop-app-inner-loop/issues/2025

Prerequisite here

WHAT is this pull request doing?

  • Introduces organization source tracking in CLI metadata and analytics
  • Updates environment and info commands to include organization source information
  • Adds organization source as a required property for developer platform clients, as sometimes that's all we have to go on (if we haven't yet fetched the org)
  • Ensures consistent organization source handling across Partners and Business Platform clients

How to test your changes?

  1. Run shopify app env pull with both Partners and Business Platform apps
  2. Run shopify app info with both Partners and Business Platform apps
  3. Verify metadata includes correct organization source in analytics

Measuring impact

  • Existing analytics will cater for this addition

Checklist

  • I've considered possible cross-platform impacts (Mac, Linux, Windows)
  • I've considered possible documentation changes

@amcaplan amcaplan marked this pull request as ready for review December 22, 2024 19:20
@amcaplan amcaplan requested a review from a team as a code owner December 22, 2024 19:20
Copy link
Contributor

github-actions bot commented Dec 22, 2024

Coverage report

St.
Category Percentage Covered / Total
🟡 Statements
75.14% (+0% 🔼)
8868/11802
🟡 Branches
70.29% (-0.02% 🔻)
4309/6130
🟡 Functions
75.06% (-0.01% 🔻)
2317/3087
🟡 Lines
75.71% (+0.01% 🔼)
8384/11074
Show files with reduced coverage 🔻
St.
File Statements Branches Functions Lines
🟡
... / context.ts
71.3% (+0.54% 🔼)
61.67% (-0.4% 🔻)
73.91%
73.91% (+0.58% 🔼)
🟢
... / app-event-watcher.ts
93.83% (-1.23% 🔻)
86.49% (-2.7% 🔻)
90.48% 98.61%

Test suite run success

1999 tests passing in 904 suites.

Report generated by 🧪jest coverage report action from 0aedc84

Copy link
Contributor

We detected some changes at packages/*/src and there are no updates in the .changeset.
If the changes are user-facing, run "pnpm changeset add" to track your changes and include them in the next release CHANGELOG.

@amcaplan amcaplan force-pushed the make-organization-source-required branch from 9ebb294 to e746586 Compare December 22, 2024 19:24
@amcaplan amcaplan force-pushed the report-BP-id-to-analytics-in-all-cases branch 2 times, most recently from 4a65bd2 to 4861084 Compare December 22, 2024 19:31
@amcaplan amcaplan force-pushed the make-organization-source-required branch from e746586 to 71e4c8e Compare January 6, 2025 13:56
@amcaplan amcaplan force-pushed the report-BP-id-to-analytics-in-all-cases branch from 4861084 to 52e68e1 Compare January 6, 2025 13:56
Copy link
Contributor

github-actions bot commented Jan 6, 2025

Differences in type declarations

We detected differences in the type declarations generated by Typescript for this branch compared to the baseline ('main' branch). Please, review them to ensure they are backward-compatible. Here are some important things to keep in mind:

  • Some seemingly private modules might be re-exported through public modules.
  • If the branch is behind main you might see odd diffs, rebase main into this branch.

New type declarations

We found no new type declarations in this PR

Existing type declarations

packages/cli-kit/dist/public/node/monorail.d.ts
@@ -16,6 +16,7 @@ export interface Schemas {
             env_plugin_installed_all?: Optional<string>;
         };
         public: {
+            business_platform_id?: Optional<number>;
             partner_id?: Optional<number>;
             command: string;
             project_type?: Optional<string>;
packages/cli-kit/dist/public/node/plugins.d.ts
@@ -16,7 +16,7 @@ import { Config, Interfaces } from '@oclif/core';
  * @returns A dictionary of plug-in names to the response from the hook.
  */
 export declare function fanoutHooks<TPluginMap extends HookReturnsPerPlugin, TEvent extends string & keyof TPluginMap>(config: Interfaces.Config, event: TEvent, options: TPluginMap[typeof event]['options'], timeout?: number): Promise<Partial<TPluginMap[typeof event]['pluginReturns']>>;
-type AppSpecificMonorailFields = PickByPrefix<MonorailEventPublic, 'app_', 'project_type' | 'api_key' | 'partner_id'> & PickByPrefix<MonorailEventPublic, 'cmd_extensions_'> & PickByPrefix<MonorailEventPublic, 'cmd_scaffold_'>;
+type AppSpecificMonorailFields = PickByPrefix<MonorailEventPublic, 'app_', 'project_type' | 'api_key' | 'partner_id' | 'business_platform_id'> & PickByPrefix<MonorailEventPublic, 'cmd_extensions_'> & PickByPrefix<MonorailEventPublic, 'cmd_scaffold_'>;
 type AppSpecificSensitiveMonorailFields = PickByPrefix<MonorailEventSensitive, 'app_'>;
 export interface HookReturnsPerPlugin extends HookReturnPerTunnelPlugin {
     public_command_metadata: {

apiKey: configuration.client_id,
organizationId: configuration.organization_id || '0',
},
configuration.organization_id ? OrganizationSource.BusinessPlatform : OrganizationSource.Partners,
Copy link
Contributor

Choose a reason for hiding this comment

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

Do we have the org or any info we can pass to this function to not rely on checking if there is an ID in the config?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah, I'm not really thrilled with this, but all we have to work with is the app configuration itself. We might eventually move to a system where we remove the organization_id and instead hit the backends to find which is the correct one, but for now I think this is what we've got.

Copy link
Contributor

Choose a reason for hiding this comment

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

Actually, I think we can remove this "logMetadata" completely.
The config use command will call linkedAppContext after this, which already handles the metadata for org+app.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It's also used in getAppConfigurationState here, will that be a problem?

Copy link
Contributor

Choose a reason for hiding this comment

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

No that's ok, the linkedAppContext handles the metadata after loading the app, so is safe to rely on that as a single place for all api-key/org metadata

Base automatically changed from make-organization-source-required to main January 7, 2025 20:03
@amcaplan amcaplan force-pushed the report-BP-id-to-analytics-in-all-cases branch from 52e68e1 to 0aedc84 Compare January 9, 2025 15:30
@amcaplan amcaplan requested a review from isaacroldan January 9, 2025 15:31
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.

2 participants