diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index e96ca8ba..ef205569 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -79,11 +79,11 @@ jobs: env_vars: OS,NODE # - name: Bundle all packages - # if: matrix.os == 'ubuntu-latest' && matrix.node-version == '18.x' + # if: matrix.os == 'ubuntu-latest' && matrix.node-version == '20.x' # run: npm i -g vsce && npm run package # - name: Archive all packages - # if: matrix.os == 'ubuntu-latest' && matrix.node-version == '18.x' + # if: matrix.os == 'ubuntu-latest' && matrix.node-version == '20.x' # uses: actions/upload-artifact@v4 # with: # name: zowe-cics-client @@ -123,7 +123,7 @@ jobs: - name: Build Source run: npm run build - - uses: zowe-actions/octorelease@fix/allow-first-time-publish2 + - uses: zowe-actions/octorelease@v1 env: GIT_COMMITTER_NAME: ${{ secrets.ZOWE_ROBOT_USER }} GIT_COMMITTER_EMAIL: ${{ secrets.ZOWE_ROBOT_EMAIL }} diff --git a/package-lock.json b/package-lock.json index b7923da9..c83d1fef 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,10 +1,12 @@ { "name": "@zowe/cics_monorepo", + "version": "5.0.3", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@zowe/cics_monorepo", + "version": "5.0.3", "workspaces": [ "./packages/*" ], @@ -20,7 +22,6 @@ "@typescript-eslint/parser": "^5.57.1", "@zowe/cli-test-utils": "^7.13.0", "@zowe/imperative": "^5.22.0", - "@zowe/secrets-for-zowe-sdk": "^7.18.6", "@zowe/zowe-explorer-api": "^2.14.0", "chalk": "^4.1.2", "eslint": "^8.37.0", diff --git a/packages/vsce/README.md b/packages/vsce/README.md index cf97b923..26082726 100644 --- a/packages/vsce/README.md +++ b/packages/vsce/README.md @@ -1,7 +1,7 @@ # Zowe CICS Explorer -[![version](https://vsmarketplacebadge.apphb.com/version-short/zowe.cics-extension-for-zowe.svg)](https://vsmarketplacebadge.apphb.com/version-short/Zowe.cics-extension-for-zowe.svg) -[![downloads](https://vsmarketplacebadge.apphb.com/downloads-short/zowe.cics-extension-for-zowe.svg)](https://vsmarketplacebadge.apphb.com/downloads-short/Zowe.cics-extension-for-zowe.svg) +[![version](https://img.shields.io/visual-studio-marketplace/v/zowe.cics-extension-for-zowe.svg)](https://img.shields.io/visual-studio-marketplace/v/zowe.cics-extension-for-zowe.svg) +[![downloads](https://img.shields.io/visual-studio-marketplace/v/zowe.cics-extension-for-zowe.svg)](https://img.shields.io/visual-studio-marketplace/v/zowe.cics-extension-for-zowe.svg) [![slack](https://img.shields.io/badge/chat-on%20Slack-blue)](https://openmainframeproject.slack.com/archives/CUVE37Z5F) [![open issues](https://img.shields.io/github/issues/zowe/vscode-extension-for-cics)](https://github.com/zowe/vscode-extension-for-cics/issues) @@ -80,7 +80,7 @@ If you don't have an existing Zowe CICS CLI profile, follow these steps to creat 5. Select the **+** button in the CICS tree and click the newly created profile to load it into view.

-Zowe CICS Explorer config profiles +Zowe CICS Explorer config profiles

Here's an example of a CICS profile entry in the config file: @@ -116,7 +116,7 @@ Here's an example of a CICS profile entry in the config file: Configuring a CICS region to have a connection is a system programmer task and more details can be found in [Setting up CMCI with CICSPlex SM](https://www.ibm.com/docs/en/cics-ts/5.3?topic=explorer-setting-up-cmci-cicsplex-sm) or [Setting up CMCI in a stand-alone CICS region](https://www.ibm.com/docs/en/cics-ts/5.3?topic=suace-setting-up-cmci-in-stand-alone-cics-region). If your CMCI connection is configured to use a self-signed certificate that your PC's trust store doesn't recognize, see [Untrusted TLS certificates](#untrusted-tls-certificates).

-Zowe CICS Explorer profiles +Zowe CICS Explorer profiles

To show more than one CICS profiles in the tree, select the **+** button and choose from the list of profiles. Only profiles that not already included in the CICS tree will be shown. @@ -149,7 +149,7 @@ To show more than one CICS profile in the tree, select the + button and choose f 4. Refresh the Zowe Explorer for IBM CICS extension by either clicking the button at the top level of the CICS view, or the `Zowe Explorer for IBM CICS: Refresh` command palette option.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

#### Using Zowe v1 profiles @@ -163,7 +163,7 @@ To show more than one CICS profile in the tree, select the + button and choose f 3. Once the details are updated, click the **Update Profile** button to apply the changes to the profile.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

### Hiding Profiles @@ -171,7 +171,7 @@ To show more than one CICS profile in the tree, select the + button and choose f Open the menu actions for a profile by right-clicking a profile and select `Hide Profile` to hide it from the CICS view. To add the profile back, click the + button and select the profile from the quick pick list.

-Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

### Deleting Profiles @@ -187,7 +187,7 @@ Open the menu actions for a profile by right-clicking a profile and select `Hide 4. Refresh the Zowe Explorer for IBM CICS extension by either clicking the button at the top level of the CICS view, or the `Zowe Explorer for IBM CICS: Refresh` command palette option.

-Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

#### Using Zowe v1 profiles @@ -197,7 +197,7 @@ Open the menu actions for a profile by right-clicking a profile and select `Hide 2. Select **Delete Profile** and click the **Yes** button when prompted to confirm the action of permanently deleting the profile. The functionality deletes the CICS profile from the persistent storage directory `~/.zowe/profiles/cics`.

-Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

## CICS Resources @@ -213,7 +213,7 @@ The list of resources are pre-filtered to exclude many of the IBM supplied ones To reset the filter to its initial criteria use the clear filter icon against the resource type. If you wish to see all resources in a region (including IBM supplied ones) you can use "\*" as a filter.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

**Tip:** To apply multiple filters, separate entries with a comma. You can append any filter with an \*, which indicates wildcard searching. @@ -225,7 +225,7 @@ Similar to filtering resources in a region, it is also possible to apply a filte To reset the filter to its initial criteria use the clear filter icon against the `Regions` tree. This will open a drop-down menu which gives the option to clear the filter for all the `Regions`, `Programs`, `Local Transactions` or `Local Files` in the plex, and an option to otherwise clear `All` filters within the plex.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

**Tip:** To apply multiple filters, separate entries with a comma. You can append any filter with an \*, which indicates wildcard searching. @@ -237,7 +237,7 @@ Plexes contain an `All Programs`, `All Local Transactions`, `All Local Files` an To view resources under these trees, use the search icon inline with the tree and apply a filter.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

If the applied filter results in over 500 records, either change the filter to narrow down the search, or click the `view X more ...` item to retrieve 'X' more resources. @@ -245,7 +245,7 @@ If the applied filter results in over 500 records, either change the filter to n **Tip:** The default 500 count can be modified via the `Record Count Increment` property in Settings (UI).

-Zowe CICS Explorer Record Count Increment in Setting UI +Zowe CICS Explorer Record Count Increment in Setting UI

### Show Attributes @@ -253,7 +253,7 @@ If the applied filter results in over 500 records, either change the filter to n Right-click and use the pop-up menu against a program to list the available actions that can be performed. For every resource, including a CICS region, `Show Attributes` opens a viewer listing all attributes and their values. The attributes page has a filter box at the top that lets you search for attributes matching the criteria.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

### Enable and Disable @@ -261,7 +261,7 @@ Right-click and use the pop-up menu against a program to list the available acti Right-click against a program, local transaction or local file to open up the pop-up menu and click `Disable [CICS resource]` to disable the resource. When a resource is already disabled the first option becomes `Enable [CICS resource]` to allow its enablement state to be toggled. A disabled resource is identified by a `(Disabled)` text next to its name.

-Zowe CICS Explorer Filter +Zowe CICS Explorer Filter

### New Copy and Phase In @@ -271,7 +271,7 @@ Use `New Copy` -Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

### Open and Close Local Files @@ -281,7 +281,7 @@ Right-click against a closed local file and perform the `Open Local File` menu a To close a local file, right-click against an open local file and perform the `Close Local File` menu action. This will bring up a prompt on the bottom right corner requesting to choose one of `Wait`, `No Wait` or `Force` for the file busy condition. Once an option has been selected, the local file name will be appended with a `(Closed)` label upon success.

-Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

### Purge Task @@ -291,7 +291,7 @@ Right-click against a task and click the `Purge Task` command. This will open a Select the appropriate condition to perform the purge.

-Zowe CICS Explorer Purge Task +Zowe CICS Explorer Purge Task

### Inquire Functionality @@ -301,7 +301,7 @@ Right-click against a Task and perform the `Inquire Transaction` command. This w The same can be done on a Local Transaction to find the associated Program by executing the `Inquire Program` right-click menu action against a Local Transaction.

-Zowe CICS Explorer Inquire functionality +Zowe CICS Explorer Inquire functionality

### View Datasets under Libraries @@ -309,7 +309,7 @@ The same can be done on a Local Transaction to find the associated Program by ex Expand libraries of a region to view specific datasets belonging to a library. Right-click on libraries to `Show Attributes` to view library attributes. Similarly, right-click on datasets to `Show Attributes` to view dataset attributes.

-Zowe CICS Explorer View Datasets functionality +Zowe CICS Explorer View Datasets functionality

### View four CICS Web Resources under the Web Folder @@ -317,7 +317,7 @@ Expand libraries of a region to view specific datasets belonging to a library. R Expand the Web folder to view TCPIP Services, URI Maps, Pipelines and Web Services. Each of these resources can be expanded and allows for right-click functionality on the specific resource to execute the `Show Attributes` command. Use the search icon to filter down specific resources by applying a filter.

-Zowe CICS Explorer Web resources under the Web folder +Zowe CICS Explorer Web resources under the Web folder

## Untrusted TLS Certificates @@ -327,7 +327,7 @@ If the CMCI connection is using a TLS certificate that your PC doesn't have in i If you define a profile as only accepting trusted TLS certificates when the Zowe Explorer first connects it will detect the mismatch and allow you to override the setting and proceed. This is done through a pop-up message with a `Yes` button to accept the untrusted certificate authority, which changes the profile's setting.

-Zowe CICS Explorer accepted untrusted certificate +Zowe CICS Explorer accepted untrusted certificate

## Usage tips @@ -345,7 +345,7 @@ If you define a profile as only accepting trusted TLS certificates when the Zowe Before filing an issue, check if an error is arising from the Zowe Explorer for IBM CICS extension and not the Zowe Explorer extension by expanding the error message and checking if the `Source` is `Zowe Explorer for IBM CICS (Extension)`.

-Zowe CICS Explorer NewCopy Program +Zowe CICS Explorer NewCopy Program

Error messages arising from the Zowe Explorer extension will have the `Source` as `Zowe Explorer(Extension)`. diff --git a/packages/vsce/src/commands/refreshCommand.ts b/packages/vsce/src/commands/refreshCommand.ts index 45abbde4..6f8f58f5 100644 --- a/packages/vsce/src/commands/refreshCommand.ts +++ b/packages/vsce/src/commands/refreshCommand.ts @@ -23,9 +23,7 @@ export function getRefreshCommand(tree: CICSTree) { cancellable: false, }, async () => { - tree.clearLoadedProfiles(); - await ProfileManagement.profilesCacheRefresh(); - await tree.loadStoredProfileNames(); + await tree.refreshLoadedProfiles(); } ); } catch (error) { diff --git a/packages/vsce/src/extension.ts b/packages/vsce/src/extension.ts index 4a65aec4..ed471b8d 100644 --- a/packages/vsce/src/extension.ts +++ b/packages/vsce/src/extension.ts @@ -85,6 +85,7 @@ import { getInquireProgramCommand } from "./commands/inquireProgram"; */ export async function activate(context: ExtensionContext) { const zeVersion = getZoweExplorerVersion(); + let treeDataProv: CICSTree; if (!zeVersion) { window.showErrorMessage("Zowe Explorer was not found: Please ensure Zowe Explorer v2.0.0 or higher is installed"); return; @@ -97,7 +98,13 @@ export async function activate(context: ExtensionContext) { // Register 'cics' profiles as a ZE extender await ProfileManagement.registerCICSProfiles(); ProfileManagement.getProfilesCache().registerCustomProfilesType("cics"); - await ProfileManagement.getExplorerApis().getExplorerExtenderApi().reloadProfiles(); + const apiRegister = await ProfileManagement.getExplorerApis(); + await apiRegister.getExplorerExtenderApi().reloadProfiles(); + if (apiRegister.onProfilesUpdate) { + apiRegister.onProfilesUpdate(async () => { + await treeDataProv.refreshLoadedProfiles(); + }); + } window.showInformationMessage("Zowe Explorer was modified for the CICS Extension."); } catch (error) { console.log(error); @@ -111,7 +118,7 @@ export async function activate(context: ExtensionContext) { return; } - const treeDataProv = new CICSTree(); + treeDataProv = new CICSTree(); const treeview = window.createTreeView("cics-view", { treeDataProvider: treeDataProv, showCollapseAll: true, diff --git a/packages/vsce/src/trees/CICSTree.ts b/packages/vsce/src/trees/CICSTree.ts index dd9fc44e..e7d7907a 100644 --- a/packages/vsce/src/trees/CICSTree.ts +++ b/packages/vsce/src/trees/CICSTree.ts @@ -19,6 +19,7 @@ import { TreeItem, WebviewPanel, window, + commands } from "vscode"; import { PersistentStorage } from "../utils/PersistentStorage"; import { InfoLoaded, ProfileManagement } from "../utils/profileManagement"; @@ -40,6 +41,11 @@ export class CICSTree implements TreeDataProvider { return this.loadedProfiles; } + public async refreshLoadedProfiles() { + this.clearLoadedProfiles(); + await this.loadStoredProfileNames(); + commands.executeCommand('workbench.actions.treeView.cics-view.collapseAll'); + } public clearLoadedProfiles() { this.loadedProfiles = []; this._onDidChangeTreeData.fire(undefined); diff --git a/packages/vsce/src/utils/expansionHandler.ts b/packages/vsce/src/utils/expansionHandler.ts index 7f45b5b9..b9a71bde 100644 --- a/packages/vsce/src/utils/expansionHandler.ts +++ b/packages/vsce/src/utils/expansionHandler.ts @@ -18,6 +18,9 @@ import { ProfileManagement } from "./profileManagement"; export async function sessionExpansionHandler(session: CICSSessionTree, tree: CICSTree) { const profile = await ProfileManagement.getProfilesCache().getLoadedProfConfig(session.label?.toString()!); + if (profile == null) { + throw new Error("sessionExpansionHandler: Profile is not defined"); + } await tree.loadProfile(profile, tree.getLoadedProfiles().indexOf(session), session); }