Mount Agung Volcano Eruption Soon?

I saw that the Mt. Agung Volcano was active and under an evacuation warning earlier today. Out of curiosity, I googled around to find out more about how I could know up to the minute what was going on with it. To weed out the nonsense from the real information I used the following query: Mount Agung seismic activity -news -guardian -express -cnn and went to page 3 or 4 to find the following:

Huge Map with Live updates on all Earthquakes in the same region of Indonesia:
https://magma.vsi.esdm.go.id/

Jakarta Post news article from Sept 25 (6 days from today!):
http://www.thejakartapost.com/news/2017/09/25/mt-agung-eruption-could-be-imminent-agency.html

Some serious details about the type of monitoring performed by an org. called WOVO:
http://www.wovo.org/1601_1607.html

8 Steps to Your Own NextCloud!

1. Go to https://cloud.techandme.se/index.php/s/whxC00V1I0l4CY8
2. Download OVA for ESXI/VM Deployment
3. Install to VM Hypervisor
4. Setup Domain to point to WAN IP via A record
5. Set Static IP to Local VM IP
6. Open 443 on Router to Local VM IP
7. Login and follow instructions, install optional addons as you wish
8. To resize, follow https://www.techandme.se/not-enough-space/

Linux Shell history Output, Ch. 01 of Ruby on Rails Tutorial


The following is output after running history command in a C9 Console (c9.io) where I am attempting my first Ruby on Rails application (Tutorial: railstutorial.org) using the Cloud 9 web IDE. Impressive amount of functionality after limited configuration. Going from zero to running application in ~50 commands is a rare feat today with how complicated the web stack world can be. Even have two environments running: prod and dev by using Heroku to deploy prod.

Project Console History Output (console 1)
Get Ruby Version
1 ruby -v
Setup Git/Bitbucket
2 git config --global user.name "your name"
3 git config --global user.email email@gmail.com

Quick aside: Server Daemon Console history output (console 2)
Install rails
1 gem install rails -v 5.1.2
Make rails app on c9
2 rails _5.1.2_ new hello_app
Goto app dir
4 cd hello_app/
Quickly read README
6 cat README.md
Quickly read Rakefile
8 cat Rakefile
9 ls

Troubleshoot bundle (dependency mgmt)
10 bundle install
11 bundle update listen

Update bundle of Gems after modifying Gemfile due to version differences
12 bundle update
13 bundle install

Spin up local rails server without params
14 rails server
Spin up rails server with params
15 rails server -b $IP -p $PORT
Create a new Git repo
7 git init
Add files to Git repo using gitignore
8 git add -A
Check status of working tree in Git
9 git status
Make a commit to repo with added files
10 git commit -m "Init repo"
Take a look at SSH for BitBucket setup
11 cat ~/.ssh/id_rsa.pub
Returning to Project Console (console 1) History Output
Add SSH key for use with BitBucket
16 git remote add origin ssh://git@bitbucket.org/username/project
Push to origin current repo, failed because of bad syntax
17 git push -u origin all
Check status of repo
18 git status
Check log of repo
19 git log
Create a master branch to troubleshoot failed push
20 git checkout -b master
Realized my username was wrong for use with BitBucket
21 git config --global user.name "username"
Pushed again, correct syntax this time
25 git push -u origin --all
Checkout to newly created modify branch for Readme work
26 git checkout -b modify-README
See branches for heck of it
27 git branch
Commit changes to repo
29 git commit -a -m "Update readme"
Go back to Master branch
30 git checkout master
Merge branches
31 git merge modify-README
Remove modify branch
32 git branch -d modify-README
Push changes
33 git push
Check status again
34 git status
Modify Gemfile to include :development and :production
35 bundle install
38 bundle install --without production
39 git commit -a -m "Update Gemfile for Heroku"

Check Heroku version for deployment to production
40 heroku version
Setup Heroku
41 heroku login
42 heroku keys:add

Create Heroku Virtual App Instance
44 heroku create
45 git push heroku master
46 git commit -a -m "Update Gemfile for Heroku"

Check on Heroku Virtual App Instance
49 heroku help
50 heroku status
51 heroku sessions
52 heroku webhooks

See progress of issued commands in the Console Window
53 history

This concludes Chapter 1 output. I will post subsequent chapters as I complete them. My goal is to revisit the process I go through to reinforce learning and identify where I made mistakes for future avoidance and for more understanding.

Java AOP

AspectJ Notes: Aspect Oriented Programming allows you to achieve an extra level of separation of concerns ontop of OOP methodology.

Key terms:
– Pointcut defines wherein the code a joinpoint (injection is what they should’ve called it) will occur.
– Advice defines what happens at the specific joinpoint.
– Weaving is the process of injecting the advice into the joinpoints.

Example code:

public aspect LicenseFee {

// playing with this to see if I can get this to work
// eclipse constantly checks to see if you actually are implementing the method before weaving occurs
// almost like it actively weaves before runtime, no wonder my computer is so slow running this thing
// so that means that when I go to run tests, some errors may occur but it should be okay/runnable despite the fact

pointcut test(): target(Main) &&
(call(void testSaveAccount()));

after(): test(){
System.out.println("TestSaveAccount called");
}

pointcut test2(): target(Main) &&
(call(void testOpenAccount()));

before(): test2(){
System.out.println("Derp");
}

}

Eclipse Semantics for Advice

Opinion: Modernization of Government

I work for a government entity as a contractor and I have found that my experience with this entity provides a very interesting glimpse into the reality of today’s government. The unfortunate reality is that our government is very much seated in the past. A reactive blob of people and money that moves slowly toward an ever moving target.

Organizations that profit, those that win are proactive, forward thinking, and ripe with change. Their actions determine their own futures. Infrastructure is built and designed according to their own agenda, rather than being fastened by another’s platform.

The new administration wants to, at least from what I have seen, enact widespread change and an overall shrinking of the unnecessary machine that cranks on and on. For this agenda, I wish them luck. And if this were their saving grace for other stances, then so be it that they move toward those goals. However, I believe this issue of government modernization to be at the forefront of our new reality.

We must adapt, accept change, and be unpredictable. Systems are only as strong as their weakest link. And, unfortunately the government has many weak and costly links unseen to the powers at be.

Where I see this link is in the modernization of infrastructure pertaining to the information technology of our most critical defense platforms. These systems and contracts are generally performed as an outsourced contract to a major corporation or group of corporations. And, unfortunately the contract process is what drives this slow to change realm.

Staffing, turnover, and attrition combined with an architecture designed to close the borders of all vulnerability present an inherent risk to the evolution of our tech ecosystems.

The private sectors are moving past this realm and are simply leaving our governments behind. Disruptive changes are not foreseen and many times not reacted upon until the government has begun to adopt an already outdated process or system.

Summing it up, I believe that if there is anything good that could come out of the new administration, it may be the fact that scrutiny-laden eyes now view all existing systems and infrastructures. That the button pushers of yesterday may have to find work elsewhere tomorrow, to make room for the next evolution of technical infrastructure development.

DigitalOcean Ubuntu 14.04 User SSH Setup

ssh root@ip
adduser username
gpasswd -a username sudo
ssh-keygen
cat keyfilename.pub
Copy Public Key to Clipboard
su username
mkdir .ssh
sudo chmod 700 .ssh
nano /.ssh/authorized_keys/
Paste Public Key from Clipboard
chmod 600 /.ssh/authorized_keys/
exit
Return to Root User
nano /etc/ssh/sshd_config/
PermitRootLogin no
service ssh restart
exit
ssh username@ip

 

Git, Java, and Netbeans Useful Links

In preparation for my new job, I’ve started to explore Java and Netbeans. In the process, I figured I would revisit using Git to cross reference some example code on Java.net while trying to learn about CRUD operations. Below is a list of links I found quite helpful.

platform.netbeans.org/tutorials/nbm-crud.html

java.net/projects/nb-api-samples/sources/api-samples/show/versions/8.0/tutorials/DBManager

youtube.com/watch?v=Kp5BSBoOw8k

java.net/projects/help/pages/SourceControl

In Car Tablet Project

A android tablet mounted into the center dash of a Honda Accord.
Not the most elegant thing but functionally it adds a lot to my day to day driving experience.

Over Christmas 2015, I picked up a $45 Android tablet with the intentions of mounting it into my 2010 Honda Accord as a media device. For now, I’ve used some black Velcro to mount it but would eventually like to explore the 3d printer realm and create a custom mount for it. I disabled many of the pre-installed applications, installed Spotify (a music subscription service), and installed a neat application called Tasker.

I used Tasker in conjunction with AutoInput¬†which essentially mirrors any programmed key-presses by searching for the internal UI shell command. All of this can be accomplished without rooting. I purchased a USB charger for the center console power port in addition to a thin USB cable and 1/8″ cable. Luckily, my car turns off the power port automatically when the car is off, unlike some other domestic models. After about an hour of tweaking, I had a working in car entertainment device that would:

  1. On power/charging detection, would turn on the screen, open the Spotify app, wait 6 seconds, and Play music from the last specified playlist.
  2. On power/charging off, would pause Spotify, wait 3 seconds, and dim the screen. By leaving the app open, it syncs with my Wifi network when I pull into the driveway nightly.
  3. From 7am to 5:30pm, would turn the screen brightness to max setting.
  4. From 5:31pm to 6:59am, would turn the screen brightness to min setting.

A helpful guide I followed for programming Tasker is here, with the exception of the input commands, as those were taken care of by the AutoInput application. The most important thing to note is the use of wait times in Tasker, so that the device is provided with enough time to execute each operation and not ignore overlapped operation requests.

The latest development with this project, is that under extreme cold temperatures, the tablet greatly misbehaves. I need to probably program the tablet to turn off based on a weather forecast. We had a 10F low and I found that it had factory reset itself after being left in the car all night, which means that I need to reprogram it entirely. Avoiding that scenario, I will probably look for a custom recovery which would allow me to take a full image backup to keep on the Micro SD card.

The tablet I purchased can be found here. (as of Jan 2016)

Installing SASS

cd c:/
cd RubyDevKit //folder where dev kit is installed
ruby dk.rb init
ruby dk.rb install
gem install json–platform=ruby
gem install sass
Then, install Scout App.

Just a quick note on installing SASS. I couldn’t find this anywhere.