Vad är öppen källkod och varför ska du bry dig?

2021-06-10

Bild med texten ''Public money Public code''

Många konsultfirmor har som affärsidé att låsa in sina kunder, både genom att låsa in data och låsa in källkod. Våra värderingar på Iteam är att Skapa värde, Ha kul och Göra något bra - och de värderingarna leder oss fram till att vi hellre hjälper våra kunder att få mer värde genom att bygga vidare på tidigare arbete - än att göra om samma jobb om och om igen. Det blir billigare, snabbare och bättre helt enkelt. Och vi kommer vidare i digitaliseringen istället för att stå kvar och stampa.

Så, vad är då öppen källkod?

Grunden är att källkoden är tillgänglig och att du får ändra i och dela med dig av den, d.v.s. att den är släppt under en licens som tillåter det. I princip räcker det att publicera koden under en sådan licens för att säga att projektet är öppen källkod, men det skapar inte så mycket värde om ingen kan bygga vidare på koden.

Öppen källkod används i nästan allt du använder till vardags. Oavsett om du slår på TV:n, mobilen eller kör din bil så använder du digital mjukvara som har sin källkod publicerad öppet med en licens som gör att du kan hämta den, förändra den och ibland även sälja en produkt med källkoden inbyggd.

Klassiska exempel på projekt med öppen källkod är: Linux, Wordpress, MySQL, Android (till största delen), Elasticsearch, Kubernetes, Docker, Node.js, PHP. Som användare är några av projekten troligtvis okända för dig men de lägger grunden till allt från nyhetssajter och sociala medier till dina vanligaste appar för att resa kollektivt, beställa mat eller hitta vägen till badstranden.

Engagemang gör hela skillnaden

Ett vanligt misstag många gör är att man väntar med att publicera källkoden tills man är klar. Det brukar oftast inte bli så bra. Om någon annan ska ha nytta av projektet måste de hitta det, förstå vad det är bra för och hur man använder det, men kanske också känna sig delaktig, då behöver man publicera koden tidigt och innan den är klar.

För att det ska vara värt något att ha tillgång till källkoden behöver den gå att förstå, och då måste den kanske vara välskriven och ha dokumentation och tester. Och för att någon ska uppleva att de kan delta i projektet på ett meningsfullt sätt behöver det kanske ta emot pull requests, issues och feature requests. Alla dessa extra grejer strävar efter att förstärka fördelarna med open source, att göra det lätt att ta del av projektet och påverka det. Men vad som är bäst beror på projektet; Vilka är målgruppen är, hur de använder koden och hur de skulle vara intresserade av att påverka projektet.

Måste man publicera all källkod bara för att man använder öppen källkod?

Vissa licenser kräver att du också öppnar din kod för att använda deras öppna källkod, den vanligaste av dessa är GPL. Nu för tiden är däremot licenser som MIT, Apache 2.0 eller ISC vanligare och de kräver inte att du publicerar källkoden. Vill du lära dig skillnaden mellan olika licenser är den här sajten en jättebra start: https://choosealicense.com/

Blir det inte enormt osäkert att ha all källkod öppet?

Det är faktiskt en myt att ett system skulle bli mer säkert om man håller all källkod gömd. Det finns nämligen alltid buggar i kod och om det är få personer som tittar på koden så är risken större att ingen hittar buggarna. Det finns självklart delar av ett system som man vill hålla stängd, t ex nycklar, lösenord och interna IP-adresser osv bör man aldrig publicera som del av källkoden utan hålla i separata stängda system.

Är all öppen källkod gratis?

För att programvara ska vara “Open Source” måste användare av programvaran vara fria att dela med sig av den hur de vill utan extra kostnader. Det betyder inte att du inte kan ta betalt för att få tillgång till programvaran och källkoden, eller ta betalt för paketerade versioner på exempelvis App Store samtidigt som källkoden är fritt tillgänglig. En relaterad modell som inte är öppen källkod är att göra källkoden tillgänglig under en licens som begränsar dess användning. Exempelvis är källkoden till Unreal Engine tillgänglig att användas av vem som helst men de måste betala royalties på de intäkter den genererar.

Hur tar man betalt för öppen källkod?

Vanliga affärsmodeller är att sälja kompetens kring programvaran, utbildning och certifiering inom den eller hosting av den. Fråga dig om tillgång till mjukvaran verkligen är det mest värdefulla ni levererar, och hur värdet av det ni levererar hade påverkats om programvaran började användas av fler.

Här är anledningarna till att du ska börja med öppen källkod

Delad kostnad.

Om någon annan hjälper dig att vidareutveckla din källkod delar ni på kostnaden för vidareutvecklingen.

Ökad innovation.

När fler hjärnor hjälps åt blir den totala intelligensen större i att lösa problemen. Kanske sitter någon där ute på precis svaret på det problem du sitter med just nu.

Minskad inlåsning.

Med öppen källkod är ni fria att göra ändringar och vidareutveckla för all framtid och är inte bundna till någon specifik leverantör eller licensavtal.

Ökad säkerhet.

Finns det buggar i din kod är chansen större att ni upptäcker den om fler har möjlighet att se hur din produkt är uppbyggd.

Större delaktighet.

En demokrati är beroende av transparens för att förstå hur världen är uppbyggd. I en digital demokrati med större och större del av verksamheten som sker med hjälp av mjukvara så blir också behovet av insyn i dessa programvaror större. Lägger man till AI till denna mix så är det ännu svårare att få insyn i den komplexa process som sker och kraven ökar mer på öppen källkod. Att ha varit med och skrivit en liten liten del av något som blir stort är en väldigt stor drivkraft för många som jobbar med utveckling. Det skapar en delaktighet och ambassadörer för ditt projekt.

Lättare onboarding.

När ett projekt utvecklas med målet att källkoden ska vara öppen blir oftast kraven större på att det ska vara enkelt att kunna få igång koden på sin egen dator. Det gör faktiskt det lättare även för teamet självt när det kommer nya personer som ansluter till teamet. Det paketeras helt enkelt lite smidigare så att man inte behöver veta exakt allt om hur allt fungerar men ändå kan hjälpa till.

Påverkar arbetsprocessen.

När ett projekt utvecklas i det öppna så kommer även fler personer engagera sig tidigt (om det är ett projekt som engagerar). Denna typ av kontinuerligt samarbete ökar intelligensen i den totala gruppen och möjliggör mer specialiserad kunskap att bidra. Det kan till exempel handla om översättningar, exempeltexter, illustrationer som kan läggas in direkt i koden utan att behöva hamna i backlogs eller annan projekthantering.

Kontakta gärna oss på Iteam om du är nyfiken på öppen källkod och digital innovation. Vi hjälper dig både med tekniken, skapa engagemang/community kring din tjänst och att hitta fram till en kultur av action, öppenhet och lärande i ditt team.

Vill du lära dig mer om öppen källkod?

Boka ett MVP team som hjälper dig att komma igång

Kollage av olika AI-genererade bilder.

2022-11-14

AI för UX:are – är vår kreativitet hotad?

UX-teamet här på Iteam ville utforska användningen av olika AI-verktyg i det dagliga arbetet och ägnade en labbfredag åt detta.

Personer som arbetar vid sina skrivbord

2022-09-26

Tips när du startar ett team

Hösten är i full gång, projekt efter projekt startas upp och med det sätts också team samman för att jobba med nya utmaningar.

Karta med visualisering av kollektivtrafik

2022-09-23

Ökad rörlighet på landsbygden

Vi jobbar just nu vidare under Predictive Movement-paraplyet i två projekt, RörLa och Digiby.

2022-09-15

Room mates sökes till vårt kontor i Göteborg!

Letar du efter plats på ett magiskt och mysigt kontor? Ta en titt på ett av våra outnyttjade kontorsrum på vårt kontor i Göteborg.

Mikael

2022-06-15

Kodlunch – Mikael pratar om varför han älskar Elixir

Vår stjärnutvecklare Mikael berättar om glädjen att koda med Elixir

En större grupp kollegor umgås i ett kök/lounge.

2022-04-13

Vi fortsätter att rekrytera!

Att bygga relationer med omtanke och respekt är något vi alla kan göra för en bättre värld. I vår välkomnar vi både nya och gamla kollegor tillbaka.

Medarbetare som sitter i en lounge och pratar

2022-04-08

Vad är DesignOps och varför är det relevant?

I takt med att fler företag inser värdet av design ökar behovet att skala designfunktioner. Och det är precis det som DesignOps fokuserar på.

mobprogrammering team flow Iteam

2021-10-22

Riktig innovation kräver team flow

Hur kan ett utvecklingsteam bli ett hockeylag. Lösningen stavas Team Flow. Men hur gör vi för att uppnå detta?

Nya kollegor

2021-08-05

Hållbar digitalisering attraherar både kompetens och kunder :D

Hållbarhet och digital innovation sitter lika naturligt ihop som Batman och Robin

Tak

2021-06-18

Hur kan bostadspriserna förändras efter pandemin?

Location, location, location. Vad har Strindbergs hiss med huspriser att göra?

API

2021-06-16

Vad är ett API?

De flesta vet vad BNP är men få vet vad ett API är. Båda är komplicerade frågor som hjälper att känna till om man ska förstå hur samhället utvecklas.

Bild med text "Public money, public code"

2021-06-10

Vad är öppen källkod och varför ska du bry dig?

Öppen källkod är mycket mer än bara gratis programvara. Det är en filosofi som rimmar väl med demokratins värderingar.

Kontor

2021-06-09

Vi sa upp vårt kontor i pandemin. Dags att tänka nytt

Vi kombinerar det bästa från hemarbetet med en ny form av lokal

Christian Landgren i Logistikpodden

2021-06-03

Logistikpodden om Predictive Movement

Hur kommer framtidens transportsystem fungera? Kan AI hjälpa miljön?

En person som jobbar vid en dator

2021-05-18

Predictive Movement testas i Pajala

Predictive Movement är en samverkansplattform för att optimera transportsystemet. Denna veckan testar vi i Pajala.

Fyra personer i ett möte

2021-05-10

Jämställdhet på Iteam

2021 är Iteam ett techbolag med lika många kvinnor som män. Det tål att uppmärksammas!

Christian Landgren

2021-03-10

Tre snabba om #jobtech med Christian Landgren

Hur påverkar öppen källkod och öppen data arbetsmarknaden framöver?

Två utvecklare som samarbetar vid en dator.

2020-10-01

DX - upplevelsen som inte får glömmas

Developer Experience - hur skapar man lösningar som utvecklare ❤️ älskar?

Drönare

2020-09-03

Drönare för medicinleveranser

Hur skulle samhället förändras om vi kunde få drönarleveranser till varje stuga?