My occasional findings
Hi there! This blog is about the problems I face when trying to make a living as a software consultant. Hey! Sometimes I even provide solutions... :-) Enjoy!
onsdag 3. januar 2018
Android  with support actionbar, two buttons at the bottom and a scrollview in between 
I recently ran into a problem with buttons located at the bottom of my screen no longer showing when the soft keyboard was present.
To investigate I created this small project:
https://bitbucket.org/ovestoerholt/layout_bottom_buttons_move_with_softkeyboard
Hope the example can be of help to someone!
onsdag 5. juli 2017
Android note to self #1: Google Maven repository
From support library version 25.4.0 and newer you need to add 'google' as a repository.
Application build.gradle:
dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:25.4.0'
    compile 'com.android.support:cardview-v7:25.4.0'
    compile 'com.android.support:design:25.4.0'
    compile 'com.android.support:recyclerview-v7:25.4.0'
}
repositories {
    mavenCentral()
    google()
}
søndag 4. juni 2017
Vert.x static content
Serving static content from Vert.x can be accomplished adding the following to your router:
This line of code will route all requests containing the word 'static' to the webroot folder.
More info about how Vert.x serves static content:
http://vertx.io/docs/vertx-web/kotlin/#_serving_static_resources
The default folder for static content is 'webroot', but trying to find out where to place this folder got me really confused...
From this question on Stack Overflow
https://stackoverflow.com/questions/31778971/vertx-web-where-do-i-place-webroot-folder
I can tell I'm not the first person wondering (lot's of suggestions with no approved answer)...
What I've found during testing is the following:
router.route("/static/*").handler(StaticHandler.create())
This line of code will route all requests containing the word 'static' to the webroot folder.
More info about how Vert.x serves static content:
http://vertx.io/docs/vertx-web/kotlin/#_serving_static_resources
The default folder for static content is 'webroot', but trying to find out where to place this folder got me really confused...
From this question on Stack Overflow
https://stackoverflow.com/questions/31778971/vertx-web-where-do-i-place-webroot-folder
I can tell I'm not the first person wondering (lot's of suggestions with no approved answer)...
What I've found during testing is the following:
- Static content outside the jar
 Is being served relative to the working directory, or the directory you're in when starting the app from the command line.
 If you have a folder called 'webroot' in this directory it's content will be available through the StaticHandler object.
- Static content inside the jar
 If you wish to serve static content directly from your jar file you need to add 'webroot' as a resource in the jar and place all the content of interest there. In the picture below I have my resources folder at the same level as the source code. Note that the folder is marked in Intellij as a resource folder.
 
søndag 8. mai 2016
How to add a systemctl service to a Ubuntu server
I have lately been using Vert.x for simple web servers/services, and found running them directly on my server was just as convenient as trying to set up Docker...
As you may know Vert.x is a framework for writing reactive applications than runs on the Java Virtual Machine (JVM). Either you can install the Vert.x framework on your server and run your application in a Vert.x context, or you can package everything (both your own code and the framework) in a single (fat) jar and run it directly.
Run command:
This command will run the service, but it will be terminated as soon as you exit out of the terminal window. To make it run as a service follow the steps below.
Note that a JVM needs to be installed on your server. To install Oracle Java 8 on Ubuntu follow this guide.
Note that when you clone a repository the repository will be cloned to the current directory.
To create the bash script I usually prefer nano.
This is the file that eventually starts your service. To start a JVM, use something similar to the command below.
Make the script executable:
You must then create a service-file in the /lib/systemd/system directory.
Add the following text:
This file is what enables systemctl to start, stop and generally handle your service.
You can now operate your service using systemctl.
Start service
Stop service
As you may know Vert.x is a framework for writing reactive applications than runs on the Java Virtual Machine (JVM). Either you can install the Vert.x framework on your server and run your application in a Vert.x context, or you can package everything (both your own code and the framework) in a single (fat) jar and run it directly.
Run command:
 sudo java -jar myjarfile.jar
This command will run the service, but it will be terminated as soon as you exit out of the terminal window. To make it run as a service follow the steps below.
Note that a JVM needs to be installed on your server. To install Oracle Java 8 on Ubuntu follow this guide.
Create a folder for the files that make up your service
The "standard" folder for your own services on a Ubuntu server would normally be /usr/local, but you can use a different folder if this better suits your needs.
Use the commands in the code section below to create a folder for your service.
Use the commands in the code section below to create a folder for your service.
 cd /usr/local  
 sudo mkdir myservice  
 cd myservice  
Add the files for your site/service
Adding the files that makes up your service depends on how you work when you are doing your development. I usually write and test my code locally, storing my files in a git repository. I then use git from the command line to update site content.
Command to install git client on Ubuntu:
 sudo apt-get install git  
Command to clone your git repository to the server:
 git clone https://<username>@<server>/<path-to-repo.git>
Note that when you clone a repository the repository will be cloned to the current directory.
Command to retrieve updates from  your git repository.
 git pull https://<username>@<server>/<path-to-repo.git>
Create a bash script for starting your service
 sudo nano runmyservice.sh
This is the file that eventually starts your service. To start a JVM, use something similar to the command below.
 #!/bin/bash  
 cd /usr/local/myservice/<name-of-repo-folder>
 java -jar ./<name-of-jar>.jar  
Make the script executable:
 chmod 755 ./runmyservice.sh  
Add a service file for your service
 cd /lib/systemd/system
 sudo nano myservice.serviceAdd the following text:
 [Unit]  
 Description=MyService
 [Service]  
 ExecStart=/usr/local/myservice/runmyservice.sh  
 Type=simple  
 User=root
 Restart=always
 [Install]  
 WantedBy=multi-user.target
This file is what enables systemctl to start, stop and generally handle your service.
Enable your service so that it starts when the server starts
 sudo systemctl enable myservice.service
You can now operate your service using systemctl.
Some useful commands
 sudo systemctl start myservice.service
Stop service
 sudo systemctl stop myservice.service
fredag 12. februar 2016
How to implement SHA2 certificates for Domino 9.0.1 FP3+
Requirements
To implement SHA-2 certificates on a Domino server you need the following:
- Domino server version 9.0.1 FP3 or higher
 The server we will install the certificate on.
- Notes client (preferably admin client) version 9.0.1 FP3 or higher
 Used for generation of the certificate.
- kyrtool.exe
 The new keyring tool for generating Domino keyring files
- OpenSSL for Windows
Preparations
Install OpenSSL for Windows
OpenSSL can be downloaded from the following site:
https://slproweb.com/products/Win32OpenSSL.html
You can download the 32 or the 64 bit version (up to you). The "light" version is good enough.
The installation is straight forward. After the installation set the som needed environment variables using the following commands:
C:\CertFolder>set OPENSSL_CONF=c:\OpenSSL-Win64\bin\openssl.cfg
C:\CertFolder>set RANDFILE=C:\Users\ove\Desktop\.rnd
For convenience you can also add the OpenSSL install folder to your PATH.
Download kyrtool.exe
Kyrtool.exe is especially written to handle SHA-2 certificates on a Domino 9.0.1 FP3+ server. You need to download the tool from the page below.http://www-933.ibm.com/support/fixcentral/swg/selectFixes?parent=ibm~Lotus&product=ibm/Lotus/Lotus+Domino&release=9.0.1.2&platform=All&function=fixId&fixids=KYRTool_9x_ClientServer
Copy the downloaded file to the program directory for your Notes client. The program needs the Notes DLL's to work.
Procedure
Generate a keyring file
We need a keyring file to store the keys and certificates. 
Note that even if you could create this file on your Domino server the server may crash when trying. Use your Notes client!
Command:
C:\IBM\Notes>kyrtool create -k C:\CertFolder\<keyring file name.kyr> -p <keyring password>
Generate a "key" for the server
Use OpenSSL to generate a key that identifies your server.
Command:
C:\CertFolder>c:\OpenSSL-Win64\bin\openssl.exe genrsa -out <keyfilename>.key 4096
Generating RSA private key, 4096 bit long modulus
............................................................................................................................++
..........................................................................................++
e is 65537 (0x10001)
After the key is created you can watch it's content.
Command:
C:\CertFolder>type <keyfilename>.key
-----BEGIN RSA PRIVATE KEY-----
MIIJKgIBAAKCAgEAwygi8FlxJOsKlVS/4AbVZpvY3TQ+hEAEsCqZu9yVg9Je7fUo
1h159HleuANfyms1tCg8nYCblXa+lj42pYgz+IfdcoyUuuv7E6vZAm7PDNBeTjN/
xD/PbXeh6HCWPPHznYxv/dE1YSck4b4BtjqH5AG6512LBmqLq8nSDFDi7E7e5Hwa
...
...
2VCtlxqeztqM66LkqDL4QWmazvrSdLiSxmJn8gr9tpM4CkpUiYvaq9pqB6kQ241n
QBrnngktGz6t06xvcjRz3PKhZkGS2jXJ79dMn+JV34WlZNC6vyzwBymJuwDppeEa
jVBhLeSJvYiZenjOfBscxZp8YxmFALzk4QKUhFLgIYeRkgNp/tt41XAb1oIPKAgm
Hks1Xrl1UOhOCcpsQjMkDVIB1U9VxQG1pE2pEigzoHDxicEqrq1U6w/6kjb9SQ==
-----END RSA PRIVATE KEY-----
Create a certificate signing request (CSR)
Command:C:\CertFolder>c:\OpenSSL-Win64\bin\openssl.exe req -new -sha256 -key <keyfilename>.key -out <keyfilename>.csr
Details for your certificate are required. You need to provide at least the following:
D:\IBM>d:\ibm\domino\kyrtool import all -k d:\IBM\v-man.kyr -i d:\IBM\star_v-man_no.pem
- Country code
- Locality name (city)
- Organization name
- Common name (server fully qualified host name)
- Email address (common email address for company)
Generate a signed certificate for the CSR
The is the part where you buy a certificate from a Certificate Authority (like DigiPlex, RapidSSL or Verisign). Most often they let you decide on a suitable certificate. You must then pay for the certificate before they let you generate a certificate by:
- Specify the server where the certificate is to be used (Domino)
- Pasting in the CSR
The generation may take a while, so be patient...
When the certificate is ready for download also remember to download the root and intermediate certificates for your new certificate. They are needed in the keyring file to form the trust chain.
Try to download the certificates in PEM format (*.pem). Preferably all the certificates in one file.
Add the certificates to the generated keyring file
Collect all the certificates and the key file in the same txt-file
The simplest way to make the keyring work is to install all certificates at the same time. To accomplish this we need to add all the certificates and key (the one we generated for the server) to a file.
The certificates are nothing else than a text-file, so use Notepad++ or similar to add them all to the same file. The following files must be present:
- The server key
- The signed certificate
 The certificate you got from the Certificate Authority.
- The intermediate certifiate
 Note that there may be more than one of these...
- The trusted root certificate
Add the key/certificates to the keyring file
Install the key/certificates to the keyring file using the following command:
C:\CertFolder>d:\ibm\notes\kyrtool import all -k C:\CertFolder\<keyring>.kyr -i C:\CertFolder\<filename_for_all_certs.txt>NOTE! Use absolute paths or you will get a "file not found" error!
You should see the following output:
Using keyring path 'C:\CerfFolder\<keyring>.kyr'
Successfully read 4096 bit RSA private key
SECIssUpdateKeyringPrivateKey succeeded
SECIssUpdateKeyringLeafCert succeeded
Verify the content of the keyring
To verify the content of the keyring file enter the following commands.To list the certificates:
C:\CertFolder>c:\ibm\notes\kyrtool.exe show certs -k C:\CertFolder\<keyring>.kyr
To list the keys:
C:\CertFolder>C:\ibm\notes\kyrtool.exe show keys -k C:\CertFolder\<keyring>.kyr
Both commands will list the certificates/keys.
Install the certificate on a Domino server
Activate HTTPS for server
By default Domino does not accept requests on the HTTPS port (443). You can activate this by setting the field "SSL port status" to "Enabled" in the server document, in the pane "Ports - Internet ports - Web".After this change the Domino server has to be restarted.
Copy the keyring file to the Domino data directory
Copy the keyring file you created to the Domino data directory. Remember to also copy the "<keyring>.sth" file. This file stores the password for the keyring file and is needed for the certificate to work.
Edit the internet site document
This procedure assumes that you have activated "Internet sites" for the server in the server document.
Edit the internet site document that will use this certificate.
- Enter the name of the keyring file in the "Key file name" field under the "Security" pane.
- Add the fully qualified host name and the IP address to the field "Host names or addresses mapped to this site".
 Note that for SSL/HTTPS to work each site that use SSL/HTTP need to be assigned a unique IP address.
When done editing, restart the HTTP task using the following command:
restart task http
Test your implementation using your web browser (of course).
Good luck!
mandag 1. februar 2016
Installing MongoDB 3.2.x (or current MongoDB) on Ubuntu 15.04/15.10
Installing MongoDB on a Unbuntu 15.04/15.10 server should in theory be trivial enough. Unfortunately this turned out to not be the case...
MongoDB has created a "howto" (available here) for Ubuntu, but it won't work as it fails to set up a systemctl service unit. From the command below it is not possible to list the mongod.service unit. It is simply missing, thus it cannot be started...
The official statement from the folks at MongoDB is that they support Ubuntu LTS releases, which would leave me with MongoDB version 2.6.something.
Or I could wait for the next LTS, but sometimes 3 months just seem to be a very looong time...
After searching the net for a solution to this I came across this posting on Stack Overflow:
http://stackoverflow.com/questions/29879231/upgrade-to-ubuntu-15-04-from-14-10-breaks-mongo-how-to-fix
To bad the wrong answer is listed, cause the fix is really simple. Just follow the link on LukePolo's answer.
The trick is simply to install using the debian instruction.
MongoDB has created a "howto" (available here) for Ubuntu, but it won't work as it fails to set up a systemctl service unit. From the command below it is not possible to list the mongod.service unit. It is simply missing, thus it cannot be started...
inforte@mean01:/etc$ sudo systemctl list-units --type=serviceUNIT LOAD ACTIVE SUB DESCRIPTION
lvm2-pvscan@8:17.service loaded active exited LVM2 PV scan on device 8:17mongod.service loaded active running LSB: An object/document-oriented databasenetworking.service loaded active exited LSB: Raise network interfaces.
The official statement from the folks at MongoDB is that they support Ubuntu LTS releases, which would leave me with MongoDB version 2.6.something.
Or I could wait for the next LTS, but sometimes 3 months just seem to be a very looong time...
After searching the net for a solution to this I came across this posting on Stack Overflow:
http://stackoverflow.com/questions/29879231/upgrade-to-ubuntu-15-04-from-14-10-breaks-mongo-how-to-fix
To bad the wrong answer is listed, cause the fix is really simple. Just follow the link on LukePolo's answer.
The trick is simply to install using the debian instruction.
tirsdag 26. januar 2016
Free Docker eBooks from "The New Stack"
If you're curious about Docker or containers and microservices in general, "The New Stack" is currently in the process of writing a series on ebooks on the subject.
2 of the books are already available and can be downloaded from here.
2 of the books are already available and can be downloaded from here.
Abonner på:
Kommentarer (Atom)
 

