This simple console app is built to demonstrate how the Kiota API client generator can simplify calling any OpenAPI described API.
The application will compile but is missing ApiKeys for several of the APIs. The API keys can be acquired from the respective API website and should be set as environment variables.
The console app needs an appSettings.json
file. To achieve it, copy the appSettings.sample.json
as appSettings.json
and fill the values for the 3 APIs we need API keys.
- Weather API : https://visualcrossing.com/
- New York Times Movie Rewiews API : https://developer.nytimes.com/docs/movie-reviews-api/1/overview
- Bing Search API : https://docs.microsoft.com/en-us/azure/cognitive-services/bing-news-search/search-the-web
Run dotnet run
and the app will perform the calls to the underlying APIs.
The console app needs an .env
file. To achieve it, copy the .env.sample
as .env
and fill the values for the 3 APIs we need API keys.
- Weather API : https://visualcrossing.com/
- New York Times Movie Rewiews API : https://developer.nytimes.com/docs/movie-reviews-api/1/overview
- Bing Search API : https://docs.microsoft.com/en-us/azure/cognitive-services/bing-news-search/search-the-web
Run npm i
to install all dependencies and npm start
to perform the calls to the underlying APIs.
This API is great to try because for a low volume of calls it does not even need an API key.
Searching for the word translate
will bring back this API.
kiota search translation
Key Title
apisguru::ebay.com:commerce-translation Translation API
apisguru::funtranslations.com:braile FunTranslations Braille API
apisguru::funtranslations.com:index FunTranslations API
apisguru::funtranslations.com:starwars Starwars Translations API
Using they key we can find more information about this API
kiota search apisguru::funtranslations.com:starwars
Key: apisguru::funtranslations.com:starwars
Title: Starwars Translations API
Description: Funtranslations Starwars API gives access to the full set of starwars language translations available at funtranslations.com so that you can integrate them in your workflow or an app. [Click here to get details and subscribe](http://funtranslations.com/api/starwars) .
You can also subscribe to individual translators. Here are the details.
Ever wonder how to talk like Yoda? Well, use our API and let your APP/webpage speak like Yoda too.[Click here to subscribe](http://funtranslations.com/api/yoda)
Sith Translator API. [Click here to subscribe](http://funtranslations.com/api/sith)
Cheunh Translator API. [Click here to subscribe](http://funtranslations.com/api/cheunh)
Huttese Translator API. [Click here to subscribe](http://funtranslations.com/api/huttese)
Mandalorian Translator API. [Click here to subscribe](http://funtranslations.com/api/mandalorian)
Gungan Translator API. [Click here to subscribe](http://funtranslations.com/api/gungan)
Service: http://funtranslations.com/
OpenAPI: https://funtranslations.com/yaml/funtranslations.starwars.yaml
Hint: use kiota download to download the OpenAPI description.
Example: kiota download apisguru::funtranslations.com:starwars -o <output path>
Hint: use kiota show to display a tree of paths present in the OpenAPI description.
Example: kiota show -k apisguru::funtranslations.com:starwars
From the response we can see that we discover more about the API using the show
command.
kiota show -k apisguru::funtranslations.com:starwars
/
└─translate
├─yoda
├─sith
├─cheunh
├─gungan
├─mandalorian
└─huttese
Hint: use the --include-path and --exclude-path options with glob patterns to filter the paths displayed.
Example: kiota show -d https://funtranslations.com/yaml/funtranslations.starwars.yaml --include-path **/foo
Hint: use kiota generate to generate a client for the OpenAPI description.
Example: kiota generate -l <language> -o <output path> -d https://funtranslations.com/yaml/funtranslations.starwars.yaml
With this information we can generate our Api client to have the class name TranslateClient
in the namespace Translate
.
kiota generate -l csharp -o funtranslate -d https://funtranslations.com/yaml/funtranslations.starwars.yaml -c TranslateClient -n Translate
kiota generate -l typescript -o funtranslate -d https://funtranslations.com/yaml/funtranslations.starwars.yaml -c TranslateClient -n Translate
kiota search News
kiota search apisguru::microsoft.com:cognitiveservices-NewsSearch
kiota generate -l csharp -o bingNews -d https://raw.githubusercontent.com/Azure/azure-rest-api-specs/master/specification/cognitiveservices/data-plane/NewsSearch/stable/v1.0/NewsSearch.json -c BingNewsClient -n Bing
kiota generate -l typescript -o bingNews -d https://raw.githubusercontent.com/Azure/azure-rest-api-specs/master/specification/cognitiveservices/data-plane/NewsSearch/stable/v1.0/NewsSearch.json -c BingNewsClient -n Bing
kiota search reviews
kiota search apisguru::nytimes.com:movie_reviews
kiota generate -l csharp -o nytmoviereviews -d https://raw.githubusercontent.com/nytimes/public_api_specs/master/movie_reviews/movie_reviews_v2.json -c NytMovieClient -n Nyt
kiota generate -l typescript -o weather -d https://www.visualcrossing.com/weather/specs/visualcrossing-weather-api-openapi.json -c Weatherclient -n Weather
kiota search weather
kiota search apisguru::visualcrossing.com:weather
kiota generate -l csharp -o weather -d https://www.visualcrossing.com/weather/specs/visualcrossing-weather-api-openapi.json -c Weatherclient -n Weather
kiota generate -l typescript -o weather -d https://www.visualcrossing.com/weather/specs/visualcrossing-weather-api-openapi.json -c Weatherclient -n Weather