середа, 11 жовтня 2017 р.

wine steam

Встановив файл проекту PortWINE і "в ус не дую"

#enable 32 bit architecture
sudo dpkg --add-architecture i386

#Add the repository:
wget -nc https://dl.winehq.org/wine-builds/Release.key
sudo apt-key add Release.key
sudo apt-add-repository https://dl.winehq.org/wine-builds/ubuntu/

# On Linux Mint 18.x, the last line should be the following:
sudo apt-add-repository 'deb https://dl.winehq.org/wine-builds/ubuntu/ xenial main'

# Update packages:
sudo apt-get update

# install Stable branch
sudo apt-get install --install-recommends winehq-stable

# or install  Development branch  (+++)
sudo apt-get install --install-recommends winehq-devel

rm -R ~/.wine 
env WINEPREFIX=~/.wine WINEARCH=win32 winecfg
(winecfg - setup winxp over win7)

# +winetricks
sudo apt install winetricks
winetricks corefonts allfonts tahoma gecko gecko-dbg vcrun2005

winetricks vcrun2005
winetricks --no-isolate steam

wine Steam.exe -no-cef-sandbox

субота, 19 серпня 2017 р.

SSL_сертифікати

Налаштування SSL-сертифікатів.

Зустрівся з помилкою в журналі поштового сервера (exim):

2017-08-17 02:42:55 TLS error on connection from mail-la0-f52.google.com [209.85.215.52] (cert/key setup: cert=/etc/exim4/exim.crt key=/etc/exim4/exim.key): The provided X.509 certificate list is not sorted (in subject to issuer order)
Рішення

Для exim4 вказуємо сертифікат сервера і ключ:
у файлі /etc/exim4/exim4.conf.template

tls_certificate = /-path-to-ssl-/server.crt
tls_privatekey = /-path-to-ssl-/server.key

Для веб-сервера сертифікат сервера потрібно об'єднати з сертифікатом кореневого сервера:
у налаштуваннях nginx.conf

server {
    ...
    ssl_certificate      /-path-to-ssl-/server.pem;
    ssl_certificate_key  /-path-to-ssl-/server.key;
    ...
}

При цьому маємо такі файли з сертифікатами:

intermediateCA.crt - кореневий сертифікат
server.crt                 - сертифікат сервера
server.pem               - об'єднаний сертифікат сервера + кореневий
       ( cp server.crt server.pem; cat intermediateCA.crt >> server.pem )
server.key                - ключ сервера


середа, 12 липня 2017 р.

VirtualBox NO_PUBKEY A2F683C52980AECF

Встановлення VirtualBox-у й ключ NO_PUBKEY A2F683C52980AECF

Рішення:
wget -q -O - \
http://download.virtualbox.org/virtualbox/debian/oracle_vbox_2016.asc | sudo apt-key add -

Універсально:
sudo apt-key adv --keyserver keyserver.ubuntu.com \ 
                 --recv-keys 517590D9A8492E35

Skype for Linux (Beta)

При встановленні Skype для Linux з'являється повідомлення про ключ NO_PUBKEY 1F3045A5DF7587C3

Рішення:
curl https://repo.skype.com/data/SKYPE-GPG-KEY | sudo apt-key add -

четвер, 25 травня 2017 р.

Viber Linux Mint (Debian)

Не запускається Viber.
Всього лише потрібно доустановити бібліотеку:

sudo apt-get install libqt5gui5
 

вівторок, 18 квітня 2017 р.

Друга Wi-Fi-точка, як продовження першої

Маю офіс з мережею 192.168.1.0/24. Маю стареньку Wi-Fi точку доступу AP1, що гарно працює в режимі "моста" (bridge).

Задача: встановити ще одну, сучасну, точку доступу AP2, щоб теж не була "розумною", тобто в режимі "моста-подовжувача" (bridge, repitor).

Рішення:
1) відключити uPnP,
2) відключити DHCP-сервер,
3) назначити IP-адресу для AP2.


субота, 8 квітня 2017 р.

WooCommerce category (categories) and product's

Документація з WooCommerce не надихає на код, а чомусь, відсилає в адмінку Wordpress-у.
/* STEP1: parent = 0
   find top-level categories
   знаходимо теки на верхнього рівня
*/
$cats0 = get_terms( 'product_cat',
                    array( 'hide_empty' => false,
                           'fields'     => 'ids',
                           'parent'     => '0',
                           'orderby'    => 'term_id',
                           'order'      => 'ASC'
                   ));
foreach ( $cats0 as $cat0_id ) {
  $cat0 = get_term( $cat0_id, 'product_cat' );
  echo $cat0->name;
  echo $cat0->slug;
  echo $cat0->description;
  /* рибимо те, що потрібно з категорією */


  /* STEP1: parent = $cat0_id
     find next-level categories
     знаходимо теки на рівень нижче
  */
  $cars1 = get_terms( 'product_cat',
                       array( 'hide_empty' => false,
                              'fields'     => 'ids',
                              'parent'     => $cat0_id,
                              'orderby'    => 'term_id',
                              'order'      => 'ASC'
                      ));
  foreach ( $cats1 as $cat1_id ) {
    $cat1 = get_term( $cat1_id, 'product_cat' );
    echo $cat1->name;
    echo $cat1->slug;
    echo $cat1->description;
    /* рибимо те, що потрібно з під-категорією */


    /* STEP3: products
       find products in this category
       знаходимо товари в цій категорії
    */
    if( $_SERVER['REQUEST_URI'] == '/shop/' ){
      $args = array( 'post_type'      => 'product',
                     'posts_per_page' => 6,
                     'product_cat'    => $cat1->slug,
                     'orderby'        => 'name',
                     'order'          => 'ASC'
                   );
      $loop = new WP_Query( $args );
      while ( $loop->have_posts() ) : $loop->the_post();
        global $product;

        /* id */
        echo get_permalink( $loop->post->ID );

        /* title */
        echo $loop->post->post_title;

        /* sale! */
        woocommerce_show_product_sale_flash(
                   $post, $product);

        /* image */
        if (has_post_thumbnail( $loop->post->ID ))
          echo get_the_post_thumbnail(
                   $loop->post->ID, 'shop_catalog');
        else
          echo '<img src="'
               .woocommerce_placeholder_img_src()
               .'"   alt="Placeholder"
                     width="300px" height="300px" />';

        /* description */
        echo strip_tags( $loop->post->post_content );

        /* price */
        echo $product->get_price_html();

        /* add to cart */
        woocommerce_template_loop_add_to_cart(
                   $loop->post, $product );

      endwhile;
      wp_reset_query();
    } /* if $_SERVER['REQUEST_URI'] */
  }   /* foreach $terms1            */
}     /* foreach $terms             */



середа, 8 березня 2017 р.

SSH-тунель з Windows-клієнта через Mikrotik

Задача: зробити віддалений доступ до Windows-сервера з Windows-клаєнта через Mikrotik.

1. Завантажити й встановити PuTTY (наприклад, putty-0.68-installer.msi)
2. Згенерувати ключі - puttygen.exe
2.1. Просто натисніть й рухайте мишкою поки не заповниться синій бігунок.
2.2. Згенеровані ключі потрібно зберегти: public.key та private.key.
 
2.3.АЛЕ, записаний нами приватний ключ не буде прийнятий Mikrotik-ом. Тому потрібно виділити все у віконці

зкопіювати й записати у файл public.key.
3. Сам файл public.ket потрібно перенести на Mikrotik:

pscp.exe -scp -P 22 -pw userpass public.key username@mikrotik:/userkey.pub

4. Імпортуємо (прив’язуємо) ключ до користувача:
5. Завантажуємо ключ в ssh-agent-а:

pageant.exe C:\Program Files\putty\keys\
private.ppk


6. Тепер робимо тунель командою plink.exe:

plink -batch -ssh -N username@mikrotik -P 22 -pw userpass -L 15110:server:3389



понеділок, 6 березня 2017 р.

Mikrotik з OpenVPN

Файл налаштування клієнта:
client
dev tap
port 1194
proto tcp

remote 192.168.88.1 1194             # VPN server IP : PORT
nobind

ca ca.crt
cert clientname.crt
key clientname.key

#comp-lzo
persist-key
persist-tun

verb 3
auth-user-pass pass.txt

route-method exe
route-delay 2
route 192.168.1.0 255.255.255.255 192.168.88.1

Файл pass.txt:
clientname
clientpass

понеділок, 27 лютого 2017 р.

Debian 7 та MySQL server 5.6+

Видалити попередню версію (5.5):
sudo apt-get purge mysql*
sudo apt-get autoremove
sudo apt-get autoclean
sudo rm -rf /var/log/mysql
sudo rm -rf /var/log/mysql.*
sudo rm -rf /var/lib/mysql
Додати репозіторій (взяти з https://dev.mysql.com/downloads/repo/apt/)
wget http://repo.mysql.com/mysql-apt-config_0.8.2-1_all.deb
sudo dpkg -i mysql-apt-config_0.8.2-1_all.deb
Після цих дій буде створений файл /etc/apt/sources.list.d/mysql.list з такими рядками:
deb http://repo.mysql.com/apt/debian/ wheezy mysql-5.6
deb-src http://repo.mysql.com/apt/debian/ wheezy mysql-5.6
Оновити ключі:
sudo apt-key adv --keyserver pgp.mit.edu \
    --recv-keys A4A9406876FCBD3C456770C88C718D3B5072E1F5

Встановити mysql 5.6:
sudo apt-get update
sudo apt-get install mysql-server-5.6

пʼятниця, 10 лютого 2017 р.

Міграція з VPS Debian 7 на VPS Debian 8

Переношу свій хостинг на новий Debian:

1. $ ssh root@vps-new
2. apt-get update
3. apt-get upgrade
4. dpkg-reconfigure locales
4.1. Locales to be generated: uk_UA.UTF-8 UTF-8 - Ok
4.2. Default locale for the system environment: uk_UA.UTF-8 - Ok
5. Ctrl+D
6. $ ssh root@vps-new
7. groupadd -r wheel
8. useradd -m -g wheel -s /bin/bash superuser
9. passwd superuser
10. додати рядок у /etc/sudoers:
       %wheel  ALL=(ALL)       NOPASSWD: ALL
11. $ sudo mcedit /etc/hostname - srv170210
12. $ sudo hostname -F /etc/hostname
13. $ wget http://vestacp.com/pub/vst-install.sh
14. $ sudo bash vst-install.sh --nginx yes --apache yes --phpfpm no --vsftpd yes --proftpd no --exim yes --dovecot yes --spamassassin yes --clamav no --named yes --iptables yes --fail2ban yes --mysql yes --postgresql no --remi no --quota no --hostname srv170210 --email superuser@email.com --force
15. Згадав, що планував змінити php на 7.х
15.1. $ dpkg --list | grep php | awk '/^ii/{ print $2}'
15.2. $ x="$(dpkg --list | grep php | awk '/^ii/{ print $2}')"
15.3. $ sudo apt-get --purge remove $x
16. Видалив php5, встановлюю php7
16.1. $ wget https://www.dotdeb.org/dotdeb.gpg
16.2. $ sudo apt-key add dotdeb.gpg
16.3. $ echo -e "deb http://packages.dotdeb.org jessie all\ndeb-src http://packages.dotdeb.org jessie all" > dotdeb.list
16.4. $ sudo cp dotdeb.list /etc/apt/sources.list.d/
16.5. $ sudo apt-get update
16.6. $ sudo apt-get install php7.0 php7.0-common php-pear
16.7. $ sudo apt-get -f install
16.8. $ sudo apt-get install libapache2-mod-php7.0
17. Перенесення бекапів
17.1. root@vps-old:# scp /home/backup/admin.2017-02-10.tar superuser@vps-new:~/home/backup/
18. Відновлення бекапів
18.1. v-restore-user admin admin.2017-02-10.tar
19. Власне, все.