Для переноса части Go-проекта в открытый доступ с сохранением истории и авторства, сначала необходимо выделить нужный пакет, используя

Критически важно убрать всю специфическую и конфиденциальную информацию из кода, используя
После подготовки кода, необходимо создать новый репозиторий на GitHub и добавить в него перенесенный пакет. Затем следует оформить новый проект, добавив README, бейджи, лицензию, workflow, релизы и запросив публикацию документации на , а также опционально настроить безопасность.
В заключение, исходный пакет можно удалить из старого проекта и установить как внешнюю зависимость через
git filter-branch. Это позволит оставить только историю изменений этого пакета. Далее следует отредактировать сообщения коммитов, удаляя корпоративные префиксы и номера тикетов, а также заменить корпоративные email-адреса и имена авторов на профили GitHub, что можно сделать через git filter-branch --env-filter. 
Изображение носит иллюстративный характер
Критически важно убрать всю специфическую и конфиденциальную информацию из кода, используя
git grep для поиска и git rebase -i для редактирования коммитов, где такая информация была первоначально добавлена. Также необходимо исключить ненужные файлы из истории с помощью git filter-branch --index-filter, чтобы не оставлять в открытом репозитории лишних следов. После всех изменений нужно проверить корректность кода и актуальность путей. После подготовки кода, необходимо создать новый репозиторий на GitHub и добавить в него перенесенный пакет. Затем следует оформить новый проект, добавив README, бейджи, лицензию, workflow, релизы и запросив публикацию документации на , а также опционально настроить безопасность.
В заключение, исходный пакет можно удалить из старого проекта и установить как внешнюю зависимость через
go get. При этом следует не забыть добавить зависимость в go.mod и vendor/. Открытие исходного кода позволяет сообществу улучшать проект, выявлять ошибки и повышать доверие к инструменту.