Хотите расти как разработчик и найти крутую работу? Не протирайте штаны — займитесь Open Source проектами. Так легче всего попасть в лучшие команды разработчиков и положить себе в резюме настоящий проект, вместо нелепых «примеров кода». Но найти подходящий проект для участия сложно. Начинаются лень и отговорки, а за ними — отсутствие профессионального роста, критики по-настоящему крутых программистов, уныние и застой.
На Cult of Martians мы собираем интересные задачи для современных веб-программистов. Можно выбрать подходящую по сложности, продолжительности и специализации. Задачи не выдуманы «из воздуха» — каждая решает насущную проблему, и решить ее можно через создание нового Open Source проекта или улучшение существующего. Решайте задачи, прокачивайтесь, присылайте решение на оценку. Лучших могут пригласить к себе на работу компании, программистам которых понравится ваше решен ие.
Для уверенных в себе, задача на пару недель
Logux Server по WebSocket получает набор операций от клиента, и для каждой операции вызывает callback, переданный разработчиком.
Сейчас обработка всех операций идет паралелльно. Но часто операции связаны: например, сначала может быть операция создания пользователя, а потом — операция смены прав у этого же пользователя. При паралелльной обработке операция смены прав может не найти пользователя, так как операция его создания идет паралелльно.
Нужно добавить последовательную обработку операций в виде очереди.
Задача сложная — требует изменить несколько проектов и хорошо продумать все необычные сценарии.
Польза: получить open source портфолио на Node.js.
inMap
и inFilter
добавлять action в лог, а сначала обрабатывать их где-то в очереди. Например, можно добавить callback onActions
, и заставить разработчика самого добавлять action в лог. Узел должен отправлять synced
сразу как action’ы будут отправлены в onActions
, а не когда они будут добавлены.access()
и process()
последовательно для всех полученных action’ов.Server#type()
опциональный ключ queue
, чтобы разные action’ы все же можно было обрабатывать паралелльно.