Share Go code on GitHub
Programming Snapshot – Go Code on GitHub
© Lead Image © bowie15, 123RF.com
Go makes it easy to bundle universal code into a package and share it with the world on GitHub. Mike Schilli explains the tricks and how to avoid the pitfalls.
Attentive readers of this column will have noticed that the Go listings covered here often reference packages on GitHub, which the Go compiler picks up from there and integrates into the binaries as libraries. But you can't always take, take, take. Instead, let's contribute back! How hard could it be to write your own code and share it with the world on GitHub? Then programmers near and far can use it, saving them the time they could otherwise use to sing the originator's praises.
By way of an example, a simple package that allows a Go application to store the passwords and API tokens it uses in an external file would be useful. These strings should never be part of the code, and not just because the listings are printed here in the magazine. Hard-coded strings are also frowned upon in production releases, because the code is usually openly available in a GitHub repo and automatic installations like to roll out binaries and secrets separately – just as if the user were configuring them manually after installation.
Take a look at the sample application shown in Listing 1, for example. It determines the five most frequently viewed videos on a YouTube channel and requires a secret API key and a channel ID to do so. Instead of keeping strings with secret data in the code, the code calls the Lookup() function twice. It reads a string for the specified keyword from an external humanly readable file (in the example, "youtube-api-key" and "youtube-channel-id") and returns the results to the application.
[...]
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Linux Foundation Report Indicates AI Driving Tech Hiring
Within growing security and skills gaps, AI has been found to be a positive driving force behind tech hiring trends in Europe.
-
United Nations Open Source Portal Goes Live
A new open source portal seeks to coordinate and scale open source efforts across the United Nations system.
-
KDE Linux Drops AUR
KDE Linux developers have dropped the Arch User Repository from the build pipeline due to security concerns; other distributions should consider doing the same.
-
California May Exempt Linux from Its Age-Verification Law
After backlash from the Linux community, California may be backing off on its promise to force all operating systems to verify age, but one platform may still have to comply.
-
Another Logic Bug Found in Linux Kernel
Qualys has discovered a vulnerability in the Linux kernel that can be used to elevate standard user privileges.
-
Ubuntu Core 26 Offers Game-Changing Enterprise Features
Ubuntu Core 26 could be a game-changer for organizations looking for increased security and reliability.
-
AI Flooding the Linux Kernel Security Mailing List
AI is giving Linus Torvalds a headache, but not in the way you might think.
-
Top Priorities for Open Source Pros Seeking a New Job
Professional fulfillment tops the list, according to LPI report.
-
Container-Based Fedora Hummingbird Designed for Agent-First Builders
Fedora Hummingbird brings the same approach to the host OS as it does to containers to level up security.
-
Linux kernel Developers Considering a Kill Switch
With the rise of Linux vulnerabilities, the kernel developers are now considering adding a component that could help temporarily mitigate against them… in the form of a kill switch.
