summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.gitignore1
-rw-r--r--python-line-protocol-parser.spec413
-rw-r--r--sources1
3 files changed, 415 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..ed5caa9 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1 @@
+/line-protocol-parser-1.1.1.tar.gz
diff --git a/python-line-protocol-parser.spec b/python-line-protocol-parser.spec
new file mode 100644
index 0000000..f4ea169
--- /dev/null
+++ b/python-line-protocol-parser.spec
@@ -0,0 +1,413 @@
+%global _empty_manifest_terminate_build 0
+Name: python-line-protocol-parser
+Version: 1.1.1
+Release: 1
+Summary: Parse InfluxDB line protocol string into Python dictionary
+License: MIT
+URL: https://github.com/Penlect/line-protocol-parser
+Source0: https://mirrors.nju.edu.cn/pypi/web/packages/5e/73/19fbf517c14fdc5d808f47e826e8a14e1b8e92ceb073d010fab4de0fe640/line-protocol-parser-1.1.1.tar.gz
+
+
+%description
+Parse InfluxDB `line protocol`_ strings into Python dictionaries.
+Example:
+^^^^^^^^
+ >>> from line_protocol_parser import parse_line
+ >>> data = parse_line('myMeas,someTag=ABC field1=3.14,field2="Hello, World!" 123')
+ >>> print(data)
+ {'measurement': 'myMeas',
+ 'fields': {'field1': 3.14, 'field2': 'Hello, World!'},
+ 'tags': {'someTag': 'ABC'},
+ 'time': 123}
+**The InfluxDB line protocol is a text based format for writing points to InfluxDB.
+This project can read this format and convert line strings to Python dicitonaries.**
+The line protocol has the following format:
+ <measurement>[,<tag_key>=<tag_value>[,<tag_key>=<tag_value>]] <field_key>=<field_value>[,<field_key>=<field_value>] [<timestamp>]
+and is documented here: `InfluxDB line protocol`_.
+The ``line_protocol_parser`` module only contains the ``parse_line`` function and the ``LineFormatError`` exception which is raised on failure.
+Installation
+^^^^^^^^^^^^
+From PyPI:
+ $ python3 -m pip install line-protocol-parser
+or from source (make sure you have ``python3 -m pip install wheel setuptools`` first):
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ python3 setup.py bdist_wheel
+ $ python3 -m pip install ./dist/line-protocol-parser-*.whl
+or from generated Debian package:
+ # Install build dependencies
+ $ sudo apt install python3-all python3-all-dev python3-setuptools dh-python
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ make deb
+ $ sudo apt install ./python3-line-protocol-parser_*.deb
+Use Case 1: Read points from a file
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+Suppose you have a text file with influxDB measurement points, "my_influxDB_points.txt"::
+ myMeasurement,someTag=A temperature=37.0 1570977942581909918
+ myMeasurement,someTag=A temperature=37.3 1570977942581910000
+ myMeasurement,someTag=A temperature=36.9 1570977942581912345
+ myMeasurement,someTag=A temperature=37.1 1570977942581923399
+Then you can load each line into a dicitonary to be printed like this:
+ >>> from line_protocol_parser import parse_line
+ >>> with open('my_influxDB_points.txt', 'r') as f_obj:
+Use Case 2: InfluxDB subscriptions
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+InfluxDB subscriptions are documented here: `InfluxDB Subscriptions`_.
+InfluxDB subscriptions are local or remote endpoints to which all data written to InfluxDB is copied. Endpoint able to accept UDP, HTTP, or HTTPS connections can subscribe to InfluxDB and receive a copy of all data as it is written.
+In this example we will do the following:
+1) Setup and run a InfluxDB container.
+2) Create a subscription.
+3) Create a Python server and register it as an endpoint.
+4) Use ``line_protocol_parser`` to read and print incoming data.
+**Step 1**. Run the following commands to run a `InfluxDB container`_ and attach to the influx client.
+ $ docker run -d --network="host" --name inf influxdb
+ $ docker exec -it inf influx
+**Step 2**. Create subscription. Run these commands in the influx client prompt.
+ > CREATE DATABASE mydb
+ > USE mydb
+ > CREATE SUBSCRIPTION "mysub" ON "mydb"."autogen" DESTINATIONS ALL 'http://localhost:9090'
+Since we used `--network="host"` we can use localhost from inside the container.
+**Step 3 & 4**. Python server to receive InfluxDB data.
+Create a python file *server.py* with the following content:
+ from pprint import pprint
+ from http.server import HTTPServer, BaseHTTPRequestHandler
+ from line_protocol_parser import parse_line
+ class PostHandler(BaseHTTPRequestHandler):
+ def do_POST(self):
+ content_length = int(self.headers['Content-Length'])
+ post_data = self.rfile.read(content_length)
+ pprint(parse_line(post_data))
+ self.send_response(200)
+ self.end_headers()
+ if __name__ == '__main__':
+ server = HTTPServer(('localhost', 9090), PostHandler)
+ print('Starting server, use <Ctrl-C> to stop')
+ server.serve_forever()
+Start the server:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+Next, go back to your influx client and insert a data point:
+ > INSERT oven,room=kitchen temperature=225.0 1234567890
+Head back to your Python server and watch the output:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+ {'fields': {'temperature': 225.0},
+ 'measurement': 'oven',
+ 'tags': {'room': 'kitchen'},
+ 'time': 1234567890}
+ 172.17.0.2 - - [14/Oct/2019 21:02:57] "POST /write?consistency=&db=mydb&precision=ns&rp=autogen HTTP/1.1" 200 -
+Pure C usage
+^^^^^^^^^^^^
+If you are not interested in the Python wrapper you may find the pure-c files useful:
+* ``include/line_protocol_parser.h``
+* ``src/line_protocol_parser.c``
+Example:
+ int main()
+ {
+ const char *line = "measurement,tag=value field=\"Hello, world!\" 1570283407262541159";
+ struct LP_Point *point;
+ int status = 0;
+ point = LP_parse_line(line, &status);
+ if (point == NULL) {
+ LP_DEBUG_PRINT("ERROR STATUS: %d\n", status);
+ }
+ // < Do something useful with point here >
+ LP_free_point(point);
+ return status;
+ }
+Please see the comments in the source and header file for more information.
+Examples from the Test Cases
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+The test cases are a good source of examples. Please see: `tests/test_parse_line.py <tests/test_parse_line.py>`_.
+Changelog
+^^^^^^^^^
+The changelog is maintained in the debian directory, please check there: `changelog <debian/changelog>`_.
+
+%package -n python3-line-protocol-parser
+Summary: Parse InfluxDB line protocol string into Python dictionary
+Provides: python-line-protocol-parser
+BuildRequires: python3-devel
+BuildRequires: python3-setuptools
+BuildRequires: python3-pip
+BuildRequires: python3-cffi
+BuildRequires: gcc
+BuildRequires: gdb
+%description -n python3-line-protocol-parser
+Parse InfluxDB `line protocol`_ strings into Python dictionaries.
+Example:
+^^^^^^^^
+ >>> from line_protocol_parser import parse_line
+ >>> data = parse_line('myMeas,someTag=ABC field1=3.14,field2="Hello, World!" 123')
+ >>> print(data)
+ {'measurement': 'myMeas',
+ 'fields': {'field1': 3.14, 'field2': 'Hello, World!'},
+ 'tags': {'someTag': 'ABC'},
+ 'time': 123}
+**The InfluxDB line protocol is a text based format for writing points to InfluxDB.
+This project can read this format and convert line strings to Python dicitonaries.**
+The line protocol has the following format:
+ <measurement>[,<tag_key>=<tag_value>[,<tag_key>=<tag_value>]] <field_key>=<field_value>[,<field_key>=<field_value>] [<timestamp>]
+and is documented here: `InfluxDB line protocol`_.
+The ``line_protocol_parser`` module only contains the ``parse_line`` function and the ``LineFormatError`` exception which is raised on failure.
+Installation
+^^^^^^^^^^^^
+From PyPI:
+ $ python3 -m pip install line-protocol-parser
+or from source (make sure you have ``python3 -m pip install wheel setuptools`` first):
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ python3 setup.py bdist_wheel
+ $ python3 -m pip install ./dist/line-protocol-parser-*.whl
+or from generated Debian package:
+ # Install build dependencies
+ $ sudo apt install python3-all python3-all-dev python3-setuptools dh-python
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ make deb
+ $ sudo apt install ./python3-line-protocol-parser_*.deb
+Use Case 1: Read points from a file
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+Suppose you have a text file with influxDB measurement points, "my_influxDB_points.txt"::
+ myMeasurement,someTag=A temperature=37.0 1570977942581909918
+ myMeasurement,someTag=A temperature=37.3 1570977942581910000
+ myMeasurement,someTag=A temperature=36.9 1570977942581912345
+ myMeasurement,someTag=A temperature=37.1 1570977942581923399
+Then you can load each line into a dicitonary to be printed like this:
+ >>> from line_protocol_parser import parse_line
+ >>> with open('my_influxDB_points.txt', 'r') as f_obj:
+Use Case 2: InfluxDB subscriptions
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+InfluxDB subscriptions are documented here: `InfluxDB Subscriptions`_.
+InfluxDB subscriptions are local or remote endpoints to which all data written to InfluxDB is copied. Endpoint able to accept UDP, HTTP, or HTTPS connections can subscribe to InfluxDB and receive a copy of all data as it is written.
+In this example we will do the following:
+1) Setup and run a InfluxDB container.
+2) Create a subscription.
+3) Create a Python server and register it as an endpoint.
+4) Use ``line_protocol_parser`` to read and print incoming data.
+**Step 1**. Run the following commands to run a `InfluxDB container`_ and attach to the influx client.
+ $ docker run -d --network="host" --name inf influxdb
+ $ docker exec -it inf influx
+**Step 2**. Create subscription. Run these commands in the influx client prompt.
+ > CREATE DATABASE mydb
+ > USE mydb
+ > CREATE SUBSCRIPTION "mysub" ON "mydb"."autogen" DESTINATIONS ALL 'http://localhost:9090'
+Since we used `--network="host"` we can use localhost from inside the container.
+**Step 3 & 4**. Python server to receive InfluxDB data.
+Create a python file *server.py* with the following content:
+ from pprint import pprint
+ from http.server import HTTPServer, BaseHTTPRequestHandler
+ from line_protocol_parser import parse_line
+ class PostHandler(BaseHTTPRequestHandler):
+ def do_POST(self):
+ content_length = int(self.headers['Content-Length'])
+ post_data = self.rfile.read(content_length)
+ pprint(parse_line(post_data))
+ self.send_response(200)
+ self.end_headers()
+ if __name__ == '__main__':
+ server = HTTPServer(('localhost', 9090), PostHandler)
+ print('Starting server, use <Ctrl-C> to stop')
+ server.serve_forever()
+Start the server:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+Next, go back to your influx client and insert a data point:
+ > INSERT oven,room=kitchen temperature=225.0 1234567890
+Head back to your Python server and watch the output:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+ {'fields': {'temperature': 225.0},
+ 'measurement': 'oven',
+ 'tags': {'room': 'kitchen'},
+ 'time': 1234567890}
+ 172.17.0.2 - - [14/Oct/2019 21:02:57] "POST /write?consistency=&db=mydb&precision=ns&rp=autogen HTTP/1.1" 200 -
+Pure C usage
+^^^^^^^^^^^^
+If you are not interested in the Python wrapper you may find the pure-c files useful:
+* ``include/line_protocol_parser.h``
+* ``src/line_protocol_parser.c``
+Example:
+ int main()
+ {
+ const char *line = "measurement,tag=value field=\"Hello, world!\" 1570283407262541159";
+ struct LP_Point *point;
+ int status = 0;
+ point = LP_parse_line(line, &status);
+ if (point == NULL) {
+ LP_DEBUG_PRINT("ERROR STATUS: %d\n", status);
+ }
+ // < Do something useful with point here >
+ LP_free_point(point);
+ return status;
+ }
+Please see the comments in the source and header file for more information.
+Examples from the Test Cases
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+The test cases are a good source of examples. Please see: `tests/test_parse_line.py <tests/test_parse_line.py>`_.
+Changelog
+^^^^^^^^^
+The changelog is maintained in the debian directory, please check there: `changelog <debian/changelog>`_.
+
+%package help
+Summary: Development documents and examples for line-protocol-parser
+Provides: python3-line-protocol-parser-doc
+%description help
+Parse InfluxDB `line protocol`_ strings into Python dictionaries.
+Example:
+^^^^^^^^
+ >>> from line_protocol_parser import parse_line
+ >>> data = parse_line('myMeas,someTag=ABC field1=3.14,field2="Hello, World!" 123')
+ >>> print(data)
+ {'measurement': 'myMeas',
+ 'fields': {'field1': 3.14, 'field2': 'Hello, World!'},
+ 'tags': {'someTag': 'ABC'},
+ 'time': 123}
+**The InfluxDB line protocol is a text based format for writing points to InfluxDB.
+This project can read this format and convert line strings to Python dicitonaries.**
+The line protocol has the following format:
+ <measurement>[,<tag_key>=<tag_value>[,<tag_key>=<tag_value>]] <field_key>=<field_value>[,<field_key>=<field_value>] [<timestamp>]
+and is documented here: `InfluxDB line protocol`_.
+The ``line_protocol_parser`` module only contains the ``parse_line`` function and the ``LineFormatError`` exception which is raised on failure.
+Installation
+^^^^^^^^^^^^
+From PyPI:
+ $ python3 -m pip install line-protocol-parser
+or from source (make sure you have ``python3 -m pip install wheel setuptools`` first):
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ python3 setup.py bdist_wheel
+ $ python3 -m pip install ./dist/line-protocol-parser-*.whl
+or from generated Debian package:
+ # Install build dependencies
+ $ sudo apt install python3-all python3-all-dev python3-setuptools dh-python
+ $ git clone https://github.com/Penlect/line-protocol-parser.git
+ $ cd line-protocol-parser
+ $ make deb
+ $ sudo apt install ./python3-line-protocol-parser_*.deb
+Use Case 1: Read points from a file
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+Suppose you have a text file with influxDB measurement points, "my_influxDB_points.txt"::
+ myMeasurement,someTag=A temperature=37.0 1570977942581909918
+ myMeasurement,someTag=A temperature=37.3 1570977942581910000
+ myMeasurement,someTag=A temperature=36.9 1570977942581912345
+ myMeasurement,someTag=A temperature=37.1 1570977942581923399
+Then you can load each line into a dicitonary to be printed like this:
+ >>> from line_protocol_parser import parse_line
+ >>> with open('my_influxDB_points.txt', 'r') as f_obj:
+Use Case 2: InfluxDB subscriptions
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+InfluxDB subscriptions are documented here: `InfluxDB Subscriptions`_.
+InfluxDB subscriptions are local or remote endpoints to which all data written to InfluxDB is copied. Endpoint able to accept UDP, HTTP, or HTTPS connections can subscribe to InfluxDB and receive a copy of all data as it is written.
+In this example we will do the following:
+1) Setup and run a InfluxDB container.
+2) Create a subscription.
+3) Create a Python server and register it as an endpoint.
+4) Use ``line_protocol_parser`` to read and print incoming data.
+**Step 1**. Run the following commands to run a `InfluxDB container`_ and attach to the influx client.
+ $ docker run -d --network="host" --name inf influxdb
+ $ docker exec -it inf influx
+**Step 2**. Create subscription. Run these commands in the influx client prompt.
+ > CREATE DATABASE mydb
+ > USE mydb
+ > CREATE SUBSCRIPTION "mysub" ON "mydb"."autogen" DESTINATIONS ALL 'http://localhost:9090'
+Since we used `--network="host"` we can use localhost from inside the container.
+**Step 3 & 4**. Python server to receive InfluxDB data.
+Create a python file *server.py* with the following content:
+ from pprint import pprint
+ from http.server import HTTPServer, BaseHTTPRequestHandler
+ from line_protocol_parser import parse_line
+ class PostHandler(BaseHTTPRequestHandler):
+ def do_POST(self):
+ content_length = int(self.headers['Content-Length'])
+ post_data = self.rfile.read(content_length)
+ pprint(parse_line(post_data))
+ self.send_response(200)
+ self.end_headers()
+ if __name__ == '__main__':
+ server = HTTPServer(('localhost', 9090), PostHandler)
+ print('Starting server, use <Ctrl-C> to stop')
+ server.serve_forever()
+Start the server:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+Next, go back to your influx client and insert a data point:
+ > INSERT oven,room=kitchen temperature=225.0 1234567890
+Head back to your Python server and watch the output:
+ $ python3 server.py
+ Starting server, use <Ctrl-C> to stop
+ {'fields': {'temperature': 225.0},
+ 'measurement': 'oven',
+ 'tags': {'room': 'kitchen'},
+ 'time': 1234567890}
+ 172.17.0.2 - - [14/Oct/2019 21:02:57] "POST /write?consistency=&db=mydb&precision=ns&rp=autogen HTTP/1.1" 200 -
+Pure C usage
+^^^^^^^^^^^^
+If you are not interested in the Python wrapper you may find the pure-c files useful:
+* ``include/line_protocol_parser.h``
+* ``src/line_protocol_parser.c``
+Example:
+ int main()
+ {
+ const char *line = "measurement,tag=value field=\"Hello, world!\" 1570283407262541159";
+ struct LP_Point *point;
+ int status = 0;
+ point = LP_parse_line(line, &status);
+ if (point == NULL) {
+ LP_DEBUG_PRINT("ERROR STATUS: %d\n", status);
+ }
+ // < Do something useful with point here >
+ LP_free_point(point);
+ return status;
+ }
+Please see the comments in the source and header file for more information.
+Examples from the Test Cases
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+The test cases are a good source of examples. Please see: `tests/test_parse_line.py <tests/test_parse_line.py>`_.
+Changelog
+^^^^^^^^^
+The changelog is maintained in the debian directory, please check there: `changelog <debian/changelog>`_.
+
+%prep
+%autosetup -n line-protocol-parser-1.1.1
+
+%build
+%py3_build
+
+%install
+%py3_install
+install -d -m755 %{buildroot}/%{_pkgdocdir}
+if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi
+if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi
+if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi
+if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi
+pushd %{buildroot}
+if [ -d usr/lib ]; then
+ find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/lib64 ]; then
+ find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/bin ]; then
+ find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/sbin ]; then
+ find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+touch doclist.lst
+if [ -d usr/share/man ]; then
+ find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst
+fi
+popd
+mv %{buildroot}/filelist.lst .
+mv %{buildroot}/doclist.lst .
+
+%files -n python3-line-protocol-parser -f filelist.lst
+%dir %{python3_sitearch}/*
+
+%files help -f doclist.lst
+%{_docdir}/*
+
+%changelog
+* Fri May 05 2023 Python_Bot <Python_Bot@openeuler.org> - 1.1.1-1
+- Package Spec generated
diff --git a/sources b/sources
new file mode 100644
index 0000000..fd3fab4
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+c971db45c6afbca23aea7cee9a755e76 line-protocol-parser-1.1.1.tar.gz