Get productive with the IntelliSense extension

admin 4 2025-01-08 编辑

Get productive with the  IntelliSense extension

We have a brand new and shiny VS Code Extension to share with you!

 

TL;DR

Schemas VS Code extension makes your work with in VS Code feel like writing in a native programming language with autocompletion capabilities. The extension enables you to write and validate API definition, keys and config files using VS Code’s IntelliSense so you can enjoy all of its amazing capabilities:

  • Autocomplete fields
  • Validates files and shows required/optional fields
  • Provides default values for fields
  • Offers autocomplete examples OOTB and even field descriptions so you don’t need to stop and look it up in our docs

’s extension aims to reduce friction in your engineering work by making it faster and easier. This way, you don’t need to learn and memorise the ins and outs, can avoid the back-and-forth copy+amend code snippet from the docs, and just start using instantly with no learning curve.

Why do I need it?

When you want to write API definitions for gateway or dashboard, you need to create a JSON file with all the required fields and POST it as a payload with the endpoint that creates the API definition (//apis in Open source or /api/apis in Self managed).

This is what the minimum API definition looks like:

{   "name": "My New Api",   "api_id": "mynewpi",   "org_id": "default",   "proxy": {     "listen_path": "/myapi/",     "target_url": "https://httpbin.org",     "strip_listen_path": true,     "preserve_host_header": true  },   "version_data": {     "versions": {       "Default": {         "name": "Default"      }    },     "not_versioned": true  },   "active": true,   "use_keyless": true }

The same goes for policies, keys, users and catalogues, and also the various config files every component is using on start up. 

As you can see, writing such a file could be quite cumbersome. For example, you could search the API definition in the docs, paste it in VS Code, amend the values, search for fields that were not included in the example and add them. Another way is to GET //apis/{some-other-api} > api-myapi.json and then edit the file. This time, you’d need to read about the existing fields so you know which one you can delete and which to amend since the new API has completely different middleware configuration.

How to find and install the extension?

You can just look up “” in the extensions section of the VS Code Marketplace and click the “Install” button.

How do I use the extension?

Once the Schemas extension is installed, you are ready to start using it. The only requirement is to rename your file in the following format:

  • *.confFor gateway config file
  • apikey*.json – For gateway keys files/payloads
  • apidef*.json, Definition*.jsonFor API definition files/payloads
  • oasapidef*.json, OasApiDef*.jsonFor OAS API definition files/payloads

As you can see in the first screenshot of this blog, when you name the file in the correct format, you’ll see a pop-up window with a suggestion to auto-complete just as it would with any programming language. If you can’t see the pop-up, click control+space.

How does the extension work under the hood?

As you probably expect, to use IntelliSense (to achieve the validation, descriptions, examples and default values), we are using JSON schemas underneath. -schemas Github repository is powering the VS Code extension and is our home for all JSON schemas (it is still a WIP, and we’ll add and publish more schema types and versions, especially as more users ask for it).

You can also find information about the extension in our official docs.

How do I publish an API in 30 seconds?

You can quickly create the API definition using the example provided via IntelliSense’s pop-up and then POST it to the OSS Gateway.

What’s next? 

This project is very much in its infancy. We’d like it to be driven by real-life usage, so please do share your feedback with us if you like it and want us to continue improving and developing it. 

We have two main GitHub repos for communicating with us: 

  • Vscode-https://github.com/Technologies/vscode-/issues – for bugs and features related directly to the extension. For example, if you want us to support more file formats or you found a missing description.
  • -schemashttps://github.com/Technologies/-schemas/issues – if you feel like taking a deep dive into the schemas that are the foundation of the extension. For example, you want to add a new schema or improve an existing one with descriptions or examples.

We also welcome code contributions, in both repos and in any of open source projects. 

If you want to get in touch directly, you can email us at info@.io

And lastly, if you liked this extension, please give us a review in the VS Code marketplace.

 


Get productive with the IntelliSense extension

上一篇: Understanding the Significance of 3.4 as a Root in Mathematics
下一篇: Deploying an API gateway to Kubernetes with ArgoCD
相关文章