<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Zeeson</title>
    <description>The latest articles on DEV Community by Zeeson (@zeeson).</description>
    <link>https://dev.to/zeeson</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F406638%2F57fc55c7-ba36-489c-85c0-1b296839f702.png</url>
      <title>DEV Community: Zeeson</title>
      <link>https://dev.to/zeeson</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/zeeson"/>
    <language>en</language>
    <item>
      <title>The Best New API For People Data and Profiles: KelvinData.com</title>
      <dc:creator>Zeeson</dc:creator>
      <pubDate>Thu, 30 Sep 2021 13:54:51 +0000</pubDate>
      <link>https://dev.to/zeeson/the-best-new-source-for-people-data-and-profiles-kelvindata-com-348b</link>
      <guid>https://dev.to/zeeson/the-best-new-source-for-people-data-and-profiles-kelvindata-com-348b</guid>
      <description>&lt;h2&gt;
  
  
  The Best New Source For People Data and Profiles: KelvinData.com
&lt;/h2&gt;

&lt;h2&gt;
  
  
  Connect with your customers in a matter of seconds
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://hashnode.com/@Zeeson" rel="noopener noreferrer"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://hashnode.com/@Zeeson" rel="noopener noreferrer"&gt;Ibrahim Saliman Zainab&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://zeeson.hashnode.dev/the-best-new-source-for-people-data-and-profiles-kelvindatacom" rel="noopener noreferrer"&gt;Published on Sep 30, 2021&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;9 min read&lt;/p&gt;

&lt;p&gt;Are you considering alternatives to FullContact, Clearbit, ZoomInfo, and other similar people data platforms? &lt;a href="https://www.kelvindata.com/" rel="noopener noreferrer"&gt;KelvinData&lt;/a&gt; got you covered. &lt;/p&gt;

&lt;p&gt;Hi devs, Today I will like to show you a great data API that can save you hours of development time. And that is &lt;a href="https://www.kelvindata.com/" rel="noopener noreferrer"&gt;KelvinData.com&lt;/a&gt;. KelvinData makes millions of people's records available through modern APIs. With  KelvinData, you can search across 1.5 billion people's records in a single line of code.&lt;/p&gt;

&lt;p&gt;Both GraphQL API, and a REST API are available, so it is easy to choose anyone you want for your next project. Do not worry! I will also show you how you can easily get started using KelvinData APIs and how you can integrate the APIs into your application with a code-along example. &lt;/p&gt;

&lt;p&gt;You can take a look at the table of content below to see what we are going to cover in this post.&lt;/p&gt;

&lt;h2&gt;
  
  
  Table of Content
&lt;/h2&gt;

&lt;p&gt;Reasons to choose&lt;/p&gt;

&lt;p&gt;What you can use KelvinData APIs for&lt;/p&gt;

&lt;p&gt;Where can I get a KelvinData API Key&lt;/p&gt;

&lt;p&gt;Kelvin Data API&lt;/p&gt;

&lt;p&gt;Kelvin Data API - NodeJs&lt;/p&gt;

&lt;p&gt;Kelvin Data API - PHP&lt;/p&gt;

&lt;p&gt;KelvinData API - Python&lt;/p&gt;

&lt;p&gt;Example Application&lt;/p&gt;

&lt;p&gt;Pre-requisite - What we need to build this great app&lt;/p&gt;

&lt;p&gt;&lt;a href="//#the-complete-app.js-form"&gt;The complete app.js form&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Reasons to choose &lt;a href="https://www.kelvindata.com/" rel="noopener noreferrer"&gt;Kelvindata&lt;/a&gt;
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;Get nearly anyone's profile&lt;/li&gt;
&lt;li&gt;Organized data at your fingertips&lt;/li&gt;
&lt;li&gt;Powerful and simple platform&lt;/li&gt;
&lt;li&gt;Easy API integration&lt;/li&gt;
&lt;/ol&gt;

&lt;h2&gt;
  
  
  What you can use KelvinData APIs for
&lt;/h2&gt;

&lt;p&gt;There is countless exciting stuff you can do with Kelvindata APIs. It all depends on your use case. KelvinData gives you access to billions of users which can allow making great decisions for your business. some of the stuff you can do with kelvinData include:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;An application that allows users to get full information about a person they want to know more about;&lt;/li&gt;
&lt;li&gt;Looking up Social media profiles for your users when they sign up; Useful for any company that wishes to tailor ads to specific users.&lt;/li&gt;
&lt;li&gt;Building a chrome extension that finds the email of a LinkedIn profile;&lt;/li&gt;
&lt;li&gt;Making a caller ID app;&lt;/li&gt;
&lt;li&gt;Building a personal CRM.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;KelvinData APIs can help you understand your users better and find a way to personalize and tailor the way you approach them and serve them the best they required. &lt;/p&gt;

&lt;h2&gt;
  
  
  Where can I get a KelvinData API Key?
&lt;/h2&gt;

&lt;p&gt;First of all, I will like to take us to the kevindata Dashboard to show us how we can generate our API key. &lt;/p&gt;

&lt;p&gt;Step 1:&lt;/p&gt;

&lt;p&gt;Login in to &lt;a href="https://www.kelvindata.com/dashboard" rel="noopener noreferrer"&gt;kelvindata&lt;/a&gt; by clicking either of the &lt;a href="https://www.kelvindata.com/dashboard" rel="noopener noreferrer"&gt;Get API key&lt;/a&gt;, &lt;a href="https://www.kelvindata.com/dashboard" rel="noopener noreferrer"&gt;Signin&lt;/a&gt;, &lt;a href="https://www.kelvindata.com/dashboard" rel="noopener noreferrer"&gt;Get started&lt;/a&gt; or &lt;a href="https://www.kelvindata.com/dashboard" rel="noopener noreferrer"&gt;Launch&lt;/a&gt; button from the &lt;a href="https://www.kelvindata.com/" rel="noopener noreferrer"&gt; homepage&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632397334779%2F3GkhahOai.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632397334779%2F3GkhahOai.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvin-2-2.png"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Step 2: &lt;/p&gt;

&lt;p&gt;Enter your email address in the &lt;a href="https://www.kelvindata.com/sign-in" rel="noopener noreferrer"&gt;login form&lt;/a&gt; and click continue. You can now check your email for a secure sign-in link. A personalized link has just been sent to your mail. Click the Sign In button or sign in by copying the sent link into your browser address bar. You will be redirected to the dashboard page. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398118258%2FCik2gvbFB.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398118258%2FCik2gvbFB.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvindata-signin.png"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398143555%2FR3SiHnXr-.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398143555%2FR3SiHnXr-.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvindata-checkemail.png"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398530681%2FJW-uabvDL.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632398530681%2FJW-uabvDL.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvin-email-signin.png"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Step 3:&lt;/p&gt;

&lt;p&gt;Congratulations! you are now in the dashboard of Kelvin Data. From here, you can manage your data access, create and manage API keys, search for data on the search page and read the documentation. Also, there is a default API key named Alpha generated for you for testing purposes. You can always create and delete yours as you required. API keys are very important as they are required for every call to the API server; from authentication to getting data. &lt;/p&gt;

&lt;h2&gt;
  
  
  Kelvin Data API
&lt;/h2&gt;

&lt;p&gt;The KelvinData API can be used to find a person's information such as:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Email&lt;/li&gt;
&lt;li&gt;Phone number&lt;/li&gt;
&lt;li&gt;company profile&lt;/li&gt;
&lt;li&gt;Social media profiles&lt;/li&gt;
&lt;li&gt;and so much more&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The right side of the page allows you to select the programming language of your choice. You can drop KelvinData API into any project of any programming language. Once selected, the code snippet containing the code will change to the specific language selected. Then followed the Authentication field where the API key should be inserted. Remember that the API key is needed to make any call. &lt;br&gt;
The left side of the page allows you to see your request history. The MetaData fields below that allow you to insert the detail of the user you want to search. One metadata is enough to search for the whole information about the user. You can use email, phone number, or LinkedIn URL. &lt;br&gt;
As you fill the fields, the code snippet is automatically filled up, after which you can click the &lt;strong&gt;Try It!&lt;/strong&gt; button under the code snippet. The response will display a long object that contains the person's information.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632411729224%2F_WKZhbwxn.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632411729224%2F_WKZhbwxn.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvin-getapi.png"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  Kelvin Data API - NodeJs
&lt;/h2&gt;

&lt;p&gt;install the API SDK:&lt;/p&gt;

&lt;p&gt;npm install api --save&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const sdk = require('api')('@kelvin-data/v1.0#6o3ak2rktrh101h');

sdk.auth('6##################################');
sdk['searchV2_query']({email: 'kelvindata@google.com'})
  .then(res =&amp;amp;gt;console.log(res))
  .catch(err =&amp;amp;gt;console.error(err));
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Kelvin Data API - PHP
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;$curl = curl_init();

curl_setopt_array($curl, [
  CURLOPT_URL =&amp;amp;gt; "https://api.kelvindata.com/rest/v1/search-v2?email=vpaquet@google.com&amp;amp;amp;apiKey=6%23#################################",
  CURLOPT_RETURNTRANSFER =&amp;amp;gt; true,
  CURLOPT_ENCODING =&amp;amp;gt; "",
  CURLOPT_MAXREDIRS =&amp;amp;gt; 10,
  CURLOPT_TIMEOUT =&amp;amp;gt; 30,
  CURLOPT_HTTP_VERSION =&amp;amp;gt; CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST =&amp;amp;gt; "GET",
  CURLOPT_HTTPHEADER =&amp;amp;gt; [
    "Accept: application/json"
  ],
]);

$response = curl_exec($curl);
$err = curl_error($curl);

curl_close($curl);

if ($err) {
  echo "cURL Error #:" . $err;
} else {
  echo $response;
}
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  KelvinData API - Python
&lt;/h2&gt;

&lt;p&gt;install the API SDK:&lt;/p&gt;

&lt;p&gt;python -m pip install requests&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;import requests

url = "https://api.kelvindata.com/rest/v1/search-v2"querystring = {"email":"kelvindata@google.com","apiKey":"6##########################"}

headers = {"Accept": "application/json"}

response = requests.request("GET", url, headers=headers, params=querystring)

print(response.text)
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Taking a closer look at the kelvindata API, the auth required the API keys. While the user parameter consists of a JSON object with key-value pairs with at least one field that has to be included in the metadata. Each field represents data about the person available before the request is made. It can be an email, a phone number, or a Linkedin URL.&lt;/p&gt;

&lt;h2&gt;
  
  
  Example Application
&lt;/h2&gt;

&lt;p&gt;Now let's dive deeper by showing an example of how to use the KelvinData API in the real-world application. Yeah! it is unlikely to use the API as a standalone app or as the main component of any application. It will rather be a key aspect of an application component that makes life easy for you. &lt;br&gt;
However, Let's create a pretty Nodejs application that will allow users to fill in the data of someone they want to know more about. Let's get started!&lt;/p&gt;

&lt;p&gt;In this application, we will create a form and allow users to fill the form with the data of the person they want. Upon submitting the form, it will fetch the whole information about the person. &lt;/p&gt;
&lt;h2&gt;
  
  
  Pre-requisite - What we need to build this great app
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;a href="https://nodejs.org/en/download/" rel="noopener noreferrer"&gt;NodeJs&lt;/a&gt;: Nodejs is JavaScript run time enviroment that allows you to build serverside applications. It is needed to build this application. In case you don't have it installed on your machine, NodeJs can be downloaded via &lt;a href="https://nodejs.org/en/download/" rel="noopener noreferrer"&gt;here&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;NPM: Node Package Manager is loaded together with Nodejs. It is needed to install a few packages we will use.&lt;/li&gt;
&lt;li&gt;
&lt;a href="https://expressjs.com/en/starter/installing.html" rel="noopener noreferrer"&gt;Express&lt;/a&gt; : Express is a popular Nodejs web application framework used for building servers and APIs. It can be downloaded via &lt;a href="https://expressjs.com/en/starter/installing.html" rel="noopener noreferrer"&gt;here&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;EJS: Embedded JavaScript Templates is a templating language that allows to generate HTML markup with plain JavaScrip. &lt;a href="https://ejs.co/" rel="noopener noreferrer"&gt;Check here for more details &lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;Kelvin Data SDK: This is the Software Development Kit that makes life easier for us to easily plug the Kelvindata API into our application.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Let's start by creating a folder named kelvindata-api. the folder will house the files of the pretty application we want to build. feel free to name it anything you like. &lt;/p&gt;
&lt;h2&gt;
  
  
  Initialize npm
&lt;/h2&gt;

&lt;p&gt;Inside the kelvindata-api folder, we need to initialize npm by doing: &lt;/p&gt;

&lt;p&gt;npm init --y&lt;/p&gt;

&lt;p&gt;This creates package.json file for our app. Package.json file is the structure of our application. &lt;br&gt;
On the app name, you can change it to app.js. We then create a file called app.js which will serve as an entry for our application. &lt;/p&gt;
&lt;h2&gt;
  
  
  Installing packages
&lt;/h2&gt;

&lt;p&gt;npm install express ejs api&lt;/p&gt;
&lt;h2&gt;
  
  
  Package.json file
&lt;/h2&gt;


&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt; "name": "kelvindata-api",
  "version": "1.0.0",
  "main": "app.js",
  "author": "Kelvin Data Team",
  "license": "MIT",
  "scripts": {
    "start": "nodemon app.js"
  },
  "dependencies": {
    "api": "^3.4.0",
    "ejs": "^3.1.6",
    "express": "^4.17.1"
  }
}
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;h2&gt;
  
  
  Files
&lt;/h2&gt;

&lt;p&gt;Let's create the remaining files: &lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Create an app.js file in the root directory of the app;&lt;/li&gt;
&lt;li&gt;Create a view folder and index.ejs file inside the folder;&lt;/li&gt;
&lt;li&gt;Create a public folder and create index.css file inside it.&lt;/li&gt;
&lt;/ol&gt;
&lt;h2&gt;
  
  
  File structure
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632510118708%2Fqv136dd0C.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1632510118708%2Fqv136dd0C.png%3Fauto%3Dcompress%2Cformat%26format%3Dwebp" alt="kelvin-filestructure.png"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  App.js file
&lt;/h2&gt;

&lt;p&gt;In the app.js file, we will require our packages including the kelvindata SDK and start our sever.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const express = require("express");const ejs   = require("ejs");const sdk = require('api')('@kelvin-data/v1.0#6o3ak2rktrh101h');const app = express();

app.use(express.json())
app.use(express.urlencoded({ extended: true }));
app.set("view engine", "ejs");
app.use(express.static('public'));const port = 2000app.listen(2000, ()=&amp;amp;gt;{
    console.log("App listening on port 2000")
})
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Let's look at what is in the app.js file closely. &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Express&lt;/strong&gt; is required from which &lt;strong&gt;app&lt;/strong&gt;constant is used to save the express function. With that, we can do a lot of stuff with express.&lt;/li&gt;
&lt;li&gt;we use &lt;strong&gt;json&lt;/strong&gt; to be able to format our result in JSON.&lt;/li&gt;
&lt;li&gt;we use &lt;strong&gt;express.urlencoded&lt;/strong&gt; to parse our form input&lt;/li&gt;
&lt;li&gt;we use &lt;strong&gt;ejs&lt;/strong&gt;as our templating engine&lt;/li&gt;
&lt;li&gt;Server was created listening on &lt;strong&gt;port 2000&lt;/strong&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  GET and POST APIs
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;app.get('/', (req, res) =&amp;amp;gt; {
res.render('index.ejs');
})

app.post('/get-details', (request, response) =&amp;amp;gt; {const userdata = request.body.userdataconsole.log(userdata)
    sdk.auth('your-api-key');
    sdk['searchV2_query']({email: userdata})
  .then(res =&amp;amp;gt; response.json(res))
  .catch(err =&amp;amp;gt;console.error(err));
})
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;In the app.js file, we have gotten 2 APIs, one GET API that displays our entry page (index.ejs) which is also the form page for users to enter the information of the person they wish to get more information about. &lt;br&gt;
the second is the POST API that gets the form detail and sends it to the kelvindata SDK. The SDK will look up the data from kelvindata database and send it back to the user asking for the details. the SDK required your API key. userdata constant will grab the request from the form. &lt;/p&gt;
&lt;h2&gt;
  
  
  The complete app.js form
&lt;/h2&gt;

&lt;p&gt;app.js&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const express = require("express");const ejs   = require("ejs");const sdk = require('api')('@kelvin-data/v1.0#6o3ak2rktrh101h');const app = express();

app.use(express.json())
app.use(express.urlencoded({ extended: true }));
app.set("view engine", "ejs");
app.use(express.static('public'));

app.get('/', (req, res) =&amp;amp;gt; {
res.render('index.ejs');
})

app.post('/get-details', (request, response) =&amp;amp;gt; {const userdata = request.body.userdataconsole.log(userdata)
    sdk.auth('your-api-key');
    sdk['searchV2_query']({email: userdata})
  .then(res =&amp;amp;gt; response.json(res))
  .catch(err =&amp;amp;gt;console.error(err));
})const port = 2000app.listen(2000, ()=&amp;amp;gt;{console.log("App listening on port 2000")
})
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Routes
&lt;/h2&gt;

&lt;p&gt;The index route displays the form, while the details route displays the JSON data of the requested person from kelvin data. When the users enter the email of the person they want to know more about, the form load and display the json data of the person. &lt;/p&gt;

&lt;p&gt;Index.ejs&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;&amp;amp;lt;!DOCTYPE html&amp;amp;gt;&amp;amp;lt;htmllang="en"&amp;amp;gt;&amp;amp;lt;head&amp;amp;gt;&amp;amp;lt;title&amp;amp;gt;Kelvin Data&amp;amp;lt;/title&amp;amp;gt;&amp;amp;lt;linkrel="stylesheet"href="/index.css"&amp;amp;gt;&amp;amp;lt;/head&amp;amp;gt;&amp;amp;lt;body&amp;amp;gt;&amp;amp;lt;divclass="login-container"&amp;amp;gt;&amp;amp;lt;div&amp;amp;gt;&amp;amp;lt;h3&amp;amp;gt; Who do you want to know more about ?&amp;amp;lt;/h3&amp;amp;gt;&amp;amp;lt;formaction="/get-details"method="POST"&amp;amp;gt;&amp;amp;lt;divclass=""&amp;amp;gt;&amp;amp;lt;divclass=""&amp;amp;gt;&amp;amp;lt;labelfor=""&amp;amp;gt;Person's Data&amp;amp;lt;/label&amp;amp;gt;&amp;amp;lt;divclass="user-form"&amp;amp;gt;&amp;amp;lt;inputid="userdata"type="text"name="userdata"required &amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;divclass="btn user-form"&amp;amp;gt;&amp;amp;lt;inputtype="submit"value="CONTINUE"&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/form&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/div&amp;amp;gt;&amp;amp;lt;/body&amp;amp;gt;&amp;amp;lt;/html&amp;amp;gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;We have come to the end of this tutorial. Kelvin Data API is easier and simple to integrate. The SDK also made it really easy to drop into any application. Additionally, the documentation is simple to follow along. The app example is just to show you a bit of what you can do with Kelvin Data API. &lt;br&gt;
Kelvin Data API is really what you need to move your (or your clients') business forward. &lt;/p&gt;

&lt;p&gt;Let me know in the comment section if you have any questions or there is anything you wish to add to the sample tutorial. &lt;/p&gt;

&lt;p&gt;Thank you for your time.&lt;/p&gt;

&lt;p&gt;Please like and share if you enjoy this tutorial. &lt;/p&gt;

&lt;p&gt;You can follow me on &lt;a href="https://twitter.com/salimanibrahimz" rel="noopener noreferrer"&gt;Twitter&lt;/a&gt; as well and lets connect to talk software! &lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
