![CrowdStrike Falcon](https://raw.githubusercontent.com/CrowdStrike/falconpy/main/docs/asset/cs-logo.png) [![Twitter URL](https://img.shields.io/twitter/url?label=Follow%20%40CrowdStrike&style=social&url=https%3A%2F%2Ftwitter.com%2FCrowdStrike)](https://twitter.com/CrowdStrike)<br/>
# Caracara Filters
[![PyPI](https://img.shields.io/pypi/v/caracara-filters)](https://pypi.org/project/caracara-filters/)
![OSS Lifecycle](https://img.shields.io/osslifecycle/CrowdStrike/caracara-filters)
A new filter system for Caracara.
Caracara's previous filter system was inflexible, and tailored too heavily toward the Hosts API module. This project aims to provide an FQL generator that is dialect-aware (i.e., contextual, based on the API module that the request will be sent to).
## Basic Concepts
Instead of declaring each filter as a class, we now have them defined in a dictionary which is significantly easier to work with. Dynamic functionality is provided by storing (partial) functions into each filter.
Each filter derives from the 'default' / base filter, which is configured with identity transforms and validators that return the input value and `True`, respectively, and expects a string input. These settings can be overridden per-filter, and are enforced when a filter is added to the `FQLGenerator` object. We call this process rebasing, as each filter is rebased from a smaller dictionary over the top of the default filter, thus ensuring that all expected values will be present.
When a filter is created, the input goes through these processing stages:
- Validation: the filter's input is passed into a validation function that always returns a `bool`. `True` means that the input is valid, and `False` will raise a `ValueError` exception. At this stage, we also validate the input type; incorrect input types will result in a `TypeError`.
- Transformation: each filter value can be transformed from a human-defined input into something machine-readable, expected by the API. For example, relative timestamps (such as `-30m`) are transformed to a UTC ISO8601 timestamp ready for the Falcon API, and `Containment Pending` is rewritten to `containment_pending` as expected by the Hosts API.
- Storage: the validated, transformed input is stored alongside the FQL property name and the operator (e.g., equality, `>=`, etc.), ready for FQL generation.
When FQL is generated, each of the filters are iterated over and converted to FQL individually, and then chained together with `+` to form an `AND` condition.
## Limitations
We currently only support a limited subset of FQL. For example:
- We *can* generate a condition like "all systems that run Windows or Linux, AND have an IP address in the range 192.168.0.0/16 OR 10.0.0.0/8".
- We *cannot* generate a condition like "all systems that run Windows AND have an IP address in the 192.168.0.0/16 range, as well as all Linux systems in the 10.0.0.0/8 range".
The latter is out of scope as it requires chaining together multiple filters. You can effectively create this functionality for yourself by creating two FQL generators, wrapping their outputs in parentheses, and chaining them together with a `'+'.join()`.
Raw data
{
"_id": null,
"home_page": "https://github.com/CrowdStrike/caracara-filters",
"name": "caracara-filters",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0.0,>=3.8.2",
"maintainer_email": null,
"keywords": "api, crowdstrike, falcon-platform, fql, query-language, sdk",
"author": "Chris Hammond",
"author_email": "chris.hammond@crowdstrike.com",
"download_url": "https://files.pythonhosted.org/packages/7d/82/2ae0283a24abe854c42e8cee009f59a795d7e234d848875f30a137dbb756/caracara_filters-1.0.0.tar.gz",
"platform": null,
"description": "![CrowdStrike Falcon](https://raw.githubusercontent.com/CrowdStrike/falconpy/main/docs/asset/cs-logo.png) [![Twitter URL](https://img.shields.io/twitter/url?label=Follow%20%40CrowdStrike&style=social&url=https%3A%2F%2Ftwitter.com%2FCrowdStrike)](https://twitter.com/CrowdStrike)<br/>\n\n# Caracara Filters\n\n[![PyPI](https://img.shields.io/pypi/v/caracara-filters)](https://pypi.org/project/caracara-filters/)\n![OSS Lifecycle](https://img.shields.io/osslifecycle/CrowdStrike/caracara-filters)\n\nA new filter system for Caracara.\n\nCaracara's previous filter system was inflexible, and tailored too heavily toward the Hosts API module. This project aims to provide an FQL generator that is dialect-aware (i.e., contextual, based on the API module that the request will be sent to).\n\n## Basic Concepts\n\nInstead of declaring each filter as a class, we now have them defined in a dictionary which is significantly easier to work with. Dynamic functionality is provided by storing (partial) functions into each filter.\n\nEach filter derives from the 'default' / base filter, which is configured with identity transforms and validators that return the input value and `True`, respectively, and expects a string input. These settings can be overridden per-filter, and are enforced when a filter is added to the `FQLGenerator` object. We call this process rebasing, as each filter is rebased from a smaller dictionary over the top of the default filter, thus ensuring that all expected values will be present.\n\nWhen a filter is created, the input goes through these processing stages:\n\n- Validation: the filter's input is passed into a validation function that always returns a `bool`. `True` means that the input is valid, and `False` will raise a `ValueError` exception. At this stage, we also validate the input type; incorrect input types will result in a `TypeError`.\n- Transformation: each filter value can be transformed from a human-defined input into something machine-readable, expected by the API. For example, relative timestamps (such as `-30m`) are transformed to a UTC ISO8601 timestamp ready for the Falcon API, and `Containment Pending` is rewritten to `containment_pending` as expected by the Hosts API.\n- Storage: the validated, transformed input is stored alongside the FQL property name and the operator (e.g., equality, `>=`, etc.), ready for FQL generation.\n\nWhen FQL is generated, each of the filters are iterated over and converted to FQL individually, and then chained together with `+` to form an `AND` condition.\n\n## Limitations\n\nWe currently only support a limited subset of FQL. For example:\n\n- We *can* generate a condition like \"all systems that run Windows or Linux, AND have an IP address in the range 192.168.0.0/16 OR 10.0.0.0/8\".\n- We *cannot* generate a condition like \"all systems that run Windows AND have an IP address in the 192.168.0.0/16 range, as well as all Linux systems in the 10.0.0.0/8 range\".\n\nThe latter is out of scope as it requires chaining together multiple filters. You can effectively create this functionality for yourself by creating two FQL generators, wrapping their outputs in parentheses, and chaining them together with a `'+'.join()`.\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "FQL generation engine for Caracara",
"version": "1.0.0",
"project_urls": {
"Homepage": "https://github.com/CrowdStrike/caracara-filters",
"Repository": "https://github.com/CrowdStrike/caracara-filters"
},
"split_keywords": [
"api",
" crowdstrike",
" falcon-platform",
" fql",
" query-language",
" sdk"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e232391a042d6b2c3ad81b206fbc90224f013ac071c046f54fe5458f916e92f2",
"md5": "32d5c58217f27d58c4066ed9e24dcc5a",
"sha256": "7c9d2ddac483e4ec94b288fe7369bb8633401a9743fa8ea84da9fbeadbed1809"
},
"downloads": -1,
"filename": "caracara_filters-1.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "32d5c58217f27d58c4066ed9e24dcc5a",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0.0,>=3.8.2",
"size": 18356,
"upload_time": "2024-09-13T01:08:11",
"upload_time_iso_8601": "2024-09-13T01:08:11.443817Z",
"url": "https://files.pythonhosted.org/packages/e2/32/391a042d6b2c3ad81b206fbc90224f013ac071c046f54fe5458f916e92f2/caracara_filters-1.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "7d822ae0283a24abe854c42e8cee009f59a795d7e234d848875f30a137dbb756",
"md5": "d117714b868fd3c134bd33664d160fe7",
"sha256": "f31c03ceb884ff1db371e9bcb72158446ca1f2ba2e2de402028d504de111fb44"
},
"downloads": -1,
"filename": "caracara_filters-1.0.0.tar.gz",
"has_sig": false,
"md5_digest": "d117714b868fd3c134bd33664d160fe7",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0.0,>=3.8.2",
"size": 13365,
"upload_time": "2024-09-13T01:08:12",
"upload_time_iso_8601": "2024-09-13T01:08:12.735943Z",
"url": "https://files.pythonhosted.org/packages/7d/82/2ae0283a24abe854c42e8cee009f59a795d7e234d848875f30a137dbb756/caracara_filters-1.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-13 01:08:12",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "CrowdStrike",
"github_project": "caracara-filters",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "caracara-filters"
}