Ssylka

Как перенести Go-модуль в Open Source, не потеряв авторство?

Для переноса части Go-проекта в открытый доступ с сохранением истории и авторства, сначала необходимо выделить нужный пакет, используя git filter-branch. Это позволит оставить только историю изменений этого пакета. Далее следует отредактировать сообщения коммитов, удаляя корпоративные префиксы и номера тикетов, а также заменить корпоративные email-адреса и имена авторов на профили GitHub, что можно сделать через git filter-branch --env-filter.
Как перенести Go-модуль в Open Source, не потеряв авторство?
Изображение носит иллюстративный характер

Критически важно убрать всю специфическую и конфиденциальную информацию из кода, используя git grep для поиска и git rebase -i для редактирования коммитов, где такая информация была первоначально добавлена. Также необходимо исключить ненужные файлы из истории с помощью git filter-branch --index-filter, чтобы не оставлять в открытом репозитории лишних следов. После всех изменений нужно проверить корректность кода и актуальность путей.

После подготовки кода, необходимо создать новый репозиторий на GitHub и добавить в него перенесенный пакет. Затем следует оформить новый проект, добавив README, бейджи, лицензию, workflow, релизы и запросив публикацию документации на , а также опционально настроить безопасность.

В заключение, исходный пакет можно удалить из старого проекта и установить как внешнюю зависимость через go get. При этом следует не забыть добавить зависимость в go.mod и vendor/. Открытие исходного кода позволяет сообществу улучшать проект, выявлять ошибки и повышать доверие к инструменту.


Новое на сайте

19150Иранская группировка RedKitten применяет сгенерированный нейросетями код для кибершпионажа 19149Как новая волна голосового фишинга в стиле ShinyHunters обходит многофакторную... 19148Почему баски стали главными пастухами Америки: врожденный дар или расовый миф? 19147Бывший инженер Google осужден за экономический шпионаж и передачу секретов искусственного... 19146Насколько критичны новые уязвимости SmarterMail и почему их немедленное исправление... 19145Истинный контроль и природа человеческого мастерства: от учения эпиктета до современной... 19144Критические уязвимости нулевого дня в Ivanti EPMM активно эксплуатируются злоумышленниками 19143Почему биология и социальное давление толкают элиту на смертельный риск ради славы и... 19142Почему сотни энергетических объектов по всему миру остаются критически уязвимыми перед... 19141Возможен ли бесконечный полет дронов благодаря новой системе лазерной подзарядки? 19140Химический анализ впервые подтвердил использование человеческих экскрементов в римской... 19139Как искусственный интеллект AnomalyMatch всего за два дня обнаружил 1300 неизвестных... 19138Какие три стратегических решения директора по информационной безопасности предотвратят... 19137Почему обнаруженные в SolarWinds Web Help Desk критические уязвимости требуют... 19136Древнейшие в мире ручные деревянные орудия возрастом 430 000 лет обнаружены в Греции