pyozk


Namepyozk JSON
Version 0.0.5 PyPI version JSON
download
home_page
SummaryA small example package
upload_time2024-01-25 10:49:44
maintainer
docs_urlNone
author
requires_python>=3.8
license
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # pyzk

[![Build Status](https://travis-ci.org/fananimi/pyzk.svg?branch=master)](https://travis-ci.org/fananimi/pyzk)

`pyzk` is an unofficial library of zksoftware (zkteco family) attendance machine.

# Installation

There is some installation method you can use below:

* pip
```sh
pip install -U pyzk
```

* manual installation (clone and execute)

```sh
python setup.py install
```

* clone and append the path of this project

```python
import sys
import os
sys.path.insert(1,os.path.abspath("./pyzk"))
from zk import ZK, const
```

# Documentation

Complete documentation can be found at [Readthedocs](http://pyzk.readthedocs.io/en/latest/ "pyzk's readthedocs") .

# API Usage

Create the ZK object and you will be ready to call api.

## Basic Usage

The following is an example code block how to use pyzk.

```python
from zk import ZK, const

conn = None
# create ZK instance
zk = ZK('192.168.1.201', port=4370, timeout=5, password=0, force_udp=False, ommit_ping=False)
try:
    # connect to device
    conn = zk.connect()
    # disable device, this method ensures no activity on the device while the process is run
    conn.disable_device()
    # another commands will be here!
    # Example: Get All Users
    users = conn.get_users()
    for user in users:
        privilege = 'User'
        if user.privilege == const.USER_ADMIN:
            privilege = 'Admin'
        print ('+ UID #{}'.format(user.uid))
        print ('  Name       : {}'.format(user.name))
        print ('  Privilege  : {}'.format(privilege))
        print ('  Password   : {}'.format(user.password))
        print ('  Group ID   : {}'.format(user.group_id))
        print ('  User  ID   : {}'.format(user.user_id))

    # Test Voice: Say Thank You
    conn.test_voice()
    # re-enable device after all commands already executed
    conn.enable_device()
except Exception as e:
    print ("Process terminate : {}".format(e))
finally:
    if conn:
        conn.disconnect()
```

## Command List

* Connect/Disconnect

```python
conn = zk.connect()
conn.disconnect()
```

* Disable/Enable Connected Device

```python
# disable (lock) device, to ensure no user activity in device while some process run
conn.disable_device()
# re-enable the connected device and allow user activity in device again
conn.enable_device()
```

* Get and Set Time

```python
from datetime import datetime
# get current machine's time
zktime = conn.get_time()
print zktime
# update new time to machine
newtime = datetime.today()
conn.set_time(newtime)
```


* Get Firmware Version and Extra Information

```python
conn.get_firmware_version()
conn.get_serialnumber()
conn.get_platform()
conn.get_device_name()
conn.get_face_version()
conn.get_fp_version()
conn.get_extend_fmt()
conn.get_user_extend_fmt()
conn.get_face_fun_on()
conn.get_compat_old_firmware()
conn.get_network_params()
conn.get_mac()
conn.get_pin_width()
```

* Get Device Usage Space

```python
conn.read_sizes()
print(conn)
#also:
conn.users
conn.fingers
conn.records
conn.users_cap
conn.fingers_cap
# TODO: add records_cap counter
# conn.records_cap
```

* User Operation

```python
# Create user
conn.set_user(uid=1, name='Fanani M. Ihsan', privilege=const.USER_ADMIN, password='12345678', group_id='', user_id='123', card=0)
# Get all users (will return list of User object)
users = conn.get_users()
# Delete User
conn.delete_user(uid=1)
conn.delete_user(user_id=123)
```

* Fingerprints

```python
# Get  a single Fingerprint (will return a Finger object)
template = conn.get_user_template(uid=1, temp_id=0) #temp_id is the finger to read 0~9
# Get all fingers from DB (will return a list of Finger objects)
fingers = conn.get_templates()

# to restore a finger, we need to assemble with the corresponding user
# pass a User object and a list of finger (max 10) to save
conn.save_user_template(user, [fing1 ,fing2])
```

* Remote Fingerprint Enrollment
```python
zk.enroll_user('1')
# but it doesn't work with some tcp ZK8 devices
```


* Attendance Record
```python
# Get attendances (will return list of Attendance object)
attendances = conn.get_attendance()
sorted_attendances = conn.get_sorted_attendance(by_date=False)  # means sorting by uid
limited_attendances = conn.get_limited_attendance(
    users=[1, 2],  # only UIDs 1, 2
    start=datetime(2022, 1, 10, 12, 42),  # from 2022,1,10 12:42:00
    end=datetime(2022, 1, 11)  # to 2022,1,11
)

# Clear attendances records
conn.clear_attendance()
```

* User history
```python
# Get the history of users records
hist = conn.get_user_history(
    users=[1, 2], start_date=datetime(2022, 1, 10, 12, 42)
)
```

* Test voice

```python
"""
 play test voice:
  0 Thank You
  1 Incorrect Password
  2 Access Denied
  3 Invalid ID
  4 Please try again
  5 Dupicate ID
  6 The clock is flow
  7 The clock is full
  8 Duplicate finger
  9 Duplicated punch
  10 Beep kuko
  11 Beep siren
  12 -
  13 Beep bell
  14 -
  15 -
  16 -
  17 -
  18 Windows(R) opening sound
  19 -
  20 Fingerprint not emolt
  21 Password not emolt
  22 Badges not emolt
  23 Face not emolt
  24 Beep standard
  25 -
  26 -
  27 -
  28 -
  29 -
  30 Invalid user
  31 Invalid time period
  32 Invalid combination
  33 Illegal Access
  34 Disk space full
  35 Duplicate fingerprint
  36 Fingerprint not registered
  37 -
  38 -
  39 -
  40 -
  41 -
  42 -
  43 -
  43 -
  45 -
  46 -
  47 -
  48 -
  49 -
  50 -
  51 Focus eyes on the green box
  52 -
  53 -
  54 -
  55 -
"""
conn.test_voice(index=0) # will say 'Thank You'
```

* Device Maintenance

```python
# DANGER!!! This command will be erase all data in the device (incuded: user, attendance report, and finger database)
conn.clear_data()
# shutdown connected device
conn.poweroff()
# restart connected device
conn.restart()
# clear buffer
conn.free_data()
```

* Live Capture!

```python
# live capture! (timeout at 10s)
for attendance in conn.live_capture():
    if attendance is None:
        # implement here timeout logic
        pass
    else:
        print (attendance) # Attendance object

    #if you need to break gracefully just set
    #   conn.end_live_capture = True
    #
    # On interactive mode,
    # use Ctrl+C to break gracefully
    # this way it restores timeout
    # and disables live capture
```

**Test Machine**

```sh
usage: ./test_machine.py [-h] [-a ADDRESS] [-p PORT] [-T TIMEOUT] [-P PASSWORD]
                         [-f] [-t] [-r] [-u] [-l] [-D DELETEUSER] [-A ADDUSER]
                         [-E ENROLLUSER] [-F FINGER]

ZK Basic Reading Tests

optional arguments:
  -h, --help            show this help message and exit
  -a ADDRESS, --address ADDRESS
                        ZK device Address [192.168.1.201]
  -p PORT, --port PORT  ZK device port [4370]
  -T TIMEOUT, --timeout TIMEOUT
                        Default [10] seconds (0: disable timeout)
  -P PASSWORD, --password PASSWORD
                        Device code/password
  -b, --basic           get Basic Information only. (no bulk read, ie: users)
  -f, --force-udp       Force UDP communication
  -v, --verbose         Print debug information
  -t, --templates       Get templates / fingers (compare bulk and single read)
  -tr, --templates-raw  Get raw templates (dump templates)
  -r, --records         Get attendance records
  -u, --updatetime      Update Date/Time
  -l, --live-capture    Live Event Capture
  -o, --open-door       Open door

  -D DELETEUSER, --deleteuser DELETEUSER
                        Delete a User (uid)
  -A ADDUSER, --adduser ADDUSER
                        Add a User (uid) (and enroll)
  -E ENROLLUSER, --enrolluser ENROLLUSER
                        Enroll a User (uid)
  -F FINGER, --finger FINGER
                        Finger for enroll (fid=0)

```

**Backup/Restore (Users and fingers only!!!)** *(WARNING! destructive test! do it at your own risk!)*

```sh
usage: ./test_backup_restore.py [-h] [-a ADDRESS] [-p PORT] [-T TIMEOUT]
                              [-P PASSWORD] [-f] [-v] [-r]
                              [filename]

ZK Basic Backup/Restore Tool

positional arguments:
  filename              backup filename (default [serialnumber].bak)

optional arguments:
  -h, --help            show this help message and exit
  -a ADDRESS, --address ADDRESS
                        ZK device Address [192.168.1.201]
  -p PORT, --port PORT  ZK device port [4370]
  -T TIMEOUT, --timeout TIMEOUT
                        Default [10] seconds (0: disable timeout)
  -P PASSWORD, --password PASSWORD
                        Device code/password
  -f, --force-udp       Force UDP communication
  -v, --verbose         Print debug information
  -E, --erase           clean the device after writting backup!
  -r, --restore         Restore from backup
  -c, --clear-attendance
                        On Restore, also clears the attendance [default keep
                        attendance]
```

To restore on a different device, make sure to specify the `filename`. on restoring, it asks for the serial number of the destination device (to make sure it was correct, as it deletes all data) WARNING. there is no way to restore attendance data, you can keep it or clear it, but once cleared, there is no way to restore it. 

# Compatible devices

```
Firmware Version : Ver 6.21 Nov 19 2008
Platform : ZEM500
DeviceName : U580

Firmware Version : Ver 6.60 Apr 9 2010
Platform : ZEM510_TFT
DeviceName : T4-C

Firmware Version : Ver 6.60 Dec 1 2010
Platform : ZEM510_TFT
DeviceName : T4-C

Firmware Version : Ver 6.60 Mar 18 2011
Platform : ZEM600_TFT
DeviceName : iClock260

Platform         : ZEM560_TFT
Firmware Version : Ver 6.60 Feb  4 2012
DeviceName       :

Firmware Version : Ver 6.60 Oct 29 2012
Platform : ZEM800_TFT
DeviceName : iFace402/ID

Firmware Version : Ver 6.60 Mar 18 2013
Platform : ZEM560
DeviceName : MA300

Firmware Version : Ver 6.60 Dec 27 2014
Platform : ZEM600_TFT
DeviceName : iFace800/ID

Firmware Version : Ver 6.60 Nov 6 2017 (remote tested with correct results)
Platform : ZMM220_TFT
DeviceName : (unknown device) (broken info but at least the important data was read)

Firmware Version : Ver 6.60 Jun 9 2017
Platform : JZ4725_TFT
DeviceName : K20 (latest checked correctly!)

Firmware Version : Ver 6.60 Aug 23 2014 
Platform : ZEM600_TFT
DeviceName : VF680 (face device only, but we read the user and attendance list!)

Firmware Version : Ver 6.70 Feb 16 2017
Platform : ZLM30_TFT
DeviceName : RSP10k1 (latest checked correctly!)

Firmware Version : Ver 6.60 Jun 16 2015
Platform : JZ4725_TFT
DeviceName : K14 (tested & verified working as expected.)

Firmware Version : Ver 6.60 Jan 13 2016
Platform         : ZMM220_TFT
DeviceName       : iFace702 (without voice function, test with encoding='gbk')
```



### Latest tested (not really confirmed)

```
Firmware Version : Ver 6.60 Jun 16 2015
Platform : JZ4725_TFT
DeviceName : iClock260

Firmware Version : Ver 6.60 Jun 5 2015
Platform : ZMM200_TFT
DeviceName : iClock3000/ID (Active testing! latest fix)

Firmware Version : Ver 6.70 Jul 12 2013
Platform : ZEM600_TFT
DeviceName : iClock880-H/ID (Active testing! latest fix)
```

### Not Working (needs more tests, more information)

```
Firmware Version : Ver 6.4.1 (build 99) (display version 2012-08-31)
Platform : 
DeviceName : iClock260 (no capture data - probably similar problem as the latest TESTED)
```

If you have another version tested and it worked, please inform me to update this list!

# Todo

* Create better documentation
* ~~Finger template downloader & uploader~~
* HTTP Rest api
* ~~Create real time api (if possible)~~
* and much more ...

# Publish
https://packaging.python.org/en/latest/tutorials/packaging-projects/
            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "pyozk",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "",
    "author": "",
    "author_email": "Chinh Nguyen <cnguyencong@owt.swiss>",
    "download_url": "https://files.pythonhosted.org/packages/1c/0f/b36e1ce4b14d7ce7b02fbce4da97dc86d4e9e8f672334befd8c75e99c440/pyozk-0.0.5.tar.gz",
    "platform": null,
    "description": "# pyzk\n\n[![Build Status](https://travis-ci.org/fananimi/pyzk.svg?branch=master)](https://travis-ci.org/fananimi/pyzk)\n\n`pyzk` is an unofficial library of zksoftware (zkteco family) attendance machine.\n\n# Installation\n\nThere is some installation method you can use below:\n\n* pip\n```sh\npip install -U pyzk\n```\n\n* manual installation (clone and execute)\n\n```sh\npython setup.py install\n```\n\n* clone and append the path of this project\n\n```python\nimport sys\nimport os\nsys.path.insert(1,os.path.abspath(\"./pyzk\"))\nfrom zk import ZK, const\n```\n\n# Documentation\n\nComplete documentation can be found at [Readthedocs](http://pyzk.readthedocs.io/en/latest/ \"pyzk's readthedocs\") .\n\n# API Usage\n\nCreate the ZK object and you will be ready to call api.\n\n## Basic Usage\n\nThe following is an example code block how to use pyzk.\n\n```python\nfrom zk import ZK, const\n\nconn = None\n# create ZK instance\nzk = ZK('192.168.1.201', port=4370, timeout=5, password=0, force_udp=False, ommit_ping=False)\ntry:\n    # connect to device\n    conn = zk.connect()\n    # disable device, this method ensures no activity on the device while the process is run\n    conn.disable_device()\n    # another commands will be here!\n    # Example: Get All Users\n    users = conn.get_users()\n    for user in users:\n        privilege = 'User'\n        if user.privilege == const.USER_ADMIN:\n            privilege = 'Admin'\n        print ('+ UID #{}'.format(user.uid))\n        print ('  Name       : {}'.format(user.name))\n        print ('  Privilege  : {}'.format(privilege))\n        print ('  Password   : {}'.format(user.password))\n        print ('  Group ID   : {}'.format(user.group_id))\n        print ('  User  ID   : {}'.format(user.user_id))\n\n    # Test Voice: Say Thank You\n    conn.test_voice()\n    # re-enable device after all commands already executed\n    conn.enable_device()\nexcept Exception as e:\n    print (\"Process terminate : {}\".format(e))\nfinally:\n    if conn:\n        conn.disconnect()\n```\n\n## Command List\n\n* Connect/Disconnect\n\n```python\nconn = zk.connect()\nconn.disconnect()\n```\n\n* Disable/Enable Connected Device\n\n```python\n# disable (lock) device, to ensure no user activity in device while some process run\nconn.disable_device()\n# re-enable the connected device and allow user activity in device again\nconn.enable_device()\n```\n\n* Get and Set Time\n\n```python\nfrom datetime import datetime\n# get current machine's time\nzktime = conn.get_time()\nprint zktime\n# update new time to machine\nnewtime = datetime.today()\nconn.set_time(newtime)\n```\n\n\n* Get Firmware Version and Extra Information\n\n```python\nconn.get_firmware_version()\nconn.get_serialnumber()\nconn.get_platform()\nconn.get_device_name()\nconn.get_face_version()\nconn.get_fp_version()\nconn.get_extend_fmt()\nconn.get_user_extend_fmt()\nconn.get_face_fun_on()\nconn.get_compat_old_firmware()\nconn.get_network_params()\nconn.get_mac()\nconn.get_pin_width()\n```\n\n* Get Device Usage Space\n\n```python\nconn.read_sizes()\nprint(conn)\n#also:\nconn.users\nconn.fingers\nconn.records\nconn.users_cap\nconn.fingers_cap\n# TODO: add records_cap counter\n# conn.records_cap\n```\n\n* User Operation\n\n```python\n# Create user\nconn.set_user(uid=1, name='Fanani M. Ihsan', privilege=const.USER_ADMIN, password='12345678', group_id='', user_id='123', card=0)\n# Get all users (will return list of User object)\nusers = conn.get_users()\n# Delete User\nconn.delete_user(uid=1)\nconn.delete_user(user_id=123)\n```\n\n* Fingerprints\n\n```python\n# Get  a single Fingerprint (will return a Finger object)\ntemplate = conn.get_user_template(uid=1, temp_id=0) #temp_id is the finger to read 0~9\n# Get all fingers from DB (will return a list of Finger objects)\nfingers = conn.get_templates()\n\n# to restore a finger, we need to assemble with the corresponding user\n# pass a User object and a list of finger (max 10) to save\nconn.save_user_template(user, [fing1 ,fing2])\n```\n\n* Remote Fingerprint Enrollment\n```python\nzk.enroll_user('1')\n# but it doesn't work with some tcp ZK8 devices\n```\n\n\n* Attendance Record\n```python\n# Get attendances (will return list of Attendance object)\nattendances = conn.get_attendance()\nsorted_attendances = conn.get_sorted_attendance(by_date=False)  # means sorting by uid\nlimited_attendances = conn.get_limited_attendance(\n    users=[1, 2],  # only UIDs 1, 2\n    start=datetime(2022, 1, 10, 12, 42),  # from 2022,1,10 12:42:00\n    end=datetime(2022, 1, 11)  # to 2022,1,11\n)\n\n# Clear attendances records\nconn.clear_attendance()\n```\n\n* User history\n```python\n# Get the history of users records\nhist = conn.get_user_history(\n    users=[1, 2], start_date=datetime(2022, 1, 10, 12, 42)\n)\n```\n\n* Test voice\n\n```python\n\"\"\"\n play test voice:\n  0 Thank You\n  1 Incorrect Password\n  2 Access Denied\n  3 Invalid ID\n  4 Please try again\n  5 Dupicate ID\n  6 The clock is flow\n  7 The clock is full\n  8 Duplicate finger\n  9 Duplicated punch\n  10 Beep kuko\n  11 Beep siren\n  12 -\n  13 Beep bell\n  14 -\n  15 -\n  16 -\n  17 -\n  18 Windows(R) opening sound\n  19 -\n  20 Fingerprint not emolt\n  21 Password not emolt\n  22 Badges not emolt\n  23 Face not emolt\n  24 Beep standard\n  25 -\n  26 -\n  27 -\n  28 -\n  29 -\n  30 Invalid user\n  31 Invalid time period\n  32 Invalid combination\n  33 Illegal Access\n  34 Disk space full\n  35 Duplicate fingerprint\n  36 Fingerprint not registered\n  37 -\n  38 -\n  39 -\n  40 -\n  41 -\n  42 -\n  43 -\n  43 -\n  45 -\n  46 -\n  47 -\n  48 -\n  49 -\n  50 -\n  51 Focus eyes on the green box\n  52 -\n  53 -\n  54 -\n  55 -\n\"\"\"\nconn.test_voice(index=0) # will say 'Thank You'\n```\n\n* Device Maintenance\n\n```python\n# DANGER!!! This command will be erase all data in the device (incuded: user, attendance report, and finger database)\nconn.clear_data()\n# shutdown connected device\nconn.poweroff()\n# restart connected device\nconn.restart()\n# clear buffer\nconn.free_data()\n```\n\n* Live Capture!\n\n```python\n# live capture! (timeout at 10s)\nfor attendance in conn.live_capture():\n    if attendance is None:\n        # implement here timeout logic\n        pass\n    else:\n        print (attendance) # Attendance object\n\n    #if you need to break gracefully just set\n    #   conn.end_live_capture = True\n    #\n    # On interactive mode,\n    # use Ctrl+C to break gracefully\n    # this way it restores timeout\n    # and disables live capture\n```\n\n**Test Machine**\n\n```sh\nusage: ./test_machine.py [-h] [-a ADDRESS] [-p PORT] [-T TIMEOUT] [-P PASSWORD]\n                         [-f] [-t] [-r] [-u] [-l] [-D DELETEUSER] [-A ADDUSER]\n                         [-E ENROLLUSER] [-F FINGER]\n\nZK Basic Reading Tests\n\noptional arguments:\n  -h, --help            show this help message and exit\n  -a ADDRESS, --address ADDRESS\n                        ZK device Address [192.168.1.201]\n  -p PORT, --port PORT  ZK device port [4370]\n  -T TIMEOUT, --timeout TIMEOUT\n                        Default [10] seconds (0: disable timeout)\n  -P PASSWORD, --password PASSWORD\n                        Device code/password\n  -b, --basic           get Basic Information only. (no bulk read, ie: users)\n  -f, --force-udp       Force UDP communication\n  -v, --verbose         Print debug information\n  -t, --templates       Get templates / fingers (compare bulk and single read)\n  -tr, --templates-raw  Get raw templates (dump templates)\n  -r, --records         Get attendance records\n  -u, --updatetime      Update Date/Time\n  -l, --live-capture    Live Event Capture\n  -o, --open-door       Open door\n\n  -D DELETEUSER, --deleteuser DELETEUSER\n                        Delete a User (uid)\n  -A ADDUSER, --adduser ADDUSER\n                        Add a User (uid) (and enroll)\n  -E ENROLLUSER, --enrolluser ENROLLUSER\n                        Enroll a User (uid)\n  -F FINGER, --finger FINGER\n                        Finger for enroll (fid=0)\n\n```\n\n**Backup/Restore (Users and fingers only!!!)** *(WARNING! destructive test! do it at your own risk!)*\n\n```sh\nusage: ./test_backup_restore.py [-h] [-a ADDRESS] [-p PORT] [-T TIMEOUT]\n                              [-P PASSWORD] [-f] [-v] [-r]\n                              [filename]\n\nZK Basic Backup/Restore Tool\n\npositional arguments:\n  filename              backup filename (default [serialnumber].bak)\n\noptional arguments:\n  -h, --help            show this help message and exit\n  -a ADDRESS, --address ADDRESS\n                        ZK device Address [192.168.1.201]\n  -p PORT, --port PORT  ZK device port [4370]\n  -T TIMEOUT, --timeout TIMEOUT\n                        Default [10] seconds (0: disable timeout)\n  -P PASSWORD, --password PASSWORD\n                        Device code/password\n  -f, --force-udp       Force UDP communication\n  -v, --verbose         Print debug information\n  -E, --erase           clean the device after writting backup!\n  -r, --restore         Restore from backup\n  -c, --clear-attendance\n                        On Restore, also clears the attendance [default keep\n                        attendance]\n```\n\nTo restore on a different device, make sure to specify the `filename`. on restoring, it asks for the serial number of the destination device (to make sure it was correct, as it deletes all data) WARNING. there is no way to restore attendance data, you can keep it or clear it, but once cleared, there is no way to restore it. \n\n# Compatible devices\n\n```\nFirmware Version : Ver 6.21 Nov 19 2008\nPlatform : ZEM500\nDeviceName : U580\n\nFirmware Version : Ver 6.60 Apr 9 2010\nPlatform : ZEM510_TFT\nDeviceName : T4-C\n\nFirmware Version : Ver 6.60 Dec 1 2010\nPlatform : ZEM510_TFT\nDeviceName : T4-C\n\nFirmware Version : Ver 6.60 Mar 18 2011\nPlatform : ZEM600_TFT\nDeviceName : iClock260\n\nPlatform         : ZEM560_TFT\nFirmware Version : Ver 6.60 Feb  4 2012\nDeviceName       :\n\nFirmware Version : Ver 6.60 Oct 29 2012\nPlatform : ZEM800_TFT\nDeviceName : iFace402/ID\n\nFirmware Version : Ver 6.60 Mar 18 2013\nPlatform : ZEM560\nDeviceName : MA300\n\nFirmware Version : Ver 6.60 Dec 27 2014\nPlatform : ZEM600_TFT\nDeviceName : iFace800/ID\n\nFirmware Version : Ver 6.60 Nov 6 2017 (remote tested with correct results)\nPlatform : ZMM220_TFT\nDeviceName : (unknown device) (broken info but at least the important data was read)\n\nFirmware Version : Ver 6.60 Jun 9 2017\nPlatform : JZ4725_TFT\nDeviceName : K20 (latest checked correctly!)\n\nFirmware Version : Ver 6.60 Aug 23 2014 \nPlatform : ZEM600_TFT\nDeviceName : VF680 (face device only, but we read the user and attendance list!)\n\nFirmware Version : Ver 6.70 Feb 16 2017\nPlatform : ZLM30_TFT\nDeviceName : RSP10k1 (latest checked correctly!)\n\nFirmware Version : Ver 6.60 Jun 16 2015\nPlatform : JZ4725_TFT\nDeviceName : K14 (tested & verified working as expected.)\n\nFirmware Version : Ver 6.60 Jan 13 2016\nPlatform         : ZMM220_TFT\nDeviceName       : iFace702 (without voice function, test with encoding='gbk')\n```\n\n\n\n### Latest tested (not really confirmed)\n\n```\nFirmware Version : Ver 6.60 Jun 16 2015\nPlatform : JZ4725_TFT\nDeviceName : iClock260\n\nFirmware Version : Ver 6.60 Jun 5 2015\nPlatform : ZMM200_TFT\nDeviceName : iClock3000/ID (Active testing! latest fix)\n\nFirmware Version : Ver 6.70 Jul 12 2013\nPlatform : ZEM600_TFT\nDeviceName : iClock880-H/ID (Active testing! latest fix)\n```\n\n### Not Working (needs more tests, more information)\n\n```\nFirmware Version : Ver 6.4.1 (build 99) (display version 2012-08-31)\nPlatform : \nDeviceName : iClock260 (no capture data - probably similar problem as the latest TESTED)\n```\n\nIf you have another version tested and it worked, please inform me to update this list!\n\n# Todo\n\n* Create better documentation\n* ~~Finger template downloader & uploader~~\n* HTTP Rest api\n* ~~Create real time api (if possible)~~\n* and much more ...\n\n# Publish\nhttps://packaging.python.org/en/latest/tutorials/packaging-projects/",
    "bugtrack_url": null,
    "license": "",
    "summary": "A small example package",
    "version": "0.0.5",
    "project_urls": {
        "Homepage": "https://github.com/cnguyencong/pyozk",
        "Issues": "https://github.com/cnguyencong/pyozk/issues"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b72c9b7c4b15948ffd85cbd119b7e6e5ff41c620d069e56ff5ef2e680459e0b6",
                "md5": "3ef12765e3e002e17425a62a21448ea6",
                "sha256": "c12d52791c11367e73a605103fbf492e1b9d90ea996aa55a70fe910409e72d10"
            },
            "downloads": -1,
            "filename": "pyozk-0.0.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "3ef12765e3e002e17425a62a21448ea6",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 40642,
            "upload_time": "2024-01-25T10:49:40",
            "upload_time_iso_8601": "2024-01-25T10:49:40.996639Z",
            "url": "https://files.pythonhosted.org/packages/b7/2c/9b7c4b15948ffd85cbd119b7e6e5ff41c620d069e56ff5ef2e680459e0b6/pyozk-0.0.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1c0fb36e1ce4b14d7ce7b02fbce4da97dc86d4e9e8f672334befd8c75e99c440",
                "md5": "f9c8e86480e6d01f65187e857c4f14e1",
                "sha256": "5f6e5afc3ef52bb8142fc98ba6bdb61e439058fb798dc9afe6f449273f11cbc9"
            },
            "downloads": -1,
            "filename": "pyozk-0.0.5.tar.gz",
            "has_sig": false,
            "md5_digest": "f9c8e86480e6d01f65187e857c4f14e1",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 379014,
            "upload_time": "2024-01-25T10:49:44",
            "upload_time_iso_8601": "2024-01-25T10:49:44.155484Z",
            "url": "https://files.pythonhosted.org/packages/1c/0f/b36e1ce4b14d7ce7b02fbce4da97dc86d4e9e8f672334befd8c75e99c440/pyozk-0.0.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-01-25 10:49:44",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "cnguyencong",
    "github_project": "pyozk",
    "github_not_found": true,
    "lcname": "pyozk"
}
        
Elapsed time: 0.19282s