Comments 271
https://github.com/
К примеру из моего опыта — банковская, кассовая и транзакционная CRM, система бронирования клиент-брокер-отель, алгоритмы прокладки маршрутов между пунктами назначения по дорогам и много чего другого.
Но сама идея у вас очень и очень интересная, поэтому спокойно относитесь к критике — у вашего проекта есть и достаточный потенциал, и хорошие перспективы.
Может вы ответите, раз считаете себя переросшим большинство профессионалов, которые писали Right Way (оригинальный), пройдя все терни языка?
yield работает и на передачу и на приём данных в генератор. Когда сработал приём данных, выдача пропускается. Данные в генератор посылаются, чтобы скорректировать его поведение, а это значит, что в более общем случае нужно пропустить выдачу, тогда вы сможете полностью контролировать процесс.
Нужно стараться вносить как можно меньше новых терминов, чтобы читателю не приходилось искать их значения. Тем не менее…
нет необходимости использовать (по крайней мере, как базовые средства разработки) технологии в Framework
роутинг страниц, как механизм излишен.
ORM как механизм излишен
Компилируемые шаблоны излишни
Механизм NAMESPACE излишен.
Интересно, а вот скажем классы — они тоже излишни? Может тогда просто сразу вернемся к четвертому PHP? Там ведь ничего лишнего — 100% соответствие идеологии SKY. Да ну его все… К чему эти излишние всякие там паблики, статики, трэйты и интерфейсы. Только вносят путанницу.Ну правильно? Писали ведь на четвертом PHP и все было предельно ясно и просто. Ну полный SKY в общем.
Вот вы работали раньше без ORM и было ужасно плохо… можете объяснить в чем были сложности?
Сложность в том, что надо писать весь этот избыточный SQL-код, помнить как названы объекты в БД, писать код, который преобразует обратно результат в тот, который нужен программе… И все это, конечно же, без поддержки компилятора.
Зачем, когда можно просто написать вот так:
var searchResult = _db.Books.Where(b => b.Author.BirthDate.Year < 1970).GroupBy(b => b.Author);
а в вашем коде надо помнить, что поле авторов у обьекта книга, называется Author.
Не надо. Автодополнение вполне работает.
ламбды (безымянные функции, да и класы) не попадают под "сильную" типизацию.
Почему не попадают-то? Код выше полностью типизированный.
Где компилятор (и ИДЕ) сможет по определению functionWhere(f(b: Book): Boolean)
проверить...Where(b => b.Year < 88)
на валидность.
Что значит "проверить на валидность"?
зануда мод: а в вашем коде надо помнить, что поле авторов у обьекта книга, называется Author.
ламбды (безымянные функции, да и класы) не попадают под «сильную» типизацию. Если же их писать с типизацией — получается больше кода и теряется преимущество синтаксического сахара.
Рекомендую вам пописать на C# в хорошей IDE, мурашки по коже пойдут) Лямбды вполне типизируются и типы выводятся автоматически (это ведь довольно просто) так, как очень часто в Generic'ах.
Посмотрите на исходники Linq:
public static IEnumerable<TSource> Where<TSource>( // 1
this IEnumerable<TSource> source, // 2
Func<TSource, bool> predicate) // 3
Строка 3 означает, что лямбда обязана принимать на вход тип TSource (тот же, что в IEnumerable), а на выход давать bool. Так и типизируется.
Без ORM я работал когда толком и ООП не использовал. Как только начал использовать, то идея что гораздо лучше будет маппить записи БД на объекты модели и наоборот, чем продолжать работать на уровне бизнес-логики и представления с массивами, возвращаемыми mysql_fetch_assoc и(или) генерировать SQL на этих уровнях, возникла практически сразу — это упрощает отслеживание и управление взаимосвязями сущностей приложения. Теперь мне не надо думать о способе хранения данных, когда я реализую бизнес-логику или представление, у меня просто есть граф объектов, с которым я работаю. А когда работаю на уровне логики хранения мне не надо думать о том, как изменения в ней могут повлиять на остальной код, логика хранения на вход команд принимает граф объектов и на выходе запросов отдаёт граф объектов.
… а какие парадигмы программирования, кроме ООП и процедурной, вы лично пробовали и знаете на уровне, достаточном, чтобы утверждать, что ООП — величайшее достижение?
Вот казалось бы, я вам задал простой и прямой вопрос. А вы, вместо того, чтобы на него ответить, от ответа уходите. "Беспрецендентная логика и глубокое понимание" — это не парадигма программирования.
И нет ничего глупого в том, чтобы поставить под сомнение громкое и ничем не обоснованное утверждение.
(я, пожалуй, заострю внимание — именно функциональное, а не процедурное)
Это еще при том, что я закрыл глаза на заявление «Большинство же из вас не понимает глубоко что делают, а просто следуют указанием «умных учителей». », ибо не ведаете что творите.
А вы пробовали ФП?
А вы? Без ооп и для чего-то крупного, с длительной поддержкой и реальными пользователями.
Сфера деятельности мне позволяет, например, использовать в работе Elm и Purescript, которые всецело опираются на Haskell. И код действительно становится проще и предсказуемей.
Хотя, к сожалению, резко повышается порог входа для поиска сотрудников.
В вашем комментарии сквозит намек на то что ФП менее удобен для больших проектов и масштабируемых систем. Непонятно откуда взялся этот стереотип, возможно из за JS к которому пока неуклюже пытаются придать функциональную парадигму некоторые фреймворки. Сами идеи ФП такие как неизменяемость состояний и чистые функции как раз и располагают к написанию более поддерживаемых больших и сложных систем. Как эти идеи представлены в конкретных языках, вопрос другой. Что касается вашего вопроса про массовый продукт реализованный исключительно с использованием ФП то как вам пример Riemann?
В вашем комментарии сквозит намек на то что ФП менее удобен для больших проектов и масштабируемых систем.
По-моему, вы предвзяты. Скорее имелось в виду, что вы намекаете на необходимость попробовать ФП, сами не обладая опытом его применения в серьёзных проектах.
Как эти идеи представлены в конкретных языках, вопрос другой
Это первейший вопрос при выборе платформы для серёзной разработки.
Я вот просто много пообщался с командами, которые использовали ФП. И вот задаешь вопрос и обычно слышить ответ:
— да, все просто шикарно, мы уже полгода фигачим, все иммутабельно, декларативно, чисто как слеза девственности, да, пользователи еще не видели, да и QA только мельком, но все точно очень клево.
— да, мы вот написали очень клевую тулзу за пару дней (даже две, если считать ту, на которой тренировались), так клево, что на ооп так не напишешь, хипстеры на последней афтерпати просто писали кипятком
— да, пользователей запустили, пришло куча чейнджреквестов и багрепортов, но пофиксить не получается ибо пользователи — идиоты и не понимают нашу стройную архитектуру, иммутабельность и чистоту (ну или если честные с собой люди, то где-то здесь осознают свою ошибку, но уже ничего не поделаешь)
— ну а люди, которые ничего толком не писали крупного обычно кидают какую-то тулзу для программистов в пример — веб-сервер, сервер чата, сервис мониторинга, етс. Где на любой чейнджреквест, который не вписывается в «стройную чистую иммутабельную архитектуру ©®» можно просто забить, а любой баг, который вызван этой архитектурой задокументировать как фичу.
Почему у кого б из сторонников ФП я не спросил — ни у одного нету личного удачного опыта.
И да, я лично не писал функционально ни на чем кроме JS.
Мы вот писали игру, пять лет, три из них с десятками тысяч живых пользователей. И я представляю, что такое поддержка живого продукта годами.
Я не программировал на ФП языках, а программирование в стиле ФП на JS убедило меня в том, что на JSв стиле ФП пишется неподдерживаемый код. И настолько медленный и текущий, что, например, для игр не подходит.
Но я так и не встретил ни одного человека, который бы писал что-то на ФП, что может сойти за опыт успешного применения ФП в коммерческой разработке. Где истории успеха?
У меня вот друг близкий любит на Ерланге в свое удовольствие писать. Говорит, что любимый и самый изящный язык. Но крупные вещи предпочитает писать на более классических — php или java зависимо от задачи.
Но я так и не встретил ни одного человека, который бы писал что-то на ФП, что может сойти за опыт успешного применения ФП в коммерческой разработке. Где истории успеха?
Я хочу не просто почитать: «да, вон та компания говорит, что крута, держит много» (та в любом стиле можно так написать)
Хочу спросить: «и как вам спустя несколько лет? насколько легко возвращаться в старый код? легко ли найти человека в команду? если найдете — как он входит? а как пишете гуи? легко ли реагировать на все хотелки пользователей/заказчиков? Я вот столкнулся с тем, что не всегда в команду приходится брать синиоров. И не всегда необходимы именно синиоры. Как мидлы от ФП справляются в вашей команде?».
Игровые объекты BigWorld написаны на языке Python, стандартном объектно-ориентированном языке, позволяющем программистам в три раза эффективнее выполнять поставленные задачи. В случае возникновения необходимости оптимизировать работу регулярно используемых функций, скрипты могут использовать язык C++
С вами всё же соглашусь в том что не весь бэкенд, но какая-то часть со сложными задачами — точно.
У нас вот в проекте для билда Gulp использовался. И вполне мы могли б на конференции какой-нибудь рассказать. Только это отвратительная, неюзабельная штука, куда нельзя послать мидла без бутылки. Не удивительно, что он так быстро умер. И вот вы уже можете сказать, что «В Варгейминге используется Gulp на продакшене», вот только комментарии о нем у нас нелестные.
Я специально в своем комментарии в защиту ФП упомянул JS, это очень распространенный опыт, обжечься на нем и ругать ФП. Сам писал бэкенд на Node.js с лямбдами и думал что пишу ФП, это был очень неудачный опыт. Но этот опыт говорит только о том что в JS очень неудачная реализация для ФП и не более. Примеры больших ФП проектов вам привели, это намекает что парадигма жизнеспособна. Почему в целом и в Российском IT сегменте такие большие проекты сложно найти? Думаю ответ очевиден, для большого проекта нужно собрать в одну команду несколько специалистов со знанием ФП языка, что ввиду невысокой распространенности проблематично, так же немаловажный аспект — бизнес не будет вкладывать деньги в непроверенную годами технологию. Повод ли это хоронить ФП? Не думаю.
Писать ФП на JS — мазохизм, тут без сомнений. Но вот на хабре много советуют ФП. Неужели никто из советчиков не может на своем опыте сказать, чем он хорош на практике?
Но ввиду своей лаконичности, F# достаточно труден и в отладке и в чтении, и в чем-то даже в написании. Но от «вау»-эффекта по первости сложно отделаться, как программировать заново научился :) Какой-нибудь энтерпрайз на функциональщине полностью точно писать не стану. Выигрыш от количества кода полагаю будет потерян, и по времени выигрыша тоже не думаю что будет много (если учитывать отладку).
А вы? Без ооп и для чего-то крупного, с длительной поддержкой и реальными пользователями.В таком случае ответ нет, но не потому что ФП не годится для промышленной разработки, а потому что компания не может себе позволить писать в ФП из-за высоких рисков не найти разработчиков. Т.е. это никак не относится к самой парадигме.
Писать ФП на JS — мазохизм, тут без сомнений
Я не программировал на ФП языках, а программирование в стиле ФП на JS убедило меня в том, что на JSв стиле ФП пишется неподдерживаемый кодПолностью с вами согласен тут, JS ужасен в этой парадигме.
Неужели никто из советчиков не может на своем опыте сказать, чем он хорош на практикеПозволю себе описать некоторые плюсы опираясь на свой опыт с elm и ps:
- Полное отсутствие рантайм-ошибок
- Хорошая тестируемость и предсказуемость кода из-за отсутствия сайд-эффектов
- Иммутабельность из коробки и как следствие time-travelling отладка, hot-reloading и прочие фишки. Ну и, опять же, предсказуемость кода
Наверное стоит уточнить, что ФП скорей всего не подходит для высокопроизводительных приложений. Хотя, тот же OCaml позволяет писать в смешанном стиле с изменяемыми значения в местах, где требуется производительность.
Но есть и минусы:
- Иногода может понадобиться сильно сломать голову, чтобы решить тривиальную задачу
- Производительность в целом ниже (я про elm и ps, OCaml местами обгоняет C++, ну или обгонял раньше)
- Необходимость крайне высокого уровня самодисциплины и, как следствие, риски при поиске разработчиков
Подводя итоги: мой совет про ФП был не про реальную коммерческую разработку а в противовес идее, что «ООП — лучшее, что придумало человечество».
«ООП — лучшее, что придумало человечество».
Ну как мне кажется, на данный момент так оно и есть (и, конечно, не в той извращенной форме, какой его видит автор). Как минимум в плане парадигм программирования. ФП — оно хорошо для определенных задач, но не так универсально, ведь решает именно определенные задачи. И игру, или графический редактор не будешь писать на ФП, в то время как серверы, чаты прекрасно пишуться на ООП или даже процедурно. Тем более, что чистота и иммутабельность — не привилегия ФП и современные ООП языки поддерживают ФП на достаточном уровне чтобы использовать его там, где он нужен и только там.
В таком случае ответ нет, но не потому что ФП не годится для промышленной разработки
А вы считаете, что годится? Ну вот я менеджер в каком-то крупном городе, куда могу схантить разработчиков. Или даже, допустим, ФП стало популярным, как это стараются сейчас всюду всунуть. И теперь у нас рынок заполонили мидлы и джуны и даже можно задорого купить синиора. И что, как на счет ответов на остальные вопросы? Можно ли будет этот код поддерживать через 3 года активных change-request? Легко ли сможете вы вставить что-либо противоречащее архитектуре? Где состояние прописано прям в бизнес-логике. Как на счет написания гуи? А если гуи игры (допустим, казуалки, где производительность должно хватить). Или какой-либо интерактивный и анимируемый. Плавные изменения значений как результат анимаций, а не мгновенная перерисовка после приказа от сервера.
Ну вот вы бы взялись написать аналог гимпа, казуальную игру, видеоредактор етс при помощи ФП? А если бы вы знали, что вам его 3 года поддерживать и вносить любые правки, то выбрали бы ФП или ООП?
Полное отсутствие рантайм-ошибок
Разве это не особенность всех статически-типизированных языков? Намного страшнее ошибки логики.
Все ваши вопросы, можно смело адресовать и к ООП. Их решения напрямую зависит от квалификации разработчика закладывающих архитектуру на старте проекта, ФП или ООП тут имеют мало значения как таковые. Особенно с учетом того что почти все языки гибридные, могу ошибаться но только Haskell можно назвать чистым ФП языком, остальные функциональные языки могут работать с мутабельными состояниями, что позволяет там где нужно писать императивно, а уже большую часть функционально. Помимо того, ошибки проектирования с использованием ФП нормальная практика для только набирающей популярность методологии, паттерны проектирования ООП тоже не за один год придумались. Для ФП есть и еще будут свои паттерны.
Отвечая на тезис «ООП — лучшее, что придумало человечество», лично для меня определенно нет, по простой причине. ООП для меня это рутинный кактус который нужно есть, а ФП это тот код, при написании которого я могу отдохнуть.
Лучшее, что придумало человечество это пиво )
для только набирающей популярность методологии
ФП зародилось практически одновременно с процедурным ИП: Лисп и Фортран — ровесники. Первый ООП язык (Smalltalk) появился гораздо-гораздо позже, в 1980-м релизнулся. А Лиспу скоро будет 60 лет, причём мёртвым языком он никогда не был, на нём писали и пишут постоянно. Напрашивается вывод, что что-то с ФП не так, раз оно 60 лет только набирает популярность и паттерны проектирования для него придумываются. Может для отдыха оно и годится, но бизнес и власть в его промышленной эксплуатации выгоды не видит, как правило, если и использует то в каких-то весьма ограниченных областях.
Зато выполнять последовательность указаний и отдавать их другим
Практика показывает, что даже программисты не всегда этим владеют в достаточной степени:
Жена посылает программиста в магазин:
— Дорогой, купи, пожалуйста, палку колбасы, и если будут яйца, то купи десяток.
Через полчаса программист возвращается с десятью палками колбасы.
Жена:
— Что это?! Зачем ты купил столько колбасы?
Программист:
— Ну так яйца-то были…
:)
А если серьёзно, то в случае если ФП действительно не соответствует человеческому мышлению в целом (не важно, врожденному или приобретенному), то область его применения крайне ограничена просто из-за малого числа альтернативно мыслящих людей.
С другой стороны, среди программистов не встречал особых трудностей с освоением азов ФП, когда какой-то кусок программы требуется написать в функциональном стиле, храня его (куска) состояние в стеке вызовов. Трудности возникают когда нужно написать всё приложение, активно взаимодействущее с внешним миром, в таком стиле. Так что я больше бы поставил на то, что ФП мало подходит для решения подавляющего большинства практических задач, чем на то, что требуется какое-то особое мышление, которое очень трудно приобрести. В конце-концов, доминирующие аппаратные архитектуры (Тьюринг-подобные машины) оперируют прежде всего набором инструкций, изменяющих состояние, а функциональные языки лишь предоставляют декларативную абстракцию над императивной машиной, что бесплатно не даётся, а в человеческом мышлении скорее первична декларативная составляющая, чем императивная. Задача обычно ставится декларативно (заметно при общении с бизнесом, далеким от ИТ или с детьми), а вот уже решение переводится в императивную форму, если нет уверенности, что исполнитель правильно поймёт декларативную. В какой-то мере работа современного программиста в принципе состоит из перевода декларативных слабоформализованных задач заказчика в императивные команды тьюринг-машины. И почему-то многие программисты избегают варианта полной формализации в декларативной форме с автоматическим переводом в императивную.
Я бы назвал общепринятым мнением, что ФП усложняет работу с мутируемым состоянием, сайд-эффектами (включая ввод/вывод) и т. п., без которых сложно обойтись (или это будет очень накладно по вычресурсам) при решении подавляющего большинства практических задач. Мой личный опыт в виде попыток создавать простейшие CRUD веб-приложения с хранением данных в РСУБД на Лиспе и Хаскеле это подтверждает. И, кстати, сложилось впечатление, что мутации внедрены в эти языки именно таким образом, чтобы облегчить работу транслятору, а не разработчику. Я очень надеюсь, что обошлось без сознательного усложнения работы с мутациями с тем чтобы разработчики прибегали к ним только когда без этого реально не обойтись, а не мешали функциональный и императивный подход руководствуясь локальной простотой начальной реализации, как это часто встречается в мэйнстримовых языках (прежде всего Си-подобных), к которым некоторые функциональные возможности были прикручены позже и транслятор не следит за чистотой функций.
Тогда, возможно, Вам для полноты картины стоит посмотреть на Elixir.Боюсь, что erlang/elixir это как раз больше про оригинальное ООП, нежели ФП. Объекты есть (процессы), общение через сообщения есть (позднее связывание), все как завещали, только приправленное некоторыми функциональными фишками.
«ФП — оно хорошо для определенных задач» — вывод сделанный не из-за количества последователей.
Тем не менее полное отсутствие свидетельствует уже о чем-то. Например…
Слышали про "Чайник Рассела"? Так вот. Сейчас ФПисты похожи на религиозных фанатиков. Да, никто не видел (лично) успешных проектов на ФП, только где-то в библии сказано, да, никто не может назвать игру или 3д-редактор на ФП, кто-то даже слышал голос бога и после химиотерапии его родственник чудесным образом исцелился. Никто не может точно наверняка сказать, что ФП работает, но все верят и стараются затянуть в эту веру окружающих.
И я не удивляюсь, что люди, которые писали маленькие или подходящие вещи действительно так считают, ибо… прототипы всегда писать намного веселее в абсолютно любом стиле. Я вот писал прототип видео-редактора на WebGL на жесткой смеси процедурщины, ооп, фп, быдлокода и какой-то матери. Писать мне было весело и легко, оно клево работало и фичи добавлялись быстро. Но это совершенно не значит, что я считаю такой подход приемлимым для реально разработки.
Мне — только о том, что никто из хаброюзеров не использовал ФП в своих больших проектах.
Или не хотят признаваться в ошибках.
Можно ли будет этот код поддерживать через 3 года активных change-request?Да, поддержка через 3 года функционального кода настолько же сложна, насколько сложна поддержка ООП через те же 3 года. Вот только накосячить с ООП гораздо проще.
Легко ли сможете вы вставить что-либо противоречащее архитектуре?Ну не сказал бы, что легко, но и не сложнее, чем с ООП. Более того, в случае ООП нужно отдавать отчет, что все вставленные костыли рано или поздно вернутся головной болью. ФП же сужает круг мест, где эти костыли можно расставить.
Как на счет написания гуи?Вот как раз ФП тут больше подходит. Взять тот же реакт: ui — чистая функция от состояния.
А если гуи игрыПочему нет? Хотя опыта в этой области у меня нет. Ну, и перфоманс видимо просядет.
Плавные изменения значений как результат анимаций, а не мгновенная перерисовка после приказа от сервера.На самом деле, все это возможно. ФП ничем не отличается в плане возможности наличия сложного состояния процесса (например, анимации). Просто обработка этого состояния по-другому происходит.
Ну вот вы бы взялись написать аналог гимпа, казуальную игру, видеоредактор етс при помощи ФП? А если бы вы знали, что вам его 3 года поддерживать и вносить любые правки, то выбрали бы ФП или ООП?Ну, я не могу похвастаться таким опытом в ФП, чтобы сесть и написать гимп. Но, тем не менее, это опять таки не значит, что ФП не годится для этих вещей. На ФП прекрасно пишутся огромные сложные вещи, взять ту же MirageOS на OCaml.
Разве это не особенность всех статически-типизированных языков?В том то и дело, что нет. Статическая типизация лишь обеспечивает проверку типов, но не обработку тех же исключений. Вот зареджектится ваш промис, а вы это не обработали — пожалуйста, рантайм ошибка. В случае же с тем же Elm (ну, раз уж за фронтенд), там просто не существует этих исключений. Все возможные сайд-эффекты обрабатываются как данные.
- Низкая скорость из-за парсинга и компиляции в момент вызова функции;
- Не используется кэш байткода;
- Ограничен доступ к локальным переменным и пространствам имён;
- Не поддерживается компиляторами, типа HipHop;
- Не понятно что там с обработкой ошибок, возникших внутри eval-кода.
Глобальные переменные доступны через инструкцию global, вы говорите о недостатках SKY Framework или о другом? В SKY Framework (текущем) eval имеет доступ ко всему что нужно.
Ваши пункты 1,2,4 — это один пункт. Замечание впросак, не готов дать ответ. Плюс нужно сравнить быстродействие готовых эквивалентных приложений. За счет того что в Symfony не используется eval, а КПИ имеет известную тяжелую архитектуру, я не думаю, что будет выигрыш в производительности.
Ошибки нормально, как обычно обрабатываются. С этим нет проблем.
Это здорово искать новые пути разработки, но опираться на функциональность, живущую на птичьих правах немного опасно.
Даже если в коде будет всего один eval, использующийся для выполнения различных кусков кода из БД и прочих источников данных, недоступных для анализатора IDE — это уже «ад» для того, кто будет с этим кодом работать после автора.
Все ваши проблемы можно решить с помощью уже давно реализованных в PHP замыканий! Но при этом разобраться с кодом стороннему разработчику в своей IDE будет в разы проще, и исчезнут проблемы с которых началась эта ветка.
> Идею проекта SKY можно излагать по разному, но самое короткое и простое изложение следующее:
В итоге получилось на полэкрана некороткого и непростого изложения, не раскрывающего сути.
> Так сайт packagist сопоставим с проектом SKY, достигшем цели X
Увы, не сталкивался с проектом packagist.
> нет ни одного, сила которого бы была обусловлена кодом пользователей
github.com
И всякие сайты-песочницы кода, вроде jsfiddle.net, нет? Сайт помогает эмулировать код, а без этого кода «силы» нет. Сюда-же можно добавить великий Stackoverflow — уберите из него все коды пользователей, и какая будет у этого сайта «сила»? Если засчитываем Stackoverflow, то считаем и миллионы форумов, где люди в топиках задают вопросы по программированию, и им отвечают предоставляя код (начиная от програмирования контроллеров и веб-страниц, заканчивая монстрами биг-даты).
> В данный момент проект SKY мало известен
Хоть 1 слово про проект то! ни слова о том, что же за проект, в конце то концов. Куча воды. После первого громадного абзаца так и не понятен проект. А второй абзац начинается вообще с мемуаров:
> Вообще, я считаю «верный путь в php» большой досадной ошибкой…
нет. я писал о идеальном коде разрабатываемом коллективно.
Теперь вопрос… вы не верите в идеальный код? Задача то для всех одна: «сделайте так чтобы сайты можно было читать в интернете...». Вспомнилось видео: хочу мышкой открывать окна..
Как может возникнуть разнобой в требовании программистов к фреймворк? Исходя из этой логики, существует единое лучшее решение. Есть одна лучшая постановка задачи и одно лучшее решение. Альтернативы, имхо, доказательство лишь того, что каноничность так и не «разрулена», хотя, я верю, что это возможно.
Первая, например, что существует центральное тело страницы и LAYOUT и нужно «их» соединить.
… и даже у этой задачи есть больше одного равноправного решения.
Люди до сих пор не могут определиться, какой presentation pattern лучше подходит для веб-приложений (и, будем честными, с развитием технологий это банально меняется), а вы говорите "идеальный фреймворк". Да он устареет раньше, чем будет написан.
Задача то для всех одна: «сделайте так чтобы сайты можно было читать в интернете...».
Эту задачу решает http-протокол… и если вы обратите внимание, тоже единой версией не обошлось.
Но вообще я вам настоятельно не рекомендую смешивать веб-сайты и веб-приложения.
А если мы говорим о веб-приложениях с изменяемыми на стороне сервера пользовательскими данными, то требования к ним куда более разнообразны чем просто «сайт можно читать и писать в интернете», особенно в части «писать». Скажем, если не предполагается какой-то совместный доступ к данным между пользователями, то его возможность в фреймворке будет избыточна для данной задачи, а если предполагается, то надо будет искать компромиссы между, как минимум, удобством работы и целостностью данных.
Вы исходите из
Вы «летаете» в абстракциях, в жизни 10% случаев это мало… Нет смысла делать код гибким, чтобы поддерживать их.
Второй «мы не должны иметь возможности при всём желании идентифицировать пользователя» — редкий, может быть получен модификацией кода CLEAR-CLOUD с помощью приложения DEV.SKY.
И вы, конечно, не в курсе, что модификация кода фреймворка для решения задачи — это плохо?
Вы «летаете» в абстракциях, в жизни 10% случаев это мало…
10% — это 36 дней в году (больше месяца). Это один месяц (больше) из вашей зарплаты за год. Это мало, да?
Если перевести в автомобильную тематику, то "Как легковушка может удовлетворить потребности в перевозке огромного количества стой-материалов?". Потом, как заметили в комментариях, кому то нравится дизайн, а кому то практичность (производительность) и далеко не все готовы идти на компромис со своими убеждениями и брать что то "идеальное".
нет папки vendor. Требуется переработка классов на packagist в соответствии с идеологией SKY.
примерно ~ 115 тысяч пакетов переработать, coresky, извини, разочарую, но на это ни кто не подпишется.
Жесть какая-то. Вы пишете на PHP 3?
Требуется переработка классов на packagist в соответствии с идеологией SKY
роутинг страниц, как механизм излишен.
Писать код в глобальную область видимости и использовать eval() в коде нужно шире, как это делается в SKY framework
Механизм NAMESPACE излишен.
автор или толстенный тролль, или не понимает о чем говорит
Мне искренне жаль, что материал показался многим сложен для чтения. А вот большой процент людей, не вникшим ни в какую суть, но желающих покритиковать, огорчает.
А вот большой процент людей, не вникшим ни в какую суть, но желающих покритиковать, огорчает.Таков сейчас хабр. Если ваше мнение отлично от мнения большинства — вас минусуют, даже не пытаясь ни в чем разобраться. Причем независимо от того, насколько вы правы/неправы или какие аргументы вы в свою пользу приводите.
P.S. Знаю, что за этот комментарий меня тоже скорей всего заминусуют, но хочется вас поддержать. Повторюсь, некоторые ваши идеи (да и сам проект тоже) достаточно интересны и заслуживают должного внимания.
Вы предлагаете не использовать PDO и именованные параметры, а экранировать данные вручную.
У вас в коде куча потенциальных SQL-инъекций.
if (sql("+select count(1) from users where email='$data[email]'$or")) return 3;
Email перед этим проверяется регуляркой. Вы в курсе, что одиночная кавычка в email это разрешенный символ? Кто-нибудь решит привести вашу регулярку в соответствие с RFC, и в запросе появится уязвимость.
Вы предлагаете писать в полупроцедурном стиле с eval() и глобальными объектами. При этом некоторые процедуры с какими-то скрытыми хаками.
function sqlf() {
$ary = func_get_args();
$func = 'global $sky; return is_array($v) ? $sky->join("' . strtolower(substr($sql = array_shift($ary), 0, 1)) . '", $v) : $v;';
return sql(vsprintf($sql, array_map(create_function('$v', $func), $ary)), 2);
}
function strand($n = 23) {
...
if ($n != 7) $str .= 'o0Ol1iIB8'; # skip for passwords (9 chars)
...
}
Вы предлагаете другим разбираться, поддерживать и развивать ваш код с кучей сокращений и запутанной архитектурой. Все вот эти
global $UA, $PVAL, $s_crypt, $p_mem; $this->idc; $this->gpc; $this->qn;
. А что означают $sky->s_c_manda
и $sky->s_j_manda
я даже думать не хочу.Это правильный путь? Нет уж, спасибо.
нет никакой кучи потенциальных SQL инъекций, зачем врать? Приведите хоть 1 пример реальный… а не «побурчал, сделал умный вид» и ушел. Да, экранировать надо вручную, это принцип KISS. Если у вас сложности с экранированием вручную, вы не будете способны написать нормальное веб-приложение, даже если фреймворк даст вам функции-методы, где авто-экранирование.
>процедуры с какими-то скрытыми хаками…
настолько сложно, что вы не можете понять работу функции? Три строчки то всего… Что может быть проще? А может просто признаетесь, что не владеете func_get_args и vsprintf в полной мере?
У меня сложная архитектура? Тут я просто «пас»…
Ручное экранирование (данных, отправляемых в БД) — это бессмысленная трата времени и сил при наличии параметризованных запросов. Более того, параметризованные запросы (обычно) производительнее на сервере. Так кому и зачем может быть нужно ручное экранирование?
Автор статьи просто не понимает, что KISS требует контекст.
- В юриспруденции важна подробность описания. И чем подробней, тем отсекаются всякие "домыслы"
- Армия (из которой пошел KISS) — важна краткость при передаче информации, чем метче и точнее, чем меньше слов — тем лучше, но все слова и фразы должны быть заранее выучены (чем и занимаются в учебках)
Потому, я считаю, KISS не такой простой каким может показаться. Другими словами — нужно учитывать внешние требования и не писать лишнего. Применять к программированию следующим образом: если требуется одностраничник — не нужно городить огород из кучи абстракций и баз данных. Если бизнес требует абстракции — пиши абстракции.
Но автор подумал, что 640 Кб хватит всем.
Автор статьи просто не понимает, что KISS требует контекст.
По моим ощущениям, автор статьи не только этого не понимает.
Если бизнес требует абстракции — пиши абстракции.
Бизнес обычно не требует абстракции, бизнес хочет, чтобы работало.
Бизнес обычно не требует абстракции, бизнес хочет, чтобы работало.
Бизнес еще требует чтобы оно быстро и легко поддерживалось. (Отсюда и любовь бизнеса к популярным фреймверкам — большое количество разработчиков и саппорт, модульности — в каком то смысле это и есть абстракции).
Бизнес хочет, чтобы стоимость сопровождения и внесения изменений была минимальной, это правда. На все остальное ему наплевать.
(К сожалению, есть бизнес, который лезет не на свою территорию, и пытается решать, каким образом стоимость сопровождения будет меньше — и, поверьте мне, далеко не всегда это "популярные фреймворки".)
Иногда дешевле бизнесу поддерживать свое, иногда взять поддерживаемое. В двух вариантах есть достоинства и не достатки. Смотря какие цели (контекст). Тут как всегда серебряной пули нет.
В конечном счете, ему (бизнесу) наверное все равно, главное чтобы соотношение "цена-качество-скорость" или улучшались или хотя бы оставались на том же уровне.
А разработчикам, чтобы непрерывно удовлетворять изменяющиеся требования бизнеса (улучшать скорость, ускорять поддержку), приходится строить абстракции (примеры: ассемблер, Java, виртуальные машины, React: рендер на клиенте или сервере), чтобы добиться заменяемости на уровнях ниже. Вчера компьютер занимал целую комнату, завтра стал квантовым, но программы тех бородатых времен продолжают работать.
нет никакой кучи потенциальных SQL инъекций, зачем врать? Приведите хоть 1 пример реальный…
«Потенциальная SQL инъекция» означает, что сейчас инъекции нет, но при некоторых условиях она может появиться. Пример я вам привел: меняем регулярное выражение для соответствия RFC — появляется инъекция в запросе.
Да, экранировать надо вручную, это принцип KISS
В запрос передаются 10 значений. Можно 10 раз вызывать escape(), можно 10 раз не вызывать escape(). Минус 80 символов, как минимум. Мне непонятно, почему более громоздкий вариант это по-вашему проще.
Если у вас сложности с экранированием вручную, вы не будете способны написать нормальное веб-приложение, даже если фреймворк даст вам функции-методы, где авто-экранирование.
Почему это? Кстати, раз уж зашел разговор, написанные вами веб-приложения можно где-то посмотреть?
У меня сложная архитектура?
Не сложная, а запутанная и, соответственно, сложная для понимания. Архитектура у вас как раз простая, и это тоже показатель — то, что вы простую архитектуру записали сложным и малопонятным кодом.
настолько сложно, что вы не можете понять работу функции?
Смысл не в том, что ее нельзя понять, а в том, что для понимания ее работы надо залезть в реализацию. А для понимания работы системы в целом надо залезть в реализацию всех функций, потому что а вдруг там тоже магические константы.
Прочитайте книжку Макконнелла, если еще не читали. А если читали, то задумайтесь, почему программисты считают ее хорошей.
Можно 10 раз вызывать escape(), можно 10 раз не вызывать escape()
вы фантазируете, это нереальный случай (оч. редкий), но даже в этом случае — просто используйте цикл, если надо. Посмотрите мой реальный код, где запросы к БД и сравните со своим. Что проще?
eval($me) or die;
if ('delete' == $PVAL):
sql("delete from $me where id=$WVAL");
jump(me);
Первые строки файла admin/_blog.php
.
И да, это ужасно.
Ужасно то, что этот кусок кода (а) делает непонятно, что (что такое $me
? $PVAL
? $WVAL
? нет, спасибо, ответ "это переменные" мне не нужен), и (б) то, что из него понятно — ужасно: представьте себе, что случится, если $WVAL
будет иметь значение id
(просто строка из двух символов).
Веселее всего, конечно, $me
— которая сначала исполняемый код, потом имя таблицы, а потом и вовсе непонятно что (что делает jump
?).
Поэтому нет, это не простой код. Простой код — это тот, который понятен и не вызывает вопросов. А у вас код… простецкий. Он прикидывается простым, но таковым не является.
Опишу глубинный смысл этого кода:
1 способ аналитического взлома сайта — это запустить файл, который сам по себе включаем, как точку входа. Такое действие часто может выдать детали кода хакеру. Существует 3 способа защиты от этого взлома:
1. модный — поместить файлы PHP выше корня веб-сервера
2. положить файл .htaccess с кодом «deny from all»
3. написать вначале файла defined('CONST') or die; — хорошо забытый старый способ
В SKY является стандартным способ номер 3, но можно использовать любой или все.
Способ номер 3 несет четыре функционала в себе, без добавления (вообще !) нового кода. Во-первых, защита от взлома. Во-вторых, в константе указывается имя точки входа, например там может быть admin или front или cron или… другая… Эта информация используется в коде первого крыла main/sky.php, который всегда (! самый потенциально употребимый код) участвует для потенциальной замены любого сайта в Интернете. Кроме того, канонически веб-приложения всегда (оч. часто) построены так, что есть LAYOUT и код «центрального тела страницы». Таким образом третье функциональное назначение: если написать eval($me) or die; это сработает так-же как и defined('CONST') or die; Если переменная $me неопределена сработает die. Код переменной $me можно найти… Но если нормальная работа $me будет хранить имя файла без подчеркивания и .php Ее можно использовать в запросах SQL. При переименовании файла, запросы менять не надо. Часто удобно, чтобы псевдо-имя файла совпадало с именем таблицы с которой работает. Кроме того в трассировке показывается что «центральный файл страницы» запустился (или нет). В четвертых: открыв любой файл SKY-приложения, всегда сразу видно это включаемый файл или файл-точка входа. Благодаря всему описанному функционалу, выбран способ 3 как базовый и стандартный для защиты от основного способа интеллектуального взлома. Есть стандартный файл admin/_main.php, в котором есть стандартный код, который можно запустить и проверить — есть ли надежная защита от такого взлома…
if ('delete' == $PVAL): — тут у вас думаю нет проблем в понимании
sql(«delete from $me where id=$WVAL»); здесь $me выше описана. $WVAL одна из стандартных переменных: $PAGE, $PVAL, $WHAT, $WVAL. Практически всегда (очень часто) первых два ключа-значение из массива $_GET нужны, для обеспечения роутинга страниц, как вы называете (хотя для меня это громкие слова только). Чтобы был проще доступ, эти ключи-значения помещены в эти переменные.… чтобы было тривиально просто.
Этот файл admin/_blog.php — авто-генерированный утилитой VISUAL из приложения DEV.SKY. Он считается только каркасом. Если вам нужен файл для приложения, которое выполняется только на вашей раб. станции, то и дополнительного «крышевания» не надо. Или если доступ к файлу есть только у вас, у разработчика в аггрессивном Интернете. Но если, вы не доверяете всем вхожим в админку, нужно допистать код крышевания, сделать защиту от SQL инъекции. Этот файл, только каркас!
jump(me); — это просто редирект. Константа me будет хранить ?blog
функция редиректа, так же как и sql() — часто используемая. Не нужно ее в класс «пихать»
все, в общем-то
В том-то и дело, что даже тривиально простой код вам не понятен
Как уже сказано выше, он совсем не "тривиально простой".
Вы не сможете никогда постичь его глубинного значения.
Оу, вы вот так легко делаете рассуждения о моих когнитивных способностях? По юзерпику, наверное?
Опишу глубинный смысл этого кода:
1 способ аналитического взлома сайта — это запустить файл, который сам по себе включаем, как точку входа.
модный — поместить файлы PHP выше корня веб-сервера
Это не "модный", это простой и эффективный. Нельзя взломать то, к чему нет доступа.
(впрочем, можно еще взять язык/платформу, где "включаемые файлы" либо изжиты, либо сами по себе не являются исполняемыми для веб-сервера, и вообще не думать о таких вещах)
- написать вначале файла defined('CONST') or die; — хорошо забытый старый способ. В SKY является стандартным способ номер 3,
То-то у вас там написано eval
, а не defined
.
Код переменной $me можно найти…
А я не хочу ничего искать, в том-то и дело. Я хочу открыть самодостаточный (а иначе зачем он в отдельном файле) код, и понять, что он делает, без дополнительных подпрыгиваний и поисков.
Но если нормальная работа $me будет хранить имя файла без подчеркивания и .php Ее можно использовать в запросах SQL. При переименовании файла, запросы менять не надо.
… теперь у вас таблица в БД связана с именем файла. Причем неявно. Как хорошо, что мне никогда не надо будет это отлаживать.
В четвертых: открыв любой файл SKY-приложения, всегда сразу видно это включаемый файл или файл-точка входа.
Угу. Я вот понял, что это включаемый файл, но вот найти, где он включается, мне не удалось.
$WVAL одна из стандартных переменных
Которая имеет какую семантику? И почему эта семантика не понятна из названия?
для обеспечения роутинга страниц, как вы называете (хотя для меня это громкие слова только)
Оно и видно, что для вас "роутинг" — это громкое слово, хотя это всего лишь обычный термин, имеющий англоязычное происхождение.
Но если, вы не доверяете всем вхожим в админку, нужно допистать код крышевания, сделать защиту от SQL инъекции.
Я имею привычку не доверять никому. Очень полезно. И если сгенеренный код по умолчанию небезопасен, то зачем он мне такой?
Константа me будет хранить ?blog
Угу, отдельное спасибо за то, что отдельно есть $me
и me
, и не дай б-г их перепутать.
все, в общем-то
Угу. Для того, чтобы объяснить пять строчек кода, вам пришлось написать экран текста. Это как раз и ужасно.
Вы не сможете никогда постичь его глубинного значения.
Вот знаете, до этого даже не смотрел код — статья как-то не настроила. Но после такого пойду посмотрю…
А так-то, постигать «глубинное значение» в коде, когда у тебя дедлайны, заказчик грозит судами-тудами, и какая-нибудь
это про симфони и ларавел я писал. Там по контектсту понятно. Но и насчет кода SKY, я писал, что считаю только коллективно можно создать идеальный код.
>Вы не сможете никогда постичь его глубинного значения.
И сами авторы не могут, косвеное доказательство появление ларавел из симфони.
Я так понимаю, здесь мало кого интересует истинна. Здесь просто арена для развлечений… Что ж вы так невнимательно читаете… (почти все комментаторы)
Мысль моего коммента была скорее в том, что инструмент хорош под задачу. Сделать быстро магазин с выгрузкой из 1С? Ну, битрикс, ладно… Сделать корпоративную визитку? Ок, вордпресс. Кастомный каталог? Zend и Doctrine замечательны.
Не остается места для философии в программировании за деньги. А для души и решений на салфетке я предпочитаю javascript.
можно создать идеальный кодИдеального кода не существует, и существовать не может. Вы, видимо, все еще на светлой стороне.
В коде у меня, как ни странно, нет ни циклов, ни escape(). Проще не придумаешь.
1) автоэкранирование есть — не надо добавлять вручную
2) не делать автоэкранирование: код фреймворк не перегружен лишним кодом и второе: сделать автоэкранирование бывает нужно для 1-2 полей часто. Если с автоэкранированием: что тогда… для моего session_id, который заведомо int будет применено автоэкранирование… нужен ли этот лишний код? Статистически это ненужное автоэкранирование будет работать очень часто, что не нужно.
На чаше весов, имхо перевешивает логика имеющаяся в SKY
Даже если вы не будете использовать PDO, а добавите автоэкранирование всех параметров запроса, на выполнение этих «лишних» вызовов уйдет гораздо меньше времени, чем на прием-передачу данных из БД через сетевое соединение. Вы пытаетесь экономить на спичках.
И претензии к вашему фреймворку связаны не только с экранированием, так что на чаше весов здесь гораздо больше критериев.
Предварительная оптимизация — зло, а у вас есть результаты замеров, где ясно что эта часть критически важна для оптимизации производительности?
Вам же уже писали, что использование prepared запросов может и увеличить производительность запроса, скешировав его на стороне DB сервера.
А в шаблонах я очень редко видел чтобы экранирование вообще существенно могло повлиять на производительность.
«что тогда… для моего session_id, который заведомо int будет применено автоэкранирование… нужен ли этот лишний код? Статистически это ненужное автоэкранирование будет работать очень часто, что не нужно.»
1. У взломщика это значение может быть чем угодно.
2. Вот вы сейчас помните что session_id — int, а через неделю уже нет или другой человек начнёт работать над вашим проектом, ему же придётся потратить время и понять как вообще там должен быть тип, а если он новичок или пофигист, он просто проигнорирует эти разбирательства и сделает как ему удобно, таким-то образом многие уязвимости и появляются.
Принцип KISS — это хотя бы взять PDO и не мучиться.
Вот именно! Я искренне не понимаю ту часть сообщества хабра которая поддерживает автора. Он скрываясь за собственными терминами и словоблудием продвигает пару вполне нормальных истин. "Простота — хорошо"; "Опенсоурс — хорошо"; "Слепое следование любым постулатам — плохо". Но при этом сам же автор всё это нарушает абсолютно.
Не понимает, что проектов в которых десятки опытных разработчиков УЖЕ ведут разработку вместе и шлифуют код полно. И Флагман это гитхаб. И такая коллективная работа ведется как раз над современными фреймворками, которые так не нравятся автору. Достаточно открыть вкладку с контребьютерами. Но нет нужно там всё бросить и делать скай, ибо там все силы тратятся в пустую.
Говоря что нельзя быть слепым следователем каких то постулатов, сам пишет о слепом следовании KISS при этом в каком то своем понимании.
И самое имхо главное то что он уже сделал это плохо, вот именно ПЛОХО. Говоря что современные подходы только вносят сложность, сам код написал так что в нем невозможно разобраться, он ужасно СЛОЖНЫЙ. Да я быстрее в ларе прикрутил бы броадкастинг эвентов через реббит, при этом сделал бы это всё используя подход фреймворка, и в слое самого приложения вообще бы не было разницы со стандартными методами броадкастинга. Чем в приложении автора пойму откуда какая переменная прилетела и откуда например на какой то строчке есть $user хранящая данные аутентифицированного пользователя. Не говоря уже о каких то сложных вещах типа нескольких одновременных аутентификациях.
А использования тысячи переключалок в визуальной утилите еще сложнее. Я бы быстрее код ядра фреймворка прочитал и понял.
Нет простоты у тебя автор. Никакой
О да, это было очень умно. Нечего сказать не по одному из пунктов? Собственно как говорят "слив засчитан".
Повторюсь ваш код ужасно сложен. Он, как тут было верно сказано, простецкий а не простой. А вы путаете эти понятия. И плюс учитывая что сами писали эти несчастные несколько файлов и мусолили их по много раз вот он и кажется вам простым. Код огромного Ларавель в котором есть функционала в сотню раз больше проще в разы чем ваши "крылья".
Первый попавшийся под руку файл и в нем жесть
$useds = ['---', 'used', 'not used'];
$edit = is_numeric($PVAL);
$block = $u_profile_code && $u_profile_code < 4 ? '' : 'none';
function checkbox($p) {
global $targets, $wona;
return sprintf('%s type="checkbox"', $p > -1 ? ($targets[$p] ? ' checked' : '') : ($wona[-$p - 1] ? ' checked' : ''));
}
$sql = "~select left(p.status,2)='00' or c.package_id=0 as x, p.name as pname, c.*
from _dev_codebase c
left join _dev_packages p on (p.id = c.package_id)
where c.id=$PVAL";
extract($edit ? sql($sql) : ['x' => 1, 'pname' => 0] + get_columns2('_dev_codebase', 3), EXTR_PREFIX_ALL, 'r');
list ($tabs, $vo_me, $vo_all, $targets, $status, $wona) = explode(' ', $r_status, 6);
$d = '';
echo str_replace('%TITLE%', "Edit CBR - $TITLE", $start_html); ?>
Об этом я и писал в комментарии к вашей прошлой публикации — «Можно сделать как в старые темные времена прям в странице sql-запрос и вывод в браузер и это будет работать».
пожалуй, хватит углубляться — весь проект в таком духе
Не думал что когда-то такое скажу, но наверно в видеоуроках попова код приятнее.
И с прошлой публикации так и не видно примеров проектов на этом чуде.
Надеюсь, это все троллинг и вы не считаете это простым и легким в поддержке.
Предложение для сайта HABRAHABR: сделайте, чтобы было можно писать анонимно комментарий зарегистрированным пользователям — жизнь предстанет в другом цвете. Да… некоторые люди, тогда будут пробовать писать плохие «каки». Нужно, чтобы авторы комментариев были предупреждены, что за нецензурную лексику — в этом случае, просто могут потерять аккаунт. А за честное мнение, не будут «заминусованы»…
Мне уже кажется, что на этом уважаемом сайте, просто имеются люди, следящие за хабами и в маркетинговых целях подавляют иные подходы, не соответствующие желаемым. Т.е. это их рабочее задание. «PHP right way» в это случае о-о-очень тонкий маркетинговый ход. Это просто вирус, поразивший программистов.
Laravel. Нравится практически всем, кто на него переходит)
Это потенциально возможно — 100%.
Но, как видите, не для вас.
И вообще, даже в таком старом деле, как физический инструментарий нету до сих пор единства. Все умные люди уже пользуются бензопилой, а есть старперы, которые до сих пор предпочитают молоток и отвертку.
Посмотрел ваш сайт, видео, исходники проекта. Количество вложенных сил и то что вы ведете проект минимум с 2013 года, бесспорно вызывает уважение. Однако меня не покидало чувство что вы с 2010 года живете в изолированном бункере где нашли книжку о PHP. На подобный проект в 2016 году кроме как с удивлением и непониманием смотреть не удается. Если вам не нравится "путь PHP" почему бы не посмотреть на другие языки? Если отойти от мейнстрима то выбор огромен, в том числе и с принципом проектирования приближенном к KISS.
Я хочу, чтобы вы перестали «дышать через противогаз» и вдохнули глоток чистого воздуха… Сорри, если аллегория показалась жесткой. Язык PHP подходит лучше других.
Посмотрел видео: особо оттуда ничего не ясно, но называть symfony и laravel невежеством — это как назвать .NET или Spring — убожеством. Вы конечно извините, но как мне кажется, для разработчиков уровня Enterprise — ваш код не подойдет. Все эти визуальные генераторы и т.п. вещи ну для замены вордпресса.
Правильно выбрать хреновую самопись.
Бред какой-то, и ведь еще не сезон обострений.
смог избавиться от локальных переменных — они сбивают с толку же! Предлагаю улучшить
код фреймворка избавившись от функций. Зачем вот они нужны? Когда читаешь код с функциями, все время нужно
куда-то перелистывать, искать эти куски (да еще и локальные переменные сбивают
с толку), возвращаться уже непонятно куда… Проще писать код прямо и читать его тоже легко.
А для одинаковых кусков есть редактор: скопировал кусок кода, вставил где нужно и все!
Я думаю, все согласятся что читаемость кода увеличивается, но опять, как сказал,
автор все гонятся за какими-то непонятными трендами.
«сделал штуку...» не «прокатит». Чтобы разобраться в «штуке» надо ее поизучать и поюзать, поразбираться. А на это надо хотя бы неделю. Тут никто по-видимому разбираться не хочет. Даже в элементарных вещах путаются. Комментарии здесь — это просто, по-моему, своеобразный способ развлечения у вас… Но кто-то возможно захочет по-разбираться, из тех, кто промолчал. Ради них я с вами общаюсь.
Ваш совет 1 — я так и делаю.
>чтобы даже вашей бабушке было понятно
Я очень много думал, как представить проект. У меня есть штук 5 или больше описаний идеи проекта
>Не обвиняйте других
Я не обвиняю вас и никого из вас. Да, я бы хотел дискуссии в другом тоне, но она в том, в котором есть. Это как здесь кто-то написал: «я не люблю PHP, но он номер 1, это факт». Жизнь нужно воспринимать такой какой она есть, не стоит совать голову в песок или уходить в свой фантазийный мир. Я виню в том, что дискуссия в таком тоне, в каком есть, только себя. Буду продолжать следовать (1)
Совет 2
>и сделать его еще лучше
coresky файлы http://ru.coresky.net/code (ядро SKY) прошли очень много итераций по совершенствованию мной, может быть 1000, начиная с 2005 года наверно, и будут продолжать совершенствоваться.
>ассоциировать свои идеи с собой…
как это? идея или есть или она не идея, а заблуждение.
>выслушать все замечания…
Этот код очень дорог для меня, потрачено очень много моих усилий для его создания. Замечания здесь в большей мере, не могут быть использованы мной, так как я слышу, например, не пишите в глобальную область видимости, но я не могу не писать, вся концепция основана на этом. По сути, большинство советует: «выбросите вашу работу», я не собираюсь это делать.
>Если Вы делаете для себя лично
прошу прощения, но глупо было это писать. Если бы я делал для себя, не было бы проекта в паблике и этой статьи
Совет 3.
>соответствует уровню любителя
если код выглядит просто, это не значит что он уровня любителя.
>странные непонятные хаки
это нормальный синтаксис PHP, это часть концепции проекта. Использование create_function, eval позволяет делать тривиально простой код. Это также часть концепции. Этот ваш совет, по сути, совет: «выкиньте ваш код»
>хорошие имена функциям
например где плохо?
>покажете свою неубранную квартиру
это нормальная критика, я знаю, что нужна лучшая «обертка для конфеты». Но я «причесал» все, как только мог, буду «причесывать» дальше… Проблема в том, что я слишком «на многое замахнулся», для того, чтобы «протолкнуть» такое, нужны о-о-очень большие ресурсы, а их у меня пока нет. И если не появится сильная помощь для проекта SKY, то он так и не запустится… Но я буду продолжать работать над ним, так как искренне верю
Так, что ваши советы или неприменимы или я уже в курсе и следую и так им.
Посмотрите последний пост Дурова в vk. Он там пишет 10 советов и совет номер 1 — все нужно делать быстро. vk сделан им за месяц и после этого стал развиваться. Я верю ему. У меня тоже был опыт успешного проекта, который был сделан за неделю, кстати на коде SKY. Насчет проекта SKY, — я сразу понимал, что он совершенно далек от такого пути. Разрешимая ли это проблема, и сейчас непонятно, но я сдаваться не собираюсь. Я получал удовольствие творчества, я искренне верил (и сейчас верю), что многие мои идеи ценны, лучше идей других людей, стал «запечатлевать их в камне». Еще ньюанс в том, что я очень люблю веб-программирование и меня тошнит от трендовых фреймворк.
Я видел интервью с А. Макаревичем, он говорил: не задавайте мне вопросы в стиле «если бы, да кабы… такого не может быть никогда, поэтому не следует об этом и думать». А я люблю, мыслить в стиле «если бы..». На сайте coresky, есть мои размышления, по поводу «если бы человечество бросило максимально возможные ресурсы для создания супер виртуальной реальности». Такой стиль мышления позволяет более красочно моделировать ситуации в уме, а программисты много моделируют в уме.
Цель X описанная выше, в статье из этой области фантазий, но потенциально реальная. Я пытаюсь придумать подход к запуску SKY в стиле «очень быстро, как VK», но не могу ничего придумать пока. Статью на хабре, я планировал написать еще 3 года назад. Я не мог больше тянуть и сделал то, что сделал. Вероятно, это бесполезно: за все время 1 регистрация на сайте, и то человек, по-видимому просто хотел посмотреть «что в средине». Около 10 установок всего-то приложения DEV.SKY. и не очень приятные ощущения в шкуре «мальчика для битья». Но я должен был попробовать хабр.
>покажите конкретные примеры
У меня есть такая идея: портировать форум PHPBB на SKY Framework. Одно время я работал с ним, его хорошо знаю. Он довольно многофункциональный, но я думаю мог бы сделать хорошую реализацию его за «терпимое время». Ничего не придумывать, взять их дизайн и портировать.
Как считаете, может это помочь проекту SKY?
Позволит ли сайт phpbb.com рекламироваться у них бесплатно или они не заинтересованы?
Может быть не phpbb, а другое хорошее приложение без изъянов? NULL-сайт, как видим не впечатляет… DEV.SKY. слишком компактное, сложное, многофункциональное приложение. Его, чтобы «причесать» нужно больше усилий, чем порт для phpbb и нет 100%-гарантий, что им будут активно пользоваться, нет потенциальной возможности получить бесплатную рекламу от авторов phpbb.
Чтобы разобраться в «штуке» надо ее поизучать и поюзать, поразбираться. А на это надо хотя бы неделю.
Ну во-первых, для поверхностных оценок достаточно нескольких часов (если, конечно, в своей отрасли).
А во-вторых, какой смысл разбираться в "штуке", если ни она, ни вы пока ничего нового и полезного не предложили?
Вы скачайте код к видео, посмотрите как он прост.
Сравните его с эквивалентным кодом вашего фреймворк…
Новое и полезное: веб-приложение разрабатывается намного проще легче и быстрее чем в вашем фреймворк… это просто небо и земля…
Нужно бы сделать тесты, чтобы сравнить производительность. Думаю и работать будет намного быстрее, несмотря на медленный eval(). Фактические измерения, были бы наверно для вас более весомым аргументом
Вы скачайте код к видео, посмотрите как он прост.
Скачал, по вашему это просто?
define('DIFF_CNTS', 'if ($d >= 0) $i++;
if ($T & 1) { if (!$sl) $l_ = $l; $sl++; }
if ($T & 2) { if (!$sn) $n_ = $n; $sn++; }
$T = 0;');
define('DIFF_UNIQ', '$f = 0;
if ($d < 0) {
$srch = $old[--$l_].$l0.$srch; $l0 = "\n";
$repl = $new[--$n_].$n0.$repl; $n0 = "\n";
if ($x && $x[2] == $l_) $f = 1;
} else {
if ($sn) for (; $sn; $sn--, $n0 = "\n") $repl .= $n0.$new[$n++]; else { $n_ = $n; $f = 1; }
if ($sl) for (; $sl; $sl--, $l0 = "\n") $srch .= $l0.$old[$l++]; else { $l_ = $l; $f = 1; }
if ($f) return 1;
}
if ($f) {
$file = str_replace($x[0], $x[1], $file); $snap = str_replace($x[1], $x[0], $snap);
$x[0] .= "\n".$srch; $x[1] .= "\n".$repl;
} elseif (eval(DIFF_TEST)) {
if ($x) $str .= sprintf("\n\n# SEARCH: #\n%s\n\n# REPLACE: #\n%s", cbesc($x[0]), cbesc($x[1]));
$x[0] = $srch; $x[1] = $repl;
} else return 1;
$x[2] = $l;
$file = str_replace($x[1], $x[0], $file); $snap = str_replace($x[0], $x[1], $snap);
$srch = $repl = $n0 = $l0 = "";
$sn = $sl = $d = 0;
$n++; $l++;
return 0;');
define('DIFF_TEST', '
if ($srch === "" || $repl === "" || substr_count($snap, $srch) != 1 || substr_count($file, $repl) != 1) return 0;
$_t = str_replace("\n", "", $srch); if ("" === $_t || "" === trim($_t, $_t[0])) return 0;
$_t = str_replace("\n", "", $repl); if ("" === $_t || "" === trim($_t, $_t[0])) return 0;
return 1;');
define('DIFF_UFIX', '
if (!$l_) $d = 1;
elseif ($i >= $c) $d = -1;
elseif ($d == 0) { # search ext direction
$db = $x ? $l_ - $x[2] : 0;
for ($df = 0; $df + $i < $c; $df++) if ($rL[$df + $i] != "=") break;
if ($df + $i == $c) $df = 0;
if ($db && $df) $d = $db < $df ? -1 : 1;
elseif ($db) $d = -1;
elseif ($df) $d = 1;
else $d = $l_ < $c - $i ? -1 : 1;
}
$sn = $sl = $d;');
у вас даже комментариев не написано почти нигде, или не писать комментарии тоже «sky-way»? Ваш код простой для вас, т.к. вы автор, для остальных — нечитабельный и корявый говнокод (по другому не знаю как назвать)
И опять же — нет примеров каких-либо приложений на этом чуде
Критиковать код прошу из видео http://ru.coresky.net/download?video1.sky.zip
Приведенный вами код из DEV.SKY. В самой статье написано в проекте SKY еще очень много работы… И проект SKY, я предложил пока только как хобби… Я не говорил, что все идеально.
Да, этот код из DEV.SKY. выглядит экстремально, непривычно. Это своеобразный способ, разделить код на части для более простого восприятия и вероятно требует переработки. Но есть и много другой более приоритетной работы, поверьте. Не забывайте, SKY это хобби и деньги мне за него никто не платит. Ресурсы мои невелеки, время от времени большие, время от времени меньшие…
raacer, так вы только сейчас на сайт зашли? Т.е. вы «пробежались» по статье, увидели «белую ворону», нонсенс и решили поразвлечься… Я так и думал, вы изначально и не собирались пытаться понять о чем я пишу, потому что вы уверены, что у вас достаточно аргументов самому-то не попасть в просак. И так многие комментаторы сделали… Жаль, что вы цените такой способ развлечения больше, чем возможность посмотреть на веб-программирование с непривычной стороны и возможно понять что-то новое.
давайте из архива из видео посмотрим
$log = [];
$sky = new SKY;
extract($sky->load(), EXTR_PREFIX_ALL | EXTR_REFS, 's') or exit('err mem');
if ($sky->debug) require 'main/debug.php';
if (at('0 23')) lsql("delete from visitors where dt_l + $s_clear < now()");
at('59 23') && sql("+select 'do work once at the end of day'"); # sample2
if (at('1 0')) $sky->s_email_cnt = 0;
if (at('3 3')) require 'main/c_sitemap.php';
$sky->save([
'cron_dt' => sprintf("%s, execution time: %01.3f sec, SQL nums in cron tasks: $sky->qn", NOW, microtime(true) - START_TS),
'online' => sql("+select count(1) from visitors where dt_l > now() - interval $s_visit minute"),
]);
lsql("+select 'test'");
не лучше.
Упаси нас все боги от такого core разработчика) Человек прибывает в своем мирке. Он сам не понимает что не предлагает ничего нового. И смена языка ему ничем не поможет. Хотя ему с его тягой к KISS (хотя я считаю, что у него свое извращенное понятие этого принципа, но всё же) можно посоветовать разве что golang попробовать.
мне так, в то время было удобней… и я писал выше, я согласен — нужно переработать
>Анализатор не предупреждает об ошибках
неверно. ошибки внутри eval() возникают, с этим нет проблем
>Дебажить такой код — это ад
diff — работает, его не надо дебажить, я уже делал миллион запусков-тестов. Еще раз: error_handler работает внутри eval.
>давайте из архива из видео посмотрим
Файл называется cron.php, значит как-то связан с кроном…
вверху: define('START', 'cron');
не defined, а define — определение константы, значит это консольный скрипт для cron-задач, точка входа.
есть такой код: lsql("+select 'test'"), значит это просто пример организации cron-задач.
at с англ. переводится как «во время»…
>Ноль часов двадцать три минуты?
верно.
Функция at() — полная эмуляция синтаксиса крон. Можно упаковать много крон-задач в один файл.
Значит скрипт должен запускаться каждую секунду…
Но плохо может быть то, что сбой одной задачи приведет к сбою остальных, такой подход нетехнологичен. Однако, есть ряд задач, когда не очень важен 100% запуск крон-задач или вы сильно уверены, что сбоя не будет, если это например запрос:
lsql(«delete from visitors where dt_l + $s_clear < now()»);
просто «чистка» таблицы сессий.
К тому же никто не запрещал, выносить крон-задачи в отдельный файл, как например в том же архиве файл c_summer.php. префикс c_ — крон-задача.
Что же тут плохого или непонятного?
Это все MetaDone, вы бы могли и сами понять, даже без документации, если бы не были настроенны на троллинг.
сравните сами и поймете что у вас все просто коряво. скажите, чем ваша реализация лучше той, что по ссылке?
Про namespace я молчу.
Начну с того, что в примере по ссылке «подтягивается» 3 файла, а сколько они в свою очередь «подтягивают» я даже не смотрел…
В SKY «подтягивается» один require 'main/conf.php', а он в свою очередь еще один require 'sky.php';
КПИ (код повторного использ.) для работы с DB лучше объединить с другим кодом, который в ларавел разделен. В этом нет смысла, нормально определить «код первого крыла» который выполняется при всех точках входа, включая CRON. Это маленький ньюанс, но все состоит из маленьких ньюансов. Если вы знаете ларавел, и вам нужен крон, дополнительно вам нужно открыть страницу (что вы дали выше) чтобы изучить документацию для Illuminate\Console\Scheduling\Schedule
В SKY не нужно ничего изучать для добавления крон-задачи.
Обычно крон-задачи простые, например очистка сессий и нужно выполнить один только запрос. В SKY я пишу
if (at('0 23')) lsql(«delete from visitors where dt_l + $s_clear < now()»);
просто в глобальной области видимости, нет никакой опасности переопределить глобальные переменные, у ларавел делается класс, что лишнее. В SKY нужно только знать SQL той БД с которой работаем, у ларавел опять таки вплюс нужно изучить класс, чтобы написать DB::table('recent_users')->delete();
разработчик пишет: When using the scheduler, only a single Cron entry is needed on your server. т.е. нужен только один файл крон нужен, а запускать будем каждую минуту… Это неверное утверждение, если крон-задача очень важна, она может невыполниться ввиду ошибок в другой задаче, поэтому желательно иметь возможность делать несколько файлов крон. ОК, сделаем еще один файл, наперекор автору ларавел, но нет метода ->now() в Illuminate\Console\Scheduling\Schedule
Тогда применим, например ->hourly();
Это «костыльно».
Вот это:
// Run hourly from 8 AM to 5 PM on weekdays…
$schedule->command('foo')->weekdays()->hourly()->timezone('America/Chicago')->between('8:00', '17:00');
выглядит сложно и некрасиво. Я сторонник чтобы был один способ ->cron('* * * * * *'); список альтернативных методов, как ->hourly(); никчему.
В SKY можно, вложено использовать функцию at()
if (at('0 1,2,12')) {
if (at('3')) { }
}
Чтобы добиться времен запуска, для которых прямой синтаксис крон невозможен.
Самое интересное, это явный бред просто, или я что-то не понял? Только спокойно, мне реально интересно…
Какой смысл вообще в ->skip() и ->when() методах, если можно просто написать:
// code of the when
$rule =…
if ($rule) {
// code of the cron-task
…
Тоже самое касается хуков ->before() и ->after()
Прошу Вас давайте разберемся…
С ларавел кроном, вроде как мне все понятно… Неужели я что-то неправильно понимаю? Или все-таки Клондайк? Спасибо.
Про namespace я молчу.
К сожалению, не молчите. Так что же плохого в namespace
?
КПИ (код повторного использ.) для работы с DB лучше объединить с другим кодом, который в ларавел разделен
Почему лучше?
В SKY не нужно ничего изучать для добавления крон-задачи.
Это банально неправда. Нужно найти, где и как это задаются задачи, и разобраться с синтаксисом.
В SKY нужно только знать SQL той БД с которой работаем, у ларавел опять таки вплюс нужно изучить класс, чтобы написать DB::table('recent_users')->delete();
Ну так знать классы фреймворка дешевле, чем знать вариации SQL для всех БД.
Это неверное утверждение, если крон-задача очень важна, она может невыполниться ввиду ошибок в другой задаче
С чего вы это взяли? Это в вашей реализации так, но не обязательно так в других.
нет метода ->now()
Логично, что нет, потому что не бывает задачи по расписанию "сейчас" (костыли в рассмотрение не берем).
Я сторонник чтобы был один способ ->cron(' '); список альтернативных методов, как ->hourly(); никчему.
Ага, давайте заставим всех, кто имеет дело с этим кодом, учить крон-нотацию. Зачем? Написать Hourly намного проще, и это дешевле в дальнейшей поддержке.
Какой смысл вообще в ->skip() и ->when() методах
Разделение действия и условия.
если можно просто написать if ($rule)
Можно. Но теперь вам придется для каждого действия написать свой код, хотя можно было бы обойтись одним действием и разными условиями.
Условия и хуки — это способ декомпоновать код на простые легко используемые структурные единицы. Ну и заодно еще читаемость повышает.
Про namespace я молчу.
я вам писал про это, ваши аргументы против пространств имен не тянут на годные
КПИ (код повторного использ.) для работы с DB лучше объединить с другим кодом, который в ларавел разделен.
бред — зачем смешивать разные зоны ответственности? Если к примеру я буду парсить посты из разных источников, то зачем мне в куски, которые получают информацию с сайта-источника, примешивать сохранение постов в базу? Получение отдельно, сохранение отдельно (первый пришедший в голову пример, таких можно кучу придумать)
дополнительно вам нужно открыть страницу (что вы дали выше) чтобы изучить документацию
Ну… в laravel есть что открывать, и самое главное — почти на любой вопрос я могу найти ответ, как и на любом популярном фреймворке. У вас даже комментариев нет, не то что документации.
В SKY не нужно ничего изучать для добавления крон-задачи.
вам — не нужно, остальным ваши извращенные идеи при создании этого не так очевидны.
В SKY нужно только знать SQL той БД с которой работаем, у ларавел опять таки вплюс нужно изучить класс, чтобы написать DB::table('recent_users')->delete();
Покажите пожалуйста пример, как в вашем чуде организовать email-рассылку на 20000 писем через mandrill, да еще так чтоб она не длилась часов 8.
ОК, сделаем еще один файл, наперекор автору ларавел, но нет метода ->now()
вы в курсе что можно просто выполнить консольную команду?
$schedule->command('foo')->weekdays()->hourly()->timezone('America/Chicago')->between('8:00', '17:00');
выглядит сложно и некрасиво.
и как оно будет выглядеть в sky?
нет никакой опасности переопределить глобальные переменные, у ларавел делается класс, что лишнее
представьте, что у вас 100-150 различных консольных команд. С вашим подходом все превратится в нечитаемую мешанину.
Тоже самое касается хуков ->before() и ->after()
Запустили плановую рассылку — как закончилась отправили письмо админу
Вы мне дали ссылку, просто Клондайк для антирекламы ларавел, если я не ошибаюсь…
ошибаетесь, как всегда, потому что судя по всему не сталкивались с хотя бы немного сложными задачами с использованием вашего чудо-фреймворка. И если вас смущает количество подтягиваемых файлов и так печетесь о быстродействии, то смотрите сюда — https://docs.phalconphp.com/ru/latest/reference/cli.html
Неужели я что-то неправильно понимаю?
Вы снова ВСЁ неправильно понимаете))
Я пропущу ваши первые тезисы о неймспейсах, числе файлов, "простоте" вашего кода и необходимости читать документацию. Ибо вам уже дали пару ответов. Скажу лишь что я рад что в Ларе код хранится по PSR-4, что каждому классу отведен свой файл а не свалено всё в единую огромную дурнопахнущую кучу вашего "первого крыла" (как же вы достали со своими самопридуманными терминами) А еще замечу что вы похоже не знаете как работает кеширование кода в php. И что Лара умеет собирать свой код ядра в один файл. Но при этом исходники приятно разложены.
Далее:
крон-задачи простые, например очистка сессий и нужно выполнить один только запрос.
Это не так. То что вы всю свою "карьеру" не писали ничего сложнее блога это ваш юзкейс.
Обычно это отдельная, зачастую ресурсоемкая задача. С достаточно большим временем выполнения. И не тривиальным кодом. (Отправка писем по запланированной рассылке, агрегация данных, подготовка отчетов). В ларавель они красиво вынесены в консольные команды. Но и что то простое можно сделать просто без класса а описав действия в замыкании.
Ваш планировщик — дно неприменимое в продакшене на сколь нибудь серьезном проекте. Я не хочу что бы одни мои задачи зависели от выполнения других.И в ларе представляешь они не зависят. Ибо тот скрипт который прописывается в крон он запускает запланированные задачи прописанные в нем изолированно. Я не хочу писать в crontab новые строки (тем более что доступа у меня может и не быть и делать это надо через админа). А блокировка от двойного запуска долгой задачи? а запуск с особыми условиями среды, часового пояса, ежеминутно но в определенный день или промежуток времени… И еще десяток юзкейсов которые дает Лара и о которых вы в силу вашего скромного опыта даже не задумываетесь. А еще я хочу иметь возможность запустить форсированно (не по крону) какое то задание, например если ночью в момент нужной задачи лег ДЦ, или еще почему то. (Вот для этого в ларе и обернуты они все в классы консольные команды)
if (at('0 23')) lsql(«delete from visitors where dt_l + $s_clear < now()»);
просто в глобальной области видимости, нет никакой опасности переопределить глобальные переменные, у ларавел делается класс, что лишнее
$schedule->call(function () {
DB::table('visitors')->where(...)->delete();
})->dailyAt('23:00');
$schedule->command('foo')->weekdays()->hourly()->timezone('America/Chicago')->between('8:00', '17:00');
выглядит сложно и некрасиво.
Ага ну давай повтори это же условие "красиво" в своей системе. Особенно between и timezone. А учитывая что я изучил твой недокод. Сразу отвечу, что ты не повторишь никак.
разработчик пишет: When using the scheduler, only a single Cron entry is needed on your server. т.е. нужен только один файл крон нужен, а запускать будем каждую минуту… Это неверное утверждение, если крон-задача очень важна, она может невыполниться ввиду ошибок в другой задаче, поэтому желательно иметь возможность делать несколько файлов крон.
Это у вас так, а вот в Ларе они запускаются изолированно, представляете до чего программисты додумались. Именно что бы время выполнения или ошибки в одних задачах не влияли на другие. И всё это разруливает 1 скрипт. Вот это да!
Или все-таки Клондайк?
Да кландайк, но не система планировщика Лары, а вот этот ваш комментарий. Он идеально показывает что вы некомпетентный, неуч и к тому же глупы. (Да я "скатился" до грубости, но пора уже огласить правду)
Я ошибся один раз, присоединив хук ларавел к ->call() вместо ->command() увидев в первый раз новую для меня документацию
Ну то есть вы раньше в laravel не разбирались? И в том, как в других системах устроены фоновые/рекуррентные задачи — тоже?
Эм, из всех ошибок на которые я указал ты увидел только call? Чувак, с тобой точно что то не так. Самая вопиющая ошибка была где ты не понял как вообще работает планировщик в ларе и написал бред
разработчик пишет: When using the scheduler, only a single Cron entry is needed on your server. т.е. нужен только один файл крон нужен, а запускать будем каждую минуту… Это неверное утверждение, если крон-задача очень важна, она может невыполниться ввиду ошибок в другой задаче, поэтому желательно иметь возможность делать несколько файлов крон. ОК, сделаем еще один файл, ...
Ну и тон сообщения это радостно презрительное улюлюкание. "Кландайк!", "антиреклама". Мне тут в одном из комментариев посоветовали уважать ваш труд. Так вот, нет. Вы не уважаете труд тысяч разработчиков.
Обычно крон-задачи простые, например очистка сессий и нужно выполнить один только запрос
Ну понятно что у Вас то они обычно простые, сложные не впишутся концепцию проекта SKY, т.к. они требуют много строк кода, а здесь то «clear cloud»
А вот рассмотрим реальные cron задачи:
— Синхронизация списка пользователей сайта и AD корпоративной сети
— Синхронизация календарей сотрудников из MS Exchange с корпоративным порталом.
— Ежедневная рассылка уведомлений по электронной почте
— Обновление поискового индекса на сайте
— Генерация отчетов
Каждая из этих задач требует выполнить не один SQL запрос, вдобавок нужно сформировать и т.д. и т.п. Боюсь ваш крон файл не выдержит такое, так же как и код.
Кстати, вы же знаете, что крон задачи можно добавлять напрямую в crontab, это сэкономит лишние!!! килобайты!!! Вдумайтесь, зачем ваш файл
cron.php
, если можно, например, crontab -e
и там добавить нужные задачи. * * * * * /var/www/sky-project/cron.php session:clear
0 0 0 0 * /var/www/sky-project/cron.php delete:project
Функция
at
костыль!дополнительно вам нужно открыть страницу (что вы дали выше) чтобы изучить документацию
Я так понимаю, вы стали программировать не заглядывая в документацию, да и видимо так со всем остальным. Дома у вас инструментов также никаких нет, только потому, что есть камень, самый простой инструмент и с его помощью можно сделать все, забить гвоздь, развести огонь ну и инструкция не нужна! Зачем усложнять жизнь?
Так вот правда в том, что инструменты, также как и ваш, рождаются тогда, когда его автор считает, что он необходим. И чем больше людей используют инструмент, чем он полезнее. Давайте обратимся к статистике: https://packagist.org/explore/popular и посмотрим какие сейчас инструменты нужны всем.
Неужели я что-то неправильно понимаю?
Вам бы идти в демагоги, а не в программисты.
Ну и напоследок: я бы советовал взять, к примеру, SugarCRM. Почему его? А потому что он монструозный и код открыт и там вы в полной мере окунетесь в мир глобальных переменных, php4, легаси кода и т.д. Изучая его вы сможете в полной мере ощутить себя в шкуре тех разработчиков, которым вы пытаете впарить свою систему. После того, как вы во все это окунетесь, задумайтесь над тем, насколько можно сократить код по идеологии SKY Project
P.s. Вы же, надеюсь, понимаете, что как только ваш КПИ (код повторного использ.) по возможностям отчасти сравняется с Laravel, то ему потребуется документация? Или вы думаете, что весь код из Laravel можно сократить до 3-х функций? И отсюда у вас возникает вопрос: раз даже я, разработчик, который решил изменить мир к лучшему не смог изучить код Laravel, то код от лукавого и не нужен, не то что мой, понятный мне без документации, а значит всем остальным и в этом его преимущество.
P.p.s У меня в проекте 276 файлов с классами покрытыми phpDoc + 60 view файлов (и это еще не большой проект, без учета сторонних библиотек), как думаете, насколько это можно сократить?
Анализатор не предупреждает об ошибках
неверно. ошибки внутри eval() возникают, с этим нет проблем
Верно-верно. "Ошибки возникают" и "анализатор предупреждает об ошибках" — это две очень большие разницы.
diff — работает, его не надо дебажить, я уже делал миллион запусков-тестов.
Любой код в какой-то момент приходится дебажить. Не надо это делать только с кодом, который никогда не запускается. А учитывая, что юнит-тестов у вас нет...
Файл называется cron.php, значит как-то связан с кроном
Угу. И весь этот велосипед можно заменить на готовое решение. В частности, вместо if (at('0 23')) lsql("delete from visitors where dt_l + $s_clear < now()");
было бы RecurringJob.AddOrUpdate(CleanUpOldVisitors, Cron.Daily);
, не было бы никакого запуска каждую секунду (который, на самом деле, не нужен, а иногда и опасен), нормальное логирование/мониторинг/UI и так далее.
>Ну так знать классы фреймворка дешевле, чем знать вариации SQL для всех БД.
Я думаю надо знать и SQL БД и ORM иначе чел. не программист. Если чел. знает только ORM, больше чем сайт-визитку он не напишет на ларавел.
>С чего вы это взяли? Это в вашей реализации так, но не обязательно так в других.
Да с того, что PHP скрипт выполняется в 1 поток и если неважная задача остановит работу скрипта например по фатальной ошибке, то важная крон-задача может вообще не выполнится. Это вопрос не SKY, а выполнения скрипта в 1 поток (процесс на UNIX машинах)
>И весь этот велосипед можно заменить…
У меня впечатление, что Вы намерено на черное говорите белое и наоборот. У меня противоположное мнение, у ларавел куча лишнего, в SKY все просто и есть все необходимое
function test() {
sleep(5);
$a = 1 + 1 // Missing ;
return $a;
}
echo "Start\n";
echo test() . "\n";
echo "Stop\n";
function test() {
sleep(5);
$a = eval('1 + 1'); // Missing ;
return $a;
}
echo "Start\n";
echo test() . "\n";
echo "Stop\n";
Первый вариант сразу вернет PHP Parse error
(при чем не обязательно даже вызывать проблемную функцию)
Второй вариант — только через 5 секунд.
Я написал eval('1 / 0;'); и вот run-time ошибка в SKY Framework,
Рантайм. А анализатор/компилятор дает ошибки раньше.
Я думаю надо знать и SQL БД и ORM иначе чел. не программист. Если чел. знает только ORM, больше чем сайт-визитку он не напишет на ларавел.
Знать все в деталях невозможно. Для общих задач знать ORM эффективнее.
(скажите, а вы, конечно, знаете все используемые вами компоненты хотя бы на один уровень вниз? и да, какие ORM вы знаете?)
Да с того, что PHP скрипт выполняется в 1 поток
Даже я слышал про pthreads
. Так что нет.
У меня впечатление, что Вы намерено на черное говорите белое и наоборот. У меня противоположное мнение, у ларавел куча лишнего, в SKY все просто и есть все необходимое
Необходимое кому? Я уж не говорю, что вопрос не только "что есть", но и "как оно реализовано". Пока что все разобранные примеры показывают, что реализовано плохо.
http://php.net/manual/ru/pthreads.requirements.php
pthreads requires a build of PHP with ZTS (Zend Thread Safety) enabled ( --enable-maintainer-zts or --enable-zts on Windows )
>представляете до чего программисты додумались
представляю
pthread не полноценно рабочая вещь
Ну, во-первых, не "неполноценно", а "не для каждого PHP", но кого это останавливает?
А во-вторых, это, в общем-то, не единственный вариант — учитывая, что запуск идет из консоли, там можно почти что угодно наворотить (собственно, Laravel pthreads
не использует, а использует, он, похоже, просто отдельные процессы).
я уже понял, что никого…
представить ситуацию, что у вас не работает на сервере phtread элементарно, когда вам это внесло существенные сложности…
Вы мне будете «втирать» что ее пофиксить легче, чем просто дать возможность записать 2 строчки в кроне, вместо одной и что ситуация, когда у вас есть возможность записать только одну строчку в кроне (а две никак) чаще чем, когда не работает pthread? Или наваять какие-то исполняемые файлы, которые фокают процесс, легче чем 2 строчки просто записать?
Это был риторический вопрос. Отвечать не надо. Всем спасибо.
Или наваять какие-то исполняемые файлы, которые фокают процесс, легче чем 2 строчки просто записать?
Конечно, легче. Для записи строчек в крон нужен доступ к серверу, а для того, чтобы использовать Process
из Symphony
достаточно взять Symphony
.
(я молчу про то, что есть решения — не на PHP, правда — которые вообще без крона работают)
Ну и на самом деле, устроено-то все ровно наоборот: Laravel-евский планировщик так написан, что ему достаточно одной строчки в кроне (и у него разумные системные требования). Разработчику для этого ничего специально делать не надо. Вы зачем-то стали утверждать, что так работать не будет, падение одной задачи приведет к падению всего планировщика.
О том, что проще — речи, на самом деле, не шло.
Мне здесь написали, что Pthreads решает задачу параллелелизма для крон в ларавел. Я сказал что «врядли». Похоже изобретатель ларавел написал исполняемый файл (для каждой ОС отдельный), чтобы решать эту задачу. «Фокает» он, а не пользователь ларавел.
Не
>2 строчки
а две Closore
А вы можете представить, что вы решаете задачу которую решил разработчик ларавел, как оно сделано? Крон раз в минуту запускает исполн. файл (условно artisan.exe), который запустил крон-файл пользователя, создал реестр запусков и потом в отдельном потоке запуcкает наши Closure-крон-задачи пользователя (или примерно так). Все довольно сложно только ради того чтобы все задачи были в одном файле и для них нужна была одна строчка в крон (раз в минуту). Вся эта сложность и надежность artisan.exe здешних менеджеров проектов «не парит», и они правы (без сарказма). artisan.exe в авторитете а ларавел бесплатно доступен.
Мне здесь написали, что Pthreads решает задачу параллелелизма для крон в ларавел.
Кто?
Похоже изобретатель ларавел написал исполняемый файл (для каждой ОС отдельный), чтобы решать эту задачу.
Тоже нет. И из доки это очевидно.
Все довольно сложно
Что сложного-то?
(повторюсь, я бы предпочел и без крона обойтись, но это не везде и не всегда работает)
Суть простая — вместо того, чтобы на каждую нужную задачу не приходилось редактировать crontab, туда пишется только задание для планировщика laravel, а внутренние команды он сам разруливает по тем же правилам что и крон. За параллельное выполнение там отвечает компонент Symfony Process.
И все сводится к тому что если время настало — запускается консольная команда, которая уже непосредственно делает что-то полезное, и для редактирования периодичности ее исполнения не придется подключаться по ssh и редактировать crontab + все расписание видно в коде.
Кстати у вас нельзя задать расписание к примеру только на рабочие дни с 9 до 18:00, к тому же все выполняется последовательно, что на реальных задачах не позволит использовать ваше чудо-решение.
тут все понимают как оно сделано, кроме вас.
У вас какая-то каша в голове.
Похоже изобретатель ларавел написал исполняемый файл (для каждой ОС отдельный)
Строка запуска «php /path/to/artisan schedule:run» намекает на то, что это PHP скрипт, а не бинарный файл. Соответвенно, он один для всех ОС. И он есть в исходниках фреймворка на github.
а две Closore
Closure это один из способов. In addition to scheduling Closure calls, you may also schedule Artisan commands and operating system commands.
Крон раз в минуту запускает исполн. файл (условно artisan.exe), который запустил крон-файл пользователя, создал реестр запусков и потом в отдельном потоке запуcкает наши Closure-крон-задачи пользователя (или примерно так). Все довольно сложно
Не знаю, почему вы так решили. Я с этим фреймворком не работал, но насколько я понял из документации, крон запускает скрипт планировщика, в планировщике запускается функция Kernel::schedule(), где написано расписание задач, нужные задачи запускаются. Closure выполняются в том же процессе, команды запускаются в отдельных процессах (не потоках). Все просто и логично.
Вся эта сложность и надежность artisan
проверена тысячами пользователей фреймворка в разных проектах.
О вы снова на высоте!) Там не используется pthread))
Ну давайте попытайтесь еще.
Тут большинство считает, что его слова адекватны. Качали мы уже всё. Нет спасибо такого нам не надо. Наш код проще. Аналогии конечно последнее дело, но никак не могу отделаться от мысли что автор настоятельно втирает всем булыжник вместо например Беретты.
Идейно тоже нет ничего нового. или напиши только чётко и без воды хоть один (лучше просто один) тезис что ты предложил.
Код шаблона админки:
<?php defined('START') or die;
# For Licence and Disclaimer of this code, see http://coresky.net/license
$err = $out = $refresh = '';
$sky->head();
$top_html = '<!doctype html><html><head>' . ob_get_clean();
$top_html .= css(".active {background: #91d0c0 !important}") . '</head><body style="margin-top:0">';
define('zebra', 'return @$i++ % 2 ? \'bgcolor="#eee"\' : "";');
define('button', '<a href="?%2$s" class="admin-btn%3$s">%1$s</a>');
if (!$user->adm_allowed): echo 'Not permited';
elseif (2 == $user->auth):
...
Для сравнения, фреймворк Yii2.
Шаблон проекта ставится одной командой, многофункциональный компонент для работы с пользователями еще одной. После установки все работает. Из коробки есть UI в стиле Bootstrap и механизм управления любыми скриптами и стилями, меню, пагинация, многоязычность и многосайтовость. Проверка доступа находится в контроллерах. Шаблонов страницы можно иметь несколько для разных разделов и менять в рантайме.
Код основного шаблона страницы:
<?php
/* @var $this \yii\web\View */
/* @var $content string */
use yii\helpers\Html;
use yii\bootstrap\Nav;
use yii\bootstrap\NavBar;
use yii\widgets\Breadcrumbs;
use frontend\assets\AppAsset;
use common\widgets\Alert;
AppAsset::register($this);
?>
<?php $this->beginPage() ?>
<!DOCTYPE html>
<html lang="<?= Yii::$app->language ?>">
<head>
<meta charset="<?= Yii::$app->charset ?>">
<meta name="viewport" content="width=device-width, initial-scale=1">
<?= Html::csrfMetaTags() ?>
<title><?= Html::encode($this->title) ?></title>
<?php $this->head() ?>
</head>
<body>
...
Новое и полезное: веб-приложение разрабатывается намного проще легче и быстрее чем в вашем фреймворк…
В современном мире скорость первоначальной разработки во многих случаях не является определяющим фактором при выборе стека технологий. Определяющим всё чаще является скорость внесения изменений при изменении требований, скорость исправления ошибок, скорость добавления новой функциональности, скорость горизонтального масштабирования в конце-концов. Как у вашего решения с этим?
Вы считаете ваши слова адекватные?
Да, я считаю, что мои слова — адекватные.
Я предложил очень много нового
Что конкретно, один пример хотя бы?
Новое и полезное: веб-приложение разрабатывается намного проще легче и быстрее чем в вашем фреймворк… это просто небо и земля…
Вам правда надо перестать гадать на юзерпике. Вы даже не знаете, каким фреймворком я пользуюсь (если вообще пользуюсь каким-то), но уже делаете какие-то утверждения о нем.
Помните, я приводил пример из вашего кода?
if ('delete' == $PVAL):
sql("delete from $me where id=$WVAL");
jump(me);
//...
elseif ('new' == $PVAL || 'edit' == $PVAL):
$new = !$WVAL or is_numeric($WVAL) or die;
Так вот, приличный современный фреймворк позволяет сделать это вот так:
Delete(int id)
_repository.DeleteById(id)
return View()
[AutoValidate]
Edit(User user)
_repository.InsertOrUpdate(user)
return View()
(более того, если становится понятно, что этот бойлерплейт повторяется без изменений, его можно просто выкинуть и заменить на генеричное поведение, другое дело, что в реальной жизни это слишком редкий сценарий)
Никаких if
, никаких магических строк, никаких ручных проверок типа (и вообще ручной валидации).
Это проще, это понятнее, это дешевле в поддержке.
Ваш подход — это не новое. Это из конца девяностых.
Омг омг омг. Начали за здравие, а потом:
> Ядро SKY. это повторно-используемый код для создания веб-сайтов
И это уже не говоря о том, что теперь чтобы сделать быстренько сайт-визитку, тебе надо написать код наивысшего качества, либо взять чей-то уже готовый код и выложить копию уже существующего сайта, слизанного со SKY. Никакого творчества, просто рутина! А через 20 лет уже не останется людей, умеющих писать новый ИДЕАЛЬНЫЙ КОД, т.к. все привыкли копировать весь идеальный код со skynet, и весь веб в будущем (в глазах автора) будет выглядеть как одинаковые странички, с одинаковым фреймворком, решающий одинаковые задачи, и даже возможно с одинаковым оформлением. /сарказм офф.
Судя по всему, у это еще один пост очень молодого, полного энтузиазма человека, бьющего себя в грудь, что изобрел лекарство от рака, и кичащий, что он знает, что надо людям, и убеждает в этом других(в начале осени была похожая тема, где другой автор поднял дикий срач, где он вышел из себя, карма опустилась ниже 50, а потом начались ответы с фейков). Не нужно его в этом винить, я и сам таким был, но надо как можно раньше проснуться и начать думать более реально.
вы не угадали, я старше многих из вас и отвечать вам грубостью на грубость не собираюсь. Если где я и ответил с сарказмом, так просто ради смеха… смешно было.
Простите, если обидел, но прямую грубость в вашу сторону я не выражал.
> вы не угадали, я старше многих из вас
порыв как у молодого бойца. не угадал, что ж
>Простите, если обидел, но прямую грубость в вашу сторону я не выражал.
я имел ввиду не вас конкретно, а любого из комментаторов. Есть некоторые позволяющие себе лишнее.
Но можно условно назвать идеальным код, который проанализирован огромным количеством программистов и активные итерации по совершенствованию которого, не прекращаются никогда.
Автор, по твоему собственному определению код современных фреймворков например laravel идеален. Более тысячи контребьютеров. Изменения вносятся ежедневно. А к тому же используются компоненты над которыми работали еще тысячи. Что ты на это скажешь?
Здесь либо программиста переклинило от того, что у него была куча кода со времен php4 и он не смог пережить его тотальное устаревание. Также я подозреваю, что человек за всю жизнь сделал всего один проект и его название SKY. Если вспомнить свой путь создания нескольких проектов для широкой публики, я могу с уверенностю сказать, что код проекта SKY будет занимать меньше места, чем список хотелок, которых не будет хватать окружающим.
Скажите, вы можете дать вразумительное объяснение, почему чтобы сделать простой запрос к БД, код в вашем framework выглядит так:
$db->$mysql->select( … )
Нет, не можете? а зачем тогда так пишите? Многие, могут поспорить сейчас и попытаться дать объяснение, но после очередных вопросов, они не смогут дать вразумительный ответ или дадут, но после следующих – не смогут.
Я так понимаю, что разработчик не знает про то, что не все используют mysql, sqlite, pgsql, и Query Builder позволяет на выходе получить запрос под конкретную БД с учетом ее особенностей.
Если происходит сабмит формы с 100 полями, то QB позаботится об экранировании данных.
Ах этот лаконичный SQL запрос… когда в нем начинают появляться условия :) Или мы не хотим соблюдать последовательность при проверке условий…
Приведу пример из SugarCRM, когда они пошли по похожему пути https://github.com/butschster/sugarcrm_dev/blob/master/data/SugarBean.php#L2883 Казалось бы, что может быть проще, чем выполнить SQL запрос и зачем только нужен этот Query Builder?!
// Пример высосан из пальца и код упрощен по максимуму
$query = DB::table('users');
if ($groupByTotalLogins) {
// Здесь мы можем не соблюсти последовательность, но на выходе получим валидный SQL
$query->join('logins_history')->....;
$query->groupBy(...);
$query->select(...)
}
if ($joinProfile) $query->join(...);
if (!$withDeleted) $query->where('deleted', 0);
if ($onlyId) $query->select('id');
if (//condition) {
$query->orWhere('field', '>', 10);
}
// Остальные 100 условий
Ну и чистый лаконичный SQL
$table = 'users';
$select = $onlyId ? 'id' : '*';
$where = '';
$groupBy = '';
$orderBy = '';
if ($joinProfile) {
$table .= ' join profile ...';
}
if ($groupByTotalLogins) {
$table .= ' join logins_history ...';
$select .= ' count(logins_history.*) as total_logins';
$groupBy .= '....'
}
if (!$withDeleted) {
$where .= 'deleted = 0';
}
if (//condition) {
$where .= !empty($where) ? ' OR' : ' ';
$where .= ' filed > 10 '
}
if(empty($where)) {
$where .= !empty($where) ? ' AND' : ' ';
$where = '1=1';
}
...
// Вспомним что у where еще могут быть группировки условий...
$query = "select {$select} from {$table} where {$where}";
if(!empty($groupBy)) {
$query .= "group by {$groupBy}";
}
if(!empty($orderBy )) {
$query .= "order by {$orderBy}";
}
В чем смысл приложения, в котором своего функционала всего с гулькин нос и банально он не будет корректно работать со сторонними библиотеками, которые по мнению автора зло, но так необходимы остальным разработчикам, которые ценят свое время и хотят использовать проверенные сообществом решения и покрытые тестами.
Хотелось бы пару строк от автора о том, как расширять ядро не затрагивая при этом сам код?
Подведем итог: с 2012 года автор смог осилить написание около 100 кб устаревшего к настоящему времени кода. Пакет «FORUM.SKY» появится тогда, когда автор сможет уместить идеальный всеохватывающий код в 800 строк. Остальные пакеты появятся тогда же.
Нет… сейчас, вы начнете оправдываться и говорить: я каждый день меняю БД в одном и том же проекте. В основном работает MySQL, а по пятницам, я запускаю сайт на PostgreSQL, QB позволяет мне просто отредактировать конфигурацию приложения.
Я при всем желании не могу понять, здешних комментаторов, похожих на вас, которые просто троллят авторов и получают при этом удовольствие?
>Я так понимаю, что разработчик не знает про то, что не все используют mysql
Вы вправду так думаете? А мне кажется, что вы просто не сообразили, как более тонко потроллить.
Давайте-ка все вместе покритикуем автора… Можно писать что попало. У всех нас цель одна — автор, и те, кто в моем лагере будут лояльны ко мне. Главное устроить вкусный цирк, удовольствие при этом получат все… Ура!!! Вперед в бой…
Я неутомимо буду прояснять ради тех кто читает и думает, но не участвует в цирке. Итак, во-первых, в этой статье четко, русским языком написано, «ORM не нужен, по крайней мере, как базовое средство разработки...». Тоже относится к QB. Только код, который требуется для 70% реальных сайтов в Интернете (потенциально может заменить их код), должен быть включен в «чистое облако». Не базовые средства разработки, могут присутствовать в коде 3 крыла и включаться в проект при необходимости. Последнее касается и QB и ORM.
Если бы вы хоть немного были внимательны, взглянув на код первого крыла http://ru.coresky.net/code?main/sky.php или почитали комментарии, прежде чем спешить участвовать в «цирке», то поняли бы, что файлы в SKY характеризуются свойством «port» и «clear-cloud». Для того, чтобы работать, например с PostgreSQL, нужно просто взять тот-же файл «main/sky.php», который является портом для этой БД.
В статье выше, ясно написано: «В SKY допускается редактирование КПИ, в том числе ядра», а вы пишите: «как расширять ядро не затрагивая при этом сам код?». Вы очень не внимательны.
Странная логика, наваяем QB, чтобы код был красив…
Милейший, вы в моем примере увидели красоту кода? Ну да, код красив, но им также удобно пользоваться! Он избавляет от дублирования кода, он экономит время разработчика.
Для того, чтобы работать, например с PostgreSQL, нужно просто взять тот-же файл «main/sky.php», который является портом для этой БД.
Вы видимо шутите? Т.е. если у вас будет поддержка 10 БД, то ваш проект будет содержать 10 клонов, разница в которых только в SQL запросах? Кто будет за этим следить?
Я так понимаю, что вы нахватались откуда то красивых словечек и умных фраз и решили, что теперь то вы бог программирования, но по факту моя теория о том, что единственный проект, который вы за всю жизнь сделали — это SKY. В противном случае вы бы понимали что даже при создании простейшего сайта для различных заказчиков вы столкнетесь в разными требованиями.
Простейший пример: Один заказчик хочет, чтобы в БД пароли хранились с определенным алгоритмом шифрования, который ваша CMS не поддерживает, второй хочет видеть авторизацию по email, третий хочет полноценной api и SPA с использованием JWT, я так понимаю что в вашей SKY ни один из этих кейсов не реализуем?
Старый без QB не рабочий?
Рабочий, но дорог в поддержке: добавление нового условия (или, хуже того, новой фичи типа пейджинга) будет слишком дорого.
Я неутомимо буду прояснять ради тех кто читает и думает, но не участвует в цирке. Итак, во-первых, в этой статье четко, русским языком написано, «ORM не нужен, по крайней мере, как базовое средство разработки...».
Вы правда думаете, что повторение одного и того же тезиса — это разъяснение? Так я вас расстрою, это не так. Если вы считаете, что ORM не нужен — докажите, что минусы от его применения превышают плюсы от него же (заметим, что действительно есть ситуации, когда ORM не нужен, вопрос только их распространенности).
В SKY допускается редактирование КПИ, в том числе ядра
Вам неоднократно написали: это плохая практика, поведение должно меняться без переписывания ядра.
Это они — путь в болото.
Это как застрявание в текстурах.
Нормальному разработчику фреймворк не нужен.
Небесный путь в PHP