Мой основной проект — это платформа для конструирования веб-приложений для автоматизации процессов: база данных, действия, триггеры, интерфейс. Но пока я её разрабатывал, сделал множество готовых решений автоматизации под конкретные задачи. И почти везде встречалась одна и та же история: проект застревал где-то посередине, и дальше требовались какие-то невероятные усилия, чтобы довести его до завершения. По факту эти усилия ложились на меня.

В конце концов я пришёл к выводу, что лучше бы их вообще не брать. Но если уж ввязался — то только на следующих условиях (которые в последние несколько проектов спасли мне миллиарды нервных клеток).

Может, это я плохой сервис оказывал клиентами, что так все плохо?

Ну не совсем так, скорее даже наоборот. Когда заказчик знает, что вы — и разработчик платформы, и общаетесь с ним не через прослойку из десяти менеджеров, а напрямую, — это создаёт некоторое измерение безумия: ночью что-то приснилось, и утром в восьми случаях из десяти с нас требовали, чтобы вот непременно именно в платформе поменяли всё вверх-ногами, потому что «вот так надо». Особенно это было интересно, когда два заказчика на разных проектах, идущих параллельно, требовали изменить стандартное поведение в противоположные стороны. Но это оставим в стороне — про это рассказывал здесь: https://habr.com/ru/companies/totum_online/articles/972596/

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

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

И одно из сильно отличающихся измерений — это сам факт сдельной оплаты

Недавно тут была статья (потерял ссылку) со статистикой судебных дел в диапазоне 1–3 млн ₽. Вот там проекты автоматизации — самые ужасные: за них, помимо того что не платят, когда они сделаны, так ещё и часто требуют вернуть деньги.

В чем проблема оплаты на подряде?

В том, что заказчику как-то не очень заходит оплачивать штуку, которая не решает его задачу (и если может не заплатить, то и не платит).

А как так может быть, что автоматизация не решает задачу, если всё сделано, как он просил, и даже лучше — ведь мы выяснили проблемы и нестыковки и сразу их порешили?

А вот как:

Он заказывает автоматизацию, рассчитывая решить проблему, которая не решается автоматизацией!

Из нашего опыта такие были случаи:

  • Система должна ликвидировать незаменимость одного из сотрудников, и данные в систему должен вводить этот же сотрудник… ну всё, приехали.

  • То же самое применительно к отделу — система автоматически выполняет работу, которую выполняет отдел из трёх человек за один вечер, и внедрение поручается… тадам! — этому же отделу!

  • Система должна решить проблему планирования и расчёта сроков (что нарушает интересы одного из начальников), но для этого в систему должны быть внесены корректные нормировочные данные (расчёт которых задерживается уже в течение Х лет), и эти данные должен предоставить… этот самый отдел!

Система предоставит данные, но дальше всё равно требуется действие в физическом мире — и это действие не совершается уже Х лет

Похоже на абонемент в спортзал: система разрабатывается, ожидая, что её наличие простимулирует выполнение этого действия. Пример — выложенная система поиска более выгодных предложений по загруженным счётам (описание здесь: https://habr.com/ru/companies/totum_online/articles/976542/). И тут даже если отделу закупок на ногу не наступает (его нет), то всё равно надо что-то менять — а не хочется (хотя пользователи есть, но используют систему для чего-то другого).

Решили приделать финтифлюшку к процессу, который и так работает

Учёт чего-то ведётся в Excel, и там уже пять лет всё в порядке: да, есть ошибки, но они ни на что не влияют и последствий не имеют. Или, например, вручную считается количество чего-то для определения качества. И тут решают сделать это очень модно — чтобы фотоаппарат сам что-то фотографировал, нейросеть считала. Но потом, правда, всё равно пересчитают для проверки.

Даже если пересчитывать не будут, установка образца, например, для пересчёта и фотографирования всё равно осуществляется вручную (робота Ф. ещё не завезли), и время установки образца занимает 80% всего процесса. Эта автоматизация просто не заработает ни при каких обстоятельствах.

Просто решили сделать бесполезную штуку

Я не знаю почему, но особенно это к заводским цехам применимо — лампочка или табло, которое светится над станком и что-то там показывает через весь цех в будку начальника смены, — это прямо какой-то фетиш. Особенно её хотят те, у кого на станках нет такой заводской. Откорректировать при этом таблицы расчёта времени они обычно не хотят — это обратно пропорционально желанию иметь мигающую лампочку. У тех, у кого японцы такую поставили, всё уже мигает, и это ничего не поменяло — они как-то более расслаблены в этом направлении.

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

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

Заказали большую систему из 10 модулей, а реальную проблему решил уже первый — и дальше ничего не надо

Но контракт-то был подписан на 10, а мотивация подупала.

Система вообще должна всё-превсё изменить, но только она одна — и магическим образом, без участия сотрудников, то есть изменить самих сотрудников

Это вообще классика — таблетка белая, чтобы вылечиться. Заказало руководство, всё даже сделали и даже запустили (сотрудники не дураки ведь — начальство хочет, чтобы что-то изобразили, вот и изобразили; время на это обычно есть свободное), и она там как-то параллельно в виде ИБД существует. Для подрядчика вообще неплохой вариант.

Как получается зомби-система?

Приступили мы к разработке вот этого всего. И да, предварительная оценка же не решает всех этих проблем, если нам надо взять заказ в разработку.

Если есть возможность отказаться (как у чуваков, которые у нас все разбежались), то это самый лучший вариант. А что если надо за что-то взять денег? Или, например, заказчик клянётся, что всё понял и порешает в процессе (ага, порешает — я ни разу не видел, чтобы порешал)?

Дальше мы как подрядчик делаем какую-то часть проекта, обычно до того момента, когда все понимают, что травка пузик не щекочет (такой момент рано или поздно наступает), — и тут начинается:

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

  • Бесконечные правочки, затягивающие всё в бесконечность.

  • Просто неоплата.

  • Игнорирование (иногда какими-то непонятными импульсами всё это движется).

  • Требование денег обратно.

  • В нашем случае — ещё и требования изменить платформу.

Неважно, из каких психологических причин это получается — ведь статья не про психологию, а про бабки и время, потраченное на фигню.

Далее — система, которая меня очень выручала, чтобы спокойно выезжать из всего этого

Ключевая подсказка, как с этим всем быть: заказчик на самом деле в глубине души всё понимает — как дела обстоят на самом деле, — и нанимать человека на зарплату (пусть даже и на временный проект) он обычно не хочет. Кто хочет — тот так и делает, и у них всё успешно: они потом годами покупают у нас лицензии, и у них всё хорошо. А если есть глубокие внутренние сомнения — то подрядчик то выгоднее (он же клиентоориентирован и мы его можем немножечко поэксплуатировать в серой зоне договоренностей, которые в сложном проекте с небольшим бюджетом есть всегда).

Выход отсюда — time-and-material, но для сложных проектов временные рамки никто не отменял. Если два дня делаем, потом полгода пауза, а потом снова срочно два дня — так в итоге ничего не получится.

Поэтому для нашего среднего чека 800К–1,5М выработали такую схему:

Здесь ещё раз оговорюсь, что всё это выработано для случая, когда нет армии менеджеров, юристов и бухгалтеров, которые могут тратить своё рабочее время на выяснение, что там не так с требованиями заказчика, — а мне самому это ещё и глубоко неинтересно.

И всё это заточено на то, чтобы завершить проект с теми, кто реально хочет его завершить, и быстро расстаться с теми, кто на старте летал в своих фантазиях. Не работает, если ваша задача — вытрясти деньги любой ценой, в том числе и из вторых.

Итак погнали:

  • Делаем некоторый предварительный скоринг (1–2 встречи по 2 часа) — бесплатно. Это не финальное ТЗ (его не будет, оно бесполезно) — это чтобы понять, что хотят сделать и где всё это зафейлится.

  • Если есть ключевой технологический элемент, в котором мы сами не уверены (например, скрипт, который будет считывать параметры чертежа из .dxf), — делаем предварительно с затратами не более 10 часов без предоплаты (сейчас с вайб-кодингом это стало сильно проще и возможностей больше), но это время учитывается далее в случае заключения договора.

  • По результатам при заключении договора на разработку составляется условная схема проекта с модулями, которые в нём должны быть, и описаниями функционала — максимум по одному абзацу на каждый.

    1. Ключевое — это взаимосвязи модулей и последовательность их разработки.

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

    3. Порядок, в котором они будут разрабатываться: мы стремились дойти до точки фейла как можно раньше (желательно в первые две итерации).

    4. Условие, что по ключевым моментам будут специальные акты-подтверждения — без них продолжение невозможно, и отдельных сроков на них не устанавливается; предполагается, что заказчик ведёт подготовку критических данных параллельно.

  • Закрепляется стоимость часа от общего объёма проекта, но с условием, что она будет пересмотрена для последующих работ, если заказчик нарушит сроки оплаты.

  • Предмет договора: часы работы, затраченные на разработку описанного проекта, — в обмен на оплату.

  • Закрепляется объём часов, который мы как подрядчик обязаны тратить на проект в месяц (не менее Х часов). Отсюда получается плюс-минус срок готовности, но никакие конкретные даты не прописываются — если есть дата, она станет инструментом давления (неважно, чьего). Также никакой ориентировочной конечной цифры по часам или сумме — ни при каких обстоятельствах! Только устно, с 100500 оговорками, и не про этот проект, а: «похожие проекты имели показатели Y». Плюс обсуждение того, что миллион у вас должен быть выделен на первый период.

  • Закрепляется объём времени, который заказчик обязан выделить ответственным сотрудникам на созвоны — обычно до 4 часов в неделю (хотя на практике это может быть и меньше; встречи проводятся по нашей необходимости).

  • Закрепляется объём итерации, обычно это 150–200 тыс. руб. — её оплачивают.

  • Разработка ведётся на сервере заказчика, чтобы не было потом вопросов с передачей. Можно контролировать в режиме реального времени.

  • За неделю предоставляется отчёт с часами и акт. По акту — возражения по объёму выполненной работы в течение недели или подписание. Нет подписания — значит, проект останавливается. Здесь важно железно не продолжать, если у вас уже два неподписанных акта. Если неподписано два — значит, можно не подписывать вообще ничего, и тогда всё это теряет смысл.

  • Когда исчерпан весь предоплаченный объём, заказчик обязан оплатить следующий в течение недели. Не оплатил — пауза до трёх недель. Не оплатил в течение месяца — неважно, что он говорит, но в договоре должно быть указано, что после такой паузы возобновление работ после оплаты осуществляется не сразу, а в течение двух-трёх месяцев (ушли делать другой проект).

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

  • Оплатил, даже подписал все акты, но застрял на внесении данных — и проект стоит. То же самое: три месяца — и есть возможность вернуть неизрасходованную часть и расторгнуть договор. Сначала подписывают соглашение о расторжении, а потом возвращаются деньги.

  • Когда дошли до первого фейл-момента и становится понятно, что заказчик его руинит (например, не вносит или не корректирует зависящие от него критические данные), но при этом требует продолжения работ, — обязательно подписать акт о том, что он не выполнил этот ключевой момент. Называть его «соглашение об отказе» ни в коем случае нельзя — он ведь не отказывается; он просто говорит, что сделают потом (никогда) или отмалчивается. Назвать его надо, например, «акт о пуско-наладочных работах» или как-то в таком духе — и прямо прописать, что заказчик реально сделал: «внесение/корректировка данных позиций — 3 из 30 000». Это позволяет избежать конфликта, а также даёт тому, кто платит деньги, чёткое понимание, что потом их истребовать обратно будет сильно сложнее — и лучше сразу сливаться.

Соответствующая законодательству схема, но важно не забивать на акты!

С госами не работает — там другая кухня.

ЭДО позволяет быстро обмениваться документами.

Никто ни с кем не разбирается и не «лечит» — все просто: «Вот, подпишите акт». Акт не подписан — проект на паузе, так как акт не подписан. Не оплачено — проект на паузе из-за задержки оплаты. Не оплачено два месяца — уведомляем: в случае просрочки три месяца у нас есть возможность одностороннего расторжения договора. Ничего личного — просто автоматическое уведомление (оно само, как и расторжение: мы просто автоматически расторгаем для поддержания порядка в документах).

Когда вы и разрабатываете, и ведёте переговоры, и потом взыскиваете дебиторку — всё это очень экономит время (надеюсь вам поможет).

В конце напомню, что мы делаем платформу для проектов учёта всякого нестандартного на производствах и не только — и у неё даже есть небольшой фримиум для пет-проектиков.

Посмотреть можно здесь: https://ru.totum.online

Комментарии (19)


  1. sergey2212
    24.01.2026 17:00

    Да весело там у вас. Ну хорошо что нашли рабочее решение. Действительно с кодом разобраться легче чем с людьми. Я думаю вы не одни такие кто сталкивается с похожими проблемами. Спасибо за ваш опыт


  1. Akon32
    24.01.2026 17:00

    Интересный метод.

    И что, заказчики соглашаются? Какие впечатления о таких проектах у заказчиков и у вас? В моём понимании, заказчику нужен результат, а у вас результат в договоре не прописан. (некоторым редкостным заказчикам, однако, результат не важен, а важно именно "поскандалить", но вряд ли хорошая идея иметь дело с такими)


    1. AlexeyPolunin Автор
      24.01.2026 17:00

      В сложных проектах результат зависит также от заказчика, как и от подрядчика. Поэтому когда мы прописываем в договор результат, зависящий от заказчика — ну все, его больше чем в половине случаев не будет (что и видно во всякой разной статистике). Но вообще в таких небольших бюджетах никому не рекомендую брать сложные проекты на разработку — бизнес из этого не получается. Отчасти потому, что определить за короткий срок первоначального обсуждения проекта, что там на самом деле творится у заказчика — нереально. Там все будут очень внимательны и заинтересованы до момента, когда разрабатываемая система начнет реально наступать им на ноги, и где это — дистанционно понять невозможно. Становится понятно через пару месяцев и дальше происходит попадание в инферно. Для того, что бы терпеть его жар и нужны манагеры, ропы, юристы и бухгалтера, что бы можно было организовать там комиссии по заинтересованости и как-то отгородится. Но если у кого-то всей этой ватаги нет, то либо как описано выше, либо проекты максимум до 100 тр за раз и очень важный навык — выключение телефона и игнор (пользоваться придется часто), либо еще можно согласится, что реальная эффективная ставка будет типа 500-600 р./час с квалификацией с которой можно в Сбере чилить с окладом 400К и смузи. Поэтому не получилось у нас сформировать базу подрядчиков, которые бы на заказ проекты делали — там просто никто не выживает, нужно либо сложность проекта меньше раза в 3, либо бюджет больше раз в 5, а такого нет. А когда сами для себя внутри делают — все ок, работает.


      1. Akon32
        24.01.2026 17:00

        А когда сами для себя внутри делают — все ок, работает.

        Выглядит как критический недостаток аутсорса вообще. Ну, и пару раз я слышал, что большие компании в рамках импортозамещения некоторых больших информационных систем решили не покупать российские продукты, а пилить своё. Как-то это нелогично всё. Может в то время было модно пытаться в ИТ, а может просто не доверяли вендорам.


        1. AlexeyPolunin Автор
          24.01.2026 17:00

          Я сейчас придерживаюсь того мнения, что если есть ресурсы и проект большой — 100% делать внутри. Могут быть отдельные технологии внешние, но именно как вещи в себе, а вот эту всю систему взаимосвязей надо генерить внутри, так как любой аутсорс создает адские издержки на коммуникацию — просто кошмарные. нет ничего такого в SAP, что нельзя собрать внутри за разумные сроки и собрать при этом именно так, как нужно. IT-система — это управленческая задача во всех смыслах, успешны те, кто это понял.


  1. eatmeat
    24.01.2026 17:00

    Я идти за тобой. Ты зришь в корень.


  1. stan1901
    24.01.2026 17:00

    Больше 10 лет был в заказной разработке, соглашусь с написанным. Основные пререквизиты успешного завершения разработки: наличие очень заинтересованного лица на стороне заказчика, или деление работы на этапы с чёткими временными и функциональными границами. Лучше и то, и другое. Заказчик может отказаться, но тогда лучше вообще не влезать в проект, чем выходить из него с минусом. Если не нравится - T&M вам в помощь с двойными ставками за работу в нерабочее время.


    1. babysas
      24.01.2026 17:00

      Дополню "наличие очень заинтересованного лица, с полномочиями и бюджетами, подтвердить свою заинтересованность"


  1. Ra3wum
    24.01.2026 17:00

    Много раз сталкивался с зомби-проектами в плане разработок железа и аппаратно-программных систем. Изложенный подход вполне логичен и использовался мной в том или ином виде. Главным звоночком чтобы не связываться всегда выступает нежелание "заказчика" (именно так, в кавычках) сформировать в начале разработки внятное техническое задание. Причём именно с этапами, хотя-бы приблизительной трудоёмкостью и стоимостью работ. Все же прекрасно понимают, что отсутствие ТЗ -- всегда соблазн на лету менять хотелки и затягивать проект до бесконечности. А если и оплата оговорена по факту, а не в процессе по этапам, то это явный признак налюбилова.


    1. AlexeyPolunin Автор
      24.01.2026 17:00

      Дело в том, что не всегда на старте понятно, что же там надо сделать и заказчику в том числе. Это не проблема — проблема именно в том, что подряд предполагает (и заказчик часто именно так и хочет), что бы затраты на поиск правильной комбинации были переложены на подрядчика. Те эксперементирует заказчик (меняя требования), а выгребать из этого должен подрядчик. Заказчик при этом может быть вполне нормальный, но вот он исходит из того, что я же не разбираюсь в вопросе — мне нужна поэтому конечная стоимость, иначе это будет проект с бесконечными затратами. Какой здесь вывод можно сгенерить — заказчик должен обладать квалификацией сам, что бы заказывать сложное что-то. А если там чуваки «да мы тут не понимаем, это вы специалист» — от таких сразу бежать надо с третьей космической — вот это всегда фейл.


      1. beskov
        24.01.2026 17:00

        проблема именно в том, что подряд предполагает (и заказчик часто именно так и хочет), что бы затраты на поиск правильной комбинации были переложены на подрядчика

        это можно частично решать тем, чтобы выстраивать с заказчиком работу по проведению им же прагматичного минимального бизнес-анализа, хотя бы через чек-листы вида:

        □ Да / □ Нет — Цель проекта сформулирована через решение проблемы, а не как задача в воздухе (не «внедрить CRM», а «сократить цикл/ошибки/затраты»).

        □ Да / □ Нет — Есть 1–3 измеримых KPI успеха: baseline → target → срок (и источник данных).

        □ Да / □ Нет — Расчетные эффекты существенны для заказчика — ROI превышает ROI других возможных инициатив по автоматизации заказчика.

        □ Да / □ Нет — Проведены натурные эксперименты, показывающие достижимость целевых эффектов.

        и т.д.


        1. AlexeyPolunin Автор
          24.01.2026 17:00

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


      1. Ra3wum
        24.01.2026 17:00

        Проработать ТЗ самому, это единственная работа, которую есть смысл сделать бесплатно. И поставить заказчика перед фактическим план-графиком с затратами по этапам, презентации с обоснованием стоимости отдельных этапов. Утвердить данный план и тогда уже приниматься за проект. И обязательно предусмотреть аванс. В таком случае 99% несерьёзных заказчиков отсеятся. Потому как у большинства зомби-проектов принцип один: завлечь разрабов пообещав золотые горы и интересную работу, попилить под эту разработку деньги спонсора (если он есть) и воспользоваться результатами проекта с минимальными или нулевыми выплатами исполнителям.


  1. Cordekk
    24.01.2026 17:00

    обычно до того момента, когда все понимают, что травка пузик не щекочет

    надо бы запомнить...
    а вообще у меня есть опыт вот такого "исполнителя", который научился на "платформе" что-то делать, а потом пытается заработать. Платформа конечно не ваша.
    И могу сказать, что это заказчики разбегаются, когда им начинаешь задавать правильные вопросы, или озвучиваешь стоимость доработок, но подозреваю, что они могут идти обратно к разработчику платформы с просьбами поменять стандартные компоненты или добавить какие-то модули.


    1. AlexeyPolunin Автор
      24.01.2026 17:00

      Да, есть чуваки (их много) которые предполагают, что если платформа стоит там условно тыщу рублей в месяц, то и месяц работы по проекту ну не дороже 10 тр., да и вообще как-то само должно. Такие отсеиваютсяяв другую сторону.


      1. Cordekk
        24.01.2026 17:00

        ну да, бывают запросы, когда говоришь, что требуется большая доработка, потому что стандартные компоненты не заточены под это дело, ну а люди явно ожидали, что ценник будет тысяч 10. Хотя если посчитать по трудозатратам, то только разговор с выяснением деталей и уточнением ТЗ можно оценить в 2-5 т.р.


        1. AlexeyPolunin Автор
          24.01.2026 17:00

          согласен, тыщ 10 — это прям золотой стандарт :)


  1. THEOILMAN
    24.01.2026 17:00

    Разработка ведётся на сервере заказчика

    А если это возможно только находясь физически сев стулом на КСПД ? Отказ? Оттуда может не быть доступа к условным зарубежным сервисам.


    1. AlexeyPolunin Автор
      24.01.2026 17:00

      Я бы предусмотрел передачу каждую неделю или раз в две недели.