DES offline/Schnittstelle

aus GenWiki, dem genealogischen Lexikon zum Mitmachen.
< DES offline(Weitergeleitet von DES/Schnittstelle)
Zur Navigation springen Zur Suche springen
Veralteter Inhalt
Die Inhalte dieser Seite sind veraltet und nicht mehr gültig. Sie werden nur noch als Archiv für historische Betrachtungen bereitgehalten.



Schnittstelle

Die Clients kommunizieren mit dem Server über eine Schnittstelle mit den folgenden Operationen. Bei allen Anfragen müssen Benutzername und Paßwort übermittelt werden.

neue Seite abrufen

Der Bearbeiter fordert für ein angegebenes Projekt eine neue Seite an. Serverseitig wird eine zu bearbeitende Seite aus dem Projekt ausgewählt und Informationen zu Bilddatei und möglicherweise bereits erfaßte Daten der Seite an den Client geschickt.

GET /extern/newPage/$PROJECT_ID$
  • Eingabe
    • Kennung des Projekts
  • Antwort
    • Kennung der Seite
    • URL zum Scan
    • Seitenzahl (beginnend bei 0 bei mehrseitigen Scans, sonst 0)
    • MIME-Type des Scans
    • Termin Abgabeschluß
    • bisher eingegebene Daten
<page id='1'>
  <url>http://wiki-commons.genealogy.net/images/2/2f/GDM_program_example04.png</url>
  <page-number>0</page-number>
  <mime-type>image/png</mime-type>
  <expires>Sun Jan 18 14:09:23 CET 2009</expires>
  <transcription>
    <row nr='8'>
      <cell nr='3'>Max</cell>
      <cell nr='4'>Mustermann</cell>
    </row>
  </transcription>
</page>

defekte Seite melden

Mit Hilfe dieser Operation meldet ein Bearbeiter eine defekte Seite. Sie wird entsprechend markiert und ist anschließend nicht mehr dem Bearbeiter zugeordnet.

POST /extern/badPage/$PAGE_ID$
<comment>Seite nur halb im Bild</comment>
  • Eingabe
    • Kennung der Seite
    • Text mit Beschreibung des Defekts
  • keine Ausgabe

Informationen zu einem Projekt abrufen

Mit dieser Operation bekommt man Informationen über ein Projekt, unter anderem über die Struktur der zu erfassenden Daten.

GET /extern/getProject/$PROJECT_ID$
  • Eingabe
    • Kennung des Projekts
  • Ausgabe
<project id='1'>
  <name>Testproject 1</name>
  <editingTime>10</editingTime>
  <columns>
    <column>
      <type>string</type>
      <name lang='de'>Familienname</name>
      <name lang='en'>family name</name>
    </column>
    <column>
      <type>string</type>
      <name lang='de'>Vorname</name>
      <name lang='en'>given name</name>
    </column>
  </columns>
</project>

Daten einschicken

Hat ein Bearbeiter eine Seite komplett bearbeitet, schickt er mit dieser Operation die Daten an den Server. Dort werden die Daten gespeichert und der Status der Seite (entsprechend des Zustandsgraphen) aktualisiert.

POST /extern/submitData/$PAGE_ID$
<transcription>
  <row>
    <cell>Max</cell>
    <cell>Mustermann</cell>
    <cell>12345</cell>
    <cell>Musterstadt</cell>
  </row>
</transcription>

Seite (unbearbeitet) freigeben

Ein Bearbeiter löst die Zuordnung einer Seite zu ihm ohne die Seite komplett bearbeitet und Daten übertragen zu haben. Anschließend steht die Seite anderen Bearbeitern zur Verfügung.

POST /extern/releasePage/$PAGE_ID$
  • Eingabe
    • Kennung der Seite
  • keine Ausgabe

Liste der Projekte abrufen

Der Server sendet eine Liste aller aktuellen Projekte.

GET /extern/projectList
  • keine Eingabe
  • Ausgabe
<projects>
  <project id='1'>
    <name>Testproject 1</name>
  </project>
  <project id='2'>
    <name>Testproject 2</name>
  </project>
</projects>