Summarized using AI

Integrating with REST APIs using Microsoft Kiota

Miller Levert • May 03, 2023 • Montréal, Canada • Talk

The video titled 'Integrating with REST APIs using Microsoft Kiota' features Darrel Miller and Sébastien Levert discussing how to simplify API consumption through Microsoft Kiota, especially for developers who face difficulties integrating with third-party APIs without SDKs. They highlight that dealing with aspects like authentication, serialization, and error handling can be cumbersome, adding risk and complexity to projects. Kiota aims to automate the generation of personalized SDK clients based on OpenAPI specifications across multiple programming languages.

Key Points Discussed:
- Importance of API Consumption: The presenters emphasize the rise of HTTP and REST APIs, stressing the need for easier integration tools for developers.
- The Role of Microsoft Graph API: They provide an overview of Microsoft Graph API, which exposes data from various services, allowing developers to connect efficiently to Microsoft's offerings.
- Challenges with SDK Adoption: Despite efforts, they note that only about 40% of developers leverage the SDKs, primarily using direct HTTP calls instead, due to hesitations around performance, dependencies, and discoverability.
- Generative Tools in Kiota: The platform can generate SDKs from OpenAPI description documents, enabling developers to automatically handle tasks like token retrieval and request serialization without diving deep into API specifics. It aims to allow focus on business logic rather than API intricacies.
- Flexibility of Code Generation: Kiota supports code generation for specific API endpoints, which helps minimize the size of the generated SDKs, thus addressing concerns related to performance and complexity.
- Demo of Code Generation: In a live demo, they showcase how Kiota generates client code for Ruby, illustrating ease of use and highlighting how it handles API calls efficiently.
- Future Enhancements and Community Contributions: The presenters discuss plans for expanding support across other languages and emphasize their commitment to openness and community engagement around Kiota.

Conclusions and Takeaways:
- Kiota presents a valuable tool for developers needing simplified access to APIs, particularly those unaccustomed to deep integrations. By enabling automatic SDK generation from OpenAPI specs, it streamlines development and enhances productivity. Community feedback and collaborative improvements are also essential for the platform's ongoing evolution and success in the developer ecosystem.

Integrating with REST APIs using Microsoft Kiota
Miller Levert • Montréal, Canada • Talk

Date: May 03, 2023
Published: unknown
Announced: unknown

Montreal.rb Ruby Talk 2023/05 - Integrating with REST APIs using Microsoft Kiota - Darrel Miller, Microsoft Graph API Architect, Microsoft & Sébastien Levert, Senior Product Manager, Microsoft

Your application integration with 3rd party APIs can be difficult if your application platform does not offer SDKs for calling the APIs. Implementation of authentication, authorization, serialization, and exception handling for calling APIs adds a lot of work and risk to your project. Join us for a session filled with demos that showcase how to generate your own personalized SDK client for a complete OpenAPI spec in multiple programming languages with the help of Microsoft Kiota. By using your new personalized client that is generated by Kiota, all the complex aspects of calling APIs get handled for you automatically so that you could concentrate on what really counts: creating value for your end users.

Montreal.rb Meetup May 2023

00:00:00.480 okay so call it what you will we tend to use
00:00:05.580 the phrase API consumption it's all about calling apis primarily HTTP apis
00:00:12.660 if you want to use the phrase rest apis that works too uh we are trying to make
00:00:18.359 it easier for people to call HTTP apis and you'll sort of see in a minute why
00:00:23.699 that's important to us um so we're starting to build a little bit of a montreal-based team uh Vincent
00:00:30.300 who actually arranged this thank you business but anyone who got married in Mexico right now and he said hey
00:00:38.520 sir Daryl could you go to this thing in Ruby and certainly I kind of looked at
00:00:43.800 each other okay sure yeah whatever no problem
00:00:49.800 um and so that's the three of us who are based here in Montreal uh but the team that are working on this set of tools
00:00:57.120 children and product to access apis is all over the world we have a PM that's
00:01:02.640 based in England we have a team at devs in Nairobi we do have some devs in
00:01:07.740 Redmond but you know we're kind of all over the place so to your question earlier we work from
00:01:15.060 Montreal but not really in in the Montreal office once every six months we'll go into the
00:01:21.540 exactly Isis like earlier today before we came here using our advantages make sure that they still feel this way
00:01:30.680 so the actual team that we work on is um
00:01:36.720 the developer experience team for you know call it a product called
00:01:42.000 Microsoft graph have you ever heard of marks okra do you know what that thing
00:01:47.040 is are you using teams at work sometimes
00:02:07.340 everything that facts teams and office and SharePoint which is where we store
00:02:13.260 files and uh emails and all click and everything all of that is stored across
00:02:19.280 thousands of services and databases and whatever but it's all available through
00:02:25.440 a single API that is available within Microsoft and we are the ones empowering devs to
00:02:33.180 connect to basically any pieces of things out of things in their like Enterprise database that is also by
00:02:41.280 Microsoft so because we're like we're building tools for for that team to
00:02:46.800 access data inside Microsoft because about age or nine years ago it would be
00:02:52.200 you went and used a long drive or you went and used the SharePoint issue or you use the exchange API that was all
00:02:58.500 managed by a different teams presented documentation at Egyptian set of sdks and everybody just think kind of
00:03:04.440 differently and to get a token for each one of those and it was a pain and so it was actually
00:03:09.599 um the people who were working micro field sales were like you need to fix the ship because it is a mess and it's a
00:03:16.620 nightmare getting people to integrate the stuff and so Microsoft graph was born as an umbrella and really we are
00:03:22.920 just a proxy we're just a oh cool term of the Year Federated Gateway
00:03:29.840 to all of the underlying Services um just so that there's a consistent
00:03:35.459 developer experience and all of that data that's stored in the Microsoft cloud gets exposed but it ends up being
00:03:42.540 an API surface area 22 000 operations across the whole APS
00:03:48.780 surface area which causes some challenges with certain tooling when you're trying to use it so one of the things our team builds is
00:03:57.299 a bunch of sdks and a bunch of different languages and we're fairly successful at growing
00:04:04.560 the use of rsdks we've got more than 500 000 applications out there going and
00:04:10.080 calling Microsoft graph API to do various things we've got some good growth we've got growth across a bunch
00:04:15.480 of different languages Ruby is in there somewhere but we have a ruby SDK that
00:04:22.800 has been had it's just no love quote for quite a number of years because we
00:04:28.380 haven't had any devs on the team who actually knew how to use Ruby um and so but we do actually have some
00:04:36.479 usage of it we have a lot of growth billion requests a month like using RSP
00:04:43.320 cameras and starting to get a little bit of hockey stick we're getting good growth it's great
00:04:48.419 until you look at this chart where the green is the stuff used in usdks and the
00:04:54.960 purple is people just calling the HTTP API directly a lot of people just like don't use
00:05:02.340 rsdks hurts yeah curious here so you're
00:05:08.220 building mainly I guess in the ocean in some other languages
00:05:13.520 away what's your feeling about asdk do you do you like using an SDK a
00:05:21.120 library that kind of abstracts the complexity of an API for you or you're
00:05:27.300 like the warrior and it comes in hey I know how to do it I know how to do it it's easy yeah it's that resource
00:05:33.419 passing in a bearer token boom access and then yeah what if your needs
00:05:39.840 is in your mind before deploying the risk is that it should be
00:05:45.180 simple you know I just need this so I'm a very basic thing maybe just a call you know you're in
00:05:52.259 your python or Ruby world so just call that http get an adjacent resolve and
00:05:58.080 that's it but your question is also okay if if there are some that would say a behavior
00:06:05.220 of uh content and maybe library's maybe something tricks that I don't know because you
00:06:12.300 know it's a new field maybe I want to be well taken care of maybe I would like to
00:06:19.220 something a little more advanced so it's suffocated look at tutorial trying to figure out what's going to do for me you
00:06:25.979 know doing what I need cool I'll just import it download it package it whatever yeah and then I'll use this yes
00:06:31.919 awesome are others feeling the same but maybe as many people are using
00:06:40.319 I don't know the exact results about it yeah maybe they're using Legacy software
00:06:46.020 they're just some dating it day by day and they don't want to go around
00:06:51.500 so you don't touch or whatever is there so maybe you're using it SDK and you don't like it because you're in an old
00:06:57.240 code base or you're not using an SDK because you you don't like it because you're also in that old pull-based
00:07:03.479 buildings or whatever yeah that's what we're using it doesn't
00:07:09.500 what we do we do have an SDK project we built our own
00:07:15.500 modules yeah because it's like because of migrating our stuff
00:07:21.300 like that that's been expensive but why is we will do it if we already have one
00:07:27.360 yeah how many sdks you might take it
00:07:33.060 5 10 100 maybe yeah there we go
00:07:38.400 so why do we care about people using sdks well we spent a while in the space
00:07:45.060 and we found people run into a bunch of issues so we've built stuff that makes it easier to do all because getting the
00:07:52.259 token is usually one of the hardest parts obviously call it an API um over on Microsoft graph world we have
00:08:00.060 started to have some Advanced capabilities where admins can control access to a variety of things and make
00:08:05.940 sure that you're doing multi-factor authentication and we handle all this kind of advanced all type scenarios in
00:08:12.419 rsdks so people can get on with just doing the business that they're trying to do and not worrying about all these
00:08:18.720 fancy new security things retry handling you know people with hammer apis and end
00:08:23.759 up returning a 429 and we do the right thing return retry after headers that say how long you should wait before you
00:08:30.120 try again and our Appliance staff libraries do that you know serializing and deserializing the payloads for the
00:08:37.080 most of the time is fairly and forward until you get adjacent payload with a date or duration or
00:08:43.500 very large decimal value or a decimal where you care about the Precision there
00:08:48.959 starts to be a bunch of edge cases when you have things where you're using inheritance or and you have polymorphic
00:08:55.680 collections this gets harder we take care of a lot of these things so we have found that by developers using the sdks
00:09:04.080 they can build apps movable get to Market faster and you kind of stall my thunder on this
00:09:10.620 yeah sorry actually this is my this is my how do you feel about sdks and what
00:09:15.779 I've found is like there's people who either love them or they hate them right it's kind of like I won't use your API
00:09:21.300 unless you give me an SDK or yeah get up on the plane I don't know how to make http
00:09:30.560 We're Not Gonna Be Friends so over time you've really identified a
00:09:37.080 bunch of things why people don't like using SDK so I don't need this because I know how to do it so
00:09:44.220 I don't want dependencies dependencies can be a real thing especially when you start calling multiple apis through your
00:09:50.339 application because that SDK pulled in some dependency library that one pulled
00:09:56.040 in the same library but a different version of it now there's conflicts of it there can be challenges people can
00:10:02.399 struggle to find sdks because it's like well where do I go looking well okay maybe you can go looking on your package
00:10:08.580 manager uh and you can find it but is that the official one or is that some kind of like Community developed one
00:10:16.260 um performance people are like well they're not too sure about that SDK was it
00:10:22.200 written efficiently is buffering item there did somebody know what they
00:10:27.720 were doing or did they just use a code generator and spit out garbage right because they were just in a hurry and
00:10:32.940 the boss told them go generate this thing in seven different languages
00:10:38.459 um because this is the problem that's making a provider you don't just have to support one language you got to support
00:10:43.980 a bunch of languages for the broadest audience we have a unique problem of having 22
00:10:50.700 000 endpoints is that our package gets kind of large you can talk to Seth
00:10:55.980 afterwards about how large are typescript packages that we probably will never ship because
00:11:01.620 of how big it is um some people don't realize the value that
00:11:07.200 it's bringing yeah it's a Marketplace and quality is definitely an issue there's a bunch of not very good
00:11:13.040 cogenerators out of there there's also a bunch of challenges with code generators often will work off an API description
00:11:19.800 there's a lot of low quality API descriptions out so there's reasons why people don't want
00:11:25.260 to use sdks but then there are people who absolutely do want it and I want to walk through a little bit of a scenario
00:11:31.380 of one of the popular apis today and sadly it's called open AI so I'm gonna
00:11:37.260 have to say the words open Ai and open API all together a few times it's hard work good luck
00:11:44.100 um so open AI everybody's into chat GPT and all the things I want to go and and
00:11:50.519 call it and integrate these great llm capabilities into my application they've got a really nice developer portal and
00:11:56.880 you can they show you how to do it you can learn a lot of things about how to call chat GPT from this API and if you
00:12:03.899 want to build your application they've got sdks in node.js everything else is like this Community
00:12:10.200 Library go figure it out yourself now they did provide an open API description
00:12:18.300 and so you can go download that open internet description and you can feed it to a code generator so that it will
00:12:23.940 generate an SDK for you in fact that's actually what they did for their typescript
00:12:30.920 no the type of the heavy coded the JavaScript one they generated
00:12:36.720 because all the machine learning folks are all the python Cruisers um so they went and used open API
00:12:43.440 generator which is one of the most common uh generators out there um
00:12:49.440 but it doesn't work so then they wrote a bunch of scripts that would take their open API
00:12:55.740 description and fix the open API description because open API generator has a bunch of scenarios that doesn't
00:13:01.320 really support and so it just becomes complicated okay fine it does generate and it will work
00:13:09.120 if you're working in a fairly Dynamic type language because the way that open
00:13:14.639 apis describe their API especially when you're doing prompt completion they have this little description here using
00:13:20.760 adjacent scalable and they say if you want me to do a prompt completion you can send me a string or an array of
00:13:27.959 strings or or an integer or an array of integers well if you're a code generator
00:13:34.200 trying to generate that in Java or C sharp it's not the easiest thing because
00:13:40.680 it doesn't have Union tires and so most SDK generators will not be able to
00:13:45.839 handle this so what's the good developer to do well maybe else has gone and built something
00:13:51.660 so I'm going to go to my package managers I'm going to nougat and I'm going to go if I'm a C sharp developer
00:13:57.660 and I'm going to search for open89 fortunately I have a luxury of many choices of 37 different packages to
00:14:04.800 choose from which one am I going to pick there's none of them are official no idea how long somebody spent we don't
00:14:11.459 know which ones of those are doing Bitcoin marketing inside it right how long you know whether or not it's ever
00:14:17.279 going to be supported and it's not just in the C sharp world if you go to npm and search for opening API there's 60 on
00:14:23.940 packages there they even have an official one there's still another bunch of them so it's like you're like oh
00:14:33.440 dependency that's going to go sour I don't have to ah it's not a very big API there's only
00:14:41.399 those few endpoints I only need to call some of them all right I own right and
00:14:47.519 then we've got another one I can just just it's just calling HTTP I know how
00:14:52.800 to make HTTP calls and the happy path of making HP calls yes is a fairly happy path it's not too
00:14:59.699 bad edge cases that come back further down the road when you deployed the app into
00:15:05.339 production and something goes wrong and you're like I wish I had something a little bit more robust and more
00:15:11.820 resilient because I just didn't have time or it's not my
00:15:18.360 area of expertise I know how to do a basic call but I don't really know how 429th or or what a 202 means a what a
00:15:25.380 407 means right so this is where we are trying to help
00:15:31.560 out here we're trying to help out API consumers consume apis because
00:15:36.600 traditionally the role of honest having an SDK is a
00:15:42.540 burden that we put on API providers I've got an API I want all the people to come
00:15:48.060 use my API because I think it's awesome and I want to get customers and I want to reach the wireless audience so now I
00:15:53.579 have to produce sdks in all of these languages but I'm going to produce a bunch of sdks
00:15:59.399 they're not quite the same as another another API who produces what your sdks and so
00:16:06.120 there's that resistance and like you saw our numbers like we're a team that have spent a lot of time with sdks and we're
00:16:13.320 only seeing 40 of our customers using our sdks even with their effort that we
00:16:19.500 put in and I've talked to people at Google I've talked to people at GitHub our numbers are no worse than anybody
00:16:26.519 else's when it comes to adoption that's the case yes numbers are real because because Legacy
00:16:32.279 work that came before you or you're starting from a certain date they say
00:16:37.920 we're available and still people are not using so the 40 is 40 of new
00:16:44.339 applications so every day people are creating new app in the in our portals yeah they get a an
00:16:53.160 ID and a key and 40 of them are using vsdk 60 of them
00:16:59.399 are not and we have a team of people looking at our portal trying to optimize
00:17:04.500 our paths to get people to drive take them down the happy paths like we've we're funded to do this and yet there's
00:17:11.400 still a challenge there right there's still that resistance and it causes people to go build stuff
00:17:16.919 so how do you solve the problem where there's all these different options that
00:17:22.860 you don't like anymore you go build another one we built a new code generator oh that's the wrong way I want
00:17:28.260 to go that way and this is just kind of a high level of
00:17:33.780 the way we think about the way we do code generation we are building it off open API because we went through a bunch
00:17:40.860 of years of API description Wars and the war one an open API basically one as a
00:17:47.120 description format for interoperability there are better languages API design
00:17:53.340 languages out there for Designing but as far as interoperability open API works
00:17:59.340 we'll take VT V2 V3 hopefully very soon we'll support V 3.1 the animal Jason I
00:18:06.299 don't care whatever you want Pull It in we take that set of URLs in the API we
00:18:12.780 build a tree out of it there's a lot of other code generators
00:18:18.240 who have tried to take the list of operations in an open API description
00:18:23.640 and try to create a bunch of methods on the class and it doesn't scale and it
00:18:28.740 requires developers to go and fill in the operation ID so first of all I designed my API and then you want me to
00:18:35.220 go and give a bunch of new names so that you know what to do coaching we don't we use the path structure that hierarchy
00:18:42.840 and that works well for us with graph because we are a big surface area
00:18:48.240 you'll see what we mean by that so if we build the URI space and then we create a code guide a lot of code generators out
00:18:55.320 there we'll try to use templating as a way of doing it Templeton has its pros
00:19:00.900 and cons we used to do templating you know the kind of the mustache templates approach but it actually causes a lot of
00:19:08.400 Maintenance work s um and we it ends up pushing a lot of
00:19:15.059 logic into the terms of sort of specific two particular languages which becomes a
00:19:20.520 maintenance burden so we build a code model based on what we generically think
00:19:26.160 our SDK should look like what classes should exist what properties and methods and then we refine it by model so that
00:19:33.299 we're using the features of the language in C sharp we make sure that we use indexers in go we go well I guess we
00:19:40.559 don't have inheritance so we'll figure out another way of doing it we use the capabilities of The Language by refactoring that code model and then we
00:19:48.240 just pass it on to what we call language writers so the particular language writers just take the code mod and
00:19:54.600 they're writing it out and we package all this up in a fairly straightforward cross-platform single binary you can
00:20:01.500 download it in a Docker container you can download it as a cross-platform exe you can download it using regular.com
00:20:08.039 but it works anywhere and it's fairly low impact
00:20:13.679 but the code generation is only one part of the story let's look at how it fits in to your
00:20:20.820 overall applications you have your application
00:20:26.580 and you want to call our generated Kyoto API client code and we have a pretty
00:20:33.960 opinionated way that we project out that HTTP API service area we don't try and
00:20:40.260 minikits the most perfect API surface area possible we'll try and make it as
00:20:45.960 consistent with the API as possible and is predictable because as we're discovering in this world of co-pilots
00:20:52.740 and llms and generated stuff predictable this has a lot of advantages
00:20:57.840 but we also don't recommend that you if you're building an app that you put our code
00:21:03.720 all the way through your code base build the service adapters go to service adapter over our code it
00:21:10.140 allows you to configure it set up your Telemetry if you're using open Telemetry do all of that necessary configuration
00:21:16.020 and isolate our generated code from the rest of your application okay now we've
00:21:21.179 got the generating code because it figures out how to make the HP requests does all the serialization all that
00:21:26.220 stuff it builds on top of a bunch of core libraries the only one you really need
00:21:31.919 is kill abstractions which describe defines this interface layer between our
00:21:37.380 generated code and the native code that is calling the underlying negative HP
00:21:43.380 libraries so in Ruby we're using Faraday at the moment if you want to use a
00:21:48.659 different HTTP client Library you can build replaceable core libraries if you want to support other media types you
00:21:55.559 can build your other serialization libraries if you have some weird authorization model that you want to do
00:22:01.500 you can plug that all in it will all just work but it's that stuff then allows you to call
00:22:08.400 an HTTP service any HP service in a fairly standardized consistent way you
00:22:15.780 learn it once you can call any API describe an open API
00:22:22.020 now this is not a new idea this idea of having consumers generate code in order
00:22:29.220 to be able to call other services we've never really done it for HTTP for some
00:22:34.260 reason we took a different path we expected API providers to go do the work but if you work in graphql you
00:22:41.640 don't go oh I want to go and download the graphql SDK for GitHub just go download some graphql quiet side tooling
00:22:49.380 and it can call any graph as well API if you want to call grpc you can go to Chronic C grab the Proto schema generate
00:22:57.539 a stub boom and I usually get some moves and misses when I mention this but
00:23:03.240 that's how I did it and so too you pointed to a whistle and we generate this stuff and you can
00:23:09.600 make a call but there's far more htcp apis out there
00:23:14.880 it's been there are the other protocols and so this is where the biggest
00:23:20.100 opportunity is just to summarize for a second
00:23:25.679 why are we doing something different because there are other open API there
00:23:31.020 are other code generators based off the open API that arouse them
00:23:36.360 a who focused on the consumer and what we discovered when
00:23:42.419 we started focusing on the consumer as I mentioned it before it's way more than
00:23:47.580 just generating the code there's a whole experience around I want to go call it
00:23:54.360 AP first of all you've got to discover that API analysts open API description that in itself is a challenge so we
00:24:02.039 built tooling to go searching for open API descriptions and we've got a bunch of different techniques is how you can
00:24:08.220 find the open API that you need we also recognize is that
00:24:13.980 people don't consume apis in the same level of granularity
00:24:20.460 as the way people publish them with the team that publishes it says here's the set of functionality that does this set
00:24:26.880 of things that might be useful to you and use the consumer bill I want that and I want that and I don't really care
00:24:33.419 about the rest of it at the moment I only care about those things why should I generate code for the whole surface
00:24:39.960 area what I normally care about those so we built tooling that allows you to just
00:24:45.000 generate the code for the forest that you care about now go back to Microsoft craft when you've got 22 000 endpoints
00:24:51.780 nobody calls them all and you have size problems so if you can just pick the ones that you want you don't have size
00:24:57.900 problems anymore we don't even install them we don't know what all of them are
00:25:03.840 exactly they're all finished um open API support I'm a little bit of
00:25:09.000 a developed on this particular topic I've worked since 2016 on the open API technical steering
00:25:16.919 committee so I contributed a lot to open API V3 we're currently working and okay
00:25:24.260 3.1 we're currently working on it we need the IV uh code name moonwalk
00:25:30.179 because nobody likes open API and everybody still calls it Swagger so we figured well if we point with a new name
00:25:36.360 it's cool maybe if you want to stop holding the Swagger um
00:25:41.760 so we are very fixated on making sure that we
00:25:46.980 accurately represent open API descriptions support all the features and generate as accurate as possible
00:25:53.299 sdks from that open API description I mentioned about the fact that we built
00:25:59.940 this URI space rather than me try and describe it it's better if you just see it in the demo as
00:26:05.520 to what we mean by that and last but not least some people like this point some people
00:26:10.919 don't um and especially because we are a completely open source project we are
00:26:17.400 I'm gonna say wait are we Apache or MIT I think we're mites that might say all of Microsoft stocks
00:26:23.820 we are on Microsoft GitHub or we are MSA license we have had a bunch of
00:26:30.179 contributions from external people red hat and now contributing extensively right now we're going to use this for
00:26:35.760 their Cloud sdks um and we intend on building the community we're in conversations with
00:26:42.120 GitHub GitHub need to support some of the languages for their API so they're trying to get out at the moment
00:26:47.900 we need sdks for our Microsoft graph customers we have a team building it
00:26:54.179 across these languages yes we don't have something with Ruby skills and I absolutely wish we did
00:27:00.120 um but we're learning and this is another good reason why we're here because we need feedback on our our Ruby
00:27:07.500 Generation Um but we're not going away
00:27:12.860 this tooling is going to need to exist for Microsoft and we are absolutely
00:27:18.659 committed to it being an open source effort that accepts external contributions not just a source open
00:27:25.380 effort and with that I'll stop talking and he's going to try and show Rubik's
00:27:31.860 head 31 minutes without seeing a code my eyes are deleted
00:27:36.900 um slides are boring no I'm joking uh I hope you like the story do you mind if I stay in English I don't know the flow is
00:27:43.140 just more natural I do I get everybody is everybody speaking French
00:28:10.460 yeah but that's okay um as I was talking about
00:28:15.659 being an API consumer first kind of thing product technology
00:28:21.320 approaches and I'm going to ask you this where is a developer spending their
00:28:29.100 entire day in their goddamn IDE right they spend
00:28:34.679 their time coding I can bring you to a portal I can build
00:28:40.080 you a nice ass I could those are all things that will distract you from being productive as a Dev
00:28:46.679 that's why you have so much tooling and when you commit to an idea or to a
00:28:52.740 technology you make sure that okay there I cannot I don't want to notepad plus the last type of experience when I code
00:28:59.460 even though I did that when I was younger and I thought it was cool until I kind of learned what the world was
00:29:05.400 about and oh my God I can dot something and I can see what's available in that
00:29:10.500 object and and that's cool I'm cool Pilots second that's how I learned my Ruby
00:29:17.580 skills co-pilotism is a great virus still big big big cabin
00:29:25.220 we as Microsoft the technology we're building which is kyota is built in the
00:29:32.820 language of choice of Microsoft it's the language we we have uh the most knowledge about it's definitely we're
00:29:39.720 building it.net into C sharp for you like you don't even need to care about what's detect that is behind it unless
00:29:46.320 you want to contribute to it and it's a great learning opportunity that's what our folks at Red Hat have been sharing
00:29:51.960 with us because they're not writing in that absolutely keep in mind.net today is 40 plus across platform Linux Mac or
00:29:59.820 Windows you can run it on PS code that's what I'm going to do today um so but we want to to reach the devs
00:30:07.740 where they are when we look at the numbers today even though some languages have great support
00:30:14.659 okay support vs code is where a lot of developers are spreading they are I'm
00:30:20.940 curious I'm going to ask you the reasons what are you using in Ruby to code so vs code
00:30:26.720 okay cool okay so the okay that's that's the the
00:30:33.000 other one um well maybe like in the in the compete space
00:30:38.880 um we're trying with with we're starting with vs code everything we do is actually part of the kiodesk like the
00:30:45.960 CLI we build so actually plugging into where there's our building could be something that that we think um in the
00:30:52.380 future in the future um so if we say that we live in Via Stone
00:30:58.200 that the devs are there that the tooling is there and why not build for these
00:31:04.260 folks right um so let's go on and open up we have an interest in terms of someone who's going
00:31:10.980 to try to build an intelligent plugin and Delhi and there we go so there we go we're going to extend that some of that
00:31:17.100 so let me close that thing here some close teams still think that there's nothing in the
00:31:22.440 thing popping up on my screen uh and let me open up that um
00:31:32.820 VM here that runs somewhere in in the cloud
00:31:39.179 um why I'm building it I'm running a VM I swaps up like four laptops a day so it's just easier to have that one thing
00:31:45.840 so I don't have to build everything all the time let me close that
00:31:57.720 it's okay sometimes I switched to light yeah
00:32:03.840 um it usually um in presentations we should be using light
00:32:09.539 um to small room so I must not I'm not too scary we're leaving so where do we start I wanna
00:32:16.980 learn about kyota by the way I'm recording these like this light better for me no it's it's going to be okay
00:32:23.279 it's gonna be okay um so I'm here I'm in my machine I run this
00:32:29.580 on Windows I'm actually not on Windows you can see here on you I'm running it through double ESL the windows uh it's
00:32:36.899 obsessive for Linux so I'm in Linux I have vs code open and I want to figure
00:32:42.840 out what kilo is all about so as a Dev my first thought the thing that I did I
00:32:48.240 shoot for Ruby I was like so we had to talk we want to meet the the Ruby devs
00:32:53.940 where where do I start I go in the extensions in VSCO in I type Ruby then I
00:32:59.159 got a little bit confused about all the ways to get intellisense and debugging and everything I ended up with the
00:33:04.200 Shopify extension is that the best one that's I don't know like the one that like provides all the really cool
00:33:10.559 intellisense and running debug whatever also complete yeah you tell Hisense is very visual studio
00:33:18.120 um so that's why my search might have not really do the best thing so I'm gonna go here I'm gonna search for stuff
00:33:24.659 I'm gonna search for kios and then I find that one extension
00:33:31.080 which is the Microsoft Toyota where you have all the description here it's already installed you install it what it
00:33:36.659 does it does two things it installed the extension so basically a UI
00:33:44.100 add-ons in some areas of vs code and it also installs the CLI so the tooling to
00:33:51.480 generate code inside vs code so as there's like a map folder somewhere it
00:33:57.059 installs it there and it tells me at the bottom that I'm using the Q10 1.1.3 version
00:34:04.159 which when you come back to us and you say your stuff is perhaps uh it's it
00:34:09.899 broke my code we're going to ask you for that uh so that's why we used to write it actually
00:34:15.899 um
00:34:30.780 three seconds and now I have a new kind of crafty I call them right here it's
00:34:36.480 Cuba welcome to Kiana um
00:34:44.280 we start there the first thing that I said earlier is dads have a hard time to
00:34:50.339 find apis I have a hard time you guys when you're building tools in the open
00:34:57.060 API space I can tell you that sure sure finding open API descriptions that are valid well written
00:35:04.200 that are a natural representation of the real API is a challenge so we're like we
00:35:12.780 can believe all the debt needs to go through this if we need to go through this so we're going to build something really cool because there is no npm and
00:35:20.579 JS equivalent for it yes there's no nougat there's no made in central there's no equivalent but imagine if it
00:35:27.839 was because then we could have one for all programming languages it wouldn't matter if programming we just all have
00:35:33.839 one and that's the beauty of apis apis are language agnostic right it's
00:35:39.119 a URL an HTTP endpoint and you call it in your in your ads even for somebody
00:35:44.460 that does not want to have to like generative code having an idea of what the API looks like is not a bad idea
00:35:51.599 so let's start with search and is it big enough in the back yeah it's good okay
00:35:57.839 um
00:36:24.140 do we agree with the policy or we don't uh but I've never searched this before
00:36:30.720 I know it's there oh you didn't so currently yeah there's a V1 of the API
00:36:37.560 there's the current so I found two apis there's the V1 there's the V2 there's
00:36:43.560 some description there's the description if you want and cool so uh
00:36:57.980 I just want to connect to the API I don't even know what language I'm going to build let's say every day you come to
00:37:04.020 work you're like I'm gonna go relax I'm gonna spin a big wheel and it's going to select the language for me okay let's do
00:37:10.680 that it's HP day it's PHP it's uh pearls it's been a while I've been coding for
00:37:18.180 um I clicked on the API and then it opened up a tree
00:37:24.560 yeah so am I gonna do this I can go okay so there's a couple of ones
00:37:30.240 um in in the URL segment now I have okay I have compliance definitely Twitter must not because
00:37:39.780 you did a search and yeah so so q9 is plugged into
00:37:47.339 um different search providers we use a first one which is a portal called API
00:37:53.339 gurus which is a vetted set of open apis 2500 approximately open
00:38:00.000 apis that are vetted confirmed valid
00:38:05.339 um we also use GitHub so basically anybody in the world could create a repo
00:38:12.359 tag the repo at the topic um index on on their repo and we're
00:38:18.240 going to search for an API that Json on that repo so what is a cool thing is everybody can
00:38:25.320 publish that it's using GitHub so zero gosh I do that I go through PR mechanism
00:38:31.020 I update my thing based on the updates in my API but also we provide the
00:38:36.660 capability to do that for private design so you can log into the tool with GitHub
00:38:41.700 and then you can do that in your private GitHub videos you're using GitHub private to do some stuff
00:38:47.520 um so depending on the organization like everybody has different things but nothing will prevent us for example to
00:38:53.040 build a get lab uh connection a Azure devops connection a whatever the tool
00:39:00.599 you're using we could do that so I clicked on it I basically in the API of
00:39:06.599 Json there's a link to the open API and I load it basically we have libraries as
00:39:12.119 we build and cars that horrible I hate you who loves me
00:39:19.339 yeah bad audience I guess uh I'm a Jackson
00:39:24.780 died yeah I know I know I know I've I've been
00:39:30.000 through this I I was in the PHD space before though I'm filming Symphony
00:39:36.240 um so it opens up their creative truth
00:39:41.579 so think about it when you do an HTTP call straight to the API what would you
00:39:47.760 do here you can already see it almost like a documentation right
00:39:53.640 I don't have that version loaded up because but now we actually have as an open API
00:40:00.480 there's actually an option to provide prescription and then the
00:40:05.700 documentation yes so now you actually would be able to click and get online click through this
00:40:11.460 specific method get the documentation by the API provider so from a new pad provider
00:40:17.400 there's no cost if anybody can become a nuclear provider or you generate your open API and then
00:40:22.740 you don't need to generate all the sdks because the consumer as well as like everyone right now let's say interested
00:40:28.020 in tools and I'm interested in uh the fire hose I'm going to get a
00:40:34.740 streak so here I could do this I'm like I really like Twitter I'm gonna go up I'm
00:40:41.520 gonna add them all now I basically generated the SDK or a
00:40:47.640 library that connects to everything in in Twitter
00:40:54.660 what I want to do is just a straight line if that's the only thing I care about my boss asked me I'm gonna have to
00:41:01.320 stream of all the all the Tweets in Twitter
00:41:06.660 as a background on like a TV on like you go at the Twitter HQ and you have all
00:41:13.020 the tweets and it's just clicking the fire emotion pretty fast yeah I don't
00:41:18.300 think it's any useful but hey maybe maybe Ellen loves to see all the tweets okay
00:41:26.060 like and that would be an example of how we manage 429
00:41:35.660 identified the pieces of the API that I care about um I'm gonna go on I'm going to hit play
00:41:43.520 oh I'm very very cool let's see how it works now it's gonna ask me you want to generate an API
00:41:50.579 client for this yeah okay how do you want to call it I want to call it Twitter
00:41:56.280 client I want to call it I don't know I'm going to call it within Twitter
00:42:04.380 um let's put it in Twitter in a folder called Twitter and then it's just going to generate all the code
00:42:11.099 and all the HTTP stuff and everything is part of that package it's going to
00:42:17.640 rely on on the on our abstractions our implementation that we provide by default or your own if you want to rely
00:42:24.660 on your own I'm gonna do that and it's going to ask you okay cool this is where the roulette starts
00:42:33.540 um uh what do you want to do do you want to do C sharp this is the only one that is
00:42:39.420 stable but you won't be able to read it right and it's going to be fun you won't know if it actually works
00:42:45.900 um I never missed it but I mean I can read it I think everybody can if I have no job if you're if you can read
00:42:53.220 typescript you can see each other even like yes today but
00:42:59.460 let's go where we are let's do Ruby yeah yeah right
00:43:05.099 and now this is where we never know actually like generations of 25 implied
00:43:13.319 for Ruby at and it gives me the password just creating it thank you that's it let's do it have a
00:43:19.859 great day everybody we're not showing you the code
00:43:26.060 so let me go back to my Explorer well now you see this I have I don't know a
00:43:32.220 very bare bottom this is probably tons of back practices in Ruby I just want to I think the goal
00:43:39.480 is not to show you how I'm good at writing Ruby the goal is to show you how good we are as generating Ruby code that
00:43:45.780 you can put in your super cool app this is the value is there not our all right so we have Twitter so what do we
00:43:52.619 have in here we have one thing I love how it translated to to because
00:44:00.060 some languages does not support using um
00:44:05.660 so first the queen of the client in there and you see it's it's proper
00:44:11.640 Ruby code and in there there's initialize and then you're going to find it too method
00:44:18.180 so you're going to be able to do client Dot two then afterwards is gonna
00:44:24.480 do a 2 what does it look like
00:44:31.140 does it look like the URL pretty much looks like the URL right so except like a two yeah but when you're
00:44:39.720 going to use in your code you're not just going to call get all stream tweets or get all tweets
00:44:47.220 from stream no you're gonna respect the API structure and that's a key to why
00:44:54.240 when you you maintain 100 sdks like I'll have different maintainers different
00:44:59.280 Fashions this year this pattern was cool the next year this pattern was not cool
00:45:05.760 so now you have 100 sdks to maintain well this all your sdks are exactly the
00:45:11.760 same the same thing you would be using just by using you should be endpoints but you're using that then you can go to
00:45:17.280 the tweets and then the tweets you're going to have the fire hose and then the firehouse you're going to have a stream and then the stream you know have
00:45:23.280 the stream that you're going to have to get because you're going to do a get on here streaming
00:45:30.240 so that's what we do we generate just the pieces of an API we line everything
00:45:36.180 up together we create the structure we make sure that it's properly created you don't
00:45:41.940 have to think about this code we even have questions around should you commit this code
00:45:50.220 why because actually as part of the generation we just created something
00:45:55.500 called a q a lot file that killer that file is this
00:46:01.740 this and where the description is what's the hash so basically if it
00:46:08.880 changed we're going to know that it actually changed and only if the methods
00:46:14.040 that you selected change do we care about it so some of the things that you don't use change they won't do a region
00:46:20.579 exactly and then at the bottom you're going to see oh the include patterns we're using glove patterns to give you
00:46:26.760 so that's the pattern that we care about in the URL we and then you could regenerate and
00:46:33.720 regenerate and regenerate the same code will always get generated so your code that is that you're you're using will
00:46:40.560 never get broken especially if you put the facade on top of it you're a service adapter something that has all your your
00:46:48.660 business uh best practices in there then we're good to go
00:46:54.359 so so the goal is to to have like say functional code that works yeah and then
00:47:00.359 you're happy in you with the last what you just you just quote was it you know it's going to update itself in some way
00:47:07.319 yeah how many people are playing on changing that code based on your experience that go into
00:47:13.140 that code and kind of fine tune it or something it's not nobody said we do not so our recommendation is don't touch it
00:47:19.200 yeah okay anything you're going to do there next Generation we're not even looking at it
00:47:25.079 if you if you tell me you regenerate we're gonna reach it we're not doing this yes uh yeah you guys can even
00:47:32.160 improve further on that code if you follow the rails conventions of translating um rest apis into show update delete
00:47:40.260 create um index yeah that would be even a higher level of
00:47:46.619 abstraction what we've talked about doing is adding hints into the open API
00:47:52.500 description so if you have a gap method you can put a hit a client hint that
00:47:57.780 says when you go generate the the final method on the end of the path don't use
00:48:03.119 the word get use this word instead but interesting sure interesting for Ruby
00:48:08.940 looks like there's a convention but it's it's so right now we're really focusing on HTTP so HTTP is get whatever it is so
00:48:18.420 so that's a very very good thing and I think this is exactly like a feedback you want to hear from from you is
00:48:25.440 will this look ridiculous across the rest of your of your code base or
00:48:32.339 remember this is commodity code it's code you don't really want to make code
00:48:37.440 you don't really want to write officially and it's code that even you might you never come into you might
00:48:42.540 never see that real code you're going to see the the projection of it when you're going
00:48:48.660 to call it but the actual code is not that right so let's do a real estate arm so I didn't want to test it on the
00:48:55.380 Twitter API because I don't have 149 bucks to spend tonight but uh and still
00:49:02.099 eats this let's go back and let's and you don't
00:49:07.800 need to delete you can have as many sdks side by side oh yeah I'm just I just for
00:49:13.440 them exactly as we want this to run exactly so let me
00:49:20.460 go here let's go search so I'm going to close the previous API I
00:49:25.740 had I'm going to go search earlier today Daryl told me it would be cool if we're doing kind of a blog posts demo on the
00:49:33.240 lists I want to list all the blog posts that are in my blog and it appears that Daryl is
00:49:40.680 is very fluent in Latin in in good Lord so we're gonna do we're gonna do that so
00:49:47.099 basically we have an API somewhere I'm going to search for it I'm going to do blog
00:49:53.099 so let's find two I should find two yeah there you go so there's the Blogger API
00:50:00.060 who uses you use it oh my God move remove do
00:50:07.079 something there's cool stuff like you're an xjs like static web app or whatever but anyway
00:50:13.740 um and then there's a second one and it's posted on my personal app that's what I did here I provided my own
00:50:20.579 API to this API that lives somewhere in the cloud so I'm gonna I'm gonna select
00:50:25.859 it it's the second one I'm gonna go here and it's gonna load it right here and there's two sexy Imports
00:50:33.000 why would you suppose in the second one which is use it right but Daryl this morning told me I really
00:50:39.960 just want to see the posts so fair enough I'm gonna go and I'm gonna see the cups I'm gonna go here and I really
00:50:47.220 care about um performance so I don't want to have music I don't want to generate too much
00:50:52.260 code for nothing I just want to focus on post I'm gonna go here I'm going to
00:50:57.420 call it the blog um I'm gonna call it uh it needs oh damn
00:51:04.099 wait I can view that oh it's worse every day I'm surprised
00:51:11.579 but um and now we're gonna put again some Ruby generation I'm gonna think of it have you seen that it literally takes
00:51:18.300 a second like we do that and boom We generate it um I'm gonna go here and then we have the
00:51:24.300 blog which has exactly the same structure that we had earlier there's a client that calls dot post and then pose
00:51:30.720 there's a DOT get and then everybody's happy and this is where things could go south
00:51:37.619 because I'm going to do life coding in a language that uh I actually think I
00:51:43.859 appreciate in in the structure and the way it's built I'm just not very proficient like I love how German sounds
00:51:51.359 but I'm not proficient in German so pretty much the same thing um so the first thing is I already have
00:51:59.700 um a gem file which are are different packages gems got to be that
00:52:05.760 we publish um that we have are abstractions our Json serializer because that's a Json
00:52:11.339 API that we're calling it and our HTTP client that will handle all of the HP
00:52:16.500 connection and do all the call we're using further um in in this case sterilization finally you notified how
00:52:23.400 we do it well do it yourself like you just plug into our stuff you can hear it from from our um our abstractions and
00:52:31.500 very very clear on how to to get I require some of them
00:52:38.640 close the file for whatever reason uh just to make sure I'm gonna do I'm going to install my bundle
00:52:45.000 um it's
00:52:55.619 seriously I don't know what's the cost of that thing but oh my God it's welcome to the
00:53:02.460 Future it's it's crazy what you've done so you're gonna see actually why you're gonna see all the compilent stuff
00:53:08.640 happening um so first thing yeah
00:53:17.839 previous model got from GitHub for my club craft yeah exactly but that's the
00:53:23.280 one I'm building I know that it's seven speaking um so first we're gonna need
00:53:30.720 off we're gonna need to authenticate well that API does not require authentication but we really require an
00:53:39.720 off mechanism so we have our own Anonymous uh
00:53:45.839 uh yeah it's on the kitchen provider so we're gonna do uh off provider
00:53:58.500 already created created this here I'm going to do a new
00:54:04.140 do I need the parenthesis there I don't think if it's
00:54:11.760 um that's actually cool because it makes everything some more so much more focused on the video so whatever so then
00:54:17.460 afterwards that off needs to be passed into how I'm gonna talk with HTTP if I
00:54:22.920 need to append to a header an authentication token or whatsoever and to do that if I need to create my own uh
00:54:30.839 request adapter that will adapt my request and we'll kind of play with uh what's coming back and how I want to
00:54:37.260 inject off so I'm going to do a uh request adapter equals
00:54:44.520 um Microsoft Friday and I'm gonna do a Friday request adapter and here I'm gonna pass in my
00:54:52.020 off why not I say every request needs to go through that off so the off
00:54:58.200 know how to do things you don't just use the off provider to do that by the way you deleted the dot knew my
00:55:04.740 mistake then constructs are very definitely right that's why
00:55:12.140 because then you're like damn then afterwards I need to have my client
00:55:18.180 the client that talks to my blog post so I'm gonna go here um I think I need to do that right
00:55:25.339 in that case log slash blog client
00:55:32.280 um in this case or not we'll see uh and here I'm gonna
00:55:39.180 happen far I'm gonna look at the guy that does I expect here and this is this
00:55:44.880 is where copana comes in thank you co-pilot does it for me it's great
00:55:52.079 um so I create a new I passed in my request about this so when you come to this API use every customer we'll talk
00:55:58.380 with this uh Provider by the capital and this is where we really call our API
00:56:04.020 I have a client it's authenticated in our case it's not but it's good that's where you can do client Dot
00:56:12.540 Dot why do I have the I know why
00:56:18.480 because this I think yes and now I can find my posts
00:56:26.640 nothing crazy it's just using Ruby in this one but now I can do
00:56:33.420 that again and then we learn about that fiber thing uh to do Ascension concurrency sound so I'm gonna do a
00:56:39.960 resume I'm not being the exact good way but um
00:56:45.960 and I'm gonna do this uh I don't think that would make sense actually
00:56:52.740 I'm gonna do a post title does that make sense
00:56:58.980 the the thing that does not make sense is I know that my API returns an object
00:57:04.440 has a value prop in the value prop has all the array of posts so I'm just going
00:57:10.079 to go here and add that value and the resume that I can get so
00:57:16.319 I go here the the I do Ruby on
00:57:29.540 that's great think about if that is a Twitter
00:57:34.619 timeline and we can only call it 30 times a minute or we can only call it 30 times an hour
00:57:39.839 how would you handle it how would you like would you kind of keep a counter and you're like
00:57:47.819 how do I handle but Twitter will tell you and by the way you're up to X percentage of your quota come back in
00:57:55.440 five minutes or whatever that's the beauty of using this because all of that retry handling sterilization is not
00:58:02.940 included so if I'm I'm hammering this API my phone will not break it's going to
00:58:09.240 automatically oh I got um at 429 from the API
00:58:14.339 a little bit and then okay now I'm good I'm gonna call I'm gonna hit the response back and I'm gonna show it so all of that is totally abstracted for
00:58:20.700 you you don't need to think about this um you're not happy with our implementation there are specific things
00:58:26.940 that your internal apis does that we don't account for bringing your own middle rail here and
00:58:33.180 we're going to handle it for you so last thing we're 802 or okay before we
00:58:40.619 spend like four more minutes on on vs code I know because like 31 minutes without cooking so
00:58:48.359 uh what we usually spend about an hour and that's working time so yeah so this is this will give us more topics to
00:58:54.780 network about exactly exactly so Daryl in the afternoon he called me was
00:59:01.079 in my car and he was driving downtown to have like his gazillion number of videos
00:59:06.540 this guy is very busy um he called me like I'd love to get the users also
00:59:13.079 oh well my code is generated don't know and let me trap
00:59:20.460 that's really the beauty of it could ask that block file right
00:59:26.940 tells me what are the posts what are the the patterns are included what are the apis are included okay we're here you
00:59:32.880 can go right click and say select lock file from API explore review okay so
00:59:38.220 basically it brings my API and brings it back for me so
00:59:44.880 cool okay I have posts that's great that's being you know the ad user is
00:59:51.119 that all really really wants the user so okay I'm gonna hit play it's remember is
00:59:57.660 everything I already told him what's the name space what's the name of the client and so on so far it generated it and now
01:00:04.260 I can do trying to die users
01:00:13.319 resume dot value each new user
01:00:19.559 and that will work this that's actually a name and now I should have both users
01:00:25.799 and books but imagine starting with a small footprint you you said it earlier I'm gonna try stuff
01:00:32.760 and then you're like oh this you guys you built your own HTTP client and then oh I'm gonna add some more and
01:00:40.079 then somebody joins you in your team and then this becomes out of control or this
01:00:45.480 we're just generating a new a new endpoint on that API so that's
01:00:50.640 what killed it is providing you as a Dev the power to connect to
01:00:56.760 I'd love to say to any API or any HTTP API we have to be more honest by saying
01:01:02.220 any open API described HTTP API but with a decent opening when it is in the open
01:01:08.400 API but our goal is to really shift the momentum instead of you doing
01:01:15.359 okay I need to connect that plug thingy let's go uh Google or Bing
01:01:22.700 will be uh or or ask check GPT to do it for you and it's going to give you
01:01:29.099 zillions of options or Google will give you gazillions of options and you're like which one do I take or do I take
01:01:35.760 the official one and I get bloated and that's really where you are in control now of any type of connections you're
01:01:43.740 making through API yep questions
01:01:48.839 um I'm thinking something but yeah like you are using like post or get to resume uh so this is like Bill in every module
01:01:57.599 like same or it's different what do you mean like there is a method like post or get it resume like resume means like
01:02:04.559 this is a method to continuously get the data so the resume is part so we we made
01:02:10.079 a large picture Choice as part of our Ruby implementation to use fibers that helps you do concurrent calls and
01:02:16.200 basically doing asynchronous calls so that's how you you basically
01:02:22.680 um asks okay you ask okay now Ruby do the actual call now instead of just like
01:02:28.680 hearing it now it's it's resuming it so the return the value you're getting back is is the actual collection or the model
01:02:36.960 or whatever from the API from the doctors but the rest is all what we project like the users is think about
01:02:45.660 twitter.com slash two yeah slash get slash
01:02:53.000 yeah and then you would get a Json object with a value product
01:02:58.880 dot path segment.pathsegment.class segment. however many past segments in your url
01:03:04.940 dot HTTP method yeah and that's how you get the results if you want to do a post you're going to
01:03:10.740 just post um like an anonymous object in there you're going to post your ID and your
01:03:17.280 user you want to add or you want to do a delete you're going to pass in just the ID of of of of the user or or whatsoever
01:03:24.900 and we handle all of them via really the the core HTTP verbs that HTTP
01:03:31.680 is meant to be used for how many apis are you using posts or
01:03:36.780 billions I've seen that the million refer to
01:03:43.500 referred to good and B to be the nicest if you get duck also learns yeah how how
01:03:50.640 much would you pay for this oh and you know if it keeps you in vs gold
01:03:56.059 okay so so how much how much because you'll be on top of the world
01:04:02.880 exactly everything exactly so AP so open API as a concept of embedding for
01:04:09.660 operation can you go and search for craft please
01:04:16.200 no I'm gonna search for GitHub can you search for GitHub please yes I'm interested yes I'm usual yeah
01:04:30.960 a bigger or maybe I should pick a little bit more this is the tree I want to see the Emojis one because I'm
01:04:37.619 a big you like the Emojis mom yeah where's the Emojis I don't know where it is let me just see if I can find it
01:04:43.500 oh that's good well there it is there's a filtering capability that's great wait interesting this version which is still
01:04:50.460 in the pr in our repo all right makes the tree a little bit bigger not only does it have the path segments in the
01:04:56.339 tree it now tells you what the operations are so you can now project out not just I want this re this path
01:05:03.180 but I only want the put or I only want the get or I won't so you can control it
01:05:08.880 down to the method and we get this delightful little icon here which when I
01:05:15.540 click on it it's going to go oh you want the docs oh yeah emojis on GitHub yeah it's right there
01:05:22.500 you want to know what the response looks like it's right there okay that's cool
01:05:29.520 and as uh it's called hyperlink
01:05:35.940 the web was built from yeah yeah as Sebastian was saying here we can do Microsoft graph
01:05:42.119 and we can pull this down and it's bigger so it'll take a little bit longer
01:05:48.420 at the moment we have plans for making this faster so I don't have to fill in the time as much with a little bit of
01:05:54.660 dialogue whilst it's loading Adventure but we also have an open issue
01:06:00.000 for could we have the Legacy uh so there we have this is just the V1
01:06:06.119 API the V the beta API is even bigger
01:06:11.339 um and the same thing here I can search for applications I have to spell applications
01:06:20.220 and then I can go here and it takes us into the Microsoft graph documentation for that particular endpoint as well oh
01:06:33.180 previous example Aaron however we can help you you can
01:06:41.160 retrial yeah can you get me the list of attendees of a meeting
01:06:47.280 enough um let's search for attendees uh well
01:06:53.700 they're not called attendees well there's an attempting reports after
01:07:01.619 the fact report no
01:07:07.500 we're gonna have to go through online meetings yeah online meetings we are under a user so
01:07:13.980 oh yeah so basically you can't even get I schedule the meaning the meeting is mine so you could slash user slash
01:07:21.619 ID whatever slash online meetings and I'm going to be able to see all my meanings you're going to select that ID
01:07:27.900 slash identity report the get and you're good to go so you have to know
01:07:35.059 the the organizer of the meeting beforehand well that's why I think that
01:07:41.460 the easiest one is the other endpoint which is more agnostic uh which is like
01:07:47.220 Communication online meetings and you don't think the I the ID of the meetings almost impossible okay
01:07:53.880 yeah you need to be a bot to basically get on that so part of my job is sitting
01:07:59.520 through API reviews from teams that bring these apis to Microsoft graph and if I had a dollar for every time we've
01:08:06.299 had an argument with this team that you have to make it easier to get that online meeting ID but there's reasons
01:08:11.940 why they can't but yes that's would be really really helpful
01:08:18.000 okay basically any and that's the duty right when you know the domain of the API you're looking for filtering is
01:08:25.199 super powerful because like literally it's 2700 documentation page that we
01:08:31.679 have for our API if you know the join URL you can filter on the collection using the join URL as
01:08:39.660 a filter like it makes my screen skin cool just even admitting that yeah
01:08:47.279 there you go did you close my deck no it's my VM okay I have like I have a
01:08:54.660 roadmap slide just to kind of talk about where we're going just to cap off the story
01:09:03.179 do that it's yours oh enjoy
01:09:08.940 road map so
01:09:14.880 we've got the ca that we'll see Sharp GA or made generally available as Microsoft
01:09:20.759 Lincoln we got to get all the other languages too you saw a bunch of them were like experimental preview we need to get
01:09:27.359 those all to stable so that we get broad support um one thing you might not notice is we
01:09:33.299 actually have a generating of a CLI so if you have an API and you want to generate command line tool we can
01:09:39.239 generate a CLI for it uh to be able to just call it from the bottom line um for those in the Microsoft world will
01:09:46.259 probably in the future you're going to do the Powershell too um you've already seen our IDE integration we've talked about our
01:09:52.620 building Partnerships with red hat and GitHub documentation is or if it's it's very
01:09:58.620 soon as soon as our Dev comes back from from bit getting married we'll get that merged in and also documentation from
01:10:05.580 another stand for standpoint where the tool is the owner has a documentation portal where you can
01:10:10.800 learn about how to install how to use how to configure how to bring your own implementations on our own abstractions
01:10:17.640 and so on if I actually hit oh if I've actually put the learned it's on
01:10:23.040 our main Microsoft Port archa of the documentation no
01:10:28.260 no the backyard highways and you're especially typing on your own yeah and it's plugged into the other one that's
01:10:34.080 probably why it's not working um yeah as Ruby is experimental we need to
01:10:41.159 do work we need to find a Dev who's got some skills to help us out there
01:10:46.500 um and dedicate some time to actually bringing the last pieces because like we
01:10:51.540 were doing this yesterday going try this again okay we have to go build our own API
01:10:58.380 because this is a bunch of edge cases because there's lots of things that can do so so there was some smoking mirrors there
01:11:05.040 okay yeah yes I know it's a networking yeah it's very similar to how we project a
01:11:11.100 code if you want to try it out I'd love to get an issue in the repo AKA like Ms slash Toyota
01:11:17.219 and you're gonna land on the GitHub repo an issue and say this doesn't work this
01:11:22.500 doesn't work this should be like this here's the proposal I'd love to hear it yes out of curiosity out of the trials
01:11:29.640 in there that you made uh what's the rough percentage of working out of the box Ruby apis and I
01:11:37.320 know it's a work in progress in the end any better than just spending these Vacations so here's the scenario um where we have issues is
01:11:46.199 we build Kyoto as a generic tool but our test bench is
01:11:52.320 Microsoft graph Microsoft graph has some special cases and I would say that
01:11:58.500 I wouldn't say the most special case but is we never return a collection
01:12:03.780 we returned an object value that has a collection so apis are
01:12:10.920 ascending raw arrays arrays you just don't work right now holy moly yeah it's
01:12:17.460 a very hard exactly so so basically the the code it's literally there's a single
01:12:24.300 line of code it needs to change to support that scenario too treat it as a collection
01:12:30.360 like from the from the get-go and not just as I guess one problem so that's
01:12:35.400 the old we could have worked way easier in that that use case was in there and we did
01:12:43.260 not catch it because we highly got far enough in our in our testings all of our
01:12:48.960 other languages are using like 20 or 30 different open apis from
01:12:55.380 tons of different we're probably 80 there and 90 of apis won't work for one
01:13:01.320 or two reasons yeah exactly so it's a it's a bunch of edge cases that that are
01:13:06.900 more than just edge cases it's not a ton of work yes I have a suggestion you mentioned
01:13:13.500 the CLI I actually own uh
01:13:20.580 uh desktop two weeks I wonder and I've been thinking about the idea of actually Auto generating buoys from uh of web
01:13:29.280 HTTP apis request apis uh so I just want to make sure that suggestion is another idea right so like
01:13:36.840 crafting rest apis in a few weeks let's talk about this mod element here so I
01:13:43.500 talked about the fact that we don't use templates we have a code dog we have a code Dom that's optimized for generating
01:13:49.520 glimmer by the way okay um and
01:13:56.460 while that is that's our bread and butter that's what we are code generating there are a bunch of other
01:14:02.159 things that you might want to generate unit tests you might want to generate sample code you might want to generate
01:14:09.060 UI things and or you might want to generate server code like scaffold up
01:14:14.880 from an open API description a an API a rails service
01:14:22.080 um and so what we're going to do is take that code down that we generate out of
01:14:29.100 our open API description and just project it out in a standardized Json model so then you can
01:14:36.120 take that and feed it into some kind of telling the thing language so you will know what our client Library looks like
01:14:42.600 and so you could generate tests uh you could generate sample code you could
01:14:48.179 generate UI that then can call those endpoints because you will know what the shape of our client libraries are going
01:14:54.300 to be but you get a machine readable machine processable format in order to
01:14:59.580 do other kinds of code generation so that's one of the things that's on our list to do soon
01:15:06.480 um we we can't have a slide at the moment without saying we're doing something about llm prompt management
01:15:13.100 AI otherwise otherwise our management think we're just not doing our jobs so it had to go on there
01:15:19.440 um so what is it you're actually doing in that space well it's or you're just putting this
01:15:26.340 um so snipper generation is an interesting one right do you really
01:15:33.380 need code to be able to generate a code snippet to be able to call an endpoint
01:15:39.440 or can you just construct a prompt that says this is kind of how kyode API
01:15:46.739 client code looks like and this is how you set headers and this is how you do parameters and this is how
01:15:53.340 a path translates into a call here's a bunch of examples of the problem now I
01:15:58.860 want to go and do this job right I want to do this other thing can you just go generate me the code and
01:16:05.400 I talked earlier about this the idea of the service adapter uh back in oh I'm
01:16:11.520 going the wrong way okay um in the little architecture diagram I
01:16:17.760 had no idea what that slide is why it's indestackable
01:16:23.219 I think it's in the hidden one we maybe do remember yesterday so this
01:16:29.400 this service adapter here yeah um this is handwritten code that provides
01:16:36.600 you with a friendly interface to our standard stuff when you sit there and start typing that
01:16:42.719 co-pilot that does awful work for you it figures out once you've got a few examples in there of how you want to
01:16:48.600 call our API client code it's really good at that we could go a little bit
01:16:53.880 further and build some tooling into our vs code extension so you could start asking as natural language questions and
01:17:00.659 we can just figure out by constructing a prompt that says this is how you call kyota so that's that's the kind of thing
01:17:06.840 that we are going to be experimenting with uh with regards to prop generation how to easily create these kind of
01:17:15.000 adapter methods call our apis why would you focus on the adapter and not on the code generator itself
01:17:23.000 itself was was prettier and more and easier and more language uh Focus to
01:17:30.920 predictability is right now a big issue for these things you are going to ask
01:17:36.600 the same question twice you're gonna get two different responses um so we we I think if we train the
01:17:44.280 model enough it's it could potentially like basically hey
01:17:50.520 here's an open API the user wants to call this this this this endpoint generate me and then well that's exactly
01:17:57.480 what the chat GPT plugin is doing today if in the chat GPT plugin you point it to an open API it puts the open API
01:18:04.679 description on the prompt and they have one they have a generator that generates python code that then calls that API and
01:18:11.340 figures that it's all done runtime on the Fly and so the plugins and checks of the T are actually using AI to
01:18:17.640 understand how to use the plugin like there's no like instructions it's all AI
01:18:23.219 bas3 we are exploring there's of course everybody's trying to figure out what to
01:18:28.500 do with it where it can really but there's so much learning to do in that space and it's changing so fast too
01:18:35.400 um we have built a web experience you can actually go to kyoto.dev and actually do all of this generation on
01:18:42.900 the web app uh it's actually because it's all written in C sharp it actually load downloads a Blazer app uh which is
01:18:50.520 comparison it's a webassembly effectively um we also think there's an opportunity
01:18:56.460 for improving API search using llms uh I want to be able to find API that does
01:19:02.420 tells me how to what is the attendance of an online meeting
01:19:07.560 There's an opportunity there for better semantic search indexes that can
01:19:13.320 understand the question that you're asking and find you the apis that can actually do the things that you're
01:19:18.960 interested in rather than just doing keyword searches that we're doing at the moment there's also a really interesting story
01:19:25.800 around workflow which is we build clients that call one API endpoint for
01:19:32.340 99 of cases um wouldn't it be nice if we could figure
01:19:38.219 out how to generate code that knows how to achieve a goal by calling this endpoint and taking the result from that
01:19:45.239 endpoint and then generating the next one or calling the next one and taking the output of one to be able to call the
01:19:51.780 other in open API there's a concept called links which start down the path
01:19:57.120 of being able to connect operations together and say how they're related we are identifying the number of gaps in
01:20:03.480 the open API specification for certain scenarios it's not easy to draw describe
01:20:08.760 next page links if you want to build a page through questions there's no easy
01:20:14.159 way to describe um how when you go and create something
01:20:19.440 you get a location header that tells you where to go and get the thing that you just created and that's another thing
01:20:25.800 that we want to start figuring out how to get into the open API description we have concept of long-running operations
01:20:31.320 which is I went to go do something it gives me a 202 to say yes I'm doing it
01:20:36.780 but it's going to take a while here's a location header for a status monitor that you can pull to find out when it's
01:20:42.600 done wouldn't it be nice if we could actually coach in for those scenarios also yes
01:20:48.300 this reminds me a bit of something uh built in the past by Yahoo it was called
01:20:53.460 Yahoo stinks I think the pipes or pipes sorry would you allow me to create a
01:20:58.500 link multiple feeds of for example atom feeds and then build a new list out of
01:21:05.520 multiple block feeds for example that's kind of similar it's not right yeah yeah there's all kinds there was focus on on
01:21:13.020 HTTP API I wish I could remember there was a there was a guy from South America in the Ruby community that did some
01:21:19.800 awesome work in the hypereal space back in the early 200s too there's all sorts
01:21:25.320 of stuff there's been there's lots of opportunity for us to be able to connect these different operations together and
01:21:31.560 actually between a combination of rich or open API descriptions and more AI
01:21:37.320 that can do the understanding the natural language of what you're trying to do and be able to break down that
01:21:44.520 natural language request into simpler steps and then mapping it to uh HP
01:21:50.100 requests I think there's a lot of opportunity even here thinking uh cloud with like basically workflows or could
01:21:59.280 could almost become like developer focused zappier like when you
01:22:05.940 do sapiers and when you do uh if this and that like in because that could be an API well that could be across apis
01:22:13.980 but because they all have the same structure you know share the same missing Concepts because they're all
01:22:19.500 generated using the same clients you could have a really really powerful instruction they don't need infrastructure anymore to do those kind
01:22:26.760 of integration scenarios you just need good API descriptions and some clever API to generate the code that will glue
01:22:34.679 the pieces together and we should have killed that last one and hence filtering because we pretty much already done it because we can filter our methods now
01:22:41.040 yeah filter so um yeah these are the things that we are building these are things we're playing
01:22:46.679 with it's open source if you want to come take a look uh in that next slide
01:22:52.800 that's the GitHub repo of Microsoft Toyota um
Explore all talks recorded at Montreal.rb Meetup
+6