Announcing SponsorLink #3
Pinned
kzu
announced in
Announcements
Replies: 1 comment 1 reply
-
I don't understand the need for this. It completely goes against open source philosophies. Why not just display a message saying something like:
...no need to collect any emails, background scanning, paused build time, execution of obfuscated code, requirement for third-party apps, privacy concerns, etc, etc. |
Beta Was this translation helpful? Give feedback.
1 reply
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
I just posted the announcement on my blog, which I reproduce here too:
Open source sustainability is a tricky topic. I would kindly refer you to the thoughtful post by Eric Sink and Six Labors's license change post.
Suffice to say, we all struggle to make this a sustainable proposition where we can dedicate full-time to the projects we love. Also, there doesn't seem to be a perfect answer for all scenarios, so there's always pros and cons.
With that in mind, let me introduce you to SponsorLink.
GitHub Sponsors
GitHub Sponsors is a fantastic thing. I'm quite convinced it's a step in the right direction, with availability throughout most of the world, and constantly adding new regions.
They have an Explorer to find projects to sponsor, and for the most part they have figured out how to make the quite tricky part of actually charging and paying people throughout the globe seem like a trivial thing. It's quite amazing. No individual could ever have enough bandwidth to figure it all out on his own just to attempt to make a few bucks from a passion project.
I have been testing it out for a while too with an organization account, but other than a few generous friends and some one-time large-ish sponsorships (very few and far between), let's just say it hasn't gotten much traction. Shocking, right?
As I'm getting ready for a serious amount of work on Moq vNext, I wanted to see if I could come up with something to help me support myself and my family while I dedicate to that full-time for a while. So I came up with SponsorLink.
Introducing SponsorLink
I believe most fellow developers don't have an issue with giving away a buck or two a month for a project they enjoy using and delivers actual value. And I'm quite positive that if a couple dollars a month is an affordable proposition for an argentinean, it surely isn't a crazy thing for pretty much anyone.
And I'm a firm believer that supporting your fellow developers is something best done personally. Having your company pay for software surely doesn't feel quite as rewarding as paying from your own pocket, and it surely feels different for me too. We really don't need to expense our employers for a couple bucks a month, right??
So the goal of SponsorLink is to connect in the most direct way possible your sponsorship with your library author' sponsor account. And since the place where you spend most of the time enjoying your fellow developers' open source projects is inside an IDE (i.e. Visual Studio or Rider), I figured that's the first place where you should be reminded that either:
You are an awesome backer and the project is alive and well thanks to you:
You should not forget to take action now to become 1), given it's incredible
straightforward and affordable!
How it works
SponsorLink will never interfere with a CI/CLI build, neither a design-time build. These are important scenarios where you don't want to be annoying your fellow oss users. I don't want to have to deal with setting up licenses on a server, provisioning test agents or whatever. Also, if you're building from the command line, it's not as if you're enjoying my oss library all that much anyway.
Initially, I built support for SponsorLink for .NET via a nuget package. The backend is agnostic to the client, though, so if this takes off, I may add other ecosystems.
The non-dotnet specific way it works for library users is:
git config --get user.email
during build to get the current user's configured email. If there's nogit
oremail
, there's nothing to do. No real work is done nowadays without both, right? :)/apps/[user_email]
. If it's a 404, it means the user hasn't installed the SponsorLink GitHub app. This app requests read access to the users' email addresses, so the previous check can succeed./[sponsor_account]/[user_email]
. If it's a 404, it means the user isn't sponsoring the given account.In both 3) and 4), users are offered to fix the situation with a quick link to install the app, and then sponsor the account.
On the sponsor account side, the way it works at a high level is:
And that's it!
From this point on, any new sponsor will immediately be notified to SponsorLink which will update the Azure Blob storage account with the right entries to that in mere seconds the experience quickly goes from Install GH App > Sponsor > Thanks!
Closing
I discussed this approach with fellow developers and it sounded unanimously reasonable. Hopefully you will think so too, and perhaps even start using it on your projects. More than 20 years after my first steps in open source, for the first time I feel this can actually work and be a sustainable endeavor. Let's make it work together!
Please do report issues and join the discussions. I want this thing to work and offer the best balance of gentle nudging users to sponsor (without being obnoxious) and being easy to integrate in your projects.
Now, it's time for me to go back to doing what I like most: hacking on more oss stuff.
Beta Was this translation helpful? Give feedback.
All reactions