intelmq.lib.bot:ParserBot.recover_line_json_stream: Makelineparameter optional, as it is not needed for this method.Bot.argparser: Added class method_create_argparser(returnsargparse.ArgumentParser) for easy command line arguments parsing.- Runtime configuration does not necessarily need a parameter entry for each block. Previously and at least empty block was required (PR#1604 by Filip Pokorný).
intelmq.lib.upgrades:- Add upgrade function for removal of HPHosts Hosts file feed and
intelmq.bots.parsers.hphostsparser (#1559).
- Add upgrade function for removal of HPHosts Hosts file feed and
intelmq.lib.exceptions:PipelineError: Remove unused code to format exceptions.
intelmq.lib.utils:create_request_session_from_bot: Changed bot argument to optional, uses defaults.conf as fallback, renamed tocreate_request_session. Namecreate_request_session_from_botwill be removed in version 3.0.0.log: Use RotatingFileHandler for allow log file rotation without external tools (PR#1637 by Vasek Bruzek).
intelmq.bin.intelmq_gen_docs: Add bot name to theFeeds.mddocumentation (PR#1617 by Birger Schacht).
intelmq.bots.collectors.eset.collector: Added (PR#1554 by Mikk Margus Möll).intelmq.bots.collectors.http.collector_http:- Added PGP signature check functionality (PR#1602 by sinus-x).
- If status code is not 2xx, the request's and response's headers and body are logged in debug logging level (#1615).
intelmq.bots.parsers.eset.parser: Added (PR#1554 by Mikk Margus Möll).- Ignore invalid "NXDOMAIN" IP addresses (PR#1573 by Mikk Margus Möll).
intelmq.bots.parsers.hphosts: Removed, feed is unavailable (#1559).intelmq.bots.parsers.cznic.parser_haas: Added (PR#1560 by Filip Pokorný and Edvard Rejthar).intelmq.bots.parsers.cznic.parser_proki: Added (PR#1599 by sinus-x).intelmq.bots.parsers.key_value.parser: Added (PR#1607 by Karl-Johan Karlsson).intelmq.bots.parsers.generic.parser_csv: Added new parametercompose_fields.
intelmq.bots.experts.rfc1918.expert:- Add support for ASN (PR#1557 by Mladen Markovic).
- Speed improvements.
- More output in debug logging mode.
- Checks parameter length on initialization and in check method.
intelmq.bots.experts.gethostbyname.expert:- Added parameter
fallback_to_urland set to True. (PR#1586 by Edvard Rejthar) - Added parameter
gaierrors_to_ignoreto optionally ignore othergethostbynameerrors (#1553).
- Added parameter
intelmq.bots.experts.asn_lookup.expert- Added
--update-databaseoption. (PR#1524 by Filip Pokorný) - The script
update-asn-datais now deprecated and will be removed in version 3.0.
- Added
intelmq.bots.experts.maxmind_geoip.expert- Added
--update-databaseoption. (PR#1524 by Filip Pokorný) - Added
license_keyparameter. (PR#1524 by Filip Pokorný) - The script
update-geoip-datais now deprecated and will be removed in version 3.0.
- Added
intelmq.bots.experts.tor_nodes.expert- Added
--update-databaseoption. (PR#1524 by Filip Pokorný) - The script
update-tor-nodesis now deprecated and will be removed in version 3.0.
- Added
intelmq.bots.experts.recordedfuture_iprisk.expert- Added
--update-databaseoption. (PR#1524 by Filip Pokorný) - Added
api_tokenparameter. (PR#1524 by Filip Pokorný) - The script
update-rfiprisk-datais now deprecated and will be removed in version 3.0.
- Added
- Added
intelmq.bots.experts.threshold(PR#1608 by Karl-Johan Karlsson).
intelmq.bots.outputs.rt: Added Request Tracker output bot (PR#1589 by Marius Urkis).
- Feeds:
- Add ESET URL and Domain feeds
- Remove unavailable HPHosts Hosts file feed (#1559).
- Added CZ.NIC HaaS feed (PR#1560 by Filip Pokorný and Edvard Rejthar).
- Added CZ.NIC Proki feed (PR#1599 by sinus-x).
- Added CERT-BUND CB-Report Malware infections feed (PR#1598 by sinus-x).
- Fixed parsing of the
publicfield in the generated feeds documentation (PR#1641 by Birger Schacht).
- Bots:
- Enhanced documentation of RFC1918 Expert.
- Enhanced documentation of SQL Output (PR #1620 by Edvard Rejthar).
- Updated documentation for Maxmind GeoIP, ASN Lookup, TOR Nodes and Recorded Future experts to reflect new
--update-databaseoption. (PR#1524 by Filip Pokorný)
- Add n6 Integration documentation.
- Moved 'Orphaned Queues' section from the FAQ to the intelmqctl documentation.
- Generate documentation using Sphinx (PR#1622 by Birger Schacht).
- The documentation is now available at https://intelmq.readthedocs.io/en/latest/
- Refactor documentation and fix broken syntax (#1639, PRs #1638 #1640 #1642 by Birger Schacht).
- Added tests for
intelmq.lib.exceptions.PipelineError. intelmq.tests.bots.collectors.http_collector.test_collector: Use requests_mock to mock all requests and do not require a local webserver.intelmq.tests.bots.outputs.restapi.test_output:- Use requests_mock to mock all requests and do not require a local webserver.
- Add a test for checking the response status code.
intelmq.tests.bots.collectors.mail.test_collector_url: Use requests_mock to mock all requests and do not require a local webserver.intelmq.tests.bots.experts.ripe.test_expert: Use requests_mock to mock all requests and do not require a local webserver.- The test flag (environment variable)
INTELMQ_TEST_LOCAL_WEBis no longer used. - Travis:
- Remove installation of local web-server (not necessary anymore) and HTTP proxy (no tests anymore).
intelmqdump:- Check if given queue is configured upon recovery (PR#1587 by Mladen Markovic).
intelmqctl:intelmq list queues:--sum,--count,-sflag for showing total count of messages (PR#1581 by Mladen Markovic).intelmq check: Added a possibility to ignore queues from the orphaned queues check.
- eventdb:
- Add SQL script for keeping track of the oldest inserted/update "time.source" information.
- Cron Jobs: The script
intelmq-update-datahas been renamed tointelmq-update-database
intelmq.lib.upgrades:- Add upgrade function for renamed Shadowserver feed name "Blacklisted-IP"/"Blocklist".
intelmq.bots.parsers.shadowserver:- Rename "Blacklisted-IP" feed to "Blocklist", old name is still valid until IntelMQ version 3.0 (PR#1588 by Thomas Hungenberg).
- Added support for the feeds
Accessible RadminandCAIDA IP Spoofer(PR#1600 by sinus-x).
intelmq.bots.parsers.anubisnetworks.parser: Fix parsing error wheredst.ipwas not equal tocomm.http.host.intelmq/bots/parsers/danger_rulez/parser: correctly skip malformed rows by defining variables before referencing (PR#1601 by Tomas Bellus).- `intelmq.bots.parsers.misp.parser: Fix MISP Event URL (#1619, PR#1618 by Nedfire23).
intelmq.bots.parsers.microsoft.parser_ctip:- Add support for
DestinationIpInfo.*andSignatures.Sha256fields, used by thectip-c2feed (PR#1623 by Mikk Margus Möll). - Use
extra.payload.textfor the feed's fieldPayloadif the content cannot be decoded (PR#1610 by Giedrius Ramas).
- Add support for
intelmq.bots.experts.cymru_whois:- Fix cache key calculation which previously led to duplicate keys and therefore wrong results in rare cases. The cache key calculation is intentionally not backwards-compatible (#1592, PR#1606).
- The bot now caches and logs (as level INFO) empty responses from Cymru (PR#1606).
- README:
- Add Core Infrastructure Initiative Best Practices Badge.
- Bots:
- Generic CSV Parser: Add note on escaping backslashes (#1579).
- Remove section of non-existing "Copy Extra" Bot.
- Explain taxonomy expert.
- Add documentation on n6 parser.
- Gethostbyname expert: Add documentation how errors are treated.
- Feeds:
- Fixed bot modules of Calidog CertStream feed.
- Add information on Microsoft CTIP C2 feed.
- In Debian packages,
intelmqctl checkandintelmqctl upgrade-configare executed in the postinst step (#1551, PR#1624 by Birger Schacht). - Require
requests<2.26for Python 3.5, as 2.25.x will be the last release series of the requests library with support for Python 3.5.
intelmq.tests.lib.test_pipeline: SkipTestAmqp.test_acknowledgeon Travis with Python 3.8.intelmq.tests.bots.outputs.elasticsearch.test_output: Refresh indexintelmqmanually to fix random test failures (#1593, PR#1595 by Zach Stone).
intelmqctl check:- For disabled bots which do not have any pipeline connections, do not raise an error, but only warning.
- Fix check on source/destination queues for bots as well the orphaned queues.
- Bash completion scripts: Check both
/opt/intelmq/as well as LSB-paths (/etc/intelmq/and/var/log/intelmq/) for loading bot information (#1561, PR#1628 by Birger Schacht).
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952).
- Corrupt dump files when interrupted during writing (#870).
intelmq.lib.upgrades:- Add upgrade function for changed configuration of the feed "Abuse.ch URLHaus" (#1571, PR#1572 by Filip Pokorný).
- Add upgrade function for removal of HPHosts Hosts file feed and
intelmq.bots.parsers.hphostsparser (#1559). intelmq.lib.harmonization:- For IP Addresses, explicitly reject IPv6 addresses with scope ID (due to changed behavior in Python 3.9, #1550).
- Ignore line length (E501) in code-style checks altogether.
intelmq.bots.collectors.misp: Fix access to actual MISP object (PR#1548 by Tomas Bellus @tomas321)intelmq.bots.collectors.stomp: Remove emptyclient.pemfile.
intelmq.bots.parsers.shadowserver.config:- Add support for Accessible-CoAP feed (PR #1555 by Thomas Hungenberg).
- Add support for Accessible-ARD feed (PR #1584 by Tomas Bellus @tomas321).
intelmq.bots.parser.anubisnetworks.parser: Ignore "TestSinkholingLoss" events, these are not intended to be sent out at all.intelmq.bots.parsers.generic.parser_csv: Allow values of type dictionary for parametertype_translation.intelmq.bots.parsers.hphosts: Removed, feed is unavailable (#1559).intelmq.bots.parsers.cymru.parser_cap_program: Add support for comment "username" for "scanner" category.intelmq.bots.parsers.malwareurl.parser: Check for valid FQDN and IP address in URL and IP address columns (PR#1585 by Marius Urkis).
intelmq.bots.experts.maxmind_geoip: On Python < 3.6, require maxminddb < 2, as that version does no longer support Python 3.5.
intelmq.bot.outputs.udp: Fix error handling on sending, had a bug itself.
- Feeds:
- Update documentation of feed "Abuse.ch URLHaus" (#1571, PR#1572 by Filip Pokorný).
- Bots:
- Overhaul of all bots' description fields (#1570).
- User-Guide:
- Overhaul pipeline configuration section and explain named queues better (#1577).
intelmq.tests.bots.experts.cymru: Adapttest_empty_result, removetest_unicode_as_nameandtest_country_question_mark(#1576).
intelmq.bin.intelmq_gen_docs: Format parameters of types lists with double quotes around values to produce conform JSON, ready to copy and paste the value into the IntelMQ Manager's bot parameter form.intelmq.bin.intelmqctl:debug: In JSON mode, use dictionaries instead of lists.debug: AddPATHto the paths shown.check: Show$PATHenvironment variable if executable cannot be found.
malware_name_mapping: Change MISP Threat Actors URL to new URL (branch master -> main) in download script.
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952).
- Corrupt dump files when interrupted during writing (#870).
- Bash completion scripts search in wrong directory in packages (#1561).
- Cymru Expert: Wrong Cache-Key Calculation (#1592).
Dropped support for Python 3.4.
__init__: Changes to the path-handling, see User Guide, section /opt and LSB paths for more information- The environment variable
INTELMQ_ROOT_DIRcan be used to set custom root directories instead of/opt/intelmq/(#805) in case of non LSB-path installations. - The environment variable
ROOT_DIRcan be used to set custom root directories instead of/(#805) in case of LSB-path installations.
- The environment variable
intelmq.lib.exceptions: AddedMissingDependencyErrorfor show error messages about a missing library and how to install it (#1471).- Added optional parameter
installedto show the installed version. - Added optional parameter
additional_textto show arbitrary text.
- Added optional parameter
- Adding more type annotations for core libraries.
intelmq.lib.pipeline.Pythonlist.sleep: Drop deprecated method.intelmq.lib.utils:write_configuration: Append a newline at end of configuration/file to allow proper comparisons & diffs.intelmq.lib.test:BotTestCasedrops privileges upon initialization (#1489).intelmq.lib.bot:- New class
OutputBot:- Method
export_eventto format/export events according to the parameters given by the user.
- Method
ParserBot: New methodsparse_json_streamandrecover_line_json_stream.ParserBot.recover_line_json: Fix format by adding a list around the line data.Bot.send_message: In debugging log level, the path to which the message is sent is now logged too.
- New class
- Bots with dependencies: Use of
intelmq.lib.exceptions.MissingDependencyError.
intelmq.bots.collectors.misp.collector: Deprecate parametermisp_verifyin favor of generic parameterhttp_verify_cert.intelmq.bots.collectors.tcp.collector: Drop compatibility with Python 3.4.intelmq.bots.collectors.stomp.collector:- Check the stomp.py version and show an error message if it does not match.
- For stomp.py versions
>= 5.0.0redirect thestomp.PrintingListeneroutput to debug logging.
intelmq.bots.collectors.microsoft.collector_azure: Support current Python libraryazure-storage-blob>= 12.0.0, configuration is incompatible and needs manual change. See NEWS file and bot's documentation for more details.intelmq.bots.collectors.amqp.collector_amqp: Requirepikaminimum version 1.0.intelmq.bots.collectors.github_api.collector_github_contents_api: Added (PR#1481).
intelmq.bots.parsers.autoshun.parser: Drop compatibility with Python 3.4.intelmq.bots.parsers.html_table.parser: Drop compatibility with Python 3.4.intelmq.bots.parsers.shadowserver.parser: Add support for MQTT and Open-IPP feeds (PR#1512, PR#1544).intelmq.bots.parsers.taichung.parser:- Migrate to
ParserBot. - Also parse geolocation information if available.
- Migrate to
intelmq.bots.parsers.cymru.parser_full_bogons:- Migrate to
ParserBot. - Add last updated information in raw.
- Migrate to
intelmq.bots.parsers.anubisnetworks.parser: Add new parameteruse_malware_familiy_as_classification_identifier.intelmq.bots.parsers.microsoft.parser_ctip: Compatibility for new CTIP data format used provided by the Azure interface.intelmq.bots.parsers.cymru.parser_cap_program: Support foropenresolvertype.intelmq.bots.parsers.github_feed.parser: Added (PR#1481).intelmq.bots.parsers.urlvir.parser: Removed, as the feed is discontinued (#1537).
intelmq.bots.experts.csv_converter: Added as converter to CSV.intelmq.bots.experts.misp: Added (PR#1475).intelmq.bots.experts.modify: New parametermaximum_matches.
intelmq.bots.outputs.amqptopic:- Use
OutputBotandexport_event. - Allow formatting the routing key with event data by the new parameter
format_routing_key(boolean).
- Use
intelmq.bots.outputs.file: UseOutputBotandexport_event.intelmq.bots.outputs.files: UseOutputBotandexport_event.intelmq.bots.outputs.misp.output_feed: Added, creates a MISP Feed (PR#1473).intelmq.bots.outputs.misp.output_api: Added, pushes to MISP via the API (PR#1506, PR#1536).intelmq.bots.outputs.elasticsearch.output: Dropped ElasticSearch version 5 compatibility, added version 7 compatibility (#1513).
- Document usage of the
INTELMQ_ROOT_DIRenvironment variable. - Added document on MISP integration possibilities.
- Feeds:
- Added "Full Bogons IPv6" feed.
- Remove discontinued URLVir Feeds (#1537).
setup.pydo not try to install any data to/opt/intelmq/as the behavior is inconsistent on various systems and withintelmqsetupwe have a tool to create the structure and files anyway.debian/rules:- Provide a blank state file in the package.
- Patches:
- Updated
fix-intelmq-paths.patch.
- Updated
- Travis: Use
intelmqsetuphere too.- Install required build dependencies for the Debian package build test.
- This version is no longer automatically tested on Python
<3.5. - Also run the tests on Python 3.8.
- Run the Debian packaging tests on Python 3.5 and the code-style test on 3.8.
- Added tests for the new bot
intelmq.bots.outputs.misp.output_feed(#1473). - Added tests for the new bot
intelmq.bots.experts.misp.expert(#1473). - Added tests for
intelmq.lib.exceptions. - Added tests for
intelmq.lib.bot.OutputBotandintelmq.lib.bot.OutputBot.export_event. - Added IPv6 tests for
intelmq.bots.parsers.cymru.parser_full_bogons. - Added tests for
intelmq.lib.bot.ParserBot's new methodsparse_json_streamandrecover_line_json_stream. intelmq.tests.test_conf: Set encoding to UTF-8 for reading thefeeds.yamlfile.
intelmqctl:upgrade-config:- Allow setting the state file location with the
--state-fileparameter. - Do not require a second run anymore, if the state file is newly created (#1491).
- New parameter
no_backup/--no-backupto skip creation of.bakfiles for state and configuration files.
- Allow setting the state file location with the
- Only require
psutilfor theIntelMQProcessManager, not for process manager independent calls likeupgrade-configorcheck. - Add new command
debugto output some information for debugging. Currently implemented:- paths
- environment variables
IntelMQController: New argument--no-file-loggingto disable logging to file.- If dropping privileges does not work,
intelmqctlwill now abort (#1489).
intelmqsetup:- Add argument parsing and an option to skip setting file ownership, possibly not requiring root permissions.
- Call
intelmqctl upgrade-configand add argument for the state file path (#1491).
intelmq_generate_misp_objects_templates.py: Tool to create a MISP object template (#1470).intelmqdump: New parameter-tor--truncateto optionally give the maximum length ofrawdata to show, 0 for no truncating.
- Added
development-tools. - ElasticSearch: Dropped version 5 compatibility, added version 7 compatibility (#1513).
- Malware Name Mapping Downloader:
- New parameter
--mwnmp-ignore-adware. - The parameter
--add-defaultsupports an optional parameter to define the default value.
- New parameter
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952).
- Corrupt dump files when interrupted during writing (#870).
- The python library
requestsis (again) listed as dependency of the core (#1519).
intelmq.lib.upgrades:- Harmonization upgrade: Also check and update regular expressions.
- Add function to migrate the deprecated parameter
attach_unziptoextract_filesfor the mail attachment collector. - Add function to migrate changed Taichung URL feed.
- Check for discontinued Abuse.CH Zeus Tracker feed.
intelmq.lib.bot:ParserBot.recover_line: Parameterlineneeds to be optional, fix usage of fallback valueself.current_line.start: Handle decoding errors in the pipeline different so that the bot is not stuck in an endless loop (#1494).start: Only acknowledge a message in case of errors, if we actually had a message to dump, which is not the case for collectors._dump_message: Dump messages with encoding errors base64 encoded, not in JSON format as it's not possible to decode them (#1494).
intelmq.lib.test:BotTestCase.run_bot: Add parametersallowed_error_countandallowed_warning_countto allow set the number per run, not per test class.- Set
source_pipeline_brokeranddestination_pipeline_brokertopythonlistinstead of the oldbroker, fixesintelmq.tests.lib.test_bot.TestBot.test_pipeline_raising. - Fix test for (allowed) errors and warnings.
intelmq.lib.exceptions:InvalidKey: AddKeyErroras parent class.DecodingError: Added, string representation has all relevant information on the decoding error, including encoding, reason and the affected string (#1494).
intelmq.lib.pipeline:- Decode messages in
Pipeline.receivenot in the implementation's_receiveso that the internal counter is correct in case of decoding errors (#1494).
- Decode messages in
intelmq.lib.utils:decode: Raise newDecodingErrorif decoding fails.
protocol.transport: Adapt regular expression to allow the valuenvp-ii(protocol 11).
intelmq.bots.collectors.mail.collector_mail_attach:- Fix handling of deprecated parameter name
attach_unzip. - Fix handling of attachments without filenames (#1538).
- Fix handling of deprecated parameter name
intelmq.bots.collectors.stomp.collector: Fix compatibility with stomp.py versions> 4.1.20and catch errors on shutdown.intelmq.bots.collectors.microsoft:- Update
REQUIREMENTS.txttemporarily fixing deprecated Azure library (#1530, PR#1532). intelmq.bots.collectors.microsoft.collector_interflow: Add method for printing the file list.
- Update
intelmq.bots.parsers.cymru.parser_cap_program: Support for protocol 11 (nvp-ii) andconfickertype.intelmq.bots.parsers.taichung.parser: Support more types/classifications:- Application Compromise: Apache vulnerability & SQL injections
- Brute-force: MSSQL & SSH password guess attacks; Office 365, SSH & SIP attacks
- C2 Sever: Attack controller
- DDoS
- DoS: DNS, DoS, Excess connection
- IDS Alert / known vulnerability exploitation: backdoor
- Malware: Malware Proxy
- Warn on new unknown types.
intelmq.bots.parsers.bitcash.parser: Removed as feed is discontinued.intelmq.bots.parsers.fraunhofer.parser_ddosattack_cncandintelmq.bots.parsers.fraunhofer.parser_ddosattack_target: Removed as feed is discontinued.intelmq.bots.parsers.malwaredomains.parser: Correctly classifyC&Candphishingevents.intelmq.bots.parsers.shadowserver.parser: More verbose error message for missing report specification (#1507).intelmq.bots.parsers.n6.parser_n6stomp: Always add n6 fieldnameasmalware.nameindependent ofcategory.intelmq.bots.parsers.anubisnetworks: Update parser with new data format.intelmq.bots.parsers.bambenek: Add new feed URLs with Hostfaf.bambenekconsulting.com(#1525, PR#1526).intelmq.bots.parsers.abusech.parser_ransomware: Removed, as the feed is discontinued (#1537).intelmq.bots.parsers.nothink.parser: Removed, as the feed is discontinued (#1537).intelmq.bots.parsers.n6.parser: Remove not allowed characters in the name field formalware.nameand write original value toevent_description.textinstead.
intelmq.bots.experts.cymru_whois.lib: Fix parsing of AS names with Unicode characters.
intelmq.bots.outputs.mongodb:- Set default port 27017.
- Use different authentication mechanisms per MongoDB server version to fix compatibility with server version >= 3.4 (#1439).
- Feeds:
- Remove unavailable feed Abuse.CH Zeus Tracker.
- Remove the field
status, offline feeds should be removed. - Add a new field
publicto differentiate between private and public feeds. - Adding documentation URLs to nearly all feeds.
- Remove unavailable Bitcash.cz feed.
- Remove unavailable Fraunhofer DDos Attack feeds.
- Remove unavailable feed Abuse.CH Ransomware Tracker (#1537).
- Update information on Bambenek Feeds, many require a license now (#1525).
- Remove discontinued Nothink Honeypot Feeds (#1537).
- Developers Guide: Fix the instructions for
/opt/intelmqfile permissions.
- Patches:
fix-logrotate-path.patch: also include path to rotated file in patch. - Fix paths from
/optto LSB forsetup.pyandcontrib/logrotate/intelmqin build process (#1500). - Add runtime dependency
debianutilsfor the programwhich, which is required forintelmqctl.
- Dropping Travis tests for 3.4 as required libraries dropped 3.4 support.
intelmq.tests.bots.experts.cymru_whois:- Drop missing ASN test, does not work anymore.
- IPv6 to IPv4 test: Test for two possible results.
intelmq.lib.test: Fix compatibility of logging capture with Python >= 3.7 by reworking the whole process (#1342).intelmq.bots.collectors.tcp.test_collector: Removing custom mocking and bot starting, not necessary anymore.- Added tests for
intelmq.bin.intelmqctl.IntelMQProcessManager._interpret_commandline. - Fix and split
tests.bots.experts.ripe.test_expert.test_ripe_stat_error_json. - Added tests for invalid encodings in input messages in
intelmq.tests.lib.test_botandintelmq.tests.lib.test_pipeline(#1494). - Travis: Explicitly enable RabbitMQ management plugin.
intelmq.tests.lib.test_message: Fix usage of the parameterblacklistfor Message hash tests (#1539).
intelmqsetup: Copy missing BOTS file to IntelMQ's root directory (#1498).intelmq_gen_docs: Feed documentation generation: Handle missing/empty parameters.intelmqctl:IntelMQProcessManager: For the status of running bots also check the bot ID of the commandline and ignore the path of the executable (#1492).IntelMQController: Fix exit codes ofcheckcommand for JSON output (now 0 on success and 1 on error, was swapped, #1520).
intelmqdump:- Handle base64-type messages for show, editor and recovery actions.
intelmq/bots/experts/asn_lookup/update-asn-data: Usepyasn_util_download.pyto download the data instead from RIPE, which cannot be parsed currently (#1517, PR#1518, hadiasghari/pyasn#62).
- HTTP stream collector: retry on regular connection problems? (#1435).
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952).
- Reverse DNS: Only first record is used (#877).
- Corrupt dump files when interrupted during writing (#870).
__init__: Resolve absolute path forSTATE_FILE_PATHvariable (resolves..).intelmq.lib.utils:- log: Do not raise an exception if logging to neither file nor syslog is requested.
- logging StreamHandler: Colorize all warning and error messages red.
- logging FileHandler: Strip all shell colorizations from the messages (#1436).
intelmq.lib.message:Message.to_json: Setsort_keys=Trueto get reproducible results.drop_privileges: Handle situations where the user or groupintelmqdoes not exist.
intelmq.lib.pipeline:Amqp._sendandAmqp._acknowledge: Log traceback in debug mode in case of errors and necessary re-connections.Amqp._acknowledge: Reset delivery tag if acknowledge was successful.
intelmq.bots.collectors.misp.collector:- Add compatibility with current pymisp versions and versions released after January 2020 (PR #1468).
intelmq.bots.parsers.shadowserver.config: Add some missing fields for the feedaccessible-rdp(#1463).intelmq.bots.parsers.shadowserver.parser:- Feed-detection based on file names: The prefixed date is optional now.
- Feed-detection based on file names: Re-detect feed for every report received (#1493).
intelmq.bots.experts.national_cert_contact_certat: Handle empty responses by server (#1467).intelmq.bots.experts.maxmind_geoip: The scriptupdate-geoip-datanow requires a license key as second parameter because of upstream changes (#1484)).
intelmq.bots.outputs.restapi.output: Fix logging of response body if response status code was not ok.
- Remove some hardcoded
/opt/intelmq/paths from code comments and program outputs.
- debian/rules: Only replace
/opt/intelmq/with LSB-paths in some certain files, not the whole tree, avoiding wrong replacements. - debian/rules and debian/intelmq.install: Do install the examples configuration directly instead of working around the abandoned examples directory.
lib/test_utils: Skip some tests on Python 3.4 becausecontextlib.redirect_stdoutandcontextlib.redirect_sterrare not supported on this version.- Travis: Stop running tests with all optional dependencies on Python 3.4, as more and more libraries are dropping support for it. Tests on the core and code without non-optional requirements are not affected.
tests.bots.parsers.html_table: Make tests independent of current year.
intelmqctl upgrade-config: Fix missing substitution in error message "State file %r is not writable.".
- bots trapped in endless loop if decoding of raw message fails (#1494)
- intelmqctl status of processes: need to check bot id too (#1492)
- MongoDB authentication: compatibility on different MongoDB and pymongo versions (#1439)
- ctl: shell colorizations are logged (#1436)
- http stream collector: retry on regular connection problems? (#1435)
- tests: capture logging with context manager (#1342)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
- Default configuration:
- Remove discontinued feed "Feodo Tracker Domains" from default configuration.
- Add "Feodo Tracker Browse" feed to default configuration.
intelmq.lib.pipeline: AMQP: using port 15672 as default (like RabbitMQ's defaults) for the monitoring interface for getting statistical data (intelmqctl_rabbitmq_monitoring_url).intelmq.lib.upgrades: Added a generic upgrade function for harmonization, checking of all message types, it's fields and their types.intelmq.lib.utils:TimeoutHTTPAdapter: A subclass ofrequests.adapters.HTTPAdapterwith the possibility to set the timeout per adapter.create_request_session_from_bot: Use theTimeoutHTTPAdapterwith the user-defined timeout. Previously the timeout was not functional.
intelmq.bots.parsers.shadowserver.parser: Fix logging message if the parameterfeednameis not present.intelmq.bots.parsers.shodan.parser: Also add fieldclassification.identifier('network-scan') in minimal mode.intelmq.bots.parsers.spamhaus.parser_cert: Add support for category'misc'.intelmq.bots.parsers.cymru.parser_cap_program:- Add support for phishing events without URL.
- Add support for protocols >= 143 (unassigned, experiments, testing, reserved), saving the number to extra, as the data would be bogus.
intelmq.bots.parsers.microsoft.parser_bingmurls:- Save the
Tagsdata assource.geolocation.cc.
- Save the
intelmq.bots.experts.modify.expert: Fix bug with setting non-string values (#1460).
intelmq.bots.outputs.smtp:- Allow non-existent field in text formatting by using a default value
Noneinstead of throwing errors. - Fix Authentication (#1464).
- Fix sending to multiple recipients (#1464).
- Allow non-existent field in text formatting by using a default value
- Feeds:
- Fix configuration of
Feodo Tracker Browsefeed.
- Fix configuration of
- Bots:
- Sieve expert: Document behavior of
!=with lists.
- Sieve expert: Document behavior of
- Adaption and extension of the test cases to the changes.
intelmq.bin.intelmqctl:- check: Check if running the upgrade function for harmonization is necessary.
- upgrade-config: Run the upgrade function for harmonization.
intelmqctl restartdid throw an error as the message for restarting was not defined (#1465).
- MongoDB authentication: compatibility on different MongoDB and pymongo versions (#1439)
- ctl: shell colorizations are logged (#1436)
- http stream collector: retry on regular connection problems? (#1435)
- tests: capture logging with context manager (#1342)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
intelmq.lib.harmonization:- Use correct parent classes.
- Add
DateTime.convertas interface for all existing conversion functions. - add
DateTime.convert_from_format. - add
DateTime.convert_from_format_midnight. - add
DateTime.convert_fuzzy.
intelmq.lib.pipeline:- Redis: Use single connection client if calling bot is not multithreaded. Gives a small speed advantage.
- Require the bot instance as parameter for all pipeline classes.
- New internal variable
_has_messageto keep the state of the pipeline. - Split receive and acknowledge into public-facing and private methods.
- Add
reject_messagemethod to the Pipeline class for explicit re-queue of messages. - AMQP:
- Make exchange configurable.
- If exchange is set, the queues are not declared, the queue name is for routing used by exchanges.
intelmq.lib.bot:- Log message after successful bot initialization, no log message anymore for ready pipeline.
- Use existing current message if receive is called and the current message still exists.
- Fix handling of received messaged after a SIGHUP that happened during a blocking receiving connection using explicit rejection (#1438).
- New method
_parse_common_parameterscalled beforeinitto parse commonly used argument. Currently supported:extract_files.
intelmq.lib.test:- Fix the tests broker by providing the testing pipeline.
intelmq.lib.utils:unzip:- new parameter
return_namesto optionally return the file names. - support for zip
- new parameters
try_zip,try_gzipandtry_tarto control which compressions are tried. - rewritten to an iterative approach
- new parameter
- add
file_name_from_responseto extract a file name from a Response object for downloaded files.
intelmq.lib.upgrades: Addedv210_deprecationsfor deprecated parameters.
- Add extra to reports.
intelmq.bots.collectors.http.collector_http:- More extensive usage of
intelmq.lib.utils.unzip. - Save the file names in the report if files have been extracted form an archive.
- More extensive usage of
intelmq.bots.collectors.rt.collector_rt:- Save ticket information/metadata in the extra fields of the report.
- Support for RT 3.8 and RT 4.4.
- New parameters
extract_attachmentandextract_downloadfor generic archive extraction and consistency. The parameterunzip_attachmentis deprecated.
intelmq.bots.collectors.mail.*: Save email information/metadata in the extra fields of the report. See the bots documentation for a complete list of provided data.intelmq.bots.collectors.mail.collector_mail_attach: Check for existence/validity of theattach_regexparameter.- Use the lib's
unzipfunction for uncompressing attachments and use the . intelmq.bots.collectors.mail.collector_mail_url: Save the file name of the downloaded file asextra.file_name.
intelmq.bots.collectors.amqp.collector_amqp: New collector to collect data from (remote) AMQP servers, for bot IntelMQ as well as external data.- use default SSL context for client purposes, fixes compatibility with python
<3.6 if TLS is used.
- use default SSL context for client purposes, fixes compatibility with python
intelmq.bot.parsers.html_table.parser:- New parameter "html_parser".
- Use time conversion functions directly from
intelmq.lib.harmonization.DateTime.convert.
- Limit lxml dependency on 3.4 to
<4.4.0 (incompatibility).
intelmq.bots.parsers.netlab_360.parser: Add support for hajime scanners.intelmq.bots.parsers.hibp.parser_callback: A new parser to parse data retrieved from a HIBP Enterprise Subscription.intelmq.bots.parsers.shadowserver.parser:- Ability to detect the feed base on the reports's field
extra.file_name, so the parameterfeednameis no longer required and one configured parser can parse any feed (#1442).
- Ability to detect the feed base on the reports's field
- Add geohash expert.
intelmq.bot.experts.generic_db_lookup.expert- new optional parameter
enginewithpostgresql(default) andsqlite(new) as possible values.
- new optional parameter
- Add
intelmq.bots.outputs.touch.output. intelmq.bot.outputs.postgresql.output:- deprecated in favor of
intelmq.bot.outputs.sql.output - Compatibility shim will be available in the 2.x series.
- deprecated in favor of
intelmq.bot.outputs.sql.outputadded generic SQL output bot. Comparted to- new optional parameter
enginewithpostgresql(default) andsqlite(new) as possible values.
- new optional parameter
intelmq.bots.outputs.stomp.output: New parametersmessage_hierarchical,message_jsondict_as_string,message_with_type,single_key.
- Feeds:
- Add ViriBack feed.
- Add Have I Been Pwned Enterprise Callback.
intelmq.tests.bots.outputs.amqptopic.test_output: Added.- Move the documentation of most bots from separate README files to the central Bots.md and feeds.yaml files.
- Travis:
- Use UTC timezone.
- Tests for
utils.unzip. - Add a new asset: Zip archive with two files, same as with
.tar.gzarchive. - Added tests for the Mail Attachment & Mail URL collectors.
- Ignore logging-tests on Python 3.7 temporarily (#1342).
- intelmqctl:
- Use green and red text color for some interactive output to indicate obvious errors or the absence of them.
- intelmqdump:
- New edit action
vto modify a message saved in the dump (#1284).
- New edit action
- malware name mapping:
- Add support for MISP treat actors data, see it's README for more information.
- And handle empty synonyms in misp's galxies data.
- Move apply-Script to the new EventDB directory
- Add support for MISP treat actors data, see it's README for more information.
- EventDB: Scripts for applying malware name mapping and domain suffixes to an EventDB.
- MongoDB authentication: compatibility on different MongoDB and pymongo versions (#1439)
- ctl: shell colorizations are logged (#1436)
- http stream collector: retry on regular connection problems? (#1435)
- tests: capture logging with context manager (#1342)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
intelmq.lib.bot.CollectorBot: Support the deprecated parameterfeeduntil version 2.2 as the documentation was not properly updated (#1445).intelmq.lib.bot.Bot:_dump_message: Wait for up to 60 seconds instead of 50 if the dump file is locked (the log message was said 60, but the code was for only 50).
intelmq.lib.upgrades.v202_fixes- Migration of deprecated parameter
feedfor Collectors. - Ripe expert parameter
query_ripe_stat_ipwas not correctly configured inv110_deprecations, now usequery_ripe_stat_asnas default if it does not exist.
- Migration of deprecated parameter
intelmq.lib.upgrades.v110_deprecations: Fix upgrade of ripe expert configuration.intelmq.lib.bot_debugger:- Fix handling of empty messages generated by parser when user wanted to show the result by "--show-sent" flag.
- Fix handling of sent messages for bots using the
path_permissiveparameter (#1453).
intelmq.lib.pipeline.Amqp:- use default SSL context for client purposes, fixes compatibility with python
<3.6 if TLS is used. - Reconnect once on sending messages if disconnect detected.
- use default SSL context for client purposes, fixes compatibility with python
intelmq.bots.collectors.api.collector_api:- Handle non-existing IO loop in shutdown.
- Close socket on shutdown, fixes reloading.
- Marked as non-threadable.
intelmq.bots.collectors.rt.collector_rt: Check for matching URLs if noattachment_regexis given.intelmq.bots.collectors.stomp.collector_stomp: Handle disconnects by actively reconnecting.
intelmq.bots.cymru.parser_cap_program: Fix parsing of the new$certname_$date.txtreport format (#1443):- Support protocol ICMP.
- Fix error message for unsupported protocols.
- Support fields
destination_port_numbers,port. - Support for all proxy types without ports.
- Use Country Code of AS as
source.geolocation.cc. - Support for 'scanner' and 'spam' categories.
- Handle bogus lines with missing separator.
- Fix bug preventing use of old format after using the new format.
- Handle postfix
(total_count:..)for destination port numbers.
intelmq.bots.experts.cymru_whois.expert: Add optional parameteroverwrite, current behavior wasTrue, default if not given isTruenow, will change toFalsein 3.0.0 (#1452, #1455).intelmq.bots.experts.modify.expert: Add optional parameteroverwrite, current behavior wasTrue, default if not given isTruenow, will change toFalsein 3.0.0 (#1452, #1455).intelmq.bots.experts.reverse_dns.expert: Add optional parameteroverwrite, current behavior wasTrue, default if not given isTruenow, will change toFalsein 3.0.0 (#1452, #1455).
intelmq.bots.outputs.amqptopic.output: use default SSL context for client purposes, fixes compatibility with python<3.6 if TLS is used.
- Rules:
- Exclude intelmqsetup tool in packages
- Include update-rfiprisk-data in packages
- Tests for
intelmq.lib.upgrades.v202_fixes. - Tests for
intelmq.lib.upgrades.v110_deprecations. - Extended tests for
intelmq.bots.parser.cymru.parser_cap_program.
- intelmqctl:
- More and more precise logging messages for botnet starting and restarting, enable and disable.
- No error message for disabled bots on botnet reload.
- Fix
upgrade-confis state file is empty or not existing. - Use arpgarse's
store_trueaction for flags instead ofstore_const. - If the loading of the defaults configuration failed, a variable definition was missing and causing an exception (#1456).
- Check MK Statistics Cronjob:
- Use
statistics_*parameters. - Make file executable
- Handle None values in
*.temporary.*keys and treat them as 0.
- Use
- systemd:
- Add
PIDFileparameter to service file.
- Add
- MongoDB authentication: compatibility on different MongoDB and pymongo versions (#1439)
- ctl: shell colorizations are logged (#1436)
- http stream collector: retry on regular connection problems? (#1435)
- tests: capture logging with context manager (#1342)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
intelmq.lib.harmonization:IPAddress: Remove Scope/Zone IDs for IPv6 addresses in sanitation.- All types: Handle
Nonefor validation and sanitation gracefully.
intelmq.lib.bot:- fix parameters of ParserBot and CollectorBot constructors, allowing
intelmqctl runwith these bots again (#1414). - Also run
rate_limitafter retry counter reset (#1431).
- fix parameters of ParserBot and CollectorBot constructors, allowing
__version_info__:- is now available in the top level module.
- uses integer values now instead of strings for numerical version parts
- Also provide (empty)
ROOT_DIRfor non-pip installations. intelmq.lib.upgrades: New library fileupgradeswith upgrade functions.intelmq.lib.utils:- New function
setup_list_loggingfor intelmqctl check an possibly others.- Fix return values (#1423).
- New function
version_smallerfor version comparisons. - New function
lazy_intfor version conversions. parse_logline: Handle thread IDs.logtakes a new argumentlogging_level_streamfor the logging level of the console handler.- New constant
LOG_FORMAT_SIMPLE, used by intelmqctl. - New function
write_configurationto write dicts to files in the correct json formatting. - New function
create_request_session_from_bot.
- New function
intelmq.lib.pipeline:- AMQP:
- Actually use
source/destination_pipeline_amqp_virtual_hostparameter. - Support for SSL with
source/destination_pipeline_sslparameter.
- Actually use
- pipeline base class: add missing dummy methods.
- Add missing return types.
- Redis: Evaluate return parameter of queue/key deletion.
- AMQP:
- Variable
STATE_FILE_PATHadded.
intelmq.bin.intelmq_gen_docs: For yaml usesafe_loadinstead of unsafeload.
- IPAddress type: Remove Scope/Zone IDs for IPv6 addresses in sanitation.
- TLP: Sanitation handles now more cases: case-insensitive prefixes and arbitrary whitespace between the prefix and the value (#1420).
intelmq.bots.collectors.http.collector_http: Useutils.create_request_session_from_bot.intelmq.bots.collectors.http.collector_http_stream: Useutils.create_request_session_from_botand thus fix some retries on connection timeouts.intelmq.bots.collectors.mail.collector_mail_url: Useutils.create_request_session_from_bot.intelmq.bots.collectors.microsoft.collector_interflow: Useutils.create_request_session_from_botand thus fix retries on connection timeouts.intelmq.bots.collectors.rt.collector_rt: Useutils.create_request_session_from_botand thus fix retries on connection timeouts.intelmq.bots.collectors.twitter.collector_twitter: Useutils.create_request_session_from_botand thus fix retries on connection timeouts for non-twitter connections.
intelmq.bots.parsers.n6.parser_n6stomp: usemalware-genericinstead ofgeneric-n6-dronefor unknown infected system events.intelmq.bots.parsers.abusech.parser_ip: Support LastOnline column in feodo feed (#1400) and use it fortime.sourceif available.- Use lower case malware names as default, should not make a difference in practice.
- Fix handling of CSV header for feodotracker (#1417, #1418).
intelmq.bots.parsers.netlab_360.parser: Detect feeds withhttps://too.
intelmq.bots.experts.generic_db_lookup: Recommend psycopg2-binary package.intelmq.bots.experts.modify.expert:- Compile regular expressions (all string rules) at initialization, improves the speed.
- Warn about old configuration style deprecation.
intelmq.bots.experts.do_portal.expert:- Use
utils.create_request_session_from_botand thus fix retries on connection timeouts (#1432). - Treat "502 Bad Gateway" as timeout which can be retried.
- Use
intelmq.bots.experts.ripe.expert: Useutils.create_request_session_from_botand thus fix retries on connection timeouts.intelmq.bots.experts.url2fqdn.expert: Support for IP addresses in hostnames (#1416).intelmq.bots.experts.national_cert_contact_certat.expert: Useutils.create_request_session_from_botand thus fix retries on connection timeouts.
intelmq.bots.outputs.postgresql: Recommend psycopg2-binary package.intelmq.bots.outputs.amqptopic:- Shutdown: Close connection only if connection exists.
- Add support for pika > 1. Pika changed the way it indicates (Non-)Acknowledgments of sent messages.
- Gracefully handle unroutable messages and give advice.
- Support for connections without authentication.
- Replace deprecated parameter
typewithexchange_typeforexchange_declare, supporting pika >= 0.11 (#1425). - New parameters
message_hierarchical_output,message_with_type,message_jsondict_as_string. - New parameter
use_sslfor SSL connections. - New parameter
single_keyfor sending single fields instead of the full event.
intelmq.bots.outputs.mongodb.output: Support for pymongo >= 3.0.0 (#1063, PR#1421).intelmq.bots.outputs.file:time.*field serialization: support for microseconds.intelmq.bots.outputs.mongodb.output: Support for authentication in pymongo >= 3.5 (#1062).intelmq.bots.outputs.restapi.output: Useutils.create_request_session_from_botand thus fix retries on connection timeouts.
- Add certbund-contact to the ecosystem document.
- Rename the IDEA expert to "IDEA Converter".
- Add the new configuration upgrade function to the docs.
- User Guide:
- Clarify on Uninstallation
- Do not execute the tcp collector tests during Debian and Ubuntu builds as they fail there.
intelmq.lib.test: Disable statistics for test runs of bots.contrib.malware_name_mapping: Added tests.- Travis: Also run tests of contrib.
intelmqsetup: Only change directory ownerships if necessary.intelmqctl:/**---- Provide new command
upgrade-confto upgrade configuration to a newer version.- Makes backups of configurations files on its own.
- Also checks for previously skipped or new functions of older versions and catches up.
- Provides logging level on class layer.
- Fix
-qflag forintelmqctl list queuesby renaming its alternative name to--non-zeroto avoid a name collision with the global--quietparameter. - For console output the string
intelmqctl:at the beginning of each line is no longer present. check: Support for the state file added. Checks if it exists and all upgrade functions have been executed successfully.- Waits for up to 2 seconds when stopping a bot (#1434).
- Exits early on restart when stopping a bot did not work (#1434).
intelmqctl run process -mdebugging: Mock acknowledge method if incoming message is mocked too, otherwise a different message is acknowledged.- Queue listing for AMQP: Support non-default monitoring URLs, see User-Guide.
- Provide new command
- logcheck rules: Adapt ignore rule to cover the instance IDs of bot names.
- malware name mapping:
- Ignore lines in mapping starting with '#'.
- Optionally include malpedia data.
- Fix command line parsing for not arguments (#1427).
- bash-completion: Support for
intelmqctl upgrade-configadded.
- http stream collector: retry on regular connection problems? (#1435)
- tests: capture logging with context manager (#1342)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
See also the changelog for 2.0.0.beta1 below.
- Defaults: New parameters
statistics_host,statistics_port,statistics_databasae,statistics_passwordfor statistics redis database (#1402).
- Add more and fix some existing type annotations.
intelmq.lib.bot:- Use
statistics_*parameters for bot's statistics (#1402). - Introduce
collector_empty_processfor collectors with an emptyprocess()method, hardcoded 1s minimum sleep time, preventing endless loops, causing high load (#1364). - Allow to disable multithreading by initialization parameter, used by intelmqctl / the bot debugger (#1403).
- Use
intelmq.lib.pipeline: redis: OOM can also be low memory, add this to log message (#1405).intelmq.lib.harmonization: ClassificationType: Update RSIT mapping (#1380):- replace
botnet dronewithinfected-system - replace
infected systemwithinfected-system - replace
ids alertwithids-alert - replace
c&cwithc2server - replace
malware configurationwithmalware-configuration - sanitize replaces these values on the fly
- replace
- Allow using non-opt/ (LSB) paths with environment variable
INTELMQ_PATHS_NO_OPT. - Disable/disallow threading for all collectors and some other bots.
- Applied isort to all core files and core-related test files, sorting the imports there (every thing except bots and bots' tests).
- See the Core section for the changes in the allowed values for
classification.type.
- Use the new RSIT types in several bots, see above
intelmq.bots.parsers.spamhaus.parser_cert: Added support forextortionevents.
- added
intelmq.bots.experts.do_portal.expert.
intelmq.bots.outputs.elasticsearch.output: Support for TLS added (#1406).intelmq.bots.outputs.tcp.output: Support non-intelmq counterparts again. New parametercounterpart_is_intelmq, see NEWS.md for more information (#1385).
- Update IntelMQ path fix patch after
INTELMQ_PATHS_NO_OPTintroduction, provideINTELMQ_PATHS_OPTenvironment variable for packaged instances.
test_conf: For yaml usesafe_loadinstead of unsafeload.- Travis: Switch distribution from trusty to xenial, adapt scripts.
- Add Python 3.7 to tests.
- Don't use Cerberus 1.3 because of pyeve/cerberus#489
- Add tests for
intelmqctl.lib.upgrades.
- intelmqdump: Fix creation of pipeline object by providing a logger.
- intelmqctl: Disable multithreading for interactive runs / the bot debugger (#1403).
- tests: capture logging with context manager (#1342)
- pymongo 3.0 deprecates used insert method (#1063)
- pymongo >= 3.5: authentication changes (#1062)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
There are some features considered as beta and marked as such in the documentation, do not use them in production yet.
- Removed compatibility shim
intelmq.bots.collectors.n6.collector_stomp, useintelmq.bots.collectors.stomp.collectorinstead (see #1124). - Removed compatibility shim
intelmq.bots.parsers.cymru_full_bogons.parser, useintelmq.bots.parsers.cymru.parser_full_bogonsinstead. - Removed compatibility shim handling deprecated parameter
feedfor collectors. Usenameinstead. - Removed deprecated and unused method
intelmq.lib.pipeline.Pipeline.sleep. - Removed support for deprecated parameter
query_ripe_statinintelmq.bots.experts.ripe.expert, usequery_ripe_stat_asnandquery_ripe_stat_ipinstead (#1291). - Removed deprecated and unused function
intelmq.lib.utils.extract_tar.
lib/pipeline:- Allow setting the broker of source and destination independently.
- Support for a new AMQP broker. See User Guide for configuration. (#1179)
lib/bot:- Dump messages locks the dump file using Unix file locks (#574).
- Print idle/rate limit time also in human readable format (#1332).
set_request_parameters: Use{}as default proxy value instead ofNone. Allows updating of existing proxy dictionaries.- Bots drop privileges if they run as root.
- Save statistics on successfully and failed processed messages in the redis database 3.
lib/utils- Function
unzipto extract files from gz-zipped and/or tar-archives. - New class
ListHandler: new handler for logging purpose which saves the messages in a list. - Add function
seconds_to_human. - Add function
drop_privileges. parse_relative: Strip string before parsing.parse_logline: Do not convert the timestamps to UTC, leave them as is.
- Function
lib/cache:- Allow ttl to be None explicitly.
- Overwrite existing cache keys in the database instead of discarding the new data.
lib/bot:- Basic, but easy-to-configure multi-threading using python's
threadinglibrary. See the User-Guide for more information (#111, #186).
- Basic, but easy-to-configure multi-threading using python's
bin/intelmqctl:- Support for Supervisor as process manager (#693, #1360).
- upgraded all files to python3-only syntax, e.g. use
super()instead ofsuper(..., ...)in all files. Migration from old to new string formatting has not been applied if the resulting code would be longer.
- added
intelmq.bots.parsers.opendxl.collector(#1265). - added
intelmq.bots.collectors.api: collecting data using an HTTP API (#123, #1187). - added
intelmq.bots.collectors.rsync(#1286). intelmq.bots.collectors.http.collector_http:- Add support for uncompressing of gz-zipped-files (#1270).
- Add time-delta support for time formatted URLs (#1366).
intelmq.collectors.blueliv.collector_crimeserver: Allow setting the API URL by parameter (#1336).intelmq.collectors.mail:- Use internal lib for functionality.
- Add
intelmq.bots.collectors.mail.collector_mail_body. - Support for
ssl_ca_certificateparameter (#1362).
- added
intelmq.bots.parsers.mcafee.parser_atd(#1265). intelmq.bots.parsers.generic.parser_csv:- New parameter
columns_requiredto optionally ignore parse errors for columns.
- New parameter
- added
intelmq.bots.parsers.cert_eu.parser_csv(#1287).- Do not overwrite the local
time.observationwith the data from the feed. The feed's field 'observation time' is now saved in the fieldextra.cert_eu_time_observation. - Fix parsing of
asn(renamed tosource asn,source.asninternally) and handle existingfeed.accuracyfor parsingconfidence. - Update columns and mapping to current (2019-04-02) data.
- Do not overwrite the local
- added
intelmq.bots.parsers.surbl.surbl - added
intelmq.bots.parsers.html_table(#1381). intelmq.bot.parsers.netlab_360.parser: Handle empty lines containing blank characters (#1393).intelmq.bots.parsers.n6.parser_n6stomp: Handle events without IP addresses.intelmq.bots.parsers.cymru.parser_cap_program: Handle new feed format.intelmq.bots.parsers.shadowserver:- Add support for the
Accessible-FTPfeed (#1391).
- Add support for the
intelmq.bots.parsers.dataplane.parser:- Fix parse errors and log more context (#1396).
- added
intelmq.bots.parsers.fraunhofer.parser_ddosattack_cnc.pyandintelmq.bots.parsers.fraunhofer.parser_ddosattack_target.py(#1373).
- added
intelmq.bots.experts.recordedfuture_iprisk(#1267). - added
intelmq.bots.experts.mcafee.expert_mar(1265). - renamed
intelmq.bots.experts.ripencc_abuse_contact.experttointelmq.bots.experts.ripe.expert, compatibility shim will be removed in version 3.0.- Added support for geolocation information in ripe expert with a new parameter
query_ripe_stat_geolocation(#1317). - Restructurize the expert and code de-duplicataion (#1384).
- Handle '?' in geolocation country data (#1384).
- Added support for geolocation information in ripe expert with a new parameter
intelmq.bots.experts.ripe.expert:- Use a requests session (#1363).
- Set the requests parameters once per session.
intelmq.bots.experts.maxmind_geoip.expert: New parameteruse_registeredto use the registered country (#1344).intelmq.bots.experts.filter.expert: Support for paths (#1208).
- added
intelmq.bots.experts.mcafee.output_esm(1265). - added
intelmq.bots.outputs.blackhole(#1279). intelmq.bots.outputs.restapi.expert:- Set the requests parameters once per session.
intelmq.bots.outputs.redis:- New parameter
hierarchichal_output(#1388). - New parameter
with_type.
- New parameter
intelmq.bots.outputs.amqptopic.output: Compatibility with pika 1.0.0 (#1084, #1394).
- added documentation for feeds
- CyberCrime Tracker
- Feodo Tracker Latest
- Feeds: Document abuse.ch URLhaus feed (#1379).
- Install and Upgrading: Use
intelmqsetuptool. - Added an ecosystem overview document describing related software.
- Add tests of AMQP broker.
- Travis: Change the ownership of
/opt/intelmqto the current user.
intelmqctl check: Now uses the newListHandlerfrom utils to handle the logging in JSON output mode.intelmqctl run: The message that a running bot has been stopped, is not longer a warning, but an informational message. No need to inform sysadmins about this intended behavior.intelmqdump: Inspecting dumps locks the dump file using unix file locks (#574).intelmqctl:- After the check if the program runs as root, it tries to drop privileges. Only if this does not work, a warning is shown.
intelmqsetup: New tool for initializing an IntelMQ environment.
malware_name_mapping:- Added the script
apply_mapping_eventdb.pyto apply the mapping to an EventDB. - Possibility to add local rules using the download tool.
- Added the script
check_mk:- Added scripts for monitoring queues and statistics.
- Multi-threaded bots require multiple SIGTERMs (#1403)
- Stats can't be saved with AMQP if redis is password-protected (#1402)
- Update taxonomies to current RSIT and vice-versa (#1380)
- stomp collector bot constantly uses 100% of CPU (#1364)
- tests: capture logging with context manager (#1342)
- Consistent message counter log messages for all kind of bots (#1278)
- pymongo 3.0 deprecates used insert method (#1063)
- pymongo >= 3.5: authentication changes (#1062)
- Bots started with IntelMQ-Manager stop when the webserver is restarted. (#952)
- n6 parser: mapping is modified within each run (#905)
- reverse DNS: Only first record is used (#877)
- Corrupt dump files when interrupted during writing (#870)
intelmq.lib.bot:Bot.__handle_sighup: Handle exceptions inshutdownmethod of bots.
- FQDN: Disallow
:in FQDN values to prevent values like '10.0.0.1:8080' (#1235).
intelmq.bots.collectors.stomp.collector- Fix name of shutdown method, was ineffective in the past.
- Ignore
NotConnectedExceptionerrors on disconnect during shutdown.
intelmq.bots.collectors.mail.collector_mail_url: Decode body if it is bytes (#1367).intelmq.bots.collectors.tcp.collector: Timeout added. More stable version.
intelmq.bots.parsers.shadowserver:- Add support for the
Amplification-DDoS-Victim,HTTP-Scanners,ICS-ScannersandAccessible-Ubiquiti-Discovery-Servicefeeds (#1368, #1383)
- Add support for the
intelmq.bots.parsers.microsoft.parser_ctip:- Workaround for mis-formatted data in
networkdestinationipv4field (since 2019-03-14). - Ignore "hostname" ("destination.fqdn") if it contains invalid data.
- Workaround for mis-formatted data in
intelmq.bots.parsers.shodan.parser:- In
minimal_mode:- Fix the parsing, previously only
source.geolocation.ccandextra.shodanwas correctly filled with information. - Add a
classification.type= 'other' to all events. - Added tests for this mode.
- Fix the parsing, previously only
- Normal mode:
- Fix the parsing of
timestampto `time.source in the normal mode, previously no timezone information has been added and thus every event raised an exception. - ISAKMP: Ignore
isakmp.aggressive, as the content is same asisakmpor less.
- Fix the parsing of
- In
intelmq.bots.parsers.abusech.parser_ip: Re-structure the bot and support new format of the changed "Feodo Tracker Domains" feed.intelmq.bots.parsers.n6.parser:- Add parsing for fields "confidence", "expires" and "source".
- Add support for type "bl-other" (category "other").
intelmq.bots.experts.sieve.expert: Fix key definition to allow field names with numbers (malware.hash.md5/sha1, #1371).
intelmq.bots.outputs.tcp.output: Timeout added. When no separator used, awaits that every message is acknowledged by a simple "Ok" string to ensure more stability.
- Install: Update operating system versions
- Sieve Expert: Fix
elsif->elif. - Rephrase the description of
time.*fields. - Feeds: New URL and format of the "Feodo Tracker IPs" feed. "Feodo Tracker Domains" has been discontinued.
- Add missing
__init__.pyfiles in 4 bot's test directories. Previously these tests have never been executed. intelmq.lib.test: Allow bot test class names with an arbitrary postfix separated by an underscore. E.g.TestShodanParserBot_minimal.
- intelmqctl:
- status: Show commandline differences if a program with the expected PID could be found, but they do not match (previous output was
None). - Use logging level from defauls configuration if possible, otherwise intelmq's internal default. Previously, DEBUG was used unconditionally.
- status: Show commandline differences if a program with the expected PID could be found, but they do not match (previous output was
- Bots started with IntelMQ-Manager stop when the webserver is restarted (#952).
- stomp collector bot constantly uses 100% of CPU (#1364).
lib/harmonization.py: Changeparse_utc_isoformatofDateTimeclass from private to public (related to #1322).lib/utils.py: Add new functionobject_pair_hook_bots.lib.bot.py:ParserBot's methodrecover_line_csvnow also handles giventempdata.Bot.acknowledge_message()deletes__current_messageto free the memory, saves memory in idling parsers with big reports.start(): Warn once per run iferror_dump_messageis set to false.Bot.start(),ParserBot.process(): If errors happen on bots without destination pipeline, theon_errorpath has been queried and lead to an exception being raised.start(): Iferror_procedureis pass and on pipeline errors, the bot retries forever (#1333).
lib/message.py:- Fix add('extra', ..., overwrite=True): old extra fields have not been deleted previously (#1335).
- Do not ignore empty or ignored (as defined in
_IGNORED_VALUES) values ofextra.*fields for backwards compatibility (#1335).
lib/pipeline.py(Redis.receive): Wait in 1s steps if redis is busy loading its snapshot from disk (#1334).
- Set
error_dump_messageto true by default indefaults.conf. - Fixed typo in
defaults.conf:proccess_manager->process_manager
bin/rewrite_config_files.py: Fix ordering of BOTS file (#1327).
Update allowed classification fields to 2018-09-26 version (#802, #1350, #1380). New values for classification.type are per taxonomy:
- Taxonomy 'intrusions':
- "application-compromise"
- "burglary"
- "privileged-account-compromise"
- "unprivileged-account-compromise"
- Taxonomy 'fraud':
- "copyright"
- "masquerade"
- "unauthorized-use-of-resources"
- Taxonomy 'information content security':
- "data-loss"
- Taxonomy 'vulnerable':
- "ddos-amplifier"
- "information-disclosure"
- "potentially-unwanted-accessible"
- "vulnerable-system"
- "weak-crypto"
- Taxonomy 'availability':
- "dos"
- "outage"
- "sabotage"
- Taxonomy 'abusive-content':
- "harmful-speech"
- "violence"
- Taxonomy 'malicious code':
- "malware-distribution"
- Taxonomy 'information-gathering':
- "social-engineering"
- "sniffing"
- Taxonomy 'information content security':
- "Unauthorised-information-access"
- "Unauthorised-information-modification"
intelmq.bots.collectors.http.collector_http:- Fix parameter name
extract_filesin BOTS (#1331). - Fix handling of
extract_filesparameter if the value is an empty string. - Handle not installed dependency library
requestsgracefully. - Explain
extract_filesparameter in docs and use a sane default in BOTS file.
- Fix parameter name
intelmq.bots.collectors.mail.collector_mail_url:- Handle HTTP status codes != 2xx the same as HTTP timeouts: No exception, but graceful handling.
- Handle HTTP errors (bad status code and timeouts) with
error_procedure== 'pass' but marking the mail as read and logging the error. - Handle not installed dependency library
requestsgracefully.
intelmq.bots.collectors.http.collector_http_stream:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
intelmq.bots.collectors.microsoft.collector_interflow:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
intelmq.bots.collectors.rt.collector_rt:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
- added
intelmq.bots.collectors.shodan.collector_streamfor collecting shodan stream data (#1096).- Correctly check the version of the shodan library, it resulted in wrong comparisons with two digit numbers.
intelmq.bots.collectors.microsoft.collector_interflow:- Add check if Cache's TTL is big enough compared to
not_older_thanand throw an error otherwise.
- Add check if Cache's TTL is big enough compared to
intelmq.bots.parsers.misp: Fix Object attribute (#1318).intelmq.bots.parsers.cymru.parser_cap_program:- Add support for new format (extra data about botnet of 'bots').
- Handle AS number 0.
intelmq.bots.parsers.shadowserver:- Spam URL reports: remove
src_naics,src_siccolumns. - fix parsing of 'spam' events in ShadowServer's 'Botnet Drone Hadoop' Report (#1271).
- Add support in parser to ignore some columns in config file by using
Falseas intelmq key. - Add support for the
Outdated-DNSSEC-KeyandOutdated-DNSSEC-Key-IPv6feeds. - Add support for the
Accessible-Rsyncfeed. - Document support for the
Open-LDAP-TCPfeed. - Add support for
Accessible-HTTPandOpen-DB2-Discovery-Service(#1349). - Add support for
Accessible-AFP(#1351). - Add support for
Darknet(#1353).
- Spam URL reports: remove
intelmq.bots.parsers.generic.parser_csv: If theskip_headerparameter was set toTrue, the header was not part of therawfield as returned by therecover_linemethod. The header is now saved and handled correctly by the fixed recovery method.intelmq.bots.parsers.cleanmx.parser: Use fieldfirstinstead offirsttimefortime.source(#1329, #1348).intelmq.bots.parsers.twitter.parser: Support forurl-normalize>= 1.4.1 and recommend it. Added new optional parameterdefault_scheme, passed tourl-normalize(#1356).
intelmq.bots.experts.national_cert_contact_certat.expert:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
intelmq.bots.experts.ripencc_abuse_contact.expert:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
intelmq.bots.experts.sieve.expert:- check method: Load missing harmonization, caused an error for every check.
- Add text and more context to error messages.
- README: Fix 'modify' to 'update' (#1340).
- Handle empty rules file (#1343).
intelmq.bots.experts.idea.expert: Add mappings for new harmonizationclassification.typevalues, see above.
intelmq.bots.outputs.redis:- Fix sending password to redis server.
- Fix for redis-py >= 3.0.0: Convert Event to string explicitly (#1354).
- Use
Redisclass instead of deprecatedStrictRedisfor redis-py >= 3.0.0 (#1355).
intelmq.bots.outputs.mongodb:- New parameter
replacement_char(default:'_') for non-hierarchical output as dots in key names are not allowed (#1324, #1322). - Save value of fields
time.observationandtime.sourceas native datetime object, not as string (#1322).
- New parameter
intelmq.bots.outputs.restapi.output:- Handle not installed dependency library
requestsgracefully.
- Handle not installed dependency library
- FAQ
- Explanation and solution on orphaned queues.
- Section on how and why to remove
rawdata.
- Add or fix the tables of contents for all documentation files.
- Feeds:
- Fix Autoshun Feed URL (#1325).
- Add parameters
nameandprovidertointelmq/etc/feeds.yaml,docs/Feeds.mdandintelmq/bots/BOTS(#1321).
- Add SECURITY.md file.
- Change the maintainer from Sasche Wilde to Sebastian Wagner (#1320).
intelmq.tests.lib.test_bot: Skiptest_logging_level_otheron python 3.7 because of unclear behavior related to copies of loggers (#1269).intelmq.tests.bots.collectors.rt.test_collector: Remove test because the REST interface of the instance has been closed (see also python-rt/python-rt#28).
intelmqctl check: Shows more detailed information on orphaned queues.intelmqctl:- Correctly determine the status of bots started with
intelmqctl run. - Fix output of errors during bot status determination, making it compatible to IntelMQ Manager.
checksubcommand: Show bot ID for messages also in JSON output.run [bot-id] process -m [message]works also with bots without a configured source pipeline (#1307).
- Correctly determine the status of bots started with
- elasticsearch/elasticmapper: Add tlp field (#1308).
feeds-config-generator/intelmq_gen_feeds_conf:- Add parameters to write resulting configuration directly to files (#1321).
- Handle collector's
feed.nameandfeed.provider(#1314).
- Bots started with IntelMQ-Manager stop when the webserver is restarted (#952).
- Tests: capture logging with context manager (#1342).
- stomp collector bot constantly uses 100% of CPU (#1364).
- Support for Python 3.3 has been dropped in IntelMQ and some dependencies of it. Python 3.3 reached its end of life and Python 3.4 or newer is a hard requirement now.
- The list of feeds docs/Feeds.md has now a machine-readable equivalent YAML file in intelmq/etc/feeds.yaml A tool to convert from yaml to md has been added.
intelmq_gen_feeds_docsadded to bin directory, allows generating the Feeds.md documentation file from feeds.yamlintelmq_gen_docsmerges bothintelmq_gen_feeds_docsandintelmq_gen_harm_docsin one file and automatically updates the documentation files.
intelmqctl startprints the bot's last error messages if the bot failed to start (#1021).intelmqctl startmessage "is running" is printed every time. (Until now, it wasn't said when a bot was just starting.)intelmqctl start/stop/restart/reload/statusnow has a "--group" flag which allows you to specify the group of the bots that should be influenced by the command.intelmqctl checkchecks for defaults.conf completeness if the shipped file from the package can be found.intelmqctl checkshows errors for non-importable bots.intelmqctl list bots -qonly prints the IDs of enabled bots.intelmqctl list queues-and-statusprints both queues and bots statuses (so that it can be used in eg. intelmq-manager).intelmqctl runparameter for showing a sent message.intelmqctl runif message is sent to a non-default path, it is printed out.intelmqctl restartbug fix; returned some half-nonsense, now returns return state of start and stop operation in a list (#1226).intelmqctl check: New parameter--no-connectionsto prevent the command from making connections e.g. to the redis pipeline.sintelmqctl list queues: don't display named paths among standard queues.- The process status test failed if the PATH did not include the bot executables and the
whichcommand failed. Then the proccess's command line could not be compared correctly. The fix warns of this and adds a new status 'unknown' (#1297).
- tool
feeds-config-generatorto automatically generate the collector and parser runtime and pipeline configurations. malware_name_mapping: Download and convert tool for malware family name mapping has been added.- Added a systemd script which creates systemd units for bots (#953).
contrib/cron-jobs/update-asn-data,contrib/cron-jobs/update-geoip-data,contrib/cron-jobs/update-tor-nodes: Errors produce proper output.
- lib/bot
- use SIGTERM instead of SIGINT to stop bots (#981).
- Bots can specify a static method
check(parameters)which can perform individual checks specific to the bot. These functions will be called byintelmqctl checkif the bot is configured with the given parameters - top level bot parameters (description, group, module, name) are exposed as members of the class.
- The parameter
feedfor collectors is deprecated for 2.0 and has been replaced by the more consistentname(#1144). - bug: allow path parameter for CollectorBot class.
- Handle errors better when the logger could not be initialized.
ParserBot:- For the csv parsing methods,
ParserBot.csv_paramsis now used for all these methods. ParserBot.parse_csv_dictnow saves the field names inParserBot.csv_fieldnames.ParserBot.parse_csv_dictnow saves the raw current line inParserBot.current_line.ParserBot.recover_line_csv_dictnow uses the raw current line.
- For the csv parsing methods,
- lib/message:
- Subitems in fields of type
JSONDict(see below) can be accessed directly. E.g. you can do: event['extra.foo'] = 'bar' event['extra.foo'] # gives 'bar' It is still possible to set and get the field as whole, however this may be removed or changed in the future: event['extra'] = '{"foo": "bar"}' event['extra'] # gives '{"foo": "bar"}' "Old" bots and configurations compatible with 1.0.x do still work. Also, the extra field is now properly exploded when exporting events, analogous to all other fields. Theinoperator works now for both - the old and the new - behavior. Message.add: The parameteroverwriteaccepts now three different values:True,FalseandNone(new). True: An existing value will be overwritten False: An existing value will not be overwritten (previously an exception has been raised when the value was given). None (default): If the value exists anKeyExistsexception is thrown (previously the same as False). This allows shorter code in the bots, as an 'overwrite' configuration parameter can be directly passed to the function.- The message class has now the possibility to return a default value for non-existing fields, see
Message.set_default_value. - Message.get behaves the same like
Message.__getitem__(#1305).
- Subitems in fields of type
- Add
RewindableFileHandleto utils making handling of CSV files more easy (optionally) - lib/pipeline:
- you may now define more than one destination queues path the bot should pass the message to, see Pipelines (#1088, #1190).
- the special path
"_on_error"can be used to pass messages to different queues in case of processing errors (#1133).
lib/harmonization: AcceptASprefix for ASN values (automatically stripped).- added
intelmq.VAR_STATE_PATHfor variable state data of bots.
- Removed print statements from various bots.
- Replaced various occurrences of
self.logger.error()+self.stop()withraise ValueError.
bots.collectors.mail:- New parameters;
sent_from: filter messages by sender,sent_to: filter messages by recipient - More debug logs
- New parameters;
bots.collectors.n6.collector_stomp: renamed tobots.collectors.stomp.collector(#716)- bots.collectors.rt:
- New parameter
search_requestorto search for field Requestor. - Empty strings and
nullas value for search parameters are ignored. - Empty parameters
attachment_regexandurl_regexhandled.
- New parameter
bots.collectors.http.collector_http: Ability to optionally use the current time in parameterhttp_url, added parameterhttp_url_formatting.bots.collectors.stomp.collector: Heartbeat timeout is now logged with log level info instead of warning.- added
intelmq.bots.collectors.twitter.collector_twitter - added
intelmq.bots.collectors.tcp.collectorthat can be bound to another IntelMQ instance by a TCP output bots.collectors.microsoft.collector_interflow: added for MS interflow API- Automatic ungzipping for .gz files.
- added
intelmq.bots.collectors.calidog.collector_certstreamfor collecting certstream data (#1120). - added
intelmq.bots.collectors.shodan.collector_streamfor collecting shodan stream data (#1096).- Add proxy support.
- Fix handling of parameter
countries.
bots.parsers.shadowserver:- changed feednames. Please refer to it's README for the exact changes.
- If the conversion function fails for a line, an error is raised and the offending line will be handled according to the error handling configuration. Previously errors like these were only logged and ignored otherwise.
- add support for the feeds
Accessible-Hadoop(#1231)Accessible ADB(#1285)
- Remove deprecated parameter
override, useoverwriteinstead (#1071). - The
rawvalues now are exactly the input with quotes unchanged, the ParserBot methods are now used directly (#1011).
- The Generic CSV Parser
bots.parsers.generic.parser_csv:- It is possible to filter the data before processing them using the new parameters
filter_typeandfilter_text. - It is possible to specify multiple columns using
|character in parametercolumns. - The parameter
time_formatnow supports'epoch_millis'for seconds since the Epoch, milliseconds are supported but not used.
- It is possible to filter the data before processing them using the new parameters
- renamed
bots.parsers.cymru_full_bogons.parsertobots.parsers.cymru.parser_full_bogons, compatibility shim will be removed in version 2.0 - added
bots.parsers.cymru.parser_cap_program - added
intelmq.bots.parsers.zoneh.parserfor ZoneH feeds - added
intelmq.bots.parsers.sucuri.parser - added
intelmq.bots.parsers.malwareurl.parser - added
intelmq.bots.parsers.threatminer.parser - added
intelmq.bots.parsers.webinspektor.parser - added
intelmq.bots.parsers.twitter.parser - added
intelmq.bots.parsers.microsoft.parser_ctip- ignore the invalid IP '0.0.0.0' for the destination
- fix the raw/dumped messages, did not contain the paling list previously.
- use the new harmonization field
tlpinstead ofextra.tlp.
bots.parsers.alienvault.parser_otx: Save TLP data in the new harmonization fieldtlp.- added
intelmq.bots.parsers.openphish.parser_commercial - added
intelmq.bots.parsers.microsoft.parser_bingmurls - added
intelmq.bots.parsers.calidog.parser_certstreamfor parsing certstream data (#1120). - added
intelmq.bots.parsers.shodan.parserfor parsing shodan data (#1096). - change the classification type from 'botnet drone' to 'infected system' in various parses.
intelmq.bots.parsers.spamhaus.parser_cert: Added support for all known bot types.
- Added sieve expert for filtering and modifying events (#1083)
- capable of distributing the event to appropriate named queues
bots.experts.modify- default rulesets: all malware name mappings have been migrated to the Malware Name Mapping repository ruleset. See the new added contrib tool for download and conversion.
- new parameter
case_sensitive(default: True)
- Added wait expert for sleeping
- Added domain suffix expert to extract the TLD/Suffix from a domain name.
bots.experts.maxmind_geoip: New (optional) parameteroverwrite, by default false. The current default was to overwrite!intelmq.bots.experts.ripencc_abuse_contact:- Extend deprecated parameter compatibility
query_ripe_statuntil 2.0 because of a logic bug in the compatibility code, usequery_ripe_stat_asnandquery_ripe_stat_ipinstead (#1071, #1291). - Handle HTTP status code 404 for DB AS queries.
- Add caching capability.
- Extend deprecated parameter compatibility
intelmq/bots/experts/asn_lookup/update-asn-data: Errors produce proper output on stdout/stderr.intelmq/bots/experts/maxmind_geoip/update-geoip-data: Errors produce proper output on stdout/stderr.intelmq/bots/experts/tor_nodes/update-tor-nodes: Errors produce proper output on stdout/stderr.
bots.outputs.file:- String formatting can be used for file names with new parameter
format_filename. - New parameter
single_keyto only save one field. - New parameter
encoding_errors_modewith default value'strict'to handle encoding errors for the files written.
- String formatting can be used for file names with new parameter
- Renamed
JSONtoJSONDictand added a new typeJSON.JSONDictsaves data internally as JSON, but acts like a dictionary.JSONaccepts any valid JSON. - fixed regex for
protocol.transportit previously allowed more values than it should have. - New ASN type. Like integer but checks the range.
- added
destination.urlpathandsource.urlpathto harmonization. - New field
tlpfor tlp level specification.- New TLP type. Allows all four tlp levels, removes 'TLP:' prefix and converts to upper case.
- Added new
classification.type'vulnerable client' - Added
(destination|source).domain_suffixto hold the TLD/domain suffix. - New allowed value for
classification.type:infected systemfor taxonomymalicious code(#1197).
- Requests is no longer listed as dependency of the core. For depending bots the requirement is noted in their
REQUIREMENTS.txtfile.
- Use Markdown for README again, as pypi now supports it.
- Developers Guide: Add instructions for pre-release testing.
- Add logcheck configuration to the packages.
- Fix packaging of bash completion script.
- Travis now correctly stops if a requirement could not be installed (#1257).
- New tests for validating
etc/feeds.yamlandbots/BOTSusing cerberus and schemes are added (#1166). - New test for checking if
docs/Feeds.mdis up to date withetc/feeds.yaml.
- contrib: feeds-config-generator does not add feed name as parameter (#1314).
- bot debugger requires configured source pipeline (#1307).
- shadowserver parser: drone feed has spam events (#1271).
- debug log level on python 3.7 not applied (#1269).
bots.experts.sievedoes not support textX (#1246).- Bots started with IntelMQ-Manager stop when the webserver is restarted (#952).
bots.collectors.rt.collector_rt: Log ticket id for downloaded reports.
bots.parsers.shadowserver:- if required fields do not exist in data, an exception is raised, so the line will be dumped and not further processed.
- fix a bug in the parsing of column
cipher_suitein ssl poodle reports (#1288).
- Reverse DNS Expert: ignore all invalid results and use first valid one (#1264).
intelmq/bots/experts/tor_nodes/update-tor-nodes: Use check.torproject.org as source as internet2.us is down (#1289).
bots.output.amqptopic:- The default exchange must not be declared (#1295).
- Unencodable characters are prepended by backslashes by default. Otherwise Unicode characters can't be encoded and sent (#1296).
- Gracefully close AMQP connection on shutdown of bot.
- Bots: document redis cache parameters.
- Installation documentation: Ubuntu needs universe repositories.
- Dropped support for Ubuntu 17.10, it reached its End of Life as of 2018-07-19.
- Drop tests for Python 3.3 for the mode with all requirements, as some optional dependencies do not support Python 3.3 anymore.
lib.test: Add parametercompare_raw(default:True) toassertMessageEqual, to optionally skip the comparison of the raw field.- Add tests for RT collector.
- Add tests for Shadowserver Parser:
- SSL Poodle Reports.
- Helper functions.
intelmqctl listnow sorts the output of bots and queues (#1262).intelmqctl: Correctly handle the corner cases with collectors and outputs for getting/sending messages in the bot debugger (#1263).intelmqdump: fix ordering of dumps in a file in runtime. All operations are applied to a sorted list (#1280).
cron-jobs/update-tor-nodes: Use check.torproject.org as source as internet2.us is down (#1289).
- shadowserver parser: drone feed has spam events (#1271).
lib/message:Report()can now create a Report instance from Event instances (#1225).lib/bot:- The first word in the log line
Processed ... messages since last logging.is now adaptable and set toForwardedin the existing filtering bots (#1237). - Kills oneself again after proper shutdown if the bot is XMPP collector or output (#970). Previously these two bots needed two stop commands to get actually stopped.
- The first word in the log line
lib/utils: log: set the name of thepy.warningslogger to the bot name (#1184).
- Added new types
unauthorized-commandandunauthorized-logintointrusionstaxonomy.
bots.collectors.mail.collector_mail_url: handle empty downloaded reports (#988).bots.collectors.file.collector_file: handle empty files (#1244).
- Shadowserver parser:
- SSL FREAK: Remove optional column
device_serialand add several new ones. - Fixed HTTP URL parsing for multiple feeds (#1243).
- SSL FREAK: Remove optional column
- Spamhaus CERT parser:
- add support for
smtpauth,l_spamlink,pop,imap,rdp,smb,iotscan,proxyget,iotmicrosoftds,automatedtest,ioturl,iotmirai,iotcmd,iotloginandiotuser(#1254). - fix
extra.destination.local_port->extra.source.local_port.
- add support for
bots.experts.filter: Pre-compile regex at bot initialization.
- Ensure that the bots did process all messages (#291).
intelmqctl:intelmqctl runhas a new parameter-l--loglevelto overwrite the log level for the run (#1075).intelmqctl run [bot-id] mesage sendcan now send report messages (#1077).
intelmqdump:- has now command completion for bot names, actions and queue names in interactive console.
- automatically converts messages from events to reports if the queue the message is being restored to is the source queue of a parser (#1225).
- is now capable to read messages in dumps that are dictionaries as opposed to serialized dicts as strings and does not convert them in the show command (#1256).
- truncated messages are no longer used/saved to the file after being shown (#1255).
- now again denies recovery of dumps if the corresponding bot is running. The check was broken (#1258).
- now sorts the dump by the time of the dump. Previously, the list was in random order (#1020).
no known issues
- make code style compatible to pycodestyle 2.4.0
- fixed permissions of some files (they were executable but shouldn't be)
- lib/harmonization:
- FQDN validation now handles None correctly (raised an Exception).
- Fixed several sanitize() methods, the generic sanitation method were called by is_valid, not the sanitize methods (#1219).
- Use the new pypi website at https://pypi.org/ everywhere.
- Shadowserver parser:
- The fields
urlandhttp_urlnow handle HTTP URL paths and HTTP requests for all feeds (#1204). - The conversion function
validate_fqdnnow handles empty strings correctly. - Feed 'drone (hadoop)':
- Correct validation of field
cc_dns, will now only be added asdestination.fqdnif correct FQDN, otherwise ignored. Previously this field could be saved in extra containing an IP address. - Adding more mappings for added columns.
- Correct validation of field
- Added feeds:
- Drone-Brute-Force
- IPv6-Sinkhole-HTTP-Drone
- A lot of newly added fields and fixed conversions.
- Optional fields can now use one column multiple times.
- Add newly added columns of
Ssl-Scanfeed to parser
- The fields
- Spamhaus CERT parser:
- fix parsing and classification for bot names 'openrelay', 'iotrdp', 'sshauth', 'telnetauth', 'iotcmd', 'iotuser', 'wpscanner', 'w_wplogin', 'iotscan' see the NEWS file - Postgresql section - for all changes.
- CleanMX phishing parser: handle FQDNs in IP column (#1162).
bots.experts.ripencc_abuse_contact: Add existing parametermodeto BOTS file.
- intelmqctl check: Fixed and extended message for 'run_mode' check.
intelmqctl startbotnet. When using--type json, no non-JSON information about wrong bots are output because that would confuse eg. intelmq-manager
- lib/bot: No dumps will be written during tests (#934).
- lib/test: Expand regular expression on python version to match pre-releases (debian testing).
- Static data is now included in source tarballs, development files are excluded
bots.collectors/outputs.xmppmust be killed two times (#970).- When running bots with
intelmqctl run [bot-id]the log level is always INFO (#1075). intelmqctl run [bot-id] message send [msg]does only support Events, not Reports (#1077).- A warning issued by the python warnings module is logged without the bot-id (#1184).
- logrotate: use sudo for postrotate script
- cron-jobs: use the scripts in the bots' directories and link them (#1056, #1142)
lib.harmonization: Handle idna encoding error in FQDN sanitation (#1175, #1176).lib.bot:- Bots stop when redis gives the error "OOM command not allowed when used memory > 'maxmemory'." (#1138).
- warnings of bots are catched by the logger (#1074, #1113).
- Fixed exitcodes 0 for graceful shutdowns .
- better handling of problems with pipeline and especially it's initialization (#1178).
- All parsers using
ParserBot's methods now log the sum of successfully parsed and failed lines at the end of each run (#1161).
- Rule for harmonization keys is enforced (#1104, #1141).
- New allowed values for
classification.type:tor&leak(see n6 parser below ).
bots.collectors.mail.collector_mail_attach: Support attachment file parsing for imbox versions newer than 0.9.5 (#1134).
- All CSV parsers ignore NULL-bytes now, because the csv-library cannot handle it (#967, #1114).
bots.parsers.shadowserver.parser: Add Accessible Cisco Smart Install (#1122).bots.parsers.cleanmx.parser: Handle new columnsfirstandlast, rewritten for XML feed. See NEWS.md for upgrade instructions (#1131, #1136, #1163).bots.parsers.n6.parser: Fix classification mappings. See NEWS file for changes values (#738, #1127).
bots.experts.modifydefault ruleset: changed conficker rule to catch more spellings.
bots.outputs.smtp.output: Fix STARTTLS, threw an exception (#1152, #1153).
Release.mdadd release procedure documentationBots.md: fix example configuration for modify expert
- intelmqctl now exits with exit codes > 0 when errors happened or the operation was not successful. Also, the status operation exits with 1, if bots are stopped, but enabled. (#977, #1143)
intelmctl checkchecks for validrun_modein runtime configuration (#1140).
tests.lib.test_pipeline: Redis tests clear all queues before and after tests (#1086).- Repaired debian package build on travis (#1169).
- Warnings are not allowed by default, an allowed count can be specified (#1129).
tests.bots.experts.cymru_whois/abusix: Skipped on travis because of ongoing problems.
- cron jobs: fix paths of executables
bots.collectors/outputs.xmppmust be killed two times (#970).- When running bots with
intelmqctl run [bot-id]the log level is always INFO (#1075). intelmqctl run [bot-id] message send [msg]does only support Events, not Reports (#1077).python3 setup.py sdistdoes not include static files in the resulting tarballs (#1146).bots.parsers.cleanmx.parser: The cleanMX feed may have FQDNs as IPs in rare cases, such lines are dumped (#1162).
lib.message.add: parameter force has finally been removed, should have been gone in 1.0.0.rc1 already
collectors.mail.collector_mail_url: Fix bug which prevented marking emails seen due to disconnects from server (#852).parsers.spamhaus.parser_cert: Handle/ignore 'AS?' in feed (#1111)
- The following changes have been in effect for the built packages already since version 1.0.0
- Support building for more distributions, now supported: CentOS 7, Debian 8 and 9, Fedora 25 and 26, RHEL 7, openSUSE Leap 42.2 and 42.3 and Tumbleweed, Ubuntu 14.04 and 16.04
- Use LSB-paths for created packages (/etc/intelmq/, /var/lib/intelmq/, /run/intelmq/) (#470). Does does not affect installations with setuptools/pip.
- Change the debian package format from native to quilt
- Fix problems in postint and postrm scripts
- Use systemd-tmpfile for creation of /run/intelmq/
- Add disclaimer on maxmind database in bot documentation and code and the cron-job (#1110)
- Feeds: use more https:// URLs
- minor fixes
- bots/experts/ripencc_abuse_contact/expert.py: Use HTTPS URLs for rest.db.ripe.net
- bots/outputs/file/output.py: properly close the file handle on shutdown
- bots/parser/shadowserver: If conversion of a value via conversion function fails, only log the function name, not the representation string (#1157).
- lib/bot: Bots will now log the used intelmq version at startup
- intelmqctl: To check the status of a bot, the command line of the running process is compared to the actual executable of the bot. Otherwise unrelated programs with the same PID are detected as running bot.
- intelmqctl: enable, disable, check, clear now support the JSON output
- Fixes a thrown
FileNotFoundexception when stopping bots started withintelmqctl run ...
- leading dots in FQDNs are rejected and removed in sanitation (#1022, #1030)
- shadowserver parser Accessible-SMB: smb_implant is converted to bool
- Changing the value of an existing field to
Nonedeletes the field. Message.updatenow behaves likedict.update. The old behavior is implemented inMessage.change- Deprecated
http_ssl_proxyhas been dropped, usehttps_proxyinstead - Deprecated
http_timeouthas been dropped, usehttp_timeout_secinstead - Deprecated parameters force and ignore of
Message.addhave been removed - Deprecated method
Message.containshas been removed - Drop support for deprecated configuration files
startup.confandsystem.conf
- We are now testing with and without optional libraries/lowest recommended versions and most current versions of required libraries
- Tests shadowserver with more data and checks for warnings and errors
- Tests: if bots log warnings this counts as failure if not allowed explicitly
- Tests: Bot preparation can be skipped
- The branching/releasing mechanism has been documented
- HTTP collectors: If
http_usernameandhttp_passwordare both given and empty or null, 'None:None' has been used to authenticate. It is now checked that the username evaluates to non-false/null before adding the authentication. (fixes #1017) - Dropped unmaintained and undocumented FTP(S) collectors
bots.collectors.ftp. Also, the FTPS collector had a license conflict (#842). bots.collectors.http.collector_http_stream: drop deprecated parameterurlin favor ofhttp_url
- Removed bots.parsers.openbl as the source is offline since end of may (#1018, https://twitter.com/sshblorg/status/854669263671615489)
- Removed bots.parsers.proxyspy as the source is offline (#1031)
- Shadowserver: Added Accessible SMB
bots.experts.ripencc_abuse_contactnow has the two additional parametersquery_ripe_stat_asnandquery_ripe_stat_ip. Deprecated parameterquery_ripe_stat. New parametermode.bots.experts.certat_contacthas been renamed tobots.experts.national_cert_contact_certat(#995)bots.experts.cymru_whoisignores registryother(#996)bots.parsers.alienvault.parser_otx: handle timestamps without floating point seconds
- bots.experts.deduplicator: New parameter
bypassto deactivate deduplication, default: False
- It's now configurable how often the bots are logging how much events they have sent, based on both the amount and time. (fixes #743)
- switch from pycodestyle to pep8
- Added
log_processed_messages_count(500) andlog_processed_messages_seconds(900) to defaults.conf. http_timeouthas been renamed tohttp_timeout_secandhttp_timeout_max_trieshas been added. This setting is honored bybots.collectors.http.*andbots.collectors.mail.collector_mail_url,bots.collectors.rt(onlyhttp_timeout_sec),bots.outputs.restapi.outputandbots.experts.ripencc_abuse_contact.
- Minor fixes
- Dropped install scripts, see INSTALL.md for more detailed instructions and explanations
- Better structure of INSTALL.md
- Better documentation of packages
- added a bot debugger (#975)
- missing bot executable is detected and handled by intelmqctl (#979)
- fix bug which prevented dumps to be written if the file did not exist (#986)
- Fix reload of bots regarding logging
- type annotations for all core libraries
- added
bots.experts.idea, bots.outputs.files - possibility to split large csv Reports into Chunks, currently possible for mail url and file collector
- elasticsearch output supports HTTP Basic Auth
bots.collectors.mail.collector_mail_urland bots collectors.file.collector can split large reports (#680)bots.parsers.shadowserversupport the VNC feed- handling of HTTP timeouts, see above #859
bots.parsers.bambeneksaves the malware namebots.parsers.fraunhofer.parser_dgasaves the malware namebots.parsers.shadowserverhandles NULL bytesbots.parsers.abusech.parser_ransomwarehandles the IP 0.0.0.0 specially
- New field named
outputto support export to foreign formats
- more verbose installation and upgrade instructions
bots.collectors.alienvault_otx: OTX library has been removed, install it as package instead
- API keys will be removed from feed.url if possible
intelmq.bots.parsers.shadowserver.config:- Added support for Compromised-Website, Open-Netis, NTP-Version, Sandbox-URL, Spam-URL, Vulnerable-ISAKMP, Botnet-CCIP, Accessible-RDP, Open-LDAP, Blacklisted-IP, Accessible-Telnet, Accessible-CWMP (#748).
- added
bots.experts.field_reducer,bots.outputs.smtp. bots.experts.deduplicator:ignore_keyshas been renamed tofilter_keysandfilter_typehas been removed.bots.experts.modify: The configuration is now list-based for a consistent ordering.bots.experts.tor_nodeas an optional parameteroverwrite.
- New parameter and field named feed.documentation to link to documentation of the feed
classification.taxonomyis lower case only
Changes between 0.9 and 1.0.0.dev6
- Dropped support for Python 2, Python >= 3.3 is needed
- Dropped startup.conf and system.conf. Sections in BOTS can be copied directly to runtime.conf now.
- Support two run modes: 'stream' which is the current implementation and a new one 'scheduled' which allows scheduling via cron or systemd.
- Helper classes for parser bots
- moved intelmq/conf to intelmq/etc
- cleanup in code and repository
- All bots capable of reloading on SIGHUP
- packages
- pip wheel format instead of eggs
- unittests for library and bots
- bots/BOTS now contains only generic and specific collectors. For a list of feeds, see docs/Feeds.md
- DEV:
intelmq_gen_harm_docs: added to generate Harmonization documentation intelmq_psql_initdb: creates a table for a postgresql database using the harmonization fields- intelmqctl: reworked argument parsing, many bugfixes
- intelmqdump: added to inspect dumped messages and reinsert them into the queues
- DEV:
rewrite_config_files: added to rewrite configuration files with consistent style
- added alienvault, alienvault otx, bitsight, blueiv, file, ftp, misp, n6, rtir, xmpp collector
- removed hpfeeds collector
- removed microsoft DCU collector
- renamed and reworked URL collector to HTTP
- reworked Mail collectors
- source specific parsers added: abusech, alienvault, alienvault otx, anubisnetworks, autoshun, bambenek, bitcash, bitsight, blocklistde, blueliv, ci army, cleanmx, cymru_full_bogons, danger_rulez, dataplane, dshield (asn, block and domain), dyn, fraunhofer_dga, hphosts, malc0de, malwaredomains, misp, n6, netlab_360, nothink, openphish, proxyspy, spamhaus cert, taichung, turris, urlvir
- generic parsers added: csv, json
- specific parsers dropped: abusehelper (broken), arbor (source unavailable), bruteforceblocker, certeu, dragonresearchgroup parser (discontinued), hpfeeds, microsoft_dcu (broken), taichungcitynetflow, torexitnode parser
- renamed
intelmq.bots.parsers.spamhaus.parsertointelmq.bots.parsers.spamhaus.parser_drop. renamedintelmq.bots.parsers.malwarepatrol.parser-dansguardian tointelmq.bots.parsers.malwarepatrol.parser_dansguardian` - renamed
intelmq.bots.parsers.taichungcitynetflow.parser tointelmq.bots.parsers.taichung.parser` - major rework of shadowserver parsers
- enhanced all parsers
- Added experts: asnlookup, cert.at contact lookup, filter, generic db lookup, gethostbyname, modify, reverse dns, rfc1918, tor_nodes, url2fqdn
- removed experts: contactdb, countrycodefilter (obsolete), sanitizer (obsolete)
- renamed
intelmq.bots.expers.abusix.abusixtointelmq.bots.expers.abusix.expertintelmq.bots.experts.asnlookup.asnlookuptointelmq.bots.experts.asn_lookup.expertintelmq.bots.experts.cymru.experttointelmq.bots.experts.cymru_whois.expertintelmq.bots.experts.deduplicator.deduplicatortointelmq.bots.experts.deduplicator.expertintelmq.bots.experts.geoip.geopiptointelmq.bots.experts.maxmind_geoip.expertintelmq.bots.experts.ripencc.ripencctointelmq.bots.experts.ripencc_abuse_contact.expertintelmq.bots.experts.taxonomy.taxonomytointelmq.bots.experts.taxonomy.expert - enhanced all experts
- changed configuration syntax for
intelmq.bots.experts.modifyto a more simple variant
- added: amqp, elasticsearch, redis, restapi, smtp, stomp, tcp, udp, xmpp
- removed: debug, intelmqmailer (broken), logcollector
- enhanced all outputs
- FIX: all bots handle message which are None
- FIX: various encoding issues resolved in core and bots
- FIX: time.observation is generated in collectors, not in parsers
- TST: testing framework for core and tests. Newly introduced components should always come with proper unit tests.
- ENH: intelmqctl has shortcut parameters and can clear queues
- STY: code obeys PEP8, new code should always be properly formatted
- DOC: Updated user and dev guide
- Removed Message.contains, Message.update methods Message.add ignore parameter
- ENH: New parameter and field named accuracy to represent the accuracy of each feed
- Consistent naming "overwrite" to switch overwriting capabilities of bots (as opposed to override)
- Renamed
http_ssl_proxytohttps_proxy - parameter
hierarchical_outputfor many output bots - deduplicator bot has a new required parameter to configure deduplication mode
filter_type - deduplicator bot key ignore_keys was renamed to filter_keys
- The tor_nodes expert has a new parameter
overwrite, which is by defaultfalse.
- ENH: Additional data types: integer, float and Boolean
- ENH: Added descriptions and matching types to all fields
- DOC: harmonization documentation has same fields as configuration, docs are generated from configuration
- BUG: FQDNs are only allowed in IDN representation
- ENH: Removed UUID Type (duplicate of String)
- ENH: New type LowercaseString and UppercaseString, doing automatic conversion
- ENH: Removed UUID Type (duplicate of String)
- ENH: FQDNs are converted to lowercase
- ENH: regex, iregex and length checks when data is added to messages
(source|destination).bgp_prefixis now(source|destination).network(source|destination).ccis now(source|destination).geolocation.cc(source|destination).reverse_domain_nameis(source|destination).reverse_dns(source|destination).abuse_contactis lower case onlymisp_idchanged tomisp.event_uuidprotocol.transportadded, a fixed list of values is allowedprotocol.applicationis lower case onlywebshot_urlis nowscreenshot_urladditional_informationrenamed toextra, must be JSONos.name,os.version,user_agentremoved in favor ofextra- all hashes are lower case only
- added
malware.hash.(md5|sha1|sha256), removedmalware.hash - New parameter and field named feed.accuracy to represent the accuracy of each feed
- New parameter and field named feed.provider to document the name of the source of each feed
- New field
classification.identifier-classification.taxonomyis now lower case only
- Harmonization: hashes are not normalized and classified, see also issue #394 and pull #634
- ansible and vagrant scripts added
- bash-completion for shells add
- cron job scripts to update lookup data added
- logcheck example rules added
- logrotate configuration added
- improvements in pipeline:
- PipelineFactory to give possibility to easily add a new broker (Redis, ZMQ, etc..)
- Splitter feature: if this option is enable, will split the events in source queue to multiple destination queues
- add different messages support:
- the system is flexible to define a new type of message like 'tweet' without change anything in bot.py, pipeline.py. Just need to add a new class in message.py and harmonization.conf
- add harmonization support
- in harmonization.conf is possible to define the fields of a specific message in json format.
- the harmonization.py has data types witch contains sanitize and validation methods that will make sure that the values are correct to be part of an event.
- Error Handling
- multiple parameters in configuration which gives possibility to define how bot will handle some errors. Example of parameters:
error_procedure- retry or pass in case of errorerror_retry_delay- time in seconds to retryerror_max_retries- number of retrieserror_log_message- log or not the message in error logerror_log_exception- log or not the exception in error logerror_dump_message- log or not the message in dump log to be fixed and re-insert in pipeline
- Exceptions
- custom exceptions for IntelMQ
- Defaults configurations
- new configuration file to specify the default parameters which will be applied to all bots. Bots can overwrite the configurations.
- New bots/feeds
- fixed the license to AGPL in setup.py
- moved back the documentation from the wiki repo to
docs/. See #205. - added python-zmq as a setup requirement in UserGuide . See #206