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

[module-detection] statsig-io/js-client #86

Open
0xdevalias opened this issue Dec 24, 2023 · 0 comments
Open

[module-detection] statsig-io/js-client #86

0xdevalias opened this issue Dec 24, 2023 · 0 comments
Labels
enhancement New feature or request

Comments

@0xdevalias
Copy link

This relates to the 'module-detection' feature described in the following issue:

Overview

  • https://github.com/statsig-io/js-client
    • Statsig
      Statsig JavaScript Client SDK

    • The JavaScript SDK for single user client environments.

    • Statsig helps you move faster with feature gates (feature flags), and/or dynamic configs. It also allows you to run A/B/n tests to validate your new features and understand their impact on your KPIs.

Code

Unminifying this source (Ref), module-56340.js:

Note: Not including the unminified examples here currently as the file is quite large

Searching for some of the symbols from module-56340.js on GitHub code search:

Of those results, this looks the most promising:


Using the madge CLI/lib that I mentioned in another issue (Ref), I was able to automatically find/generate a graph of all of the module dependencies related to this.

I narrowed down on this by first creating a larger image of all the dependencies in a chunk/etc, finding something that looked like a lib like this, then running it again on that module.

Note also that I haven't manually checked through all of the modules mentioned here yet.

.madgerc
// See: https://github.com/pahen/madge#configuration
{
  "fileExtensions": ["js"],
  "detectiveOptions": {
    "es6": {
      "mixedImports": true,
      "skipTypeImports": true
    },
    "ts": {
      "mixedImports": true,
      "skipTypeImports": true
    }
  }
}
⇒ npx madge --image 56340.svg stage3-unminified/pages/_app/module-56340.js

56340

(blue has dependencies, green doesn't)

madge --json output
⇒ npm run-script madge:json stage3-unminified/pages/_app/module-56340.js
> [email protected] madge:json
> f() { MODULE_PATH="$1"; npx madge --json "$MODULE_PATH"; }; f stage3-unminified/pages/_app/module-56340.js

{
  "module-12229.js": [],
  "module-13290.js": [
    "module-44675.js"
  ],
  "module-13957.js": [
    "module-13290.js",
    "module-27046.js"
  ],
  "module-25609.js": [],
  "module-27046.js": [],
  "module-3009.js": [
    "module-13957.js",
    "module-49787.js"
  ],
  "module-30227.js": [
    "module-13957.js",
    "module-5502.js",
    "module-98480.js"
  ],
  "module-44675.js": [],
  "module-49787.js": [],
  "module-51475.js": [],
  "module-5502.js": [],
  "module-56340.js": [
    "module-12229.js",
    "module-25609.js",
    "module-3009.js",
    "module-30227.js",
    "module-51475.js",
    "module-5502.js"
  ],
  "module-98480.js": []
}
@pionxzh pionxzh added the enhancement New feature or request label Dec 24, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants