Frequently Asked Questions
Table of contents
- How to install a specific version?
- How to change my stack’s configuration?
- I am having some warnings while launching docker-compose up for the first time
- What is the use of the I_AM_DEVELOPER_DISABLE_INDEX_IP_CHECK environment variable?
- How to access My application’s frontend?
- How to switch between dev/prod/xdebug environments? (experimental)
- How to configure the mailer in the parameters.yml file?
- How to configure the websocket service in the parameters.yml file?
- How to configure the database service in the parameters.yml file?
- How to configure the search engine service in the parameters.yml file?
- How to configure the message queue service in the parameters.yml file?
- How to enable ElasticStack logging
- How to access to Mailcatcher’s interface?
- How to access RabbitMQ manager’s interface?
- How to access Dejavu’s interface for Elasticsearch?
- How to access Elasticsearch’s API?
- How to access Kibana’s interface?
- How to access Redis service from your computer?
- How to access MySQL or PostgreSQL service from your computer?
How to install a specific version?
Versions available are : 1.0, 1.1 and 1.2
Example for 1.2.2
sudo curl -L -o /usr/local/bin/kloud https://github.com/kiboko-labs/kloud/releases/download/1.2.2/kloud.phar
sudo curl -L -o /usr/local/bin/kloud.pubkey https://github.com/kiboko-labs/kloud/releases/download/1.2.2/kloud.phar.pubkey
sudo chmod +x /usr/local/bin/kloud
How to change my stack’s configuration?
kloud stack:upgrade
I am having some warnings while launching docker-compose up
for the first time
If you are having this sort of messages:
WARNING: The MAILCATCHER_PORT variable is not set. Defaulting to a blank string.
ERROR: The Compose file './docker-compose.yml' is invalid because:
services.mail.ports contains an invalid type, it should be a number, or an object
Those warnings and errors are due to missing environment variables, probably because you did
not copy the .env.dist
file to a .env
file, or you juste made a stack:upgrade
and some
new environment variables are required.
What is the use of the I_AM_DEVELOPER_DISABLE_INDEX_IP_CHECK
environment variable?
This environment variable is used to disable the IP check in the public/index_dev.php
file.
To benefit from this feature, you will need to apply the following patch:
Index: public/index_dev.php
IDEA additional info:
Subsystem: com.intellij.openapi.diff.impl.patch.CharsetEP
<+>UTF-8
===================================================================
--- public/index_dev.php
+++ public/index_dev.php
@@ -13,9 +13,12 @@
// This check prevents access to debug front controllers that are deployed by accident to production servers.
// Feel free to remove this, extend it, or make something more sophisticated.
-if (isset($_SERVER['HTTP_CLIENT_IP'])
- || isset($_SERVER['HTTP_X_FORWARDED_FOR'])
- || !in_array(@$_SERVER['REMOTE_ADDR'], array('127.0.0.1', 'fe80::1', '::1'))
+if (!isset($_ENV['I_AM_DEVELOPER_DISABLE_INDEX_IP_CHECK'])
+ && (
+ isset($_SERVER['HTTP_CLIENT_IP'])
+ || isset($_SERVER['HTTP_X_FORWARDED_FOR'])
+ || !in_array(@$_SERVER['REMOTE_ADDR'], array('127.0.0.1', 'fe80::1', '::1'))
+ )
) {
header('HTTP/1.0 403 Forbidden');
exit('You are not allowed to access this file. Check '.basename(__FILE__).' for more information.');
How to access My application’s frontend?
The application frontend can be accessed through the port defined in the HTTP_PORT
environment variable value.
How to switch between dev/prod/xdebug environments? (experimental)
We have built a Firefox/Chrome plugin to help you switch between environments.
This extension is currently experimental and is limited to a few domain names. It may fit your needs as is, but be aware that you may need to manually package the extension if you need other domain names.
How to configure the mailer in the parameters.yml
file?
The parameters should be set as the following:
parameters:
mailer_transport: smtp
mailer_host: mail
mailer_port: 1025
mailer_encryption: null
mailer_user: null
mailer_password: null
Notice that the MAILER_PORT
variable is not used, as this port is the one from your
computer’s point of view, not a container’s point of view in the stack.
How to configure the websocket service in the parameters.yml
file?
The parameters should be set as the following on Oro 4.1+:
parameters:
websocket_bind_address: 0.0.0.0
websocket_bind_port: 8080
websocket_frontend_host: '*'
websocket_frontend_port: '%env(WEBSOCKET_PORT)%'
websocket_frontend_path: ''
websocket_backend_host: '*'
websocket_backend_port: '%env(WEBSOCKET_PORT)%'
websocket_backend_path: ''
websocket_backend_transport: tcp
websocket_backend_ssl_context_options: { }
Notice that the WEBSOCKET_PORT
variable is not used for the websocket_bind_port
, as this
port is the one from your computer’s point of view, not a container’s point of view in the stack.
How to configure the database service in the parameters.yml
file?
The parameters should be set as the following on Oro 4.1+:
parameters:
database_driver: pdo_pgsql
database_host: sql
database_port: null
database_name: '%env(DATABASE_NAME)%'
database_user: '%env(DATABASE_USER)%'
database_password: '%env(DATABASE_PASS)%'
database_driver_options: { }
Notice that the DATABASE_PORT
variable is not used, as this port is the one from your
computer’s point of view, not a container’s point of view in the stack.
How to configure the search engine service in the parameters.yml
file?
The parameters should be set as the following:
parameters:
search_engine_name: elastic_search
search_engine_host: elasticsearch
search_engine_port: null
search_engine_index_prefix: oro_search
search_engine_username: null
search_engine_password: null
search_engine_ssl_verification: null
search_engine_ssl_cert: null
search_engine_ssl_cert_password: null
search_engine_ssl_key: null
search_engine_ssl_key_password: null
website_search_engine_index_prefix: oro_website_search
Notice that the ELASTICSEARCH_PORT
variable is not used, as this port is the one from your
computer’s point of view, not a container’s point of view in the stack.
How to configure the message queue service in the parameters.yml
file?
The parameters should be set as the following:
parameters:
message_queue_transport: amqp
message_queue_transport_config:
host: amqp
port: '5672'
user: '%env(RABBITMQ_USER)%'
password: '%env(RABBITMQ_PASSWORD)%'
vhost: /
Notice that the ELASTICSEARCH_PORT
variable is not used, as this port is the one from your
computer’s point of view, not a container’s point of view in the stack.
How to enable ElasticStack logging
To integrate ElasticStack in your monolog config, you will need to change your config/config_dev.yml
file, as such:
services:
monolog.formatters.logstash:
class: Monolog\Formatter\LogstashFormatter
arguments:
$applicationName: 'your application'
monolog:
handlers:
logstash:
type: socket
connection_string: 'tcp://logstash:5044'
level: debug
formatter: monolog.formatters.logstash
persistent: true
connection_timeout: 5
How to access to Mailcatcher’s interface?
The Mailcatcher interface can be accessed through the port defined in the MAILCATCHER_PORT
environment variable value.
How to access RabbitMQ manager’s interface?
The RabbitMQ manager interface can be accessed through the port defined in the RABBITMQ_PORT
environment variable value.
How to access Dejavu’s interface for Elasticsearch?
The Dejavu interface can be accessed through the port defined in the DEJAVU_PORT
environment variable value.
Additionnally, the ELASTICSEARCH_PORT
variable should be defined in order to make
Elasticsearch’s API accessible from your computer.
How to access Elasticsearch’s API?
The Elasticsearch API can be accessed through the port defined in the ELASTICSEARCH_PORT
environment variable value.
How to access Kibana’s interface?
The Kibana interface can be accessed through the port defined in the KIBANA_PORT
environment variable value.
How to access Redis service from your computer?
The Redis servcie can be accessed through the port defined in the REDIS_PORT
environment variable value.
How to access MySQL or PostgreSQL service from your computer?
The MySQL or PostgreSQL servcie can be accessed through the port defined in the DATABASE_PORT
environment variable value.