Archive | Eylül, 2019

Omarine 6.2 duyuruldu

Aslında bir sunucu projesi olan Vietnam kökenli GNU/Linux dağıtımı Omarine‘in 6.2 sürümü duyuruldu. Ayrıca GNOME, KDE Plasma, Xfce ve LXDE masaüstü ortamlarıyla bir masaüstü bilgisayarda da kullanılabilen Omarine, ilk başta Slackware Linux’a dayalı olarak üretilmiş olsa da artık bağımsız olarak çıkarılıyor. Sistemin virüslere karşı son derece korunaklı olarak üretildiği ifade ediliyor. Dahili bir güvenlik duvarı içeren sistem Security Enhanced Linux (SELinux) ile donatılmış bulunuyor. Yeni sürüm, Xfce 4.14 ve GNOME 3.32.2 masaüstü ortamları dışında BIND 9.14.4, MySQL 8.0.17, GnuCash 3.6 gibi güncel yazılımları içeriyor. Bu sürümdeki en önemli değişikliğin, sistemi otomatik olarak güncelleyen Omarine Update programı olduğu bildirilirken, güncellemelerin kullanıcıya bildirileceği, dileyen kullanıcının root olarak omarine-update komutunu kullanarak sistemi güncelleyebileceği belirtildi. Omarine 6.2 hakkında ayrıntılı bilgi edinmek için sistemin web sayfasını inceleyebilirsiniz.

Continue Reading →

Omarine 6.2 edinmek için aşağıdaki linkten yararlanabilirsiniz.

0

Endless OS 3.6.3 duyuruldu

GNOME 3’ten çatallanmış özelleştirilmiş bir masaüstü ortamını kullanarak, basitleştirilmiş ve düzenli bir kullanıcı deneyimi sunmayı amaç edinen Debian GNU/Linux tabanlı Endless OS‘nin 3.6.3 sürümü, Endless OS ekibi tarafından duyuruldu.  3.6 serisi için yeni bir güncelleme olarak gelen yeni sürüm, bilgisayar sahibinin sistemi kilitlemesine yardımcı olmak için birkaç yeni temel özellik sunuyor ve aynı zamanda önyükleme ve masaüstünde oturum açma ile ilgili bazı sorunları düzeltiyor. Artık kullanıcıların web tarayıcılarına ebeveyn denetimleriyle erişimlerini kısıtlamak olanağı olduğu bildiriliyor. 3.6.0 ve 3.6.2 arasında, önyükleme ve bilgisayarda oturum açmayı önleyebilecek bilinen iki sorun olduğu, her ikisinin de bu sürümde düzeltildiği ifade ediliyor. Debian 10 “Buster” tabanlı olarak gelen sistemde, pek çok paket en güncel sürümleriyle geliyor. Endless OS 3.6.3 hakkında ayrıntılı bilgi edinmek için sürüm duyurusunu inceleyebilirsiniz.

Continue Reading →

Endless OS 3.6.3 edinmek için aşağıdaki linklerden yararlanabilirsiniz.

0

Wine-Staging 4.16 duyuruldu

Wine’in 4.16 sürümünün duyurulmasından sonra, Wine-Staging’in 4.16 sürümü de, Alistair Leslie-Hughes tarafından duyuruldu. Henüz geliştirme aşamasına gelmemiş hata düzeltmelerini ve özellikleri ele alan ve winehq.org‘un bir test alanı olan Wine Staging‘in yeni sürümünde, 2 değişiklik, 3 ekleme ve 3 silme işlemi gerçekleştirilmiş bulunuyor. Wine-Staging 4.16, Direct3D 9 görüntü oluşturma sorunları hakkında uzun süredir var olan bir hata raporu için geçici bir düzeltme getiriyor. İşlevsellik, Final Fantasy XIV, The Witcher 2, Darkness II, Speed Shift 2, Resident Evil 4 ve diğer oyunlarla ilgili sorunları çözmek için yeni bir “multiply_special” kayıt defteri anahtarıyla etkinleştirilebiliyor. Yeni sürüm; 800’den fazla düzeltme ekine sahip ve mevcut bazı özellik düzeltme ekleri için bir dizi yeni düzeltme eki ve güncelleme işlevi de içeriyor. Wine-Staging belgelerine ise buradan ulaşabilirsiniz. Wine-Staging 4.16 hakkında daha ayrıntılı bilgi edinmek için GitHub üzerindeki değişiklikler sayfasını inceleyebilirsiniz.

Continue Reading →

Wine-Staging 4.16 edinmek için aşağıdaki linkten yararlanabilirsiniz.

0

KDE Frameworks 5.62.0 duyuruldu

KDE topluluğu, Qt eklenti kütüphanelerinin en yeni sürümü olan KDE Frameworks 5.62.0’ı duyurdu. Geliştirme ekibinin KDE Frameworks 5.62.0’ı duyurmaktan çok mutlu olduğu belirtilirken, dost lisans şartları ile kütüphanelerin test edildiği, KDE Frameworks’un Qt için işlevselliği geniş bir yelpazede 70 eklenti kütüphanesi içerdiği ifade edildi. KWayland ile the zwp_linux_dmabuf_v1 Wayland protokolü için destek sağlanan sürümde, KFileMetaData şimdi kalıpların yazılmasını destekliyor. Birçok KIO düzeltmesi ile gelen yeni sürümde, C++, JavaScript ve diğer diller etrafında özdizimi vurgulama desteğinin düzeltme ve iyileştirmeleri bulunuyor. Bu sürümün, geliştiriciler için hızlı ve öngörülebilir bir şekilde iyileştirmeler sağlayan, iyileştirme amaçlı bir dizi çalışmasının bir parçası olduğu söyleniyor. KDE Frameworks 5.62.0 hakkında ayrıntılı bilgi edinmek için sürüm duyurusunu inceleyebilirsiniz.

Continue Reading →

Çeşitli dağıtımlar için paketlerin yüklenmesine yönelik yönergeleri burada bulabilirsiniz. KDE Frameworks 5.62.0 edinmek için buradan yararlanabilirsiniz.

0

PyCharm 2019.3 EAP 1 duyuruldu

PyCharm’ın PyCharm 2019.3 EAP 1 sürümü, Joaquin Treviño tarafından duyuruldu. Yazılıma Python çalıştırması yapılandırmasında parametre olarak ayarlanabilecek komut dosyası çalıştırma işlemlerini kişiselleştirmek için şimdi yeni bir seçenek eklediklerini belirten Treviño; Jupyter notebooklarda bazı düzeltmeler yapıldığını söyledi. IPython için hata ayıklayıcının düzgün çalışmamasına neden olan bazı sorunlar da çözülmüş bulunuyor. Daha fazla bilgi için sürüm notlarının incelenebileceğini ifade ediliyor. Bunun bir test sürümü olduğunun unutulmaması ve yalnızca test etmek amacıyla kullanılması gerektiği hatırlatılırken, test eden kullanıcıların tespit ettikleri hataları rapor etmeleri rica ediliyor. PyCharm 2019.3 EAP 1 hakkında ayrıntılı bilgi edinmek için sürüm duyurusunu inceleyebilirsiniz.

Continue Reading →

PyCharm 2019.3 EAP 1 edinmek için aşağıdaki linkten yararlanabilirsiniz.

0

Slax 9.11.0 duyuruldu

Debian’ın kararlı versiyonuna dayanan minimalist bir masaüstü live CD’si olarak kullanıma sunulan Slax‘ın 9.11.0 sürümü, Tomáš Matějíček tarafından duyuruldu. Yeni okul yılının başladığını söyleyen Matějíček; yeni Slax sürümünün de kullanıma hazır olduğunu belirtti. Sürümün, Debian 9.11 Jessie’den gelen tüm hata düzeltmelerini ve güvenlik güncellemelerini içerdiğini söyleyen Matějíček; konsol boşluğunun varsayılan olarak devre dışı olduğunu hatırlattı. Slax projesinin kararlı sürümün onbirinci güncellemesini duyurmaktan mutluluk duyduğunu söyleyen Matějíček; paralel indirme özelliği kullanılarak TFTP sunucusundan PXE önyüklemesinin şimdi 3 kat daha hızlı indirilebildiğini söyledi. Matějíček; Debian 10’a dayanan Slax için çalışmaların devam ettiğini, ancak henüz hazır olmadığını, hazır olması için en azından birkaç hafta gerektiğini söyledi. Slax 9.11.0 hakkında ayrıntılı bilgi edinmek için sürüm duyurusunu inceleyebilirsiniz.

Continue Reading →

Slax 9.11.0 edinmek için aşağıdaki linklerden yararlanabilirsiniz.

0

Expect command and how to automate shell scripts like magic

In the previous post, we talked about writing practical shell scripts and we saw how it is easy to write a shell script. Today we are going to talk about a tool that does magic to our shell scripts, that tool is the Expect command or Expect scripting language. Expect command or expect scripting language is a language that talks with your interactive programs or scripts that require user interaction. Expect scripting language works by expecting input, then the Expect script will send the response without any user interaction. You can say that this tool is your robot which will automate your scripts.

Continue Reading →

If Expect command if not installed on your system, you can install it using the following command:

$ apt-get install expect

Or on Red Hat based systems like CentOS:

$ yum install expect

Expect Command

Before we talk about expect command, Let’s see some of the expect command which used for interaction:

spawn                  Starting a script or a program.

expect                  Waiting for program output.

send                      Sending a reply to your program.

interact                Allowing you in interact with your program.

  • The spawn command is used to start a script or a program like the shell, FTP, Telnet, SSH, SCP, and so on.
  • The send command is used to send a reply to a script or a program.
  • The Expect command waits for input.
  • The interact command allows you to define a predefined user interaction.

We are going to type a shell script that asks some questions and we will make an Expect script that will answer those questions.

First, the shell script will look like this:

#!/bin/bash

echo "Hello, who are you?"

read $REPLY

echo "Can I ask you some questions?"

read $REPLY

echo "What is your favorite topic?"

read $REPLY

Now we will write the Expect scripts that will answer this automatically:

#!/usr/bin/expect -f

set timeout -1

spawn ./questions

expect "Hello, who are you?\r"

send -- "Im Adam\r"

expect "Can I ask you some questions?\r"

send -- "Sure\r"

expect "What is your favorite topic?\r"

send -- "Technology\r"

expect eof

The first line defines the expect command path which is #!/usr/bin/expect.

On the second line of code, we disable the timeout. Then start our script using spawn command.

We can use spawn to run any program we want or any other interactive script.

The remaining lines are the Expect script that interacts with our shell script.

The last line if the end of file which means the end of the interaction.

Now Showtime, let’s run our answer bot and make sure you make it executable.

$ chmod +x ./answerbot

$./answerbot

expect command

Cool!! All questions are answered as we expect.

If you get errors about the location of Expect command you can get the location using the which command:

$ which expect

We did not interact with our script at all, the Expect program do the job for us.

The above method can be applied to any interactive script or program.Although the above Expect script is very easy to write, maybe the Expect script little tricky for some people, well you have it.

Using autoexpect

To build an expect script automatically, you can the use autoexpect command.

autoexpect works like expect, but it builds the automation script for you. The script you want to automate is passed to autoexpect as a parameter and you answer the questions and your answers are saved in a file.

$ autoexpect ./questions

autoexpect command

A file is generated called script.exp contains the same code as we did above with some additions that we will leave it for now.

autoexpect script

If you run the auto generated file script.exp, you will see the same answers as expected:

autoexpect script execution

Awesome!! That super easy.

There are many commands that produce changeable output, like the case of FTP programs, the expect script may fail or stuck. To solve this problem, you can use wildcards for the changeable data to make your script more flexible.

Working with Variables

The set command is used to define variables in Expect scripts like this:

set MYVAR 5

To access the variable, precede it with $ like this $VAR1

To define command line arguments in Expect scripts, we use the following syntax:

set MYVAR [lindex $argv 0]

Here we define a variable MYVAR which equals the first passed argument.

You can get the first and the second arguments and store them in variables like this:

set my_name [lindex $argv 0]

set my_favorite [lindex $argv 1]

Let’s add variables to our script:

#!/usr/bin/expect -f

set my_name [lindex $argv 0]

set my_favorite [lindex $argv 1]

set timeout -1

spawn ./questions

expect "Hello, who are you?\r"

send -- "Im $my_name\r"

expect "Can I ask you some questions?\r"

send -- "Sure\r"

expect "What is your favorite topic?\r"

send -- "$my_favorite\r"

expect eof

Now try to run the Expect script with some parameters to see the output:

$ ./answerbot SomeName Programming

expect command variables

Awesome!! Now our automated Expect script is more dynamic.

Conditional Tests

You can write conditional tests using braces like this:

expect {

"something" { send -- "send this\r" }

"*another" { send -- "send another\r" }

}

We are going to change our script to return different conditions, and we will change our Expect script to handle those conditions.

We are going to emulate different expects with the following script:

#!/bin/bash

let number=$RANDOM

if [ $number -gt 25000 ]; then

echo "What is your favorite topic?"

else

echo "What is your favorite movie?"

fi

read $REPLY

A random number is generated every time you run the script and based on that number, we put a condition to return different expects.

Let’s make out Expect script that will deal with that.

#!/usr/bin/expect -f

set timeout -1

spawn ./questions

expect {

"*topic?" { send -- "Programming\r" }

"*movie?" { send -- "Star wars\r" }

}

expect eof

expect command conditions

Very clear. If the script hits the topic output, the Expect script will send programming and if the script hits movie output the expect script will send star wars. Isn’t cool?

If else Conditions

You can use if/else clauses in expect scripts like this:

#!/usr/bin/expect -f

set NUM 1

if { $NUM < 5 } {

puts "\Smaller than 5\n"

} elseif { $NUM > 5 } {

puts "\Bigger than 5\n"

} else {

puts "\Equals 5\n"

}

if command

Note: The opening brace must be on the same line.

While Loops

While loops in expect language must use braces to contain the expression like this:

#!/usr/bin/expect -f

set NUM 0

while { $NUM <= 5 } {

puts "\nNumber is $NUM"

set NUM [ expr $NUM + 1 ]

}

puts ""

while loop

For Loops

To make a for loop in expect, three fields must be specified, like the following format:

#!/usr/bin/expect -f

for {set NUM 0} {$NUM <= 5} {incr NUM} {

puts "\nNUM = $NUM"

}

puts ""

for loop

User-defined Functions

You can define a function using proc like this:

proc myfunc { TOTAL } {

set TOTAL [expr $TOTAL + 1]

return "$TOTAL"

}

And you can use them after that.

#!/usr/bin/expect -f

proc myfunc { TOTAL } {

set TOTAL [expr $TOTAL + 1]

return "$TOTAL"

}

set NUM 0

while {$NUM <= 5} {

puts "\nNumber $NUM"

set NUM [myfunc $NUM]

}

puts ""

user-defined functions

Interact Command

Sometimes your Expect script contains some sensitive information that you don’t want to share with other users who use your Expect scripts, like passwords or any other data, so you want your script to take this password from you and continuing automation normally.

The interact command reverts the control back to the keyboard.

When this command is executed, Expect will start reading from the keyboard.

This shell script will ask about the password as shown:

#!/bin/bash

echo "Hello, who are you?"

read $REPLY

echo "What is you password?"

read $REPLY

echo "What is your favorite topic?"

read $REPLY

Now we will write the Expect script that will prompt for the password:

#!/usr/bin/expect -f

set timeout -1

spawn ./questions

expect "Hello, who are you?\r"

send -- "Hi Im Adam\r"

expect "*password?\r"

interact ++ return

send "\r"

expect "*topic?\r"

send -- "Technology\r"

expect eof

interact command

After you type your password type ++ and the control will return back from the keyboard to the script.

Expect language is ported to many languages like C#, Java, Perl, Python, Ruby and Shell with almost the same concepts and syntax due to its simplicity and importance.

Expect scripting language is used in quality assurance, network measurements such as echo response time, automate file transfers, updates, and many other uses.

I hope you now supercharged with some of the most important aspects of Expect command, autoexpect command and how to use it to automate your tasks in a smarter way.

Thank you.

0