क्लाउड्राइल - कोडिंग
बनाए गए फ़ोल्डर में अपने सर्वर कोड के लिए एक नई फ़ाइल बनाएं और आयात और सेटअप में निम्न जोड़ें Express तथा CloudRail -
javascript
const express = require("express");
const cloudrail = require("cloudrail-si");
const app = express();
cloudrail.Settings.setKey("[CloudRail license key]");
अब, हम एक फ़ंक्शन लिखकर जारी रखते हैं जो उन सेवाओं को त्वरित कर देगा जिन्हें हम सामाजिक लॉगिन के लिए उपयोग करना चाहते हैं -
javascript
function makeService(name, redirectReceiver) {
let service;
switch (name) {
case "twitter":
service = new cloudrail.services.Twitter(
redirectReceiver,
"[Twitter Client ID]",
"[Twitter Client Secret]",
"http://localhost:12345/auth/redirect/twitter"
);
break;
case "facebook":
service = new cloudrail.services.Facebook(
redirectReceiver,
"[Facebook Client ID]",
"[Facebook Client Secret]",
"http://localhost:12345/auth/redirect/facebook",
"state"
);
break;
// More services from the Profile interface can be added here,
//the services above are just examples
default: throw new Error("Unrecognized service");
}
return service;
}
हमें उपयोगकर्ता पहचान को ट्रैक रखने का एक तरीका चाहिए। यह आम तौर पर एक डेटाबेस में किया जाता है, लेकिन इस ट्यूटोरियल को छोटा रखने के लिए, हम एक ऑब्जेक्ट का उपयोग करेंगे जो एक के रूप में कार्य करता हैpseudo-database।
इसका सारा डेटा मेमोरी में रखा जाता है और इस प्रकार सर्वर के रीस्टार्ट होने पर खो जाता है -
javascript
const users = {
records: {}
};
users.find = (id) ⇒ {
return users.records[id];
};
users.save = (id, data) ⇒ {
users.records[id] = data;
};
उसके बाद, हम सर्वर एंडपॉइंट को पंजीकृत करते हैं जो सामाजिक लॉगिन प्रवाह की शुरुआत को संभाल लेगा -
javascript
app.get("/auth/start/:serviceName", (req, res) ⇒ {
let serviceName = req.params["serviceName"];
let redirectReceiver = (url, state, callback) ⇒ {
res.redirect(url);
};
let service = makeService(serviceName, redirectReceiver);
service.login();
});
हमने जिस सेवा के साथ सामाजिक लॉगिन शुरू किया है, वह हमारे सर्वर पर रीडायरेक्ट करेगा और हमें इस रीडायरेक्ट को संभालने की आवश्यकता है।
उपयोगकर्ता के लिए एक विशिष्ट पहचानकर्ता प्राप्त करने के बाद, हम जांचते हैं कि क्या हमने इस उपयोगकर्ता को पहले देखा है। यदि हाँ, तो हम उनके नाम के साथ अभिवादन करते हैं। यदि नहीं, तो हमें सोशल नेटवर्क से नाम मिलता है और एक नए उपयोगकर्ता को बचाता है -
javascript
app.get("/auth/redirect/:serviceName", (req, res) ⇒ {
let serviceName = req.params["serviceName"];
let redirectReceiver = (url, state, callback) ⇒ {
callback(undefined, "http://bla.com" + req.url);
// The callback expects a complete URL but only the query matters
};
let service = makeService(serviceName, redirectReceiver);
service.getIdentifier((err, identifier) ⇒ {
if (err) res.status(500).send(err);
let user = users.find(identifier);
if (user) {
res.send("Welcome back " + user.name);
} else {
service.getFullName((err, name) ⇒ {
if (err) res.status(500).send(err);
users.save(identifier, {
name: name
});
res.send("Welcome greenhorn!");
});
}
});
});
अंत में, हमारे पास 12345 पोर्ट पर सर्वर है -
javascript
app.listen(12345);
अब हम एप्लिकेशन को शुरू कर सकते हैं और अपने स्थानीय ब्राउज़र में इसका परीक्षण कर सकते हैं।
अगर आप नेविगेट करते हैं http://localhost:12345/auth/start/facebook आप फेसबुक लॉगिन प्रवाह शुरू करेंगे।
अगर आप नेविगेट करते हैं http://localhost:12345/auth/start/twitter आप ट्विटर लॉगिन प्रवाह शुरू करेंगे।
सेवा में प्रवेश करने और पहुँच प्रदान करने के बाद, आपको "वेलकम ग्रीनहॉर्न!" दिखाई देगा। यदि आप इसे पहली बार करते हैं और लगातार यात्राओं पर "आपका स्वागत है [आपका नाम]"।
उदाहरण के लिए, इसे एक वास्तविक वेबसाइट में एकीकृत करने के लिए, आप सेवा प्रदाता के लोगो को शामिल करेंगे और लोगो को संबंधित URL से लिंक करेंगे।
इसके अलावा, छद्म डेटाबेस को वास्तविक के साथ प्रतिस्थापित किया जाना चाहिए। और आप जाते हैं, 9 विभिन्न प्रदाताओं के लिए सामाजिक लॉगिन!