Добрый вечер уважаемые читатели Хабра, Хабровчане, а также все спеллчекеры с личным мнением - мое специализированное почтение.
Перед вами пример Первого Инженерного Действия, а именно пример принятия решения в обстоятельствах неопределенности, с ходом обдумывания дальнейших шагов развития в ситуации с обозначенным топиком - пора валить, куда как, кого, опенсорс, самопис, заказ и тд и тп.
Большинство известных мне случаев при принятии решений характеризуются одним общим показателем - отсутствием письменного размышления при принятии решений.
Те кто приходят к этой практике получают много полезного в своей жизни.
Так как Хабр это текстовый портал, привожу текстовый пример, демонстративный, он имеет основания, шаги, таблички, действия и заключения.
Написан в форме условного диалога, как могло бы происходить коллективное размышление в этой ситуации у заинтересованной стороны и возможного выполнителя этого замысла.
В наличии корректное оформление для уважения читателя, Ноушн пишется с прописной и с курсивом.
Желаю приятного прочтения.
Письменный замысел, промысел
В нашей компании сотрудники для выполнения рабочих задач пользуются зарубежной системой Notion.
Продукт хороший, ребятам нравится, все удобно и понятно.
Проявилась проблема - компания официально уходит из РФ в связи с санкциями. Учитывая что ранее это было стабильно, и никто не ожидал таких событий, все привыкли пользоваться SAAS сервисами для своей работы.
Проявившаяся перспектива лишения доступа к корпоративным данным, как и к управлению ими же, поднимает вопрос о решении возникшей проблемы.
Посовещавшись с людьми, видящими возможные варианты развития событий, мы (руководство компании) коллегиально увидели возможные риски нахождения данных не под контролем нашей компании, а расположенных на серверах любого “вендора”.
Помимо международных рисков компании в РФ также могут закрываться, пропадать, технически они могут терять, а также сливать данные.
Определение потребностей
Задача информационного обмена коллективного знания и фактами о протекающей деятельности компании является ключевой для нас, и было принято решение изучить возможность и целесообразность переезда на собственные решения.
В связи с этим прорабатывались два ключевых вопроса:
Выбор технологического решения opensource.
Разработка собственными силами (нашими или привлеченными специалистами) решения, закрывающего наши ключевые потребности.
Для решения этой задачи мы сформулировали потребности, по принципу “а что ... если нет”, а именно:
Идем по списку функций системы Notion.
Составляем список тех функций, которыми пользуются в нашей компании - те, по которым зафиксированы регулярные информационные обмены.
Сортируем список по убыванию активности.
Добавляем колонку справа от каждой функции и пишем в нее - что случиться в нашей компании с деятельностью если этой функции не будет. (ничего, или такой-то процесс встанет и по цепочке убьет бизнес).
Как мы пользуемся системой сейчас
К нашему удивлению практически из всех заявленных функций системы мы используем только табличные данные, чтобы из них составлять сводные отчетные страницы.
Текстовые блоки мы используем как замену внутренних и внешних электронных документов.
Суммарно мы используем систему как единое место достоверности актуальной информации.
Простота разбиения страниц на блоки позволяет каждому сотруднику держать под контролем свой участок информационного обмена, отвечать за его актуальность, а коллективу использовать в работе его блоки, зная что они всегда будут актуальны.
Такую связанность системы знаний организовать в электронных документах гугл также возможно, но это западная компания раз, два все-таки не так практично постоянно перемещаться по файлам (происходит регулярный разрыв контекста и потеря внимания), нежели по одному веб приложению.
Нужны ли нам канбан доски
Отдельным вопросом мы рассмотрели возможности туду трекеров, а также канбан досок, и пришли к следующему заключению.
Просмотр досок полезен для быстрой ориентировки формата как у нас дела в непосредственной работе. То есть человеку, который сам двигает карточки, а также его коллеге, который в этих карточках задействован уже ознакомлен с ними, в связи с работой по их содержанию.
В этом случае мы действительно подтверждаем, что беглый взгляд на структуру канбан доски быстро фокусирует внимание, и действительно облегчает восприятие.
Но учитывая наше разделение ответственности между командами, не имеет никакого значения для внешнего участника (относительно каждой команды) расположение этих карточек.
Непосвященный в ежедневную деятельность человек может только лишь получить ответ в форме удовлетворения любопытства, что “там” что-то делается. А что конкретно - для этого нужно погружаться, что не входит в его рабочие интересы и временные возможности.
Учитывая что каждый руководитель группы ответственен за результаты своей группы, а управленческую информацию о состоянии и перечне получаемых результатов он предоставляет в виде короткой пофамильно-компонентной таблицы - нами было принято решение о том, что доски могут быть использованы любые на усмотрение и предпочтение команд, и за внешний контур команды они протекать не будут.
Предоставляем командам работать так, как им удобно, а не ограничиваем творческий процесс и удобства, благо досок уже предостаточно и есть очень достойные.
Вопросы развития возможностей
Также была рассмотрена ситуация о возможном развитии системы, каких-либо нужных нам интеграций которые мы сейчас уже можем знать, а также понимание что мы не знаем, какие у нас могут быть интеграции со временем.
Ситуация с ChatGPT показывает, что решение, возможно решающее чьи-то задачи появится во внешней системе только тогда, когда это будет мейнстримом.
К сожалению для системы Ноушн интеграция с нашей учетной системой 1С, а также наших более мелких, но не менее нужных нам потребностей, мейнстримом не стала. Решать это предлагается внешними специалистами, или же интеграциями с такими же внешними сервисами, риск нахождения которых за границами нашей инфраструктуры мы уже обсудили, это не совсем приемлемо.
Также есть интересная особенность, мы не добавили, что иногда мы работаем с закрытым корпоративными клиентами, и нам необходимо подтверждение о целостности нашего информационного контура.
Планы на перспективу работы с Госзаказчиками сейчас не рассматриваются, но в будущем чего только не бывает, кто это может знать.
Определяемся с требованиями
В связи с этим утверждаем, что нам нужны следующие функции:
-
Возможность блочного редактирования текстовой информации, с базовыми WYSIWYG функциями:
Работа с текстом, курсив, жирный, списки, вставка изображений, цитаты, примеры кода, ссылки (может что-то добавим потом, пока достаточно).
-
Работа с таблицами:
Быстрое создание по шаблону и изменение содержания ячеек и колонок прямо по клику как в Ноушне и в экселе.
Возможность настраивать атрибуты свойств как - валюта (пока рубли), текст, выбор из списка вариантов один из или много из.
-
Возможность закрепления информации из других документов в отдельный нужный для работы.
Подкреплять тексты, без возможности редактирования.
-
Подкреплять таблицы, с возможностью фильтрации данных для отображения:
Выбор отображаемых свойств
Сортировки по датам создания и обновления записей
Фильтрации по значениям - подстрока, сравнения больше меньше или равно, по наличию конкретных опций.
Иерархичность документов.
Возможность разделения рабочих пространств.
Наличие учетных записей.
Совместная работа и редактирование.
-
Требования устойчивого развития:
Понятное пространство развития решения с минимизированными зависимостями от внешних обстоятельств.
Гарантированное шифрование хранимой информации, когда в случае кражи самой базы данных, утекла только зашифрованная информация.
Идем двумя путями
В связи с вышеизложенными утверждениями, мы приняли решение о двух направлениях действий:
-
Получить отчет о возможности использования решения opensource, соответствующего указанным требованиям.
Требуемая квалификация специалистов для установки и поддержки эксплуатации.
Возможность доработок и развития (для этого нужно знание и опыт работы с данным решением, если этого знания нет, требуется программа получения этого знания и подтверждения о “взятии” под контроль со сроками)
Узнать возможные пути решения с подтверждением в случае самостоятельной разработки с теми же требованиями к специалистам и возможностей доработок и развития в условиях неизвестности потребностей в будущем.
Принципы выбора путей
По первому пункту мы выделили специалиста для изучения этого вопроса, параллельно запустив задачу Сане, потому что он постоянно имеет мозг и его никак не отпускает на тему самостоятельных разработок из подручных материалов.
По первому вопросу для получения ответов мы поставили задачу на исследование рынка, продолжаем мониторить ситуацию, навскидку необходимо получить сводный отчет по проверенному способу https://deppkind.livejournal.com/4523.html:
Название проекта
Процент матчинга требуемых функций и их наличия в продукте
Сроки получения пробы для работы
Стоимость и условия официального использования, вопросы лицензий.
Возможности развития
Так как простое чтение и ознакомление с материалами занимает время погружения, а также требует анализа, это не может занимать меньше одного рабочего дня, но мы спешим, и поставим на два вопроса получения пробы по одному дню.
Результаты исследования рынка
Так как мы доверяем лучшим, то мы воспользовались вдумчивым рисерчем Кирилла Мокевнина, основателя школы программирования Хекслет. По нашим наблюдениям Notion там используется и в хвост и в гриву, а также проблема санкций и ухода Ноушена коснулась и этих ребят.
Из результатов его исследования мы сделаем для себя вывод, что так или иначе кандидаты есть, но по указанному выше принципу матчинга нет ни у одного решения, даже которое выбрал для себя Кирилл.
Но мы знаем, что Кирилл как и мы, является предпринимателем и уже бизнесменом, а у предпринимателя и бизнесмена выбор простой, не лучшее решение, а наименее худшее из возможных.
Пока мы будем кликать и клацать программы из списка исследования, уже примерно понимая ответ (мы скорее всего выберем что-то из списка и будем фичекатить наши непомерные запросы), но при этом мы подождем что скажет нам Саня с его вымыслами и фантазиями.
Тут пришел ответ о Сани, и он снова начил Гайдить, когда его не просили:
Во 1) я уже прикинул к носу и готов сесть запилить вам демку, все на рубях, фрондендеры снова завоют на болотах.
вовторых выкидывайте на помойку свои списки, что с шифрованием и развитием - вы сразу повисаете на когото, переставляете только кровати в вашем предприятии и ничего нового.
3) проба где? я чтоли буду этим пользоваться? я то могу накатать, но вы это выкините как обычно оклеймив это потоком сознания.
Вот получили вы нечто, дальше что, как тыкать чем и куда, как поймете что это оно? Мож позовете кого? Зовите сразу тогда его ко мне а не вату перекатывайте.
Не загоняйте себя в прокрустово ложе фрактального типа, процитирую себя еще раз:
Если ты не знаешь что ты хочешь (сделать с этим), то любая система тебя удовлетворит.
Если ты не знаешь что ты хочешь (сделать с этим), то никакая система тебя не удовлетворит.
Сначала ваша проба, на нее я дам предметку действий, вот пример https://neolurk.org/wiki/Грабить_корованы
Жду.
Всегда хочется ему как-то указать на его место, но по делу человек говорит - как мы поймем то в итоге?
Давайте формулировать пробу, и то, как мы узнаем что это решение нам подходит, кажись мы поняли что от нас хотят:
Проба:
Допустим я зарегистрируюсь
Создам новый воркспейс
Сделаю три страницы, поперетаскиваю их в меню одну в другую, ок
Переименую и увижу что все обновляется везде как в ноушне
Добавлю текст и сделаю все перечисленные выше редактирования типа курсив, список и тд
-
Загружу прямо в текст файл с десктопа - фотку Сани из Геленджика, ту, что без фингала, в садах которая.
Сделаем эту страницу главной воркспейса
-
Добавим на двух других страницах по таблице
Клиенты с колонками фио, телефон, о да, надо тут комментарии по карточке клиента и поле последний комментарий!!!
Заказы - статус, сумма, номер из 1с, достаточно
-
На главной странице добавим секции
Новые клиенты, отфильтруем по количеству - 5, и отобразим дату создания записи, отсортируем по убыванию даты создания.
Последние заказы, можно фильтрануть по сумме, чтобы интересно было крупняк смотреть, мелкие не надо.
Ну трекер задач и вики не будем пока делать, и так понятно уже если первые пункты ок, тогда будем двигать дальше.
Отправив эту пробу Сане, мы получили во ответ номер заказа, и комментарий:
- завтра вечером выйду на связь, я в другмо городе.
На следующий день получаем ответ:
Я все сделал, в таблице вы найдете перечнь полученного на запрошенное.
Вот ссылка на видос без таймкодов, там 6 с половиной часов, ютуб еле прожевал, вк еще грузит, рутуб и дзен послали лесом.
Комментарий по блоку “Каменты” - они будут, не беспокойтесь, но потом, как решите что ок, это у вас уже пошли фантазии на тему как вам будет удобно работать, типа вы уже получили продукт.
Получите сначала пробу, бойцы.
Справка по требованиям к развитию
Шифрование - вижу вы писали, но не запросили напрямую, но шифрование данных есть из коробки, включается одной строчкой, даже не думайте об этом.
Масштабирование - запускаемся от “на ноутбуке директора” до горизонтального масштабирования, шардинг из коробки.
Хранилище - какое хотите, хоть любая ФС, хоть S3 и если надо свой адаптер напишите (оно вам надо?). Например, если бекенд S3, то его можно скормить в ваш nextcloud и наблюдать загруженные файлы из проги в вашем файлообменнике.
БД - реляционная какая душе угодно, Sqlite, Mysql, Postgresql если скучно, сможете переписать на MongoID.
Пока вы не гоняете миллионы пользователей вам не понадобится даже понимание что там с облаками, тем более что все кто понимает происходящее трезво, уже бегут из них со всех ног, просто берете крепкую железку за копейки и живете счастливо.
Rails это открытый one person framework, поэтому для поддержки вашего решения по вашим потребностям будет достаточно одного вчерашнего студента Бауманки с горящими глазами, ну или любого прошедшего курсы у того же Кирилла на хекслете.
На демо видно что просто автоматом генерируются ресурсные API, сделать нужные расширения для скормки в сервисы, которые работают по апи - 10 минут.
Написать приемник веб хука для получения такого же добра из других систем - 10 минут.
Покрыть тестами - ну 20 минут если совсем не понятно что продемонстрировано в рамках процедуры scaffold.
Вам ехать или шашечки
В общем, если вам ехать а не шашечки, вот вам решение, напишите что готовы брать я выставлю счет, оплачиваете и получаете:
Чистый от мусора код с комментариями, где это уместно
Причесанный по модулям, то что надо куда-то вынести - будет вынесено.
Покрытый тестами согласно полученному на запрошенное - чтобы вы имели инструмент проверки целостности передаваемого и приобретаемого, не только с моих слов и видеороликов.
Подготовленный для, и задеплоеный к вам, на ваш vps проект.
А я пока закину видос на хабр, слегка напишу о чем речь.
Миллиард лет не писал туда, вот там ребятам понравится, наконец-то у меня есть что-то не переводилкино-капитаноочевидное а прямо поделка, как там и любили в лучшие годы, может даже хабраэффект получу, уух кайф как интересно.
Там же все адекватные и дружелюбные ребята, а не какие-то чудаки на букву М.
Саша интересный человек, пожелаем ему удачи в его фантазиях.
Выводы и выбор
Ну а у нас простой выбор мы имеем пруф системы отвечающей нашим первоначальным требованиям.
Проба готова для следующего шага. Вопрос по выбору SAAS отложим на потом, когда по текущей разработке мы потерпим фиаско.
Мы решаем что неделю на это инвестировать мы еще можем, нам все понятно.
Мы понимаем что разработчиков на любой запах и цвет мы всегда найдем, нам все нравится, стилизация дело наживное, видно что базовые запросы рабочие, все шустро, в общем мы берем, и попробуем переводить новые дела в эту систему.
А по старым, выгрузим, надо спросить будет у Сани че там по импорту, ну это уже потом, может и не понадобится, это мы громко заявляем что у нас системы такие, а так-то на вскидку наш стажер за два дня руками три раза все перекопипастит, сколько у нас там страниц всего - 50?
Да, пусть топчет клаву, дадим ему бонус за инициативность, пора заканчиваем с этим, я уже устал генерировать эту историю.
Комментарии (8)
shsv382
04.09.2024 11:02+1Для меня главное раздумье, связанное с Notion, и чего в полной мере не даёт Obsidian (даёт, но с костылями) - это то, что у меня в Notion лежат учебные материалы, которые я подготовил для своих студентов и расшарил им из Notion по веб-доступу. Теперь стою перед выбором:
Obsidian - можно расшарить, но вопрос со стилизацией страниц, а также это реализовано через их сервера, которые точно также могут "уйти из России"
Выложить всё статьями на хабр - и словить кучу говна а-ля "про это уже 100500 статей написано, нафиг ты опять пишешь, и вообще у тебя всё не так!"
Самописное решение на VPS, которое будет из markdown делать HTML, скорее всего на этом остановлюсь, так как вижу в этом много плюсов
apavlyut Автор
04.09.2024 11:02В вашем случае только третий пункт, я все свои материалы храню маркдауном, появляются на нулевой стадии они только в текстовых редакторах.
Все ноушны и обсидианы это уже следующий шаг творческого развития, но исходники должны быть под гитом в текстовом виде, а это маркдаун.Все будет менятся и всегда, но вопрос что вы контролируете находится в ваших руках.
VPS для этих целей стоит 250р в месяц.
Rampages
04.09.2024 11:02+1Если вместо markdown подойдет LaTeX, то можете поднять локально Overleaf/overleaf: A web-based collaborative LaTeX editor (github.com)
Вообще с точки зрения написания статей LaTeX наверное самый любимый инструмент, в нем можно описать любые формулы, сноски, ссылки и все это текстом.
clerik_r
У вас опечатка, не MongoID, а MongoDB
apavlyut Автор
MongoID библиотека для работы с монгой на Ruby
clerik_r
Просто в контексте этого пункта речь шла именно о самих базах, а не о библиотеках для работы с ними
apavlyut Автор
Там ссылка на в контексте адаптеров для этих баз данных в самой рельсе. И помимо условно стантартных можно взять и нестандартные вроде MongoID.
В пункте идет речь о возможности применения данных баз в приложении из коробки в рамках этой технологии.