DEV Community

mehmet akar
mehmet akar

Posted on

Using LocalTunnel with Upstash QStash: E-commerce Use Case

With Localtunnel, sharing a web service on your local development workstation is simple and doesn't require tinkering with firewall and DNS settings. On the other hand, Upstash QStash offers a unique way to handle serverless messaging for distributed applications. Often, developers want to expose their local environments for testing webhooks or integrating with external services—a scenario where a localtunnel service comes in handy. I will explore how to use Upstash QStash with a localtunnel and present a trending real-world use case: building a serverless e-commerce notification system.

Prerequisites

Before we begin, ensure you have the following:

  • An Upstash account with access to QStash.
  • A local development environment with Node.js installed.
  • The localtunnel npm package installed. You can install it using:
  npm install -g localtunnel
Enter fullscreen mode Exit fullscreen mode

Setting Up Local Tunnel

Local Tunnel allows you to expose your local server to the internet securely. Let’s set it up:

  1. Start your local server (e.g., a Node.js/Express app) on a specific port, such as 3000.

  2. Run the following command to expose your local server:

   lt --port 3000
Enter fullscreen mode Exit fullscreen mode

This will provide you with a public URL like https://your-app.loca.lt that tunnels to your local server.

Integrating QStash with Local Tunnel

QStash provides a powerful way to enqueue messages and process them using serverless functions or APIs. Here’s how you can integrate it with your local environment using Local Tunnel:

Step 1: Create a QStash Queue

  1. Log in to your Upstash account and navigate to the QStash dashboard.
  2. Create a new queue for your application.
  3. Note the queue’s endpoint and the API key for authentication.

Step 2: Set Up Your Local API to Handle Webhooks

For example, using Express.js:

const express = require('express');
const bodyParser = require('body-parser');

const app = express();
const PORT = 3000;

app.use(bodyParser.json());

app.post('/webhook', (req, res) => {
  console.log('Webhook received:', req.body);
  res.status(200).send('Webhook processed successfully!');
});

app.listen(PORT, () => {
  console.log(`Server running on http://localhost:${PORT}`);
});
Enter fullscreen mode Exit fullscreen mode

Step 3: Send Messages to QStash

Using the public URL provided by Local Tunnel, you can now send messages to your local API via QStash. Here’s an example using the Upstash QStash SDK:

const { QStashClient } = require('@upstash/qstash');

const qstash = new QStashClient({
  token: 'YOUR_QSTASH_API_KEY',
});

(async () => {
  const response = await qstash.publish({
    destination: 'https://your-app.loca.lt/webhook',
    body: JSON.stringify({ orderId: '12345', status: 'Shipped' }),
  });

  console.log('Message published:', response);
})();
Enter fullscreen mode Exit fullscreen mode

Trending Use Case: E-Commerce Notification System

Imagine you’re building a serverless e-commerce platform where users are notified in real time about their order status. Using QStash with Local Tunnel, you can:

  1. Handle Order Updates: When an order is updated (e.g., payment confirmed, shipped, or delivered), your backend publishes a message to QStash.

  2. Notify Local Development: During development, you can test the notification logic by receiving QStash messages in your local environment via Local Tunnel.

  3. Simulate Delayed Messaging: QStash supports delayed messages. For instance, you can send a follow-up notification to remind the user to review the product after 7 days.

Here’s how this workflow might look:

Step 1: Publishing Order Updates

const orderNotification = async (orderId, status) => {
  await qstash.publish({
    destination: 'https://your-app.loca.lt/webhook',
    body: JSON.stringify({ orderId, status }),
    delay: 0, // Immediate notification
  });
};

orderNotification('12345', 'Shipped');
Enter fullscreen mode Exit fullscreen mode

Step 2: Handling Notifications Locally

Your local API receives and processes the messages:

app.post('/webhook', (req, res) => {
  const { orderId, status } = req.body;
  console.log(`Order ${orderId} is now ${status}`);
  res.status(200).send('Notification received');
});
Enter fullscreen mode Exit fullscreen mode

Step 3: Testing Delayed Messages

Simulate sending a reminder after a delay:

await qstash.publish({
  destination: 'https://your-app.loca.lt/webhook',
  body: JSON.stringify({ orderId: '12345', message: 'Please review your purchase!' }),
  delay: 604800, // Delay in seconds (7 days)
});
Enter fullscreen mode Exit fullscreen mode

Benefits of QStash with Local Tunnel

  • Serverless and Scalable: No need to maintain a queue server or polling mechanism.
  • Easy Development and Debugging: Test webhooks locally with Local Tunnel before deploying to production.
  • Built-in Delays and Scheduling: Schedule notifications effortlessly with QStash’s built-in delay support.
  • Secure Integration: Use QStash’s authentication and validation to ensure secure communication.

To Sum Up: LocalTunnel Ecommerce Use Case

Using Upstash QStash with Local Tunnel simplifies the process of testing and integrating serverless messaging into your applications. Whether you’re testing an e-commerce notification system or any event-driven architecture, this combination empowers you to move faster in testing.

You can ask anything you want or give a feedback! Thanks...

Speedy emails, satisfied customers

Postmark Image

Are delayed transactional emails costing you user satisfaction? Postmark delivers your emails almost instantly, keeping your customers happy and connected.

Sign up

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Explore a sea of insights with this enlightening post, highly esteemed within the nurturing DEV Community. Coders of all stripes are invited to participate and contribute to our shared knowledge.

Expressing gratitude with a simple "thank you" can make a big impact. Leave your thanks in the comments!

On DEV, exchanging ideas smooths our way and strengthens our community bonds. Found this useful? A quick note of thanks to the author can mean a lot.

Okay