Skip to content
This repository has been archived by the owner on May 30, 2023. It is now read-only.

Latest commit

 

History

History
194 lines (142 loc) · 16.3 KB

README.md

File metadata and controls

194 lines (142 loc) · 16.3 KB

Global Open Source Permissionless Enterprise League (GOSPEL)

This document is a work-in-progress. The ideas are presented authoritatively, however, they may not work for everyone. Pull requests and feedback are welcome. If you believe in the GOSPEL's mission, please contribute your findings.

We live in a new world. With increased global Internet connectivity and a large-scale transition from physical to information-based labor, new paradigms must emerge if organizations are to adapt to this new landscape. There is no one-size-fits-all approach, but GOSPEL recognizes the potential to radically optimize work flows to this new environment. If traditional, non-Internet-native, geography-based work is a single-core processor, this document attempts to lay out a specification for a distributed system. The Internet does not completely overturn the old principles governing how organizations operate. However, it should cause an operator to make different choices and sacrifices after taking the big picture into consideration. This allows them to take advantage of the massive increase in output that a distributed system can bring.

About the Author: LZRS is a software developer with experience:

  • Managing community contributions and working as an engineer at a prominent cryptocurrency company
  • Founding a startup with cofounders and employees in radically different timezones and countries
  • Most recently, building software supporting COVID-19 immunization and working as a tech lead at one of the world's largest vaccine distributors

LZRS has been greatly inspired by some personal friends who have had success building global workforces, as well as the thought leadership of Balaji Srinivasan.

In a nutshell

GOSPEL is targeted at commercial tech enterprises and has three tenets.

  1. Operate globally
    • Communicate via long-form writing.
    • Execute asynchronously.
  2. Open source everything
    • Make source code, internal communications, and business strategy public.
    • Some things may need to be proprietary, but that should be the exception and not the norm.
  3. Enable permissionless contributions
    • Since everything is open source and globally optimized, allow anyone in the world read the source code or business strategy and get paid to contribute (i.e. fixing a bug in the app).
    • Contributors may still be able to opt for salaried employment.

These three tenets work in concert to provide enterprises with certain benefits:

  • Better talent.
    • The purpose of hiring globally is to access a larger pool of highly skilled labor, not to cut costs.
    • Permissionless contributions enable enterprises to tap into the global talent pool without experiencing the significant friction of navigating foreign labor markets.
    • Contributors can be pseudonymous and are compensated based on merit. This provides opportunities to those excluded from the traditional hiring process and allows enterprises to utilize underrated talent.
    • Top talent often prefers the flexibility of remote, asynchronous work.
  • A more robust organization.
    • Long-form written communication extracts important information out of the heads of individuals and small teams, and places it into version control.
    • Problems are often detected earlier in open source projects because there are more eyes on them.
    • Optimizing for permissionless contributions makes it easier to replace lost personelle.
  • Becoming a nexus of industry.
    • Transparency builds good will among customers and the community.
    • Sharing implementation and execution details attracts talent when they are trying to learn.
    • An enterprise is constantly creating internal content, but wasting valuable opportunities to use it for content marketing due to unnecessary confidentiality.
  • The potentional to attain "workforce autoscaling"; by simply paying more, a workforce can be blitzscaled with few bottlenecks.

The playbook

This playbook is for software company operators. It expores specific considations that must be taken into account when enacting the three tenets.

Levels of contribution

  1. Task delegation
    • A contributor completes a task according to its specification.
    • Example: coding a well-specified feature for an app.
  2. (Technical) product management
    • A contributor specifies a task that must be completed to acheive a strategic goal.
    • Example: designing the specification for the feature mentioned above in accordance with the roadmap.
  3. Strategy
    • A contributor lays out, at a high level, what the company ought to do.
    • Example: creating the roadmap that indicates the need for the feature specification mentioned above.

As the levels increase, the operator's mindset must change from that of a bureaucratic manager to that of an asset allocator. The operator has capital to spend and must invest in a portfolio of features and strategies, each with their own execution risk.

This playbook is built from real experience and not theory. Due to the experience of the author(s), it only discusses level 1 contributions. However, GOSPEL believes higher-level contributions are possible and has a mandate to explore them further. If you have experience with this, please consider contributing your findings.

Decide and commit

First, decide. Is this right for the enterprise? If so, is there any information that cannot be shared publicly? Exclude such information when open sourcing everything.

Then, commit. Make a pledge to work in an open manner for a meaningful period of time. Contributors must learn about the business and existing technology before adding value. Therefore, it is important to make them comfortable investing time to learn about the enterprise. They need to be assured that this knowledge they are working to acquire will be useful for many contributions to come.

Open source everything

The source code

Put code in a public Github repository or use a similar platform. Put upcoming features and bug fixes into a public issue tracker so contributors can know what to build and submit pull requests.

Frontend applications almost always can be made open source. The reason is that you must design them assuming they are running on untrusted machines. Backend applications should be open sourced with caution. An application built with best practices will be fine, but be sure you are not committing any secrets into version control.

Generally speaking, the more that can be put into version control the better. While there is no particular guidance for infrastructure as code, it is worth exploring how to incorproate securely into an open source codebase.

The business

Make business information public. This includes:

  • Internal communications
  • Strategy documents
  • Industry research
  • Internal knowledge base
  • Roadmap

Accept contributions

Establish roles

  • Technical Lead The leader responsible for ensuring code quality in a repository or a portion of a repository. The technical lead also assess the difficulty of tasks and sets bounty targets (subject to financial constaints and oversight).
  • Code Reviewer A developer that reviews code contributions to see if they should be merged or rejected. This is often the technical lead, but could also be a trusted developer on behalf of the technical lead.
  • Finance Lead A person, group of people, or system that sets budgets and has the authority to approve or reject spending on code contributions. The finance lead should have minimal involvement and give the technical lead as much autonomy as possible.

Set contribution guidelines

Clearly define best practices. If appropriate: require linting, code formatting, and full unit test coverage. Prefer correctness over individual developer speed (i.e. consider statically typed over dynamically typed lanugages). The project's development speed will increase by decreasing coordination overhead instead of the speeding up individual contributors. Optimze for easy code reviews, not easy contributions.

Document architecture decisions. This allows contributors to get a better idea of which approach they should take.

Set bounties

Set a value that each upcoming task is worth. Aim for compensation parity with salaried employees. If a task would take a median salaried employee approximately 1 week full-time at $10k per month, pay $2.5k.

If nobody is fulfilling a given task, raise the bounty. However, this is assuming that enough capable developers have seen it. If they have not, then try driving more traffic to it (see Traffic Strategies).

Be firm yet compassionate

Operate in good faith, but reject bad submissions swiftly and hold contributors to a high standard in accordance with contribution guidelines.

A contributor's best effor may not be good enough. For example, a junior engineer may submit unreadable code or not notice a certain class of bug. The code reviewer must quickly reject this contribution and the contributor must not get paid. Ideally, the code reviewer will be able to point to where the submission can be improved, but this can be a time-intensive exercise and therefore must be done at the discretion of the code reviewer.

The onus is on the contributor to find a way to add value given that all information is available. The contributor might need to spend time studying the enterprise's codebase and operations more in-depth, attempting to make contributions along the way, and earning trust before getting a contribution accepted.

With that said, the enterprise must operate in good faith. Good contributions ought to be rewarded in a timely manner and opportunities to contribute must be as plentiful as the enterprise can afford. Further, providing feedback to genuine contributors is a great way of building a more robust community of developers.

Traffic Strategies

while developing in public, try to bring new developers into the fold. Transparency is a compentitve advantage. Use public information as content marketing and build trust with a community of fans who know the mission and want to be a part of it. Entice them with fair compensation for their labor.

Content is king online. Turn business and architectural decisions into blogposts. Show your work. Build a community around people who care about the enterprise, its mission, and each other. Adopt the spirit of a community-oriented project that everyone has an opportunity to profit from if they are able to add value.

There are also several bug bounty listing websites that can generate inbound traffic. More on traffic generatorion in a later section.

Retain great contributors

Convert impressive contributors to remote, salaried employees. Aim for pay parity if they worked full-time as a permissionless contributor. Attempt to always raise the bar when deciding who to put on salary. The best hire is someone who is able and willing to do code reviews and act as a technical lead. This is a force multiplier and typically deserves extra pay. However, even if certain contributors do not wish to interact with the community, it is valuable to reserve 100% of their time by putting them on salary.

FAQ

What technologies are recommended?

Bold are technologies used by GOSPEL. Recommendation does not mean it is the best, only that it does the job well.

Verison control for source code:

  • GitHub - most popular platform
  • GitLab - self-hosted options, leader in remote work
  • SourceHut - free open source software

Public documentaion

Ideally, all business information would be stored in local text files and tracked in Git. However, the tooling around this is simply not always up to par.

  • GitHub Wiki - Git-based, highly GitHub-integrated
  • HackMD - many features, GitHub-integrated
  • Notion - most popular platform
  • Obsidian - local, markdown-based

Public issue tracker

Currently, it is recommended to use the issue tracker integrated with the chosen version control provider. Ideally, this would also be local data that could be stored directly into version control, however, there are no known good options for this at this time. If you know a good option for this, please submit your suggestion.

Internal communications

  • Discord - most popular for online communities
  • Discourse - forum instead of real-time messaging, open source
  • Slack (configured to be public) - most popular among tech companies

Isn't outsourced labor low quality?

Not necessarily. There are untalented developers in every country. Some countries may have less capable developers on average than others. However, there are more talented developers, in total, in the global market than in any given country.

Thank about it from a Baysean persepctive. A random developer in country X country may likely be more talented than a random developer globally. But any given talented developer is most likely not from country X.

It is difficult to find talent abroad. However, open source permissionless work attracts developers around the world so traditional recuritment efforts are unnecessary.

Isn't it hard to manage so many low quality pull requests?

This can be challenging, but if a company operates in good faith and holds a clearly communicated high-standard, this should not be a problem.

How is one supposed to work with foreign developers that have poor English?

Operators should not tolerate poor communication. Contributors should know English to a near-native proficiency. With that said, there isn't much need for realtime listening/speaking, only reading/writing.

It can be an advantage for multilingual operators to hire non-English speakers, but beware of creating language-based siloes. It is best for everyone to be able to communicate well with each other.

Isn't asynchronous work hard?

If asynchronous work is hard, then learn to write better. Writing helps to fully think through ideas and thoroughly communicate them. Synchronous communication does not scale, while asynchronous does.

Example of large systems relying on asynchronous/written work:

  • Amazon 6-page memos
  • Scientific research and peer review
  • Legal systems

What if bounties don't work?

Many people are skeptical of whether developers will work for bounties. However, even without many contributions there are considerable benefits.

  1. Building a community that trusts the enterprise and values its mission
  2. Writing down ideas to think through them more clearly
  3. Flexible work arrangements that can accomodate a larger pool of traditionally acquired talent

Contributors are not going to replace the operators. Operators must continue building the company whether or not they are getting contributions. With time, contributions will come.

Don't open source projects already do this?

Yes, open source projects have had to fully lean into the powers of the Internet to turn altruism into code. Enterprises have an advantage in that they can provide sizable amounts of monetary compensation in exchange for contributions. Unforuntately, most enterprises are stuck spending that money on the pre-Internet employment model. GOSPEL is for enterprises (with money) that want to use Internet-native techniques (developed by open source projects) to scale much better.

Don't cryptocurrency projects already do this?

Yes, many cryptocurrency companies are enterprise/open source hybrids. However, non-cryptocurrency companies can do this too.

Can't competitors copy open source code?

There are legitimate reasons that code should be private. However, consider the following.

There are two types of moats:

  1. Having better technology
  2. Having a brand and community

Many people are so worried about moat 1 that they will not take actions that boost moat 2. Ironically, often times moat 2 is more important. However, it is a case-by-case basis.

Certain code bases such as websites are easily copyable in the first place and need not be kept private under almost any circumstances. AS a last resort, intellectual property can help protect the codebase from bad actors.

Aren't there security concerns surrounding open sourcing backend code?

If done imporperly, yes. However, there are many examples of backend code being successfully open sourced.

  1. Signal has open sourced their server implementation
  2. Mullvad has opene sourced many codebasess, including backend infrastructure code
  3. Wordpress is open source. Many businesses run the same open source code with minimal modifications (and most modifications are not security enhancements).