systemlink-cli 1.4.3__tar.gz → 1.4.6__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/PKG-INFO +1 -1
  2. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/pyproject.toml +1 -1
  3. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/_version.py +1 -1
  4. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/demo-complete-workflow/README.md +1 -3
  5. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/platform.py +4 -52
  6. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/systemlink-webapp/SKILL.md +47 -34
  7. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/user_click.py +1 -1
  8. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/LICENSE +0 -0
  9. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/dff-editor/editor.js +0 -0
  10. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/dff-editor/index.html +0 -0
  11. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/__init__.py +0 -0
  12. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/__main__.py +0 -0
  13. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/asset_click.py +0 -0
  14. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/cli_formatters.py +0 -0
  15. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/cli_utils.py +0 -0
  16. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/comment_click.py +0 -0
  17. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/completion_click.py +0 -0
  18. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/config.py +0 -0
  19. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/config_click.py +0 -0
  20. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/dff_click.py +0 -0
  21. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/dff_decorators.py +0 -0
  22. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/example_click.py +0 -0
  23. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/example_loader.py +0 -0
  24. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/example_provisioner.py +0 -0
  25. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/README.md +0 -0
  26. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/_schema/schema-v1.0.json +0 -0
  27. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/demo-complete-workflow/config.yaml +0 -0
  28. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/demo-test-plans/README.md +0 -0
  29. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/demo-test-plans/config.yaml +0 -0
  30. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/exercise-5-1-parametric-insights/README.md +0 -0
  31. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/exercise-5-1-parametric-insights/config.yaml +0 -0
  32. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/exercise-7-1-test-plans/README.md +0 -0
  33. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/exercise-7-1-test-plans/config.yaml +0 -0
  34. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/README.md +0 -0
  35. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/config.yaml +0 -0
  36. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/notebooks/SpecAnalysis_ComplianceCalculation.ipynb +0 -0
  37. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/notebooks/SpecComplianceCalculation.ipynb +0 -0
  38. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/notebooks/SpecfileExtractionAndIngestion.ipynb +0 -0
  39. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/examples/spec-compliance-notebooks/spec_template.xlsx +0 -0
  40. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/feed_click.py +0 -0
  41. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/file_click.py +0 -0
  42. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/function_click.py +0 -0
  43. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/function_templates.py +0 -0
  44. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/main.py +0 -0
  45. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/mcp_click.py +0 -0
  46. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/mcp_server.py +0 -0
  47. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/notebook_click.py +0 -0
  48. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/policy_click.py +0 -0
  49. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/policy_utils.py +0 -0
  50. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/profiles.py +0 -0
  51. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/response_handlers.py +0 -0
  52. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/routine_click.py +0 -0
  53. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skill_click.py +0 -0
  54. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/slcli/SKILL.md +0 -0
  55. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/slcli/references/analysis-recipes.md +0 -0
  56. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/slcli/references/filtering.md +0 -0
  57. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/systemlink-webapp/references/deployment.md +0 -0
  58. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/systemlink-webapp/references/nimble-angular.md +0 -0
  59. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/skills/systemlink-webapp/references/systemlink-services.md +0 -0
  60. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/ssl_trust.py +0 -0
  61. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/system_click.py +0 -0
  62. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/table_utils.py +0 -0
  63. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/tag_click.py +0 -0
  64. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/templates_click.py +0 -0
  65. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/testmonitor_click.py +0 -0
  66. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/universal_handlers.py +0 -0
  67. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/utils.py +0 -0
  68. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/web_editor.py +0 -0
  69. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/webapp_click.py +0 -0
  70. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/workflow_preview.py +0 -0
  71. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/workflows_click.py +0 -0
  72. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/workitem_click.py +0 -0
  73. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/workspace_click.py +0 -0
  74. {systemlink_cli-1.4.3 → systemlink_cli-1.4.6}/slcli/workspace_utils.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: systemlink-cli
3
- Version: 1.4.3
3
+ Version: 1.4.6
4
4
  Summary: SystemLink Integrator CLI - cross-platform CLI for SystemLink workflows and templates.
5
5
  License-File: LICENSE
6
6
  Author: Fred Visser
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "systemlink-cli"
3
- version = "1.4.3"
3
+ version = "1.4.6"
4
4
  description = "SystemLink Integrator CLI - cross-platform CLI for SystemLink workflows and templates."
5
5
  authors = ["Fred Visser <fred.visser@emerson.com>"]
6
6
  packages = [{ include = "slcli" }]
@@ -1,4 +1,4 @@
1
1
  """Version information for slcli."""
2
2
 
3
3
  # This file is auto-generated. Do not edit manually.
4
- __version__ = "1.4.3"
4
+ __version__ = "1.4.6"
@@ -303,9 +303,7 @@ slcli result list -w <workspace>
303
303
 
304
304
  ## Additional Resources
305
305
 
306
- - **SystemLink API Documentation**: https://dev-api.lifecyclesolutions.ni.com/
307
- - **Test Monitor Specs**: https://dev-api.lifecyclesolutions.ni.com/nitestmonitor/swagger/
308
- - **Work Item API**: https://dev-api.lifecyclesolutions.ni.com/niworkitem/swagger/
306
+ - **SystemLink API Documentation**: https://demo-api.lifecyclesolutions.ni.com/niapis/
309
307
  - **systemlink-cli GitHub**: https://github.com/ni/systemlink-cli
310
308
 
311
309
  ## Contact & Support
@@ -87,7 +87,6 @@ def detect_platform(api_url: str, api_key: str) -> str:
87
87
  Uses check_service_status to probe services and determine:
88
88
  - Platform type (SLE vs SLS)
89
89
  - Server reachability
90
- Falls back to URL pattern matching when probe is inconclusive.
91
90
 
92
91
  Args:
93
92
  api_url: The SystemLink API base URL
@@ -101,45 +100,6 @@ def detect_platform(api_url: str, api_key: str) -> str:
101
100
  return status["platform"]
102
101
 
103
102
 
104
- def _detect_platform_from_url(api_url: str) -> str:
105
- """Detect platform from URL pattern without making network requests.
106
-
107
- This is a lightweight detection for use when environment variables
108
- are set and we need quick platform detection.
109
-
110
- SLE (SystemLink Enterprise Cloud) URLs typically contain:
111
- - api.systemlink.io (production)
112
- - dev-api.lifecyclesolutions.ni.com (development)
113
- - demo-api.lifecyclesolutions.ni.com (demo)
114
-
115
- On-premises SystemLink Server (SLS) instances may use custom domains
116
- or even *.systemlink.io subdomains (like base.systemlink.io).
117
-
118
- Args:
119
- api_url: The SystemLink API base URL
120
-
121
- Returns:
122
- Platform identifier: PLATFORM_SLE or PLATFORM_SLS.
123
- Note: This function never returns PLATFORM_UNKNOWN - it defaults to SLS.
124
- """
125
- api_url_lower = api_url.lower()
126
-
127
- # SLE cloud service has specific URL patterns
128
- sle_patterns = [
129
- "api.systemlink.io", # SLE production
130
- "-api.lifecyclesolutions.ni.com", # SLE dev/demo with -api suffix
131
- "dev-api.lifecyclesolutions",
132
- "demo-api.lifecyclesolutions",
133
- ]
134
- for pattern in sle_patterns:
135
- if pattern in api_url_lower:
136
- return PLATFORM_SLE
137
-
138
- # Default to SLS for on-premises/custom URLs
139
- # This includes on-prem servers that may use *.systemlink.io subdomains
140
- return PLATFORM_SLS
141
-
142
-
143
103
  @lru_cache(maxsize=1)
144
104
  def get_platform() -> str:
145
105
  """Get the current platform from stored configuration or environment.
@@ -147,8 +107,7 @@ def get_platform() -> str:
147
107
  Detection priority:
148
108
  1. SYSTEMLINK_PLATFORM environment variable (explicit, most reliable)
149
109
  2. Stored platform from keyring config (set during login via endpoint probing)
150
- 3. URL pattern matching (fallback, less reliable)
151
- 4. Return PLATFORM_UNKNOWN if all methods fail
110
+ 3. Return PLATFORM_UNKNOWN if no explicit or stored platform is available
152
111
 
153
112
  Note: Results are cached for performance. Use clear_platform_cache() to reset.
154
113
 
@@ -169,12 +128,6 @@ def get_platform() -> str:
169
128
  if platform in (PLATFORM_SLE, PLATFORM_SLS):
170
129
  return platform
171
130
 
172
- # Priority 3: URL pattern matching (fallback, less reliable)
173
- # Only used when env vars are set but no explicit platform is provided
174
- env_url = os.environ.get("SYSTEMLINK_API_URL")
175
- if env_url:
176
- return _detect_platform_from_url(env_url)
177
-
178
131
  return PLATFORM_UNKNOWN
179
132
 
180
133
 
@@ -349,8 +302,8 @@ def check_service_status(api_url: str, api_key: str) -> Dict[str, Any]:
349
302
  ("ok", "unauthorized", "not_found", "error", "unreachable")
350
303
  - file_query_endpoint: selected file query endpoint, if available
351
304
  - elasticsearch_available: bool | None - whether search-files is available
352
- - platform: detected platform string (PLATFORM_SLE, PLATFORM_SLS,
353
- PLATFORM_UNREACHABLE)
305
+ - platform: detected platform string (PLATFORM_SLE, PLATFORM_SLS,
306
+ PLATFORM_UNREACHABLE, PLATFORM_UNKNOWN)
354
307
  """
355
308
  headers = {
356
309
  "x-ni-api-key": api_key,
@@ -425,8 +378,7 @@ def check_service_status(api_url: str, api_key: str) -> Dict[str, Any]:
425
378
  elif workorder_status == "not_found":
426
379
  platform = PLATFORM_SLS
427
380
  else:
428
- # Fall back to URL pattern matching
429
- platform = _detect_platform_from_url(api_url)
381
+ platform = PLATFORM_UNKNOWN
430
382
 
431
383
  file_capability = get_file_query_capability(api_url, api_key)
432
384
  services["File"] = file_capability["status"]
@@ -30,14 +30,14 @@ Ask before generating any code:
30
30
  3. **Starting point** — Fresh Angular project, or do they have existing code?
31
31
  4. **Auth context** — Will the app run on the same SystemLink instance it calls (same-origin cookie auth), or does it need an API key for a remote server?
32
32
 
33
- You do NOT need to ask about Angular version or Nimble versions — always use the latest (Angular 19, @ni/nimble-angular latest).
33
+ You do NOT need to ask about Angular version or Nimble versions — always use Angular 20 and the latest compatible `@ni/nimble-angular`.
34
34
 
35
35
  ---
36
36
 
37
37
  ## Step 2: Scaffold the Angular project
38
38
 
39
39
  ```bash
40
- npx -y @angular/cli@latest new <app-name> --routing --style=scss --skip-git --no-standalone
40
+ npx -y @angular/cli@20 new <app-name> --routing --style=scss --skip-git --no-standalone
41
41
  cd <app-name>
42
42
  npm install @ni/nimble-angular
43
43
  ```
@@ -58,22 +58,23 @@ npm install @ni/systemlink-clients-ts
58
58
 
59
59
  ### Available services (import paths)
60
60
 
61
- | Service | Import path | `baseUrl` (append to `window.location.origin`) |
62
- |---------|-------------|------------------------------------------------|
63
- | Feeds | `@ni/systemlink-clients-ts/feeds` | (none — spec paths already include `/nifeed/v1/`) |
64
- | Tags | `@ni/systemlink-clients-ts/tags` | `+ '/nitag'` |
65
- | User / Workspaces | `@ni/systemlink-clients-ts/user` | `+ '/niuser/v1'` |
66
- | Web Application | `@ni/systemlink-clients-ts/web-application` | `+ '/niapp/v1'` |
67
- | File Ingestion | `@ni/systemlink-clients-ts/file-ingestion` | `+ '/nifile'` |
68
- | Test Monitor | `@ni/systemlink-clients-ts/test-monitor` | `+ '/nitest'` |
69
- | Asset Management | `@ni/systemlink-clients-ts/asset-management` | `+ '/niapm'` |
70
- | Work Items | `@ni/systemlink-clients-ts/work-item` | `+ '/niworkorder'` |
71
- | Systems Management | `@ni/systemlink-clients-ts/systems-management` | `+ '/nisysmgmt'` |
72
- | Notebooks | `@ni/systemlink-clients-ts/notebook` | `+ '/ninotebook'` |
61
+ | Service | Import path | Client `baseUrl` |
62
+ |---------|-------------|------------------|
63
+ | Feeds | `@ni/systemlink-clients-ts/feeds` | `window.location.origin` |
64
+ | Tags | `@ni/systemlink-clients-ts/tags` | `window.location.origin + '/nitag'` |
65
+ | User / Workspaces | `@ni/systemlink-clients-ts/user` | `window.location.origin + '/niuser/v1'` |
66
+ | Web Application | `@ni/systemlink-clients-ts/web-application` | `window.location.origin + '/niapp/v1'` |
67
+ | File Ingestion | `@ni/systemlink-clients-ts/file-ingestion` | `window.location.origin + '/nifile'` |
68
+ | Test Monitor | `@ni/systemlink-clients-ts/test-monitor` | `window.location.origin + '/nitestmonitor'` |
69
+ | Asset Management | `@ni/systemlink-clients-ts/asset-management` | `window.location.origin` |
70
+ | Work Items | `@ni/systemlink-clients-ts/work-item` | `window.location.origin` |
71
+ | Work Orders | `@ni/systemlink-clients-ts/work-order` | `window.location.origin` |
72
+ | Systems Management | `@ni/systemlink-clients-ts/systems-management` | `window.location.origin` |
73
+ | Notebooks | `@ni/systemlink-clients-ts/notebook` | `window.location.origin` |
73
74
 
74
75
  The client factory for each service lives at `@ni/systemlink-clients-ts/<service>/client`.
75
76
 
76
- > **Base URL gotcha:** Each generated client's path depends on its OpenAPI spec base. For **Feeds**, the spec base is `https://host/` and operation paths already include `/nifeed/v1/...`, so use `baseUrl: window.location.origin` with no suffix. For all other services the spec root matches the service prefix (`https://host/nitag`, `https://host/niuser/v1`, etc.), so set `baseUrl: window.location.origin + '/<prefix>'` as shown above.
77
+ > **Base URL gotcha:** Verify the generated operation URLs, not just the service name. In the published `@ni/systemlink-clients-ts` package, `tags` uses `/v2/...` with `baseUrl: origin + '/nitag'`, `user` uses `/users` and `/workspaces` with `baseUrl: origin + '/niuser/v1'`, `web-application` uses `/webapps/...` with `baseUrl: origin + '/niapp/v1'`, `file-ingestion` uses `/v1/...` with `baseUrl: origin + '/nifile'`, and `test-monitor` uses `/v2/...` with `baseUrl: origin + '/nitestmonitor'`. Services like `feeds`, `asset-management`, `systems-management`, `work-item`, `work-order`, and `notebook` already include `/nifeed`, `/niapm`, `/nisysmgmt`, `/niworkitem`, `/niworkorder`, or `/ninotebook` in each operation path, so those clients should use `baseUrl: window.location.origin`.
77
78
 
78
79
  > **SDK type mismatch fallback:** If a generated SDK function causes `InputFieldValidationError`, verify the actual request body the server expects with a raw `curl` POST. Sometimes the generated types wrap the body in a `{ request: { ... } }` envelope that the server does not accept (or expect a flat body the type shows as nested). Use direct `fetch` with a manually constructed body as a reliable fallback when the SDK types are wrong.
79
80
 
@@ -390,10 +391,18 @@ const { data, error } = await buildClient().post<MyResponse, unknown>({
390
391
  Always compute the base URL from `window.location.origin` — never hardcode a hostname:
391
392
 
392
393
  ```typescript
393
- const BASE_URL = `${window.location.origin}/nitag`; // Tags
394
- const BASE_URL = `${window.location.origin}/nitest`; // Test Monitor
395
- const BASE_URL = `${window.location.origin}/niapm`; // Asset Management
396
- const BASE_URL = `${window.location.origin}/nifile`; // File Ingestion
394
+ const tagsBaseUrl = `${window.location.origin}/nitag`; // tags.js -> /v2/...
395
+ const userBaseUrl = `${window.location.origin}/niuser/v1`; // user.js -> /users, /workspaces
396
+ const webAppBaseUrl = `${window.location.origin}/niapp/v1`; // web-application.js -> /webapps/...
397
+ const fileIngestionBaseUrl = `${window.location.origin}/nifile`; // file-ingestion.js -> /v1/...
398
+ const testMonitorBaseUrl = `${window.location.origin}/nitestmonitor`; // test-monitor.js -> /v2/...
399
+
400
+ const feedsBaseUrl = window.location.origin; // feeds.js -> /nifeed/v1/...
401
+ const assetBaseUrl = window.location.origin; // asset-management.js -> /niapm/v1/...
402
+ const systemsBaseUrl = window.location.origin; // systems-management.js -> /nisysmgmt/v1/...
403
+ const workItemBaseUrl = window.location.origin; // work-item.js -> /niworkitem/v1/...
404
+ const workOrderBaseUrl = window.location.origin; // work-order.js -> /niworkorder/v1/...
405
+ const notebookBaseUrl = window.location.origin; // notebook.js -> /ninotebook/v1/...
397
406
  ```
398
407
 
399
408
  ### Authentication
@@ -608,7 +617,7 @@ node_modules/.bin/ng build --configuration production --output-path dist/<app-na
608
617
  ```
609
618
 
610
619
  - Do **not** pass `--base-href` — that would re-introduce the `<base>` element
611
- - Output goes to `dist/<app-name>/browser/` (Angular 19)
620
+ - Output goes to `dist/<app-name>/browser/` (Angular 20)
612
621
 
613
622
  If you hit budget errors, increase limits in `angular.json`:
614
623
 
@@ -647,8 +656,8 @@ Save the returned webapp ID — you'll need it for every subsequent redeploy.
647
656
  | CSP `unsafe-inline` error | Beasties injects `onload` in style tags | `inlineCritical: false` in angular.json optimization |
648
657
  | App stays light inside dark SystemLink shell | Theme-aware aliases defined on `:root` or embedded app not watching host provider | Define color/shadow aliases on `nimble-theme-provider`; sync `currentTheme` from parent provider |
649
658
  | `theme="dark"` is set but colors still look light | Checked the attribute only, not the resolved tokens | Inspect `getComputedStyle(themeProvider).getPropertyValue('--ni-nimble-application-background-color')` in the hosted iframe |
650
- | CORS / status 0 | `basePath` points to different origin | Set `basePath = window.location.origin + '/service-prefix'` |
651
- | 404 on API calls | Missing service prefix in base URL | e.g., `/nitag` not just `window.location.origin`; Feeds service paths already include `/nifeed/v1/` so use origin alone |
659
+ | CORS / status 0 | `baseUrl` points to the wrong origin or wrong service root | Match the generated client: for example `test-monitor` uses `${window.location.origin}/nitestmonitor`, while `work-item` uses `window.location.origin` |
660
+ | 404 on API calls | Wrong `baseUrl` for the selected client | Only `tags`, `user`, `web-application`, `file-ingestion`, and `test-monitor` need a prefixed `baseUrl`. `feeds`, `asset-management`, `systems-management`, `work-item`, `work-order`, and `notebook` use bare origin because their operation URLs already include the service prefix |
652
661
  | `InputFieldValidationError` on API call | SDK-generated request body has wrong shape | Inspect raw API; the generated type may add or omit a `request: {}` wrapper. Use direct `fetch` with manually constructed body |
653
662
  | nimble-dialog does not open | `*ngIf` destroys element before `ViewChild` can resolve | Remove `*ngIf` from the dialog element; use `@ViewChild` + `ElementRef` and call `nativeElement.show()` / `nativeElement.close()` |
654
663
  | Icon module import fails | Icon sub-path `@ni/nimble-angular/icons/...` does not exist | Import icon modules from the main `@ni/nimble-angular` barrel only |
@@ -670,18 +679,22 @@ If the host and iframe are same-origin, Playwright or DevTools can inspect `ifra
670
679
 
671
680
  ---
672
681
 
673
- ## Known SystemLink service prefixes
674
-
675
- | Service | URL prefix |
676
- |---------|-----------|
677
- | Tag Historian | `/nitag/v2` |
678
- | Test Monitor | `/nitest` |
679
- | Asset Management | `/niapm` |
680
- | Systems Management | `/nisysmgmt` |
681
- | Work Orders | `/niworkorder` |
682
- | Feeds (Package Manager) | `/nifeed` |
683
- | Files | `/nifile` |
684
- | Notebooks | `/ninotebook` |
682
+ ## Known SystemLink client base URLs
683
+
684
+ | Service | Client `baseUrl` |
685
+ |---------|------------------|
686
+ | Tag Historian | `window.location.origin + '/nitaghistorian'` |
687
+ | Tags | `window.location.origin + '/nitag'` |
688
+ | User / Workspaces | `window.location.origin + '/niuser/v1'` |
689
+ | Web Application | `window.location.origin + '/niapp/v1'` |
690
+ | File Ingestion | `window.location.origin + '/nifile'` |
691
+ | Test Monitor | `window.location.origin + '/nitestmonitor'` |
692
+ | Asset Management | `window.location.origin` |
693
+ | Systems Management | `window.location.origin` |
694
+ | Work Items | `window.location.origin` |
695
+ | Work Orders | `window.location.origin` |
696
+ | Feeds (Package Manager) | `window.location.origin` |
697
+ | Notebooks | `window.location.origin` |
685
698
 
686
699
  See `references/systemlink-services.md` for full API details.
687
700
 
@@ -423,7 +423,7 @@ def _query_all_users(
423
423
  - Uses 'status = "active"' for filtering disabled users
424
424
 
425
425
  TODO: Follow this pattern for other API clients that support continuation tokens
426
- Reference: https://dev-api.lifecyclesolutions.ni.com/niuser/swagger/v1/niuser.yaml
426
+ Reference: https://demo-api.lifecyclesolutions.ni.com/niuser/swagger/v1/niuser.yaml
427
427
 
428
428
  Args:
429
429
  filter_str: Filter expression for users
File without changes