Разборки айтишников на непонятном для нас, простых смертных, языке (c)

У вас тут явно фундаментальные проблемы с безопасностью. У вас про Threat Analysis, SAST/DAST/SIEM, security champion roles и т.п. не слышали? Удобно конечно повесть всех собак на последнего индуса (в данном случае я их не выгораживаю, там много балбесов).

Но знаете, чтоб авиация стала безопасна, нужно все сто тысяч компонентов правильно дизайнить from ground up. Так же и здесь.

Это не проблема разработчика.

В гихабе есть Secret scanning with push protection: если секрет обнаружен прямо во время git push, GitHub блокирует пуш и показывает ошибку. Чтобы пропустить, разработчик должен либо убрать секрет, либо явно подтвердить, что это не секрет.

Причёт тут Гитхаб, он про секреты в логах пишет. Эту глупость делает конкретная строка в коде, которая отслеживается средствами SAST, независимо от глупости девелопера. Если всё-таки пропустили - тогда включается уровень SIEM, при правильной настройке она отлавливает в логах и алертит. Ну и в принципе, long lived credentials уже не кошерно, пора на динамические переходить (JWT, OIDC…) стильно-модно-молодёжно. На процессуальном уровне прогонять девелоперов через хотя бы базовые секьюрити тренинги, и бить по башке за не сданные тесты после них.

Это называется Swiss Cheese Principle, multi layer defense.

Секреты в репозиториях GitHub это вобще дно.

Еще можно DAST прикрутить, но не мой профиль.

До этого так же был разговор что у него в компании пушат секреты в репо.

А ну это полный флеш-рояль! На лицо проблема системы, а не отдельных индусов.

Но да, систему, возможно, индусы и строили…

Ну дак а кто ее строил еще. Все хранилось в гитлабе в environment variables типа aws_secret_dev, aws_secret_prod и так далее. Потом они получали эти секреты, присваивали в конфиг объект и печатали его в логи. Хотя в гитлабе можно настроить чтобы в зависимости от окружения нужный ключ выдавался, но они этого не знали видимо. Сейчас сделали и авторотейшн и никто кроме самого гитлаба не может их получить. Даже я их не знаю.

Ну это уже в рамках best practices. Можно пойти дальше и прикрутить внешний secrets manager типа Vault, это будет совсем красота. Дорого и сложно, но максимально гибко.

Я, когда пришел в свою контору самообучившимся зелёным новичком, то в ней было всего пара индусов, которые говорили на разных языках и исповедывали разные религии. Но это не помешало мне в течение первых полгода указать своей команде (где все в основном местные), что у них все логины и пароли пользователей в продакшине логятся на стороннем сервисе DataDog. Нашел API ключи там же в логах, в сценариях, когда запрос фэйлился, а это происходило каждый второй раз. Увидел в настройках сервера, что весь бандл кода веб-приложения отправляется единым 3-мегабайтным куском без какой-либо компрессии. Я всё это починил, настроил сервер, разбил код на чанки. Сказал об этом команде, они - окей. Уже 4-й год жду хоть единого бонуса, хоть единого повышения самой маленькой в команде зарплаты. А контора - 100% американская, одна из крупнейших в США

А да, забыл, там ещё в логи шла вся информация при регистрации новых пользователей, включая последние 5 цифр SSN.

А вот если накосячил бы то тут же бы сделалили ататай. Инициатива “любит” инициатора, в больших американских конторах это четко работает.

2 лайка

Кстати, к вопросу, к чему это привело. Я имею в виду, что мне даже спасибо не сказали. Теперь я, когда вижу, что кто-то из команды стреляет себе в ногу, я просто жду момента, когда можно идти за порцией поп-корна. Я молча беру, не споря, и прикручиваю два аналогичных запроса, каждый из которых обращается к одному и тому же ресурсу с целью чисто получения данных, но один из них GET, а другой POST. Я молчу, потому что знаю, что им не ведомо, как посылать параметры в GET запросах. Короче, там вот такой уровень. Если укажешь на что-то подобное, то тебе сначала огрызнутся, потом позже втихую исправят. Нет, я лучше буду с берега смотреть, как корабль тонет.

1 лайк

А зачем посылать параметры в GET запросах?? Чтобы они были видны в URL? ??:roll_eyes: Конфиденциальные данные передают в POST-запросах.

1 лайк

Здравствуй, жопа, Новый год. И эти люди отучают нас ковырятся в носу (с)

2 лайка

Любителю рофликов: :sweat_smile: :woman_facepalming:

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

Глупо беседовать с теми, кто не “шарит” в теме как ты, но все время в нее лезет. :rofl: Постоянно “мимо кассы”, но лезешь в предметную область. Позоришься, эникейщик.

Забавно, ты похоже даже и не понимаешь глубину своей некомпетентности.

3 лайка

Эникейщикам слишком далеко до уровня программиста, им не понять. Поэтому все, что они не понимают им мерещится как “некомпетентность”. :rofl:

Я тебе серьезно говорю, держись за свое место мертвой хваткой. У нас даже джуны не позволяли себе такие гупости говорить на собеседовании.

1 лайк

Вот тут всё и встало на свои места. Что же нынче творится с индустрией :man_facepalming:

1 лайк

На места встало то, почему Вас не только не повышают, но даже СПАСИБО не говорят. Закономерно. Самоучка, не удивительно, базы -то нет.

P.S. Меня повышают ежегодно. И благодарят за работу.