Quick test on Terraform with Azure DevOps

Trying to terraform with Azure DevOps, and using these instructions available in internet:
https://www.carbonlogiq.io/post/azure-devops-pipeline-terraform-deployment-tutorial

The original pipeline and terraform files are available at
https://github.com/andrew-kelleher/terraformadopipeline

The files I used are summarized below:

Pipeline files consist of 2 files:

deploy/tfdemo-env01-terraform.yml
- name: Terraform - deploy Service Bus to env01
- stages: template: templates/terraform-template.yml

deploy/templates/terraform-template.yml
- stages: 
  - stage: 'Terraform_Plan'
  - stage: 'Terraform_Apply'

Terraform files are:

terraform/main.tf
- resource "azurerm_resource_group"

terraform/providers.tf
- required_providers azurerm
- backend "azurerm"

terraform/servicebus.tf
- resource "azurerm_servicebus_namespace"
- resource "azurerm_servicebus_queue" "queue01"
- resource "azurerm_servicebus_queue" "queue02"

terraform/variables.tf
- Variable definitions

terraform/tfdemo.env01.tfvars
- Variables values

The main relationships between the files are shown in the picture below.

Pipeline defines the stages Plan and Apply, and refers to all Terraform files located in the Terraform folder.
The actual Terraform commands are executed in the pool agent.

In order to get things working, one has to create self-hosted agent.
The overall working setup is depicted in the picture below:

Fixing naming conflicts in files:

- providers.tf 
- tfdemo.env01.tfvars

Had to define local pool in tfdemo.env01.tfvars:

- pool:
    name: Local
    demands: Agent.Name -equals MUNACER

and in terraform-template.yml:

- pool: Local

For creating self-hosted agents for the local pool, one can download the software via Azure DevOps:
https://learn.microsoft.com/en-us/azure/devops/pipelines/agents/windows-agent?view=azure-devops

How to delete virtual resources

Something not mentioned in the original instructions, is how to delete the resources you have just created.

One way to delete the resources is to use a duplicate of the pipeline and adding
“-destroy” parameter to all Terraform plan and apply commands

Here is an example below:

tfdemo-destroy-part1.yml
- pointing the template to the next yml file:
  template: tfdemo-destroy-part2.yml
tfdemo-destroy-part2.yml
- adding "-destroy" to Plan and Apply stages:
  terraform plan -destroy ...
  terraform apply -destroy ...

Infrastructure as a Service (quick test on Terraform)

I was recently testing Infrastructure as a Service (IaaS) through Terraform.

To be able to get a basic understanding of Terraform, I followed instructions in a book called Learning DevOps to try out a simple test they had outlined in the book.
Link to the book: https://www.packtpub.com/en-fi/product/learning devops-9781801818964

I found the test to be quite interesting, so I want to share the link to which the book had also instructed to go to look.
Link: https://github.com/PacktPublishing/Learning-DevOps-Second-Edition/tree/main/CHAP02/terraform_simple_script

First i had to install Terraform onto the PC.
During the test, I did have some trouble with naming conflicts and having to figure out some authentication mishaps, but after those were resolved it worked as intended.

Here is a picture i made of the setup

The Terraform script in the test creates various resources in Azure, e.g. VM (Virtual Machine) that is accessible from the internet.
There is actually a nice tool in Azure that lets one see the connections/dependencies of different resources. It’s called Resource Visualizer

A picture of the view Resource Visualizer showed me

The test’s execution was quite straightforward. I essentially just used the following four commands:
terraform init
terraform plan -out=terraform-run4.tfstate
terraform apply “terraform-run4.tfstate”
terraform destroy

In the future I have intentions of replicating a similar test to this one with Azure DevOps and Terraform.

VMware and WordPress

Hello, and welcome back to another update!

Today I will briefly cover what I have learned from using a Virtual Machine (VM) to run WordPress.

For this project I used the pre-packaged Virtual Machine image for the VMware Workstation player that is provided by bitnami.
(More information can be found from the links at the bottom of this post!)

The setup seems to be pretty well done.
It was good for learning more about the setup itself as well as the integration.
(eg. apache webserver configuration and wordpress configuration for connecting to database.)

The home PC (host OS) is running MS Windows, while the quest OS is running debian linux.

Here is the simplified diagram of all the main components.

The connections to virtual machine are only possible from the host OS
(since the virtual network “VMNet8” of the VMware workstation player does not allow incoming connection from outside).

The figure below shows how the normal wordpress user on home PC can connect to the apache/wordpress; while admin access to quest OS, PhpMyAdmin and Maria DB requires connection to ssh server.

To connect to the PhpMyAdmin or Maria DB, one can use putty with port forwarding.

When the ssh session is opened, local port in host OS is opened by putty and traffic arriving to that port is forwarded to pre-defined destination at the ssh server environment.

Here is a simplified view when tunnel is set up for PhPMyAdmin

When defining the local port in putty, remember not to allow connections from other hosts to the local port that was opened by putty.
Bellow a picture for reference:

That was all this time, until next time!

More information of the pre-package and instructions:
https://bitnami.com/stack/wordpress/virtual-machine

Draw.io configuration

Hello all, I am back with more news and small projects I’ve been up to.

This time it is a project related to what colors are available in the color picker in draw.io.

Before we get more into this, a quick summary of what draw.io is:

Draw.io is a free online diagram software for making flowcharts, process diagrams, org charts, UML, ER and network diagrams. It can also be downloaded, which is what I have in use at the moment.

Then to the plan and results

Now, normally the draw.io color picker looks something like this:

While these options are great for their variety, for this project I wanted a simpler assortment of colors, that I was already familiar with.

That is how I ended up configuring the colors to look like the options in PowerPoint.

This is how the colors look in PowerPoint, for ease of reference.

That is how I made the following plan of action:

And then had this as the end result:

Not the most elegant looking solution, but it did what I wanted it to.

But how did we get here?

Draw.io is interesting for how you are able to modify it.

From the research I have done, if you know what you’re doing, anything is configurable and can be done following this path:

Extras -> Configuration…

Then clicking on “Configuration..” will open this view:

And after entering the wanted JSON configuration, clicking apply and restarting the software, the changes will take effect.

In case anyone would want to try doing the same configuration I will embed what I used bellow:

{
  "defaultFonts": [
    "Helvetica",
    "Verdana",
    "Times New Roman",
    "Garamond",
    "Comic Sans MS",
    "Courier New",
    "Georgia",
    "Lucida Console",
    "Tahoma"
  ],
  "defaultColorSchemes": [
	[ null,	{ "fill": "#f5f5f5", "stroke": "#666666" },				{ "fill": "#dae8fc", "stroke": "#6c8ebf" },				{ "fill": "#d5e8d4", "stroke": "#82b366" },				{ "fill": "#ffe6cc", "stroke": "#d79b00" },				{ "fill": "#fff2cc", "stroke": "#d6b656" },				{ "fill": "#f8cecc", "stroke": "#b85450" },				{ "fill": "#e1d5e7", "stroke": "#9673a6" } ],
	[ null,	{ "fill": "#f5f5f5", "stroke": "#666666", "gradient": "#b3b3b3" },	{ "fill": "#dae8fc", "stroke": "#6c8ebf", "gradient": "#7ea6e0" },	{ "fill": "#d5e8d4", "stroke": "#82b366", "gradient": "#97d077" },	{ "fill": "#ffcd28", "stroke": "#d79b00", "gradient": "#ffa500" },	{ "fill": "#fff2cc", "stroke": "#d6b656", "gradient": "#ffd966" },	{ "fill": "#f8cecc", "stroke": "#b85450", "gradient": "#ea6b66" },	{ "fill": "#e6d0de", "stroke": "#996185", "gradient": "#d5739d" } ],
	[ null,	{ "fill": "#eeeeee", "stroke": "#36393d" },				{ "fill": "#f9f7ed", "stroke": "#36393d" },				{ "fill": "#ffcc99", "stroke": "#36393d" },				{ "fill": "#cce5ff", "stroke": "#36393d" },				{ "fill": "#ffff88", "stroke": "#36393d" },				{ "fill": "#cdeb8b", "stroke": "#36393d" },				{ "fill": "#ffcccc", "stroke": "#36393d" } ]
  ],	
  "presetColors": [
	"none",		"C00000",	"FF0000",	"FFC002",	"FFFF00",	"92D050",	"00B050",	"00B0F0",	"0070C0",	"002060",	"7030A0",	"none",
	"none",		"C00000",	"FF0000",	"FFC002",	"FFFF00",	"92D050",	"00B050",	"00B0F0",	"0070C0",	"002060",	"7030A0",	"none"
  ],
  "defaultColors": [
	"none",		"FFFFFF",	"000000",	"E7E6E6",	"44546A",	"5B9BD5",	"ED7D31",	"A5A5A5",	"FFC000",	"4472C4",	"70AD47",	"none",
	"none",		"F2F2F2",	"7F7F7F",	"D0CECE",	"D6DCE5",	"DEEBF7",	"FBE5D6",	"EDEDED",	"FFF2CC",	"DAE3F3",	"E2F0D9",	"none",
	"none",		"D9D9D9",	"595959",	"AFABAB",	"ADB9CA",	"BDD7EE",	"F8CBAD",	"DBDBDB",	"FFE699",	"B4C7E7",	"C5E0B4",	"none",
	"none",		"BFBFBF",	"404040",	"767171",	"8497B0",	"9DC3E6",	"F4B183",	"C9C9C9",	"FFD966",	"8FAADC",	"A9D18E",	"none",
	"none",		"A6A6A6",	"262626",	"3B3838",	"333F50",	"2E75B6",	"C55A11",	"7C7C7C",	"BF9000",	"2F5597",	"548235",	"none",
	"none",		"7E7E7E",	"0D0D0D",	"181717",	"222A35",	"1F4E79",	"843C0C",	"525252",	"7F6000",	"203864",	"385723",	"none",
	"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",
	"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",
	"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",
	"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none",		"none"
  ],
  "defaultLibraries": "general;images;uml;er;bpmn;flowchart;basic;arrows2",
  "colorNames": {
	"FFFFFF": "White",		"F2F2F2": "White, Darker 5%",		"D9D9D9": "White, Darker 15%",		"BFBFBF": "White, Darker 25%",		"A6A6A6": "White, Darker 35%",		"7E7E7E": "White, Darker 50%",
	"000000": "Black",		"7F7F7F": "Black, Lighter 50%",		"595959": "Black, Lighter 35%",		"404040": "Black, Lighter 25%",		"262626": "Black, Lighter 15%",		"0D0D0D": "Black, Lighter 5%",
	"E7E6E6": "Light Gray",		"D0CECE": "Light Gray, Darker 10%",	"AFABAB": "Light Gray, Darker 25%",	"767171": "Light Gray, Darker 50%",	"3B3838": "Light Gray, Darker 75%",	"181717": "Light Gray, Darker 90%",
	"44546A": "Gray Blue",		"D6DCE5": "Gray Blue, Lighter 80%",	"ADB9CA": "Gray Blue, Lighter 60%",	"8497B0": "Gray Blue, Lighter 40%",	"333F50": "Gray Blue, Darker 25%",	"222A35": "Gray Blue, Darker 50%",
	"5B9BD5": "Light Blue",		"DEEBF7": "Light Blue, Lighter 80%",	"BDD7EE": "Light Blue, Lighter 60%",	"9DC3E6": "Light Blue, Lighter 40%",	"2E75B6": "Light Blue, Darker 25%",	"1F4E79": "Light Blue, Darker 50%",
	"ED7D31": "Dark Orange",	"FBE5D6": "Dark Orange, Lighter 80%",	"F8CBAD": "Dark Orange, Lighter 60%",	"F4B183": "Dark Orange, Lighter 40%",	"C55A11": "Dark Orange, Darker 25%",	"843C0C": "Dark Orange, Darker 50%",
	"A5A5A5": "Dark Gray",		"EDEDED": "Dark Gray, Lighter 80%",	"DBDBDB": " Dark Gray, Lighter 60%",	"C9C9C9": "Dark Gray, Lighter 40%",	"7C7C7C": "Dark Gray, Darker 25%",	"525252": "Dark Gray, Darker 50%",
	"FFC000": "Gold",		"FFF2CC": "Gold, Lighter 80%",		"FFE699": "Gold, Lighter 60%",		"FFD966": "Gold, Lighter 40%",		"BF9000": "Gold, Darker 25%",		"7F6000": "Gold, Darker 50%",
	"4472C4": "Blue",		"DAE3F3": "Blue, Lighter 80%",		"B4C7E7": "Blue, Lighter 60%",		"8FAADC": "Blue, Lighter 40%",		"2F5597": "Blue, Darker 25%",		"203864": "Blue, Darker 50%",
	"70AD47": "Forest Green",	"E2F0D9": "Forest Green, Lighter 80%",	"C5E0B4": "Forest Green, Lighter 60%",	"A9D18E": "Forest Green, Lighter 40%",	"548235": "Forest Green, Darker 25%",	"385723": "Forest Green, Darker 50%",
	"C00000": "Dark Red",
	"FF0000": "Red",
	"FFC002": "Orange",
	"FFFF00": "Yellow",
	"92D050": "Light Green",
	"00B050": "Green",
	"00B0F0": "Sky Blue",
	"0070C0": "Navy Blue",
	"002060": "Dark Blue",
	"7030A0": "Purple"
  }
}

Thank you all, that was it for this time.

Until next time!

ER-diagram & SQL/DBeaver-schema

Hello, once again, and welcome all to an example on how to go from an ER diagram into a DB schema!

We will look into this example, by usin Videolister, which I did an update on a little while ago. To develop and transform the videolister tool into an online tool, an ER-diagram (ER=Entity Relationship) was made for the new multi-user tool.

I used ERDplus to make it, but draw.io would be just as sufficient.

The ER diagram for Videolister

After making the ERDplus, I used DBeaver program to transform it into a database schema.

SQL/DBeaver diagram of Videolister

Though I used DBeaver to do this, it is also possible to create this using other similar programs, or the SQL language. With similar programs, and in DBeaver, the SQL portions are often created for you and your work in making the schema stays mostly visual.

Here are some examples of SQL that DBeaver created for “Linkkikokoelma” and “Videolinkki” tables:

CREATE TABLE Linkkikokoelma (

      kokoelma_ID INTEGER NOT NULL,

      nimi VARCHAR NOT NULL,

      kuvaus VARCHAR,

      käyttäjänimi VARCHAR NOT NULL,

      CONSTRAINT Linkkikokoelma_PK PRIMARY KEY (kokoelma_ID),

      CONSTRAINT Linkkikokoelma_Käyttäjä_FK FOREIGN KEY (käyttäjänimi) REFERENCES Käyttäjä(käyttäjänimi)

);

CREATE TABLE Videolinkki (

      kokoelma_ID INTEGER NOT NULL,

      URL VARCHAR NOT NULL,

      otsikko VARCHAR NOT NULL,

      kuvaus VARCHAR,

      arvosana INTEGER,

      CONSTRAINT Videolinkki_PK PRIMARY KEY (URL,kokoelma_ID),

      CONSTRAINT Videolinkki_Videolinkkilista_FK FOREIGN KEY (kokoelma_ID) REFERENCES Videolinkkilista(kokoelma_ID)

);

After the tables have been added and connected visually, it’s time to add data into the tables. Here are some examples using the same tables as above:

Data that was inputed onto Linkkikokoelma table
Some of the data inputed onto Videolinkki table

All in all, I think DBeaver was quite easy to pick up and use (at least somewhat) effectively. It was very helpful in managing the general flow of database creation and modification.

That was all for this time; until next time!

Links for those interested:

ERDplus: https://erdplus.com/standalone

DBeaver: https://dbeaver.io/

Videolister – a List of links

I worked on a project that I am calling Videolister.

The idea for the project came from one of my friends. They mentioned storing link to various ukulele tutorials in a simple text editor, not all in one place, and how it was a chore to go through. So I thought of making a simple tool for maintaining list of links to youtube videos.

This was great for me as I was looking for a java object oriented programming exercise, and I had just found what I was looking for.

Bellow are some screenshots and explanations.

Here is the main screen of the program, after choosing a List. In this main screen you manage all added videos in the specific List.

Should you click the “Modify tags” button in the earlier view, you’d be met with this pop-up. In here you create and manage the tags that can then be added to your video for easier identification and searching.

Here is the “filter config” window, opened by the button with the same name on the main screen. It is essentially a rudimentary search system. It applies a filter on every video on the List and only shows those that match the given parameters.

I should have some pictures still saved from earlier versions and other neat things to give a sort of tutorial on how to make one. I might add it here at some point. Who knows?

Still there is one more picture for me to share:

This is a printed table of how the data is stored for the program to read. It’s not all the data it needs, but I thought it would be nice to get to see this for some. So there you go!

That was all this time around. Thanks for reading!

Draw.io

I am trying to learn how to manage draw.io.

In this post it’s going to be used to make a BPMN diagram as an example, using draw.io’s BMPN 2 tools. The version of draw.io I am using is the standalone version.

Very usefull and handy for doing diagrams. It was fairly simple to use too! Please see the BPMN picture below:

Links for those interested below!

site: https://www.drawio.com

downloads: https://github.com/jgraph/drawio-desktop/releases/tag/v22.1.21

Dolibarr

Trying out getting first look on Dolibar. It was quite impressive functionality. Trying to connect things and figure out how things work was difficult at first though and it can feel overwhelming. Try to find some guides to help you out in the beginning and then just start experimenting!

Here are some screenshots:

Please note! In this, the windows version was used, and had to use http instead of https. For any real use, remember to implement https.

If you get interested in trying out Dolibarr yourself, you can find it here: https://www.dolibarr.org

Nextcloud setup: An update!

Here comes the updated setup, working well now with mini-PC. The rasberry PI was a little too slow when sharing screen. (previous blog on https://cloudtech.ovh/nextcloudpi-setup-on-home-network)

This is the (not so modified) way of doing things now:

This is the mini-PC we used for this project’s update!

Mini-PC Specs:
HP ProDesk 600 G3
Core i7-7700T 2.9 GHz
MEMORY 16
ssh 500 Gb
Win 10 Home

Interested in nextcloud? Try it out here for yourself:

https://nextcloud.com/

https://en.wikipedia.org/wiki/Nextcloud

NextCloudPi setup on home network

This time I decided to setup a NextCloudPi with the help of my friend to see if it would be something we would like to use. We are interested to get our own video conference with screen sharing for doing some things (small projects) together.

NextCloud is a community sourced file hosting software similar to Dropbox, Office 365 or Google Drive. It’s main usage and feature is file storage and sharing, but add-ons, like a zoom-meeting/skype chat type of function, are quite readily available and easy to install.

We set it up to run on a Rasberry Pi 3. It isn’t the fastest, but it does what we wanted it to and it wasn’t that hard to get running. The diagram below shows the setup.

We got the voice conference working, and screen sharing when we are both in the same network. But when in different networks, the screen sharing worked only for one.

As the system with raspberry was extremely slow, we will try next the same setup with an old laptop, to presumably increase the processing speed. If the same problem persists, then we fix it.

Looking forward 🙂