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

zkteco-attendence

v1.0.1

Published

Node.js library for ZKTeco attendance devices (SpeedFace-V5L compatible)

Downloads

9

Readme

zkteco-attendence

A JavaScript library for interacting with ZK Time & Attendance devices.

Overview

This library provides a simple and robust interface for communicating with ZKTeco biometric devices (fingerprint, face, card, and more) over TCP/UDP. It is designed to be compatible with a wide range of ZKTeco models and is based on node-zklib, with additional enhancements for reliability and compatibility.

Note:
This package is a fork and extension of node-zklib.
It was created because I experienced issues fetching attendance logs from ZKTeco SpeedFace-V5L machines using the original package.
The getAttendances function has been rewritten for SpeedFace-V5L compatibility and reliability.


Installation

npm i zkteco-attendence

Usage

Basic Example

const ZKLib = require('zklib-js')

async function test() {
    let zkInstance = new ZKLib('192.168.1.201', 4370, 5200, 5000);
    
    try {
        // Create socket to machine
        await zkInstance.createSocket()
        
        // Get general info
        console.log(await zkInstance.getInfo())
        
        // Get users in machine
        const users = await zkInstance.getUsers()
        console.log(users)
        
        // Get attendance logs (SpeedFace-V5L compatible)
        const logs = await zkInstance.getAttendances()
        console.log(logs)
        
        // Disconnect
        await zkInstance.disconnect()
    } catch (e) {
        console.log(e)
    }
}

test()

Available Functions

  • createSocket(): Establish connection with the device
  • getInfo(): Get general device information
  • getUsers(): Retrieve users from the device
  • setUser(uid, userid, name, password, role = 0, cardno = 0): Create a new user
  • getAttendances(callback): Get all attendance logs (rewritten for SpeedFace-V5L)
  • getRealTimeLogs(callback): Get real-time logs
  • getTime(): Get current time from the device
  • getSerialNumber(): Get device serial number
  • getFirmware(): Get firmware version
  • getPIN(): Get device PIN
  • getFaceOn(): Check if face recognition is enabled
  • getSSR(): Get Self-Service-Recorder status
  • getDeviceVersion(): Get device version
  • getDeviceName(): Get device name
  • getPlatform(): Get platform version
  • getOS(): Get OS version
  • getWorkCode(): Get work code
  • getAttendanceSize(): Get attendance log size
  • clearAttendanceLog(): Clear attendance logs
  • disconnect(): Disconnect from the device

Custom Commands

You can execute custom commands using the executeCmd function:

async function executeCmd(command, data='') {
    return await this.functionWrapper(
        () => this.zklibTcp.executeCmd(command, data),
        () => this.zklibUdp.executeCmd(command, data)
    )
}

// Example: Unlock the door
zkInstance.executeCmd(CMD.CMD_UNLOCK, '')

For more commands, refer to the ZK protocol documentation.


Why This Fork Exists

  • The original node-zklib library works well for many ZKTeco models.
  • SpeedFace-V5L and similar devices have a unique log record structure and firmware quirks.
  • The standard getAttendances function did not reliably return correct attendance logs for SpeedFace-V5L.
  • This library rewrites the attendance log parsing and filtering to ensure you get accurate logs from SpeedFace-V5L (and most ZKTeco face devices).

Credits

This library is based on:


Contributing

Contributions are welcome! Please feel free to submit a Pull Request.


License

MIT License