From db4cba338fc5af1e505a2d3874e3b4c1ea5dec51 Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Mon, 18 Nov 2024 11:40:56 -0500 Subject: [PATCH 1/7] fix: respect common env variables Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- src/core/zowe/core_for_zowe_sdk/request_handler.py | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/core/zowe/core_for_zowe_sdk/request_handler.py b/src/core/zowe/core_for_zowe_sdk/request_handler.py index 113d133a..95634277 100644 --- a/src/core/zowe/core_for_zowe_sdk/request_handler.py +++ b/src/core/zowe/core_for_zowe_sdk/request_handler.py @@ -98,10 +98,7 @@ def __send_request(self, stream: bool = False): stream : bool Flag indicates whether it is a streaming requests. """ - session = self.session - request_object = requests.Request(method=self.__method, **self.__request_arguments) - prepared = session.prepare_request(request_object) - self.__response = session.send(prepared, stream=stream, **self.session_arguments) + self.__response = self.session.request(method=self.__method, stream=stream, **self.session_arguments, **self.__request_arguments) def __del__(self): """Clean up the REST session object once it is no longer needed anymore.""" From 7768995916f663abbd242d01fd07a37808416417 Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Mon, 18 Nov 2024 12:50:25 -0500 Subject: [PATCH 2/7] review: fix lint issue and update changelog Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- CHANGELOG.md | 1 + src/core/zowe/core_for_zowe_sdk/request_handler.py | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c67a29ce..3eb25952 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ All notable changes to the Zowe Client Python SDK will be documented in this fil ### Enhancements - Turning of logger at the class-constructor level [#316] (https://github.com/zowe/zowe-client-python-sdk/issues/316) +- Added support for commonly used environmental variables, like `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE`. [#346](https://github.com/zowe/zowe-client-python-sdk/issues/346) ### Bug Fixes diff --git a/src/core/zowe/core_for_zowe_sdk/request_handler.py b/src/core/zowe/core_for_zowe_sdk/request_handler.py index 95634277..adcd09b0 100644 --- a/src/core/zowe/core_for_zowe_sdk/request_handler.py +++ b/src/core/zowe/core_for_zowe_sdk/request_handler.py @@ -98,7 +98,8 @@ def __send_request(self, stream: bool = False): stream : bool Flag indicates whether it is a streaming requests. """ - self.__response = self.session.request(method=self.__method, stream=stream, **self.session_arguments, **self.__request_arguments) + self.__response = self.session.request( + method=self.__method, stream=stream, **self.session_arguments, **self.__request_arguments) def __del__(self): """Clean up the REST session object once it is no longer needed anymore.""" From f2b264a023ac4fc31171e6e7153004c81362bd31 Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Mon, 25 Nov 2024 10:56:09 -0500 Subject: [PATCH 3/7] docs: add small doc entry Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- CHANGELOG.md | 1 - docs/source/usage/getting-started.rst | 6 ++++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0acb43bb..cc738d98 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -20,7 +20,6 @@ All notable changes to the Zowe Client Python SDK will be documented in this fil - Fixed Core SDK package referencing a non-existent version of Secrets SDK. - ## `1.0.0-dev20` ### Enhancements diff --git a/docs/source/usage/getting-started.rst b/docs/source/usage/getting-started.rst index d64ddd7b..9f77c729 100644 --- a/docs/source/usage/getting-started.rst +++ b/docs/source/usage/getting-started.rst @@ -6,3 +6,9 @@ Getting started installation examples + +Tips +---- + +- You can use a custom Certificate Authority. + The python SDK supports the commonly used environmental variables `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE` to provide a certificate chain. Also, you may use the `SSL_CERT_FILE` environmental variable. From 014dae6e86339237dc10752b75823b9f4e7daf5d Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Wed, 11 Dec 2024 11:21:55 -0500 Subject: [PATCH 4/7] chore: add doc-build steps Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- docs/README.md | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 docs/README.md diff --git a/docs/README.md b/docs/README.md new file mode 100644 index 00000000..dbd7fe53 --- /dev/null +++ b/docs/README.md @@ -0,0 +1,26 @@ +# Zowe CLient Python SDK - ReadTheDocs + +This document is intended to help you build the documentation that will eventually make its way into the live site: [https://zowe-client-python-sdk.readthedocs.io/en/latest/index.html](https://zowe-client-python-sdk.readthedocs.io/en/latest/index.html) + +## Installation requirements + +- Python 3.13 or above: [https://www.python.org/downloads/](https://www.python.org/downloads/) +- Sphinx: [https://www.sphinx-doc.org/en/master/usage/installation.html#os-specific-package-manager](https://www.sphinx-doc.org/en/master/usage/installation.html#os-specific-package-manager) + - Windows users may need to install Chocolatey: [https://chocolatey.org/install](https://chocolatey.org/install) + - I suggest going through the NodeJS installer and opt-in to instal Chocolatey in the final step + ![node-setup-choco](https://user-images.githubusercontent.com/3109072/68096791-82350c00-fe89-11e9-8cfa-b4619ce96162.jpg) +- Enchant: (Optional) [https://pyenchant.github.io/pyenchant/install.html](https://pyenchant.github.io/pyenchant/install.html) + +## Build steps + +These steps should help you to build the documentation + +0. Clone the repository, open a terminal, and `cd` into the repository directory +1. Create a virtual environment and install all dependencies: + - `python -m venv venv` + - `python -m pip install -r docs/requirements.txt` +2. On the terminal, navigate to the docs folder and run `make html` + - `cd docs` + - `make html` +3. On the file explorer, navigate to the `/docs/build/html/` directory +4. Open the `index.html` in a browser. \ No newline at end of file From 7de93d0432f62b5b27ae7222d8a6d556ba2616a6 Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Wed, 11 Dec 2024 11:46:19 -0500 Subject: [PATCH 5/7] chore: add npm scripts to help remember build steps Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- .gitignore | 2 + docs/source/index.rst | 2 +- docs/source/usage/advanced.rst | 5 + docs/source/usage/getting-started.rst | 8 +- docs/source/usage/requirements.rst | 8 + package-lock.json | 554 ++++++++++++++++++++++++++ package.json | 46 +++ 7 files changed, 618 insertions(+), 7 deletions(-) create mode 100644 docs/source/usage/advanced.rst create mode 100644 docs/source/usage/requirements.rst create mode 100644 package-lock.json create mode 100644 package.json diff --git a/.gitignore b/.gitignore index d8c69b1d..1b8e43c7 100644 --- a/.gitignore +++ b/.gitignore @@ -180,3 +180,5 @@ docs/source/classes # Team config files zowe.config*.json zowe.schema.json + +node_modules/ diff --git a/docs/source/index.rst b/docs/source/index.rst index 31b060bf..6c4c43b7 100644 --- a/docs/source/index.rst +++ b/docs/source/index.rst @@ -9,8 +9,8 @@ Python developers can leverage the Zowe SDK in order to create powerful scripts/ :maxdepth: 2 :caption: Contents: - usage/getting-started about/about + usage/getting-started packages/packages classes/index contributing/contributing diff --git a/docs/source/usage/advanced.rst b/docs/source/usage/advanced.rst new file mode 100644 index 00000000..06e4adfe --- /dev/null +++ b/docs/source/usage/advanced.rst @@ -0,0 +1,5 @@ +Advanced usage +=============== + +- You can use a custom Certificate Authority. + The python SDK supports the commonly used environmental variables `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE` to provide a certificate chain. Also, you may use the `SSL_CERT_FILE` environmental variable. diff --git a/docs/source/usage/getting-started.rst b/docs/source/usage/getting-started.rst index 9f77c729..6149f6d8 100644 --- a/docs/source/usage/getting-started.rst +++ b/docs/source/usage/getting-started.rst @@ -4,11 +4,7 @@ Getting started .. toctree:: :maxdepth: 2 + requirements installation examples - -Tips ----- - -- You can use a custom Certificate Authority. - The python SDK supports the commonly used environmental variables `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE` to provide a certificate chain. Also, you may use the `SSL_CERT_FILE` environmental variable. + advanced diff --git a/docs/source/usage/requirements.rst b/docs/source/usage/requirements.rst new file mode 100644 index 00000000..f87a3e50 --- /dev/null +++ b/docs/source/usage/requirements.rst @@ -0,0 +1,8 @@ +Requirements +============= + +The project requires the following: + +- Python 3.9 and above +- Sphinx (optional - To build project documentation) +- Enchant (optional - to build project documentation) diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..7c2e7b13 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,554 @@ +{ + "name": "zowe-client-python-sdk", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "zowe-client-python-sdk", + "hasInstallScript": true, + "license": "EPL-2.0", + "devDependencies": { + "opener": "^1.5.2", + "rimraf": "^6.0.1" + } + }, + "node_modules/@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "dev": true, + "license": "ISC", + "dependencies": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/ansi-regex": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", + "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true, + "license": "MIT" + }, + "node_modules/cross-spawn": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", + "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", + "dev": true, + "license": "MIT", + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", + "dev": true, + "license": "MIT" + }, + "node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", + "dev": true, + "license": "MIT" + }, + "node_modules/foreground-child": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.0.tgz", + "integrity": "sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==", + "dev": true, + "license": "ISC", + "dependencies": { + "cross-spawn": "^7.0.0", + "signal-exit": "^4.0.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.0.tgz", + "integrity": "sha512-9UiX/Bl6J2yaBbxKoEBRm4Cipxgok8kQYcOPEhScPwebu2I0HoQOuYdIO6S3hLuWoZgpDpwQZMzTFxgpkyT76g==", + "dev": true, + "license": "ISC", + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^4.0.1", + "minimatch": "^10.0.0", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^2.0.0" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true, + "license": "ISC" + }, + "node_modules/jackspeak": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-4.0.2.tgz", + "integrity": "sha512-bZsjR/iRjl1Nk1UkjGpAzLNfQtzuijhn2g+pbZb98HQ1Gk8vM9hfbxeMBP+M2/UUdwj0RqGG3mlvk2MsAqwvEw==", + "dev": true, + "license": "BlueOak-1.0.0", + "dependencies": { + "@isaacs/cliui": "^8.0.2" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/lru-cache": { + "version": "11.0.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-11.0.2.tgz", + "integrity": "sha512-123qHRfJBmo2jXDbo/a5YOQrJoHF/GNQTLzQ5+IdK5pWpceK17yRc6ozlWd25FxvGKQbIUs91fDFkXmDHTKcyA==", + "dev": true, + "license": "ISC", + "engines": { + "node": "20 || >=22" + } + }, + "node_modules/minimatch": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.1.tgz", + "integrity": "sha512-ethXTt3SGGR+95gudmqJ1eNhRO7eGEGIgYA9vnPatK4/etz2MEVDno5GMCibdMTuBMyElzIlgxMna3K94XDIDQ==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/opener": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/opener/-/opener-1.5.2.tgz", + "integrity": "sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A==", + "dev": true, + "license": "(WTFPL OR MIT)", + "bin": { + "opener": "bin/opener-bin.js" + } + }, + "node_modules/package-json-from-dist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz", + "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==", + "dev": true, + "license": "BlueOak-1.0.0" + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-scurry": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-2.0.0.tgz", + "integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==", + "dev": true, + "license": "BlueOak-1.0.0", + "dependencies": { + "lru-cache": "^11.0.0", + "minipass": "^7.1.2" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-6.0.1.tgz", + "integrity": "sha512-9dkvaxAsk/xNXSJzMgFqqMCuFgt2+KsOFek3TMLfo8NCPfWpBmqwyNn5Y+NX56QUYfCtsyhF3ayiboEoUmJk/A==", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^11.0.0", + "package-json-from-dist": "^1.0.0" + }, + "bin": { + "rimraf": "dist/esm/bin.mjs" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/string-width-cjs": { + "name": "string-width", + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width-cjs/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true, + "license": "MIT" + }, + "node_modules/string-width-cjs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/strip-ansi-cjs": { + "name": "strip-ansi", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs": { + "name": "wrap-ansi", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true, + "license": "MIT" + }, + "node_modules/wrap-ansi-cjs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 00000000..6592b3df --- /dev/null +++ b/package.json @@ -0,0 +1,46 @@ +{ + "name": "zowe-client-python-sdk", + "description": "Zowe Client Python SDK", + "private": true, + "directories": { + "doc": "docs", + "test": "tests" + }, + "scripts": { + "postinstall": "npm run src:install && npm run doc:install", + "src:install": "python -m pip install -r requirements.txt", + "src:pydocstyle": "pydocstyle --match-dir='^(?!(build|response)$).*' --match='^(?!(__init__\\.py|setup\\.py$)).*\\.py$' src", + "src:pydoclint": "pydoclint --exclude='.*/(build|response)/.*' src", + "src:lint": "npm run src:lint:error && npm run src:lint:other", + "src:lint:error": "pylint src --errors-only --disable=E0401,E0611 --ignore=build", + "src:lint:other": "pylint ./src --disable=all --enable=C0103,C0301 --ignore=build,response --max-line-length=127", + "src:license": "python scripts/license_header.py src", + "src:test": "npm run src:test:pytest && npm run src:test:xml", + "src:test:pytest": "coverage run -m pytest ./tests/unit", + "src:test:xml": "coverage xml", + "doc:install": "python -m pip install -r docs/requirements.txt", + "doc:build": "cd docs && make html", + "doc:open": "opener docs/build/html/index.html", + "env:create": "python -m venv env", + "env:delete": "deactivate && rimraf env" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/zowe/zowe-client-python-sdk.git" + }, + "keywords": [ + "zowe", + "python", + "sdk" + ], + "author": "Zowe", + "license": "EPL-2.0", + "bugs": { + "url": "https://github.com/zowe/zowe-client-python-sdk/issues" + }, + "homepage": "https://github.com/zowe/zowe-client-python-sdk#readme", + "devDependencies": { + "opener": "^1.5.2", + "rimraf": "^6.0.1" + } +} From c0e1ca236e2ac195f5d1dfe65e3f16338ca9eee2 Mon Sep 17 00:00:00 2001 From: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> Date: Wed, 11 Dec 2024 12:37:58 -0500 Subject: [PATCH 6/7] chore: update npm script :yum: Signed-off-by: Fernando Rijo Cedeno <37381190+zFernand0@users.noreply.github.com> --- docs/README.md | 18 ++++++++++-------- package-lock.json | 15 +++++++++++++-- package.json | 11 ++++++++--- 3 files changed, 31 insertions(+), 13 deletions(-) diff --git a/docs/README.md b/docs/README.md index dbd7fe53..682903d7 100644 --- a/docs/README.md +++ b/docs/README.md @@ -16,11 +16,13 @@ This document is intended to help you build the documentation that will eventual These steps should help you to build the documentation 0. Clone the repository, open a terminal, and `cd` into the repository directory -1. Create a virtual environment and install all dependencies: - - `python -m venv venv` - - `python -m pip install -r docs/requirements.txt` -2. On the terminal, navigate to the docs folder and run `make html` - - `cd docs` - - `make html` -3. On the file explorer, navigate to the `/docs/build/html/` directory -4. Open the `index.html` in a browser. \ No newline at end of file +1. Install project dependencies: + - `npm install` +2. Create a virtual environment: + - `npm run env:create` +3. Activate the virtual environment: + - `npm run env:activate` +4. Install the doc dependencies + - `npm run doc:install` +5. Build and open the documentation: + - `npm run doc:dev` diff --git a/package-lock.json b/package-lock.json index 7c2e7b13..211aee08 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5,11 +5,11 @@ "packages": { "": { "name": "zowe-client-python-sdk", - "hasInstallScript": true, "license": "EPL-2.0", "devDependencies": { "opener": "^1.5.2", - "rimraf": "^6.0.1" + "rimraf": "^6.0.1", + "run-script-os": "^1.1.6" } }, "node_modules/@isaacs/cliui": { @@ -296,6 +296,17 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/run-script-os": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/run-script-os/-/run-script-os-1.1.6.tgz", + "integrity": "sha512-ql6P2LzhBTTDfzKts+Qo4H94VUKpxKDFz6QxxwaUZN0mwvi7L3lpOI7BqPCq7lgDh3XLl0dpeXwfcVIitlrYrw==", + "dev": true, + "license": "MIT", + "bin": { + "run-os": "index.js", + "run-script-os": "index.js" + } + }, "node_modules/shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", diff --git a/package.json b/package.json index 6592b3df..3f12dbcc 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,6 @@ "test": "tests" }, "scripts": { - "postinstall": "npm run src:install && npm run doc:install", "src:install": "python -m pip install -r requirements.txt", "src:pydocstyle": "pydocstyle --match-dir='^(?!(build|response)$).*' --match='^(?!(__init__\\.py|setup\\.py$)).*\\.py$' src", "src:pydoclint": "pydoclint --exclude='.*/(build|response)/.*' src", @@ -19,10 +18,15 @@ "src:test:pytest": "coverage run -m pytest ./tests/unit", "src:test:xml": "coverage xml", "doc:install": "python -m pip install -r docs/requirements.txt", + "doc:dev": "npm run doc:clean && npm run doc:build && npm run doc:open", "doc:build": "cd docs && make html", + "doc:clean": "cd docs && make clean", "doc:open": "opener docs/build/html/index.html", "env:create": "python -m venv env", - "env:delete": "deactivate && rimraf env" + "env:active": "run-script-os", + "env:active:win32": "echo 'To activate, run the following command:\n\nenv\\Scripts\\activate\n\nTo deactivate, simply run:\n\ndeactivate\n'", + "env:active:default": "echo 'To activate, run the following command:\n\nsource env/bin/activate\n\nTo deactivate, simply run:\n\ndeactivate\n'", + "env:delete": "rimraf env" }, "repository": { "type": "git", @@ -41,6 +45,7 @@ "homepage": "https://github.com/zowe/zowe-client-python-sdk#readme", "devDependencies": { "opener": "^1.5.2", - "rimraf": "^6.0.1" + "rimraf": "^6.0.1", + "run-script-os": "^1.1.6" } } From 5f4cd2395f2e50dd1ff03879383cf28bb4a747a5 Mon Sep 17 00:00:00 2001 From: anaxceron Date: Wed, 18 Dec 2024 14:21:42 -0500 Subject: [PATCH 7/7] minor edit to Reqs page Signed-off-by: anaxceron --- docs/source/usage/advanced.rst | 8 +++-- docs/source/usage/examples.rst | 49 +++++++++++++++------------ docs/source/usage/getting-started.rst | 2 ++ docs/source/usage/installation.rst | 16 +++------ docs/source/usage/requirements.rst | 8 ++--- 5 files changed, 43 insertions(+), 40 deletions(-) diff --git a/docs/source/usage/advanced.rst b/docs/source/usage/advanced.rst index 06e4adfe..e387e497 100644 --- a/docs/source/usage/advanced.rst +++ b/docs/source/usage/advanced.rst @@ -1,5 +1,7 @@ -Advanced usage +Advanced steps =============== -- You can use a custom Certificate Authority. - The python SDK supports the commonly used environmental variables `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE` to provide a certificate chain. Also, you may use the `SSL_CERT_FILE` environmental variable. +- Use a custom Certificate Authority if working in a restricted environment. + The Python SDK supports the commonly used environmental variables `REQUESTS_CA_BUNDLE` and `CURL_CA_BUNDLE` to provide a certificate chain. + + You can also use the `SSL_CERT_FILE` environmental variable in project-level configurations. diff --git a/docs/source/usage/examples.rst b/docs/source/usage/examples.rst index fbda0ba7..5aa86a31 100644 --- a/docs/source/usage/examples.rst +++ b/docs/source/usage/examples.rst @@ -1,32 +1,37 @@ -Basic usage +First steps ============ -After you install the package in your project, import the class for the required sub-package (i.e `Console` class for z/OS Console commands). -Create a dictionary to handle communication with the plug-in: +After you install the package in your project, integrate the SDK in your script: -.. code-block:: python +1. Import the class for the required sub-package in order to call the individual SDK method and run plug-in commands. - from zowe.zos_console_for_zowe_sdk import Console - profile = { - "host": "", - "port": 443, # Include the port if different from the default (443) - "user": "", - "password": "", - # "rejectUnauthorized": True, # Set to False to disable SSL verification - # "basePath": "", # Define base path if using Zowe API ML (e.g. "/ibmzosmf/api/v1" for z/OSMF) - # "protocol": "https", # Include the protocol if different from the default (https) - } + For example, the `Console` class must be imported for z/OS Console commands to be issued. - my_console = Console(profile) +2. Create a dictionary to add connection information to communicate with the plug-in: -Alternatively you can use an existing Zowe CLI profile instead: + .. code-block:: python -.. code-block:: python + from zowe.zos_console_for_zowe_sdk import Console + profile = { + "host": "", + "port": 443, # Include the port if different from the default (443) + "user": "", + "password": "", + # "rejectUnauthorized": True, # Set to False to disable SSL verification + # "basePath": "", # Define base path if using Zowe API ML (e.g. "/ibmzosmf/api/v1" for z/OSMF) + # "protocol": "https", # Include the protocol if different from the default (https) + } - from zowe.zos_console_for_zowe_sdk import Console - from zowe.core_for_zowe_sdk import ProfileManager + my_console = Console(profile) - # Load the profile using ProfileManager - profile = ProfileManager().load(profile_name="") + Alternatively you can use an existing Zowe CLI profile instead: - my_console = Console(profile) + .. code-block:: python + + from zowe.zos_console_for_zowe_sdk import Console + from zowe.core_for_zowe_sdk import ProfileManager + + # Load the profile using ProfileManager + profile = ProfileManager().load(profile_name="") + + my_console = Console(profile) diff --git a/docs/source/usage/getting-started.rst b/docs/source/usage/getting-started.rst index 6149f6d8..aeff66e3 100644 --- a/docs/source/usage/getting-started.rst +++ b/docs/source/usage/getting-started.rst @@ -1,5 +1,6 @@ Getting started ================= +Review the requirements and installation instructions to get started using the Zowe Client Python SDK. .. toctree:: :maxdepth: 2 @@ -8,3 +9,4 @@ Getting started installation examples advanced + diff --git a/docs/source/usage/installation.rst b/docs/source/usage/installation.rst index 7b63c6fd..9b5aac55 100644 --- a/docs/source/usage/installation.rst +++ b/docs/source/usage/installation.rst @@ -1,23 +1,17 @@ Installation ============ +When installing the Zowe Client Python SDK you have two options: -When installing the Zowe Client Python SDK you have two options. +- Install **all Zowe packages** to install everything under the `zowe` namespace in PyPi. +- Install a **single subpackage** for a smaller installation. -- Install all the Zowe packages -- Install a single sub-package - -The choice depends on your intentions. If you chose to install all Zowe SDK packages -this means that you will install everything under the `zowe` namespace in PyPi. - -Alternatively you can chose to install only a single subpackage for a smaller installation. - -To install all Zowe SDK packages using pip: +To install all Zowe SDK packages using `pip`: .. code-block:: pip install -U --pre zowe-python-sdk-bundle -To install only a subpackage using pip: +To install only a subpackage using `pip`: .. code-block:: diff --git a/docs/source/usage/requirements.rst b/docs/source/usage/requirements.rst index f87a3e50..f1b5927f 100644 --- a/docs/source/usage/requirements.rst +++ b/docs/source/usage/requirements.rst @@ -1,8 +1,8 @@ Requirements ============= -The project requires the following: +Zowe Client Python SDK requires the following: -- Python 3.9 and above -- Sphinx (optional - To build project documentation) -- Enchant (optional - to build project documentation) +- **Python** 3.9+ to run your script +- (optional) **Sphinx** to build project documentation +- (optional) **Enchant** to build project documentation