npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

sso_otp_sumut

v1.0.4

Published

SSO BPS SUMUT menggunakan middleware dalam penggunaanya. pengguna cukup memasang function middleware untuk mengaktifkan SSOnya

Readme

SSO OTP Sumut - Aplikasi Otentikasi SSO

Aplikasi otentikasi untuk SSO (Single Sign-On) yang digunakan oleh BPS Provinsi Sumatera Utara. Proyek ini mengintegrasikan otentikasi berbasis JWT yang menggunakan enkripsi AES-256 dan token aplikasi untuk memastikan otentikasi yang aman dan valid.

Prasyarat

Pastikan kamu sudah menginstal dan menyiapkan software berikut:

  • Node.js (versi LTS)
  • npm
  • dotenv - Untuk memuat variabel lingkungan dari file .env
  • cookie-parser - Untuk memanipulasi dan membaca cookies
  • jsonwebtoken - Untuk membuat dan memverifikasi token JWT
  • crypto - Untuk enkripsi dan dekripsi menggunakan AES-256-CBC

Instalasi

Langkah-langkah untuk menyiapkan dan menjalankan proyek secara lokal.

1. Clone repository

Clone repository proyek ini ke lokal dengan perintah berikut:

git clone <repository-url>

2. Masuk ke direktori proyek

Masuk ke dalam direktori proyek yang sudah di-clone:

cd <nama-direktori>

3. Instal dependensi

Instal semua dependensi yang dibutuhkan menggunakan npm:

npm install

4. Buat file .env

Buat file .env di direktori root proyek. Salin dan sesuaikan konfigurasi berikut:

SECRET_KEY=your_secret_key_here
APP_TOKEN=your_app_token_here
ENCRYPTION_KEY=your_32_bytes_encryption_key_here
LINK_SSO=your_sso_login_link_here

Penjelasan variabel .env:

SECRET_KEY: Kunci rahasia untuk menandatangani dan memverifikasi JWT. APP_TOKEN: Token aplikasi yang digunakan untuk memverifikasi aplikasi pada sistem. ENCRYPTION_KEY: Kunci enkripsi 32 byte untuk mendekripsi data. LINK_SSO: URL untuk halaman login SSO yang digunakan untuk otentikasi pengguna.

Struktur Proyek

Berikut adalah struktur proyek secara keseluruhan:

  • /node_modules/sso_otp_sumut/index.js: Dependensi proyek yang diinstal melalui npm dan Middleware otentikasi dan token
  • /.env: File konfigurasi lingkungan
  • /package.json: Konfigurasi npm untuk proyek
  • /index.js: Entry point utama aplikasi

Penggunaan

1. Akses Dashboard

Setelah aplikasi berjalan, kamu dapat mengakses halaman dashboard dengan membuka http://localhost:4000/dashboard. Untuk mengakses halaman ini, kamu harus login terlebih dahulu melalui sistem SSO.

Jika token JWT tidak ada atau tidak valid, pengguna akan diarahkan ke halaman login SSO yang ditentukan dalam variabel LINK_SSO.contoh aplikasi penggunaan di bawah ini:

const port = 4000; // Port untuk App1
const express = require("express");
const cookieParser = require("cookie-parser");
const sso = require("sso_otp_sumut"); // Mengimpor modul SSO

const app = express(); // Inisialisasi aplikasi Express
app.use(cookieParser()); // Middleware untuk membaca cookie

// Rute dengan middleware autentikasi
app.get("/dashboard", sso.authenticateJWT, (req, res) => {
  res.send(`
    <h1>Dashboard App 1</h1>
    <p>Halo, ${req.user.nama}!</p>
    <p>Username: ${req.user.username}</p>
    <p>NIP: ${req.user.nip}</p>
    <p>Kode Satker: ${req.user.kode_satker}</p>
    <p>NoHp: ${req.user.nohp}</p>
    <p>Foto: <img src="${req.user.foto}" alt="Foto User" style="width: 100px; height: 100px;"></p>
    <a href="/logout">Logout</a>
  `);
});

// Rute logout
app.get("/logout", (req, res) => {
  res.clearCookie("jwt", {
    httpOnly: true,
    secure: process.env.NODE_ENV === "production", // Gunakan secure hanya di production
    sameSite: "None",
    domain: "bps.web.id",
  });
  res.redirect("/"); // Redirect ke halaman utama
});

// Menjalankan server
app.listen(port, () => {
  console.log(`App 1 berjalan di http://localhost:${port}`);
});

2. Logout

Untuk logout, akses halaman /logout yang akan menghapus cookie JWT dan mengarahkan pengguna kembali ke halaman utama atau halaman login.

// Route logout
app.get("/logout", (req, res) => {
  res.clearCookie("jwt", {
    httpOnly: true,
    secure: true, // Gunakan HTTPS
    sameSite: "None", // Sesuaikan dengan kebijakan browser
    domain: "bps.web.id", // Sesuaikan dengan domain aplikasi
  });
  res.redirect("/"); // Redirect ke halaman utama setelah logout
});

3. Middleware authenticateJWT

Middleware authenticateJWT digunakan untuk memverifikasi JWT yang diterima melalui cookie. Berikut adalah cara menggunakannya di aplikasi Express:

const sso = require("sso_otp_sumut"); // Mengimpor middleware

// Rute untuk halaman dashboard
app.get("/dashboard", sso.authenticateJWT, (req, res) => {
  res.send(`
    <h1>Dashboard App 1</h1>
    <p>Halo, ${req.user.nama}!</p>
    <p>Username: ${req.user.username}</p>
    <p>NIP: ${req.user.nip}</p>
    <p>Kode Satker: ${req.user.kode_satker}</p>
    <p>NoHp: ${req.user.nohp}</p>
    <p>Foto: <img src="${req.user.foto}" alt="Foto User" style="width: 100px; height: 100px;"></p>
    <a href="/logout">Logout</a>
  `);
});

4. Menggunakan Middleware dalam Aplikasi

Untuk menggunakan middleware authenticateJWT pada aplikasi Express, pastikan kamu sudah mengimport dan memanggilnya sesuai kebutuhan.

// Import middleware dari modul 'sso_otp_sumut'
const sso = require("sso_otp_sumut"); // Sesuaikan dengan path yang benar jika diperlukan

const express = require("express");
const app = express();
const port = 4000;

// Middleware untuk otentikasi
app.get("/dashboard", sso.authenticateJWT, (req, res) => {
  res.send(`
    <h1>Welcome to the Dashboard</h1>
    <p>Nama: ${req.user.nama}</p>
    <p>Username: ${req.user.username}</p>
    <p>Foto: <img src="${req.user.foto}" alt="Foto User" style="width: 100px; height: 100px;"></p>
  `);
});

// Rute untuk logout
app.get("/logout", (req, res) => {
  res.clearCookie("jwt", {
    httpOnly: true,
    secure: true,
    sameSite: "None",
    domain: "bps.web.id",
  });
  res.redirect("/"); // Redirect ke halaman utama setelah logout
});

app.listen(port, () => {
  console.log(`App berjalan di http://localhost:${port}`);
});

Troubleshooting

1. Error Cookie Tidak Tersimpan

Pastikan bahwa server menggunakan HTTPS dan cookie memiliki opsi secure: true agar dapat disimpan di browser.

2. Token Tidak Valid

Pastikan token yang diterima benar dan sesuai dengan format yang diharapkan. Token yang dienkripsi harus didekripsi terlebih dahulu sebelum diverifikasi.

3. Browser Cache

Jika ada perubahan pada cookie atau token, pastikan untuk membersihkan cache browser untuk memastikan data yang terbaru digunakan.

Kontribusi

Jika kamu ingin berkontribusi pada proyek ini, silakan fork repository ini dan kirimkan pull request. Pastikan untuk melakukan pengujian yang memadai sebelum mengirimkan kontribusimu.

Lisensi

Proyek ini dilisensikan di bawah MIT License.