Änderungen von Dokument 08 Schnittstelle ONYX Reporter

Zuletzt geändert von Carina Enke am 26.11.2025

Von Version 375.1
bearbeitet von tleu
am 01.12.2014
Änderungskommentar: Es gibt keinen Kommentar für diese Version
Auf Version 404.1
bearbeitet von Carina Enke
am 26.11.2025
Änderungskommentar: Migrated property [stableId] from class [Confluence.Code.ConfluencePageClass]

Zusammenfassung

Details

Seiteneigenschaften
Titel
... ... @@ -1,1 +1,1 @@
1 -Schnittstelle ONYX Reporter
1 +08 Schnittstelle ONYX Reporter
Übergeordnete Seite
... ... @@ -1,0 +1,1 @@
1 +ONYX.Systeminformationen.WebHome
Dokument-Autor
... ... @@ -1,1 +1,1 @@
1 -XWiki.tleu
1 +XWiki.carina
Inhalt
... ... @@ -1,47 +1,25 @@
1 -{{layout}}
2 -{{layout-section ac:type="two_right_sidebar"}}
3 -{{layout-cell}}
4 -====== Inhalt: ======
1 +{{section}}
2 +{{column width="60%"}}
3 +
4 +{{/column}}
5 5  
6 +{{column width="30%"}}
7 +{{panel title="Inhalt"}}
8 +{{toc start="2"/}}
9 +{{/panel}}
6 6  
11 +{{panel title="Weiterführende Inhalte"}}
12 +* [[Schnittstelle ONYX Player>>doc:ONYX.Systeminformationen.Schnittstelle ONYX Player.WebHome]]
13 +{{/panel}}
14 +{{/column}}
15 +{{/section}}
7 7  
8 -{{toc style="square" maxLevel="5" outline="true" absoluteUrl="true"/}}
9 -{{/layout-cell}}
10 10  
11 -{{layout-cell}}
12 -|=(% colspan="1" %)(% colspan="1" %)
13 -(((
14 -Programmversion
15 -)))|(% colspan="1" %)(% colspan="1" %)
16 -(((
17 -
18 -)))
19 -|=(((
20 -Status
21 -)))|(((
22 -(% class="status-macro aui-lozenge aui-lozenge-error" %)ENTWURF
23 -)))
24 -|=(((
25 -Aufgaben
26 -)))|(((
27 -
28 -
29 -
30 -)))
31 -|=(((
32 -JIRA
33 -)))|(((
34 -
35 -)))
36 -{{/layout-cell}}
37 -{{/layout-section}}
38 -
39 -{{layout-section ac:type="single"}}
40 -{{layout-cell}}
41 41  == Allgemeines ==
42 42  
43 43  Über die Schnittstelle zum ONYX WebReporter erfolgt jede Kommunikation zwischen dem LMS und dem Reporter. Dazu erfolgt eine Reihe von Aufrufen:
44 44  
22 +(% class="wrapped" %)
45 45  |(((
46 46  armSite
47 47  )))|(((
... ... @@ -60,9 +60,7 @@
60 60  |(((
61 61  getResultValues
62 62  )))|(((
63 -Gibt alle bzw. die angeforderten Resultate für den Test zurück. Voraussetzung:
64 -
65 -Es ist nur exakt ein Student in der bei initiateSite übertragenen Liste.
41 +Gibt alle bzw. die angeforderten Resultate für den Test zurück. Voraussetzung: Es ist nur exakt ein Student in der bei initiateSite übertragenen Liste.
66 66  )))
67 67  |(% colspan="1" %)(% colspan="1" %)
68 68  (((
... ... @@ -74,7 +74,8 @@
74 74  
75 75  == Anmeldung des LMS ==
76 76  
77 -{{code title="Anmeldung des LMS" language="xml"}}@WebMethod(operationName = „armSite")
53 +{{code language="xml" title="Anmeldung des LMS"}}
54 +@WebMethod(operationName = „armSite")
78 78  public String armSite(
79 79  @WebParam(name = „version") final Integer version,
80 80  @WebParam(name = „userId") final String userId,
... ... @@ -83,53 +83,286 @@
83 83  @WebParam(name = „optionalUserLastName") final String userLastName,
84 84  @WebParam(name = „optionalUserFirstName") final String userFirstName,
85 85  @WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
86 -}{{/code}}Parameter armSite
63 +}
64 +{{/code}}
87 87  
66 +=== Parameter armSite ===
67 +
68 +(% class="wrapped" %)
88 88  |(((
89 -
70 +version
90 90  )))|(((
91 -
72 +Angefragte Version: 1
92 92  )))
93 93  |(((
94 -
75 +userId
95 95  )))|(((
96 -
77 +UserId des anfragenden Reporter-Benutzers
97 97  )))
98 98  |(((
99 -
80 +optionalRole
100 100  )))|(((
101 -
82 +Optional. Rolle des Benutzers. 0 = Student, 1= Tutor
102 102  )))
103 103  |(((
104 -
85 +secretToShare
105 105  )))|(((
106 -
87 +Ein geheimer String, mit dessen Hilfe Server und Client ihre Kommunikation verschlüsseln. Muss bei jeder weiteren Kommunikation gleich bleiben.
107 107  )))
108 108  |(((
109 -
90 +optionalUserLastName
110 110  )))|(((
111 -
92 +Optional. Nachname des Benutzers.
112 112  )))
94 +|(% colspan="1" %)(% colspan="1" %)
95 +(((
96 +optionalUserFirstName
97 +)))|(% colspan="1" %)(% colspan="1" %)
98 +(((
99 +Optional. Vorname des Benutzers.
100 +)))
101 +|(% colspan="1" %)(% colspan="1" %)
102 +(((
103 +additionalParams
104 +)))|(% colspan="1" %)(% colspan="1" %)
105 +(((
106 +Reserved for future use.
107 +)))
113 113  
114 -= Überschrift2 =
109 +=== ReturnValue armSite ===
115 115  
116 -Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aliquam fermentum vestibulum est. Cras rhoncus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Sed quis tortor. Donec non ipsum. Mauris condimentum, odio nec porta tristique, ante neque malesuada massa, in dignissim eros velit at tellus. Donec et risus in ligula eleifend consectetuer. Donec volutpat eleifend augue. Integer gravida sodales leo. Nunc vehicula neque ac erat. Vivamus non nisl. Fusce ac magna. Suspendisse euismod libero eget mauris.
117 -{{/layout-cell}}
118 -{{/layout-section}}
111 +(% class="wrapped" %)
112 +|(((
113 +String
114 +)))|(((
115 +Session ID, mit der alle weiteren Reporter-Aufrufe gekennzeichnet werden müssen.
116 +)))
119 119  
120 -{{layout-section ac:type="two_right_sidebar"}}
121 -{{layout-cell}}
122 -====== untergeordnete Seiten: ======
118 +== Initialisierung durch LMS ==
123 123  
120 +{{code language="xml" title="Initialisierung durch LMS"}}
121 +@WebMethod(operationName = „initiateSite")
122 +public String initiateSite(
123 +@WebParam(name = „version") final Integer version,
124 +@WebParam(name = „sessionId") final String sessionId,
125 +@WebParam(name = „secretToShare") final String secretToShare,
126 +@WebParam(name = „students") final ArrayList<ResultsForStudent> students,
127 +@WebParam(name = „optionalContentPackage") final byte[] contentPackage,
128 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
129 +}
130 +{{/code}}
124 124  
132 +=== Parameter initiateSite ===
125 125  
126 -{{children all="true"/}}
127 -{{/layout-cell}}
134 +(% class="wrapped" %)
135 +|(((
136 +version
137 +)))|(((
138 +Angefragte Version: 1
139 +)))
140 +|(% colspan="1" %)(% colspan="1" %)
141 +(((
142 +sessionId
143 +)))|(% colspan="1" %)(% colspan="1" %)
144 +(((
145 +SessionId, wie von armSite zurück geliefert.
146 +)))
147 +|(((
148 +secretToShare
149 +)))|(((
150 +Ein geheimer String, mit dessen Hilfe Server und Client ihre Kommunikation verschlüsseln. Muss bei jeder weiteren Kommunikation gleich bleiben.
151 +)))
152 +|(((
153 +students
154 +)))|(((
155 +Liste der Studenten mit ihren Resultaten. Siehe unten.
156 +)))
157 +|(((
158 +optionalContentPackage
159 +)))|(((
160 +Optional. Content Package (gezippt) als Byte-Array.
161 +)))
162 +|(((
163 +additionalParams
164 +)))|(((
165 +Reserved for future use.
166 +)))
128 128  
129 -{{layout-cell}}
130 -====== relevante Links: ======
168 +=== ReturnValue initiateSite ===
131 131  
132 -* [[lorem ipsum>>url:https://www.bps-system.de/help/display/OPAL/Handbuch+OPAL||shape="rect"]]
133 -{{/layout-cell}}
134 -{{/layout-section}}
135 -{{/layout}}
170 +(% class="wrapped" %)
171 +|(((
172 +String
173 +)))|(((
174 +Absolute URL der Reporter-Seite für den IFrame. Dieser ist vom LMS durch die folgenden URL-Parameter anzureichern:
175 +
176 +* sid: Session ID, wie von armSite zurück gegeben
177 +* uid: Student ID, wie in initiateSite beim Reporter angemeldet
178 +)))
179 +
180 +{{code language="xml"}}
181 +public class ResultsForStudent {
182 +   private String studentId = „";
183 +   private String firstname = „";
184 +   private String lastname = „";
185 +   private String groupname = „";
186 +   private String tutorname = „";
187 +   private File contentFile = null;
188 +   private byte[] resultsFile = null;
189 +}
190 +{{/code}}
191 +
192 +== Abmeldung durch LMS ==
193 +
194 +
195 +{{code}}
196 +@WebMethod(operationName = „disarmSite")
197 +public Boolean disarmSite(
198 +@WebParam(name = „version") final Integer version,
199 +@WebParam(name = „sessionId") final String sessionId,
200 +@WebParam(name = „secretToShare") final String secretToShare,
201 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
202 +}
203 +{{/code}}
204 +
205 +
206 +=== Parameter disarmSite ===
207 +
208 +(% class="wrapped" %)
209 +|(((
210 +version
211 +)))|(((
212 +Angefragte Version: 1
213 +)))
214 +|(% colspan="1" %)(% colspan="1" %)
215 +(((
216 +sessionId
217 +)))|(% colspan="1" %)(% colspan="1" %)
218 +(((
219 +SessionId, wie von armSite zurück geliefert.
220 +)))
221 +|(((
222 +secretToShare
223 +)))|(((
224 +Ein geheimer String, mit dessen Hilfe Server und Client ihre Kommunikation verschlüsseln. Muss bei jeder weiteren Kommunikation gleich bleiben.
225 +)))
226 +|(((
227 +additionalParams
228 +)))|(((
229 +Reserved for future use.
230 +)))
231 +
232 +=== ReturnValue disarmSite ===
233 +
234 +|(((
235 +Boolean
236 +)))|(((
237 +True bei Erfolg, sonst false.
238 +)))
239 +
240 +== Abfrage von Lernerresultaten durch LMS ==
241 +
242 +{{code language="xml" title="Abfrage von Lernerresultaten durch LMS"}}
243 + @WebMethod(operationName = „getResultValues")
244 +public HashMapWrapper getResultValues(
245 + @WebParam(name = „version") final Integer version,
246 + @WebParam(name = „sessionId") final String sessionId,
247 + @WebParam(name = „secretToShare") final String secretToShare,
248 + @WebParam(name = „requestedValues") final HashMap<String, String>
249 + requestedValues,
250 + @WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
251 +}
252 +{{/code}}
253 +
254 +=== Parameter getResultValues ===
255 +
256 +|(((
257 +version
258 +)))|(((
259 +Angefragte Version: 1
260 +)))
261 +|(% colspan="1" %)(% colspan="1" %)
262 +(((
263 +sessionId
264 +)))|(% colspan="1" %)(% colspan="1" %)
265 +(((
266 +SessionId, wie von armSite zurück geliefert.
267 +)))
268 +|(((
269 +secretToShare
270 +)))|(((
271 +Ein geheimer String, mit dessen Hilfe Server und Client ihre Kommunikation verschlüsseln. Muss bei jeder weiteren Kommunikation gleich bleiben.
272 +)))
273 +|(((
274 +requestedValues
275 +)))|(((
276 +Kann leer sein, dann werden alle Result-Variables zurück geliefert. Sind Keys enthalten, so kommen nur diese zurück.
277 +)))
278 +|(((
279 +additionalParams
280 +)))|(((
281 +Reserved for future use.
282 +)))
283 +
284 +=== ReturnValue getResultValues ===
285 +
286 +|(((
287 +HashMap<String, String>
288 +)))|(((
289 +Map der Result-Variables, Key ist der Variablenname, Value der jeweilige Wert (HashMap ist gewrappt)
290 +)))
291 +
292 +== Abfrage von Ergebnisvariablen durch LMS ==
293 +
294 +{{code language="xml" title="Abfrage von Ergebnisvariablen durch LMS"}}
295 + @WebMethod(operationName = „getResultVariables")
296 +public HashMapWrapper getResultVariables(
297 +@WebParam(name = „version") final Integer version,
298 +@WebParam(name = „contentPackage") final byte[] contentPackage,
299 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
300 +}
301 +{{/code}}
302 +
303 +=== Parameter getResultVariables ===
304 +
305 +|(((
306 +version
307 +)))|(((
308 +Angefragte Version: 1
309 +)))
310 +|(((
311 +contentPackage
312 +)))|(((
313 +Content Package (gezippt) als Byte-Array.
314 +)))
315 +|(((
316 +additionalParams
317 +)))|(((
318 +Reserved for future use.
319 +)))
320 +
321 +=== ReturnValue getResultVariables ===
322 +
323 +|(((
324 +HashMap<String, String>
325 +)))|(((
326 +Map der Result-Variables, Key ist der Variablenname, Value der jeweilige Wert (HashMap ist gewrappt)
327 +)))
328 +
329 +== Wrapper ==
330 +
331 +Da die Übertragung von Maps und Listen über JAX-WS Probleme machen kann, müssen diese gewrappt werden.
332 +
333 +=== Wrapper für die HashMap<String, String> ===
334 +
335 +HashMapWrapper.java:
336 +
337 +[[image:attach:HashMapWrapperjava.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
338 +
339 +[[image:attach:HashMapWrapperjava2.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
340 +
341 +=== Wrapper für die ArrayList<ResultsForStudent> ===
342 +
343 +ResultsForStudentsWrapper.java:
344 +
345 +[[image:attach:ResultsForStudentsWrapperjava.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
HashMapWrapperjava.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiGuest
Größe
... ... @@ -1,0 +1,1 @@
1 +135.3 KB
Inhalt
HashMapWrapperjava2.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiGuest
Größe
... ... @@ -1,0 +1,1 @@
1 +187.3 KB
Inhalt
ResultsForStudentsWrapperjava.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiGuest
Größe
... ... @@ -1,0 +1,1 @@
1 +83.3 KB
Inhalt
Confluence.Code.ConfluencePageClass[0]
id
... ... @@ -1,1 +1,1 @@
1 -3342392
1 +3342390
url
... ... @@ -1,1 +1,1 @@
1 -https://www.bps-system.de/help/display/SOV/wiki/spaces/ONYX/pages/3342392/Schnittstelle ONYX Reporter
1 +https://www.bps-system.de/help/display/SOV/wiki/spaces/ONYX/pages/3342390/Schnittstelle ONYX Reporter