DES offline/Schnittstelle: Unterschied zwischen den Versionen

aus GenWiki, dem genealogischen Lexikon zum Mitmachen.
Zur Navigation springen Zur Suche springen
K (neue Extension f³r Syntax-Highlighting)
K (Automatic page editing)
Zeile 28: Zeile 28:
     </row>
     </row>
   </transcription>
   </transcription>
</page></xml>
</page></source>


=== defekte Seite melden ===
=== defekte Seite melden ===
Zeile 34: Zeile 34:
   
   
  POST /extern/badPage/$PAGE_ID$
  POST /extern/badPage/$PAGE_ID$
<source lang="xml"><comment>Seite nur halb im Bild</comment></xml>
<source lang="xml"><comment>Seite nur halb im Bild</comment></source>


* Eingabe
* Eingabe
Zeile 64: Zeile 64:
     </column>
     </column>
   </columns>
   </columns>
</project></xml>
</project></source>


=== Daten einschicken ===
=== Daten einschicken ===
Zeile 77: Zeile 77:
     <cell>Musterstadt</cell>
     <cell>Musterstadt</cell>
   </row>
   </row>
</transcription></xml>
</transcription></source>


=== Seite (unbearbeitet) freigeben ===
=== Seite (unbearbeitet) freigeben ===
Zeile 102: Zeile 102:
     <name>Testproject 2</name>
     <name>Testproject 2</name>
   </project>
   </project>
</projects></xml>
</projects></source>

Version vom 3. Juni 2009, 19:38 Uhr

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/project/$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>