#internet #query #document #trigger #standard #content #monitoring

bin+lib ieql

An open standard and implementation for monitoring Internet content

16 releases

Uses old Rust 2015

0.3.0 Feb 13, 2020
0.2.8 Jan 6, 2020
0.2.7 Jun 14, 2019
0.2.6 Jan 29, 2019
0.1.2 Dec 28, 2018

#2281 in Command line utilities

42 downloads per month

GPL-3.0 license

115KB
1.5K SLoC

An open standard for monitoring Internet content


This repository contains the specification and reference implementation for IEQL (Internet Extensible Query Language, pronounced equal). IEQL is an open standard for monitoring and querying Internet content designed to be fast, efficient, and scalable.

What are queries made of?

IEQL queries have two parts: the triggers and the threshold.

Triggers are individual queries, typically RegEx patterns. Triggers can be configured to match only on certain elements of Internet documents (such as body text or HTTP headers), and also to match on Internet documents at a certain location (for example, every document from domain nytimes.com).

The threshold are the compositions of triggers that are required in order for the query to match. For example, an IEQL might have three different triggers: Trigger A, Trigger B, and Trigger C. An IEQL query could be defined such that a match is defined as any time Trigger A fires and either Trigger B or Trigger C fires. Alternatively, the IEQL query's match threshold could be any two triggers. These trigger compositions are an important part of what makes IEQL powerful.

Why are IEQL queries awesome?

IEQL queries provide three main features:

  • Speed — IEQL queries can be compiled so that they can scan millions of documents per second. They are blazing fast.
  • Grouping — You can combine thousands of IEQL queries together and scan using all of them at the same time without serious performance trade-offs.
  • Openness — IEQL is an open standard, which means that you can implement it however you'd like.
  • Extensibility — Because IEQL is built on top of RON, it's extensible—and yet also backwards-compatible.

How can I use IEQL myself?

To get started with IEQL, either use the reference Rust implementation or create your own based off of the open specification.

Licensing

This document is licensed CC-BY-SA, © R. Miles McCain 2018. The Rust reference implementation is licensed according to the LICENSE file.

Dependencies

~7–17MB
~228K SLoC