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 16:59] – [Install MySQL] 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: | ||
</ | </ | ||
- | + | | |
- | <WRAP center round tip 60%> | + | |
- | If you are following the development of RADIUSdesk and want to make sure you have the latest SVN you can simply cd to / | + | |
- | </ | + | |
- | + | ||
- | | + | |
* 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:// | ||
- | * Alternatively (also if you do not have Internet Access on the machine use this URL which is a bit slower: http:// | + | * Alternatively |
--------------------------- | --------------------------- | ||
Line 306: | 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 318: | 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]] |