• Криптовалюта и интернет-магазин. История подлючения и немного 54-ФЗ

    Здравствуйте, дорогие хабрачитатели!

    Появилась недавно задача подключить к одному интернет-магазину оплату криптовалютой. Причем не только популярными биткоинами, но и такими валютами, о которых мне раньше и слышать не приходилось. Реализовывать полноценный функционал взаимодействия с каждой криптовалютой отдельно, задача не из простых. Если для того же биткоина есть библиотеки, позволяющие начать работу практически из коробки (но без допиливания и танцев с бубном, как показывает практика, не обходится), то, например, для dogecoin нужно писать все с нуля. Так как данный вид оплаты для сайта не предполагался как основной, а скорее как фишка для рекламы и раскрутки, то и бюджет не предполагал крупной разработки.
    Читать дальше →
  • Экономим трафик в SPA

    Основная задача одностраничных приложений (SPA) – это коммуникация с сервером, а зачастую и с многочисленными серверами по средствам XHR. Но большинство данных достаточно загрузить один раз. Как это сделать красиво? Способов много. Однако, мы рассмотрим только один, с помощью обещаний Promises.
    Читать дальше →
  • Элегантное решение задачи о спичках [спортивное программирование]

    В этой статье будет описан способ решения одной не очень известной задачи спортивного программирования. Решение требует всего несколько строк кода и очень эффективно, однако требует объяснения.
    Читать дальше →
  • Изменение синтаксиса Free Pascal при помощи макросов

    Речь в статье пойдет о составных операторах begin-end, форматировании кода и синтаксисе языка Pascal. А начнем мы с цитаты из книги Стива Макконнелла «Совершенный код».


    «Большинство споров по поводу форматирования возникает из-за несовершенства большинства популярных языков программирования. Хорошо спроектированный
    язык имеет явную структуру блоков, которая приводит к естественному стилю отступов.»
    Читать дальше →
  • Because of the complexity или кроссплатформенная работа с фискальным принтером Posnet Temo HS FV Ej

    История началась с того, что наша маленькая, но гордая компания решила создать приложение для собственных логистических нужд. Обсудив нюансы работы и обозначив конкретные цели, я приступил к реализации. Спустя некоторое время была написана первая версия java приложения и отдана на растерзание тестирование логистам и сотрудникам склада. Более года все шло хорошо, баги успешно создавались и фиксились, функционал приложения постоянно расширялся и совершенствовался, автоматизируя все больше процессов, пока мы не столкнулись с необходимостью использования фискального принтера Posnet Temo HS FV Ej.
    Читать дальше →
  • Алгоритм подсчета кол-ва расстановок n ферзей со сложностью меньше чем O(n!)

    Пронумеруем строки и столбцы доски размером nxn номерами от 0 до n-1. Номер клетки будет иметь вид (i,j), где i – номер строки, j – номер столбца. Координаты ферзей будут иметь вид (i,p(i)).

    Пускай у нас уже расставлены k ферзей в строках от 0 до k-1.

    Тогда ферзь с координатами (i,p(i)), где i<k, может бить клетки в строке k с координатами (k,p(i)), (k,p(i)-(k-i)) и (k,p(i)+(k-i)), при этом нас интересуют только клетки с номерами столбцов от 0 до n-1.

    Теперь определим битовую маску, для того чтобы определить, в какие клетки строки k нельзя ставить ферзя.

    SV(k)=Sum(i=0..k-1,2^p(i))
    SD1(k)=Sum(i=0..k-1,2^p(i) shr (k-i))
    Если p(i)-(k-i)<0, то 2^p(i) shr (k-i)=0.
    SD2(k)=Sum(i=0..k-1,2^p(i) shl (k-i)) and (2^n-1)
    Если p(i)+(k-i)>=n, то 2^p(i) shl (k-i) будет отброшено при помощи and (2^n-1).
    S(k)=SV(k) or SD1(k) or SD2(k)

    где ^ – возведение в степень, or – побитовое или, and – побитовое и, shl – сдвиг влево, shr – сдвиг вправо.

    В данном случае используется Sum вместо or, т.к. на любой вертикали или диагонали не может быть более одного ферзя.

    Если записать рекуррентно, то получится

    SV(0)=0
    SD1(0)=0
    SD2(0)=0
    SV(k+1)=SV(k) or 2^p(k)
    SD1(k+1)=(SD1(k) or 2^p(k)) shr 1
    SD2(k+1)=((SD2(k) or 2^p(k)) shl 1) and (2^n-1)
    Читать дальше →
  • Iodine: улучшенный язык Java

    Это рассказ о новой разработке RemObjects — компании, которая начинала с компонентов для Delphi, а сейчас выпускает целый набор компиляторов Elements для всех популярных платформ: Windows, .NET, JVM, Android, iOS, Cocoa. В набор входят компиляторы с языков Oxygene (клон Паскаля-Delphi), C#, Swift (бесплатный), на любом из которых можно писать для любой указанной выше платформы. И вот теперь в этот список добавляется новый язык — Java. Чем не повод для статьи на Habrahabr?
    Читать дальше →
  • Если не срабатывает свойство translate при css анимации в мобильном Safari

    То, что Safari стал для верстальщиков новым IE6 ни для кого не новость. Сегодня столкнулся с очередным багом, решение которого банально до невозможности, но отняло у меня час рабочего времени.

    Итак, имеем блок, который должен непрерывно плавать вверх-вниз. Сходу пишем стандартный для такой анимации код:

    .block {
    	animation-name: floating;
    	-webkit-animation-name: floating;
    	animation-duration: 3.0s;	
    	-webkit-animation-duration: 3.0s;
    	animation-iteration-count: infinite;
    	-webkit-animation-iteration-count: infinite;	
    	animation-timing-function: ease-in-out;	
    	-webkit-animation-timing-function: ease-in-out;
    }
    
    @keyframes floating {
    	0% {transform: translateY(0%);}
    	50% {transform: translateY(8%);}	
    	100% {transform: translateY(0%);}			
    }
    
    @-webkit-keyframes floating {
    	0% {-webkit-transform: translateY(0%);}
    	50% {-webkit-transform: translateY(8%); }	
    	100% {-webkit-transform: translateY(0%); }			
    }
    
    

    Тестируем и видим, что данный код работает во всех популярных браузерах, кроме мобильного Safari. Причём согласно спецификации он должен поддерживать этот код. Далее замечаем ещё одну особенность. Если перейти в другое приложение или по какой-то ссылке и вернуться назад, то анимация начинает работать. Очень странное поведение Safari. То есть сам код ему понятен, но при обновлении страницы анимация сразу не хочет проигрываться.

    Долгие поиски по различным форумам ни к чему не привели, поэтому решение было найдено методом «научного тыка».
    Читать дальше →
  • ROSA и ОСь репозитории CentOS 7

    Всем привет.

    Хочу с Вами поделиться информацией как к «российским» ОС прикрутить репозитории CentOS и заменить установленные пакеты.

    Всё началось, когда нашу организацию обязали перейти на «российское» ПО. В первую очередь начал искать серверные ОС. Как оказалось наши разработчики предлагают ОС на базе Linux, а в организации 100% windows платформа. Организация не маленькая, примерно 150 серверов только в одном округе.

    После изучения рынка «российских» ОС выбор пал на ROSA и ОСь. ROSA это платная ОС и стоит не маленьких денег, но так как не очень уж хочется платить за воздух я остановился на ОС ОСь. Далее начинается самое интересное далее. У ОСи добавлен репозиторий от РосТех и в версии пакетов добавлена как правило одна буква:

    1. Пакет от ОСи — openssh-6.6.1p1-33z3.el7.x86_64
    2. Стандартный пакет CentOS — openssh-6.6.1p1-33.el7.x86_64

    Первопроходцем должен быть AD на samba4, но тут возникает проблема. При установке зависимостей для samba4 yum не чего не может сделать с пакетами ОСи и соответственно пакеты не устанавливаются из-за неразрешнных зависимостей.

    Все действия я делал на ОС ОСь minimal.

    В общем решение этой проблемы следующее:

    1. Необходимо закоментировать существующие репозитории.
    2. Создать новый файл с CentOS'совскими репозиториями.

    vi /etc/yum.repos.d/centos7.repo

    Вот сам файл centos7.repo
    Читать дальше →
  • ЭВМ

    Россия, Иркутск, 1990 год, ДК «Юный техник»

    Каждый вечер мальчишки с нашего района собирались в ДК «Юный техник», который находился на первом этаже обычной пятиэтажки и слушали лекции Виктора Анатольевича, записывали самое важное и зарисовывали схемы, а после с пионерским рвением выпаивали резисторы и транзисторы со старых плат, и раскладывали их по специальным деревянным коробочкам. Все шло своим чередом, уже скоро мне, ученику первого класса, разрешат паять первые простенькие схемы.
    Читать дальше →
  • Торговые боты как биосистема

    Я написал своего бота для торгов на бирже bittrex через API с нуля. php+MySql. В части статей опишу сложности, с которыми столкнулся, как их решил, и что осталось нерешенным.

    2 бота реально торгуют. Еще 16 виртуально. В условиях без «катастроф» (типа валюта перестала существовать и теперь стоит 0, или биржа накрылась) и при той волатильности что есть сейчас — прибыль около 0,05-0,25% в день.
    Читать дальше →
  • Вывод иерархических данных DataObjects в DevExpress GridControl

    Понадобилось нам выводить данные в виде дерева.
    Причем, надо выводить не одно поле, а несколько. Поэтому стандартный TreeView подходит плохо.
    В программе использовался WPF и компоненты DevExpress. Там есть навороченный GridControl, предоставляющий в числе прочего просмотр данных в виде дерева. То есть на первый взгляд проблема на полчаса.

    Читать дальше →
  • Волшебный квадрат

    Приветствую! Хотел бы представить вам простенькую, но в то же время интересную задачку по программированию. Магический квадрат (волшебный квадрат) — это таблица заполненная числами таким образом, что сумма чисел в каждой строке, каждом столбце и на обеих диагоналях одинакова. Программка составлена на языке Python.



    # Создадим переменную равную наименьшему из 9-ти разрядного числа

    counter = 100000000

    Далее запускаем цикл пока не достигнем наибольшего 9-ти разрядного числа

    while counter < 999999999:
    # Разбиваем наще число на разряды
    p = [int(n) for n in str(counter)]
    
     #Теперь складываем отдельные цифры и присваиваем результат
     #переменным согласно расположению в таблице
     diagonal_1   = p[0] + p[4] + p[8]
     diagonal_2   = p[2] + p[4] + p[6]
     gorizontal_1 = p[0] + p[1] + p[2]
     gorizontal_2 = p[3] + p[4] + p[5]
     gorizontal_3 = p[6] + p[7] + p[8]
     vertical_1   = p[0] + p[3] + p[6]
     vertical_2   = p[1] + p[4] + p[7]
     vertical_3   = p[2] + p[5] + p[8]
    

    Завершающий этап: проверка всех вышеперечисленных переменных на равенство
    и вывод результатов на экран

    
    #Проверка на равенство
     if diagonal_1 == diagonal_2 and diagonal_1 == gorizontal_1 and diagonal_1 == vertical_1 and  gorizontal_1 == gorizontal_2 and gorizontal_1 == gorizontal_3 and vertical_1 == vertical_2 and vertical_1 == vertical_3 and vertical_1 == gorizontal_1 and vertical_1 == gorizontal_2 and vertical_1 == gorizontal_3:
    
      #Печать результатов
      print ( p[0], p[1], p[2] )
      print ( p[3], p[4], p[5] )
      print ( p[6], p[7], p[8] )
      print ( 'Счетчик равен: ', counter )
      print ('________________' )
    
     counter += 1
    
    Читать дальше →
  • Как я Scala учил

    Месяца назад я получил свою первую работу и стал стажер-разработчиком, наша команда использует язык Scala. Мне кажется, все начинающие разработчики в первый день потерянные. одновременно наваливается куча новых имен, технологий, каких-то правил, да и мало ли что еще, абсолютно все для тебя ново, это же первая работа. В моем же случае я еще и не знал языка, на котором буду программировать, до момента собеседования я даже никогда о нем не слышал. Итог: в первый день я был в полном ауте. Спросите как тогда я вообще получил эту работу? Я знал Java, на собеседовании мне сказали что джависту перейти на скалу будет достаточно легко и можно не переживать. Но видимо чуть-чуть попереживать все же стоило, потому что первое время перед собой я видел просто экраны, заполненные текстом, в которых сходу была ясна едва ли половина.

    Но больше дискомфорта приносило даже не то, что я чего-то не понимал, а то что там многое по-другому, да даже тип переменной идет после названия, а порой его вообще нет.

    final String str = "abc"; //Java

    val str = "abc" // Scala
    Читать дальше →
  • Охлаждение в бюджетном miditower или как опустить процессор ниже 30 градусов

    После очередной чистки системы (пылесосом) и смены термопасты (впервые с 2011 года) 45 нанометровый AMD Phenom II X6 1100T 3.3 GHz в простое грелся до 35 градусов, под нагрузкой до 60. Температура мостов на материнке (GA-880GA-UD3H AMD880G/SB850) была 38-45 градусов в простое, датчик общей температуры в корпусе около 37-39.

    Цифры вроде не критичные, более чем адекватные для такого техпроцесса, но захотелось их снизить. Благо вентиляторы сейчас не самые дорогие.



    Первые три температуры — корпус и мосты, далее скорости вентиляторов, ниже ядра процессора. Температура в простое до замены вентиляторов.

    Человек я не особо организованный и увлекающийся, так что к процессу подходил не комплексно а по-вдохновению. Начал я с банальной замены вентиляторов.

    Читать дальше →
  • Получение участников сообщества vk.com через REST API с помощью PHP

    На данный момент VK API уже имеет версию 5.68 и многие уже знакомы с его методом execute, который позволяет запускать последовательность других методов, сохраняя промежуточные результаты.

    На днях столкнулся с задачей получения списка участников сообщества. Поиск в интернете дал достаточные результаты, но к сожалению интересующий метод был реализован не на PHP. Подумал, что кому-то еще будет интересна и полезная такая реализация алгоритма.

    Реализация на PHP


    Чтобы работать с API на PHP необходимо подключить библиотеку

    require_once('src/VK/VK.php');
    require_once('src/VK/VKException.php');
    

    Затем необходимо пройти авторизацию, для того, чтобы начать делать запросы к vk.com

    self::ex();
    public static function ex () {
            $attach = ORM::for_table('attach')->where('id', 1)->find_one(); // получение данных для авторизации из базы данных таблицы attach
            $vk_config = array(
                'app_id'        => $attach->app_id,
                'api_secret'    => $attach->api_secret,
                'access_token'  => $attach->access_token
            );
    
            $vk = new VK\VK($vk_config['app_id'], $vk_config['api_secret'], $vk_config['access_token']); // создание объекта с последующей авторизацией
    
    Читать дальше →
  • Spree 3 и Google Cloud Storage

    Привет Хабр!

    Столкнувшись с проблемой, готового решения найдено не было, в следствии чего приобрел опыт коим есть желание поделится.
    Дело в том что, разработчики оpen-source движка для интернет магазина (Spree), подружили его только с S3 (Amazon Cloud Storage).

    Но вы можете это исправить,
    Читать дальше →
  • Мониторинг состояния дисков на контроллерах adaptec через zabbix

    Добрый день. Возникла ситуация, когда выпал диск из raid массива. Пришло уведомление от Zabbix о том, что 1 диск выпал, но без пояснения, какой, не очень информативно, пришлось лезть на сервер и смотреть, какой же диск выпал.

    Небольшой скрипт на python который парсит вывод arcconf и сопоставляет диск в рейде с реальным диском(позиция на backplane).

    Читать дальше →
  • В поисках приложения для системного администратора



    Задача: найти приложение(я) которое могло бы немного упростить жизнь обычного системного администратора, почувствовать себя на некоторое время Индианой Джонсом на просторах Google Play. Естественно священный Грааль найти вряд ли получится, но почему бы не попробовать.

    До недавнего времени я использовал на своем android устройстве пожалуй только Speedtest.net для того чтоб замерить скорость интернета. Но время не стоит на месте и каждый день появляются какие-нибудь новые приложения. Давайте же на них посмотрим.
    Читать дальше →
  • Тестирование реализаций ELM327

    Когда речь заходит о диагностике автомобиля, первое, что приходит на ум, это сканер ELM327, подключаемый по интерфейсу OBD-II. Его можно без лишних трудностей заказать из-под небесной, выбрав нужный интерфейс (USB, Bluetooth, WiFi). Однако на данный момент довольно часто возникают ситуации, когда сканер "криво" работает, либо и вовсе нет. Причин может быть несколько: как "левая" аппаратная конструкция (сейчас под этим подразумеваются сканеры, не на основе PIC18*), так и программное обеспечение (например, указана версия 1.5, по факту ею не являющейся). Стало интересно разобраться, есть только один рабочий вариант по аппаратно-программной начинке, или же различные реализации заточены под разные задачи.

    Читать дальше →