-
Notifications
You must be signed in to change notification settings - Fork 3
feat: add-recognize-proxy #580
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
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,24 @@ | ||
| import baseConfig from '../../eslint.config.mjs'; | ||
|
|
||
| export default [ | ||
| { | ||
| ignores: [ | ||
| 'node_modules', | ||
| '*.md', | ||
| 'LICENSE', | ||
| '.swcrc', | ||
| '.babelrc', | ||
| '.env*', | ||
| '.bin', | ||
| 'dist', | ||
| '.eslintignore', | ||
| '*.html', | ||
| '*.svg', | ||
| '*.css', | ||
| 'public', | ||
| '*.json', | ||
| '*.d.ts', | ||
| ], | ||
| }, | ||
| ...baseConfig, | ||
| ]; | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,18 @@ | ||
| { | ||
| "name": "@forgerock/recognize-app", | ||
| "version": "0.0.1", | ||
| "private": true, | ||
| "scripts": { | ||
| "build": "pnpm nx nxBuild", | ||
| "lint": "pnpm nx nxLint", | ||
| "preview": "pnpm nx nxPreview", | ||
| "serve": "pnpm nx nxServe" | ||
| }, | ||
| "dependencies": { | ||
| "@forgerock/journey-client": "workspace:*", | ||
| "@forgerock/recognize": "workspace:*" | ||
| }, | ||
| "nx": { | ||
| "tags": ["scope:e2e"] | ||
| } | ||
| } |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,14 @@ | ||
| <!doctype html> | ||
| <html lang="en"> | ||
| <head> | ||
| <meta charset="UTF-8" /> | ||
| <meta name="viewport" content="width=device-width, initial-scale=1.0" /> | ||
| <title>Recognize E2E Test Index | Ping Identity JavaScript SDK</title> | ||
| </head> | ||
| <body> | ||
| <div id="app"> | ||
| <h2>Recognize E2E Test Index | Ping Identity JavaScript SDK</h2> | ||
| </div> | ||
| <script type="module" src="index.ts"></script> | ||
| </body> | ||
| </html> |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1 @@ | ||
| import './styles.css'; |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,11 @@ | ||
| body { | ||
| font-family: | ||
| -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif; | ||
| margin: 0; | ||
| padding: 2rem; | ||
| } | ||
|
|
||
| #app { | ||
| max-width: 960px; | ||
| margin: 0 auto; | ||
| } |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,29 @@ | ||
| { | ||
| "extends": "../../tsconfig.base.json", | ||
| "compilerOptions": { | ||
| "outDir": "dist", | ||
| "types": ["node"], | ||
| "rootDir": "src", | ||
| "module": "esnext", | ||
| "moduleResolution": "bundler", | ||
| "tsBuildInfoFile": "dist/tsconfig.app.tsbuildinfo" | ||
| }, | ||
| "exclude": [ | ||
| "out-tsc", | ||
| "dist", | ||
| "src/**/*.spec.ts", | ||
| "src/**/*.test.ts", | ||
| "eslint.config.js", | ||
| "eslint.config.cjs", | ||
| "eslint.config.mjs" | ||
| ], | ||
| "include": ["src/**/*.ts"], | ||
| "references": [ | ||
| { | ||
| "path": "../../packages/recognize/tsconfig.lib.json" | ||
| }, | ||
| { | ||
| "path": "../../packages/journey-client/tsconfig.lib.json" | ||
| } | ||
| ] | ||
| } |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,10 @@ | ||
| { | ||
| "extends": "../../tsconfig.base.json", | ||
| "files": [], | ||
| "include": [], | ||
| "references": [ | ||
| { | ||
| "path": "./tsconfig.app.json" | ||
| } | ||
| ] | ||
| } |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,33 @@ | ||
| import { defineConfig } from 'vite'; | ||
| import { dirname, resolve } from 'path'; | ||
| import { fileURLToPath } from 'url'; | ||
|
|
||
| const __dirname = dirname(fileURLToPath(import.meta.url)); | ||
|
|
||
| export default defineConfig(() => ({ | ||
| root: __dirname + '/src', | ||
| cacheDir: '../../node_modules/.vite/e2e/recognize-app', | ||
| publicDir: __dirname + '/public', | ||
|
Comment on lines
+8
to
+10
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Point With 🛠️ Proposed fix- publicDir: __dirname + '/public',
+ publicDir: resolve(__dirname, 'src/public'),🤖 Prompt for AI Agents |
||
| server: { | ||
| port: 8443, | ||
| host: 'localhost', | ||
| }, | ||
| preview: { | ||
| port: 8443, | ||
| host: 'localhost', | ||
| }, | ||
| plugins: [], | ||
| build: { | ||
| outDir: __dirname + '/dist', | ||
| emptyOutDir: true, | ||
| reportCompressedSize: true, | ||
| rollupOptions: { | ||
| input: { | ||
| main: resolve(__dirname + '/src', 'index.html'), | ||
| }, | ||
| output: { | ||
| entryFileNames: '[name]/main.js', | ||
| }, | ||
| }, | ||
| }, | ||
| })); | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,11 @@ | ||
| # recognize | ||
|
|
||
| This library was generated with [Nx](https://nx.dev). | ||
|
|
||
| ## Building | ||
|
|
||
| Run `nx build recognize` to build the library. | ||
|
|
||
| ## Running unit tests | ||
|
|
||
| Run `nx test recognize` to execute the unit tests via [Vitest](https://vitest.dev/). |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,25 @@ | ||
| import baseConfig from '../../eslint.config.mjs'; | ||
|
|
||
| export default [ | ||
| ...baseConfig, | ||
| { | ||
| files: ['**/*.json'], | ||
| rules: { | ||
| '@nx/dependency-checks': [ | ||
| 'error', | ||
| { | ||
| ignoredFiles: [ | ||
| '{projectRoot}/eslint.config.{js,cjs,mjs,ts,cts,mts}', | ||
| '{projectRoot}/vite.config.{js,ts,mjs,mts}', | ||
| ], | ||
| }, | ||
| ], | ||
| }, | ||
| languageOptions: { | ||
| parser: await import('jsonc-eslint-parser'), | ||
| }, | ||
| }, | ||
| { | ||
| ignores: ['**/out-tsc'], | ||
| }, | ||
| ]; |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,45 @@ | ||
| { | ||
| "name": "@forgerock/recognize", | ||
| "version": "0.0.1", | ||
| "private": true, | ||
| "type": "module", | ||
| "main": "./dist/src/index.js", | ||
| "module": "./dist/src/index.js", | ||
| "types": "./dist/src/index.d.ts", | ||
| "exports": { | ||
| "./package.json": "./package.json", | ||
| ".": { | ||
| "types": "./dist/src/index.d.ts", | ||
| "import": "./dist/src/index.js", | ||
| "default": "./dist/src/index.js" | ||
| } | ||
| }, | ||
| "dependencies": { | ||
| "tslib": "^2.3.0" | ||
| }, | ||
| "devDependencies": { | ||
| "@aracna/web-components": "^1.1.16" | ||
| }, | ||
|
Comment on lines
+17
to
+22
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🧩 Analysis chain🏁 Script executed: #!/bin/bash
set -euo pipefail
manifest="$(fd -a '^package\.json$' packages/recognize | head -n 1)"
sdk_dts="$(fd -a '^index\.d\.ts$' packages/recognize/src/lib/recognize-sdk | head -n 1)"
echo "Package manifest: $manifest"
jq '{dependencies, peerDependencies, devDependencies}' "$manifest"
echo
echo "External imports used by recognize-sdk declaration:"
rg -n "from '(@[^']+|[^./][^']*)'" "$sdk_dts" -o --replace '$1' | sort -uRepository: ForgeRock/ping-javascript-sdk Length of output: 1419 Add missing SDK dependencies to package.json. The copied 🤖 Prompt for AI Agents |
||
| "nx": { | ||
| "tags": ["scope:package"], | ||
| "targets": { | ||
| "build": { | ||
| "executor": "@nx/js:tsc", | ||
| "outputs": ["{options.outputPath}"], | ||
| "options": { | ||
| "outputPath": "packages/recognize/dist", | ||
| "main": "packages/recognize/src/index.ts", | ||
| "tsConfig": "packages/recognize/tsconfig.lib.json", | ||
| "generatePackageJson": false, | ||
| "assets": [ | ||
| { | ||
| "input": "packages/recognize/src/lib/recognize-sdk", | ||
| "glob": "**/*", | ||
| "output": "./src/lib/recognize-sdk" | ||
| } | ||
| ] | ||
| } | ||
| } | ||
| } | ||
| } | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1 @@ | ||
| export * from './lib/recognize.js'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧩 Analysis chain
🏁 Script executed:
Repository: ForgeRock/ping-javascript-sdk
Length of output: 102
🏁 Script executed:
Repository: ForgeRock/ping-javascript-sdk
Length of output: 438
🏁 Script executed:
Repository: ForgeRock/ping-javascript-sdk
Length of output: 237
🌐 Web query:
ESLint flat config ignore patterns glob semantics documentation💡 Result:
In ESLint flat config (eslint.config.js, default since v9), ignore patterns use minimatch glob syntax. They are specified in the ignores array within config objects. Global ignores (applied project-wide, skipping file traversal): Use a standalone object with only ignores or the globalIgnores helper from eslint/config. Example: import { globalIgnores } from "eslint/config"; export default [ globalIgnores(["/node_modules/", "dist/", ".git/"]), // other configs ]; Local ignores (apply only to that config object): Use ignores alongside files, rules, etc. Example: { files: ["/.js"], ignores: ["/.config.js"], rules: { /* ... / } } Glob semantics (minimatch): - recurses directories (e.g., /node_modules/ ignores all node_modules). - * matches non-/ chars. - ? single non-/ char. - dir/ matches only that dir (relative to config file location). - dir/ ignores dir + contents (no unignore inside). - dir// ignores contents but allows unignoring specific files. - !pattern negates (unignores). - Patterns ending / match dirs; others match files/dirs. - Defaults: ["/node_modules/", ".git/"]. - Resolution: Relative to eslint.config.js for globalIgnores; cwd for CLI --ignore-pattern. Unlike .eslintignore (gitignore-style), flat config uses strict minimatch (e.g., dist ignores only top-level dist, use /dist/ for recursive). Primary source: Official ESLint docs (https://eslint.org/docs/latest/use/configure/ignore).
Citations:
Make asset ignore globs recursive.
Patterns like
*.htmland*.cssmatch only root-level files in ESLint's flat config (using strict minimatch). Nested files such assrc/index.htmlandsrc/styles.csswill not be ignored, allowing the linter to process them despite being asset files.🛠️ Proposed fix
📝 Committable suggestion
🤖 Prompt for AI Agents