DEV Community

Cover image for Real-Time Location Tracking with Node.js and Pulsetracker's Redis Pub/Sub
Walid LAGGOUNE
Walid LAGGOUNE

Posted on

Real-Time Location Tracking with Node.js and Pulsetracker's Redis Pub/Sub

Introduction

Real-time location tracking is at the heart of many modern applications, from delivery services to personal tracking tools. Pulsetracker simplifies this process by offering a dedicated Redis Pub/Sub server that allows developers to subscribe to real-time location updates on the backend. In this guide, we'll demonstrate how to build a Node.js application that listens to these updates and processes location data in real time.


Why Pulsetracker?

Pulsetracker eliminates the complexity of building a backend for real-time location tracking. It provides a scalable infrastructure with privacy-focused options and features like WebSocket dispatching, Redis Pub/Sub integration, and configurable privacy settings.


Why Node.js?

Node.js is a perfect choice for real-time applications due to its non-blocking, event-driven architecture. Using Redis Pub/Sub in Node.js enables you to handle real-time data streams efficiently.


Setting Up the Node.js Environment

Prerequisites:

  • Node.js installed
  • Redis client library (ioredis) installed
  • Pulsetracker account and API credentials

Step 1: Install Dependencies

Run the following command to install the necessary Redis library:

npm install ioredis
Enter fullscreen mode Exit fullscreen mode

Step 2: Configure Your Application

Create a .env file and add your Pulsetracker Redis configuration:
(Get your APP_KEY and TOKEN from pulsestracker dashboard)

PULSETRACKER_REDIS_URL=redis://redis-sub.pulsestracker.com:6378
APP_KEY=YOUR_APP_KEY
TOKEN=YOUR_TOKEN
Enter fullscreen mode Exit fullscreen mode

Step 3: Write the Node.js Subscriber

Here’s an example Node.js script to listen for location updates:

const Redis = require("ioredis");
require("dotenv").config();

// Configuration
const redisUrl = process.env.PULSETRACKER_REDIS_URL;
const appKey = process.env.APP_KEY;
const token = process.env.TOKEN;

// Generate the signature
function generateSignature(appKey, token) {
  const crypto = require("crypto");
  const [prefix, secret] = token.split("|");
  if (!secret) throw new Error("Invalid token format");

  const innerHash = crypto.createHash("sha256").update(secret).digest("hex");
  return crypto.createHmac("sha256", innerHash).update(appKey).digest("hex");
}

const signature = generateSignature(appKey, token);
const channel = `app:${appKey}.${signature}`;

// Connect to Redis
const redis = new Redis(redisUrl);

console.log(`Subscribing to channel: ${channel}`);
redis.subscribe(channel, (err, count) => {
  if (err) {
    console.error("Failed to subscribe:", err);
    process.exit(1);
  }
  console.log(`Successfully subscribed. Waiting for messages...`);
});

// Listen for messages
redis.on("message", (channel, message) => {
  console.log(`Received message ${message}`);
});
Enter fullscreen mode Exit fullscreen mode

How It Works

  1. Environment Configuration: Redis connection URL and credentials are stored securely in the .env file.
  2. Signature Generation: The app generates a secure channel signature using HMAC to subscribe to the correct channel.
  3. Redis Subscription: The application listens for real-time location updates published to the Redis channel.

Running the Application

  1. Save the script as subscriber.js.
  2. Run the script using:
node subscriber.js
Enter fullscreen mode Exit fullscreen mode
  1. Your application will log real-time location updates received from Pulsetracker.

Example LOG :

{"point":{"type":"Point","coordinates":[-0.070906,51.509816]},"appId":"a9b8dffd-e68c-4bff-95cd-21fbcb86fcfb","clientId":"3faffcfa-d486-4e38-9598-e27ff129b6e9","extraData":{"speed":100}}

Enter fullscreen mode Exit fullscreen mode

Conclusion

Pulsetracker's Redis Pub/Sub integration makes it simple to build robust real-time location tracking applications. With Node.js, you can process these updates in real-time, enabling seamless backend operations for your apps.

Explore Pulsetracker's documentation to learn more about its features and start building scalable tracking solutions today!

Top comments (0)