Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dderevjanik/wsdl-tsclient
:page_facing_up: Generate typescript client from WSDL
https://github.com/dderevjanik/wsdl-tsclient
generator soap soap-client typescript web-service wsdl wsdl-generation wsdl-tsclient
Last synced: 3 months ago
JSON representation
:page_facing_up: Generate typescript client from WSDL
- Host: GitHub
- URL: https://github.com/dderevjanik/wsdl-tsclient
- Owner: dderevjanik
- License: mit
- Created: 2021-03-01T18:01:44.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-08-02T08:56:29.000Z (3 months ago)
- Last Synced: 2024-08-02T10:27:06.922Z (3 months ago)
- Topics: generator, soap, soap-client, typescript, web-service, wsdl, wsdl-generation, wsdl-tsclient
- Language: TypeScript
- Homepage: https://npm.im/wsdl-tsclient
- Size: 677 KB
- Stars: 95
- Watchers: 6
- Forks: 70
- Open Issues: 37
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# WSDL TSClient
![license](https://img.shields.io/npm/l/wsdl-tsclient)
[![Known Vulnerabilities](https://snyk.io/test/github/dderevjanik/wsdl-tsclient/badge.svg)](https://snyk.io/test/github/dderevjanik/wsdl-tsclient)
[![npm-version](https://img.shields.io/npm/v/wsdl-tsclient)](https://npmjs.com/package/wsdl-tsclient)**Example how to generate and use wsdl-tsclient:** [wsdl-tsclient-example](https://github.com/dderevjanik/wsdl-tsclient-example)
Generate a [soap client](https://www.npmjs.com/package/soap) with typescript definitions from a WSDL file.
This library uses [ts-morph](https://www.npmjs.com/package/ts-morph) to generate typescript code and [soap](https://github.com/vpulim/node-soap) for runtime. Inspired by Java [wsimport](https://docs.oracle.com/javase/8/docs/technotes/tools/unix/wsimport.html) and [openapi-generator](https://github.com/OpenAPITools/openapi-generator).
*NOTE:* Add [soap](https://www.npmjs.com/package/soap) to your npm runtime dependencies (`npm i soap`).
## Install
```sh
npm i wsdl-tsclient
```or install it with `-g` to have CLI globally available.
```sh
npm i -g wsdl-tsclient
```or you can use `npx` to run it without installing
```sh
npx wsdl-tsclient ./path/to/wsdl.wsdl -o ./generated/
```## Usage
You can check example repository [wsdl-tsclient-example](https://github.com/dderevjanik/wsdl-tsclient-example)
### Generate client using CLI
Easiest way to generate client from is to use CLI. You need to provide only path to `.wsdl` file and
path to output directory (`-o` param). If you want to generate **only typescript types** (no runtime code) for node-soap, you can pass `--emitDefinitionsOnly` param.`wsdl-tsclient ./soap.wsdl -o ./generated`
`wsdl-tsclient ./resources/**/*.wsdl -o ./generated` - using glob
you can also use `npx`
`npx wsdl-tsclient ./soap.wsdl -o ./generated`
```bash
wsdl-tsclient [options] [path]Options:
--help Show help [boolean]
-v, --version Show version number [boolean]
-o Output directory for generated TypeScript
client [string] [required]
--emitDefinitionsOnly Generate definitions only (interfaces and
types) [boolean]
--modelNamePreffix Prefix for generated interface names[string]
--modelNameSuffix Suffix for generated interface names[string]
--modelPropertyNaming Property naming convention ('camelCase' or
'PascalCase') [string]
--caseInsensitiveNames Parse WSDL definitions case-insensitively
[boolean]
--maxRecursiveDefinitionName Maximum count of definitions with the same
name but increased suffix. Will throw an
error if exceeded. [number]
--esm Generate imports with .js suffix [boolean]
--quiet Suppress all logs [boolean]
--verbose Print verbose logs [boolean]
--no-color Logs without colors [boolean]Examples:
wsdl-tsclient file.wsdl -o ./generated/
wsdl-tsclient ./res/**/*.wsdl -o ./generated/
```### Generate client programmatically
```typescript
import { generateClient } from "wsdl-tsclient";parseAndGenerate("./path/to/MyWsdl.wsdl", "./generated/");
```### Using generated client in your project
*Note:* Make sure you have [soap](https://www.npmjs.com/package/soap) package in your runtime dependencies (`npm i soap`)
```typescript
import { createClientAsync } from "./generated/MyWsdl";const client = await createClientAsync("./path/to/wsdl.wsdl");
client.CallSoapMethodAsync();
```Setting basic auth
```typescript
import soap from "soap";
import { createClientAsync } from "./generated/MyWsdl";const client = await createClientAsync("./path/to/wsdl.wsdl");
const basicAuth = new soap.BasicAuthSecurity(auth.username, auth.password);
client.setSecurity(basicAuth);client.CallSoapMethodAsync();
```for more information about the use of the client, read more about [soap](https://github.com/vpulim/node-soap)
## How it works
![overview](./docs/Overview.png)
## Develpoment
- Clone the repository
- Install dependencies `npm i`
- Run tests `npm test`## License
The source code is licensed under the [MIT](./LICENSE) license
## Contributors
![Contributors](https://contrib.rocks/image?repo=dderevjanik/wsdl-tsclient)