Skip to content

Latest commit

 

History

History
181 lines (134 loc) · 5.42 KB

README.md

File metadata and controls

181 lines (134 loc) · 5.42 KB

AIS-140

Introduction

This is based on QuecPython.

Currently AIS-140 (2016) is supported.

The purpose of this library is to provide the building blocks to construct a vehicle location tracking and emergency button. The library does not provide a completed solution, as any implementation is specific for its intended use. The documents in this library should be inspected, as these documents provided guidance on how best to build a complete solution.

Note:

To run these examples the dependency usocket is required!

Vehicle Location Tracking and Emergency Button

The demo/ais_client_demo.py is a Vehicle Location Tracking and Emergency Button demo.

from usr.ais import AISClient

# Receive Server Commands Funtion.
def server_cmd(cmd, key, val):
    """This function is for receiving server commands.

    Args:
        cmd(str): SET/GET/CLR.
        key(str): 
            PIP - Primary Server IP
            PPT - Primary Server Port
            SIP - Secondary Server IP
            SPT - Secondary Server Port
            EO  - Emergency OFF
            ED  - Emergency Duration
            APN - Network APN
            SL  - Speed Limit
            VN  - Vehicle Registration Number
            UR  - Update Rate
            URE - Update Rate Emergency
            URH - Update Rate Health Packet
            VID - Vendor ID
            ODM - Set Odometer
        val(str): Value of commmand key.
    """
    print("cmd[%s], key[%s], val[%s]" % (cmd, key, val))


def main():
    # Init AIS Client.
    cfg = {
        "ip": "xxx.xxx.xxx.xxx",
        "port": 9000,
    }
    ais_client = AISClient(**cfg)
    ais_client.set_callback(server_cmd)

    # Connect Server
    res = ais_client.connect()

    # Send Login Packet
    login_kwargs = {...}
    res = ais_client.send_login(**login_kwargs)
    print("ais_client.send_login() %s" % res)

    # Send Health Monitoring Packet
    hbt_kwargs = {...}
    res = ais_client.send_heart_beat(**hbt_kwargs)
    print("ais_client.send_heart_beat() %s" % res)

    # Send Location/Alert Information Packet
    lai_kwargs = {...}
    res = ais_client.send_loction_alert_information(**lai_kwargs)
    print("ais_client.send_loction_alert_information() %s" % res)

    # Send Emergency Packet
    meg_kwargs = {...}
    res = ais_client.send_emergency(**meg_kwargs)
    print("ais_client.send_emergency() %s" % res)

    # Disconnect Server
    res = ais_client.disconnect()
    print("ais_client.disconnect() %s" % res)

Project Files Description

|-- code
    |-- ais.py
    |-- logging.py
|-- demo
    |-- ais_client_demo.py
    |-- ais_server_demo.py
|-- docs
    |-- AIS-140 (2016).pdf
    |-- VT140-Protocol_V1._20200104.pdf
  • code floder is incloud AIS client codes.
    • code/ais.py is incloud all ais client requests interface.
    • code/logging.py is log module.
  • demo floder is incloud AIS client demo and AIS server demo.
    • demo/ais_client_demo.py is an AIS client demo base on QuecPython.
    • demo/ais_server_demo.py is an AIS server demo base on CPython.
  • docs floder is incloud AIS-140 protocal documents.

How To Use

Running AIS-140 Server

If you have your own AIS-140 server, you can skip this instruction.

1. Install environments

  • Operating System: Window or Linux.

  • Language: Python (Python-3.11.2).

2. Config server and running demo

  • Change your server port in demo/ais_server_demo.py.
SERVER_PORT = 31500  # Change this port value for your own server port.
...

if __name__ == '__main__':
    try:
        logging.info("Start Server !")
        socket_serve = TCPServer(('', SERVER_PORT), ReceiveHandler)
        for i in range(THREAD_WORKERS_NUM):
            t = Thread(target=socket_serve.serve_forever)
            t.daemon = True
            t.start()
        socket_serve.serve_forever()
    except KeyboardInterrupt:
        socket_serve.shutdown()
        logging.info("Stop Server !")
  • Running python demo/ais_server_demo.py. When output [INFO] xxxx-xx-xxx xxx xx:xx:xx ais_server_demo.py: Start Server !, the server is started.
>>> python ais_server_demo.py
[INFO] xxxx-xx-xxx xxx xx:xx:xx ais_server_demo.py: Start Server !

Running AIS-140 Client

1. Running environment

You need to use our QuecPython module.

2. Config client and running demo

  • Config your server host and port in demo/ais_client_demo.py
if __name__ == "__main__":
    # Init AIS Client.
    cfg = {
        "ip": "xxx.xxx.xxx.xxx",
        "port": 9000,
    }  #  Use your own server ip and port.
    ais_client = AISClient(**cfg)
    ais_client.set_callback(server_cmd)
  • Download code to QuecPython module

Note:

You can find documents in QuecPython Document Center for how to download python code and running python demo in our QuecPython module

You can download full code floder and demo/ais_client_demo.py to our QuecPython module and run ais_client_demo.py to test AIS-140 Vehicle Location Tracking and Emergency Button.

You can see log ais_client.send_login() True. in our QPYcom REPL, than the Login Packet message is sented to server.

Note:

You can refer to demo/ais_client_demo.py to write client requests that conform to business logic.