h1. Creating Veery API NodeJS Jan 24, 2017 http://veeryapinodejs.soupmode.com hr. edit dns. create cname record: hostname = veeryapinodejs is an alias of = @ cd into /home/veery mkdir Veery-API-NodeJS cd into Veery-API-NodeJS mkdir js cd js mkdir node_modules, although it might get automatically created later create package.json { "name" : "Veery-API-NodeJS", "version" : "1.0.0", "dependencies" : { "express" : "4.14.0", "body-parser" : "1.16.0", "html-entities" : "1.2.0", "querystring" : "0.2.0" } } unsure if i need all of those packages. i looked up the most recent package version numbers at https://www.npmjs.com the command "npm install" will read the package.json file, create node_modules directory, and place the downloaded the packages listed in the json file in that directory. within the same "js" directory, create dispatch.js var express = require('express'), bodyParser = require('body-parser'), path = require('path'), app = express(); app.use(bodyParser.urlencoded({ extended: true })); // parse application/x-www-form-urlencoded app.get('/', function(req, res){ res.send('hello world'); }); app.listen(3002); cd /etc/nginx/sites-available create veeryapinodejs.soupmode.com # veeryapinodejs.soupmode.com-info server { listen 80; server_name veeryapinodejs.soupmode.com; location / { default_type text/html; error_page 404 = @fallback; } location @fallback { proxy_pass http://veeryapinodejs.soupmode.com:3002; } } ln -s /etc/nginx/sites-available/veeryapinodejs.soupmode.com /etc/nginx/sites-enabled/veeryapinodejs.soupmode.com service nginx restart forever start dispatch.js more about forever commands: usage: forever [start | stop | stopall | list] [options] SCRIPT [script options] options: start start SCRIPT as a daemon stop stop the daemon SCRIPT stopall stop all running forever scripts list list all running forever scripts forever list in browser or with curl, access http://veeryapinodejs.soupmode.com should see the plain text response: hello world h3. etc. http://expressjs.com/en/4x/api.html http://jothut.com/cgi-bin/junco.pl/blogpost/36422/10Nov2014/Learning-NodeJS-Programming h3. couchdb clients 1. https://www.npmjs.com/package/couchdb 2. https://www.npmjs.com/package/nano 3. https://www.npmjs.com/package/couchdb-client 4. - the one that i chose to try first: https://www.npmjs.com/package/couchdbjs h3. Jan 26, 2017 created command prompt test script. tried running but i received: SyntaxError: Use of const in strict mode. which is due to the use of const in the couchdbjs module and due to my server running and old version of node. http://askubuntu.com/questions/426750/how-can-i-update-my-nodejs-to-the-latest-version sudo npm cache clean -f sudo npm install -g n sudo n stable sudo ln -sf /usr/local/n/versions/node/<VERSION>/bin/node /usr/bin/node version=7.4.0 but when i ran node -v, i was still running the old version instead of v7.4.0 that i installed. the old version was v0.10.21 i tried whereis node which produced: /usr/bin/node /usr/local/bin/node both of those were version 7.4.0. then i did "which node" which produced: /root/local/bin/node i did: ln -sf /usr/local/n/versions/node/7.4.0/bin/node /root/local/bin/node and now when i run "node -v", i get: v7.4.0 and now my test script works. test.js: 'use strict'; const Couchdbjs = require('couchdbjs'); const db = new Couchdbjs('mycouchdbname', cb); var docinfo = db.getDoc('profile', cb); var json_str = JSON.stringify(docinfo); function cb (err, data) { if (err) console.error(err); else console.log(data); // data is array of uuids } json= { _id: 'profile', _rev: '11-501aa2dd05bf45d71beee85c15bf2cca', author: 'JohnR', reading_time: 0, text_intro: 'My profile page. Nothing here for now.', created_at: '2015/06/12 14:04:52', html: '<p>My profile page.</p>\n\n<p>Nothing here for now.</p>\n', post_type: 'article', markup: 'h1. Profile\r\n\r\nMy profile page.\r\n\r\nNothing here for now.', more_text_exists: 0, tags: [], post_status: 'public', updated_at: '2015/09/15 22:51:42', word_count: 7, type: 'post', title: 'Profile' } h3. Helpful Links * https://nodejs.org/api/errors.html * http://veeryclientnodejs.soupmode.com/ * http://veeryapiperl.soupmode.com/api/posts/profile * http://veeryapiperl.soupmode.com/api/posts/profile/?text=markup * https://github.com/jrsawvel/Veery-API-Perl/blob/master/docs/veery-api.md * https://github.com/jrsawvel/Veery-Client-Perl/blob/master/lib/App/ShowPost.pm * https://github.com/jrsawvel/Veery-API-Perl/blob/master/lib/App/ReadPost.pm * https://github.com/jrsawvel/Veery-Client-NodeJS * http://jothut.com/cgi-bin/junco.pl/blogpost/15807/27Jan2017/GitHub-Commits h3. Jan 27, 2017 forever info. i need to rename the dispatch.js files to something unique. i cannot determine which dispatch.js belongs to which app. i have to use ps and forever to match up files with apps. # date Fri Jan 27 17:04:04 UTC 2017 root@soupmode:/home/veery/Veery-Client-NodeJS/js# forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] xX4P /root/local/bin/node dispatch.js 2156 9574 /root/.forever/xX4P.log 46:15:23:36.471 data: [1] RalR /root/local/bin/node index.js 3495 3499 /root/.forever/RalR.log 524:20:8:21.26 data: [2] v76p /root/local/bin/node dispatch.js 27383 24934 /root/.forever/v76p.log 367:22:57:58.595 no shock that after upgrading nodejs this week that now after stopping and restarting my dispatch.js files for older nodejs apps, those apps don't restart. i renamed the node_modules directory within my client nodejs app for veery to something old. then i cat package.json and i did nmp install for all of the packages. i also installed express-generator for some reason. anyway, i restarted dispatch.js and it didn't error out. my code works. h3. api code issues http://stackoverflow.com/questions/26066785/proper-way-to-set-response-status-and-json-content-in-a-rest-api-made-with-nodej http://expressjs.com/4x/api.html#res.send h3. Forever jan 27, 2017 unlink /root/local/bin/forever npm uninstall forever -g npm install forever -g ln -s /usr/local/n/versions/node/7.4.0/lib/node_modules/forever/bin/forever /root/local/bin/forever i don't know why the server environment wants to find forever at /root/local/bin/ i didn't read this but maybe it's useful http://garrows.com/blog/install-and-setup-node-js-to-run-forever/ h3. callbacks and promises https://www.tutorialspoint.com/nodejs/nodejs_callbacks_concept.htm http://stackoverflow.com/questions/29447451/user-defined-function-with-callback-in-nodejs http://stackoverflow.com/questions/18382186/creating-callbacks-for-required-modules-in-node-js http://callbackhell.com/ http://www.theprojectspot.com/tutorial-post/nodejs-for-beginners-callbacks/4 http://thenodeway.io/posts/understanding-error-first-callbacks/ http://www.theprojectspot.com/tutorial-post/Node-js-for-beginners-part-1-hello-world/2 https://www.codementor.io/codeforgeek/manage-async-nodejs-callback-example-code-du107q1pn https://medium.freecodecamp.com/javascript-callbacks-explained-using-minions-da272f4d9bcd#.6k7bcjxg4 https://docs.nodejitsu.com/articles/HTTP/clients/how-to-create-a-HTTP-request/ [x] https://www.codeschool.com/discuss/t/how-do-i-return-a-value-from-my-node-js-module-after-it-has-been-updated-by-an-async-function/27392 https://www.tomas-dvorak.cz/posts/nodejs-request-without-dependencies/ http://stackoverflow.com/questions/23667086/why-is-my-variable-unaltered-after-i-modify-it-inside-of-a-function-asynchron https://blog.domenic.me/youre-missing-the-point-of-promises/ https://developers.google.com/web/fundamentals/getting-started/primers/promises [x] http://stackoverflow.com/questions/10058814/get-data-from-fs-readfile/10058879#10058879 function doSomething (callback) { // any async callback invokes callback with response } doSomething (function doSomethingAfter(err, result) { // process the async result }); [x] http://stackoverflow.com/questions/14220321/how-do-i-return-the-response-from-an-asynchronous-call/14220323#14220323 [x] http://stackoverflow.com/questions/23339907/returning-a-value-from-callback-function-in-node-js [x] http://stackoverflow.com/questions/14220321/how-do-i-return-the-response-from-an-asynchronous-call h3. bodyparser json parsing http://stackoverflow.com/questions/24330014/bodyparser-is-deprecated-express-4