Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hvordan vedlikeholdes kodeliste-oppføringer? #147

Open
petterreinholdtsen opened this issue Apr 19, 2019 · 4 comments
Open

Hvordan vedlikeholdes kodeliste-oppføringer? #147

petterreinholdtsen opened this issue Apr 19, 2019 · 4 comments
Assignees
Labels
Høst 2019 Høst 2019 - vurderes for versjon 2.0

Comments

@petterreinholdtsen
Copy link
Collaborator

Dette er en mangelmelding som kun er registrert på github, og ikke er sendt inn til Arkivverkets postmottak. Se også https://github.com/petterreinholdtsen/noark5-tester/blob/master/mangelmelding/sendt/2019-04-19-vedlikeholde-kodelister.md .


       Prosjekt  Noark 5 Tjenestegresesnitt
       Kategori  Versjon 1.0 beta
    Alvorlighet  protest
   Meldingstype  utelatt
Brukerreferanse  [email protected]
    Dokumentdel  7.2.2 (Kodelister)
     Sidenummer  165
    Linjenummer  n/a
Innsendingsdato  2019-04-19

Denne teksten er del av en samling innspill til Noark5-standarden tilgjengelig fra https://github.com/petterreinholdtsen/noark5-tester/.

Beskrivelse

Dette gjelder del 7.2.2 (Kodelister) på side 165 og etterfølgende sider.

Det fremgår ikke fra spesifikasjonen hvordan kodelister og andre metadatalister får nye oppføringer, eller hvordan utdaterte oppføringer fjernes. Det er ikke oppgitt noen ny-* type relasjoner for disse, og det er ikke nevnt noe om hvor de kan finnes. Uten slike operasjoner vil det ikke være mulig å vedlikeholde kodelistene via API-et.

Det mangler både informasjon om hvordan POST for nye oppføringer skal fungere (dvs. hvordan ny-* URL der slike POST skal gjøres skal finnes) og hva som er den unike URL for hver enkelt metadataoppføring der PUT og DELETE skal utføres.

I GeoIntegrasjons-spesifikasjonen har alle oppføringer i kodelister en bolsk verdi "erGyldig" som jeg antar markerer om kodeverdien kan brukes ved oppretting og endring av instanser som bruker kodelisten, for å sikre at utdaterte kodelisteverdier fortsatt er registrert i databasen selv om de ikke lenger skal brukes. Det virker som en god ide også for tjenestegrensesnittet. Foreslår at dette feltet heter "aktiv" og antas å være "true" hvis det ikke er satt, slik at det kun skal være satt for verdier som ikke skal brukes.

En ide for oppretting er å gjøre tilsvarende som for http://localhost:49708/api/arkivstruktur , der det finnes relasjonsnøkler for .../ny-arkivskaper/ og .../ny-arkiv/ for å lage nye instanser av arkivskaper og arkiv. Ideen er å definiere et nytt relasjonsnøkkeltre med base http://rel.arkivverket.no/noark5/v4/api/metadata/ der alle ny-*-relasjonene for oppretting av nye metadataoppføringer listes opp, tilsvarende det som beskrives i mangelmelding #107 for arkivstruktur og sakarkiv. Det nye relasjonsnøkkeltreet bør inneholde lenke til alle kodelister som er tilgjengelig. Slike ny-*-relasjoner skal kun være synlige for priviligerte brukere som har rett til å opprette nye kodelisteoppføringer. I tillegg til POST må i hvert fall operasjonene GET og OPTIONS (helst også PATCH) fungere på disse ny-*-oppføringene, tilsvarende for andre ny-*-operasjoner.

En tilsvarende ide for oppdatering og sletting er å gi hver kodeliste-oppføring en SystemID og 'self'-relasjonnøkkel, for eksempel for dokumentmedium href vil være http://localhost:49708/api/metadata/dokumentmedium/<systemID>/, som så kan brukes til PUT og DELETE-opperasjoner ved oppdatering og sletting. Den bør naturligvis også fungere for GET for å kunne vite hva som kan endres, selv om den normale måten å få ut kodelister og andre metadata vil være å hente ut listen via den kjente relasjonsnøkkelen bruker, for eksempel http://rel.kxml.no/noark5/v4/api/metadata/dokumentmedium/ for alle dokumentmedium.

Her er for eksempel hvordan arkivstatus kan se ut når en tar GET mot href for relasjonen http://rel.kxml.no/noark5/v4/api/metadata/arkivstatus/:

{
  "results": [
    {
      "systemID": "9ed3f5d3-9934-446d-85b8-b2ada9498aa7",
      "kode": "O",
      "beskrivelse": "Opprettet",
      "_links": [
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/9ed3f5d3-9934-446d-85b8-b2ada9498aa7/",
          "rel": "self"
        },
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/9ed3f5d3-9934-446d-85b8-b2ada9498aa7/",
          "rel": "http://rel.kxml.no/noark5/v4/api/metadata/arkivstatus/"
        }
      ]
    },
    {
      "systemID": "b94eb9cf-e71f-4d68-964b-b68c7f9962b6",
      "kode": "A",
      "beskrivelse": "Avsluttet",
      "_links": [
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/b94eb9cf-e71f-4d68-964b-b68c7f9962b6/",
          "rel": "self"
        },
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/b94eb9cf-e71f-4d68-964b-b68c7f9962b6/",
          "rel": "http://rel.kxml.no/noark5/v4/api/metadata/arkivstatus/"
        }
      ]
    },
    {
      "systemID": "43421e68-62bf-11e9-ae3a-002354090596",
      "kode": "U",
      "beskrivelse": "Påtenkt",
      "aktiv": false,
      "_links": [
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/43421e68-62bf-11e9-ae3a-002354090596/",
          "rel": "self"
        },
        {
          "href": "http://localhost:49708/api/metadata/arkivstatus/43421e68-62bf-11e9-ae3a-002354090596/",
          "rel": "http://rel.kxml.no/noark5/v4/api/metadata/arkivstatus/"
        }
      ]
    }
  ],
  "_links": [
    {
      "href": "http://localhost:49708/api/metadata/arkivstatus/",
      "rel": "self",
    }, {
      "href": "http://localhost:49708/api/metadata/arkivstatus/",
      "rel": "http://rel.kxml.no/noark5/v4/api/metadata/arkivstatus/"
    }
  ]
}

Det bør være krav om at DELETE av en eller flere kodeliste-verdier kun kan gjennomføres hvis det ikke finnes noen instanser i databasen som bruker den aktuelle kodeliste-verdien.

Ønsket endring

Legg inn i starten av dokumentdel 7.2.2 (Kodelister) en gjennomgang av hvordan kodelister representeres i JSON og hva som gjelder generelt for slike kodelister, der det står at de har SystemID og "self"-relasjonsnøkkel som kan brukes ved oppdatering og sletting. Definer relasjonsnøkler ny-* for å opprette nye kodelisteoppføringer for hver enkelt kodeliste.

Beskriv videre i samme del hvilke relasjonsnøkler som skal være tilgjengelig på metadata-nivåen under toppen, ala det som er beskrevet i mangelmelding #107 for andre deler av API-et.

Jeg sender inn konkret forslag til endring som patch via github.

@petterreinholdtsen petterreinholdtsen added protest spesifikasjonen bør ikke godkjennes før mangelen er utbedret utelatt spesifikasjonen mangler noe som burde vært omtalt labels Apr 19, 2019
@hanber
Copy link
Contributor

hanber commented Jun 5, 2019

Endrer fra aktiv til inaktiv. Vi må se på håndtering av kodelister relatert til kodelistekatalog i Felles datakatalog.

@AnnKnu
Copy link
Contributor

AnnKnu commented Jun 19, 2019

@hanber kan denne lukkes?

@petterreinholdtsen
Copy link
Collaborator Author

Jeg har ikke skrevet det konkrete endringsforslaget som løser denne mangelmeldingen. Endringen foreslått for å fikse #148 løser andre mangler med kodelister, men er ikke oppdatert til å bruke 'inaktiv' i stedet for 'aktiv', og må skrives om til å dokumentere at kodelisteverdier skal kopieres inn i instanser ved endring, slik at eventuelle endringer i kodelisteverdier i kodelistene ikke påvirker eksisterende instanser.

@monadani
Copy link
Collaborator

monadani commented Jul 4, 2019

Antar at dette tas høst 2019?

@monadani monadani added Høst 2019 Høst 2019 - vurderes for versjon 2.0 and removed protest spesifikasjonen bør ikke godkjennes før mangelen er utbedret utelatt spesifikasjonen mangler noe som burde vært omtalt labels Jul 4, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Høst 2019 Høst 2019 - vurderes for versjon 2.0
Projects
None yet
Development

No branches or pull requests

4 participants