Before You Start
What Open Source Is

What Open Source Really Is (and Is Not)

ℹ️

The Definition Most Get Wrong

Open source isn't just "code you can see." It's a philosophy, a legal framework, and a cultureβ€”all in one.

The Three Pillars of Open Source

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                     THE THREE PILLARS OF OPEN SOURCE                        β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                             β”‚
β”‚         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                β”‚
β”‚         β”‚             β”‚   β”‚             β”‚   β”‚             β”‚                β”‚
β”‚         β”‚   LICENSE   β”‚   β”‚  COMMUNITY  β”‚   β”‚   CULTURE   β”‚                β”‚
β”‚         β”‚             β”‚   β”‚             β”‚   β”‚             β”‚                β”‚
β”‚         β”‚  Legal      β”‚   β”‚  People who β”‚   β”‚  Shared     β”‚                β”‚
β”‚         β”‚  permissionsβ”‚   β”‚  build &    β”‚   β”‚  values &   β”‚                β”‚
β”‚         β”‚  granted    β”‚   β”‚  use the    β”‚   β”‚  practices  β”‚                β”‚
β”‚         β”‚             β”‚   β”‚  software   β”‚   β”‚             β”‚                β”‚
β”‚         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                β”‚
β”‚               β”‚                 β”‚                 β”‚                        β”‚
β”‚               β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                        β”‚
β”‚                                 β”‚                                          β”‚
β”‚                                 β–Ό                                          β”‚
β”‚                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                             β”‚
β”‚                    β”‚     OPEN SOURCE         β”‚                             β”‚
β”‚                    β”‚     SOFTWARE            β”‚                             β”‚
β”‚                    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                             β”‚
β”‚                                                                             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

What Open Source IS

Transparent Development

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚        TRADITIONAL SOFTWARE       β”‚       OPEN SOURCE           β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                   β”‚                             β”‚
β”‚  Decisions behind closed doors    β”‚  Discussions in public      β”‚
β”‚                                   β”‚  issues & PRs               β”‚
β”‚                                   β”‚                             β”‚
β”‚  Roadmap hidden                   β”‚  Roadmap in public docs     β”‚
β”‚                                   β”‚                             β”‚
β”‚  Bug reports internal             β”‚  Bug reports public         β”‚
β”‚                                   β”‚                             β”‚
β”‚  Code review private              β”‚  PRs visible to all         β”‚
β”‚                                   β”‚                             β”‚
β”‚  "Trust us, it works"             β”‚  "Here's the code, verify"  β”‚
β”‚                                   β”‚                             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Collaborative by Default

Open source projects invite participation:

  • Anyone can contribute β€” If you follow the process
  • Anyone can review β€” Code reviews are public
  • Anyone can fork β€” Create your own version legally
  • Anyone can learn β€” The codebase is your classroom

The Ecosystem

                         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                         β”‚   End Users      β”‚
                         β”‚   (Millions)     β”‚
                         β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                                  β”‚ use
                                  β–Ό
                         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                         β”‚   The Software   β”‚
                         β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                                  β”‚ built by
                                  β–Ό
          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
          β”‚                       β”‚                       β”‚
          β–Ό                       β–Ό                       β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚   Maintainers   β”‚    β”‚  Contributors   β”‚    β”‚   Companies     β”‚
β”‚   (2-10)        β”‚    β”‚  (Hundreds)     β”‚    β”‚   (Sponsors)    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜
         β”‚                      β”‚                      β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                                β”‚
                       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β–Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                       β”‚   The Community  β”‚
                       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

What Open Source Is NOT

❌ It's Not Free Labor for Companies

⚠️

Know Your Worth

Many companies benefit from open source. That doesn't mean you should work for free on their products. Be aware of the dynamic when contributing to corporate-backed projects.

❌ It's Not a Shortcut

ExpectationReality
"I'll contribute for 2-3 months and get hired"Career impact takes 1-2+ years of consistent work
"My first PR will be merged quickly"First PR reviews often take 1-3 weeks
"I'll become a core contributor fast"Core contributor status takes 1-2+ years
"Maintainers will mentor me"Maintainers are busy volunteers

❌ It's Not Always Welcoming

Toxic Communities Exist

Some projects have:

  • Hostile maintainers
  • Cliquish communities
  • No documentation
  • Abandoned codebases

Before investing time:

  • Check the Code of Conduct
  • Read recent issue discussions
  • See how maintainers respond to newcomers
  • Look for "contributor-friendly" labels

The Open Source Development Model

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                    OPEN SOURCE DEVELOPMENT FLOW                             β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                             β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚
β”‚  β”‚  Issue  │───▢│  Fork   │───▢│ Branch  │───▢│  Code   │───▢│  PR     β”‚  β”‚
β”‚  β”‚ Created β”‚    β”‚  Repo   β”‚    β”‚ Create  β”‚    β”‚ Changes β”‚    β”‚ Submit  β”‚  β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”˜  β”‚
β”‚                                                                    β”‚       β”‚
β”‚                                                                    β–Ό       β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚
β”‚  β”‚ Released│◀───│ Merged  │◀───│ Approved│◀───│ Review  │◀───│  CI     β”‚  β”‚
β”‚  β”‚         β”‚    β”‚         β”‚    β”‚         β”‚    β”‚ Changes β”‚    β”‚  Runs   β”‚  β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚
β”‚                                                                             β”‚
β”‚  ◄──────────────── Time: Days to Weeks ────────────────────────────────►   β”‚
β”‚                                                                             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

License Types at a Glance

LicenseCan Use CommerciallyMust Share SourceAttribution Required
MITβœ… Yes❌ Noβœ… Yes
Apache 2.0βœ… Yes❌ Noβœ… Yes
GPL v3βœ… Yesβœ… Yesβœ… Yes
BSD 3-Clauseβœ… Yes❌ Noβœ… Yes
LGPLβœ… Yesβœ… For modificationsβœ… Yes
AGPLβœ… Yesβœ… Even for SaaSβœ… Yes
πŸ’‘

License Matters

Understanding licenses helps you know your rights and obligations. MIT and Apache are permissive; GPL is copyleft.


The Philosophy in Practice

Transparency First

Before asking a question privately, check if it should be asked publicly where others can learn.

Patience Always

Before pinging a maintainer, wait at least a week for a response.

Humility Required

Before arguing about your PR, consider that maintainers know the codebase better than you.

Gratitude Matters

Before complaining, remember maintainers are unpaid volunteers.


Key Takeaways

Open Source is:

  • πŸ“œ A legal framework (licenses)
  • πŸ‘₯ A community (people)
  • 🀝 A culture (values)
  • πŸ“– Transparent (public everything)
  • πŸ”„ Collaborative (anyone can contribute)

Open Source is NOT:

  • πŸ’° Free labor
  • πŸš€ A shortcut to anything
  • πŸ€— Always welcoming
  • πŸ“š Just code