Configuring MISP
How to set MISP configuration options
Using the MISP Puppet module
The recommended way of configuring MISP is via the MISP Puppet module available on GitHub Voxpopuli.
The MISP class can take many parameters to change the configuration of MISP. However, they all have the default value set to the recommended value so there is no need to change many of them. The parameters can be classified in the ones needed for the installation of MISP itself, for the database, for the configuration and for the services. Of course Hiera can also be used for changing the value of the different parameters.
Wherever possible the names of the parameters for the misp
Puppet class follows the names of the configuration options used in the various configuration files.
By editing the configuration file
All the configuration options are stored in different files located in the configuration directory (by default /<install_dir>/app/Config/
): core.php
, bootstrap.php
, database.php
and config.php
.
From the web UI
From the web UI you can navigate to Administration -> Server settings and from there change between the various tabs. By double clicking the value of a setting you can change it. After changing the value you need to press the tick button to validate the change and have it stored in the configuration file.
Configuration settings
Below you can find the various parameters supported by the misp
Puppet class with a description of each of them. As mentioned above, wherever possible the names of the parameters for the misp
Puppet class follows the names of the configuration options used in the various configuration files. You can use the documentation below as a reference on how to best configure MISP.
Redis
redis_host
- The host running the Redis server to be used for generic MISP tasks such as caching. This is not to be confused by the Redis server used by the background processing. By default set to localhost (127.0.0.1
).redis_port
- The port used by the Redis server to be used for generic MISP tasks such as caching. This is not to be confused by the Redis server used by the background processing. By default set to6379
.redis_database
- The database on the Redis server to be used for generic MISP tasks. If you run more than one MISP instance or if you use Redis for multiple applications, please make sure to use a different database on each instance. By default set to13
.
MISP configuration
Site configuration
debug
- Debug mode for the full instance. By default set to0
(false
).site_admin_debug
- The debug level of the instance for site admins. This feature allows site admins to run debug mode on a live instance without exposing it to other users. The most verbose option ofdebug
andsite_admin_debug
is used for site admins. By default this is set tofalse
.
These two parameters are recommended to be set to 0
and false
respectively. However, if needed they can be set to true
to find errors with names / tables in the database. In this case it would be better to just set to true site_admin_debug
instead of the whole instance.
Security
security_level
- The level of CakePHP security, by default set tomedium
.salt
- The salt used for the hashed passwords. Keep in mind that the salt this will invalidate all passwords in the database. By default set toRooraenietu8Eeyo<Qu2eeNfterd-dd+
. Make sure to change it before importing the DB schema and before accessing the MISP web UI for the first time.cipherseed
- Seed for the cipher. Empty by default.auth_method
- Authentication method used for the instance. Empty means default user-password login method. Empty by default.password_policy_length
- Password length requirement. By default set to6
.password_policy_complexity
- Password complexity requirement. By default set to/((?=.\d)|(?=.\W+))(?![\n])(?=.[A-Z])(?=.[a-z]).*$/
.sanitise_attribute_on_delete
- Enabling this setting will sanitise the contents of an attribute on a soft delete. By default set tofalse
.hide_organisation_index_from_users
- Enabling this setting will block the organisation index from being visible to anyone besides site administrators on the current instance. Keep in mind that users can still see organisations that produce data via events, proposals, event history log entries, etc. By default is set to false.
MISP
live
- If set tofalse
the instance will only be accessible by site admins. By defaulttrue
.language
- The language MISP should use. The default is english.enable_advanced_correlations
- Enable some performance heavy correlations (currently CIDR correlation). By defaultfalse
.max_correlations_per_event
- Sets the maximum number of correlations that can be fetched with a single event. For extreme edge cases this can prevent memory issues. The default value is 5000.maintenance_message
- The message that users will see if the instance is not live. By default set toGreat things are happening! MISP is undergoing maintenance, but will return shortly. You can contact the administration at \$email.
.footermidleft
- Footer text prepending the "Powered by MISP" text. Empty by default.footermidright
- Footer text following the "Powered by MISP" text. Empty by default.footer_logo
- This setting allows you to display a logo on the right side of the footer. Empty by default.home_logo
- If set, this setting allows you to display a logo as the home icon. Upload it as a custom image in the file management tool. Empty by default.main_logo
- If set, the image specified here will replace the main MISP logo on the login screen. Upload it as a custom image in the file management tool. Empty by default.org
- The organisation tag of the hosting organisation. This is used in the e-mail subjects. By default set toORGNAME
.host_org_id
- The hosting organisation of this instance. If this is not selected then replication instances cannot be added. By default is set to1
, meaning the first organisation in the system.showorg
- Setting this setting tofalse
will hide all organisation names / logos. By default set to true.extended_alert_subject
- Enabling this flag will allow the event description to be transmitted in the alert e-mail's subject. By default set totrue
.threatlevel_in_email_subject
- Put the event threat level in the notification e-mail subject. By default set totrue
.email_subject_tlp_string
- This is the TLP string in alert e-mail sent when an event is published. By defaultTLP Amber
.email_subject_tag
- If this tag is set on an event its value will be sent in the e-mail subject. If the tag is not set theemail_subject_TLP_string
will be used. By default set totlp
.email_subject_include_tag_name
- Include the name of theemail_subject_tag
tag in the subject. Whenfalse
only the tag value is used. By default set tofalse
.email
- The e-mail address that MISP should use for all notifications. By defaultroot@localhost
.disable_emailing
- When enabled, no outgoing e-mails will be sent by MISP. By default set tofalse
.cached_attachments
- Allow the XML caches to include the encoded attachments. By default set totrue
.download_attachments_on_load
- Always download attachments when loaded by a user in a browser.contact
- The e-mail address that MISP should include as a contact address for the instance's support team. By defaultroot@localhost
.background_jobs
- Enables the use of MISP's background processing. By default set totrue
.cveurl
- Turns vulnerability type attributes into links linking to the provided CVE lookup. By default set tohttp://cve.circl.lu/cve/
.disablerestalert
- When enabled notification e-mails will not be sent when an event is created via the REST interface. By default set tofalse
.default_event_distribution
- The default distribution setting for events (0-3
).0
means your organisation only,1
means this community only,2
means contacted communities and3
is all communities. By default set to1
.default_attribute_distribution
- The default distribution setting for attributes, set it toevent
if you would like the attributes to default to the event distribution level (0-3
orevent
). By default set toevent
.default_event_threat_level
- The default threat level setting when creating events. By default set to1
.tagging
- Enable the tagging feature of MISP. By default set totrue
.full_tags_on_event_index
- Show the full tag names on the event index. By default set totrue
.welcome_text_top
- Used on the login page, before the MISP logo. Empty by default.welcome_text_bottom
- Used on the login page, after the MISP logo. Empty by default.welcome_logo
- Used on the login page, to the left of the MISP logo, upload it as a custom image in the file management tool. Empty by default.welcome_logo2
- Used on the login page, to the right of the MISP logo, upload it as a custom image in the file management tool. Empty by default.title_text
- Used in the page title, after the name of the page. By default is set to 'MISP'.take_ownership_xml_import
- Allows users to take ownership of an event uploaded via the "Add MISP XML" button. By default set tofalse
.terms_download
- Choose whether the terms and conditions should be displayed inline (false
) or offered as a download (true
). By default set to false.terms_file
- The filename of the terms and conditions file. Make sure that the file is located in yourMISP/app/files/terms
directory. Empty by default.showorgalternate
-True
enables the alternate org fields for the event index (source org and member org) instead of the traditional way of showing only an org field. By default set tofalse
.unpublishedprivate
-True
will deny access to unpublished events to users outside the organisation of the submitter except site admins. By default set tofalse
.new_user_text
- The message sent to the user after an account creation. By default set toDear new MISP user,\n\nWe would hereby like to welcome you to the \$org MISP community.\n\n Use the credentials below to log into MISP at \$misp, where you will be prompted to - manually change your password to something of your own choice.\n\nUsername: \$username\nPassword: \$password\n\nIf you have any questions, don't hesitate to contact us at: \$contact.\n\nBest regards,\nYour \$org MISP support team
.password_reset_text
- The message sent to the users when a password reset is triggered.By default set to Dear MISP user,\n\nA password reset has been triggered for your account. Use the below provided temporary password to log into MISP at \$misp, where you will be - prompted to manually change your password to something of your own choice.\n\nUsername: \$username\nYour temporary password: \$password\n\nIf you have any questions, don't hesitate to contact us at: \$contact.\n\nBest regards,\nYour \$org MISP support team
.enable_event_blacklisting
- Enable the blacklisting of event UUIDs to prevent them from being pushed to your instance. By default set totrue
.enable_org_blacklisting
- Enable blacklisting of organisation UUIDs to prevent them from creating events. By default set totrue
.log_client_ip
- All log entries will include the IP address of the user. By default set totrue
.log_auth
- MISP will log all successful authentications using API keys. By default set tofalse
.mangle_push_to_23
- When enabled, your 2.4+ instance can push events to MISP 2.3 installations. This is highly advised against and will result in degraded events and lost information. Use this at your own risk. By default set tofalse
.delegation
- This feature allows users to created org only events and ask another organisation to take ownership of the event. This allows organisations to remain anonymous by asking a partner to publish an event for them. By default set tofalse
.ssdeep_correlation_threshold
- Set the ssdeep score at which to consider two ssdeep hashes as correlating [1-100].show_correlations_on_index
- When enabled, the number of correlations visible to the currently logged in user will be visible on the event index UI. This comes at a performance cost but can be very useful to see correlating events at a glance. By default set tofalse
.show_proposals_count_on_index
- When enabled, the number of proposals for the events are shown on the index. By default set tofalse
.show_sightings_count_on_index
- When enabled, the aggregate number of attribute sightings within the event becomes visible to the currently logged in user on the event index UI. By default set tofalse
.show_discussions_count_on_index
- When enabled, the aggregate number of discussion posts for the event becomes visible to the currently logged in user on the event index UI. By default set tofalse
.disable_user_self_management
- When enabled only Org and Site admins can edit a user's profile. By default set tofalse
.block_event_alert
- Enable this setting to start blocking alert e-mails for events with a certain tag. Define the tag inblock_event_alert_tag
. By default set tofalse
.block_event_alert_tag
- If theblock_event_alert
setting is set, alert e-mails for events tagged with the tag defined by this setting will be blocked. By default set tono-alerts="true"
.block_old_event_alert
- Enable this setting to start blocking alert e-mails for old events. By default set tofalse
.block_old_event_alert_age
- This setting will control how old an event can be for it to be alerted on, measured in days. By default set to30
.rh_shell_fix
- If you are running CentOS or RHEL using SCL and are having issues with the Background workers not responding to start / stop / restarts via the worker interface, enable this setting. This will pre-pend the shell execution commands with the default path to -rh-php56
(/opt/rh/rh-php56/root/usr/bin:/opt/rh/rh-php56/root/usr/sbin
). By default set tofalse
.rh_shell_fix_path
- If you haverh_shell_fix
enabled, the defaultPATH
forrh-php56
is added (/opt/rh/rh-php56/root/usr/bin:/opt/rh/rh-php56/root/usr/sbin
). If you prefer to use a different path, you can set it here. By default set to/opt/rh/rh-php56/root/usr/bin:/opt/rh/rh-php56/root/usr/sbin
.tmpdir
- Please indicate the temp directory you wish to use for certain functionalities in MISP. By default this is set to/tmp
and will be used among others to store certain temporary files extracted from imports during the import process.custom_css
- If you would like to customise the css, simply drop a css file in the/var/www/MISP/webroot/css
directory and enter the name here. Empty by default.proposals_block_attributes
- Enable this setting to allow blocking attributes fromto_ids
sensitive exports if a proposal has been made to it to remove the IDS flag or to remove the attribute altogether. This is a powerful tool to deal with false-positives efficiently. By default set totrue
.incoming_tags_disabled_by_default
- Enable this settings if new tags synced / added via incoming events from any source should not be selectable by users by default. By default set tofalse
.completely_disable_correlation
- WARNING This setting will completely disable the correlation on this instance and remove any existing saved correlations. Enabling this will trigger a full recorrelation of all data which is an extremely long and costly procedure. Only enable this if you know what you're doing. By default set tofalse
.allow_disabling_correlation
- WARNING This setting will give event creators the possibility to disable the correlation of individual events / attributes that they have created. By default set tofalse
.event_view_filter_fields
* - Specify which fields to filter on when you search on the event view. Default values are : "id, uuid, value, comment, type, category, Tag.name"deadlock_avoidance
* - Only enable this if you have some tools using MISP with extreme high concurency. General performance will be lower as normal as certain transactional queries are avoided in favour of shorter table locks.syslog
- Enable this setting to pass all audit log entries directly to syslog. Keep in mind, this is verbose and will include user, organisation, event data. By default is set to false.
GPG
gpg_binary
- The location of the GPG executable. If you would like to use a differentgpg
executable than/usr/bin/gpg
, you can set it here. If the default is fine, just keep the setting suggested by MISP. By default set to/usr/bin/gpg
.gpg_onlyencrypted
- Allow (false) unencrypted e-mails to be sent to users that don't have a PGP key. By default set tofalse
.gpg_email
- The e-mail address that the instance's PGP key is tied to. By defaultno-reply@localhost
.gpg_homedir
- The location of the GPG homedir. By default/var/www/MISP/.gnupg
.gpg_password
- The password (if it is set) of the PGP key of the instance. Empty by default.gpg_bodyonlyencrypted
- Allow (false
) the body of unencrypted e-mails to contain details about the event. By default set tofalse
.
SMIME
smime_enabled
- Enable SMIME encryption. By default set tofalse
.smime_email
- The e-mail address that the instance's SMIME key is tied to. Empty by default.smime_cert_public_sign
- The location of the public half of the signing certificate. Empty by default.smime_key_sign
- The location of the private half of the signing certificate. Empty by default.smime_password
- The password (if it is set) of the SMIME key of the instance. Empty by default.
Proxy
proxy_host
- The hostname of an HTTP proxy for outgoing sync requests. Leave empty to not use a proxy. Empty by default.proxy_port
- The TCP port for the HTTP proxy. Empty by default.proxy_method
- The authentication method for the HTTP proxy. Currently supported are Basic or Digest. Empty by default.proxy_user
- The authentication username for the HTTP proxy. Empty by default.proxy_password
- The authentication password for the HTTP proxy. Empty by default.
SecureAuth
secure_auth_amount
- The number of tries a user can try to login and fail before the bruteforce protection kicks in. By default set to5
.secure_auth_expire
- The duration (in seconds) of how long the user will be locked out when the allowed number of login attempts are exhausted. By default set to300
.
Session
session_auto_regenerate
- Set to true to automatically regenerate sessions on activity (recommended). By default set tofalse
.session_defaults
- The session type used by MISP. The default setting isphp
, which will use the session settings configured inphp.ini
for the session data (supported options:php
,database
). The recommended option isphp
and setting your PHP up to use redis sessions via yourphp
.ini. Just addsession.save_handler = redis
andsession.save_path = 'tcp://localhost:6379'
(replace the latter with your redis connection) to. By default set tophp
.session_timeout
- The timeout duration of sessions (in minutes). Keep in mind that autoregenerate can be used to extend the session on user activity. By default set to60
.session_cookie_timeout
- The expiration of the cookie (in MINUTES). The session timeout gets refreshed frequently, however the cookies do not. Generally it is recommended to have a much higher cookie_timeout than timeout.
Plugins
RPZ
rpz_policy
- The default policy action for the values added to the RPZ.0
meansDROP
,1
meansNXDOMAIN
,2
meansNODATA
and3
is used for walled-garden. By default set to0
.rpz_walled_garden
- The default walled garden used by the RPZ export. By default set to127.0.0.1
.rpz_serial
- The serial in the SOA portion of the zone file. By default set to$date00
.rpz_refresh
- The refresh specified in the SOA portion of the zone file. By default set to2h
.rpz_retry
- The retry specified in the SOA portion of the zone file. By default set to30m
.rpz_expiry
- The expiry specified in the SOA portion of the zone file. By default set to30d
.rpz_minimum_ttl
- The minimum TTL specified in the SOA portion of the zone file. By default set to1h
.rpz_ttl
- The TTL of the zone file. By default set to1w
.rpz_ns
- The RPZ ns. By default set tolocalhost
.rpz_email
- The e-mail address specified in the SOA portion of the zone file. By default set toroot.localhost
.
ZeroMQ
zeromq_enable
- Enables or disables the pub / sub feature of MISP. By default set tofalse
.zeromq_port
- The port that the pub / sub feature will use. By default set to50000
.zeromq_redis_host
- Location of the Redis DB used by MISP and the Python PUB script to queue data to be published. By default set tolocalhost
.zeromq_redis_port
- The port that Redis is listening on. By default set to6379
.zeromq_redis_password
- The password, if set for Redis. Empty by default.zeromq_redis_database
- The database to be used for queuing messages for the pub / sub functionality. By default set to1
.zeromq_redis_namespace
- The namespace to be used for queuing messages for the pub / sub functionality. By default set tomispq
.zeromq_include_attachments
- Enable this setting to include the base64 encoded payloads of malware-samples/attachments in the output.zeromq_event_notifications_enable
- Enables or disables the publishing of any event creations/edits/deletions. By default is set to false.zeromq_object_notifications_enable
- Enables or disables the publishing of any object creations/edits/deletions. By default is set to false.zeromq_object_reference_notifications_enable
- Enables or disables the publishing of any object reference creations/deletions. By default is set to false.zeromq_attribute_notifications_enable
- Enables or disables the publishing of any attribute creations/edits/soft deletions. By default is set to false.zeromq_tag_notifications_enable
- Enables or disables the publishing of any tag creations/edits/deletions as well as tags being attached to / detached from various MISP elements.zeromq_audit_notifications_enable
- Enables or disables the publishing of log entries to the ZMQ pubsub feed. Keep in mind, this can get pretty verbose depending on your logging settings. By default its set to false.
Sightings
sightings_anonymise
- Enabling the anonymisation of sightings will simply aggregate all sightings instead of showing the organisations that has reported a sighting. By default set tofalse
.sightings_policy
- This setting defines who will have access to seeing the reported sightings.0
means event owner,1
event owner and sighting reporter and2
means everyone. By default set to0
.sightings_enable
- When enabled, users can use the UI or the appropriate APIs to submit sightings data about indicators. By default set tofalse
.sightings_range
- Set the range in which sightings will be taken into account when generating graphs. For example a sighting with asighted_date
of7
years ago might not be relevant anymore. Setting given in number of days, default is365
days.
Custom Authentication
customauth_enable
- Enable this functionality if you would like to handle the authentication via an external tool and authenticate to MISP using a custom header. By default set tofalse
.customauth_header
- Set the header that MISP should look for here. If left empty it will default to theAuthorization
header. By default set toAuthorization
.customauth_use_header_namespace
- Use a header namespace for the auth header - default setting isenabled
.customauth_required
- If this setting is enabled then the only way to authenticate will be using the custom header. Alternatively you can run in mixed mode that will log users in via the header if found, otherwise users will be redirected to the normal login page. By default set tofalse
.customauth_only_allow_source
- If you are using an external tool to authenticate with MISP and would like to only allow the tool's URL as a valid point of entry then set this field. Empty by default.customauth_name
- The name of the authentication method, this is cosmetic only and will be shown on the user creation page and logs. By default set toExternal authentication
.customauth_disable_logout
- Disable the logout button for users authenticate with the external auth mechanism. By default set totrue
.customauth_custom_password_reset
- Provide your custom authentication users with an external URL to the authentication system to reset their passwords. Empty by default.customauth_custom_logout
- Provide a custom logout URL for your users that will log them out using the authentication system you use. Empty by default.
Enrichment
enrichment_services_enable
- Enable / disable the enrichment services. By default set totrue
.enrichment_services_url
- The URL used to access the enrichment services. By default set tohttp://127.0.0.1
.enrichment_services_port
- The port used to access the enrichment services. By default set to6666
.enrichment_timeout
- Set a timeout for the enrichment services. By default set to10
.enrichment_hover_enable
- Enable / disable the hover over information retrieved from the enrichment modules. By default set totrue
.enrichment_hover_timeout
- Set a timeout for the hover services. By default set to5
.
Export
export_services_enable
- Enable / disable the import services. By default set totrue
.export_services_url
- The URL used to access the export services. By default set tohttp://127.0.0.1
.export_services_port
- The port used to access the export services. By default set to6666
.export_timeout
- Set a timeout for the import services. By default set to10
.
Import
import_services_enable
- Enable / disable the import services. By default set totrue
.import_services_url
- The url used to access the import services. By default set tohttp://127.0.0.1
.import_services_port
- The port used to access the import services. By default set to6666
.import_timeout
- Set a timeout for the import services. By default set to10
.
Cortex
cortex_services_enable
- Enable / disable the import services. By default set tofalse
.cortex_services_url
- The URL used to access Cortex. By default, it is accessible athttp://cortex-url/api
.cortex_services_port
- The port used to access Cortex. By default, this is port9000
.cortex_authkey
- Set an authentication key to be passed to Cortex.cortex_timeout
- Set a timeout for the import services. By default set to120
.cortex_ssl_verify_peer
- Set to false to disable SSL verification. This is not recommended.cortex_ssl_verify_host
- Set to false if you wish to ignore hostname match errors when validating certificates.cortex_ssl_allow_self_signed
- Set to true to enable self-signed certificates to be accepted. This requirescortex_ssl_verify_peer
to be enabled.cortex_ssl_cafile
- Set to the absolute path of the Certificate Authority file that you wish to use for verifying SSL certificates.
Apache Shibboleth Authentication
shib_default_org
- ID of the default organisation for user creation when using the Shibboleth authentication plugin. By default set to1
.shib_use_default_org
- Whether to use the default organisation for the users on the local MISP instance.egroup_role_match
- Group to role mapping used for authorisation when using the Shibboleth authentication plugin. Empty by default ({}
).
Services
webservername
- The name of the service of the web server on top of which MISP is running. By defaulthttpd
.redis_server
- If the Redis database will be hosted locally or not, meaning that the Redis server will be installed. By defaulttrue
.