Installing Grebe - Jul 30, 2014 Documenting the steps, which will lead to additional programming changes to make it simpler. * With the hosting provider, add DNS information, if necessary. * Create a CNAME record if installing the code under a subdomain. ** grebe CNAME @ * May have to wait a while before DNS updates in order to use the new subdomain website. * Log onto remote server. * Change to user @root.@ or use @sudo@ ahead of each command. ** https://help.ubuntu.com/community/RootSudo * Change directory to web server config area. This example uses the Nginx web server, and it assumes that FastCGI has been installed. ** @cd /etc/nginx@ * Need to create a server block config file to support Grebe. ** http://wiki.nginx.org/ServerBlockExample *** _"VirtualHost" is an Apache term. Nginx does not have Virtual hosts, it has "Server Blocks" that use the server_name and listen directives to bind to tcp sockets._ * This is an example of using Grebe under a subdomain. ** @cd sites-available@ ** @vim grebe.yourdomain.com@ ** add the following and save the file: code. ######## # GREBE ######## server { listen 80; server_name grebe.yourdomain.com; location ~ ^/(css/|javascript/|images/) { root /home/grebe/Grebe/root; access_log off; expires max; } location /api/v1 { root /home/grebe/Grebe/root/api/v1; index grebeapi.pl; rewrite ^/(.*)$ /grebeapi.pl?query=$1 break; fastcgi_pass 127.0.0.1:8999; fastcgi_index grebeapi.pl; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } location / { root /home/grebe/Grebe/root; index grebe.pl; rewrite ^/(.*)$ /grebe.pl?query=$1 break; fastcgi_pass 127.0.0.1:8999; fastcgi_index grebe.pl; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } } code.. * Create a link to the new Nginx server block file. ** @ln -s /etc/nginx/sites-available/grebe.yourdomain.com /etc/nginx/sites-enabled/@ * Restart Nginx. ** @/etc/init.d/nginx restart@ * Create a home directory for Grebe. ** @mkdir /home/grebe@ * Change to Grebe directory. ** @cd /home/grebe@ * Create directories that will host markup and HTML template files that represent the posts created. These directories exist outside of document root, but they are used by the Grebe code. ** @mkdir posts@ ** @mkdir markup@ * Within the @/home/grebe@ directory, download or copy over the gzipped tar file that contains the Grebe code, and unpack it. Example file: @Grebe-29Jul2014.tar.gz@ ** unpack in two steps: *** @gunzip Grebe-29Jul2014.tar.gz@ *** @tar -xvf Grebe-29Jul2014.tar@ ** or unpack in one step: *** @tar -zxvf Grebe-29Jul2014.tar.gz@ * The unpacking creates a directory called @Grebe@. * Change ownership of all contents under the Grebe directory to the owner (username) and group that Nginx operates under. ** @chown - R owner:group Grebe@ * While in @/home/grebe@ change directory to @Grebe@. ** @cd Grebe@ * For curiosity sake, show a listing of all files and subdirectories under Grebe: ** @ls -lR@ * The directory structure under Grebe: ** lib *** API *** Client *** Config *** CPAN **** Algorithm **** HTML **** JSON **** REST **** Text **** URI ***** Escape **** XML **** YAML *** JRS ** nginx ** root *** api **** v1 *** css *** images *** javascript **** splitscreen ** sql ** t ** tmpl ** yaml * While at @/home/grebe/Grebe@, change to the web root directory. ** @cd root@ * Edit the small file @grebe.pl@. Here is the entire file. Ensure of the proper directory structures after the @lib@ commands. code.#!/usr/bin/perl -wT use strict; $|++; use lib '/home/grebe/Grebe/lib'; use lib '/home/grebe/Grebe/lib/CPAN'; use Client::Dispatch; Client::Dispatch::execute(); code.. * While in @/home/grebe/Grebe/root@, change directory to the version one API directory. Since we're under the web root directory for the Nginx web server, this directory is part of the API URL. ** @cd api/v1@ * Edit the small file @grebeapi.pl@. Here is the entire file. Ensure of the proper directory structures after the @lib@ commands. code.#!/usr/bin/perl -wT use strict; $|++; use lib '/home/grebe/Grebe/lib'; use lib '/home/grebe/Grebe/lib/CPAN'; use API::DispatchAPI; API::DispatchAPI::execute(); code.. * Change to the directory that contains the database files. ** @cd /home/grebe/Grebe/sql@ * This assumes that MySQL is installed. * Create a new database and database user for Grebe. If planning to use an existing database, then skip these steps. * Enter this command to get into the mysql command line interface: (it will ask for the root password) ** @mysql -uroot -p@ * At the @mysql>@ prompt, enter the following commands, one at a time: ** @create database grebe;@ ** create user 'grebe'@'localhost' identified by 'set_your_password_here'; ** grant all privileges on grebe.* to 'grebe'@'localhost'; ** @flush privileges;@ ** @quit;@ * Create the Grebe database tables. ** @mysql -ugrebe -pyourpassword -D grebe < grebe-users.sql@ ** @mysql -ugrebe -pyourpassword -D grebe < grebe-posts.sql@ ** @mysql -ugrebe -pyourpassword -D grebe < grebe-tags.sql@ ** @mysql -ugrebe -pyourpassword -D grebe < grebe-sessionids.sql@ * Change directory to the location of the Config module. ** @cd /home/grebe/Grebe/lib/Config@ * Edit @Config.pm@ and make the appropriate directory location change for the variable @$yml_file@ which points to the location of the Yaml configuration file. ** @my $yml_file = "/home/grebe/Grebe/yaml/grebe.yml";@ * Change directory to the Yaml config file location. ** @cd /home/grebe/Grebe/yaml@ *** For testing, enable debug mode. **** @debug_mode: 1@ * Edit the file @grebe.yml@ and make the appropriate changes. * If @read_template: 1@, then the following files need linked from the @Grebe/tmpl@ directory to the @posts@ directory. ** @ln -s /home/grebe/Grebe/tmpl/header.tmpl /home/grebe/posts@ ** @ln -s /home/grebe/Grebe/tmpl/inc_headernav.tmpl /home/grebe/posts@ ** @ln -s /home/grebe/Grebe/tmpl/footer.tmpl /home/grebe/posts@ * Open web browser and enter the following URL: ** @http://grebe.yourname.com@ * The site or blog app should load, displaying the default image header and other links. hr. * http://grebe.soupmode.com/signup FIX the signup procedure, sending e-mail with activation link or displaying it to the page by default. * http://grebe.soupmode.com/login * create a test post * create posts titled "about" and "info" or remove the links from homepageheader.tmpl and footer.tmpl. hr. File changes to move to other sites: * ShowPost.pm