From d863c15d2438d9d28515d3e67f20af8045ca761a Mon Sep 17 00:00:00 2001 From: Jon Ursenbach Date: Wed, 25 Oct 2023 15:15:14 -0700 Subject: [PATCH] feat: client config for documenting installation instructions --- src/helpers/__snapshots__/utils.test.ts.snap | 9 +++++++++ src/targets/csharp/restsharp/client.ts | 1 + src/targets/index.ts | 1 + src/targets/javascript/axios/client.ts | 1 + src/targets/node/axios/client.ts | 1 + src/targets/node/fetch/client.ts | 1 + src/targets/node/request/client.ts | 1 + src/targets/ocaml/cohttp/client.ts | 1 + src/targets/php/guzzle/client.ts | 1 + src/targets/python/requests/client.ts | 1 + src/targets/shell/httpie/client.ts | 1 + 11 files changed, 19 insertions(+) diff --git a/src/helpers/__snapshots__/utils.test.ts.snap b/src/helpers/__snapshots__/utils.test.ts.snap index a4cc15d87..fd0cb7915 100644 --- a/src/helpers/__snapshots__/utils.test.ts.snap +++ b/src/helpers/__snapshots__/utils.test.ts.snap @@ -44,6 +44,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Simple REST and HTTP API Client for .NET", "extname": ".cs", + "installation": "dotnet add package RestSharp", "key": "restsharp", "link": "http://restsharp.org/", "title": "RestSharp", @@ -129,6 +130,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Promise based HTTP client for the browser and node.js", "extname": ".js", + "installation": "npm install axios --save", "key": "axios", "link": "https://github.com/axios/axios", "title": "Axios", @@ -193,6 +195,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Simplified HTTP request client", "extname": ".cjs", + "installation": "npm install request --save", "key": "request", "link": "https://github.com/request/request", "title": "Request", @@ -207,6 +210,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Promise based HTTP client for the browser and node.js", "extname": ".cjs", + "install": "npm install axios --save", "key": "axios", "link": "https://github.com/axios/axios", "title": "Axios", @@ -214,6 +218,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Simplified HTTP node-fetch client", "extname": ".cjs", + "installation": "npm install node-fetch@2 --save", "key": "fetch", "link": "https://github.com/bitinn/node-fetch", "title": "Fetch", @@ -242,6 +247,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Cohttp is a very lightweight HTTP server using Lwt or Async for OCaml", "extname": ".ml", + "installation": "opam install cohttp-lwt-unix cohttp-async", "key": "cohttp", "link": "https://github.com/mirage/ocaml-cohttp", "title": "CoHTTP", @@ -264,6 +270,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "PHP with Guzzle", "extname": ".php", + "installation": "composer require guzzlehttp/guzzle", "key": "guzzle", "link": "http://docs.guzzlephp.org/en/stable/", "title": "Guzzle", @@ -314,6 +321,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "Requests HTTP library", "extname": ".py", + "installation": "python -m pip install requests", "key": "requests", "link": "http://docs.python-requests.org/en/latest/api/#requests.request", "title": "Requests", @@ -364,6 +372,7 @@ exports[`availableTargets > returns all available targets 1`] = ` { "description": "a CLI, cURL-like tool for humans", "extname": ".sh", + "installation": "brew install httpie", "key": "httpie", "link": "http://httpie.org/", "title": "HTTPie", diff --git a/src/targets/csharp/restsharp/client.ts b/src/targets/csharp/restsharp/client.ts index 8dec38da9..35d7eb347 100644 --- a/src/targets/csharp/restsharp/client.ts +++ b/src/targets/csharp/restsharp/client.ts @@ -14,6 +14,7 @@ export const restsharp: Client = { link: 'http://restsharp.org/', description: 'Simple REST and HTTP API Client for .NET', extname: '.cs', + installation: 'dotnet add package RestSharp', }, convert: ({ method, fullUrl, headersObj, cookies, postData, uriObj }) => { const { push, join } = new CodeBuilder(); diff --git a/src/targets/index.ts b/src/targets/index.ts index 914a76802..0c65f9ffe 100644 --- a/src/targets/index.ts +++ b/src/targets/index.ts @@ -29,6 +29,7 @@ export type ClientId = string; export interface ClientInfo { description: string; extname: Extension; + installation?: string; key: ClientId; link: string; title: string; diff --git a/src/targets/javascript/axios/client.ts b/src/targets/javascript/axios/client.ts index 5e1bb5c4e..493c12104 100644 --- a/src/targets/javascript/axios/client.ts +++ b/src/targets/javascript/axios/client.ts @@ -20,6 +20,7 @@ export const axios: Client = { link: 'https://github.com/axios/axios', description: 'Promise based HTTP client for the browser and node.js', extname: '.js', + installation: 'npm install axios --save', }, convert: ({ allHeaders, method, url, queryObj, postData }, options) => { const opts = { diff --git a/src/targets/node/axios/client.ts b/src/targets/node/axios/client.ts index 744cb4f03..9306eb0f8 100644 --- a/src/targets/node/axios/client.ts +++ b/src/targets/node/axios/client.ts @@ -20,6 +20,7 @@ export const axios: Client = { link: 'https://github.com/axios/axios', description: 'Promise based HTTP client for the browser and node.js', extname: '.cjs', + install: 'npm install axios --save', }, convert: ({ method, fullUrl, allHeaders, postData }, options) => { const opts = { diff --git a/src/targets/node/fetch/client.ts b/src/targets/node/fetch/client.ts index e7424fe35..c8f1b76c6 100644 --- a/src/targets/node/fetch/client.ts +++ b/src/targets/node/fetch/client.ts @@ -21,6 +21,7 @@ export const fetch: Client = { link: 'https://github.com/bitinn/node-fetch', description: 'Simplified HTTP node-fetch client', extname: '.cjs', + installation: 'npm install node-fetch@2 --save', }, convert: ({ method, fullUrl, postData, headersObj, cookies }, options) => { const opts = { diff --git a/src/targets/node/request/client.ts b/src/targets/node/request/client.ts index 30c0bae7e..284d13c0b 100644 --- a/src/targets/node/request/client.ts +++ b/src/targets/node/request/client.ts @@ -20,6 +20,7 @@ export const request: Client = { link: 'https://github.com/request/request', description: 'Simplified HTTP request client', extname: '.cjs', + installation: 'npm install request --save', }, convert: ({ method, url, fullUrl, postData, headersObj, cookies }, options) => { const opts = { diff --git a/src/targets/ocaml/cohttp/client.ts b/src/targets/ocaml/cohttp/client.ts index 4156cc07d..a7a9d91fc 100644 --- a/src/targets/ocaml/cohttp/client.ts +++ b/src/targets/ocaml/cohttp/client.ts @@ -19,6 +19,7 @@ export const cohttp: Client = { link: 'https://github.com/mirage/ocaml-cohttp', description: 'Cohttp is a very lightweight HTTP server using Lwt or Async for OCaml', extname: '.ml', + installation: 'opam install cohttp-lwt-unix cohttp-async', }, convert: ({ fullUrl, allHeaders, postData, method }, options) => { const opts = { diff --git a/src/targets/php/guzzle/client.ts b/src/targets/php/guzzle/client.ts index 6aa978c56..5248831ed 100644 --- a/src/targets/php/guzzle/client.ts +++ b/src/targets/php/guzzle/client.ts @@ -28,6 +28,7 @@ export const guzzle: Client = { link: 'http://docs.guzzlephp.org/en/stable/', description: 'PHP with Guzzle', extname: '.php', + installation: 'composer require guzzlehttp/guzzle', }, convert: ({ postData, fullUrl, method, cookies, headersObj }, options) => { const opts = { diff --git a/src/targets/python/requests/client.ts b/src/targets/python/requests/client.ts index 110dae5a2..f3e3944e6 100644 --- a/src/targets/python/requests/client.ts +++ b/src/targets/python/requests/client.ts @@ -27,6 +27,7 @@ export const requests: Client = { link: 'http://docs.python-requests.org/en/latest/api/#requests.request', description: 'Requests HTTP library', extname: '.py', + installation: 'python -m pip install requests', }, convert: ({ fullUrl, postData, allHeaders, method }, options) => { const opts = { diff --git a/src/targets/shell/httpie/client.ts b/src/targets/shell/httpie/client.ts index 5da406df7..18a00b83f 100644 --- a/src/targets/shell/httpie/client.ts +++ b/src/targets/shell/httpie/client.ts @@ -33,6 +33,7 @@ export const httpie: Client = { link: 'http://httpie.org/', description: 'a CLI, cURL-like tool for humans', extname: '.sh', + installation: 'brew install httpie', }, convert: ({ allHeaders, postData, queryObj, fullUrl, method, url }, options) => { const opts = {