Skip to content

nokia/vscode-intent-manager

Repository files navigation

NOKIA Intent Manager vsCode extension

vsCode extension settings

This vsCode extension connects to Nokia NSP Intent Manager to facilitate Intent development and delivery.

Warning

Known Issues and Limitations:

  • Intent decorations are automatically updated by audit/sync methods to reduce server load. In some error scenarios the displayed alignment state does not reflect the server state. Consider to trigger a manual resync to reload alignment states from the backend server.
  • process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0" disables SSL verification (not recommended).
  • Log access (opensearch) is on-demand. Limits apply (check settings).
  • No local validation of intent-types. NSP will validate changes during upload/save.
  • If running NSP releases 23.11 and prior, some of the functionality may not be supported due to API restrictions

License

Copyright 2024 Nokia Licensed under the BSD 3-Clause License. SPDX-License-Identifier: BSD-3-Clause Nokia logo is trademark of Nokia

Features

The vsCode extension for NSP Intent Manager allows the user to:

  • Virtual remote file system to access intent-types and intents.
  • Create, Update, Delete operations for intent-types and intents.
  • Download intent-types (including resources).
  • Upload intent-types from local file-system (git)
  • Code snippets to accelerate coding.
  • Retrieve logs from OpenSearch (filtered by intent-types and intents)
  • Cross navigate to NSP WebUI in context of intent-types and intents
  • Multi-target operations (sync, audit, set-state, logging)
  • Deletion of intent-types including intents (confirmation dialogue)

This project is community-driven. This means that support is best-effort coming from the community (i.e. anyone with access to the code extension) and contributions from the community are welcome at any time.

As such, this tool has not been scale tested and it is meant to help in the developer journey with a limited number of intent-types and instances, but it is not designed to work in a production network setup.

Extensive logging is available for all communication between this vsCode plugin and NSP IM. Check "OUTPUT" for more details.

Build VSIX

Please make sure, you've got the following installed in your environment:

# npm install -g typescript
# npm install -g @vscode/vsce

Installation can be validated like this:

% npm list -g             
/usr/local/lib/node_modules/node/lib
├── @vscode/vsce@2.27.0
└── typescript@5.4.5

Before you compile and build the distribution, make sure all depended modules are installed:

% npm install .
% npm list
nokia-intent-manager@2.1.1 ~/dev/vscode-intent-manager
├── @types/node@18.19.34
├── @types/vscode@1.90.0
├── @typescript-eslint/eslint-plugin@6.21.0
├── @typescript-eslint/parser@6.21.0
├── @vscode/codicons@0.0.36
├── base-64@1.0.0
├── esbuild@0.21.5
├── eslint@8.57.0
├── lodash@4.17.21
├── node-fetch@2.7.0
├── nunjucks@3.2.4
├── typescript@5.4.5
├── vscode-uri@3.0.8
├── vse@0.5.1
└── yaml@2.4.5

To see all dependencies, you can run npm list --all. In cases of any issues, visit the npm doctor.

To compile and generate the VSIX for installation, run:

vsce package

Extension Settings and Usage

General Settings

To configure the extension, you need to configure the following attributes in VsCode Extension Settings.

ctrl+shift+p > Preferences: Open Settings > Extensions > Intent Manager
  • Intent Manager > Parallel Operations: Enable: Improve performance by running things in-parallel (EXPERIMENTAL)
  • Timeout: Client-side timeout for NSP API calls
  • Ignore Labels: Hide intent-types from the user based on labels (helps to focus)

Connect to NSP IM

To connect to an NSP IM, you need to configure the following attributes in VsCode workspace settings:

ctrl+shift+p > Preferences: Open Workspace Settings > Extensions > Intent Manager
  • NSPIP: IP-address or hostname of the NSP server
  • User: NSP username to be used
  • Password: NSP password to be used (password is hidden, using vsCode secrets)
  • Port: Usage of port 443 is recommended

Release Notes

See release changes in Changelog.

Contributors

Important links

NOKIA | Network Developer Portal

Enjoy!