Skip to content
This repository has been archived by the owner on Jul 29, 2019. It is now read-only.

Latest commit

 

History

History
101 lines (71 loc) · 4.71 KB

README.md

File metadata and controls

101 lines (71 loc) · 4.71 KB

Welcome to the API Elements extension for Visual Studio Code! This is a totally untested extension which will improve your experience working with API description formats like API Blueprint and Swagger. It provides some great features, such as:

Basic Screenshot

What's API Elements about?

API Elements is the structure for parse results of both API Blueprint and Swagger, and it is built on the Refract format. It provides a single format for interacting with parse results from various API description formats. So far, only API Blueprint and Swagger are supported.


Warning: This package is alpha and probably might be buggy, but I decided to share the progress for those who are interested. Proceed at your own risk!


Future development / ideas

  • Swagger support (move from drafter to fury)
  • Provide parser output
  • Render the document using aglio
  • Login with Apiary account to use some features on the IDE directly
  • Provide autocomplete (if I type + Request [ I want to see Http verbs, or in payloads I want to recall MSON structures)
  • Use Codelens feature to provide MSON references and Dredd test status for endpoint

Found a Bug or - do you need a particular feature?

Please file an issue at https://github.com/XVincentX/vscode-apielements.

Development

First install:

  • Node.js (newer than 4.3.1)
  • Npm (newer 2.14.12)

This extension is built on top of Visual Studio template; so:

To run and develop do the following:

  • For both server and client directory (in the exact order):

  • Run npm i

  • Open the server in Visual Studio Code (code .) and run the build task

  • Open the client in Visual Studio Code (code .) and run the launch task

  • Press F5 in the server to debug and use the extension in the VS Host instance.

Notes

Best parser selection

As you might know, Apiary offers multiple parsers for API Elements which get updated multiple times per week. In order to decouple this extension from the "parsing service" itself, the mechanism to detect the parser to use is the following.

This extension ships with drafter.js whose version can be determined looking at package.json of the server directory. The idea would be to update it everytime a new parser version comes out.

However, I know this cannot be always possible. So, whenever this extension is started, it will try to

  1. Lookup for a local drafter.js version in your current workspace
  2. Lookup for a local protagonist version in your current workspace.

If neither one or the other is found, the extension will use its internal parser.

In this way, you should be able to work with your preferred version without having to wait for update on my side. If a particular parser version breaks the extension, please file an issue.

Symbol navigation

Symbol navigation is strongly dependant on sourcemaps quality provided by the parser. Currently, the following resources are indexed:

  1. API Title
  2. resource
  3. resourceGroup

The idea would be, of course, to improve symbol navigation as much as possible and exploit sourcemaps in all their power. This, however, might take time. If you feel there are some important symbols I'm missing, please file an issue, I'll be happy to evaluate it.

Basic Apiary Integration

This extension is able to provide basic Apiary integration. Fundamentally, all Apiary client have been reimplemented following the Apiary API documentation. It means that you can perform the following actions:

  1. Fetch an API Description Document from your account
  2. Publish an API Description Document to your account

without having to leave the editor at all.

Most of the process is actually automated. Thous, it will ask you to provide a token and redirect you to the right page if it's not avaliable on your computer. All those commands are listed with an Apiary prefix. Therefore, to see what you can do, simply type Apiary in the command box to see what's going on.