"WEBVTTKind: captionsLanguage: en- Hi there, I'm Craig,and I'm a developer.In this course, we are going to explorethe wonderful world of webhooks.Understanding theconcepts behind webhooks,will open up a new and powerfulworld of possibilities,for your projects and your applications.There are infiniteopportunities available for youto connect applications thatyou know and love together,to create new experiencesfor both you and your users.Now, in order for you to getthe most out of this course,I'd love it if you hada basic understanding ofhow to access web-based APIs.Now, if you don't yet, no worries.I've attached to thisvideo, some teacher's notes.I've listed some ways for youto gain that experience there.Now, even if you've alreadymet the prerequisites,can you please take a minuteand locate the teacher's notes?Throughout the course,I'm gonna refer to them.In those notes, I'll dropadditional information,and share places whereyou can learn more aboutwhat we're chatting about.I'll also use those notes tokeep you updated on anythingthat might've changed from,my right now, when I'mfilming this course,to your right now,whenever you're watchingthis in the future.I hope things are goinggood for you in the future.Well, while we'll talkingabout your future,let's chat a bit about what youcan expect from this course.We're gonna first talk aboutthe high-level concepts of webhooks.Where they come from, when andwhy you might wanna use them,and I'll walk you throughsome inspiring solutionsthat you can build withoutwriting any code whatsoever.You're gonna love it.Pretty sure you're gonna get hooked,and after you get webhooked,we'll move from a no-code solution,to explore some more low-code solutions.We're gonna explore eventsthat GitHub sends out,when activity happens on their site.Now, no worries, if you haven'thad any previous experiencewith the code-sharing site, GitHub.We'll start from the very beginning,and get you up and running quickly.We'll also then spin upa serverless function,using a free platform named, Netlify,and we'll handle or do something with,the event data that comes from GitHub.If you haven't usedserverless technology before,again, don't fret.We'll walk through what that means,and how to take advantage of its power.Now, all the code in this course,we'll walk through together.You'll have access to allof the completed code.After we've got a goodgrasp on the basics,we'll make use webhooks to buildan entire telephone-based application.We'll build, from start to finish,an entire idea capturing andtext transcription service.The application will lean completelyon webhooks for workflow management.All done with, shockinglyfew lines of code.This course it's going todeal with consuming events,passed through our webhooks.Now, that is to say, wewon't be writing codethat sends informationto register webhooks.Check the teacher's notes,if you're interestedin learning more abouthow to send webhook events.I am super excited to getstarted with this course,but there's just one more thingthat I'd like to talkabout with future you.If at any time you needme to pause or slow down,remember you're in a video-based course,take advantage of that.I am more than happy to repeat myself,if you miss something.Speed me up, slow me down,flip on the closed captions,make yourself at home.These days, I know I'vegotten pretty bad aboutthe way that I consume video content.I just watch and watch,and then I watch some more.Well, it turns out thateducation doesn't really worktoo well with bingeing like that.If you feel like you'restarting to zone out,like I did through theendless seasons of \"Survivor,\"it's time for a break, andI'm not here to make friends.I've put some deliberatestopping points in this course,and I'll do my best toremind you to take a break.Breaks are important,they're super critical for your learning.You need to let things sink in,and I want you to get themost out of our time together.Whew, there we go.We got all that housekeepingstuff all covered.I'm sure you were startingto get like my kids doon a long drive and they'relike, Dad, are we there yet?Actually, that's a pretty good examplefor where a webhook works wonderfully.My kids continually askme that question overand over again, are we there yet?They keep making that request,the same one, over and over,polling me directly to seeif we've arrived at our destination.Now, typically, my response is,I'll tell you when we get there.More or less, what I'm promisingis that when we get there,I will broadcast our arrival status.When that approach works,like when my kids actually decideto subscribe to my status updates,I can tell you that it makes thingsa lot easier on the whole car.I don't get overloaded and they can relax.They just sit thereand wait for my update,so much more efficient.I guess what I'm attemptingto broadcast to you now is,we're here, we've arrivedat the start of the course.Now, I think the best placeto start our journey isto explore a concept often presentin application development, events.Let's get started.An event, in code, is adefined action or occurrence.Now, these events aretypically exposed to us,software developers, sothat we can write codethat runs specifically whenone of these actionsor occurrences happen.The first type of eventthat I'd like to talk aboutis one that is caused by theuser of your application.Let's think about a button on a webpage.This button will trigger an eventwhen it is clicked by an user.You can optionally writesome code that will run,and only run when that event occurs.You do this by adding orregistering what is known asan event listener.You write code, alsoreferred to as a handler,used to handle the specific event.In this case, click,this code will only runwhen that event happens.This is called, event-driven programming.In this example, it's used to empower youto not have to write codethat continually checksto see if the button is being pressed.Just like the kids in the car,it isn't very efficient foryou to write code asking,hey, button, are you clicked yet?Are you clicked yet?Now, how 'bout now, are you clicked?The click event is just one of many eventsthat webpages allow for listening to.Check the teacher's notesfor more browser-based event examples.Similar in concept toa user-generated event,is what is known as a lifecycle event.Lifecycle events aretypically exposed to usvia application libraries or frameworks.You can think of applicationlibraries and frameworksas tools that help us rapidlydevelop our applications.These libraries do this byproviding repeatable waysfor us to write our applications.For example, these librariesallow us developersto customize variousparts of the application,at specific times, in specific contexts.They allow us to hook intospecific lifecycle events.For instance, when you're buildinga web application these days,you're almost certainly usinga front-end application library.One of the main benefitsthat these libraries give youis the ability to write codefor only your specific needs.A great example is you can write codeonce your component hasbeen loaded on the screen.This load is a lifecycle event.Usually this looks somethinglike, has been loaded.What's happening here is what is known as,inversion of control.Now, this is because thecontrol is being handed to you,the developer, from the application,at exactly the right time.The library does its magic,it prepares your component.It then renders it out to the screen,and when it's loaded on the page,it calls the code that you wired upto your has-been-loaded hook,and that abstraction is super nice.You don't call the function yourself.The library actually callsyour function when it's ready.This inversion of control patternis also often referred to,as the Hollywood principle.In Hollywood, casting directorsusually tell the person auditioning,don't call us, we'll call you.Now, this is because if they didn't,the actor would just keep calling them.Yeah, I was just in there auditioning.I pretty sure I got thepart, I did a really good.Weird, they hung up, Iguess I'll call back.No, I was the older guy.I was just wondering when should I come infor my wardrobe fitting, hello?Weird they disconnected, Iguess I'll try that again.Again, like my kids,these actors are totally goingto overload these directorswith their needy questions.If they were allowed to call the directorand check for their approval,they'd do it all the time.That Hollywood-principle abstraction,allows the actor to not needto understand the entire processthat Hollywood directorsare going through.The directors do whateverit is that directors do.I think it involves tallchairs, and megaphones,and snacks, definitely snacks.The point is, only when thedirectors make their decision,do they call to inform the actor.These patterns of eventhandlers and lifecycle hookshave really proven usefulin helping developersto build extensible applications.The good news is,that this powerful abstractioncan also span acrossentirely differentapplications over the internet,by using what is knownas, ta-da, a webhook.Now, that we've got alight understanding ofthe basics of event handlers and hooks,let's run through a quickrefresher of how to use an API.Have you heard of IOT,the internet of things?Well, this here is a thing.Well, not this adorable/weirddog lamp thing,but the actual light bulb itself,it's what is known as a smart bulb.Now, I've got an app on my phone,which lets me turn on thelight, pretty cool, right?I mean, don't get me wrong.A plain old light bulb is pretty amazingwhen you think about it.When I turn on the light switch,it allows power to come tothe bulb and it lights up.That's cool, but that's medoing it, I'm turning it on.In reality, it's notmuch different with meusing an application on my phone, is it?I'm telling it to turn on.I can also even change the color,but even that, I'm sayingto make the light green,and I'm telling it to do it when I click.Now, what makes theselight bulbs really shine?That's a dad joke, I tend todo that, sorry about that one.What makes these light bulbs really smart,is that they can becontrolled by external events.Like for instance,I can make it so thebulb turns on at sundown,I can even set up a scheduleso that it gets darkerthe closer it comes to mybedtime, making me feel sleepier,because my lights are outsmarting me.In fact, you've probably seen it.There's a whole industryaround smart homes.So many products, all sortsrevolving around the house,being smarter than what'sgoing on around it.Now, the industry saw incredible growthover the past couple of years.Now, the way thisparticular light bulb works,is that I define a scheduleof how I want it to behave.The light bulb isn't sittingthere asking my scheduleover and over again, ifit's time to turn on.There's an externalprogram that's running,and when my defined time occurs,it sends the requestto the bulb to turn on.It's almost as if the sunsaid to my light bulb,don't call us kid, we'll call you.At sunset, turn on the lights,and it does just like I didwhen I clicked my phone.It sends the same message tothe light bulb to turn on,and in fact, in this particular example,it quite literally is as ifI did it using the phone.This light bulb is actuallyconnected to the internetwith an exposed API.I can control it via anAPI from my computer here.This here is Postman,if you haven't seen this tool before,you should totally check it out.I absolutely love it for exploring APIs.Now, the API that I'm exploringhere is from LIFX or LI-FX,the company that produces my light bulb.Now, you'll see here thatI can change the values,and you'll notice here that it's a PUT.PUTs can be used to explain changinga particular property of the resource,and not replacing all of them.In this case, I'm gonnasend a PUT request,so I'm gonna send a PUTrequest to my light.This API uses a bearertoken to authenticate,and I've got that all set up.You can see here that I amchanging the color to red.Now, I'm gonna send a PUTrequest to this specific bulb.I'm gonna click this here,and boom, it's red andthat's pretty cool, isn't it?I can use this code toturn this light off and on.We already know thatjust letting this lightturn off and on, with regards to the sun,has made it labeled smart.When the sun goes down, turn on.Sure, that's pretty smart,but I bet us being ableto control it via codemight make this thing labeled a genius.I mean, if you think about it,it's like when anything,like anything at all,that I can dream up happens, turn it on.Even better, we saw thatwe can change the color.I can make this turn greenwhen I have a new email,or flash different colors,when someone comments on a YouTube video.Or, I'm sure if I was into sports,I bet I would love if thisblinked my team's colorswhen they scored apoint, go, team, sports!What if I use this for an on-air light,for like when I was in a video conference,so my kids knew not tocome barging in on my call?They'd see this,\"Rudolph the Red-Nosed\"dog lamp-thing was on,and they'd know that I was on a call.When it was done, I could turn it off.Genius, I tell you, genius.Now, whoa, I actuallyneed that like right now,but wait a second.Would that mean that I'dhave to write a programthat just sat there andchecked all those situations?Like, keep checking the sports scores,and keep checking my email inbox?Like for that video callexample, if I think about it,what it feels like to me,is that I'd have to writesome code to continually checkand see if I was on a video call.It doesn't feel veryefficient at all, does it?It fact that feels an awfullot like my kids askingif we were there yet?Ooh, but what if a video call startingwas considered an event?What if I was able to write some codeto handle that video-call-started event,I'd be able to, in that handlingcode, turn on the light,just like we did in the code.I guess that would mean I'dhave to write some sort of,plug-in for my videoconferencing software,if I wanted to share it?I'd have to have everybody in the worldinstall some software ifthey wanted to use it.Yuck, wouldn't it be niceif somehow that eventcould trigger outside ofthe application to anyone,like over the internet.This is my friend, is wherewebhooks come into play.Chances are your videoconferencing provider allows you tolisten and handle events using webhooks.That solution basically already exists.We'll look at webhooks likethat one, here in a bit,but do you see how if that eventwas sent across the internet,I wouldn't need to writecode to continually pullto see if I was in a meeting.I can just wait forthe video-conference-started notification.Now, my video conferencing provider says,don't call me kid, I'll call you,and our handler justsays, turn on the light.It only runs when our provider says,psst, hey kid, a video conference started.Now, I hope that you just hadone of those light bulb moments.I mean that quiteliterally and figuratively,like the type above your head.I hope that thing just turned on.I'd like to ask you totake a little break now.I'd like this to sink in for you,and one way to help this all make sense,is for you to pause the video,and think about what we just saw.Can I get you to come up with three ideasof what you might want to doif you owned the smart bulb.Everyone has different needs,and remember quite literallyanything could trigger it,could make a change colors.Now, if you're havingtrouble coming up with ideas,check the notes.Really, I want you tolet your mind wander.What would you like to have happento make this light turn on?It can literally anythingyou can dream up.Let's take a break,and when you come back,I'll share some toolsthat will give you a lot of inspiration.I'm thinking you'll bepleasantly surprised.You might even be able to achievewhat you dreamed up withjust a couple of clicks.See you in a bit.(mellow electronic music)Before the break,I asked you to come up with some ideasto make this smart light bulb,even smarter, how'd it go?Did ideas just flow out of your mind?Sometimes I find thatwhen I'm told to dream upanything at all, suddenly I can't.I have ideas pop in my mind all the time,but the second you askedme to come up with one,like right on the spot,my mind goes blank.And, that's a bummer,especially when you're tryingto learn a new technologyyou wanna put into practice,but you have no real idea where to start.If that just happened to you, no worries.I kind of expected it would happen.I've got a solution forthat lack-of-ideas problem,and we'll get to that here in a second.To get there first though,let's talk about a growingmovement called, no code.Don't worry, it's not amovement to abolish coders.No code is the concept thatyou can, and often should,build applications withoutactually writing any code.You're given building blocksand you snap them together.The concept is that theapplications we buildare similar enough thatthey can be broken downinto reusable parts and snapped togetherinto new formations tobuild new applications.It's wonderful forprototyping, and frankly,sometimes you can build exactlywhat you were trying to dowithout writing a single lineof code, like no code at all.I'm talking about somesuper impressive stuff.E-commerce sites and integrationswith third party APIs,Check the notes,if you're interested indiving deeper into this.One of my favorite no-code siteshas been around for a long time.Even before the no-code movement took off,it's called, IFTTT, whichstands for, If This Then That.It's a no-code solutionfor exactly what we've been leading up to.It's an event handler for the internet.If this happens, then do something,and there are a smattering of optionsthat they call, services.These are services thatexpose events that can happen.There are a bunch of them,from your location changed,to it's snowing, to the sun is setting.You'll also notice thatthere are other services herethat are web specific.There's an email servicethat exposes events,like new email received.You define the service that you wanna use,and you choose the specific event.If this, and now,you choose what happens whenthat event occurs, then that.These are called, service actions,and there are a differentset of services herethat allow you to do different things.For instance, the company that makesthis light bulb I was using,was called, LIFX or L-I-F-X.They provide an action service,and it exposes a bunch of thingsthat I can do with my lightbulb, like change the color.Because, I've linked my accounts already,I can choose which of mylight bulbs, what color,and many other things.Combining the service withan action, like a whole,if-this-then-that combo, iscalled, an applet, cool, right?I'm pretty sure that you couldbuild a couple of appletsto create your own ideas,with just a couple of clicks,and definitely no code.I think that this #nocodemovementmight be onto something,it's #nojoke.But, now though,what about the situation that we hadwhere you didn't have an idea?Well, this is awesome,and this is a developerhack that keeps on giving.Sample applications are awonderful way to get inspired,and guess what?These applets are shareable.In fact, if you up here toexplore, you'll get suggestions,but you can also typewhat you're looking for.I asked you to come upwith ideas about lights,so let's type that, lights.Let's see all the appletssurrounding lights,so here we have togglelights, blink your lights,that's nice, disco party forhue lights, that's wonderful.Alexa, turn on the lights.Sorry, if I just triggeredyour Alexa at home,if you have one.Turn on my lights blink,when your doorbell rings,these are great.All sorts of things.Now, I can enable one ofthese for my own account,and when it comes up, it asksfor my specific configuration.Now, you probably noticed that there weredifferent types of smartbulbs in there, in that list,but that doesn't mean thatyou can't take that ideaand make it work for your own-use case.Can you see the power in that?Now, this is actuallya pretty common patternin developing software.You take the base code,and you make a copy of it,and you make your changes.This is called, forking,you fork your new copy.Remember, this is just one ofmany no-code automation tools.If you're enjoying this way of thinking,I encourage you to look at Zapier.They provide similar building blocksto the complete same sort of,if this happens, then do that.You wire up services tocreate what they call, Zaps.It's super fun, and I highlyrecommend exploring here too.There are lots of inspiringideas to be found.Zapier makes you happier,I just love that.These no-code automationtools go a long wayin making just about anything possible.But, as you can imagine,there are gonna be cases when you're gonnawanna have more control.You're gonna wannawrite some specific codethat the action doesn't provide.I'm pretty sure that'swhy you're here, in fact.You want to use awebhook, so let's do that.Let's explore how that worksright after a quick break.I'd love to give yousome more time to explorethese no-code tools.I really want you to thinkabout these applets or Zaps,as an abstraction ofthe power of webhooks.Oh, one thing that might help,if you wanna just playaround with some actions,there's a smartphone app andit lets you install buttonson your home screen, justlike this, like look here.I've wired it up, an IFTTTbutton so that when I click it,it turns on the red light.That way Roxanne doesn't haveto do it, that was a bad one.Don't call the joke police on me.I hope that one didn't sting too much.(cymbals crashing)Check the teacher's notes formore exploration guidance,and please let me knowwhat you come up with.See you in a bit, and when you come back,we'll explore how to capture informationsent from a webhook.I think in order to getthe clearest pictureof how webhooks work,it will help if wetravel way back to 2007.It was a time of wearingdouble polo shirts,so you could pop your collar, twice.People wore Ugg boots with shorts,and Justin Timberlake wasactively trying to bring \"SexyBack,\"and web forms were still a thing.It was a simpler time.To gather information froma user on your website,you'd write an HTML form andyou'd put a method on it of,POST, and in the action, you'dput the name of the script.It's important to remember,that the web is stateless.Once this request to generate the pagethat the form lives on,the web server job is done.The GET request is over.Your user would fill out the HTML formwith the named fields and thenthey'd click a submit button.What the browser doesfor you in this case,is it takes all the valuesthat were entered in the form,and it makes a brand new HTTP requestto the URL that you specifiedin the action attribute.That POST request contains the datathat the user entered in an encoded way.As a developer,you would write a requesthandler on your websiteto capture the informationfrom this request,and then you'd act on it.Again, your browser is makinga request to your server.Way back in 2007,a developer by the name of Jeff Lindsay,made a proposal to use anexisting idea already very presentin software design patterns.He proposed to use the hookmodel that we talked about,but instead of locally,he suggested to do it over the internet,and he called it, a webhook.Jeff realized that it wouldbe fairly straightforwardfor web developers whowere already very familiarwith processing form datasubmitted via a POST request.What this approach wouldfeel like to developers,is just another form submission.In this case, instead of theuser submitting the form,a third party could submit the data.The handler could be written the same waythe developer already knows.The information is pushed to the handler,in that same familiar way,to the developer and everyone wins.In order for this to work,the third-party applicationneeds to be informedfrom the developer where theyshould post their information.You know, the URL wherethat handler lives.And then, when thethird-party event happens,it posts the informationabout the event to that URL.(icon exploding)That app is definitely embracingthe Hollywood principle, right?Don't call us, we'll call you.It took off,for all the reasons thatevent-based programming wins.It's, of course, waymore efficient to receivea POST request, thancontinuously polling an API,checking for a change.Instead of, are we thereyet, are we there yet?Via an API, the POSTrequest sends, we're here!That was 2007, webhooksare now everywhere.I'm guessing what broughtyou to this course,was that you encountered one in the wild,and you weren't exactlysure how to use it.No worries, this happens to everyonethe first time they run across one.It's a bit challengingto understand at first,the web has changed a lot since 2007,but the webhook concept here,is still pretty much the same.Our apps are now built differently.Like for instance, wemay be using services,and instead of form post,we build our own APIsfor our clients to use.The client post information to our API,usually not using a form.We developers useweb-based APIs all the timeto build our applications.You should view webhooksas an extension of that type of work.This is why sometimes you'llhear webhooks referred to as,a reverse API.It calls you, instead of you calling it.When you use an API,you need to understand theparameters that it expects,and the reverse is true for webhooks.You need to know whatinformation is being sent to you,and in what format.There's no formal specification,and any data can be sent to your handler.Now these days, our webhandlers most likely looka wee-bit different than they did in 2007.Technology has evolved,some handlers still accepttraditional, form-posted data,and some of our handlers acceptJSON, posted in the body,for client side, the APIsthat we're writing, right?See the teacher's notes for more on this.You'll find a variety in whatwebhooks post to your handlers as well.As a developer, writing oneof these webhook handlers,it's pretty important that you understandhow to capture and parsethat incoming data.Let's take a look at anexisting webhook implementationand see if we can't capturethe data to inspect,right after a quick break.By now, I'm hoping thatyou're inspired to connectunrelated applications together.Well, we've got a good tasteof some powerful concoctionsthrough the no-code solutionsof IFTTT and Zapier.You've seen what's possible.You understand why you'd want to useevents to trigger actions,as opposed to pulling an API repeatedly.With the what and the why,of webhooks out of the way,I think it's time that we takea deeper look under the hoodto see how these webhooksare actually working.I was trying to thinkof common applicationsthat all of us developersare bound to use.The obvious one to me, is GitHub.If you've taken a look atthe notes for this course,which I hope you have,then you've for surealready encountered GitHub.I've put the notes andcode for this course,in a GitHub repository, or repo.GitHub is a social coding site.It enables you to share your code,and work on projects together.You can submit issues,and keep detailed-versionhistory of your software,and you can read documentation.It's a wonderful place to explorewhen you're first learning to code.If you don't have an account yet,I'd love for you to pause the video,and sign up for a free account.Now, quick note,I'm gonna show off a littlebit of how to use GitHub.I've dropped notes thatgive a more detailed tourin the teacher's notes to learn more.Make sure to check it out.There's even a link to a video game,that will walk you throughmaking your first poll request,or a request to make a changeto someone else's code.I know that can feela little bit daunting,but it doesn't need to.I want it to feel funfor you, because it is.After you've got yourselflogged in to GitHub,wheel fork my teacher's notesrepository to your account.This will make it all yours.Now, forking is the process that happenswhen you see a repository that you like,and you'd like to explore it,and make your own changes.You fork it, and you make it your own.You make your own copy of that repository.Now, you can always laterask to apply the changes backto the original repository.Now, I want you to fork the repository,because once the repository is all yours,you can specify some webhooks on it.Here I am on the notesrepository for this class,the links attached in the video.I did wanna make a quick note,that the layout might looka little bit differenton the GitHub site,as they're constantly making improvements.Now, in the off chance thatyou can't find what I'm doing,because the site has changed.Please remember to check thenotes for this specific video.I'll update future youthere, with what's different,and we'll get back on track.Sure glad I used GitHub for this.Up here, you'll see some social features.You can star a repo,which is equivalent of asocial media love or thumbs up.Now, as a developer,someone giving you a starhas that same dopamine hitas a like does.The more stars your repo receives,the more likely it'll be discovered.Here is the fork icon.What I'm gonna do, isI'm going to fork this,and I'm gonna put a copy in my account.Now, you'll see it'scopying everything over,and this is now my own copy.Boom, just like that.Pretty forking fast, right?Note how this repo is mine.It's under my username,and you can see where it was forked from.Now, that this repo is mine,you can see that I havea settings tab now.I'm gonna go ahead, I'mgonna click into here.You'll see here on the left nav,that we have an option for webhooks.Awesome, let's click into it.Ooh, webhooks allow externalservices to be notifiedwhen certain events happen,just like we talked about.Awesome, totally makes sense.Okay, so let's add a webhook for our repo.I'm gonna click this add webhook button.I was thinking that weshould get the informationwhen someone stars our repo.What we're going to need isan URL to handle that request.Do you have one?I don't have one.A quick solution to capture a webhook,just to check things out,is to use what's known as a mocking tool.One of my favorite waysto mock a webhook handler,is to use a web-basedtool called, Beeceptor.Here let me show you,I'm gonna open that up.I'm gonna come here, I'mgonna make a new tab.We're gonna go to beeceptor.comLet's make this a little bit bigger.Again, Beeceptor mightlook a little bit differentif you come in here.Check the notes,if you can't seem to followalong with what I'm doing.Let's see, what am I gonna do?I'm gonna try a GitHub event.Let's call it, github.Basically, what you do isyou just put your name there,and you can click this create endpoint.Now, as you can see, I havethis github.free.beeceptor.com.I'm gonna go ahead, I'm gonna copy this.I'm gonna keep this page open.I'm gonna pop back over tomy add-a-webhook page here.I'm gonna paste that into the payload URLso that that's where it will be sent,where the information will be sent.We're gonna capture the stars,so I'm just gonna put/stars at the end here,so that I know what that is.That's the cool thing about Beeceptor,you can just invent whatever you want,that that route doesn't exist,but it will still catch it.All right, let's keepfilling out this form.We have content type,that's nice that GitHub lets you do that.We have a couple options here.We can either send JSONor form URL encoded.I'm gonna choose JSON, let's do that.The other nice thing that GitHub does,is they let you choose which eventsyou would like to trigger the webhook.You can send just the push event,that's when somebodysends code to your repo,or you can say, send me everything,but they also let youselect individual events.We really only want whensomeone stars the repo,so let's do that.I'm gonna click that, and I'mgonna choose, down in here,there is one for, see howmany, much stuff you can do.You can sure do a lot,so I'm gonna do stars.Here it says,a star is created ordeleted from a repository,and I'm gonna uncheck pushes, okay.There we go, we just have stars.Anytime somebody stars thisrepo, we should get an event.Cool, all right, so I'mgonna click, add webhook.Now, if I go and star my ownrepo, because I can do that,'cause I like myself.I star it, and if Ihead over to Beeceptor,you'll see that there was a post to stars.Actually, there was two,because GitHub postsoriginally to you're link,just to make sure it works.Here is what happened when we starred.I'm gonna click into this here,and then I'm gonna clickthis little cody-thing,looking thing over here.I'm gonna click this,'cause it will help format things better,and this is what GitHub sentus, it's pretty cool, right?It shows you all the different informationof the repo that was on,and if we scroll downa little bit farther,we can see all things about the repo.All these different,rest APIs that I can hit,to get more information if I wanted to.This is all about the repo itself,and I think if we get downhere a little bit closer,this is kind of, hard to read in here,but definitely capturesexactly what was sent.If we scroll down, wow, that's a lot.If we scroll down into here.There we go, we can see who sent the star,and we can see who the userwas, which is very nice.It's got more information,it's got the avatar URL.I'm gonna actually, let's open that up.Let's see what this is.Wow, look at that dorkwho liked this repo.I can use this to figure out,what I would like to handle, right?This was a post that was sent to any URL,and I can figure out what I wanna handle.I wanna go back andshow you something elsethat's pretty cool inside of GitHub,that not everybody offers,that offers a webhook,but GitHub is pretty great.I'm gonna come back intoour webhook, that it exists,and it will show you what happened, right?It will show you thedeliveries that were made.If I open this up, I can see,and this is actuallymore nicely formatted.Not everything offers this,so it is important to remember Beeceptor,because you're gonna wannacatch other webhooks,and not everybody hasthis nice functionality.Again, we can see this, and we can see,see that dork, this dork here.It's so nice that GitHublets you control the format,and actually see the waythe data's presented.They really webhook you up.Okay, so now that wehave a firing webhook,let's see if we can'tmake use of that dataright after a quick break.We've now got a webhook that fireswhen our repository is starred.I think we should use thatknowledge to celebrateand we shouldn't celebrate alone.I was thinking about anotherpretty common developer toolthat you're bound toencounter is some sort of,real-time group chat software.It's very common that you'llend up in a chat room of sorts.Now, whether that be Slack, orMicrosoft Teams, or Discord,these channels are a greatway to stay up to datewith whatever it is thatyou're congregating around.It's also a good place tojust hang out and learn.I was thinking, why don't weexplore sending our GitHub datainto one of these chat platforms.We'll make sure that everyone celebrateswhen our repo gets starred.Now, I'm gonna choose Discord,but you'll find thatmost platforms providea similar sort of integration.Now, like we saw with GitHub,we were able to define awebhook that would firewhen certain events happen.Now, Discord actually allows you toset up the other side automatically.They set up a webhook handler for you.Let's see what that feels like.Just a friendly reminder.This is probably gonna looka little different for you,in the future.Now, if you run into anyproblems following along,check the teacher's notes,I'll update you there with changes.All right, so if you don'talready have Discord,it's a pretty quick setup,and I've included installationinstructions in the notes.Go ahead and pause me,and get it all set up.This here is my current Discord.I've got some learning channels set up.Here's the free code camp,and there's TwilioQuest.There's the coding den, allgreat learning communities.If you're looking forextra places to hang outand learn to code, checkout the teacher's notes.I'm gonna go ahead,I'm gonna make my own brand-new server,by clicking the plus button,and I am going to say,create a new server andinvite your friends.I'm gonna do that.Let's go ahead,I'm gonna call this exploration,and we can get rid ofthis later, totally fine.I'm gonna click create,and it's gonna say, invite your friends.I'm just gonna go ahead and close this.I've got friends, I promise I got friends.What's really nice about eachone of these Discord channels,like this is where youcould come and talk, right?You could talk in these channels.Each one of them hasthis little icon here,and because we own the server,we can edit the webhook.Let's go in here,I'm gonna click on thisintegrations, over here on the left,and you'll see here,there's this webhooks.I'm gonna choose, createwebhook, and let's see,webhooks are a simple way topost messages from other appsand websites into Discordusing internet magic.I agree, they are prettymagical, aren't they?Let's make some magic.Oh, and here it came up with asuggested name, Captain Hook.(chuckles) What a great dadjoke, which if I'm honest,I'm kind of bummed that I didn't think of.Hopefully some more dad jokes pan out.This one kind of, petered out at the end.All right, so I'm gonna changethis to GitHub Notifier.It says careful, you have unsaved changes.I'm gonna click savechanges, 'cause I want that.I want a the thing called,GitHub Notifier, in general.Again, what's happening here,is that this is buildinga webhook handler.When you post to it,it sends a message intothe general channel.Now, this is important to note,this is different fromwhat we saw at GitHub.GitHub made the request to the handler.This handles the request,both called webhooks.But therefore, because wehave both sides of this,we should just be ableto connect them, right?In fact, it looks likethe only thing I can do,is just copy this webhook URL.I'm really, that's thewebhook handler URL.I'm gonna go ahead, I'm gonna click this,learn more, up here,because let's assume that we didn't knowwhat we were gonna do.I'm gonna click up at this learn more.It talks about some thingsthat we could do, and it says,can't really use webhooks,can use webhooks.Here's GitHub, that's great.I'm gonna make this a littlebit bigger for all of us.It's talking about making a webhook.Oh, look it's changed already.Before it was, it'sunder integrations now,so already see these noteshave changed a little bit, that's fine.There's the Captain Hookjoke, for GET updates.Let's see, let's keep on scrolling.Well, this looks important,to make a webhook messagedisplay messages properly,it's really, really,really, really, really,really important, the caps there got me,that you append /github to the end of it.Yes, like five really is important.Okay, it's telling us to goover to our GitHub settings,like we had done before,and put the /github on there.Let me get back to that, let's get back.Here we are, here is my GitHub repo,and I'm gonna leave this old,this old webhook in place.Let's go back into our webhooks here,and I'm gonna add a new one.You can have multiple webhooksdoing different things,and let's do that, let's justexplore what that feels like.I'm gonna add a new webhook,and I'm gonna paste,before I copied, right?I copied from that Discord, Iclicked the copy URL button,so I have that there, exceptthen I copied the help,so that's not good, let's not use that.Let's go back to the Discord,and I'm gonna do this, copy webhook URL.Now, it says copied in the clipboard.I'm gonna come back overhere, and I am going to paste,and wow, that is a long URLand I need to do something.I was reminded somethinglike five times, oh, right.Really, really importantto say /github at the end.There we go.Now, this handler is unique to me,so that you can tell thatthis is whatever this is here.Yours is gonna look different than this.This is my specific user,probably my specific channel,all encoded in there.I've added /github at the end,and the content type in those notes,I saw that it said, application JSON,what's nice about, of coursehaving two different webhooks,is we can do whatever we want here.I'm gonna click, just send me everything,everything that happens.Let's go ahead and send it, andI'm gonna click add webhook.Okay, and fingers crossed.I am going to,un-star the event andthen I'm gonna star it.Ooh, I heard a little Discord beep,I think we got, I think we did it.I'm gonna go, oh, that was,that reveal wasn't as excitingas it could have been,'cause I wasn't here,but look, there we go.A new star was added by craigsdennis,and there's that little avatar of mine.It's working, I think it could probably bea little bit morecelebratory, but check us out.We wired up two completelyseparate services,(snaps) just like that.Pretty cool, right?We set out to do basicallyjust what we wanted.When someone stars our repo,everyone in the general channelthere will be able to see itand they can celebrate along.We saw how the nomenclaturewas kind of interesting, right?Like we saw how bothservices, GitHub and Discord,call it a webhook.One is the pushing side andthe other is the handler side.It's a little confusing, isn't it?But, what Discord is doing,by putting that trailing /github,is specifically formattingthat informationthat's pushed across from GitHub.It understands what is sent from GitHub,and it has specificformatting for Discord.I don't know about you,but I think for stars,I'd like to see it more sparkly.Give me some more emoji'sin there at least,you know, really celebrate.In order to do that,we'll need to handle thatGitHub request ourselves,and turn it into the formatthat Discord is expecting.That sounds like a good idea.Let's get ready to write some code.There goes our no-code streak.Why don't you get up?Take a breath of fresh air,give those coding muscles a stretch,and be ready to come backand dive into some code.We've got our GitHub event notificationsbroadcasting to our Discord channel.We're feeling pretty good aboutwhat we were able to accomplish,with just a little bit of configuration.But, we've decided thatwe wanna make things worka little bit differently than the default.This is a very common scenario,and a good look at why sometimesyou can't solve everythingwith no-code solutions.There are often specific tweaksthat your customers would like to make,that aren't necessarily exposed.Let's make our tweak.Let's make it so that whensomeone stars our repo,we write out some emojis,and show a big pictureof our code's newest fan.Now, in order to do this,we'll need to write a handler.I've written the boiler plate,or the beginning common bitsof the code, for us already.It's available in the repo.Before we dive in,I wanna take a quickmoment here to talk aboutsome of the possible challengesthat we might to encounter,as we start developingon our local machines.In order to get thingsup and running here,I'm going to be using a lot of tools.Now, depending on where youare in your coding journey,some of these tools mightbe completely unfamiliar.I wanna assure you that it is okayfor it to feel overwhelming,we've all been there.Setting up these toolsis a one-time thing,but it definitely is a hurdlethat I don't wanna minimize.I've seen this frustrate folksto the point of givingup their coding journey.Please don't give up.You are doing great and youwill make it through this.Ask for help, and remember,all of us have been through this.I've included instructionsfor installation for allof the tools that we'll be usinghere shortly, in the notes.Please, remember that you can pause mefor as long as you needto get things working.All right, let's do this.The first thing thatwe're gonna need to do,is get this repository fromGitHub onto our local machines.The way you do that is byclicking this code button.As you can see,there are several ways toget ahold of this code.You could even downloada ZIP if you wanted to.However, I'm gonna suggestthat we use Git to do this,but like you see here, you don't have to.I'm using a Mac and I'mgoing to start my terminal.I'm gonna do that bypressing command+space,and typing, terminal.On Windows, this will be eitheryour command prompt or your PowerShow.At the command prompt,I'm going make sure thatI have Git installed.I'm gonna type, git --version.There we go, and as longas something comes back,you're all set.If not, you'll need to install, Git,there are instructionsin the teacher's notes.Git is a powerfulversion control software,which lets you and your fellow developers,make and document changes to files.Now, using Git is unfortunatelyout of the scope of this course,but I highly recommend learning it.I've shared links in the notes,for where to pick up thiscrucial collaboration tool.It makes things like we'reabout to do, super convenient.I am going to navigate to whereI'd like to store this code.This is of course, a personal decision.I keep a code directory, or folder,right off my home directory,which is represented bythis tilde, in Unix land.I'm gonna change directories,or CD, into that directory,and it's called, code,and I'm gonna make a newdirectory here called, courses.I like to store the tutorialsand courses that I take,the code for them,I store them in a place called, courses.I'm gonna say, make der, mkder courses.Back at GitHub, I'm gonnachoose that I wanna getthis using HTTPS.I could use SSH if I wantedto, but I'm gonna use HTTPS.Typically I do use SSH, this is up to you.If you have it set up,this is something that you need to do,if this is your first time doing it,you won't need to setanything up to make this work.I'm gonna copy this URL here.I'm gonna click this, I'mgonna go back to my terminal.I'm gonna say, git clone,and then I'm going to paste,so we've got that URL there.I'm gonna click this.What this does, is this pullsa copy of all of the code,and puts it locally on my machine here.Now, that it's here, I'm gonnachange into that directory.CD web, and I'm gonnapress tab, webhooks course.Here we go,and I'm gonna open up thiswhole directory in my editor.I use Visual Studio Code,and if you don't yet have an editor,I highly recommend this editor as well.It's pretty great, it's free,there's tons of plugins.There are installationinstructions in the notes,so I'm gonna type code, andthen I'm gonna press dot.Awesome, here it goes.Let me make this a little bit bigger.The code that I wannadraw your attention to,is over here in the code directory.I'm gonna click this to open it,and then I'm gonna lookat this express-discorder,this is what we'regonna work on right now.We're gonna open upthis express-discorder,and in here in this server.js,this has the boiler platecode that I was talking about.This is using a webserver called, Express.In the handler that we're going to handle,is a post from /github, andthen it will run this code.We'll take a look at thiscode here in a second,but basically it means if,you make a post to this webserver, that's running here,this web server, at /github,it'll run this code here.This code will run when a post happens,but in order to run this,we need to make sure thatwe have Node installed.VS Code has a built-in terminal actually,so let's go ahead and use that.We're gonna go toterminal and new terminal,and you'll see here that in the future,I can use control and then tilde.Nice, and so now it'sput me in the root there,so I'm gonna go into CD code/,and then I'm gonna go intothe express-discorder folder.Awesome, in order to run this server,we'll need to make sure thatyou have Node installed.(chuckles) I told youthere were a lot of tools.Node is a JavaScript runtime,that allows you to runscripts on your local machine.Let's check and see ifyou have it already.I'm gonna go ahead andtype node --version.Now, as long as this first part here,this V, whatever, is 10 or greater,the code should work as expected.Now, if not,check the teacher's notesfor how to install Node.Once you have Node installed,you'll also have npm installed.npm is Node's package manager,and you'll find that it standsfor just about anything.I actually have quite abunch of fun with that.Let's just go to the page really quick.It stands for, nice paintings, Mondrian.What else does it stand for?Oh, does it not refresh every time?There we go.Nincompoops producing methane,novelty plastic mustache.Okay, there we go.It stands for, Node Package Manager,but it stands for a lot of things.What I've done already,is I've built this package.json file,and it has in here some dependencies,and the dependencieswill come in and it will,they're gonna be installedfor you when we use npm.Let's install those things.We'll do that with npm install,and that will go and installpackages like Express,you know, the web server.It will also use Axios,which is a library that we can use,to make our own POST requests,'cause we're gonna postto, the Discord URL.We need to make POST requests,because we're going to post toour Discord webhook handler,like right in here.It says, axios.post,and we're gonna post, oh, that reminds me,we're gonna need to store this someplace.'Cause remember, thatthat's private to you.It's your personal link,and as you're about to see,you don't want anyonegetting their hands on it.If they just post to it, theycould post on your channel,and you don't want that happening.One way of dealing with the security,is to use what's known asan environment variable,and what the code here is using,this process.env.DISCORD_WEBHOOK_URL,is accessing your environment variables.What I've done, is I've set things up,so that you can definein a file named, .env,and that's right over here.That's short for environment,and you'll see that youdon't have one right now,'cause we just check this out, right?What you're gonna do,is you're gonna want tocopy this .env.example,so we're gonna grab this file.We're going to,let's see, I'm gonna copy,and then I'm gonna click this,and I'm gonna click paste, right?I right clicked, or two-fingerclicked on a Mac, to do that.I'm gonna rename this file now, to .env,.env, here we go, and in here you'll see,that you need to get ahold of your webhook URL.I'm going to go andgrab that from Discord.Back in my settings,remember in the channelunder integrations,under webhooks, I can view this webhook.Here's my GitHub notifier,and I'm gonna copy the webhook URL.I'm gonna come over here,and I am going to paste it and save.Now, I have a .env, andthis is my own private file.What's nice about that is,this code can now be shared, right?It's code that maybeanybody can run, right?I was able to give this to you,and what made it personal for you,was you put stuff in yourenvironment variable.This is a common way to share code,but have the private information,like the stuff that'sunique to you, hidden.Okay, with that all set up.I think that we're readyto spin up this web server.I'm gonna write npm start,and it says that it islistening at local hosts.It's telling me I can command+click that.Let's go ahead and dothat, and thumbs up indeed.We did it, so we have a localweb server running, awesome.Whew, that was a lot of toolsto install in one video.Now, that we're all set up,we need to make it so that GitHubpoints to our local web server.Uh-oh, our local web server,it's not on the internet.How can GitHub possibly see it?Let's take a quick break,and when you come back,let's explore tunneling,so that webhooks can see our local system.We just got a local web server all set up,and it's ready to handleevents from the GitHub webhook.But, we have a slight problem,our web server is local.Only we can see it, it'snot on the internet,and this is typically howyou do development, right?You develop locally,you get things workingthe way that you want to,and then eventually,you deploy your web serverto a public-facing URL,so that the world canvisit your masterpiece.But, typically you only deploy afteryou've worked through all your challenges,you don't deploy right away.Now, this makes for aninteresting challengein creating webhooks.In order for a webhook to work,we need to be able to make aPOST request to a public URL.Now, the good news is,there are a lot of tools,and yes, I'm gonna haveyou install another tool,sorry, but it's just one this time.What this tool does,is it opens up a tunnelon your local machine,so that your applicationcan be publicly accessiblefrom the internet.Now, this type of tool is handy also,for like if you wanna see yourapplication in development.Like, if you wanna look atyour phone or your tablet,instead of just your local machine,it's pretty handy and it's quick to use.All right, let's open up this tunnel.The tool we're going toinstall is called, ngrok.The N stands for, network,and to grok something,means to understand it.It's also a Unix toolthat allows you tounderstand unstructured data.What ngrok allows you to do,is open up a specificport on your machine.Now, if you recall,our local server was running on port 3000.What we can do, is open upthat port to the internet.I hope that you'll grokngrok here shortly.First things first, get ngrok installed.Now, not be a broken record,but this page is bound tolook different in your future.Check the notes if you have troublefollowing along at any point.There's a download section,so let's go in here.Let's go ahead, let'sdownload it, it's free.I'm gonna download this for Mac OS.I'm sure it'll detect where you're at,and what you get back is a ZIP filethat has a command line executable in it.I'm gonna click that and open it up,and it automatically openedup in my downloads directory.Go ahead and pause me,and try to find where your download went.Mine went into my downloads directory.I'm gonna go in my Visual Studio Code.I'm gonna open up another terminal here.You can do that withthis little plus here.Here's another terminal,and I know that that wentinto my downloads directory.I can say, CD, my homedirectory, and then downloads.And then, from here, I can say,in this directory run ngrok --help,we can just kind of, see what it does.There's the differentthings that it can do.I use ngrok all the time,so I've put it in my path,and that lets me run itfrom wherever I'm at.Check the notes on how to dothis, it's totally optional.I will use the ngrok frommy downloads directoryin these videos,but if you wanna add it to your path,'cause you wanna use it all the time,check the notes and youcan get yourself set up.Okay, so I'm gonna goback to my other tab.Looks like I have three open,you can type exit there.I've got, the server is running,and it's running on localhost:3000.In my other terminal here,I'm gonna go ahead and ./ngrok,and then you say what you want to do.I'm gonna open up an HTTP port, right?Hypertext Transfer Protocol,and I wanna open it up on port 3000.If I do this, what happensis, I get a brand new URL,and if I copy this, I copy this URL.You'll notice thatthere's the HTTPS as well,which is pretty awesome.You get a HTTPS for free.I'm gonna go ahead, I'mgonna copy that one,or actually I could command+click it.Let's do that, we'll command+click it,and it's gonna open up that webpage,and you'll see that this stringof numbers, if I did that,I could also open that upon my phone or my tablet,and it would be working.I totally had that hairdo, by the way.So, because we can seethis URL, it also means,GitHub can now post its payloadto us and we can process it.Let's jump back,and let's take a little deeperlook at what's happeningin that code in the server.js.Let's get back into that code there.See if we can get a littlemore real estate over here.I can't, unfortunately,let's see maybe we can go alittle bit lower over there,is that all right?I think that's all right, okay.We are going to get a post to /github,and it's going to, it setsup a couple of things.We've got this content,and we have this hard-coded avatar URL,and it's gonna post to our webhook URL.It's gonna post the content,which is what we saidhere, should say, wave.This is an emoji, andit should say, hi, Mom!I like to always debug withmy mom, whenever I can.And then, we're gonnapost, and then we'll get,we'll send back a successmessage if it worked,and if not, we'll send out an error here.Well, let's run it.I'm gonna copy ourngrok URL one more time.Just to make sure I'vegot that in the clipboard.I'm gonna copy this,and I'm gonna take that overto our GitHub settings, right?Let's get back.Here's the get GitHub course,I'm gonna go into the settings.Head over to webhooks,and I am going to add a new webhook,oh, and it's making me log in.I'm gonna use, let megrab my password here.Okay.All right, so we'regonna add that webhook.Again, I'm gonna copy that,'cause I copied my password,so I'm gonna copy thislink here, the ngrok.io,and remember that we havea /github that we need to post too.Let's go in here, we're gonna paste.Let's get this (faintly speaking) off,and we'll say, /github.We want it to send JSON,'cause I think that that'seasier to work with,and let's do, again,let's just select the individual events.We'll do a star, let's uncheck pushes.When you're just interestedin when somebody stars,and we're gonna go ahead and add webhook.Okay.Let's switch back to our Node server.Oh, it said, success.It said, success, does thatmean that we got a post already?Don't switch.Boom, we got it.As soon as you set it up, itsends one, so there we go.Hi, Mom, and there's Dr. Tysonamazed by what we just did.We sent a message fromGitHub, through our tunnel,to our local machine, backout to the webhook handler.Awesome, boom indeed, Dr. Tyson.We got it, well kind of,I mean, we got the starts of it, right?Now, we can iterate our developmentuntil we get exactly what we want.Just like we saw with Beeceptor,I can actually use ngrok tosee what was passed to us.Let's go to the ngrok,go back to the ngrok window real quick.If I come, I'm gonna movethis up a little bit here,even a little bit more.I can see that there is,a post was made to our GitHub from GitHub.In here, there's this web interface.If you follow this link bydoing a command+click on it,you will see that this is the informationthat we got from GitHub.Now, let's go ahead,let's make sure that it'sworking when we get a star,'cause right now that justworked from the original message.I'm gonna go to webhooks.I'm going to un-star and star.I think we'll get two, yeah,so you get one every time you starand every time you don't star.There was a new star added.That was from one of the botsthat we were pushing before,and then here's this one that we just didfrom getting a star on the thing, awesome.It's working and if we lookat our ngrok inspector here,we can see that this isthe message that was sent,and it was an action that was created.This is nice, right?We can see exactly what was sent,so we can hang out in here.Now, I realize that GitHubalso shows you this,and we could do this with Beeceptor,but once you get ngrok running,this flow is prettymuch all we need, right?We can see that there's the sender,there's the avatar thatwe're gonna need to grab.I'd also like to show therepository name, right?Let's take a look and seeif we can't find that too.The repository name, oh, this is great.This would be awesome hereto say the name of it.You can either use this name or full name.Those are what we wannagrab from this JSONthat just came in from the post.Let's take a look at that real quick.Since we already have the, in our code,let's back down here, in our code,we already have thisavatar URL defined here.Let's go ahead and let'sgrab that from the request.How's that sound?We're gonna get rid of this hard-coded,Dr. Tyson-thing there,and we're gonna get,from the JavaScript objectthat's being passed in here.We have the request thatcomes in, and on the request,there is a body and Ihave it so that it isreading JSON for us, this boilerplate is reading the JSON,so it knows about it.That was in .sender, right?At the bottom there.If we look,we were in down here,in sender we have this avatar URL, right?This is who starred itand this is their avatar.I have this avatar URL, soI'm gonna use that here.I'm gonna say req.body.sender.avatar,and it was _url.Now, to make sure I got it,I'm gonna need to startand stop my server.It's a little annoying, right?This is a little annoying to have tostart and stop my serverto make sure that it works,but I will.Control+C, we'll get you out of that,and then I'm gonna do npmstart, to run that again.Now, my code is reloaded,but I don't wanna do that every time.I don't wanna stop, I don'twanna control+C and do stuff.I know I said only one tool,and you don't really need this,but I think you're gonna want this.There's a tool called, nodemon,that will watch your JavaScript files,and it will automaticallyrestart the server for you.It's really nice, andI want you to have it,although I don't want to keepon throwing tools at you,but let's, I'm gonna showyou how I install it.You don't have to use it.We're gonna do npm install,or nodemon -g, for global.After you install this,you can use it whenever,that's what the -g means there.Now, that this has been installed,we can say, nodemon start,it kind of looks like it saysno demon or like node, mon.Anyway, so here we go.Now, you can see thatif I add this, hi, Mom,and I add some more and I click save,it will restart the server,which is exactly whatwe love, want, right?You wanna change, every time you save,you want the server to berunning your latest thing,it's a quick, rapid development thing,that once you get inthe handle, hang of it,you will love it.All right, so the server restarted,and back on the ngrok page,I don't know if you noticed this or not,but this is awesome.There is also, just likeon, there's a replay,so you can replay and youcan actually even edit it.But, I'm gonna go aheadand click this replay.Ooh, there we go, ba-boop.Okay, so there we go, hi, Mom.There's my avatar coming through.My avatar URL is now there.Now, that's a pretty bigpicture, I love that.That feels great, this is like,this is a new person who liked your code.Great, good feeling.We're doing good,and we really say, hi, Mom, now, right?Our change is live.Now, what we need to do,is we need to change thecontent variable, okay?We need to change this content,so instead of saying, hi, mom,we need to make thisdynamic about who came in.Let's do this, I'm gonnawrite a to-do here.I'm gonna write a to-do,so we'll say, to-do,change the content variableto contain the repository name and,the GitHub,username, and why don'tyou add some emoji flares?You can explore, if you want to, in here,you can explore with, you know,there's like rocket, right?There's a rocket-thing that you can do.If you just type colonand then the name of it,you can start seeing what it isthat you could do with emoji flare.Why don't you pause me,and see if you can complete this to-do?Use the request fromGitHub to do this, right?You can look over at your ngrok,and see what's going on there,and make sure that youchange the content of this.And then, go ahead and do a replay,and see if you can getthat content to be whatyou're happy with, whensomebody stars your repo.Give it a shot,and when you're done unpause me,and I'll show you how I did it.Remember, to use ngrok to seewhat the request looks like,and to replay it, are you ready?Pause me.(icon beeps)(icon beeps)How'd you do?I hope it went well, anddon't sweat it, if it didn't,you'll get this.What I'm gonna do is I'mgonna grab the username,and that was inreq.body.sender.login, okay?And then, I'm also gonnagrab the repo name.I like to pull these things out,just to make sure I got 'em.We'll say, req.body.repository.name.The sender is at the bottom,and the repository was up atthe top there, that request.What we can do is we can usea string template in JavaScript.We can say, one of theseback ticks like this, right?Then, we can say, $(username),just starred $(repoName),and this way you could have other peopleset up to their repos.You could share like,let's say we're in acommunity of everybody who is,write some code together,we can all run this.Because, this is ourown private Discord URL,you could let other peoplerun it in there GitHub,in their Discord webhooks,or they can post to this URL.Awesome, so let's go ahead.I'm gonna save this, it's saved,and the server has restarted,so fingers crossed.We're gonna go back over to our ngrok,and we're gonna click replay.We heard the littleDiscord go, and it says,craigsdennis just starredthe webhooks course.Oh, shoot, I forgot my flair.Let's go back, let's see.I definitely think we need some tacos.I can't have enoughtacos, we got taco, taco.How about, let's definitely do the rocket.That's one of my favorites,rocket, and I also like,ta-da,ta-da,taco.I will save, and again,I'm gonna come back,and I am gonna replay.I heard the boop-boop.There we go, oh, beautiful,so much flair, awesome.Pretty smooth workflow, right?I hope that gave you aclear feeling of whatdeveloping a webhook handlermight feel like in practice.We saw how not only canngrok open up a tunnelto your local machine, but italso provides the ability toreview and store what was posted,and it even allows you to replay.It really speeds up yourdevelopment process.Now, I'm sure you're probablywondering, well, great,but does this mean I have toleave my local machine on?Of course, the answer is, no,but you're gonna need todeploy your applications,so that GitHub can reach 'em.Now, if you don't havean existing application,this can definitely seem daunting.You probably don't wannaspin up a Heroku instance,just to host this single endpoint.That seems like a lot of work.One of the solutions that hasbeen gaining a lot of ground,is the idea of a cloud function.We'll take a look atthis here in a second,so that you can see how that feels.These make a really good solutionfor a quick webhook handler.I want you to get a feeling for it,as it's getting more andmore popular in this world.But, before we get there,you, my friend are due for a break.That was a lot of technologyand a smattering of concepts.I want you to take a breakand let it all soak in.I'd love for you to make surethat you can picture in your brain,the request from GitHubcoming to your handler,and your handler doing what it needs.Now, in our case,it's posting to a webhook handlerthat was already set up by Discord.I'd also like you to take a minuteand realize that you cannow run any code at all.When an event thatsupports webhooks occurs,you can handle it.That's pretty cool, isn't it?Now, as empowered as I feltbefore by the no-code workflows,like IFTTT, these possibilities areactually quite limitless.Now, I could definitelymake my dog light upwhen I get a star, look, check this out.Just like this,dog star, Keanu would get that one.Okay, so after your break,let's swing back and check outserverless cloud functions.(upbeat electronic music)Okay, we got our webhookwritten and we're happy with it,but in order to run, we need a public URL.While our tunnel solves the problemfor development purposes,it's definitely not production ready.Now, we could deploy our web server thatwe wrote and hosted somewhere.There are lots of providers that do that,and it's definitely gettingeasier to deploy a web server,but even the server seemsa little heavy, doesn't it?We're really just taking some values,and quickly doing our thingfor a single request type.It's hardly a web application.Well, we're not loving this feeling.Succinctly, this feeling is,do we even need a server?Could the project go withoutone, could this be serverless?There's a growing movementcalled, serverless,and it tackles this problem exactly.You don't need to worry about the server,someone else will handle it for you,and it will scale bothup and down for you.Now, this scaling both directionsis referred to as, elasticity.Function-as-a-Service, or FaaS,is the idea at the core of serverless.Basically, you write a function,and you follow the specific parameters.The provider handles allthe routing responses and scaling.All of the big cloud playershave some sort of version of this,and typically the executions are free,until you hit a certain threshold.Even then, you only pay forwhen the function executes.This can lead to tremendous cost savings,also because there'sonly ever one function,it makes the code very easyto read and understand.It's kind of like.♪ Take me down to theparadise elasticity ♪♪ Where the FaaS is cheapand the code is pretty ♪♪ Oh won't you pleasetake me home, oh yeah ♪Is that too much?I really Axl Rose to the occasion there,I guess we can probably justslash that part out later.Okay, fine no more puns,and roses.I thought you should have a taste of howthe serverless development feels.I went ahead and got the solutionall coded up and ready to deploy.There are a lot of serverlessproviders to choose from,but one of my favoritesto get up and running quickly is, Netlify.Now, standard warning is in effect.This flow that we're about to dois bound to look a little bit different.Netlify is always adding functionality.Another thing that I wanna point out here,before we dive in, thisis totally optional.You don't need to do this.I totally won't be offendedif you just watch me do this.I've signed up for a Netlify account,and I used my GitHub account,and I'm gonna head totheir docs really quick.They're right here in the header, docs.Now, what I wanna install is the CLI,or command-line interface,which allows us to run commandsfrom our command line for Netlify.Let's go ahead, let's click this.Let's get started.Here's some great information on it,and we're gonna go ahead and install it,and we're gonna install it with a -g,which makes it go globally, okay?That means that we can use it wherever.I'm gonna come in hereand I'm gonna run this rightfrom the root of the directory.It doesn't matter where we do it,'cause we're gonna do it globally.This will install the Netlify package.What this will do, is we'll, here shortly,what we'll do is we'll authenticate,and it will allow us to doactions on Netlify on our behalf.It's super powerful, it's great.You hardly ever actually need to leaveyour command line anymore.You just hang out in this editor.I think you're gonna love it.Okay, we are all set up here.Again, like I said,I had already startedporting this code over,and first though, let's log in first.If you do Netlify space login,I'm already logged in,but what will happen,here I'll switch my account,so that you can see that I go throughthe same thing that you do.I'm gonna say, switch my account,and I am going to log into a new account,and it's gonna pop uphere, and it's gonna say,authorize this application.This is okay to do this,this is what we wanna do,we wanna authorize that CLI, awesome.Now, we can, you canalso revoke at any timefrom the screen here insideof Netlify after a login.All right, here we go.We are logged in to Netlify.I'm gonna take a lookat this directory here.This is the netlify-discorder.Open that up, and underfunctions/discorder,there's a file called, discorder.js.This is very, verysimilar to the local codethat we had just lookedat, the Express code.There's a couple of things thatare a little bit different.The first thing that I wanna point out,is that this function is asynchronous.You can tell that, because it says async.What that allows you todo, is then later await.You can see here that when this Axios,remember this is what we'reusing to post to Discord,this returns, what's known as, a promise.It's a promise that in thefuture there'll be a value.We handled this differently,when we were not in an async function.Let's just take a look at that real quick.If I open up the express-discorderand I look at the server,you'll see that I did axios.post,and then down I used a .then,and I got the response back,and then I played withthe response, right?This is a function that'sgetting the response back.But, this function, when it was declared,is not asynchronous,and it's using a request anda response, remember that.It's using the request,and we were able to pullthings off of the body before,so we were using req.body,and it was already a blown-up object.Just remember that, it'sa little bit different.Again, this is using a promise,and it's using the then pattern.Where what's different over in Netlify,is we are using an async method,which means that we're ableto do something like this,where we can say, await.Now, instead of it comingthrough in a then function.this pauses and waits, andthen it goes here to go rest,so it actually runs synchronously,or it appears to run synchronously, right?What makes this different, isbefore we were catching it,we were doing a then,and then we were doinga catch on the error.Here, we're using a standardJavaScript try and catch,very similar, just a littlebit different of a pattern.I know that that can hang some people up,so please check the notes,if you'd like to learn moreabout asynchronous JavaScript.The other thing I really wanna point out,what's the main differencethat I had to do here,porting these things over,was before remember itwas request and response?This just has event, okay?What's expected is theresponse you just returned,so I'm returning an object thatgives a status code of 204,instead of returning a response.That's what Express had expected,and event is basically therequest object, more or less.What you'll see here, isevent.body is a string,and in this case, it'sgoing to be a JSON string,and we're going to parse it into body.Then, the rest of the code is the same.I just made an object called, body,which is what was on the other request.It's just a little bit different,but pretty much the same code.This code we're gonna goover into Netlify, Discord,we're gonna go intocode/netlify-discorder/, right?'Cause, we wanna get ourprompt in the same place here.Now, this is using Axios, andthis also has a packaged JSON,and you'll see that it's got Axios.I'm gonna go ahead, I'mgonna do an npm install,and there we go.Believe it or not, thisis ready to deploy.Watch this, this is awesome.We're gonna say, Netlify deploy,and we're gonna send thisup to the Netlify server.The way that this works,is anything that's in thisfunctions folder here,is going to become a serverlessfunction, let's do it.It's gonna ask, it's notconfigured to a site,this folder that we're in right now.We want to create a brandnew site, so with that,that is what we wanna do, and here we go.It says, team Craig Dennis's,everybody with the last letter of S,knows what I'm feeling there.Yes, we do want Craig Dennis's team.All right, so we wannamake a unique site name.They suggested,super-cool-site-by-craigsdennis.Let's try gitubstars, 'causethat's what we're doing, right?You'll have to choose something different,'cause I'm gonna take it,and somebody else already took it.Don't you hate this though?People end up with like,githubstars1925, so githubstarred,yes, I got it.I've got, githubstarred,and that's gonna be,githubstarred.netlify.app.Now, it's asking whatdirectory do you wanna publish?And, it's that, it lookslike almost like an emoji,but it's a dot there.It says like, this current directory.Yes, that's the directory Iwant, and would you believe it?But, we just pushed up toa server, a live server,there's a function that'srunning, and it's running.Let's go, I'm gonna jump in herein the admin side of things,I'm gonna follow this link.I clicked that logs linkthere, here we come.We are up, we are publishedtoday, and let's drop out.Let's go take a look at these functions.It says, one Lambda functionis ready, and it's down here.It's this function.In here, whenever the function would run,this is what the function's name is.This is it here live, whenever this runs,the function log will showany sort of console log thatwe have, pretty cool, right?I do have one little bitof configuration to do.We need to set an environment variablefor what our personal Discordwebhook URL is, right?That code, remember,I'm still using the environmentvariables in that code.I need to put thatenvironment variable here,and that's under here,it's under settings, and thenit's under build and deploy.Here we go, environment variables.I'm gonna say, edit variables,and our variable name,let's just verify we knowwhat that variable name is.It's inside this discorder file here,and we called it, DISCORD_WEBHOOK_URL.I'm gonna pop that into myenvironment variable here,and the value that we want,you can get that from Discord.Let's go, let's grab that one more time,just to remind ourselves where that's at.We're gonna click thesettings here, integrations,view webhooks, GitHub notifier,and I'm gonna copy the webhook URL, okay?I copied that.Come over to the build,I'm going paste that.I'm gonna click save.Now,if I come back to my function,let's go ahead and get that URL again.It says that it is running in production.I'm gonna grab that, I'mgonna head over to our GitHub.I'm gonna go in my webhook course,in the webhook course here under settings,under webhooks,let's go ahead and let'sedit this one, right?This is our local machine.This is the one that wewere doing last time.It's not gonna work,'cause sometime I'm gonnashut my computer off.I swear one of these days,I'm not gonna have it on.All right, I'm gonna grab my password.I paste my password,and I'm gonna make sure thatI have the webhook URL copied.I'm gonna change that to be,that's not right, we don'twant the Discord web app URL.We want the githubstarred.netlify.app,new site on Netlify.I'm gonna copy that,and I am going to pastethat into my webhook.There we go.Everything is still set, I'mgonna update the webhook.I am going to get myDiscord into a good state.Here we go, let's star this thing.(computer beeps)Ooh, I heard it.We get the new star added from here,where is the one from Netlify?What happened? Let'ssee if we can debug it.Is this updated?Githubstarred,netflify-discorder, what's this?This doesn't look like, maybewe need to update the webhook,maybe it didn't update.Oh, here we go.Here's some failedones, let's take a look.What do we get in response?The URL argument must be oftype string, received undefined.Let's see, that's the same thing again,the URL argument must be oftype string, received undefined.Let's see.It doesn't like thatavatar URL, let's see why.We've got the body sender avatar URL,we're parsing the event body.I'm assuming that's what the 500 is.Let's look at our, we canlook at our logs though, too.Let's see if there's anythingthat happened in the logs.It just says, that it ran.I didn't get an error there.Let's see, one more time what that said.Let's make sure that it hasa sender with an avatar URL.Sender avatar URL, yeah, it's still there.Sender avatar URL.Let's do a console log,let's just show that off.I would say, console.logevent.body,and then we'll do afterwards, we'll say,console.log(body), okay?I'm going to, now I made the changes here,so I need to push them up.Publish that directory,and see it's a lot quickerthe second time around.All right, and let's goreplay that from GitHub.We don't want the delete one,that was the deleted, right?Let's replay the one.Let's do it.(computer beeping)Well, there we go, now it's working.I don't know what thatwas, something silly,but I wanted you to see.What you should seem isthat this should update.There we go, so see, Ican use console log here,to look at things.I'm not exactly sure what happened.I think what I'll do, isI'll go back and watch this,but you don't need to dothe console log bits there,but that is how you deployand debug a function,in this one new world.The good news is, is thatthis function is free,for a 125,000 executions a month.I don't think I'm gonnarun into that limit,but you never know, this isa pretty killer repository.Oh, and while debugging with thosehandy-dandy console logstatements, on the production,might not be your style,and it really shouldn't be your style.You can actually run a localNetlify dev environment,check the teacher's notes for that.I hope that gave you a good test driveof serverless functions,pretty neat, right?These functions are especiallyhandy for webhook handlersand other one-off scripts.You literally could use afunction just like that,to kick off just aboutanything that you can imagine.That's a lot of power.Now, remember on top ofbeing basically free,this will scale bothup and down with load,because that elasticityis at the heart of serverless technology.I've added links in thenotes to other serverlessor cloud computing providers.All right, so now I hopethat you're feeling likeyou've got a prettygood handle on webhooks.You understand why they're useful,you know what they can accomplish.You can see how you cando just about anything,and you even understandwhen you should use them.Really, that when is any timeyou wanna get notifiedof an external event.Whenever you feel like pulling an API,check to see if theysupport webhooks first.Basically, you're a pro,and I realize you might not feel like one,we've been focusing on just one event.Now, there are a couple of other platformsthat deeply embrace theconcept of webhooks.I've got something plannedthat will really stretchyour new webhook muscles,and I hope it shouldgive you the confidence,and most importantly, thepractice that you need.Take a quick break,and then let's get started onthe final project for this course.So far in this course,you've picked up theessential skills that you needto make use of webhooksin your applications.I thought we'd apply thoseskills in a large project,using completely differenttechnology than we used thus far.This way, you can see howyour skills are transferable.When it comes to technologythat fully embraces webhooks,it's pretty hard for meto think of anything elseother than Twilio.Now, if you've seen my courses before,you know that I am prettyobsessed with Twilio.When I saw that they useda video game to educate developers,I was like, I've gotta work at this place.Freeze frame, record scratch,(record scratches)now I'm a Twilion, and I'm in the game,but really I've loved Twilio,ever since I was introduced to it,I was at a JavaScript conference in 2012,and someone had built a scavenger huntthat you could participatein by just texting a number,and it would respond with different hints.Now, not only was it fun,I was also impressed with how peoplewere using the text messagesto build interactivity.You didn't need to install anything,you just text a numberand you were playing.It's a pretty incredible input device.Text messaging is justone part of the platform.Really, any sort ofcommunication or engagementthat you wanna have,Twilio has an API for it.The way most of the products work,is that you buy a phone numberand that number is yours immediately.You can use it to make calls and texts,and you can program what happenswhen people call into it or text it.People build all sorts of funand creative things on the platform.In addition to a completelycloud-powered call center,I've seen a video gameget modified live through a text message.Somebody built a Smashmouthhotline, which plays that one.♪ Somebody once told me ♪When you call, it was such amean trick to give someone,when they ask for your number.There have been crisis linesthat keep caller's number anonymous,and routes to an available personwho can help in the time of need.I even saw a kid built afake snow day alert message,he got in trouble.You can build just aboutanything you can imagine,and Twilio does most ofthis magic through webhooks.We talked a while backabout lifecycle hooks.This is the concept wherethe flow of the applicationallows you to hook into it andthe control is passed to you.You're responsible to respondwith what the application should do next.That's the main concept forwhat happens with incoming inputto your Twilio number, a callor a text message, right?The control of the applicationis passed to you via a webhook.There are a ton of otherwebhooks that allow youto control what happensat different times,when different events occur,continually passing controlback to your webhook handlers.Because, your handler isany public accessible URL,your code can be in anyprogramming language.It just needs to respondwith what you want Twilio to do next.Twilio's basically a webhooks playground.There are an impressiveamount of them to play with.Here's a couple of reasons for that.First off, Twilio has beenaround for a long timeso there's been lots oftime to build these events,to hook into, and to perfect that flow.For another reason,remember when we talked aboutthe creator of the webhookconcept, Jeff Lindsay?Well, he was a Twilion,in the very early days of the company.I found that out researchingthe history of webhooks,and it all made sense.I figure, what better place to show offyour new webhooks skills,is there than Twilio?First, we'll build a simpleaffirmation text app,to get your feet wet.And then, we'll launchinto a larger projectthat will take ideas fromcallers, record them,and text them to us, all with webhooks.All right, let's get started buildingthis webhook-based application.In order to show off theTwilio webhook basics,let's build a really simplemessaging application.What we'll build is an app that respondsto any text message with, you've got this,just to give our textersa little confidence boost.Turns out those three words go a long waywhen you really need them.Now, in order to get started,you're gonna need a Twilio account.Now, don't worry, it's totally free.Twilio offers a free trial,and they give you morethan enough free creditto build all of theapplications in this course.If you don't already have an account,go ahead and pause me,and follow the instructionsin the teacher's notes.After you get your free trial all set up,unpause me, ready?Standard word of warning.This is bound to looka little bit different,as Twilio is always improving things.Check the notesfor anything that mightfunction a little bit different.All right, I've set up afree-trial account too.We should be having prettysimilar experiences.There are a couple of restrictionswith your trial account,which are listed up here.You can send messages and makecalls to verified numbers,and messages and calls include a noteabout this coming froma Twilio trial account.Like, when we send this text message,when you get a text message back,it's gonna say, sent fromyour Twilio trial account.Now, if you didn't alreadyget your free trial number,go ahead and do that.Get a trial number, go ahead, click that.That's gonna give youone, 203, that's great.I'm just gonna choose this number,and right away, this number is all mine.With a paid account, you could get more,we only need, everythingthat we're gonna build here,we just need this one phone number,and it doesn't matter that it hasthe trial message stuff on itfor what we're gonna build.All right, let's do it.Remember what we're going to do,is we're going to make itso that if anybody textsthis brand new number that we just bought,we're gonna return backa nice affirmation.To do that, I am gonnanavigate to my numbers.Over here, there'sthese little three dots,all products and services,and I'm gonna choose phone numbers here.You'll notice that there'sthis little pin icon.If you pin that,it will make it so thatit's part of the menu.When you come back inhere, you can find it.There's a ton of products.I'm gonna pin it right now, let's do that.You'll see here's the menu now,I've this phone numbers thing here.Let's go into our phone numbers.Again, this is our demo one, my demo one,you have a different demo one.I'm gonna click into that,and I'm gonna scroll downon this configure page.You'll see voice and fax.Yes, you can actually sendfaxes, actually comes in handy,I don't know if you have afax machine anymore, I don't.I'm gonna scroll down here to messaging,and you'll see it says, messaging.When a message comes in,send it to this webhook via an HTTP post,send it to this webhook.That is supposed toreturn the instructionsthat Twilio is expecting.Now, the format that's expected is TwiML,or Twilio Markup Language.Just like HTML renders your webpage,TwiML renders your application.I'm actually gonna change thisfrom webhook to TwiML Bin.A TwiML Bin is a handy wayto return these instructions.You don't need to spin up your own server,this is taken care of for you by Twilio.It's a serverless solution,so here, I'm gonna make one.I'm gonna do that by clickingthis plus button here.I'll say, plus,so I am going to name my TwiMLevent so I can find it later.I'm gonna call it, affirmation.Now, TwiML is tag-basedand case-sensitive,so I'm gonna say, and all ofthem start with a response,so response, response, okay.We want to add a tag thatsends back a message,and that tag is actually, message.We'll say, you got this!I'm gonna drop a muscly icon in here,just to really get the point across.There we go, and then I'mgonna close this message tag.Awesome, and you'll see that there's some,it'll tell us whether ornot we've got it good.It says, this is good,valid messaging TwiML.Let's do it, let's go ahead.We're gonna click create on this,and now you'll see messaging,when a message comes in.Go to this TwiML event called,affirmation, return that.Need to remember to savethe number, all right.Now, I'm gonna pull out my phone,and I am going to text my number there.203-902-5283,and what I expect, whatever I send, right?It immediately, it's gonnasend back, you got this!I'm gonna say,I'm having a hard time with JavaScript,and it says, you got this.You're right, I do got this, thanks.Awesome, okay, so that is basicallythe \"Hello, World!\" of TwiML webhooks.That's pretty awesome, right?It's a good use, it's like,when a message comes in,send it to this webhook.Now remember, this couldbe any programming languageor tool that returns a valid TwiML string.You can return thisfrom any web applicationthat you have existing already.And, this TwiML Bin that we used,because we didn't havea server up and running,it's a serverless solution.Twilio's hosting it for us, andhandling the scaling for us.Like, we don't need toworry about that at all.More of this in the teacher's notes.Pretty great, right?We now have a way to respond toany incoming message to our number.While we're currently onlyusing a static solution,we could definitely build a dynamic,a handler that did whatever we wanted.This is like our handler that we usedfor posting to Discord.This could be whatever you could dream up,and you can respond witha valid TwiML stringto continue the application.We'll get to some more localdevelopment here in a second,but first, I think we shouldexplore a low-code toolused to build complexserverless workflows.Okay, my next idea foran app is a little meta.I would love to have a call-in line,where anyone could calland describe their ideasfor cool webhook implementations.I love hearing all your ideas,and I find that when Idiscuss things out loud,it greatly increases thelikelihood that I'll get it done.Let's do that, let's builda hotline that promptsthe caller to record their idea.Once the idea is recorded,let's transcribe it,and then text it to ourselves.We took a look earlierat some no-code solutionsthat were powered underthe covers by webhooks.Well, Twilio provides alow-code, serverless solution,that allows for rapid developmentand prototyping of applications.It's called, Studio,and like most no-code or low-code tools,you'll find that you canbuild a lot of solutionsjust by dragging some objects around.Let's build the first part ofan application using Studio.We'll make sure to keepour eyes out for webhooks.Hey, future you, this is forsure going to look different.You'll find that almost allno-code tools rapidly iterateon their UI daily to makethings more quick and clear,and I'm always pleasantlysurprised when I open up Studio.I'll update the notes on anychanges that might've occurred,since right now in my timeline.All right, let's do this.Okay, so we are in our Twilio console.I'm on the phone number page currently,and I'm gonna jump over to Studio.That's this, these threelittle dots over here,and I am going to scrolldown, into runtime,and I'm gonna choose Studio.I don't wanna do thatscroll again, so again,I'm gonna pin that, so thatshows up in my little menu here.I'm gonna go to Studio,and I'm going to clickthis, create a flow button,'cause that's what we're going to do.We're gonna create a brand new flow.Let's do that, I wanna callthis flow, idea catcher,and we'll say, next, and you'll see,there's a bunch oftemplates that we can use,but let's just start from scratch.We have a pretty straightforwardway of doing this.Let's go ahead, let's just go, next.That looks like the dorkthat starred my repo.This here is called, the canvas,and what you do, is youdrag widgets onto it.Let's see, when someone calls,we should tell them whatwe're expecting them to do.I am going to grab this, say and play,because I want it to saywhat we want them to do.I'm gonna drag this over,and we're gonna drop it right here.Now, that it's out here, I can click it.What will happen is over here,these properties will change.This say widget allowsus to do text to speech.I could also give it anaudio file if I wanted to,that's in here, I canmake it play a message,but we're gonna have it say a message.We'll do text to speech, so let's see,I want it to say, hello there,I'd love to hear your wonderful idea.Tell me about it after the beep.All right, so theseother fields down here,they are optional,but they're here, might aswell fill 'em out, right?Let's make it English,and let's choose a voice.I'm gonna choose, Kendra-Neural.This is from Amazon Polly,all these voices are from Amazon Polly,and this is Kendra-Neural.It's kind of got thisfun, those days of like,those robo voices are gone.I remember when,Texas Speech first came out,and it couldn't even say cheeseburger,it was like, chaz-ebbiger.I'm calling, Kendra.I'm gonna leave her there,and we can make a loop acertain number of times.That is feeling pretty good.I'm gonna click save to update the widget.We want this to be saidwhen somebody calls.What we're gonna do, is we'regonna drag from this trigger,note, this is like a webhook, right?We're gonna say, whenan incoming call comes,we're gonna go to this here, awesome.That's probably enough to test, isn't it?Don't you think?The way that these work,is you can see that I made four changes,but I'm gonna go ahead andI'm gonna click publish here.We're gonna publish the flow.It gives us a little bitof warning ahead of time.Now, this is ready to use.I'm gonna go into, back to my number,and I am going to come into my number,and I'm gonna scroll down here.Under the voice and fax section,so when a voice call comesin, when a call comes in,we want to use a Studio flow,and we can choose our flow ofidea catcher and click save.Awesome, now I am goingto call that number,and I'll put it on speakerphone here.- You have a trial account.You can remove this message at any timeby upgrading to a full account.Press any key to execute your code.(phone beeps)(phone ringing)- Here comes Kendra.- Hello there,I'd love to hear your wonderful idea.Tell me about it after the beep.- There's Kendra, it'stelling us about the beep.That's awesome, right?We got that up and running, very easily,going through a webhook, and again,that's really renderingTwiML behind the scenes.It works, so now here's the trick,that flow that we built isactually a webhook handler.It actually has a URL, that little menu,this little like, select the flow,it's kind of hiding it from you,but it really is just an URL.What's really happening,is when a call comes in,and Twilio posted this URL,our flow returns TwiML,in this case, it's the sayTwiML (faintly speaking),which is very similar tothe TwiML that we wroteto send the message.But, the low-code solutionhas that hidden away.Now, this is very common inthese low-code solutions.They abstract away the cogenerationand all the webhook handling, okay.Next, we want to recordwhat our callers say.Let's go back to our flow,so I'm gonna jump back into Studio.I'm gonna click this idea catcher,and get back into our flow here.Now, we want to record,so I'm gonna drag outthis record voicemail.We'll drag this out here.Awesome, and let's takea look at its setting.If I click onto it,we can see that it will stoprecording after five seconds,or you can make it stop on,if somebody pressed the key.Ooh, and 3,600, that's 10 minutes.Oh, sorry, that's an hour.3,600 seconds is an hour,and that's more than enough,even for chatty folks, whohave very detailed ideas,like myself, very chatty.Okay, cool, so we also cantranscribe the audio to text.We want that for sure.I'm gonna click that on, and look at this,we have a transcription callback URL.I know what that is, that's a webhook.That is a webhook, isn't it?But, what is actually gonna happen,when that transcription comes?I know that I could go up here.I could probably go to thishelp here and figure that out.But, if there was onlya tool that we could usethat would just allow us toput some random URL there,so that we could see the results,so we could capture what was sent.Wouldn't that be nice?Wait a second,there was something that weused earlier, wasn't there?Do you recall what it was?You wanna try and do this yourself?If so, go ahead and pause me,and get a web-based URL in here,that we can use to see whatvalues are posted to it.Are you ready?You can do this, pause me.(icon beeping)Okay, ready, how'd you do?The tool that I wasthinking of was Beeceptor.I'm gonna head over there really quick,jump over to Beeceptor again.I'm gonna create a newone called, recording,'cause that's whatwe're looking at, right?We're looking at thisrecording thing here,and we have that up and running.Now, we know that wehave this Beeceptor URL.I've got this, I'm gonna copy this,I'm gonna come back over here.In the transcription URL, I'mgonna paste the recording,and I'm gonna make my own thing up here,we'll say, transcription.Let's see, do we wanna play the beep?Yes, we definitely wanna play a beep,'cause we said that, right?We also have a recording status callback.I think we just need thetranscription right now, right?We don't really need to have,to know when a recording is available,but look, there's another webhook.All right, so I'm gonna click save,and then I want to connectthese two together.It says, when audio completes,we want it to go to this one.You can see that there's,if you had more here,you could choose differentthings to happen,when different transitionshappen in each of these widgets.Okay, so an incoming call is gonna come,it's gonna say, hello there.It's gonna record the voicemail,and that voicemail shouldbe sent to our place.I'm gonna click save, andI'm gonna click publish,and now I don't need togo update my number again,'cause it's alreadyset to the flow, right?It's already set to this flow.It should be working now.If all is working as planned,when I call this number again,when I call my number and leave a message,we should see a webhookkick off here, let's do it.- You have a trial account.You can remove this message at any timeby upgrading to a full account.Press any key to execute your code.(phone beeps)(phone ringing)- Hellothere, I'd love to hearyour wonderful idea.Tell me about it after the beep.(phone beeps)- Yeah, so I have this idea,where I'd like to set up a call linewhere people could callin and record their ideas,that's my idea.Now, hopefully I hung up,and hopefully we shouldsee here in a second.We should see our messagehas been recorded,and it's being transcribed right now.When the transcription's done,we should get pinged overhere, if all is working.I'm trying to be patient.There it is, so we gotto post to transcription.I'm gonna take a look at that.I clicked this and it's in the new format.Let's scroll this down here.We can see we've got abunch of stuff that came in.Let's see, I called that number.Ooh, there's my number.Feel free to call, I guess.Here we go, transcription to text,so it says, yeah, so I have an ideawhere I'd like to set up acall line where people calland record their ideas,yeah, that's my idea.That's pretty great, butthat's exactly what I need.I need that transcription-textfield that comes across,that's submitted to my webhook.I need that transcription text,that's what I need, awesome.Now, that we've got a webhook event,we can write any sortof handler that we want.We definitely now have the,message has been transcribed, event.We can do whatever wewant with that event.We could very easily sendthat text to Discord.Now, to complete our app,we're gonna have to have thisevent send a text message.Now, I'm excited to show you this,as it's super common towant to send a text messagefrom your webhook handler.There are so many, whenthis one event occurs,text me about it.All those ideas are out there,and they're just waiting to be fulfilled.Let's develop the solution locally,using the local-development toolsthat we learned about earlier.We now have a transcriptionwebhook event that's happening.We saw in Beeceptor whatthe format looked like,and we saw what we wanted.We are ready to handle it.We are going to text thattranscription to ourselves.It doesn't seem like that bigof an application does it?Now, I could spin up a whole web serverto handle this request,but that sure seems like a lot of work,for a simple, little application.Do you remember this feeling from before?Now, we solved it by usinga serverless functionon the Netlify platform.Because, this sort of one-offhandler is very common,Twilio also providesserverless-function capabilities.What do you say, we get oneof these serverless handlersup and running to sendour text messages out?Guess what?I am going to ask youto install some tools,but they're super handyand should be pretty quick.The first thing I'd like foryou install is the Twilio CLI,or command-line interface.This is very much like whatwe installed for Netlify.It will let you authenticateand send commands to Twilio,from the comfort of your own terminal.I love it.If you're a Homebrew user on a Mac,you can install things using Brew,check the teacher's notes for that.We're gonna use npm to install it.We're gonna say npm install, twilio-cli,and we're gonna do this with a -g,which means it's installed globally,and we can run it from wherever we need.Cool, and now we're gonna do,much like we did with Netlify,we're gonna say Twilio login.This is gonna ask us for our account SID,or string identifier for our account,for our Twilio account.Let's open that up.Let's jump into here,let's go back to the home,the console dashboard.Your account sits here.There's a little copy button here,so I'm gonna click that and copy that.I'm gonna pop back over to myterminal, paste that there,and then we will go grab the auth token,which is a secret token thatyou should never let out.You can get rid of it, andI will get rid of it later,in case mine ever endsup showing to you here,but you don't wanna let that out.That's a secret, secret,so I pasted, there we go.I am going to call this,I'm gonna call it, my webhook account.I'm gonna call it, webhooks, awesome.The CLI supports plugins,and one of my absolute favoritesis the serverless toolkit.We're going to use it to setup and deploy our function.Let's go ahead and install it.Now, this is in the notes,if you wanna copy and paste this,but you would do Twilio plugins install,and then @twilio-labs/and plugin-serverless.If everything is working as planned,you should be able towrite, Twilio serverless,and get some response back, awesome.There are the things that we can do.I am going create,a new Twilio serverless project.In this directory where we're at, up here,so there's this directory called, code.I made one called, Twilio.There's some light changer code in here,that you can look at later.Just kind of, a littleadded bonus here for you.Let's go, let's jump into that directory.We're gonna go CD code/twilio,and then inside of this directory here,what we're gonna do,is we're gonna make abrand new server list,Twilio serverless project.We're gonna use theserverless plugin to do that.We're gonna say, Twilio serverless:init,and then you name it.Let's call this, idea catcher, right?'Cause, this is the thingthat we're gonna write to,we're gonna post to this,and then we're gonna makethis thing text to us.We'll do --empty, there's lots of,if you don't specify empty,like we saw with the Studio,there's lots of templatesthat you can use.I think we're gonna start from scratch,'cause I think it's clearer,in the direction thatwe're headed right now.This is preparing a new directory,so it will be all ready for us.Let's go ahead, try to get to the,we're gonna go over into idea catcher now.You'll see up here, there's this Twilio,and we have idea catcher here,and let's take a look at what it added,it added some stuff for us, awesome.You'll see that there'sa folder for functionsand there's one for assets.Let's go ahead and let's make a new filein this functions here.I am going to click thislittle plus button hereto add a new file into this directory,and I'm gonna call it, sendtext.js.All right, this is thestandard boiler platethat you'll need, it's inthe teacher's notes too,if you wanna just copy that.Exports.handler, we're gonna writea function called, handler,and it takes a context, anevent object, and a callback.All right, and we willmake a function there.Callback is how you complete the function,and it's important,because of that asynchronousnature of JavaScript,you can complete thefunction anywhere really.Just to make sure thatwe got things working,I'm going to call it.Now, it's a standard-nodecallback function.That means that it takesits first parameter,is any sort of error that occurred.We're not gonna be expectingany errors with this,and we'll debug, we'll just do my typical,hi, Mom, awesome.The toolkit allows us to runour own functions locally,so that we can test them,so let's spin that up.To do that, you doTwilio serverless start.Awesome, and you'll see that it now says,that there's a functionavailable on local host 3000.If I go ahead and I clickthat, I got, hi, Mom.Hi, Mom, how you doing, Mom?All right, and you'll see in the logs,I've got a 200, and it madea git request to send test.Excellent, now this serverthat we have up and running,is hot reloadable,just like we saw with nodemon or node-mon.This means that you can make a change,and it will be appliedwithout you needing to restart the server.Let's add a little console log here.We'll say, console.log.We're gonna be sending atext here, sending text.Awesome, so now if I go andI refresh my mom page again,I did a command+R there,control+R to do a refresh,and if we look back,we'll see that the consolelog popped out here.Again, another 200 (faintly speaking),awesome, without needing to restart.Totally speeds up the development cycle.Speaking of which, let'sget to quickly developing.Okay, so okay, we needto have our Studio flowpost to our server, uh-oh,our machine is local.We're going to need tohave some way for our flowto be able to see our local server.Do you remember how we did that before?Wanna pause me and see if you can somehowget a public URL for thisfunction without deploying it?Okay, pause me and see if you can rememberhow to open up the tunnel.Remember, you can go back,and it's okay if you totallydidn't grok it the first time.Ready? Pause me.(computer beeps)All right, how'd you do?I was talking about ngrokto open up our tunnel.I'll open up a new terminalhere with the plus,and I'm gonna run that again.That was in my downloads directory,my downloads directory, andit's ngrok, there we go.ngrok, HTTP 3000, right?That was running on port 3000.There we go, and so now,we'll see that we havethis wild-looking URL.I'm gonna click that, open it up.It's not for that, it'sfor a /send-text, right?Isn't it called, send-text?Oh, I wrote, I called it, send-test,but it should be send-text.Let's fix that.If you were followingalong, like I hope you were,you probably did that too.You can right-click and choose rename,and you can call this, send-text.I don't know, what happens ifyou do that, does it restart?Look at that,it restarted with a newthing called, send-text.I didn't have to restartthe server, awesome.It's now called, send-text,and if we're up here,I now have this wonky URL,ngrok URL that's up and running,That gets the send-text.Now, the Studio flow can see it.I'm gonna grab that URL.I'm gonna go back to theflow, so over here, Studio.Wanna get back into my idea catcher,and on the record voicemail,we had left the Beeceptor URL,and now we're gonna pasteour ngrok URL there, awesome.I'm gonna click save,and I'm going to publish,and we'll call.- You have a trial account.- I sure do.- You can remove this messageat any time by upgradingto a full account.Press any key to execute your code.(phone beeps)(phone ringing)- Hello there,I'd love to hear your wonderful idea.Tell me about it after the beep.(phone beeps)- Here's my idea.I wanna build an app thatgathers ideas from people,and then texts it to me.Awesome, so let's jump over now.I've hung up, let's jumpover and watch it come in.We should see a post to send-text here,in a second, as thattranscription happens.Boom, there it is, awesome.If we go over to our ngrok,we should be able to open that up,and see that the message came through.All right, so what we were looking for,is transcription text, here we go.Here's my idea.I wanna build an app thatgathers ideas from people,and then texts it to me (chuckles).That's pretty good, isn't it?Pretty cool, okay so,let's make sure that we can access that.In our code, where we're sending the text,the way that those values come across,is they're on this secondobject here called, event.We'll say, let's do one ofthese, we'll say, transcription.That was event.TranscriptionText.Now, do you wanna hear me call back?Do you want me to takethat time to call back,or is there some other way I can do that?This is the awesome flowthat happens, right?I'm gonna go back now.I'm just gonna replay this,and we sent that text again,and now we should see inmy console log, right?If I switch back over to my console log,we see there's the transcriptionthing, and there it is,we did it.Awesome, we got the TwilioCLI installed and all set up.This'll let us interact with our account,and it also has a plugin that allows usto quickly build serverless functions.We got our local server all up and runningand opened up a tunnel using ngrok.We're now able to handle theincoming webhook request.We were able to getaccess to the informationand now we can also replay those requests.That was quite a bit of work.Nice job, recalling how to getall those things working together.Now this, what we just did,is a very common flow that you'll be doingthe more that you develop webhooks.It'll only get morefamiliar, as you progress.Why don't we both take a real quick break.I know I need some water.When you come back,we'll wrap up thehandler side of the code,and then we'll deploy thisfunction to the cloud.So, we don't need tokeep our local machinesrunning all the time.Enjoy your well-deserved break.You're doing great, see you soon.(bright electronic music)Okay, let's write our handler bit.We're gonna write some codethat texts you thetranscriptions when they arrive.Let's do this.All right, so I am ableto get the transcriptionthat's being passed, beingpublished from that webhook.We're able to get the transcription back.Now, we want to text it.The context object here is very handy.It has a handy way to get access tothe JavaScript helper library.What that does, is givesyou an authenticated client.We're gonna say, const client= context.getTwilioClient.Now, here's the thing we needto be authenticated locally.We're going to need toprovide the toolkit,or official account set and auth token.I'm gonna jump into this .env file here,so see it's this file label .env.We have two things here in this already,and I'm gonna just gonnagrab, again from the console,I'm gonna grab my account SID.You'll see, and it starts with AC,and this of course mightlook a little bit different,as the flow goes, check the notes,and I'm gonna go and grab my auth token.I'm gonna come in here,and I'm gonna paste it,and I'm going to make myselfa note to cancel that,because I just showed you my auth token.That is dangerous,'cause now you could loginto my account here,and do things on my behalf,because you know what that auth token is.This magic .env file in theserverless-toolkit world,what this is, is ourenvironment variables.They will be exposed, actuallyon that context object,that we were seeing.We're going to need a couple of things.We're going to need myactual phone number, right?My phone number that I wanted it text,which is, 1-503-461-0234,please don't call me too late at night.All right, so there's that,and I'm gonna put in my Twilio number,this Twilio number that I have here.Again,what is my Twilio number?My Twilio number is righthere, this is my trial number,I'm gonna grab this, andpaste that here, awesome.I'm gonna save my .env file,and now we can use those.I'm gonna jump back into the send-text,and we're gonna, under thissending text, what we'll say is,well, let's move this back up too.All right, so the client,it has access to all the resources,so we can do client.messages.And then, what we wanna do,is we wanna create a new message.What we'll do, is wewill pass in some values.We're gonna send a messageto me or to you, right?Whatever we put in there for phone number,that's what we're gonna do.Then, we're gonna text thatfrom our trial number, right?Let's say, context,.trial_number, now, or .TWILIO_NUMBER.The reason why this is working,is that number should be verified, right?That phone number that weput in, I'm in trial mode,I verified with my phone number,so that's why it will be able to text it.We have two from, and we have bodies.These helper messages area little intense sometimes.The body that we want, is we wanna say,that there was a newidea that came in, right?Then, we just want to kindof, grab what we did before,where we got thetranscription text, right?Here's the new idea.That's the body of themessage, seems pretty good.Maybe, you know what we should do?We should also just dropone of those in there,I'm gonna pop a bulb in there.I like that my burritois a commonly used emoji.All right, awesome, it'stime to, I think we're good.I don't think we need tosay, hi to mom anymore.We'll be sending the text.Now, because we didn't put ourpersonal information in here,we could share this file with people,and they could just copyit and paste it, right?Like we could put this up on GitHub,and somebody could just use it.In fact, this is in the notes,and you can just use this codewithout changing anything,except for your personalenvironment number.Your phone number and your Twilio account,and your Twilio number, aregonna be different than mine,but the code is the same.That's the power of environment variables.We have the same code indifferent environments.Now, there's something trickythat we need to be reallycareful about here.This create call here off of messages,this is asynchronous.We saw this before, it's promise-based,which means it provides functionsto return values or errorsthat will be called when a valuearrives or an error occurs,which is a mouthful, I realize.What we wanna do, is wewant to call the callback,only after the message has been sent.Otherwise, it will justbe over right away, right?'Cause this'll just,finish will be right over.We need to put the callbackinside of the then.So, what we're gonna dois we're gonna chain offof the promise that's returned.When we say .then,and that's gonna return a function,and it's gonna return afunction that could just say,it will be the message, right?The message that was created,if it was successful.What we'll do here, iswe'll do the callback,and we'll, there was noproblems and we will return.We can return a message,we say, sent message.That message object that comes back,has an identifier as well.Let's put this on a separate line.Let's make that a littlebit more friendly.You can do that all in one line like that.Let's see, so we're gonna have a function,the then is gonna return,the then is going to,expects a function that takeswhatever the return value was,if it was successful, and thenit will run this function.That's when we want the function to end.We don't want it to end beforehand.That's, again, this isthat asynchronous behavior.We'll put a semi-colon here at the end,and then we are going to comeand we're gonna catch this.The catch also expects,if there is an error, let's,the catch expects if there is an error,that you say something about it.That this is a greatplace to do the callback,and just pass the error into it.Okay, so let's walk this one more time.We're gonna use the context again,an authenticated Twilio client,and it's gonna use valuesfrom our environment,our account SID and our auth token,to make sure that we areauthenticated properly.And then, it's going to, forthis authenticated client,it's going to make a new message.It's going to create a brand new message,and it's gonna send it to aphone number, our phone number,the mobile number thatyou registered with.It's going to send it fromour trial number, right?That's the trial numberthat we have in there.It's going to pass acrossthe transcription text.That was on the event thatcame from the request,and if that were successful,we're going to say the function is overand no error happened.And then, we'll just write something else,it's not expecting anything.If there is a catch,if there is a problem,we are going to call thatcallback with the error.We could put some logging inhere too, why don't we do that?We'll say, console.log, and we'll say,we'll just do a sent message,and we'll do a message.sid.Again, that's a string identifier.If there is an error,we'll do console.error,and we'll say, uh-oh!Then, we'll output that error, cool,or at least the string versionof that error, awesome.Okay, I am going toclear things down here.I have that saved.Let's run this locally first,since we were just doingour development thing there,I had stopped my server.Again, that's Twilio server.Let's start, so that willstart the local server here.Looks like I was in the wrong directory.That's what that means,so I need to get in myidea catcher directory,and I will run that again.That was the up and down arrowsto get back to the previous commands,Twilio serverless start.All right, here we go.This is what was running before,I still have my ngrok running,and my flow is still pointing to things.That means I should able to go backto my ngrok,and just go ahead and do another replay.I should receive a text message,and look at that, sent frommy Twilio trial account.There's a new idea, and itgathers ideas from people,and texts it to me, awesome, cool.We have the text working,we have done our local development flow,and now we wanna be able tonot have to run this onour computers, right?We don't wanna keep our computer upand running all the time,so we're gonna deploy it.The way that we do thatis very, very easily,we say, Twilio, swerverless,serverless deploy.It's building up everything we need here.You'll notice that what it's gonna do,is it's gonna take the name of our projectand put some extra stuff atthe end to make it unique.It's got this little four-digit number,and it's got this .dev,'cause that's theenvironment that you are in.By default, it puts you inthe development environment.Let's go ahead.It's deployed, believe it ornot, this is up and running.We could actually hit that,but I'm just gonna grab this.I'm gonna pop back over to my flow,and jump back in here.You feelin' my flow?I'm gonna go into record voicemail,and I am going to, now thetranscription URL is an actual,real-live hosted,elastic in case I geta whole bunch of ideas,which I hope that I do.I'm gonna click save, andthat is publicly accessible.It's now running on the server.The final test, let's go aheadand give our number a call.- You have a trial account.You can remove this message at any time,by upgrading to a full account.Press any key to execute your code.(phone beeps)(phone ringing)- Hello there,I'd love to hear your wonderful idea.Tell me about it after the beep.(phone beeps)- Yeah, I have an idea tomake my dog lamp light upin Morse code, wheneverI receive a new idea,that gets transcribed.Wouldn't that be great?I should just about any second now,I should get a message with avery strange idea (chuckles)about sending Morse code over a dog lamp.I think I might actuallywrite that, oh, there, got it.It transcribed it exactly right, awesome.We got it deployed, and nowwe can shut our computers off.Now, you might have noticedthat this was deployed to dev.I know that we talked about that,you can also deploy to dev or staging,and then you can deploy to production.That way you can developas a team in one place,if you needed to.There's more on that in the notes,if you're interested in it,but they're just different environments.Just keep that in mind,you can have differentenvironments hosted up there.With that, we did it.That is awesome.Did you see how the webhookskills that you've picked upare fairly universal?It's pretty neat, right?I hope you're feelingconfident in your ability.First, we were able to providea handler for the lifecyclehook of an incoming text messageto our number.We did this with a static TwiML Bit,but remember, this is a webhook.As long as we returned validTwiML, we could do anything.We didn't end up using thebody of the text message,that was sent to us, butwe definitely could have.Like for instance,I could make it so that ifsomeone texted my number,a color, it could changethe dog color light.Like for instance, if I type blue.There we go, it respondsto the incoming message.I deployed that, it's asimple, serverless function.It's in the notes,and it responds to anincoming text message.We also used a no-code solutionto answer an incomingcall and record a message.What the tool did for us was to deployand return the necessary TwiML codeto render the application.As more and more ofthese no-code solutionsstart popping up,look for how they'remaking use of webhooks.You can impress your friendslike, you can be like,well, actually that's just a webhook.Actually, never say that.Never say, well, actually,it's not a good look.We saw how the debugging tools,like Beeceptor and ngrok,work to capture what wasposted from the webhook.The replay feature saves a ton of time.I'm glad that you've gotthat in your tool belt.We also got to use anotherserverless function.Those things are awesome.Little snippets of code thatyou don't need to manage.They're elastic, meaning they scale upand down automatically,and almost all of the serverless providersgive a very generous free tier.Until your application getsvery popular, which it will,you don't need to pay anything at all.These are great forlittle one-off scripts,like webhook handlers.You did it, made it tothe end of this course.Nice work, I hope you enjoyed yourself.I know I did.I hope you now have a ton of ideas,that you can't wait toimplement with webhooks.Remember if you run out of ideas,go explore some no-code automation sites,like IFTTT or Zapier.There are tons of great ideas there.I can't wait to see what you build.Make sure to let me know about it.I've spun up a number,that's similar to what we built together.I'll use it to capture yourfeedback on this course.I use the transcription webhook,to add your feedback toa Google spreadsheet.I hope that you're proudof your new skills.Ooh, that reminds me.- Send him in.(intense music)- I have something prettyimportant to talk with you about,something serious, the powerthat you wield is needed.Now, more than ever,we are living in some dark, dark times.Most of our time is spentonline in virtual worlds.Worlds that are governedby the laws of code.Somebody writes that code,you're gonna write that code.You know, a kid's uncleonce famously said,\"with great power, comesgreat responsibility.\"I guess that's justreally a roundabout wayof me asking you, isthe code that you write,gonna be used for good or not?It's your choice, really.I'm asking you to take a vow.I want you to writecode that unlocks hope,power, and freedom for all of humanity.I'm asking you to become an operator.I want you to join our quest.I need your help to,line?- Save the cloud.- Of course, we need your helpto save the cloud.Thank you, thank you very much.- Thank you.- When should I?- Oh, oh, no need tocall us, we'll call you.- Oh, right, right.I'm still waiting forthem to call me back.They got tired of me calling and calling,to see if I landed it.Those Hollywood folks shouldstick to their principles.I hope I get it, 'cause Ilove that TwilioQuest game.Have you played it yet?It's super addicting.It has awesome content forthose just getting started,and those who have beenthere for a long time.It has a built-in devenvironment, fun side quests,like contributing to open source.It covers JavaScript, PHP, and Python.There are new updates all of the time,and OMG, the original soundtrack,also, I've got a seriousrobo-crush on Cedric,he's super adorable.I can't recommend it enough.Finally, if you enjoyed this course,please let others know about it.I'm sure they'll thankyou for hooking them up.Thanks for hanging out andwe'll see you real soon.(upbeat electronic music)\n"