module.exports = { sendDiscord }; routes/api.js const express = require('express'); const router = express.Router(); const Task = require('../models/Task'); const Profile = require('../models/Profile'); const { snipeTask } = require('../services/sniper'); // Create sniper task router.post('/tasks', async (req, res) => { const task = await Task.create(req.body); res.json(task); });
module.exports = mongoose.model('Profile', ProfileSchema); const TaskSchema = new mongoose.Schema({ name: String, productUrl: String, profileId: { type: mongoose.Schema.Types.ObjectId, ref: 'Profile' }, maxPrice: Number, size: String, quantity: { type: Number, default: 1 }, status: { type: String, enum: ['idle', 'running', 'completed', 'failed'], default: 'idle' }, runs: { type: Number, default: 0 }, lastRun: Date, createdAt: { type: Date, default: Date.now } }); module.exports = mongoose.model('Task', TaskSchema); models/Log.js const LogSchema = new mongoose.Schema({ taskId: { type: mongoose.Schema.Types.ObjectId, ref: 'Task' }, message: String, type: { type: String, enum: ['info', 'success', 'error'] }, timestamp: { type: Date, default: Date.now } }); 4. Core Sniper Service services/sniper.js const puppeteer = require('puppeteer-extra'); const StealthPlugin = require('puppeteer-extra-plugin-stealth'); puppeteer.use(StealthPlugin()); const notifier = require('./notifier'); const Log = require('../models/Log'); const Profile = require('../models/Profile'); async function snipeTask(task) { const profile = await Profile.findById(task.profileId); if (!profile) throw new Error('Profile missing'); Zenohack.com Sniper
// Get profiles router.get('/profiles', async (req, res) => { const profiles = await Profile.find(); res.json(profiles); }); module
const browser = await puppeteer.launch({ headless: true, args: ['--no-sandbox'] }); const page = await browser.newPage(); Go to checkout await page
// 4. Add to cart await page.click('#add-to-cart'); await page.waitForSelector('.cart-notification', { timeout: 3000 }); log('Item added to cart', 'success');
// 5. Go to checkout await page.goto(process.env.ZENOHACK_CHECKOUT_URL, { waitUntil: 'networkidle2' });
// 2. Go to product page await page.goto(task.productUrl, { waitUntil: 'networkidle2' }); await page.waitForSelector('.product-price', { timeout: 5000 }); const priceText = await page.$eval('.product-price', el => el.innerText); const price = parseFloat(priceText.replace(/[^0-9.]/g, '')); if (price > task.maxPrice) { throw new Error(`Price ${price} exceeds max ${task.maxPrice}`); }