Задать вопрос
  • Какой дистрибутив *unix посоветуете для серфинга интернета + плохое зрение?

    @inkvizitor68sl
    Linux-сисадмин с 8 летним стажем.
    Ubuntu + Unity, масштабирование работает из коробки для gtk приложений, в том числе и для web-а внутри таких приложений (firefox, chrome).
    С QT (в т.ч. и скайпом) масштабированием есть проблемы, лучше его заменить на что-то gtk-ное.
    Ответ написан
    Комментировать
  • Какой дистрибутив *unix посоветуете для серфинга интернета + плохое зрение?

    romy4
    @romy4
    Exception handler
    Любой линукс. Все эти экранные лупы — вспомогательный софт. Ставьте что-то гномоподобное
    Ответ написан
    Комментировать
  • Какой софт и плагины использует front-end developer на ubuntu? Какие плюсы для разработчика имеет Linux(ubuntu)?

    IonDen
    @IonDen
    JavaScript developer. IonDen.com
    Ubuntu - слишком хардкорно. Я бы рекомендовал вам OSX все же. Ибо близость фотошопа важна.
    В остальном ничего особенного. WebStorm (Sublime, Atom, и т.д.) + командная строка с node.js. + пачка виртуальных машин с IE (берем здесь)
    Ответ написан
  • Как создать автопилот для большегрузных транспортных средств используя искусственный интеллект?

    NeiroNx
    @NeiroNx
    Программист
    Для начала - написать систему распознования дорожных обьектов в реальном времени - по ее данным строить виртуальную модель. В виртуальной модели прокладывать маршрут, расчитывать вероятности столкновений - перестраивать маршрут в критических ситуациях.
    Ответ написан
    3 комментария
  • Каково состояние дел у PHP на фронте?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Перефразирую ваш вопрос: каково стояние дел у молотка по забиванию гвоздей?))

    Где можно ознакомиться с состоянием дел у PHP?

    php.net
    habrahabr.ru
    opennet.ru

    Какой рантайм брать?

    7-ка только-только вышла, пока что опасно. Берите 5.6

    Какой фрейворк юзать?

    Смотря какой проект.

    Что с интернационализацией?

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

    Люблю функции высшего порядка

    В php их конечно можно использовать, но только там, где это необходимо. Вообще говоря это отличная практика по отстреливанию яиц.

    он создан чтобы умирать

    Все верно, это stateless язык, он так спроектирован, под свои задачи лучше пока не придумали.

    А мне бы желательно запланировать на фронте возможность ещё и с вебсокета раздать уведомления.

    Планируйте на здоровье, но на бэкенде под это лучше пойдет nodejs. Демоны на php конечно пишут, но это не целевое применение языка, такие дела.
    Ответ написан
  • Как запретить доступ к сайту по ip сервера?

    BuriK666
    @BuriK666 Куратор тега Nginx
    Компьютерный псих
    nginx.org/ru/docs/http/request_processing.html

    Если его значение не соответствует ни одному из имён серверов или в заголовке запроса нет этого поля вовсе, nginx направит запрос в сервер по умолчанию для этого порта. В вышеприведённой конфигурации сервером по умолчанию будет первый сервер, что соответствует стандартному поведению nginx по умолчанию. Сервер по умолчанию можно задать явно с помощью параметра default_server в директиве listen:
    Ответ написан
    Комментировать
  • Как контролировать использование программы в windows?

    @abcyu
    Разработчик
    У многих браузеров именно специально для этих целей есть "kiosk mode"
    Для этих же целей есть и специальные браузеры, урожденные без контролов.
    Искать по фразе "browser kiosk mode"
    Node-WebKit, например, умеет.
    Умеют и классические браузеры, например, Chrome: www.kioware.com/resources.aspx?resID=41
    Ответ написан
    Комментировать
  • Как контролировать использование программы в windows?

    mourr
    @mourr
    Passionate JS developer
    Используйте например nw.js в режиме kiosk - он откроется на весь экран без контролов закрытия. А само приложение будет состоять только из index.html файла с кодом вида
    <iframe src="http://your-web-service.com" height="100%" width="100%" frameborder="0"></iframe>
    Ответ написан
    Комментировать
  • Почему отдает 404 ошибку(nginx+alias)?

    BuriK666
    @BuriK666 Куратор тега Nginx
    Компьютерный псих
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    а root у Вас /usr/share/
    т.е. он ищет /usr/share/pma/index.php
    Ответ написан
    3 комментария
  • Я что то пропустил?

    sim3x
    @sim3x
    Кто-то микширует табы и пробелы
    Ответ написан
    Комментировать
  • Попросили проверить код, на что смотреть нужно?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Смотря зачем)). Я когда делаю Code Review критерии следующие:

    * Безопасность:
    - Каждый аргумент метода простого типа должен проверяться на тип в случае его проксирования и на граничные значения в случае обработки. Чуть что не так - бросается исключение. Если метод с кучкой аргументов на 80% состоит из поверки из аргументов - это вполне норм))
    - Никаких trigger_error, только исключения.
    - Исключения ДОЛЖНЫ быть человеко-понятны, всякие "Something went wrong" можно отдавать пользователю, но в лог должно попасть исключение со стектрейсом и человеко-понятным описанием, что же там пошло не так.
    - Каждый аргумент (объект) метода должен быть с тайпхинтингом на этот его класс, или интерфейс.
    - За eval как правило шлю на **й.
    - @ допускается только в безвыходных ситуациях, например проверка json_last_error.
    - Перед работой с БД - обязательная проверка данных.
    - Никаких == и !=. Со swtich - единственное исключение, по ситуации.
    - Если метод возвращает не только bool, а еще что-то - жесткая проверка с ===, или !== обязательна.
    - Никаких условий с присваиваниями внутри. while($row = ...) - тоже идет лесом.
    - Магические геттеры/сеттеры разрешаются только в безвыходных ситуациях, в остальном - запрещены.
    - Конкатенации в sql - только в безвыходных ситуациях.
    - Параметры в sql - ТОЛЬКО через плейсхолдеры.
    - Никаких глобальных переменных.
    - Даты в виде строки разрешаются только в шаблонах и в БД, в пхп коде сразу преобразуется в \DateTimeImmutable (в безвыходных ситуациях разрешено \DateTime)
    - Конечно зависит от проекта, но как приавло должно быть всего две точки входа: index.php для web и console(или как-то по другому назваться) - для консоли.

    * Кодстайл PSR-2 + PSR-5 как минимум, + еще куча более жестких требований (для начала все то что в PSR помечено как SHOULD - становится MUST)
    - В PhpStorm ни одна строчка не должна подсвечиваться (исключением является typo ошибки, например словарик не знает какой-то из аббревиатур, принятых в вашем проекте). При этом разрешается использовать /** @noinspection *** */ для безвыходных ситуаций.
    - Если кто-то говорит, что пишет в другом редакторе и у него не подсвечивается, на эти отговорки кладется ВОТ ТАКЕЕЕНЫЙ мужской половой **й и отправляется на доработку)).

    * Организация кода:
    - Никаких глобальных функций.
    - Классы без неймспейса разрешаются только в исключительно безвыходных ситуациях.

    * Тестируемость (в смысле простота тестирования) кода должна быть высокая.
    - Покрытие кода обязательно для всех возможных кейсов использования каждого публичного метода с моками зависимостей.

    * Принципы MVC:
    - Никаких обработок пользовательского ввода в моделях, от слова совсем.
    - Никаких ***ть запросов в БД из шаблонов.
    - Никаких верстки/js/css/sql-ин в контроллерах.
    - В моделях НИКАКОЙ МАГИИ, только приватные свойства + геттеры с сеттерами.
    - В моделях разрешено использовать метод save(при наличии такого разумеется) только в исключительных ситуациях. Во всех остальных - либо insert, либо update.

    * Принципы SOLD:
    - Никаких божественных объектов умеющих во все.
    - Если метод для внутреннего пользования - private, никаких public.
    - Статические методы разрешаются только в случае безвыходности.

    * Принцип DRY разрешено нарушать в случаях:
    - Явного разделения обязанностей
    - В тестах (каждый тест должен быть независимым, на сколько это возможно)

    * Работа с БД:
    - Запрос в цикле должен быть РЕАЛЬНО обоснован.
    - За ORDER BY RAND() - шлю на***й.
    - Поиск не по ключам (конечно если таблица НЕ на 5 строк) запрещен.
    - Поиск без LIMIT (опять же если таблица НЕ на 5 строк) запрещен.
    - SELECT * - запрещен.
    - Денормализация БД должна быть обоснована.
    - MyISAM не используется (так уж)) )
    - Множественные операции обязательно в транзакции, с откатом если чо пошло не так.
    - БД не должна содержать бизнес логики, только данные в целостном виде.
    - Не должно быть нецелесообразного дерганья БД там, где без этого можно обойтись.

    * Кэш должен очищаться по двум условиям (не по одному из, а именно по двум):
    - Время.
    - Протухание по бизнес логике.
    Разрешается по только времени в безвыходных ситуациях, но тогда время - короткий период.
    - При расчете ключей кэша должна использоваться переменная из конфигурации приложения (на случай обновлений кэш сбрасывается кодом, а не флашем кэш-сервера). В случае использования множества серверов - это очень удобный и гибкий инструмент при диплое.

    * О людях:
    - "Я привык писать так и буду дальше" - не вопрос, ревью пройдешь только когда поменяешь свое мнение.
    - "Я пишу в vim-е и мне так удобно" - здорово, код консолью я тоже в нем пишу)) но есть требования к коду, если в них не сможешь - не пройдешь ревью.
    - "Я скопировал этот страшный метод и поменял 2 строчки" - это конечно замечательно, но по блейму автор всего этого метода ты, так что давай без говняшек, хорошо?
    - "Оно же работает!" - вот эта фраза переводится примерно так: "да, я понимаю, что пишу полную хрень, но не могу писать нормально потому, что руки из жо", я правильно тебя понял?))
    - "У меня все работает!" - рад за тебя, а как на счет продакшна?
    - "Там все просто" - не используй слово "просто", от слова "совсем". Вот тебе кусок кода (первого попавшегося с сложной бизнес логикой), где там ошибка (не важно есть она, или нет)? Ты смотришь его уже 2 минуты, в чем проблема, там же все "просто"))

    * Всякое:
    ActiveRecord (это я вам как в прошлом фанат Yii говорю) - полное говно, примите за исходную. По факту у вас бесконтрольно по проекту гуляют модельки с подключением к БД. Не раз натыкался на то, что в тех же шаблонах вызывают save, или update (за такое надо сжигать).
    То, что используется Laravel - это печально((. Что бы выполнить требования приведенные выше, приходится "воевать" с фреймворком.

    Это далеко не полный список требований, очень много зависит от проекта в целом и от принципов, заложенных в нем. Для больших мредж реквестов 200 комментариев к коду - это ок. Дерзайте.

    UPD

    Формализировал данные критерии по ссылочке: https://github.com/index0h/php-conventions
    Ответ написан
    55 комментариев
  • Как правильно настроить nginx для нескольких сайтов и поддоменов?

    Gasoid
    @Gasoid
    лучше блог сделать тоже в отдельной категории и отдельный файл конфиг создать
    blog.site.ru.conf

    server {
            server_name blog.site.ru;
            root "/var/www/blog.site.ru/";
    
            include sites-available/common.conf;
    }
    Ответ написан
    3 комментария
  • Как решить проблему с access_token?

    nazarpc
    @nazarpc
    Open Source enthusiast
    Вы издеваетесь? Вам же в ошибке написали в чём проблема, какой, млин, домен и с чего вы это поняли?
    Засуньте в Google Translate и поймите что токен полученный с домашним IP не работает на сервере.
    Ответ написан
  • Как красиво сделать список услуг?

    LittleFatNinja
    @LittleFatNinja
    горе девелопер, любитель лютой садомии
    просто списком
    Ответ написан
    Комментировать
  • Где взять примеры текстуры "сеточка"?

    kawabanga
    @kawabanga
    в лендингах - css матрица, 4 пикселя в пнг

    черный - прозрачный
    прозрачный - черный

    Свойством css делаете бэкграунд блока поверху, и снижаете прозрачность в зависимости от требований.
    Ответ написан
    3 комментария
  • В чем преимущество SOA и когда такую архитектуру нужно юзать?

    dasha_programmist
    @dasha_programmist
    ex Software Engineer at Reddit TS/React/GraphQL/Go
    удобно понимать в терминах: микросервисы или монолит
    1) микросервисы имеют преимущество горизонтального масштабирования, но они stateless, поэтому для организации общей памяти необходим сервис кэширования, взаимодействие сетевое
    2) монолит имеет преимущество, когда требуется общая память (быстрый отклик) для частей приложения, он statefull, поэтому сетевые задержки минимальны или отсутствуют

    стоит помнить: операции I/O всегда медленней CPU, поэтому выбор зависит от зачади, а в целом применяют комплексные решения состоящие из первого и второго
    Ответ написан
    Комментировать