Skip to main content

Publiccode

OpenCatalogi ondersteunt het gebruik van de Publiccode-standaard. Dit betekent dat we ervan uitgaan dat alle publicaties in een publieke repository staan en zijn voorzien van een publiccode.yaml bestand. Dit bestand bevat de metadata en informatie van je publicatie, zoals naam, beschrijving en type. Het helpt het platform om jouw component te indexeren en gemakkelijk te vinden voor andere gebruikers.

[!Note] OpenCatalogi scant GitHub elke nacht, als je een component sneller wilt aanmelden of bijwerken, kan dat door naar opencatalogi.nl te gaan en hier het formulier in te vullen om een repository toe te voegen. Deze trigger wordt ook afgevuurd door de workflow.

[!Warning] Let op, OpenCatalogi bevraagt bij het inlezen van een repository de GitHub Search API, deze geeft alleen goede resultaten terug wanneer de repository is geïndexeerd. Dit kan worden geforceerd door een zoekopdracht uit te voeren op de GitHub website. Gebruik hiervoor de GitHub zoekbalk met bijvoorbeeld repo:{{Uw Organisatie/Gebruiker}}/{{Uw repository}} publiccode en wacht tot deze opdracht resultaten geeft. Dit kan zo'n 10 minuten duren en daarbij moet de pagina enige keren ververst worden.

Maken met workflow

Vanuit het OpenCatalogi-project is een GitHub-workflow beschikbaar die een publiccode.yaml bestand aanmaakt, bijwerkt en het federatieve netwerk op de hoogte stelt van eventuele wijzigingen in de beschrijving van uw organisatie.

U kunt deze workflow op de volgende manier gebruiken:

  1. Maak binnen de repository van uw component een directory aan met de naam .github (als u deze nog niet heeft).
  2. Maak binnen deze directory een map workflows aan, die zelf binnen een .github map hoort te zitten. Plaats daarin deze workflow.yaml.
  3. Commit en push het workflow-bestand naar jouw repository.

Handmatig Maken

U kunt er ook voor kiezen om handmatig een publicorganisation.yaml-bestand in uw repository op te nemen. Houdt er in dat geval rekening mee dat het tot 24 uur kan duren voordat wijzigingen in het federatieve netwerk zichtbaar worden.

  1. Maak een publiccode.yaml bestand in de root van jouw repository met een teksteditor of een geïntegreerde ontwikkelomgeving (IDE).
  2. Voeg de vereiste metadata toe aan het publiccode.yaml bestand. Een voorbeeld van een basisstructuur tref je hieronder.
  3. Voeg eventuele aanvullende metadata toe die relevant kan zijn voor jouw component, zoals documentatie, afhankelijkheden, contactinformatie of onderhoudsinformatie.
  4. Commit en push het publiccode.yaml bestand naar jouw repository. Houd er rekening mee dat het de eerste keer tot 24 uur kan duren voordat OpenCatalogi je component indexeert.

Voorbeeld

publiccodeYmlVersion: "0.2"
# Pas dit voorbeeld aan op basis van de specificaties van jouw component. Een volledige beschrijving van de publiccode standaard vind je op [yml.publiccode.tools](https://yml.publiccode.tools/schema.core.html#top-level-keys-and-sections)
name: Medusa
url: "https://example.com/italia/medusa.git"
softwareVersion: "dev" # Optional
releaseDate: "2017-04-15"
platforms:
- web

categories:
- financial-reporting

developmentStatus: development

softwareType: "standalone/desktop"

description:
en:
localisedName: medusa # Optional
shortDescription: >
A short description of the software.

longDescription: >
Very long description of this software, also split
on multiple rows. You should note what the software
is and why one should need it. We can potentially
have many pages of text here.

features:
- Just one feature

legal:
license: AGPL-3.0-or-later

maintenance:
type: "community"

contacts:
- name: Francesco Rossi

localisation:
localisationReady: true
availableLanguages:
- en
# De Nederlandse uitbreiding op de Common Ground standaard
nl:
countryExtensionVersion: "1.0"
commonground:
- layerType: "interface"
- installationType: "helm"
- intendedOrganisations: "https://github.com/Rotterdam"
gemma:
bedrijfsfuncties:
- "sadsad"
- "sadsad"
bedrijfsservices:
- "sadsad"
- "sadsad"
applicatiefunctie: "referentie component"

Zijn er mininmum eisen aan een publiccode?

Nee, de publiccode.yaml mag zelfs leeg zijn. Puur het plaatsen daarvan in een open toegankenlijke repository spreekt de intentie uit om een opensource oplossing aan te bieden en is voldoende om te worden mee genomen in de indexatie. In het geval bepaalde gegevens missen worden deze aangevuld vanuit de repository (naam, beschrijving, organisatie, url, licentie).

Welke velden kan ik verwachten in een publiccode?

In een publiccode.yaml bestand zijn er verschillende properties die gedefinieerd kunnen worden om verschillende aspecten van de software of het project te beschrijven. Deze properties variëren van het geven van basisinformatie zoals de naam van de software, tot meer specifieke informatie zoals de gebruikte licentie of de ontwikkelstatus van de software. De volgende tabel geeft een overzicht van de mogelijke properties, of ze verplicht zijn of niet, wat het verwachte type input is en een korte beschrijving van elk.

Hier is een voorbeeld van hoe de tabel eruit kan zien, gebaseerd op de standaard die wordt beschreven op yml.publiccode.tools en uitgewerkt onder top level formats op docs.italia.it.:

PropertyVerplichtVerwachte InputDefaultEnumVoorbeeldBeschrijving
publiccodeYmlVersionNeeString (SEMVER)0.2Nee0.2This key specifies the version to which the current publiccode.yml adheres to, for forward compatibility.
nameNeeStringDe naam ven de repository waarin de public code is gevondenNeeMedusaThis key contains the name of the software. It contains the (short) public name of the product, which can be localised in the specific localisation section. It should be the name most people usually refer to the software. In case the software has both an internal "code" name and a commercial name, use the commercial name.
applicationSuiteNeeStringn.v.tNeeMegaProductivitySuiteThis key contains the name of the "suite" to which the software belongs.
urlNeeString (URL)De url van de repository waarin de public code is gevondenNeehttps://example.com/italia/medusa.gitA unique identifier for this software. This string must be a URL to the source code repository (git, svn, ...) in which the software is published. If the repository is available under multiple protocols, prefer HTTP/HTTPS URLs which don't require user authentication. Forks created for the purpose of contributing upstream should not modify this file; this helps software parsing publiccode.yml to immediately skip technical forks. On the contrary, a complete fork that is meant to be maintained separately from the original software should modify this line, to give themselves the status of a different project.
landingURLNeeString (URL)De url onder repository settings (indien opgegeven)Neehttps://example.com/italia/medusaIf the url parameter does not serve a human readable or browsable page, but only serves source code to a source control client, with this key you have an option to specify a landing page. This page, ideally, is where your users will land when they will click a button labeled something like "Go to the application source code". In case the product provides an automated graphical installer, this URL can point to a page which contains a reference to the source code but also offers the download of such an installer.
isBasedOnNeeString (URL)N.v.t.Neehttps://example.com/italia/medusa.giIn case this software is a variant or a fork of another software, which might or might not contain a publiccode.yml file, this key will contain the url of the original project(s).The existence of this key identifies the fork as a software variant, descending from the specified repositories..
softwareVersionNeeString (SEMVER)N.v.t.Nee1.0This key contains the latest stable version number of the software. The version number is a string that is not meant to be interpreted and parsed but just displayed; parsers should not assume semantic versioning or any other specific version format.The key can be omitted if the software is currently in initial development and has never been released yet.
releaseDateNeeString (DATE)De creatie datum van de repository (indien opgegeven)Nee2023-01-01This key contains the date at which the latest version was released. This date is mandatory if the software has been released at least once and thus the version number is present.
createdDateNeeString (DATE)De creatie datum van de repository (indien opgegeven)Nee2023-01-01This key contains the date at which the latest version was released. This date is mandatory if the software has been released at least once and thus the version number is present.
logoNeeStringDe afbeedling van de repository (indien opgegeven)Neeimg/logo.svgThis key contains the path to the logo of the software. Logos should be in vector format; raster formats are only allowed as a fallback. In this case, they should be transparent PNGs, minimum 1000px of width. The key value can be the relative path to the file starting from the root of the repository, or it can be an absolute URL pointing to the logo in raw version. In both cases, the file must reside inside the same repository where the publiccode.yml file is stored.
monochromeLogoNeeStringN.v.t.Neeimg/logo-mono.svgA monochromatic (black) logo. The logo should be in vector format; raster formats are only allowed as a fallback. In this case, they should be transparent PNGs, minimum 1000px of width. The key value can be the relative path to the file starting from the root of the repository, or it can be an absolute URL pointing to the logo in raw version. In both cases, the file must reside inside the same repository where the publiccode.yml file is stored.
platformsNeeLijstN.v.t.web, windows, mac, linux, ios, android, haven,kubernetes,azure,aws0.2This key specifies which platform the software runs on. It is meant to describe the platforms that users will use to access and operate the software, rather than the platform the software itself runs on.Use the predefined values if possible. If the software runs on a platform for which a predefined value is not available, a different value can be used.
categoriesNeeLijstN.v.t.Any of the catagories list.0.2A list of words that can be used to describe the software and can help building catalogs of open software.
usedByNeeLijstN.v.t.Neen.v.tWebsites of github organisatie pagina's van organisaties die dit component gebruiken
supportedByNeeLijstN.v.t.Neen.v.tWebsites of github organisatie pagina's van organisaties die services en diensten afgeven op dit component
roadmapNeeString (URL)N.v.t.Neehttps://example.com/italia/medusa/roadmapA link to a public roadmap of the software.
developmentStatusNeeStringN.v.t.'concept', 'development', 'beta', 'stable', 'obsolete'stableDe huidige ontwikkelstatus van de software.
softwareTypeNeeStringN.v.t.'standalone/mobile', 'standalone/iot', 'standalone/desktop', 'standalone/web', 'standalone/backend', 'standalone/other', 'addon', 'library', 'configurationFiles'0.2Het type software (e.g., standalone, library, etc.).
intendedaudienceNeeObjectN.v.t.Neen.v.t.Bevat de licentie onder welke de software is vrijgegeven.
descriptionNeeObjectDe beschrijving van de repository waarind e publiccode is gevondenNee0.2Bevat gelokaliseerde namen en beschrijvingen van de software.
legalNeeObjectDe licentie van de repository (indien opgegeven)Neen.v.t.Bevat de doelgroepen voor de applicatie.
maintenanceNeeObjectN.v.t.Neen.v.t.Bevat onderhoudsinformatie voor de software.
localisationNeeObjectN.v.t.Neen.v.t.Bevat informatie over de beschikbare talen van de software.
dependsOnNeeObjectN.v.t.Neen.v.t.Bevat de afhankenlijkheden (componenten) van de applicatie.
nlNeeobjectN.v.t.Neen.v.t.A link to a public roadmap of the software.
inputTypesNeearray (String)N.v.t.as per RFC 6838
outputTypesNeearray (String)N.v.t.as per RFC 6838
hiddenNeeObjectN.v.t.Neen.v.t.
downloadsNeeObjectN.v.t.Neen.v.t.
uplNeearray (String)N.v.t.N.v.t.One or more from the UPL list, defines products provided by this sotware
bedrijfsfunctiesNeeArray (STRING)n.v.tn.v.tEen of meerdere bedrijfsfuncties
bedrijfsservicesNeeArray (STRING)n.v.t.n.v.tEen of meerdere [bedrijfsservices]

Dat laat dus een aantal mogelijke subobjecten over:

description

Conform specs description.

intended audience

Conform specs description.

description

Conform specs description.

Conform specs description.

maintenance

Conform specs description.

localisation

Conform specs description.

dependsOn

Conform specs description.

nl

Een (concept) Nederlandse uitbreiding op de publiccode standaard in lijn met de mogelijkheid tot regionale uitbreidingen.

PropertyVerplichtVerwachte InputDefaultEnumBeschrijving
countryExtensionVersionJaString (SEMVER)N.v.t.N.v.t.This key specifies the version to which the current extension schema adheres to, for forward compatibility.Please note how the value of this key is independent from the top-level publiccodeYmlVersion one (see The Standard (core)). In such a way, the extensions schema versioning is independent both from the core version of the schema and from every other Country.
commongroundNeeStringN.v.t.N.v.t.An object describing the commonground attributes of this software, look bellow for the object definitions.
gemmaNeeString (URL)N.v.t.N.v.t.An object describing the GEMMA attributes of this software, look bellow for the object definitions.
uplNeearray (String)N.v.t.N.v.t.One or more from the UPL list, defines products provided by this sotware

Dit leidt tot de volgende subobjecten:

Commonground

PropertyVerplichtVerwachte InputDefaultEnumBeschrijving
intendedOrganisationsNeeArrayn.v.tn.v.t.This key specifies the version to which the current extension schema adheres to, for forward compatibility.Please note how the value of this key is independent from the top-level publiccodeYmlVersion one (see The Standard (core)). In such a way, the extensions schema versioning is independent both from the core version of the schema and from every other Country.
installationTypeNeeStringn.v.t.self, helm, provisionDefines how the software should be installed
layerTypeNeeStringn.v.tinterface, integration, data, service, processAn extension to public code based on the componentencatalogus. Refers to the layer on wich the component oprates.

Gemma

PropertyVerplichtVerwachte InputDefaultEnumBeschrijving
bedrijfsfunctiesNeeArray (STRING)n.v.tn.v.tEen of meerdere bedrijfsfuncties
bedrijfsservicesNeeArray (STRING)n.v.t.n.v.tEen of meerdere [bedrijfsservices]
applicatiefunctieNeeStringn.v.tn.v.tEen van de mogenlijke applicatie functies
modelNeeStringn.v.tsemantic, conceptual,logical, physicalHet soort model (mag alleen worden gebruikt als het type schema is).

In theorie zijn er meer mogelijke Nederlandse utibreidingen te bedenken, maar voor fase 1 hebben we ons bewust tot het bovenstaande beperkt.

Zijn er uitbreidingen op en afwijkingen van de publiccode standaard?

We hebben op verschillende plekken afgeweken en uitgebreid op de publiccode standaard, met namen omdat deze te beperkend bleek. We hebben er overal voor gekozen om aan te vullen of eisen te verlagen. Dat betekent dat een (volgens de standaard) geldige publiccode.yaml ook voor OC werkt maar dat je aanvullende informatie zou kunnen opnemen.

Bij het veld softwareType ondersteunen we extra mogelijkheden

Software TypeBeschrijving
standalone/mobileThe software is a standalone, self-contained. The software is a native mobile app.
standalone/iotThe software is suitable for an IoT context.
standalone/desktopThe software is typically installed and run in a a desktop operating system environment.
standalone/webThe software represents a web application usable by means of a browser.
standalone/backendThe software is a backend application.
standalone/otherThe software has a different nature from the ones listed above.
softwareAddonThe software is an addon, such as a plugin or a theme, for a more complex software.
libraryThe software contains a library or an SDK to make it easier to third party developers.
configurationFilesThe software does not contain executable script but a set of configuration files.
apiThe repository/folder doesn't contain software but an OAS api description.
schemaThe repository/folder doesn't contain software but a schema.json object description.
dataThe repository/folder doesn't contain software but a public data file (e.g. csv, xml etc).
processThe repository/folder doesn't contain software but an executable process (e.g. bpmn2, camunda).
modelThe repository/folder doesn't contain software but a model (e.g. uml).

Bij het veld platforms ondersteunen we extra opties "haven", "kubernetes", "azure", "aws"

Daarnaast zijn in de normale versie van de standaard de velden "publiccodeYmlVersion", "name", "url" verplicht en kent Public Code vanuit de standaard geen default values (die wij onttrekken aan de repository)

Bij logo laten we naast een relatief pad ook een absolute URL naar het logo toe.

Monorepo

Het kan voorkomen dat uw organisatie code en documenten niet over meerdere repositories verdeeld maar alles opslaat in één repository, een zogenoemde monorepo. In dat geval is het mogenlijk om meerdere Open Catalogi publicaties vanuit dezelfde repository te publiceren. Voor het het publiceren van een tweede publicatie kunt u simpelweg een tweede publiccode.yaml in de repository toevoegen (let er hierbij wel op dat er geen twee publiccode bestanden in één folder kunnen staan).

Let er wel op de alle verijkings functies op repositorie niveau gaan, met andere woorden als bijvoorbeeld de beschrijving in de publiccode zal die worden overgenomen vanuti de repository. Het zelfde geld ook voor de punten beoordeling van de publicatie.

Parsing en verschil tussen publiccode.yaml en Open Catalogi datamodel

Zo als je welicht opvalt wijkt de publicode.yaml af van de Open catalogi api en data model, dat komt omdat voor een aantal properties binnen Open Catalogi in het datamodel objecten worden gebruikt. Bij het inlezen van de publiccode worden de daar aangetroffen waarden omgezet naar objecten en indien nodig verijkt. Dit betreft

Property
applicationSuite
url
usedBy
supportedBy
rating
downloads