Wednesday, July 26, 2017

How to setup a NodeJS app on Ubuntu

Untitled Document.md

Make All The Services

Ubuntu uses something called Upstart for services so you can either use services already on your box or make new ones. Your app uses nodejs so lets review how to install that and then make a service out of it:

Install NodeJS

This installs it to /usr/bin/nodejs:

sudo apt-get update
sudo apt-get install nodejs

Make the Web User and the web hosting directory

adduser www
mkdir /home/www/run
chown -R www:www /home/www/run && chmod -R 770 /home/www/run
mkdir -P /home/www/MY_APP/log
chown -R www:www /home/www/MY_APP && chmod -R 770 /home/www/MY_APP

Push All The Codes

Now that you are done writing your code, go ahead and push the code to:

/home/www/MY_APP/

Run this command again after to give the right permissions on your newly placed files:

chown -R www:www /home/www/MY_APP && chmod -R 770 /home/www/MY_APP

Your directory structure should look something like this because NodeJS:

node_modules
package.json
server.js
public/
routes/
view/

What we’re concerned with is the server.js file. That isNode.JS entry point to the world. In that file you will have something like the following symbolizing that your app runs on port 3000:


var app = express();

app.set('port', process.env.PORT || 3000);

Make the Upstart Service

Making a service is as easy as adding a .conf file to the /etc/init directory:

/etc/init/MY_APP.conf
description "MY_APP"
author "MY_NAME"


env NODE=/usr/bin/nodejs
env SCRIPT=/home/www/MY_APP/server.js
env LOG_FILE=/home/www/MY_APP/log/stdout.log
env PID_FILE=/home/www/run/MY_APP.pid
env USER=www


start on filesystem or runlevel [2345]
stop on shutdown


respawn
respawn limit 10 5


script
    exec start-stop-daemon --start --chuid $USER --make-pidfile --pidfile $PID_FILE --exec $NODE $SCRIPT >> $LOG_FILE 2>&1
end script


pre-start script
    touch $LOG_FILE
    chown root:$USER $LOG_FILE
    chmod 770 $LOG_FILE
    echo "[`date`] MY_APP starting" >> $LOG_FILE
end script


pre-stop script
    rm -f $PID_FILE
    echo "[`date`] MY_APP stopping" >> $LOG_FILE
end script

Check to make sure the new Service is ok:

 init-checkconf /etc/init/MY_APP.conf

Check the status of the new Service

service MY_APP status

Start the new Service

service MY_APP start
  1. Check the status of the new Service again
service MY_APP status

Why all this logging crap? Logs are important, when your NodeJS app starts behaving strangely you will want to know why on your production server so follow the paths of the log files, and verify they are there and correct.

I owe it to https://ubuverse.com/run-your-node-js-app-as-an-upstart-service/ who originally wrote a general version of the Upstart user creation and script

Aren’t Reverse Proxies Fun?

Your app is running but you have to hit port:3000 in order to view it, what do we do now?

This guide is how to setup Apache to handle your reverse proxy because Apache and because exposing NodeJS to port:80 is bad.

Enable proxies in apache

 sudo a2enmod proxy_http

Go to your /etc/apache2/sites-available/000-default.conf or whatever config file you are using to tell apache what to do:

<VirtualHost *:80>
       DocumentRoot /home/www/MY_APP
       ServerName www.awesome.com
       ServerAlias awesome.com

       ProxyRequests on
       ProxyPass / http://localhost:3000/
</VirtualHost>

Reload Apache

sudo service apache2 reload

Monday, April 17, 2017

How To Get MiniVMac Working on a PC (2017)


Follow the three below steps and you will get the bare essentials. 
  1. Download MiniVMac, the first one on this list is what you want, http://www.gryphel.com/c/minivmac/download.html
  2. Download a ROM as found here, https://sites.google.com/site/minivmacapplicationsv6/disk-images-and-roms
  3. Download a Diskette as found here, the first one on the list will do fine, https://sites.google.com/site/minivmacapplicationsv6/systems-os
Now let’s try to kick it up a notch. What we want to do here is load a diskette into the (already) running machine. What we can do here is follow the below instructions.
  1. Download PT-109 an old game but an awesome game. http://www.myabandonware.com/game/pt-109-ce#Mac
  2. Go onto Mini V Mac File Menu and select Open Disk Image...
  3. Point that to the game you downloaded and then it will show up on your Desktopdouble click it and go.

Wednesday, February 15, 2017

React Powered by Bootstrap!

#This tutorial is on how to run React JS and Bootstrap 1. First you will need to read this page (here)|https://react-bootstrap.github.io/getting-started.html 2. Then you will have to open this page (here)|https://react-bootstrap.github.io/components.html #Now You Can Get Coding 1. This Tutorial Makes A Couple Of Assumptions: - You Created This App With `$ create-react-app app_name` -

Saturday, January 21, 2017

React on NodeJS for Beginners

React on Node for Beginners: Build a basic Macintoshes App

The app you will be building here is pretty generic (on purpose for simplicity). It takes from a JS file with a JSON set in it as a fake database as a starting point for your content. You could always connect this to a real database later it is a proof of concept.
In our databank as it is referred to in this tutorial we have a list of our favorite Macintosh computers throughout time. We then have this list displaying via react on port 8080 via a node server.
$ mkdir your_app && cd your_app
$ npm init (press return multiple times
$ touch webpack.config.js
$ mkdir -p src/static src/static/css src/components src/data
$ touch src/static/index.html
$ touch src/data/databank.js
Everything starts out nice and basic, lets go ahead and create an index.html file that will serve our forthcoming webpack.js file.
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Best Macs - A Universal JavaScript demo application with React</title>
    <link rel="stylesheet" href="/css/app.css">
</head>
<body>
<div id="main"></div>
<script src="/js/bundle.js"></script>
</body>
</html>
Now what we are doing is making our JSON file that will serve as a database, we’ll call it databank, because its not-quite-a-database but it’s good enough.
// src/static/databank.js
const databank = [
     {
        'id': 'mactwo-ci',
        'name': 'Macintosh IIci',
        'country': 'united states',
        'birth': '1989',
        'price': '$6269',
        'cpu': 'moto 68030 25mhz',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIci.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_IIci'
    },
    {
        'id': 'mactwo-fx',
        'name': 'Macintosh IIfx',
        'country': 'united states',
        'birth': '1990',
        'price': '$9900',
        'cpu': 'moto 68030 40mhz',
        'ram': '4 MB',
        'max-ram': '128 MB',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIfx.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_IIfx'
    },
    {
        'id': 'macse-30',
        'name': 'Macintosh SE30',
        'country': 'united states',
        'birth': '1989',
        'price': '$4369',
        'cpu': 'moto 68030 16mhz',
        'ram': '1 MB',
        'max-ram': '128 MB',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIfx.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_SE/30'
    },
];

export default databank;
Next we create the DataPreview Component. For our React App. Think of this as the list of things from the databank.js which is told to the IndexPage.js (forthcoming).
// src/components/DataPreview.js
// I preview your data from your databank.js so your IndexPage.js knows what to show

import React from 'react';
import { Link } from 'react-router';

export default class DataPreview extends React.Component {
    render() {
        return (
            <Link to={`/hardware/${this.props.id}`}>
                <div className="data-preview">
                    <h2 className="name">{this.props.name}</h2>
                </div>
            </Link>
        );
    }
Now we have all the dependencies that the index page will need let’s go out and do the index page. Keep in mind this is the react jS index page.
// the almighty IndexPage.js

import React from 'react';
import DataPreview from './DataPreview'
import databank from '../data/databank';

export default class IndexPage extends React.Component {
    render() {
        return (
            <div className="home">
                <div className="data-selector">
                    {databank.map(databankData => <DataPreview key={databankData.id} {...databankData} />)}
                </div>
            </div>
        );
    }
}
Now it’s time to think about your navbar and the template for your entire app. There is no way we are doing this by hand. Let’s be thankful that react JS is smart enough to take the objects in our databank.JS fil in our navbar for us.
The final file we will do is our template. We will reference our nav. bar and our index.JS in this file. And finally we will do the now bar or menu file.
// components/NavBar.js

import React from 'react';
import { Link } from 'react-router';
import databank from '../data/databank';

export default class NavBar extends React.Component {
    render() {
        return (
            <nav className="data-menu">
                {databank.map(menuData => {
                    return <Link key={menuData.id} to={`/hardware/${menuData.id}`} activeClassName="active">
                        {menuData.name}
                    </Link>;
                })}
            </nav>
        );
    }
}
The Template Component of our ReactJS app is very self explanatory so we are kind of thrown a bone here.
// components/Template.js

export default class Template extends React.Component {
    render() {
        return (
            <div className="app-container">
                <header>
                    <Link to="/">
                        <img className="logo" src="/img/logo-apple-logo.png"/>
                    </Link>
                </header>
                <div className="app-content">{this.props.children}</div>
                <footer>
                    <p>
                        This is a demo app to showcase universal rendering and routing with <strong>React</strong> and <strong>Express</strong>.
                    </p>
                </footer>
            </div>
        );
    }
}
There will be two more pages. A computers page which will display the info on all of the parts of your databank for each object. And you need to finesse your routes.JS page in order to tell your react application about all of these nifty things that you have just created underneath the components folder.
So let’s get the computers page. Clearly if your app is something other than computers you will insert the noun which you are listing from your databank instead of computers so it will not be confusing.
//components/ComputerPage.js

// src/components/AthletePage.js
import React from 'react';
import { Link } from 'react-router';
import NavBar from './NavBar';
import databank from '../data/databank';


export default class ComputerPage extends React.Component {
    render() {
        const id = this.props.params.id;
        const data = databank.filter((databank) => databank.id === id)[0];
        if (!data) {
            return <div> not found dude :( </div>;
        }

        return (
            <div className="computer-full">
                <NavBar/>
                <div className="computer">

                    <div className="item-container">
                                            <h2 className="name">Welcome to the {data.name}</h2>
                    </div>

                </div>
                <div className="navigateBack">
                    <Link to="/">« Back to the index</Link>
                </div>
            </div>
        );
    }
}
One more thing is that there will be an out Apple routes component file to which she will import your routes JS file. While it was rather generic and basically just set up your environment for your react JS application. One important thing to note is the line about importing the reactor router. You will either specify hashhistory or browserhistory based on whether or not you are running in development or production respectively.
Remember you will put this file in your components directory.
// src/components/AppRoutes.js
import React from 'react';
import { Router, hashHistory } from 'react-router';
import routes from '../routes';

export default class AppRoutes extends React.Component {
    render() {
        return (
            <Router history={hashHistory} routes={routes} onUpdate={() => window.scrollTo(0, 0)}/>
        );
    }
}
Let’s get to your regular routes page. This one is way more fun, it’s where everything comes together.
If you are familiar with the rails is should bring them back some serious memories. Although it is not as strict as a rails app will be with routes.
Pay attention! This one goes one directory level up – not in your components directory.
// src/routes.js
import React from 'react'
import { Route, IndexRoute } from 'react-router'
import Template from './components/Template';
import IndexPage from './components/IndexPage';
import ComputerPage from './components/ComputerPage';
// import NotFoundPage from './components/NotFoundPage';

const routes = (
    <Route path="/" component={Template}>
        <IndexRoute component={IndexPage}/>
        <Route path="hardware/:id" component={ComputerPage}/>

    </Route>
);

export default routes;
You know how in a node JS application you will have your server.JS file? Well since this is a reactive application you will need a client.JS file as an entry point for your app to run. Remember this will go in the same directory as your routes.JS file.
// src/client.js
import React from 'react';
import ReactDOM from 'react-dom';
import AppRoutes from './components/AppRoutes';

window.onload = () => {
    ReactDOM.render(<AppRoutes/>, document.getElementById('main'));
};
Here is the dread of every react developer setting up your web pack.Jazz file. Now I will tell you an important secret. What you want to do here is make sure that when you are developing to run web pack in a watching mode. In order to do that after paste the following in your webpack.config.js way back in your application's root folder, run a $ webpack -w, or you will have to recompile your sources every single time, not fun:
// webpack.config.js
const webpack = require('webpack');
const path = require('path');

module.exports = {
    entry: path.join(__dirname, 'src', 'client.js'),
    output: {
        path: path.join(__dirname, 'src', 'static', 'js'),
        filename: 'bundle.js'
    },
    module: {
        loaders: [{
            test: path.join(__dirname, 'src'),
            loader: ['babel-loader'],
            query: {
                cacheDirectory: 'babel_cache',
                presets: ['react', 'es2015']
            }
        }]
    },
    plugins: [
        new webpack.DefinePlugin({
            'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)
        }),
        new webpack.optimize.DedupePlugin(),
        new webpack.optimize.OccurenceOrderPlugin(),
        new webpack.optimize.UglifyJsPlugin({
            compress: { warnings: false },
            mangle: true,
            sourcemap: false,
            beautify: false,
            dead_code: true
        })
    ]
};
If you are reading this congratulations. First of all you need to level-up your webpack game. Let's run Webpack in Watch mode so that when we make changes to any of our JS asset's webpack will recompile on the fly, do this from the application's root directory.
$ webpack -w
The last thing you want to do is fire up your Application via a HTTP-server Node module you do that like so from your application root directory:
$ node_modules/.bin/http-server src/static
A couple of beginner notes to watch:
  • watch your directory structure
  • your syntax may be so messed up that it crashes $ webpack -w if you do watch your webpack error messages and restart $ webpack -w
  • JSON notation can be tricky, use a good editor and watch for errors there, plus hyphens (-) are going to pwn your dataset if they are in the key position of your key-value pairs

React on Node for Beginners: Build a basic Macintoshes App

React on Node for Beginners: Build a basic Macintoshes App

The app you will be building here is pretty generic (on purpose for simplicity). It takes from a JS file with a JSON set in it as a fake database as a starting point for your content. You could always connect this to a real database later it is a proof of concept.

In our databank as it is referred to in this tutorial we have a list of our favorite Macintosh computers throughout time. We then have this list displaying via react on port 8080 via a node server.

$ mkdir your_app && cd your_app
$ npm init (press return multiple times
$ touch webpack.config.js
$ mkdir -p src/static src/static/css src/components src/data
$ touch src/static/index.html
$ touch src/data/databank.js
src/static/index.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Best Macs - A Universal JavaScript demo application with React</title>
    <link rel="stylesheet" href="/css/app.css">
</head>
<body>
<div id="main"></div>
<script src="/js/bundle.js"></script>
</body>
</html>
// src/static/databank.js
const databank = [
     {
        'id': 'mactwo-ci',
        'name': 'Macintosh IIci',
        'country': 'united states',
        'birth': '1989',
        'price': '$6269',
        'cpu': 'moto 68030 25mhz',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIci.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_IIci'
    },
    {
        'id': 'mactwo-fx',
        'name': 'Macintosh IIfx',
        'country': 'united states',
        'birth': '1990',
        'price': '$9900',
        'cpu': 'moto 68030 40mhz',
        'ram': '4 MB',
        'max-ram': '128 MB',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIfx.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_IIfx'
    },
    {
        'id': 'macse-30',
        'name': 'Macintosh SE30',
        'country': 'united states',
        'birth': '1989',
        'price': '$4369',
        'cpu': 'moto 68030 16mhz',
        'ram': '1 MB',
        'max-ram': '128 MB',
        'image': 'https://en.wikipedia.org/wiki/File:Macintosh_IIfx.png',
        'link': 'https://en.wikipedia.org/wiki/Macintosh_SE/30'
    },
];

export default databank;
// src/components/DataPreview.js
// I preview your data from your databank.js so your IndexPage.js knows what to show

import React from 'react';
import { Link } from 'react-router';

export default class DataPreview extends React.Component {
    render() {
        return (
            <Link to={`/hardware/${this.props.id}`}>
                <div className="data-preview">
                    <h2 className="name">{this.props.name}</h2>
                </div>
            </Link>
        );
    }

Now we have all the dependencies that the index page will need let’s go out and do the index page. Keep in mind this is the react jS index page.

// the almighty IndexPage.js

import React from 'react';
import DataPreview from './DataPreview'
import databank from '../data/databank';

export default class IndexPage extends React.Component {
    render() {
        return (
            <div className="home">
                <div className="data-selector">
                    {databank.map(databankData => <DataPreview key={databankData.id} {...databankData} />)}
                </div>
            </div>
        );
    }
}

Now it’s time to think about your navbar and the template for your entire app. There is no way we are doing this by hand. Let’s be thankful that react JS is smart enough to take the objects in our databank.JS fil in our navbar for us.

The final file we will do is our template. We will reference our nav. bar and our index.JS in this file. And finally we will do the now bar or menu file.

// components/NavBar.js

import React from 'react';
import { Link } from 'react-router';
import databank from '../data/databank';

export default class NavBar extends React.Component {
    render() {
        return (
            <nav className="data-menu">
                {databank.map(menuData => {
                    return <Link key={menuData.id} to={`/hardware/${menuData.id}`} activeClassName="active">
                        {menuData.name}
                    </Link>;
                })}
            </nav>
        );
    }
}
// components/Template.js

export default class Template extends React.Component {
    render() {
        return (
            <div className="app-container">
                <header>
                    <Link to="/">
                        <img className="logo" src="/img/logo-judo-heroes.png"/>
                    </Link>
                </header>
                <div className="app-content">{this.props.children}</div>
                <footer>
                    <p>
                        This is a demo app to showcase universal rendering and routing with <strong>React</strong> and <strong>Express</strong>.
                    </p>
                </footer>
            </div>
        );
    }
}

I lied there will be two more pages. A computers page which will display the info on all of the parts of your databank for each object. And you need to finesse your routes.JS page in order to tell your react application about all of these nifty things that you have just created underneath the components folder.

So let’s get the computers page. Clearly if your app is something other than computers you will insert the noun which you are listing from your databank instead of computers so it will not be confusing.

`` //components/ComputerPage.js

// src/components/AthletePage.js import React from ‘react’; import { Link } from ‘react-router’; import NavBar from ‘./NavBar’; import databank from ‘../data/databank’;

export default class ComputerPage extends React.Component { render() { const id = this.props.params.id; const data = databank.filter((databank) => databank.id === id)[0]; if (!data) { return

not found dude :(
; }

    return (
        <div className="computer-full">
            <NavBar/>
            <div className="computer">

                <div className="item-container">
                                        <h2 className="name">Welcome to the {data.name}</h2>
                </div>

            </div>
            <div className="navigateBack">
                <Link to="/">« Back to the index</Link>
            </div>
        </div>
    );
}

} ```

One more thing is that there will be an out Apple routes component file to which she will import your routes JS file. While it was rather generic and basically just set up your environment for your react JS application. One important thing to note is the line about importing the reactor router. You will either specify hashhistory or browserhistory based on whether or not you are running in development or production respectively.

Remember you will put this file in your components directory.

// src/components/AppRoutes.js
import React from 'react';
import { Router, hashHistory } from 'react-router';
import routes from '../routes';

export default class AppRoutes extends React.Component {
    render() {
        return (
            <Router history={hashHistory} routes={routes} onUpdate={() => window.scrollTo(0, 0)}/>
        );
    }
}

Let’s get to your regular routes page. If you are familiar with the rails is should bring them back some serious memories. Although it is not as strict as a rails app will be with routes. Here because your routes Jay asked file will go in your S RC directory one level up not in your components directory.

// src/routes.js
import React from 'react'
import { Route, IndexRoute } from 'react-router'
import Template from './components/Template';
import IndexPage from './components/IndexPage';
import ComputerPage from './components/ComputerPage';
// import NotFoundPage from './components/NotFoundPage';

const routes = (
    <Route path="/" component={Template}>
        <IndexRoute component={IndexPage}/>
        <Route path="hardware/:id" component={ComputerPage}/>

    </Route>
);

export default routes;

You know how in a node JS application you will have your server.JS file? Well since this is a reactive application you will need a client.JS file as an entry point for your app to run. Remember this will go in the same directory as your routes.JS file.

// src/client.js
import React from 'react';
import ReactDOM from 'react-dom';
import AppRoutes from './components/AppRoutes';

window.onload = () => {
    ReactDOM.render(<AppRoutes/>, document.getElementById('main'));
};

Here is the dread of every react developer setting up your web pack.Jazz file. Now I will tell you an important secret. What you want to do here is make sure that when you are developing to run web pack in a watching mode. In order to do that after paste the following in your webpack.config.js way back in your application's root folder, run a $ webpack -w, or you will have to recompile your sources every single time, not fun:

// webpack.config.js
const webpack = require('webpack');
const path = require('path');

module.exports = {
    entry: path.join(__dirname, 'src', 'client.js'),
    output: {
        path: path.join(__dirname, 'src', 'static', 'js'),
        filename: 'bundle.js'
    },
    module: {
        loaders: [{
            test: path.join(__dirname, 'src'),
            loader: ['babel-loader'],
            query: {
                cacheDirectory: 'babel_cache',
                presets: ['react', 'es2015']
            }
        }]
    },
    plugins: [
        new webpack.DefinePlugin({
            'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)
        }),
        new webpack.optimize.DedupePlugin(),
        new webpack.optimize.OccurenceOrderPlugin(),
        new webpack.optimize.UglifyJsPlugin({
            compress: { warnings: false },
            mangle: true,
            sourcemap: false,
            beautify: false,
            dead_code: true
        })
    ]
};

If you are reading this congratulations. The last thing you want to do is fire up your Application via a HTTP-server Node module you do that like so from your application root directory:

$ node_modules/.bin/http-server src/static

A couple of beginner notes to watch:

  • watch your directory structure
  • your syntax may be so messed up that it crashes $ webpack -w if you do watch your webpack error messages and restart $ webpack -w
  • JSON notation can be tricky, use a good editor and watch for errors there, plus hyphens (-) are going to pwn your dataset if they are in the key position of your key-value pairs