Änderungen von Dokument 08 Schnittstelle ONYX Reporter

Zuletzt geändert von Carina Enke am 26.11.2025

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

Zusammenfassung

Details

Seiteneigenschaften
Titel
... ... @@ -1,1 +1,1 @@
1 -08 Schnittstelle ONYX Reporter
1 +Schnittstelle ONYX Reporter
Übergeordnete Seite
... ... @@ -1,1 +1,0 @@
1 -ONYX.Systeminformationen.WebHome
Dokument-Autor
... ... @@ -1,1 +1,1 @@
1 -XWiki.carina
1 +XWiki.sandra_riediger
Inhalt
... ... @@ -1,25 +1,48 @@
1 -{{section}}
2 -{{column width="60%"}}
3 -
4 -{{/column}}
1 +{{sv-translation language="de"}}
2 +{{layout}}
3 +{{layout-section ac:type="two_right_sidebar"}}
4 +{{layout-cell}}
5 +====== Inhalt: ======
5 5  
6 -{{column width="30%"}}
7 -{{panel title="Inhalt"}}
8 -{{toc start="2"/}}
9 -{{/panel}}
10 10  
11 -{{panel title="Weiterführende Inhalte"}}
12 -* [[Schnittstelle ONYX Player>>doc:ONYX.Systeminformationen.Schnittstelle ONYX Player.WebHome]]
13 -{{/panel}}
14 -{{/column}}
15 -{{/section}}
16 16  
9 +{{toc style="square" maxLevel="5" outline="true" absoluteUrl="true"/}}
10 +{{/layout-cell}}
17 17  
12 +{{layout-cell}}
13 +|=(% colspan="1" %)(% colspan="1" %)
14 +(((
15 +Programmversion
16 +)))|(% colspan="1" %)(% colspan="1" %)
17 +(((
18 +
19 +)))
20 +|=(((
21 +Status
22 +)))|(((
23 +(% class="status-macro aui-lozenge aui-lozenge-error" %)ENTWURF
24 +)))
25 +|=(((
26 +Aufgaben
27 +)))|(((
28 +
29 +
30 +
31 +)))
32 +|=(((
33 +JIRA
34 +)))|(((
35 +
36 +)))
37 +{{/layout-cell}}
38 +{{/layout-section}}
39 +
40 +{{layout-section ac:type="single"}}
41 +{{layout-cell}}
18 18  == Allgemeines ==
19 19  
20 20  Über die Schnittstelle zum ONYX WebReporter erfolgt jede Kommunikation zwischen dem LMS und dem Reporter. Dazu erfolgt eine Reihe von Aufrufen:
21 21  
22 -(% class="wrapped" %)
23 23  |(((
24 24  armSite
25 25  )))|(((
... ... @@ -50,7 +50,7 @@
50 50  
51 51  == Anmeldung des LMS ==
52 52  
53 -{{code language="xml" title="Anmeldung des LMS"}}
76 +{{code title="Anmeldung des LMS" language="xml"}}
54 54  @WebMethod(operationName = „armSite")
55 55  public String armSite(
56 56  @WebParam(name = „version") final Integer version,
... ... @@ -65,7 +65,6 @@
65 65  
66 66  === Parameter armSite ===
67 67  
68 -(% class="wrapped" %)
69 69  |(((
70 70  version
71 71  )))|(((
... ... @@ -108,7 +108,6 @@
108 108  
109 109  === ReturnValue armSite ===
110 110  
111 -(% class="wrapped" %)
112 112  |(((
113 113  String
114 114  )))|(((
... ... @@ -117,7 +117,7 @@
117 117  
118 118  == Initialisierung durch LMS ==
119 119  
120 -{{code language="xml" title="Initialisierung durch LMS"}}
141 +{{code title="Initialisierung durch LMS" language="xml"}}
121 121  @WebMethod(operationName = „initiateSite")
122 122  public String initiateSite(
123 123  @WebParam(name = „version") final Integer version,
... ... @@ -131,7 +131,6 @@
131 131  
132 132  === Parameter initiateSite ===
133 133  
134 -(% class="wrapped" %)
135 135  |(((
136 136  version
137 137  )))|(((
... ... @@ -167,7 +167,6 @@
167 167  
168 168  === ReturnValue initiateSite ===
169 169  
170 -(% class="wrapped" %)
171 171  |(((
172 172  String
173 173  )))|(((
... ... @@ -191,6 +191,7 @@
191 191  
192 192  == Abmeldung durch LMS ==
193 193  
213 +
194 194  
195 195  {{code}}
196 196  @WebMethod(operationName = „disarmSite")
... ... @@ -202,10 +202,10 @@
202 202  }
203 203  {{/code}}
204 204  
225 +
205 205  
206 206  === Parameter disarmSite ===
207 207  
208 -(% class="wrapped" %)
209 209  |(((
210 210  version
211 211  )))|(((
... ... @@ -239,7 +239,7 @@
239 239  
240 240  == Abfrage von Lernerresultaten durch LMS ==
241 241  
242 -{{code language="xml" title="Abfrage von Lernerresultaten durch LMS"}}
262 +{{code title="Abfrage von Lernerresultaten durch LMS" language="xml"}}
243 243   @WebMethod(operationName = „getResultValues")
244 244  public HashMapWrapper getResultValues(
245 245   @WebParam(name = „version") final Integer version,
... ... @@ -291,7 +291,7 @@
291 291  
292 292  == Abfrage von Ergebnisvariablen durch LMS ==
293 293  
294 -{{code language="xml" title="Abfrage von Ergebnisvariablen durch LMS"}}
314 +{{code title="Abfrage von Ergebnisvariablen durch LMS" language="xml"}}
295 295   @WebMethod(operationName = „getResultVariables")
296 296  public HashMapWrapper getResultVariables(
297 297  @WebParam(name = „version") final Integer version,
... ... @@ -328,18 +328,386 @@
328 328  
329 329  == Wrapper ==
330 330  
331 -Da die Übertragung von Maps und Listen über JAX-WS Probleme machen kann, müssen diese gewrappt werden.
351 +Da die Übertragung von Maps und Listen über JAX-WS Probleme macht (clientseitig gefüllte Listen werden leer über den WS versandt und kommen daher auch leer serverseitig an), müssen diese gewrappt werden.
332 332  
333 333  === Wrapper für die HashMap<String, String> ===
334 334  
335 335  HashMapWrapper.java:
336 336  
337 -[[image:attach:HashMapWrapperjava.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
357 +[[image:attach:HashMapWrapperjava.png]]
338 338  
339 -[[image:attach:HashMapWrapperjava2.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
359 +[[image:attach:HashMapWrapperjava2.png]]
340 340  
341 341  === Wrapper für die ArrayList<ResultsForStudent> ===
342 342  
343 343  ResultsForStudentsWrapper.java:
344 344  
345 -[[image:attach:ResultsForStudentsWrapperjava.png||data-xwiki-image-style="img-screen" data-xwiki-image-style-border="true" width="500"]]
365 +[[image:attach:ResultsForStudentsWrapperjava.png]]
366 +{{/layout-cell}}
367 +{{/layout-section}}
368 +
369 +{{layout-section ac:type="two_right_sidebar"}}
370 +{{layout-cell}}
371 +
372 +{{/layout-cell}}
373 +
374 +{{layout-cell}}
375 +====== relevante Links: ======
376 +
377 +* [[doc:Schnittstelle ONYX WebPlayer]]
378 +{{/layout-cell}}
379 +{{/layout-section}}
380 +{{/layout}}
381 +{{/sv-translation}}
382 +
383 +{{sv-translation language="en"}}
384 +{{layout}}
385 +{{layout-section ac:type="two_equal"}}
386 +{{layout-cell}}
387 +====== Content: ======
388 +
389 +
390 +
391 +{{toc style="square" maxLevel="5" outline="true" absoluteUrl="true"/}}
392 +{{/layout-cell}}
393 +
394 +{{layout-cell}}
395 +
396 +{{/layout-cell}}
397 +{{/layout-section}}
398 +
399 +{{layout-section ac:type="single"}}
400 +{{layout-cell}}
401 +
402 +
403 +== General ==
404 +
405 +The API to the ONYX WebReporter enables the communication between the LMS and the reporter. Therefore, a couple of commands will be executed:
406 +
407 +|(((
408 +armSite
409 +)))|(((
410 +Registration of sequence requests at the ONYX reporter
411 +)))
412 +|(((
413 +initiateSite
414 +)))|(((
415 +Initiates the reporter session (transmission of the CP).
416 +)))
417 +|(((
418 +disarmSite
419 +)))|(((
420 +Release of all reporter resources for this session.
421 +)))
422 +|(((
423 +getResultValues
424 +)))|(((
425 +Returns all or all requested results for the test. Condition: there is exactly one student in list transmitted in the initiateSite.
426 +)))
427 +|(% colspan="1" %)(% colspan="1" %)
428 +(((
429 +getResultVariables
430 +)))|(% colspan="1" %)(% colspan="1" %)
431 +(((
432 +Returns all or all requested outcome variables for the test. No armSite, initiateSite or disarmSite is necessary.
433 +)))
434 +
435 +== Connection to the LMS ==
436 +
437 +{{code title="Anmeldung des LMS" language="xml"}}
438 +@WebMethod(operationName = „armSite")
439 +public String armSite(
440 +@WebParam(name = „version") final Integer version,
441 +@WebParam(name = „userId") final String userId,
442 +@WebParam(name = „optionalRole") final Integer role,
443 +@WebParam(name = „secretToShare") final String secretToShare,
444 +@WebParam(name = „optionalUserLastName") final String userLastName,
445 +@WebParam(name = „optionalUserFirstName") final String userFirstName,
446 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
447 +}
448 +{{/code}}
449 +
450 +=== Parameter armSite ===
451 +
452 +|(((
453 +version
454 +)))|(((
455 +Requested version: 1
456 +)))
457 +|(((
458 +userId
459 +)))|(((
460 +UserId of the requested reporter user
461 +)))
462 +|(((
463 +optionalRole
464 +)))|(((
465 +Optional. User role. 0=student, 1=tutor
466 +)))
467 +|(((
468 +secretToShare
469 +)))|(((
470 +Shared secret. Has to remain identical for every communication.
471 +)))
472 +|(((
473 +optionalUserLastName
474 +)))|(((
475 +Optional. User lastname.
476 +)))
477 +|(% colspan="1" %)(% colspan="1" %)
478 +(((
479 +optionalUserFirstName
480 +)))|(% colspan="1" %)(% colspan="1" %)
481 +(((
482 +Optional. User firstname.
483 +)))
484 +|(% colspan="1" %)(% colspan="1" %)
485 +(((
486 +additionalParams
487 +)))|(% colspan="1" %)(% colspan="1" %)
488 +(((
489 +Reserved for future use.
490 +)))
491 +
492 +=== ReturnValue armSite ===
493 +
494 +|(((
495 +String
496 +)))|(((
497 +Session ID that has to be used to mark any further reporter call.
498 +)))
499 +
500 +== Initialisation through LMS ==
501 +
502 +{{code title="Initialisierung durch LMS" language="xml"}}
503 +@WebMethod(operationName = „initiateSite")
504 +public String initiateSite(
505 +@WebParam(name = „version") final Integer version,
506 +@WebParam(name = „sessionId") final String sessionId,
507 +@WebParam(name = „secretToShare") final String secretToShare,
508 +@WebParam(name = „students") final ArrayList<ResultsForStudent> students,
509 +@WebParam(name = „optionalContentPackage") final byte[] contentPackage,
510 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
511 +}
512 +{{/code}}
513 +
514 +=== Parameter initiateSite ===
515 +
516 +|(((
517 +version
518 +)))|(((
519 +Requested version: 1
520 +)))
521 +|(% colspan="1" %)(% colspan="1" %)
522 +(((
523 +sessionId
524 +)))|(% colspan="1" %)(% colspan="1" %)
525 +(((
526 +SessionId, as returned by armSite.
527 +)))
528 +|(((
529 +secretToShare
530 +)))|(((
531 +Shared secret. Has to remain identical at every communication.
532 +)))
533 +|(((
534 +students
535 +)))|(((
536 +List of students with their results. See below.
537 +)))
538 +|(((
539 +optionalContentPackage
540 +)))|(((
541 +Optional. Content Package (zipped) as byte array.
542 +)))
543 +|(((
544 +additionalParams
545 +)))|(((
546 +Reserved for future use.
547 +)))
548 +
549 +=== ReturnValue initiateSite ===
550 +
551 +|(((
552 +String
553 +)))|(((
554 +Absolute URL of the reporter site for the frame. It has to be enriched by the LMS with the following URLparameters:
555 +
556 +* sid: Session ID as returned by armSite
557 +* (((
558 +uid: Student ID as registrated in the initiateSite at the ONYX Reporter.
559 +)))
560 +)))
561 +
562 +{{code language="xml"}}
563 +public class ResultsForStudent {
564 +   private String studentId = „";
565 +   private String firstname = „";
566 +   private String lastname = „";
567 +   private String groupname = „";
568 +   private String tutorname = „";
569 +   private File contentFile = null;
570 +   private byte[] resultsFile = null;
571 +}
572 +{{/code}}
573 +
574 +== Deconnection through the LMS ==
575 +
576 +
577 +
578 +{{code}}
579 +@WebMethod(operationName = „disarmSite")
580 +public Boolean disarmSite(
581 +@WebParam(name = „version") final Integer version,
582 +@WebParam(name = „sessionId") final String sessionId,
583 +@WebParam(name = „secretToShare") final String secretToShare,
584 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
585 +}
586 +{{/code}}
587 +
588 +
589 +
590 +=== Parameter disarmSite ===
591 +
592 +|(((
593 +version
594 +)))|(((
595 +Requested version: 1
596 +)))
597 +|(% colspan="1" %)(% colspan="1" %)
598 +(((
599 +sessionId
600 +)))|(% colspan="1" %)(% colspan="1" %)
601 +(((
602 +SessionId, as returned by armSite.
603 +)))
604 +|(((
605 +secretToShare
606 +)))|(((
607 +Shared secret. Has to remain identical at every communication.
608 +)))
609 +|(((
610 +additionalParams
611 +)))|(((
612 +Reserved for future use.
613 +)))
614 +
615 +=== ReturnValue disarmSite ===
616 +
617 +|(((
618 +Boolean
619 +)))|(((
620 +True if successful, otherwise false.
621 +)))
622 +
623 +== Request of learning results through the LMS ==
624 +
625 +{{code title="Abfrage von Lernerresultaten durch LMS" language="xml"}}
626 + @WebMethod(operationName = „getResultValues")
627 +public HashMapWrapper getResultValues(
628 + @WebParam(name = „version") final Integer version,
629 + @WebParam(name = „sessionId") final String sessionId,
630 + @WebParam(name = „secretToShare") final String secretToShare,
631 + @WebParam(name = „requestedValues") final HashMap<String, String>
632 + requestedValues,
633 + @WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
634 +}
635 +{{/code}}
636 +
637 +=== Parameter getResultValues ===
638 +
639 +|(((
640 +version
641 +)))|(((
642 +Requested version: 1
643 +)))
644 +|(% colspan="1" %)(% colspan="1" %)
645 +(((
646 +sessionId
647 +)))|(% colspan="1" %)(% colspan="1" %)
648 +(((
649 +SessionId, as returned by armSite.
650 +)))
651 +|(((
652 +secretToShare
653 +)))|(((
654 +Shared secret. Has to remain identical at every communication.
655 +)))
656 +|(((
657 +requestedValues
658 +)))|(((
659 +Can be empty, thus all result variables will be returned. If it contains keys, only those will be returned.
660 +)))
661 +|(((
662 +additionalParams
663 +)))|(((
664 +Reserved for future use.
665 +)))
666 +
667 +=== ReturnValue getResultValues ===
668 +
669 +|(((
670 +HashMap<String, String>
671 +)))|(((
672 +Map of result variables, key is the variable name, value the corresponding value (HashMap is wrapped)
673 +)))
674 +
675 +== Request of result variables through the LMS ==
676 +
677 +{{code title="Abfrage von Ergebnisvariablen durch LMS" language="xml"}}
678 + @WebMethod(operationName = „getResultVariables")
679 +public HashMapWrapper getResultVariables(
680 +@WebParam(name = „version") final Integer version,
681 +@WebParam(name = „contentPackage") final byte[] contentPackage,
682 +@WebParam(name = „additionalParams") final HashMapWrapper additionalParams) {
683 +}
684 +{{/code}}
685 +
686 +=== Parameter getResultVariables ===
687 +
688 +|(((
689 +version
690 +)))|(((
691 +Requested version: 1
692 +)))
693 +|(((
694 +contentPackage
695 +)))|(((
696 +Content package (zipped) as byte array.
697 +)))
698 +|(((
699 +additionalParams
700 +)))|(((
701 +Reserved for future use.
702 +)))
703 +
704 +=== ReturnValue getResultVariables ===
705 +
706 +|(((
707 +HashMap<String, String>
708 +)))|(((
709 +Map of result variables, key is the variable name, value the corresponding
710 +value (HashMap is wrapped).
711 +)))
712 +
713 +== Wrapper ==
714 +
715 +As the transmission of maps and lists generate problems via JAX-WS (lists filled by the customer are sent without any data and thus reach the server without data) they have to be wrapped.
716 +
717 +=== Wrapper for HashMap<String, String> ===
718 +
719 +HashMapWrapper.java:
720 +
721 +[[image:attach:HashMapWrapperjava.png]]
722 +
723 +[[image:attach:HashMapWrapperjava2.png]]
724 +
725 +=== Wrapper for the ArrayList<ResultsForStudent> ===
726 +
727 +ResultsForStudentsWrapper.java:
728 +
729 +[[image:attach:ResultsForStudentsWrapperjava.png]]
730 +{{/layout-cell}}
731 +{{/layout-section}}
732 +{{/layout}}
733 +{{/sv-translation}}
HashMapWrapperjava.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.XWikiGuest
Größe
... ... @@ -1,1 +1,0 @@
1 -135.3 KB
Inhalt
HashMapWrapperjava2.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.XWikiGuest
Größe
... ... @@ -1,1 +1,0 @@
1 -187.3 KB
Inhalt
ResultsForStudentsWrapperjava.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.XWikiGuest
Größe
... ... @@ -1,1 +1,0 @@
1 -83.3 KB
Inhalt
Confluence.Code.ConfluencePageClass[0]
id
... ... @@ -1,1 +1,1 @@
1 -3342390
1 +3342937
url
... ... @@ -1,1 +1,1 @@
1 -https://www.bps-system.de/help/display/SOV/wiki/spaces/ONYX/pages/3342390/Schnittstelle ONYX Reporter
1 +https://www.bps-system.de/help/display/SOV/wiki/spaces/ONYX/pages/3342937/Schnittstelle ONYX Reporter