Within last 2 days I was searching for a resource to learn open API specification and swagger and this is the best tutorial I had ever found. very straight forward and to the point. Thanks for this content.
The time is approximate 01:17 Why ? 04:20 Solution 05:28 What is OpenAPI and what is swagger 06:09 What is new on OAPI 3 06:51 Specification restructure and improve usability -- 08:10 Parameters -- 09:11 Contact negotiation 09:37 Demo -- 09:37 Overview -- 10:21 Planning -- 11:10 How they going to build it ( tools) -- 12:10 How to create API in swagger hub 50:17 Resources and Q/A
A few years ago, I check the date on a post, the number of views and comments to watch a video on youtube (If it has a long date, fewer views, likes, and comments, GONE!). But with time I have come to realize some videos are just not meant for everyone. But this video, GREAT ✌🏽
"Your API's no longer a black box, there's actually a RESTful interface that allows your clients to actually interact with the data or service you want to expose." Tell me you don't understand what a black box is without saying you don't understand what a black box is.
That's good. Following your exact steps, I am getting these errors : Schema error at paths['/employees'].post.requestBody should have required property '$ref' missingProperty: $ref Jump to line 65 Schema error at paths['/employees'].post.requestBody should match exactly one schema in oneOf Jump to line 65 Schema error at paths['/employees'].post.requestBody.content['application/json'] should be object Jump to line 67 Schema error at paths['/employees'].post.requestBody.content['schema'] should NOT have additional properties additionalProperty: type, properties Jump to line 69
Thanks for the video, so helpful in starting out! I do have a question though, when you create and use your $ref, why are you not getting an error that there is a sibling value (in your case type) alongside your $ref? What would be the best way to handle this? Thank you again, awesome stuff!
Hey, I know I'm late but the solution is to put the "type: object" in the "Employee" inside components, right under description, just like he did for "Employees" where "type: array" is there. Then erase "type: object" from the rest of the code.
Excellent presentation. I have one question, how do you know what words write? where can i find the glossary o list of words allowed? I'm new designing API with swagger
Hi I liked the video. Thanks for sharing. I have a specific question: if we have a crud operation to return true/false, how we will modify the response for it? Also how to add the pagination to the specific crud operation let's say GET operation? Any help on that will be much appreciated..
Good presentation... have a question... "servers" tag, is it mandatory to define the host servers in the open api yaml definition file? maybe when we do publish these apis to be used through URLs, but most of the cases (dev, test, etc) while defining the APIs these info is not static isn't it?
Thanks for the great tutorial. How do i use OAuth2 client credentials for secure server to server communication? I cant find a proper tutorial or documentation for this. Most of them has their focus on user interaction.
Here, I can not found answers, what I'm looking for. I have several queries. It will really help me if anyone can answer. 1) Suppose, I have a schema for Project model which contains 20 properties. Now for my project-dropdown API I only need 3 properties from the schema then how I can refer the schema and pick few properties only? 2) I have 2 schemas, one for Project with 20 properties and another one is Task with 10 properties. Now for ProjectDetails API I have response something like { id: 1, name: "ProjectName", tasks: [ {id: 1, name: "TaskName"} ] } Now how I can accomplish this nested object by referring both individual schema which are Project and Task 3) Can I have search box in Swagger UI to filter APIs?
I got this too, after some playing about, and commenting out type: object it seemed to get rid of the compilation warning. However, I haven't got to the end of the video as yet, so don't know if this will have any other knock on effect... 200: description: Successful user info retrieved content: application/json: schema: # type: object $ref: '#/components/schemas/Users'
I"ve generated petstore api using the openapi generator but can anyone explain how to write the code implementation of it by using json/yaml format? it is only creating the interfaces and controller classes which returns http response as not implemented.(I'm using springboot)
At 36:00 I don't think this is the type of parameter you want to put in a path. An employee ID is a great example of a query parameter; not something from which you want to build a unique endpoint with. A path parameter would contain values like "evaluations," "taxDocuments," insuranceElections," "projectHistory..." These are things that define entire subsets of data about their parent.
what if you were building a portal for employees where they can view tasks assigned, store personal documents, view & update their personal details. All of that would fall under an employee entity
I want use servers , currently we have 4 env. and I want to execute few api based on 1 server, few api on other server. Can I do this using openapi 3.0.0
Bonjour je suis nouvelle sur les api rest et il m'a été demandée de réaliser la documentation open Api d'un diagramme de classe je voudrais savoir comment on fait
@@design7054 I use FastAPI for Python and Swashbuckle for .net core, they both autogenerates auto-generates the swagger docs for me. I've never needed to hand-code swagger docs.
How to define same api resource for multiple roles for example register api for user role normal_user, custom_user, admin and so on? could you please let me know?
The components section of the specification can be referenced multiple times swagger.io/docs/specification/using-ref/. Swaggerhub takes this to the next level by storing these reusable assets in a separate file, allowing them to be used across multiple APIs app.swaggerhub.com/help/domains/index. I hope this helps!
It was impossible to open this video fullscreen on the swagger.io site. Couldn't right click. Couldn't click anywhere near the youtube controls. Was this on purpose?
Thank you all for the amazing feedback! We really appreciate it!
Well explained man!
Amazing explanation!
why have a fake accent ? were you born in US?
Love the way it was explained. Straightforward. No flowering words. Direct to the point. Appreciated much.
Within last 2 days I was searching for a resource to learn open API specification and swagger and this is the best tutorial I had ever found. very straight forward and to the point. Thanks for this content.
The time is approximate
01:17 Why ?
04:20 Solution
05:28 What is OpenAPI and what is swagger
06:09 What is new on OAPI 3
06:51 Specification restructure and improve usability
-- 08:10 Parameters
-- 09:11 Contact negotiation
09:37 Demo
-- 09:37 Overview
-- 10:21 Planning
-- 11:10 How they going to build it ( tools)
-- 12:10 How to create API in swagger hub
50:17 Resources and Q/A
A few years ago, I check the date on a post, the number of views and comments to watch a video on youtube (If it has a long date, fewer views, likes, and comments, GONE!). But with time I have come to realize some videos are just not meant for everyone. But this video, GREAT ✌🏽
That's how one should explain things, awesome and conceptually clear.
"Your API's no longer a black box, there's actually a RESTful interface that allows your clients to actually interact with the data or service you want to expose." Tell me you don't understand what a black box is without saying you don't understand what a black box is.
Nice ! Short,crisp and clear
Keshav neenga vera level boss.
Very clear and up to the point. Just shows how documentation is SO important
Great tutorial. Loved it. Got a better understating of OpenAPI from this 1h video rather than reading for hours some course-tutorial. Like!
This is just what I needed to learn how to create an API spec. Straight to the point. Thank you!
Excellent tutorial for the beginners...
Good presentation. The only weird thing is that you post the employ ID on Post trigger. But thanks for the video.
Thank you soo much...I created my first API by watching this video...this is really helpful...
That's good. Following your exact steps, I am getting these errors :
Schema error at paths['/employees'].post.requestBody
should have required property '$ref'
missingProperty: $ref
Jump to line 65
Schema error at paths['/employees'].post.requestBody
should match exactly one schema in oneOf
Jump to line 65
Schema error at paths['/employees'].post.requestBody.content['application/json']
should be object
Jump to line 67
Schema error at paths['/employees'].post.requestBody.content['schema']
should NOT have additional properties
additionalProperty: type, properties
Jump to line 69
Simply cool. It certainly gives a jump start to API Development especially with 3.0. Thanks!
Very nice and detail presentation ...!!! GOOD Job Keshav
The question is, why I need OpenAPI 3.0 ? Cause every company have own requirements.
Well structured, great explanation, and excellent example! Saves time reading myriads of documentations.
very good video but It honestly had me wishing there was a 5x speed on youtube
Thank you very much for sharing this knowledge. Appreciated!
Thanks for the video, so helpful in starting out! I do have a question though, when you create and use your $ref, why are you not getting an error that there is a sibling value (in your case type) alongside your $ref?
What would be the best way to handle this? Thank you again, awesome stuff!
Hey, I know I'm late but the solution is to put the "type: object" in the "Employee" inside components, right under description, just like he did for "Employees" where "type: array" is there.
Then erase "type: object" from the rest of the code.
great explanation with practical point of view.
Excellent presentation. Hats off !!! Just one thing , it is possible to provide sample request and response rather than defining object and array ?
Very cool introduction to the subject matter. Thanks a lot for the video
Next question is, how to use it OFFLINE ?
any good tutorial on how to use those with php attributes in symfony instead of writing in yaml?
Thank you for explaining this so well! Needed it.
Excellent presentation. I have one question, how do you know what words write? where can i find the glossary o list of words allowed? I'm new designing API with swagger
Thank you! This tutorial will help you with writing OAS definitions: app.swaggerhub.com/help/tutorials/openapi-3-tutorial
Thanks , very clear explanation
Hi I liked the video. Thanks for sharing. I have a specific question: if we have a crud operation to return true/false, how we will modify the response for it?
Also how to add the pagination to the specific crud operation let's say GET operation?
Any help on that will be much appreciated..
You don' mention where you are getting the names and level of all fields you are typing.
A rare gem. Thank you sir!
Clear explanation. Thanks 🙏
It was really a great introduction.
can u share best practices of openAPI Specification
Dear All/Host of this Video,
Good you please provide details about How to secure this REST API while it is being hosted in public domain?
Nice demo
Good presentation... have a question... "servers" tag, is it mandatory to define the host servers in the open api yaml definition file? maybe when we do publish these apis to be used through URLs, but most of the cases (dev, test, etc) while defining the APIs these info is not static isn't it?
Well explained..... Thanks for sharing wonderful knowledge
thank you Keshav..
Thanks for the great tutorial. How do i use OAuth2 client credentials for secure server to server communication? I cant find a proper tutorial or documentation for this. Most of them has their focus on user interaction.
Awesome explanation!!! Thank you so much and shout out to the swagger team ;)
Here, I can not found answers, what I'm looking for. I have several queries. It will really help me if anyone can answer.
1) Suppose, I have a schema for Project model which contains 20 properties. Now for my project-dropdown API I only need 3 properties from the schema then how I can refer the schema and pick few properties only?
2) I have 2 schemas, one for Project with 20 properties and another one is Task with 10 properties. Now for ProjectDetails API I have response something like { id: 1, name: "ProjectName", tasks: [ {id: 1, name: "TaskName"} ] } Now how I can accomplish this nested object by referring both individual schema which are Project and Task
3) Can I have search box in Swagger UI to filter APIs?
Quite descriptive
Thanks Keshav, very nicely done...
Very clear, thank you.
Excellent video
Your demo was great, why? first you showed in action. and second you explained clearly what we can do. only limited by our imagination.
Great presentation. Is there one for advanced modeling too?
amazing content friend
Great intro, thank you.
Is they are any way to hide Schema/Models from API Documentation in SwaggerHub?
Could you please share how to create error schema for http error codes
Thank you so much
Nicely explained..!!
how to handle the situation of multiple path parameters
Blessed tutor. Thanks!
I am getting a warning "Sibling values are not allowed alongside $refs" after adding the reference to Employee model. Any idea why?
I got this too, after some playing about, and commenting out type: object it seemed to get rid of the compilation warning. However, I haven't got to the end of the video as yet, so don't know if this will have any other knock on effect...
200:
description: Successful user info retrieved
content:
application/json:
schema:
# type: object
$ref: '#/components/schemas/Users'
I"ve generated petstore api using the openapi generator but can anyone explain how to write the code implementation of it by using json/yaml format? it is only creating the interfaces and controller classes which returns http response as not implemented.(I'm using springboot)
At 36:00 I don't think this is the type of parameter you want to put in a path. An employee ID is a great example of a query parameter; not something from which you want to build a unique endpoint with. A path parameter would contain values like "evaluations," "taxDocuments," insuranceElections," "projectHistory..." These are things that define entire subsets of data about their parent.
what if you were building a portal for employees where they can view tasks assigned, store personal documents, view & update their personal details. All of that would fall under an employee entity
@@mcdonaldslover52 Indeed, I'm not sure I agree with my past opinion on this anymore.
Excellent
How I can secure the nodejs generated stub
I want use servers , currently we have 4 env. and I want to execute few api based on 1 server, few api on other server. Can I do this using openapi 3.0.0
can we hide parameters from the UI?
Do you have a product like swagger which generates OAS 3.0 specifications
Hi Narendra! Yes we do. You can check out Swagger Inspector here: swagger.io/swagger-inspector/
how to connect this API to a oracle database and how can we manipulate the data in oracle database through this API designed.
Buen vídeo , pero hubieras probado el api en swagger
Can anyone help to understand how to test the OpenAPI?
Great video :)
Thank you for this excellent video.
Good presentation. Thanks.
extremly helpful!
Bonjour je suis nouvelle sur les api rest et il m'a été demandée de réaliser la documentation open Api d'un diagramme de classe je voudrais savoir comment on fait
Great explanation :)
Bro, why you generating swagger docs by hand?
How else can he generate if implementation does not exist yet?
@@koraytugay Spend time on the implementation, then auto-generate the swagger docs using a framework, otherwise just time wasting.
What's the usual best practice alternative to craeating swagger docs by hand?
@@design7054 I use FastAPI for Python and Swashbuckle for .net core, they both autogenerates auto-generates the swagger docs for me. I've never needed to hand-code swagger docs.
How to define same api resource for multiple roles for example register api for user role normal_user, custom_user, admin and so on? could you please let me know?
The components section of the specification can be referenced multiple times swagger.io/docs/specification/using-ref/. Swaggerhub takes this to the next level by storing these reusable assets in a separate file, allowing them to be used across multiple APIs app.swaggerhub.com/help/domains/index. I hope this helps!
Thanks for your reply. but both the links that you have shared with me not working. so could you please let me know how to do that?
Here you go, let me know if these do not work for you: swagger.io/docs/specification/using-ref/ & app.swaggerhub.com/help/domains/index
Well explained !!
Great video! All the best
I need to know how to implement pagination .. can anyone help me pls ?
While recording, click on "New Page" within the Instaplay Recorder.
You can implement pagination using linking. Learn more here swagger.io/docs/specification/links/
Preview window shows: "We're sorry, but an error occured in this component. Please check the console for details."
It was impossible to open this video fullscreen on the swagger.io site. Couldn't right click. Couldn't click anywhere near the youtube controls. Was this on purpose?
Thank you so much!
is this still relevant? 7 years passed, but looks like in symfony current it still is used OAS 3.0 . Weird.
31:05
okay my name is Rajeet and now we will talk about a shitty pee pee request
33:42 because you are using Windows LOL
test
test
test
An Indian and an American I think!!