Cloudrail - kodowanie

Utwórz nowy plik dla kodu serwera w utworzonym folderze i dodaj następujące elementy, aby zaimportować i skonfigurować Express i CloudRail -

javascript
const express = require("express");
const cloudrail = require("cloudrail-si");
const app = express();
cloudrail.Settings.setKey("[CloudRail license key]");

Teraz kontynuujemy, pisząc funkcję, która utworzy wystąpienie usług, których chcemy używać do logowania społecznościowego -

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;
}

Potrzebujemy sposobu na śledzenie tożsamości użytkowników. Zwykle odbywa się to w bazie danych, ale aby ten samouczek był krótki, użyjemy obiektu, który działa jak plikpseudo-database.

Wszystkie jego dane są przechowywane w pamięci i tym samym są tracone po ponownym uruchomieniu serwera -

javascript
const users = {
   records: {}
};
users.find = (id) ⇒ {
   return users.records[id];
};
users.save = (id, data) ⇒ {
   users.records[id] = data;
};

Następnie rejestrujemy punkt końcowy serwera, który będzie obsługiwał początek przepływu logowania społecznościowego -

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();
});

Usługa, z której uruchomiliśmy logowanie społecznościowe, przekieruje na nasz serwer i musimy obsłużyć to przekierowanie.

Po uzyskaniu unikalnego identyfikatora użytkownika sprawdzamy, czy widzieliśmy go wcześniej. Jeśli tak, to witamy go jego imieniem. Jeśli nie, otrzymujemy nazwę z sieci społecznościowej i zapisujemy nowego użytkownika -

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!");
         });
      }
   });
});

Wreszcie serwer nasłuchuje na porcie 12345 -

javascript
app.listen(12345);

Możemy teraz uruchomić aplikację i przetestować ją w naszej lokalnej przeglądarce.

Jeśli przejdziesz do http://localhost:12345/auth/start/facebook uruchomisz przepływ logowania na Facebooku.

Jeśli przejdziesz do http://localhost:12345/auth/start/twitter rozpoczniesz proces logowania na Twitterze.

Po zalogowaniu się do usługi i przyznaniu dostępu zobaczysz komunikat „Witaj, głupku!” jeśli zrobisz to po raz pierwszy i „Witaj z powrotem [Twoje imię]” przy kolejnych wizytach.

Aby zintegrować go z rzeczywistą witryną internetową, należy na przykład umieścić tam logo usługodawcy i połączyć logo z odpowiednimi adresami URL.

Poza tym pseudo-bazę danych należy zastąpić prawdziwą. I gotowe, logowanie społecznościowe dla maksymalnie 9 różnych dostawców!