ZKTeco Biometric Attendance | ZKteco Biometric Attendance Integration | ZKTeco | ADMS Push Attendance Integration | ZKTeco Attendance Integration | ZKTeco ADMS Integration
by Waqas Mustafa https://www.linkedin.com/in/waqas-mustafa-ba5701209/$ 39.83
| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Attendances (hr_attendance)
• Discuss (mail) • Employees (hr) |
| Lines of code | 1943 |
| Technical Name |
odoo_zkteco_biometric_attendance |
| License | LGPL-3 |
| Website | https://www.linkedin.com/in/waqas-mustafa-ba5701209/ |
| Versions | 18.0 19.0 |
| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Attendances (hr_attendance)
• Discuss (mail) • Employees (hr) |
| Lines of code | 1943 |
| Technical Name |
odoo_zkteco_biometric_attendance |
| License | LGPL-3 |
| Website | https://www.linkedin.com/in/waqas-mustafa-ba5701209/ |
| Versions | 18.0 19.0 |
-
Community
-
Enterprise
ZKTeco Biometric Attendance Integration for Odoo
Real-time attendance sync via Direct IP/LAN or ADMS Cloud Push
Connect your ZKTeco biometric terminals directly to Odoo. Attendance punches are automatically converted into Odoo HR Attendance check-in and check-out records no manual data entry required.
Supports both Direct IP / LAN (Odoo pulls from device) and ADMS / Cloud Push (device pushes to Odoo in real-time). Works with fingerprint, face, card, and PIN verification methods.
Odoo connects directly to device via TCP/IP using pyzk library
Device pushes punches to Odoo in real-time works over internet, no polling
Auto and manual mapping of device users to Odoo employees
Punches automatically create or close HR Attendance records
Unique key per punch prevents duplicate attendance records
Connected devices, today's attendance, unmapped logs, missing checkouts
- Go to Settings → Users & Companies → Users
- Open the user you want to give access to
- Scroll down to the Extra Rights section
- Enable one of the following:
- Biometric Attendance User can view dashboard and attendance logs
- Biometric Attendance Administrator full access (devices, mapping, settings)
- Click Save the user will now see the Biometric Attendance menu
pyzk installation required.
- Server Mode: ADMS
- Enable Domain Name: Off (use IP directly)
- Server Address: Your Odoo server IP
- Server Port: 8069 (Odoo default port)
Note down the Serial Number (e.g. FQQ2252400516).
- Connection Mode: ADMS / Cloud Push
- Serial Number: Paste the serial number from Step 2
- Timezone: Select your local timezone (e.g. Asia/Karachi)
pip install pyzk
- Connection Mode: Direct IP / LAN
- Device IP: IP address of your ZKTeco device
- Port: 4370 (default)
- Timezone: Select your local timezone
Auto-detected from device punch data â no manual configuration required.
- Make sure
pyzkis installed on the Odoo server - Confirm device IP is correct and reachable from the server
- Device and server must be on the same network or configure port forwarding (port 4370) on the router
- Check that no firewall is blocking port 4370
- Verify Server Address and Port (8069) on the device
- Make sure Enable Domain Name is OFF when using IP
- Serial number in Odoo must exactly match the device's serial number
- Odoo server must be publicly accessible localhost will not work
- Try restarting the device after saving settings
- Set the correct Timezone on the device record in Odoo (e.g. Asia/Karachi)
- The module converts device local time to UTC automatically using this setting
- Go to Employee Mapping and map the device user to an Odoo employee
- Unmapped logs are stored and will be processed automatically once mapped
-
18.0.2.0.1 2026-06-22
- ADMS real-time push mode â full support for ZKTeco Push Protocol 3.x
- Fixed device re-registration loop in ADMS mode
- Timezone-aware punch time conversion for correct local time display
- Verified code mapped to Fingerprint / Face / Card / PIN method field
- getrequest heartbeat and command delivery working correctly
-
18.0.1.0.0 2025-12-05
- Initial release â Direct IP / LAN mode with pyzk
- Employee mapping, duplicate protection, cron-based auto sync
- Live dashboard with connected devices and attendance stats
Please log in to comment on this module