This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| getting_started:install_ubuntu_nginx [2016/10/18 20:16] – [Viewer component] admin | getting_started:install_ubuntu_nginx [2017/07/06 21:17] (current) – [Install RADIUSdesk] admin | ||
|---|---|---|---|
| Line 127: | Line 127: | ||
| sudo apt-get install mysql-server php-mysql | sudo apt-get install mysql-server php-mysql | ||
| </ | </ | ||
| + | |||
| + | === Disable strict mode === | ||
| + | * With the 16.04 release of MySQL there were some changes to the MySQL configuration which causes problems on the current RADIUSdesk database implementation. | ||
| + | * We will disable Strict SQL Mode in MySQL 5.7. | ||
| + | <code bash> | ||
| + | sudo vi / | ||
| + | </ | ||
| + | * Enter these two lines: | ||
| + | <code bash> | ||
| + | [mysqld] | ||
| + | sql_mode=IGNORE_SPACE, | ||
| + | </ | ||
| + | * Save the file and restart the MySQL service | ||
| + | < | ||
| + | sudo systemctl restart mysql.service | ||
| + | </ | ||
| + | |||
| ----- | ----- | ||
| Line 137: | Line 154: | ||
| * Add the following inside the server section: | * Add the following inside the server section: | ||
| <code bash> | <code bash> | ||
| - | location ~* ^.+\.(jpg|jpeg|gif|png|ico|js|css)$ { | + | location ~ ^/cake2/.+\.(jpg|jpeg|gif|png|ico|js|css)$ { |
| rewrite ^/ | rewrite ^/ | ||
| rewrite ^/ | rewrite ^/ | ||
| Line 178: | Line 195: | ||
| * RADIUSdesk consists of three components. | * RADIUSdesk consists of three components. | ||
| * **rd** directory with its contents contains all the HTML and JavaScript code and is used as the presentation layer. | * **rd** directory with its contents contains all the HTML and JavaScript code and is used as the presentation layer. | ||
| - | * **rd_cake** is a CakePHP application and can be considered the engine room. Here the data is processed before being presented by the presentation layer. | + | * **rd_cake** is a CakePHP application and can be considered the engine room. Here the data is processed before being presented by the presentation layer. |
| * **rd_login** is a directory with various login pages which are centrally managed through the RADIUSdesk **Dynamic Login Pages** applet. Although this is optional, it is used by most installs. | * **rd_login** is a directory with various login pages which are centrally managed through the RADIUSdesk **Dynamic Login Pages** applet. Although this is optional, it is used by most installs. | ||
| Line 184: | Line 201: | ||
| === Install CakePHP === | === Install CakePHP === | ||
| + | <WRAP center round info 100%> | ||
| + | * As from December 2016 we started a migration process of migrating from CakePHP v2 to CakePHP v3. | ||
| + | * The ORM component of CakePHP v3 is completely new and different which makes the migration fairly involved. | ||
| + | * Since the architecture of RADIUSdesk is following modern design principles it allows us to run both CakePHP v2 and CakePHP v3 simultaneously. | ||
| + | * We can then do the migration gradually over time. | ||
| + | </ | ||
| + | |||
| + | == Required packages == | ||
| + | |||
| * Make sure the following packages are installed: | * Make sure the following packages are installed: | ||
| <code bash> | <code bash> | ||
| - | sudo apt-get install php-cli php-gd php-curl | + | sudo apt-get install php-cli php-gd php-curl |
| </ | </ | ||
| - | | + | |
| + | == Install CakePHP v2 == | ||
| + | |||
| + | | ||
| * There are two formats to choose from when selecting to download, Zip or Tar.gz. Select Tar.gz. | * There are two formats to choose from when selecting to download, Zip or Tar.gz. Select Tar.gz. | ||
| * Copy and extract it inside the directory that Nginx is serving its content from (/ | * Copy and extract it inside the directory that Nginx is serving its content from (/ | ||
| <code bash> | <code bash> | ||
| - | sudo cp 2.9.1.tar.gz / | + | sudo cp 2.9.7.tar.gz / |
| cd / | cd / | ||
| - | sudo tar -xzvf 2.9.1.tar.gz | + | sudo tar -xzvf 2.9.7.tar.gz |
| - | sudo ln -s ./ | + | sudo ln -s ./ |
| </ | </ | ||
| * Reload php7.0-fpm | * Reload php7.0-fpm | ||
| Line 202: | Line 231: | ||
| </ | </ | ||
| - | === Install RADIUSdesk CakePHP Application === | + | == Install |
| * Install subversion in order for you to check out the latest source for RADIUSdesk. | * Install subversion in order for you to check out the latest source for RADIUSdesk. | ||
| <code bash> | <code bash> | ||
| Line 223: | Line 253: | ||
| sudo chown -R www-data. / | sudo chown -R www-data. / | ||
| sudo chown -R www-data. / | sudo chown -R www-data. / | ||
| + | </ | ||
| + | |||
| + | == Install the RADIUSdesk CakePHP v3 Application == | ||
| + | |||
| + | * Check out the cake3 branch from trunk to / | ||
| + | <code bash> | ||
| + | cd / | ||
| + | sudo svn checkout svn:// | ||
| + | </ | ||
| + | |||
| + | * Change the following directories to be writable by www-data: | ||
| + | <code bash> | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| + | sudo chown -R www-data. / | ||
| </ | </ | ||
| Line 237: | Line 286: | ||
| * Populate the database (trunk): | * Populate the database (trunk): | ||
| <code bash> | <code bash> | ||
| - | mysql -u root rd < / | + | |
| </ | </ | ||
| Line 249: | Line 298: | ||
| === Configure Nginx === | === Configure Nginx === | ||
| - | * Since CakePHP uses rewrite rules, we have to configure Nginx in such a way as to allow rewriting of the URL's that starts with / | + | * Since CakePHP uses rewrite rules, we have to configure Nginx in such a way as to allow rewriting of the URL's that starts with /cake2/rd_cake or with /cake3/rd_cake. |
| * Edit /// | * Edit /// | ||
| <code bash> | <code bash> | ||
| Line 260: | Line 309: | ||
| | | ||
| } | } | ||
| + | |||
| + | location / | ||
| + | | ||
| + | | ||
| + | } | ||
| + | |||
| </ | </ | ||
| * Reload the Nginx web server: | * Reload the Nginx web server: | ||
| Line 266: | Line 321: | ||
| </ | </ | ||
| - | === Test things out === | ||
| - | * RADIUSdesk supports multiple languages which are sourced during loading. To confirm that the CakePHP application is working as intended, go to this URL: | ||
| - | http:// | ||
| - | * Your browser should show a JSON encrypted string: | ||
| - | <code bash> | ||
| - | {" | ||
| - | </ | ||
| * Congratulations you are almost there. Next we will install the viewer component | * Congratulations you are almost there. Next we will install the viewer component | ||
| + | |||
| ----- | ----- | ||
| Line 284: | Line 333: | ||
| </ | </ | ||
| - | * For the viewer component you need the ExtJS toolkit. We've added version 6 to the SVN repository for easy download :-) | + | * For the viewer component you need the ExtJS toolkit. We've added version 6.2.0 to the SVN repository for easy download :-) |
| * Checkout and unzip the GPL version under the / | * Checkout and unzip the GPL version under the / | ||
| <code bash> | <code bash> | ||
| cd / | cd / | ||
| sudo svn checkout svn:// | sudo svn checkout svn:// | ||
| - | sudo mv ext-6-sencha_cmd.tar.gz ./rd | + | sudo mv ext-6-2-sencha_cmd.tar.gz ./rd |
| cd / | cd / | ||
| - | sudo tar -xzvf ext-6-sencha_cmd.tar.gz | + | sudo tar -xzvf ext-6-2-sencha_cmd.tar.gz |
| </ | </ | ||
| * Now try to log in on the following URL with username **root** and password **admin**: http:// | * Now try to log in on the following URL with username **root** and password **admin**: http:// | ||
| Line 301: | Line 350: | ||
| * **RADIUSdesk** requires a few scripts to run periodically in order to maintain a healthy and working system. | * **RADIUSdesk** requires a few scripts to run periodically in order to maintain a healthy and working system. | ||
| * To activate the cron scripts execute the following command, which will add **RADIUSdesk**' | * To activate the cron scripts execute the following command, which will add **RADIUSdesk**' | ||
| - | * For Apache | ||
| - | <code bash> | ||
| - | sudo cp / | ||
| - | </ | ||
| - | * For Nginx | ||
| <code bash> | <code bash> | ||
| sudo cp / | sudo cp / | ||
| Line 313: | Line 357: | ||
| * Be sure to also install **FreeRADIUS** and **Node.js**, | * Be sure to also install **FreeRADIUS** and **Node.js**, | ||
| * [[Getting Started: | * [[Getting Started: | ||
| - | * [[Getting Started:Install Ubuntu Node.js|Install node.js]] | + | * [[getting_started:install_ubuntu_node_js|Install node.js]] |