ebook img

Building APIs with Node.js PDF

152 Pages·2015·3.4 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Building APIs with Node.js

BuildAiPniwgsi tNho de.JS ++ ? 0 • ... • 111.1.1. 111•1•1• • • 111.1.1. 111•1•1• • • � 111•1•1• 111•1•1• CaiRoi bePierroe ira Building APIs with Node.js Caio Ribeiro Pereira © 2016 Caio Ribeiro Pereira Tweet This Book! PleasehelpCaioRibeiroPereirabyspreadingthewordaboutthisbookonTwitter! Thesuggestedtweetforthisbookis: Ijustboughttheebook:BuildingAmazingAPIswithNode.js Thesuggestedhashtagforthisbookis#NodejsAPI. Findoutwhatotherpeoplearesayingaboutthebookbyclickingonthislinktosearchforthis hashtagonTwitter: https://twitter.com/search?q=#NodejsAPI ThanksGodforeverythinghehasdoneinmylifesofar!I’dliketoalsothankmyparentsforallthe love,thestrength,theincentiveandforallthesupporttheyhavegavemesincethebeginningofmy life. Thanks to the NodeBR community. Their feedback helped me to improve this book. Also, thanks to allthereadersoftheblogUndergroundWebDev,afterall,theessenceofthisbookisbasedonmany ofmyposts. Finally,thankyou,dearreaderbypurchasingthisbook. Contents Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i Thecurrentwebapplicationscene . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i Whoisthisbookfor? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i HowshouldIstudyit? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i IntroductiontoNode.js . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 What’sNode.js? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Mainfeatures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 WhydoIneedtolearnNode.js? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Settinguptheenvironment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 Node.jsstandardinstalation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 Node.jsinstalationviaNVM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 ManagingmoduleswithNPM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 WhatdoesNPMdo? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 TopNPMcommands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Understandingpackage.jsonfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 NPMTaskautomation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 BuildinganAPI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 IntroductiontoExpress . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Gettingstartedthepilotproject . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Implementingasimpleandstaticresource . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Arrangingtheloadingofmodules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 WorkingwithSQLdatabases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 IntroductiontoSQLite3andSequelize . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 SettingupSequelize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 Creatingmodels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 CRUDifyAPIresources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Organizingtasksroutes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 ListingtasksviaGET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 CreatingtasksviaPOST . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 CONTENTS FindingataskviaGET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 UpdatingataskviaPUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 DeletingataskviaDELETE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Refactoringsomemiddlewares . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Creatinguser’sendpoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Testingendpoint’saccessusingPostman . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 Authenticatingusers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 IntroductiontoPassport.jsandJWT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 InstallingPassportandJWT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 ImplementingJWTauthentication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 Generatingtokensforauthenticatedusers . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Testingtheapplication-Part1. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 IntroductiontoMocha . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 Settingupthetestenvironment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 Testingtheauthenticationendpoint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 Testingtheapplication-Part2. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Testingtask’sendpoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Testinguser’sendpoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 DocumentingtheAPI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 IntroductiontoApiDoc.js . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 Documentingtokengeneration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 Documentinguser’sresource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 Documentingtask’sresource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 Preparingtheproductionenvironment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 IntroductiontoCORS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 EnablingCORSintheAPI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 Generatinglogs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 Configuringparallelprocessingusingclustermodule . . . . . . . . . . . . . . . . . . . . 102 CompactingrequestsusingGZIPmiddleware . . . . . . . . . . . . . . . . . . . . . . . . 105 InstallingSSLsupporttouseHTTPS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 ArmoringtheAPIwithHelmet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Buildingtheclient-sideapp-Part1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Settinguptheappenvironment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Creatingsigninandsignupviews . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116 Writingsigninandsignupcomponents . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 Buildingtheclient-sideapp-Part2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 Viewsandcomponentsfortask’sCRUD . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 Viewsandcomponentsforloggedusers . . . . . . . . . . . . . . . . . . . . . . . . . . . 134 CONTENTS Creatingthemainmenu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 136 Treatingallscreen’sevents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 138 Preface The current web application scene Currently,weliveinaperiodinwhichthemajorityofusersusedifferenttypesofdevicestoconnect to the internet. The most popular devices are smartphones, tablets and notebooks. Developing systems for different types of devices requires the work of building web services, also known by thenameofAPI(ApplicationProgramInterface). Basically, the APIs are back-end systems that are designed to work only with data in a centralized manner,allowingclient-sideapplicationstobedevelopedseparately,tohaveauniqueinterfacesto the final user. These client-side applications are typically mobile apps, desktop applications or web apps. Since 2010 Node.js increasingly proved to be an excellent platform to solve many problems, especially for building REST APIs. The single-thread architecture that performs non-blocking I/OrunningontopofJavaScript-whichisaverypresentlanguageinallcurrentbrowsers-showed good performance in the processing of many kind of applications. There are some cases of large companies,suchasLinkedInandPayPal,whichsignificantlysavedexpenseswithserversmigrating someoftheirprojectstoNode.js. In addition, another advantage of using the Node.js, which captivated many developers, is the low learning curve. After all, who has worked with web development already have at least a basic understandingoftheJavaScriptlanguage. Who is this book for? This book is targeted for developers who have at least the basic knowledge of JavaScript and, especially, know well about Object Oriented Programming (OOP), a little bit of client-server architectureandthathaveanunderstandingaboutthemaincharacteristicsof RESTAPIs. Tomastertheseconcepts,evenbasicknowledgeofthem,isessentialtofullyunderstandthereading ofthisbook. Something really cool about this book is that all the codes are written using the latest JavaScript’s implementation,theEcmaScript2015(akaECMAScript6orES6). How should I study it? Throughout the reading, many concepts and codes are going to be presented for you to learn in practice all the theoretical part of this book. It will guide you in a didactic way in the development i Preface ii oftwoprojects(anAPIandawebclientapplication),whichintheendbotharegoingtobeintegrated toworkasasingleproject. Warning: It is highly recommended to follow step-by-step these book’s instructions, so in the end youcanconcludetheprojectcorrectly. Introduction to Node.js What’s Node.js? Node.jsis a lowleveland a highlyscalable platform. UsingNode.jsyouwillprogramdirectly with many network and internet protocols or use libraries that have access to OS resources. To program in Node.js you only need to master JavaScript language – that’s right, only JavaScript! And the JavaScript runtime used in this platform is the famous Javascript V8, which is also used in Google Chrome. Main features Single-Thread Asingle-threadarchitectureworkswithonlythemainthreadinstanceforeachinitiatedprocess.If youareusedtoprogramminginmulti-threadarchitecture,likeJavaor.NETtousetheconcurrency processing, unfortunately it won’t be possible with Node.js. However, you can works with parallel processingusingmultipleprocess. Forexample,youcanuseanativelibraryfromNode.jscalledclustersthatallowsyoutoimplement a network of multiple processes. In Node.js you can create N-1 processes to work with parallel processing, while the main process (aka master process) works on balancing the load among the other processes (aka slave process). If your server has multiple cores, applying this technique will optimizetheprocessing’susage. Another way is to use asynchronous programming, which is one of the main resources from JavaScript.TheasynchronousfunctionsonNode.jsworkasNon-blockingI/O,thatis,incaseyour application has to read a huge file it will not block the CPU, allowing your application to continue toprocessothertasksrequestedbyotherusers. Event-Loop Node.js has event-oriented paradigm. It follows the same philosophy of event-oriented on JavaScript client-side, the only difference is the type of event, meaning that there are not events such as mouse’s click, key up from the keyboard or any other events from web browsers. In fact, Node.jsworkswithI/Oevents,forexample:connectfromadatabase,openafileorreaddatafrom astreamingandmanyothers. 1

Description:
Currently, we live in a period in which the majority of users use different types of devices to connect to the internet. The most popular devices are smartphones, tablets and notebooks. Developing systems for different types of devices requires the work of building web services, also known by the na
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.