Compare commits

...

495 commits

Author SHA1 Message Date
anhefti
0187f3a4a5 preparing for release 2.0.0 2024-09-02 14:47:14 +02:00
anhefti
d3ad1b64d0 preparing for release 2.0.0 2024-09-02 14:45:58 +02:00
anhefti
0019d948f6 preparing for release 2.0.0 2024-09-02 12:14:31 +02:00
anhefti
e56605f405 preparing for release 2.0.0 2024-09-02 12:08:35 +02:00
anhefti
ebb6f8f1b3 preparing for release 2.0 test run feature 2024-09-02 11:48:36 +02:00
anhefti
48b04b0679 preparing for release 2.0 test run feature 2024-08-29 16:24:31 +02:00
anhefti
cc77c03961 preparing for release 2.0 test run feature 2024-08-29 16:13:32 +02:00
anhefti
b3e47772d4 preparing for release 2.0 test run feature 2024-08-29 15:00:01 +02:00
anhefti
b03bd6e3f7 preparing for release 2.0 fixed image refs 2024-08-29 14:38:37 +02:00
anhefti
0244b775fd preparing for release 2.0 fixed image refs 2024-08-29 14:34:57 +02:00
anhefti
f4ac677ae6 preparing for release 2.0 fixed image refs 2024-08-29 14:29:17 +02:00
anhefti
018e9f3f7b preparing for release 2.0 docu 2024-08-29 14:14:57 +02:00
anhefti
9e25ee7c9a preparing for release 2.0 2024-08-29 08:05:20 +02:00
anhefti
cc27f9dd1d preparing for release 2.0 2024-08-29 07:57:29 +02:00
Nadim Ritter
c6999e79c3 proctoring docu add line breask 2024-08-28 14:56:45 +02:00
Nadim Ritter
047758cb9f correct typos in proctoring docu 2024-08-28 14:29:30 +02:00
NadimETH
cb20f6feb5
Merge pull request #136 from SafeExamBrowser/docu
Docu
2024-08-28 13:24:19 +02:00
Nadim Ritter
7f7ac3e378 Merge branch 'dev-2.0' of github.com:SafeExamBrowser/seb-server into docu 2024-08-28 13:23:17 +02:00
anhefti
081b9943e9 SEBSERV-574 fixed text 2024-08-27 13:36:08 +02:00
anhefti
9e70b39400 SEBSERV-574 2024-08-26 13:54:13 +02:00
anhefti
a7aedc58dc fixed some minor text issue 2024-08-22 11:50:16 +02:00
anhefti
ed48fad27c SEBSERV-581 fixed (skip for none LMS Exams) 2024-08-21 12:07:31 +02:00
anhefti
9e5a0085b3 SEBSERV-580 fixed by skip active testing for Exam without LMS 2024-08-21 10:52:09 +02:00
anhefti
bb0df16a56 SEBSERV-574 on access denied check if admin and show hinted message 2024-08-20 11:22:55 +02:00
anhefti
2d5baeba1c SEBSERV-578 fixed by skip full integration testing for pure Moodle core 2024-08-20 10:28:39 +02:00
Nadim Ritter
54ec29d647 Merge branch 'dev-2.0' of github.com:SafeExamBrowser/seb-server into docu 2024-08-16 16:17:26 +02:00
Nadim Ritter
ccae9fa780 docu progress & new images 2024-08-16 16:16:38 +02:00
Nadim Ritter
203575a35f progress in docu & new images 2024-08-14 10:12:42 +02:00
anhefti
f632cc9750 SEBSERV-570 fixed, skip full integration test for plugin version 1 2024-08-13 10:40:03 +02:00
anhefti
d5ccc0f093 SEBSERV-572 fixed, added new property setting sebserver.webservice.autologin.url 2024-08-13 10:40:03 +02:00
Nadim Ritter
f88335b17c add http to screen proctoring url 2024-08-08 16:52:06 +02:00
Nadim Ritter
b962b24492 change screen proctoring url to ps-webservice 2024-08-08 16:25:07 +02:00
Nadim Ritter
7406bc5ad4 Merge branch 'dev-2.0' of github.com:SafeExamBrowser/seb-server into docu 2024-08-06 08:42:36 +02:00
Nadim Ritter
dff1a051e9 remove print outs 2024-08-05 11:02:49 +02:00
Nadim Ritter
13eda2eda4 docu upload screenshots & create screen proctoring docu 2024-07-25 11:21:59 +02:00
Nadim Ritter
98ea35f118 add screen proctoring page 2024-07-23 10:06:55 +02:00
Nadim Ritter
deac21f4ba rename redirect to gallery-view 2024-07-22 14:13:50 +02:00
Nadim Ritter
1cb0242507 better logging for lastname bug 2024-07-19 11:34:45 +02:00
anhefti
f4ccd16425 SEBSERV-569 fixed, regression due to code cleanup 2024-07-18 14:18:29 +02:00
anhefti
b0e8e11d26 SEBSERV-569 fixed, regression due to code cleanup 2024-07-18 14:18:10 +02:00
anhefti
3166152c90 SEBSERV-541 column width now sticks to user session 2024-07-18 13:44:54 +02:00
anhefti
6c4902db02 improve logging for Moodle user Details 2024-07-18 12:00:22 +02:00
anhefti
93858944d8 SEBSERV-560 only master needs to update groups 2024-07-18 07:23:42 +02:00
anhefti
1ef1052275 SEBSERV-568 fixed 2024-07-17 15:37:53 +02:00
anhefti
95c2057dad improved sps group number update 2024-07-17 14:28:27 +02:00
anhefti
4cd498d29e SEBSERV-566 fixed, update SPS session 2024-07-16 16:25:02 +02:00
anhefti
e70a209217 SEBSERV-560 SEBSERV-563 implementation 2024-07-16 14:15:25 +02:00
anhefti
303b3ac548 SEBSERV-560 SEBSERV-563 implementation 2024-07-16 09:38:29 +02:00
anhefti
f2f8a561a8 SEBSERV-565 added new Status Filter for Ready status 2024-07-11 15:41:08 +02:00
anhefti
413fb96240 SEBSERV-564 fixed for Moodle 2024-07-11 11:02:32 +02:00
anhefti
c3a03719c9 Merge branch 'master' into development 2024-07-09 17:13:40 +02:00
Andreas Hefti
48bdf5e2cd
Merge pull request #132 from SafeExamBrowser/dependabot/pip/docs/urllib3-1.26.19
Bump urllib3 from 1.26.13 to 1.26.19 in /docs
2024-07-09 17:06:37 +02:00
anhefti
b7fb95a1c3 SEBSERV-562 DB migration charset utf8mb4 2024-07-09 15:30:04 +02:00
anhefti
fc6e5be155 code cleanup and better logging 2024-07-09 13:30:57 +02:00
anhefti
9ad13ffe3f code cleanup 2024-07-04 16:31:00 +02:00
anhefti
fb8df62f59 SEBSERV-419 implementation and local testing 2024-07-04 15:29:43 +02:00
anhefti
16b2c8deb4 SEBSERV-559 and SEBSERV-552 2024-07-03 16:29:00 +02:00
anhefti
c0ead99e2b SEBSERV-419 2024-07-02 13:43:07 +02:00
anhefti
900bbfe5f4 SEBSERV-555 use "0" for no template selection 2024-07-01 13:40:51 +02:00
anhefti
ee89d2a24e SEBSERV-556 fixed notify exam template deletion to moodle 2024-07-01 12:23:31 +02:00
anhefti
b0617803f1 SEBSERV-555 should be fixed, testing on ralph 2024-07-01 11:32:38 +02:00
Andreas Hefti
2f260212ae
Merge pull request #135 from SafeExamBrowser/SEBSP-131
Sebsp 131
2024-07-01 09:11:43 +02:00
anhefti
41ce1bc268 SEBSERV-419 implementation 2024-06-27 16:21:14 +02:00
Nadim Ritter
4b0f88d0b6 SEBSP-131 replace fullname with lastname and firstname + fix test 2024-06-27 16:02:26 +02:00
Nadim Ritter
1831de1437 SEBSP-131 fix broken test 2024-06-27 13:25:30 +02:00
Nadim Ritter
31924877ee SEBSP-131 use lastname + firstname instead of fullname in moodle 2024-06-27 13:13:43 +02:00
anhefti
8539da1879 fixed localization in monitoring indicator 2024-06-26 14:32:38 +02:00
anhefti
66b2eebf1d fixed some list mismatches due to read access + code cleanup 2024-06-26 14:14:24 +02:00
anhefti
6cc2f7b84b check right privileges batch actions and code cleanup 2024-06-26 12:59:48 +02:00
anhefti
01bd5c5558 SEBSERV-418 removed SEB config upload to Moodle and call set_exam_data on change instead 2024-06-26 10:57:18 +02:00
anhefti
d291e21543 fixed build 2024-06-26 09:14:33 +02:00
anhefti
644f0a4cd1 fixed Moodle file upload 2024-06-26 09:11:14 +02:00
anhefti
b33998be07 fixed file upload to moodle 2024-06-25 17:02:49 +02:00
anhefti
7fbf49397c SEBSERV-552 fixed SPS exam creation and update 2024-06-25 16:50:40 +02:00
anhefti
27542a2293 SEBSERV-553 fixed file upload 2024-06-25 14:47:45 +02:00
anhefti
07bbf6c49b SEBSERV-553 fixed file upload 2024-06-25 14:43:47 +02:00
anhefti
abe8bcd4d3 SEBSERV-553 fixed show quit link and improved logging 2024-06-25 13:54:15 +02:00
anhefti
65e717349b SEBSERV-553 fixed show quit link and improved logging 2024-06-25 10:47:38 +02:00
anhefti
0b21baac24 SEBSERV-553 fixed show quit link and improved logging 2024-06-25 10:31:11 +02:00
anhefti
b808d65f53 SEBSERV-553 fixed show quit link and improved logging 2024-06-25 10:20:27 +02:00
anhefti
8b30771021 SEBSERV-553 fixed show quit link and improved logging 2024-06-25 09:59:13 +02:00
anhefti
485273d05e fixed build 2024-06-24 13:46:25 +02:00
anhefti
a6b9554c76 fixed build 2024-06-24 13:35:41 +02:00
anhefti
99bf2f25da SEBSERV-549 fixed. was introduced by fix of SEBSERV-515 + code cleanup 2024-06-24 13:23:19 +02:00
anhefti
d528f66afa Merge remote-tracking branch 'origin/development' into development 2024-06-24 13:13:11 +02:00
anhefti
38fb5e06a0 Merge branch 'dev-1.6' into development
# Conflicts:
#	pom.xml
2024-06-24 11:47:40 +02:00
anhefti
967f6792dc SEBSERV-549 fixed. was introduced by fix of SEBSERV-515 2024-06-24 11:46:43 +02:00
NadimETH
a72a88e4ef
Merge pull request #133 from SafeExamBrowser/SEBSP-143
Sebsp 143
2024-06-21 12:49:58 +02:00
anhefti
45969934c3 SEBSERV-417 fix teacher account selection for supporter 2024-06-20 10:41:18 +02:00
anhefti
ce168094cf SEBSERV-417 fix check full integration 2024-06-20 10:11:27 +02:00
anhefti
68be1b4322 SEBSERV-417 fix check full integration 2024-06-20 09:56:40 +02:00
anhefti
b4907fcda9 SEBSERV-417 fix check full integration available and fix Exam Config change apply 2024-06-20 09:40:28 +02:00
anhefti
e0952da7f3 SEBSERV-417 fix autologin 2024-06-19 16:48:06 +02:00
anhefti
a31e001f69 SEBSERV-417 fix autologin 2024-06-19 16:38:30 +02:00
anhefti
1a5bb6ff7d SEBSERV-417 fixed screen proctoring re-init plus autologin 2024-06-19 16:25:36 +02:00
Nadim Ritter
a8bcaa53e5 SEBSP-143 add utf8 encoding to body encoding function 2024-06-19 16:11:36 +02:00
anhefti
9d93826a35 SEBSERV-417 testing 2024-06-19 14:19:13 +02:00
anhefti
a8185095f2 SEBSERV-417 testing 2024-06-19 14:10:07 +02:00
anhefti
bcb28b0945 fixed bean dependencies for gui 2024-06-19 13:47:15 +02:00
anhefti
34ad7b5177 SEBSERV-417 apply exam_data and connection config after 2024-06-19 13:23:13 +02:00
anhefti
df78a6a2a4 SEBSERV-417 apply exam_data before SEB restriction 2024-06-19 12:58:17 +02:00
anhefti
8238361910 SEBSERV-417 apply exam_data before SEB restriction 2024-06-19 12:17:12 +02:00
Nadim Ritter
ae37a8cf12 Merge branch 'development' of github.com:SafeExamBrowser/seb-server into SEBSP-143 2024-06-19 10:07:43 +02:00
anhefti
fbe7781be1 SEBSERV-417 add rollback of exam import on partial import 2024-06-18 17:14:53 +02:00
anhefti
4dc8064f88 SEBSERV-417 add rollback of exam import on partial import 2024-06-18 13:52:21 +02:00
anhefti
374ea4fee5 SEBSERV-417 testing 2024-06-18 13:34:26 +02:00
Nadim Ritter
0fbdec95d3 SEBSP-143 add utf8 url encoding for screen proctoring 2024-06-18 13:17:50 +02:00
anhefti
438453dfe9 SEBSERV-417 do not send error to Moodle on Exam deletion request when Exam already has been deleted 2024-06-18 11:46:52 +02:00
anhefti
bf7204660d SEBSERV-417 do not deactivate teacher account (might be used by others) 2024-06-18 10:57:41 +02:00
anhefti
27c5cff6f5 SEBSERV-417 fixed predicate 2024-06-18 10:37:41 +02:00
anhefti
3e426ce2cc SEBSERV-417 show teacher for supporter selection 2024-06-18 10:26:29 +02:00
anhefti
6de875b29c SEBSERV-417 added get exam data from Moodle on exam import and fixed teacher account for different exams 2024-06-18 09:46:07 +02:00
dependabot[bot]
e48a1d5885
Bump urllib3 from 1.26.13 to 1.26.19 in /docs
Bumps [urllib3](https://github.com/urllib3/urllib3) from 1.26.13 to 1.26.19.
- [Release notes](https://github.com/urllib3/urllib3/releases)
- [Changelog](https://github.com/urllib3/urllib3/blob/1.26.19/CHANGES.rst)
- [Commits](https://github.com/urllib3/urllib3/compare/1.26.13...1.26.19)

---
updated-dependencies:
- dependency-name: urllib3
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-06-18 00:02:30 +00:00
anhefti
b6e3772dcd SEBSERV-417 removed debug code 2024-06-13 15:24:21 +02:00
anhefti
8155d155c0 SEBSERV-417 and SEBSP-111 2024-06-13 13:11:08 +02:00
anhefti
c161e3c5ef SEBSERV-417 and SEBSP-111 2024-06-12 15:36:35 +02:00
anhefti
3a5129f796 SEBSERV-417 try fix corrupt Moodle data 2024-06-12 09:42:14 +02:00
anhefti
1ef62af9a5 SEBSERV-417 try fix corrupt Moodle data 2024-06-12 09:15:34 +02:00
anhefti
7a3e3a2492 SEBSERV-417 try fix corrupt Moodle data 2024-06-12 08:51:07 +02:00
anhefti
6a81b3f717 SEBSERV-417 try fix corrupt Moodle data 2024-06-12 08:43:58 +02:00
anhefti
9bf843e4fa SEBSERV-417 fixed SEB Restriction 2024-06-11 16:13:21 +02:00
anhefti
c4dc211cb6 SEBSERV-417 improved error and waning handling and logging 2024-06-11 13:13:02 +02:00
anhefti
dc98f451fa SEBSERV-417 improved error and waning handling and logging 2024-06-06 13:59:21 +02:00
anhefti
07391430c4 SEBSERV-417 improved error and waning handling and logging 2024-06-06 13:50:07 +02:00
anhefti
05d6cdaf21 fixed exam update additional quiz attributes 2024-06-06 12:09:22 +02:00
Andreas Hefti
0dd70f3ff4
Merge pull request #128 from SafeExamBrowser/pw-bug
pw-bug comment if on additional attributes for exam
2024-06-06 11:37:23 +02:00
Nadim Ritter
7c99ae04e7 pw-bug comment if on additional attributes for exam 2024-06-06 11:14:23 +02:00
anhefti
f9de99d9bc SEBSERV-417 adapt Moodle API calls, error handling and fixes 2024-06-06 10:19:01 +02:00
anhefti
012b0e2f99 Merge remote-tracking branch 'origin/rel-1.6.1' into development
# Conflicts:
#	pom.xml
2024-06-05 09:26:05 +02:00
anhefti
00e8366fda Merge remote-tracking branch 'origin/rel-1.6.1' 2024-06-05 09:21:04 +02:00
anhefti
37f5cf9ea9 Prepare for next patch release 1.6.2 2024-06-05 09:18:49 +02:00
anhefti
1ac7e99be0 Prepare for patch release 1.6.1 2024-06-05 08:49:09 +02:00
anhefti
db4411c52e SEBSERV-417 new Moodle POST API calls 2024-06-05 08:44:46 +02:00
Andreas Hefti
17400023f3
Merge pull request #127 from SafeExamBrowser/logging
add date to logging config
2024-06-04 13:15:33 +02:00
Nadim Ritter
4b1b6ebefa add date to logging config 2024-06-04 12:51:30 +02:00
anhefti
d6e65eb8ad manually picked changes from pull-request: Integrate SEB Server in OLAT again #121 2024-06-04 12:09:31 +02:00
anhefti
7ec942e264 SEBSERV-417 fixed broken build 2024-06-04 11:46:57 +02:00
anhefti
fc7ac4c4e0 SEBSERV-417 better connection init 2024-06-04 09:43:09 +02:00
anhefti
b1e4f50a1a debugging 2024-06-04 08:27:18 +02:00
anhefti
a90f358bd5 fixed ignore TLS verification for demo setup 2024-06-03 13:49:39 +02:00
anhefti
908665ddcc SEBSERV-418 finished implementation for teacher account and login 2024-05-30 16:33:58 +02:00
anhefti
1d332fc579 SEBSP-129 and SEBSERV-418 2024-05-29 12:05:20 +02:00
anhefti
41b056edce SEBSP-129 and SEBSERV-418 2024-05-29 09:39:30 +02:00
anhefti
9618b942fb SEBSERV-418 2024-05-22 13:32:30 +02:00
anhefti
1ae00cc4ab SEBSP-119 and SEBSP-111 2024-05-16 10:50:36 +02:00
anhefti
3501c5de05 SEBSERV-417 finished first part 2024-05-08 14:29:53 +02:00
anhefti
4b675bc717 SEBSERV-527 2024-05-02 12:52:57 +02:00
anhefti
91212c65be Merge branch 'dev-1.6' into development 2024-05-02 12:02:03 +02:00
anhefti
c8ff644e7d SEBSERV-543 fixed selection filter 2024-05-02 12:01:16 +02:00
anhefti
ff89864b19 SEBSERV-417 create delete exam from Moodle 2024-05-02 11:39:41 +02:00
anhefti
c0919ce0cf SEBSERV-417 Exam Template enhancements 2024-04-24 15:43:35 +02:00
anhefti
f8bba38f4d Changed OpenOLAT to OLAT Documentation 2024-04-22 11:08:33 +02:00
anhefti
7e2baedc03 Changed OpenOLAT to OLAT 2024-04-22 11:06:24 +02:00
anhefti
4a98dfcfa1 Merge remote-tracking branch 'origin/development' into development 2024-04-22 10:56:34 +02:00
anhefti
568113003d SEBSERV-417 access token for Moodle 2024-04-22 10:56:21 +02:00
Andreas Hefti
43acb3d3d5
Merge pull request #117 from olatorg/rename-openolat-to-olat
Rename Open Olat to OLAT
2024-04-22 10:54:55 +02:00
Christian Schweizer
b1d255c88e Rename Open Olat to OLAT 2024-04-22 09:48:57 +02:00
anhefti
6e2feafc5a SEBSERV-417 access token for Moodle 2024-04-18 16:12:09 +02:00
anhefti
0f27ef0f38 SEBSERV-417 and data migration 2024-04-18 09:56:40 +02:00
anhefti
e023a8ec31 SEBSERV-417 and data migration 2024-04-17 12:01:22 +02:00
anhefti
9162899683 Merge branch 'dev-1.6' into development 2024-04-15 08:47:41 +02:00
anhefti
5cc7624f73 SEBSERV-417 impl still in progress 2024-04-15 08:46:55 +02:00
anhefti
a81447601b changed version from 1.7 to 2.0 2024-04-11 09:05:39 +02:00
anhefti
d1cb6fc2c9 SEBSERV-535 fixed 2024-04-11 09:01:50 +02:00
anhefti
3cd4cbb0c0 SEBSP-120 code gen for 2.0 and first migration SEBSERV-534 2024-04-11 08:34:56 +02:00
anhefti
0a2bf98c96 SEBSP-120 code gen for 2.0 and first migration SEBSERV-534 2024-04-11 08:12:07 +02:00
anhefti
c1b62b45cc SEBSP-120 code gen for 2.0 2024-04-09 13:51:11 +02:00
anhefti
d09bc1f95c SEBSERV-417 skeleton 2024-04-09 13:41:42 +02:00
Andreas Hefti
e9285c375a
Merge pull request #115 from lucaboesch/ipaddresssebversionosname
Amend "IP Address,SEB Version, OSName" order.
2024-04-08 09:21:28 +02:00
Luca Bösch
12fe3950d7 Amend "IP Address,SEB Version, OSName" order. 2024-04-05 13:06:28 +02:00
anhefti
1c0cf3285b Merge branch 'dev-1.6' into development 2024-04-04 16:28:36 +02:00
anhefti
207ac959a6 SEBSERV-533 fixed 2024-04-04 16:27:58 +02:00
anhefti
0fb7b7019e remove code cov 2024-04-04 08:13:18 +02:00
anhefti
3cdff1b4ac remove code cov 2024-04-04 08:12:27 +02:00
anhefti
845e29ed17 Merge branch 'SEBSERV-417' into development 2024-04-04 08:07:36 +02:00
anhefti
b15221753a fixed reporting for Java 17 2024-04-03 16:09:08 +02:00
Nadim Ritter
ee6a46907c SEBSLI-9 change record 'UsernamePasswordView' to class 2024-04-03 15:41:14 +02:00
anhefti
ad6908dc8c SEBSERV-417 architecture setup 2024-04-03 15:37:51 +02:00
anhefti
36c84b894f fix docu 2024-04-02 14:39:44 +02:00
NadimETH
afb2685664
Merge pull request #112 from SafeExamBrowser/SEBSLI-9
Sebsli 9
2024-04-02 11:08:51 +02:00
anhefti
1657824285 fix build 2024-03-28 16:05:47 +01:00
anhefti
f8d70c4ab7 fix build 2024-03-28 15:58:24 +01:00
anhefti
7103e721b5 Merge branch 'dev-1.6' into development
# Conflicts:
#	pom.xml
2024-03-28 15:51:06 +01:00
anhefti
5d05cb4213 prepare for next patch 2024-03-28 15:50:16 +01:00
anhefti
e5f7321e4b fix readme 2024-03-28 15:30:40 +01:00
anhefti
fbb97ba42a fix readme 2024-03-28 15:29:24 +01:00
anhefti
b5851405dd fix readme 2024-03-28 15:23:58 +01:00
anhefti
6e943e9f1a fix readme 2024-03-28 15:19:52 +01:00
anhefti
df4781992a fix readme 2024-03-28 15:18:41 +01:00
anhefti
b54844ec1a prepare for release 2024-03-28 15:04:59 +01:00
anhefti
7c194a3d69 Merge branch 'master' into dev-1.6 2024-03-28 15:00:47 +01:00
anhefti
0c0ffcd9d6 SEBSERV-496 2024-03-28 14:59:07 +01:00
anhefti
c556c1cafa SEBSERV-496 2024-03-28 14:55:19 +01:00
anhefti
2f674ecd4c SEBSERV-496 2024-03-28 14:48:12 +01:00
anhefti
3838109072 SEBSERV-496 2024-03-28 13:36:34 +01:00
anhefti
1e96932226 SEBSERV-496 2024-03-28 09:56:55 +01:00
anhefti
984187c242 SEBSERV-496 2024-03-27 15:38:54 +01:00
anhefti
9b930347f0 SEBSERV-496 2024-03-27 14:40:54 +01:00
NadimETH
db2d19b6ec
SEBSLI-9 update version in build file 2024-03-26 16:59:54 +01:00
Nadim Ritter
114313e207 Merge branch 'development' of github.com:SafeExamBrowser/seb-server into SEBSLI-9 2024-03-26 16:55:41 +01:00
Nadim Ritter
0b00724b26 SEBSLI-9 code clean-up and improvements 2024-03-26 16:39:33 +01:00
anhefti
96c403f12a SEBSERV-502 change deprecation Note 2024-03-26 14:38:38 +01:00
anhefti
68d367d1fb Merge branch 'dev-1.6' into development 2024-03-26 09:50:20 +01:00
anhefti
a53b3b0947 SEBSERV-529 fixed empty additional attributes 2024-03-26 09:28:38 +01:00
anhefti
28960ddacc SEBSERV-529 fixed 2024-03-25 16:26:47 +01:00
anhefti
a1660de341 merged development 2024-03-21 10:13:08 +01:00
Nadim Ritter
ed9e86436b SEBSLI-9 store admin pw in db + expose endpoint in ssl mode + remove admin pw after pw change 2024-03-20 16:04:00 +01:00
anhefti
67b223ad02 Merge remote-tracking branch 'origin/dev-1.6' into development 2024-03-20 11:31:30 +01:00
anhefti
b463e5be6c SEBSERV-528 fixed 2024-03-20 11:30:48 +01:00
anhefti
5008fbcd19 SEBSERV-527 temporary fix 2024-03-20 11:00:25 +01:00
anhefti
a492605458 CI fix cleanup 2024-03-20 09:07:57 +01:00
anhefti
08af91cd49 CI fix cleanup 2024-03-20 09:01:47 +01:00
anhefti
d3052dea87 CI fix cleanup 2024-03-20 08:57:34 +01:00
anhefti
ffc09ddc75 CI fix cleanup 2024-03-20 08:51:27 +01:00
anhefti
a40b65ea00 Fixed CI pipelenie + codecov token 2024-03-20 08:45:03 +01:00
anhefti
d20883c2fd Fixed some Spring security related warnings and converted http.ignore paths to http...permitAll configs where possible 2024-03-20 08:44:26 +01:00
Nadim Ritter
32fc2817d4 SEBSLI-9 move init event below admin account create event 2024-03-18 13:57:42 +01:00
anhefti
9e82fac386 code cleanup 2024-03-18 13:16:09 +01:00
Nadim Ritter
4a97e8d32c SEBSLI-9 comment out creation of connection config 2024-03-15 15:49:57 +01:00
Nadim Ritter
7594a03de5 SEBSLI-9 new light init class 2024-03-15 13:42:04 +01:00
Nadim Ritter
2670d57351 Merge branch 'development' of github.com:SafeExamBrowser/seb-server into SEBSLI-9 2024-03-14 09:19:46 +01:00
anhefti
a5ed8a1850 Merge remote-tracking branch 'origin/dev-1.6' into development 2024-03-13 16:28:37 +01:00
anhefti
dc8a21daaf SEBSERV-511 removed also from Monitoring and form Exam Config 2024-03-13 16:28:10 +01:00
anhefti
9d423649c4 Merge remote-tracking branch 'origin/dev-1.6' into development 2024-03-13 15:52:29 +01:00
anhefti
a905ed63c3 SEBSERV-515 fixed delete actual multi selection on table filter change 2024-03-13 15:51:54 +01:00
anhefti
7f8106e3c3 code cleanup 2024-03-13 13:52:55 +01:00
anhefti
2611f4f464 code cleanup 2024-03-13 13:45:38 +01:00
Nadim Ritter
c110d7aec4 Merge branch 'dev-1.6' of github.com:SafeExamBrowser/seb-server into development 2024-03-13 13:10:06 +01:00
Nadim Ritter
2baf0d4caf Merge branch 'dev-1.6' of github.com:SafeExamBrowser/seb-server into dev-1.6 2024-03-13 13:07:38 +01:00
Nadim Ritter
28e95e44b3 SEBSERV-515 fix multiselection bug 2024-03-13 13:07:16 +01:00
anhefti
912ec31716 Merge remote-tracking branch 'origin/dev-1.6' into development 2024-03-12 16:32:25 +01:00
anhefti
7e9b5f92af Change Copyright 2024-03-12 16:31:43 +01:00
anhefti
1998f4dc2c Merge remote-tracking branch 'origin/dev-1.6' into development 2024-03-12 15:25:41 +01:00
anhefti
102da3ccdf SEBSERV-455 for 1.6 2024-03-12 15:25:19 +01:00
anhefti
843b051597 Merge remote-tracking branch 'origin/dev-1.6' into development
# Conflicts:
#	src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/AttributeMapping.java
2024-03-11 16:27:33 +01:00
anhefti
46c2ca997b SEBSERV-455 for 1.6 2024-03-11 16:20:37 +01:00
anhefti
3ae95e2bd2 Merge branch 'downgrade_exam_config' into dev-1.6
# Conflicts:
#	src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/AttributeMapping.java
#	src/main/resources/config/application-dev-ws.properties
2024-03-11 16:06:37 +01:00
anhefti
4cfc666029 update pom Version to 1.7-SNAPSHOT 2024-03-11 15:48:59 +01:00
anhefti
4fe5ebea69 SEBSERV-455 for 1.7 and 1.6 2024-03-11 15:48:04 +01:00
anhefti
dc3b94c328 Merge branch 'downgrade_exam_config' into development
# Conflicts:
#	src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/AttributeMapping.java
#	src/main/resources/config/application-dev-ws.properties
2024-03-11 15:36:16 +01:00
anhefti
ae4b60e3e8 fix cleanup task 2024-03-06 13:01:36 +01:00
anhefti
25cdffbbb0 fix cleanup task 2024-03-06 12:55:55 +01:00
anhefti
640e398d49 Merge remote-tracking branch 'origin/development' into development 2024-03-06 12:09:42 +01:00
anhefti
3b123ff698 fix cleanup task 2024-03-06 12:09:34 +01:00
Andreas Hefti
d8c464be90
Merge pull request #110 from SafeExamBrowser/SEBSERV-508
SEBSERV-508 change base image to eclipse-temurin:17-jre
2024-03-06 11:52:01 +01:00
anhefti
816528de87 adapt to new jenkins reporting 2024-03-05 14:20:44 +01:00
anhefti
c1a10d564a remove double maven build for reporting 2024-03-05 13:21:34 +01:00
anhefti
52247e8a56 remove double maven build for reporting 2024-03-05 13:16:59 +01:00
anhefti
0ccc5d2164 remove double maven build for reporting 2024-03-05 12:58:51 +01:00
anhefti
3940dcb280 remove double maven build for reporting 2024-03-05 12:50:24 +01:00
anhefti
04ad9da947 fixed maven for reporting 2024-03-05 11:26:53 +01:00
anhefti
3b96c11324 fixed maven for reporting 2024-03-05 10:37:28 +01:00
anhefti
8e115d26d0 remove spotbugs (seems not be existing anymore) 2024-03-05 10:20:35 +01:00
anhefti
350d679300 remove spotbugs (seems not be existing anymore) 2024-03-05 10:09:13 +01:00
anhefti
87a7e11530 fixed let_reporting to 17 2024-03-05 09:59:32 +01:00
anhefti
acc4532ff4 fixed let_reporting 2024-03-05 09:49:19 +01:00
Nadim Ritter
ed68a5c74f SEBSLI-9 reset build yaml to development state 2024-03-05 09:33:28 +01:00
anhefti
4fc5f6fe95 Jenkins test 2024-03-05 09:24:35 +01:00
anhefti
e76d558e48 Jenkins test 2024-03-05 08:52:52 +01:00
anhefti
4ec0cc7aa6 Jenkins test 2024-03-05 08:18:53 +01:00
NadimETH
cd7c759b58
use correct version tag in build yaml 2024-03-04 17:37:35 +01:00
NadimETH
8f8ede317c
upgrade to java 17 in build yaml 2024-03-04 17:34:53 +01:00
anhefti
015806db5b test new Jenkinsfile and switch integration test port to 8888 2024-03-04 16:41:18 +01:00
anhefti
26406b4fdb test new Jenkinsfile 2024-03-04 16:15:46 +01:00
anhefti
d4fd49da9d test new Jenkinsfile 2024-03-04 16:11:44 +01:00
anhefti
543498c0c7 test new Jenkinsfile 2024-03-04 16:10:45 +01:00
anhefti
2c23b4e07d test new Jenkinsfile 2024-03-04 16:09:58 +01:00
anhefti
dfe593836d test new Jenkinsfile 2024-03-04 16:08:32 +01:00
anhefti
284109c77c test new Jenkinsfile 2024-03-04 16:00:06 +01:00
anhefti
69f5ae1d8f test new Jenkinsfile 2024-03-04 15:57:19 +01:00
anhefti
7d466f8151 test new Jenkinsfile 2024-03-04 15:56:17 +01:00
anhefti
0ca2622319 test new Jenkinsfile 2024-03-04 15:49:55 +01:00
anhefti
704578853c test new Jenkinsfile 2024-03-04 15:47:45 +01:00
anhefti
05d4dd11f1 test new Jenkinsfile 2024-03-04 15:46:26 +01:00
anhefti
d30188f01e test new Jenkinsfile 2024-03-04 15:45:25 +01:00
anhefti
4b264abee6 test new Jenkinsfile 2024-03-04 15:42:48 +01:00
anhefti
21f1708ac0 test new Jenkinsfile 2024-03-04 15:41:47 +01:00
anhefti
5667bc8000 test new Jenkinsfile 2024-03-04 15:40:17 +01:00
anhefti
807e4daf8f test new Jenkinsfile 2024-03-04 15:34:16 +01:00
NadimETH
675ae47e04
change base image to eclipse-temurin:17-jre 2024-03-04 15:22:24 +01:00
anhefti
6f97900447 Merge branch 'dev-1.6' into development 2024-03-04 13:24:28 +01:00
anhefti
d6b3ac43c6 SEBSERV-512 fix error on downgrade for SEB Settings 2024-03-04 13:23:47 +01:00
Nadim Ritter
f3a34ab06f Merge branch 'development' of github.com:SafeExamBrowser/seb-server into SEBSLI-9 2024-02-29 16:56:28 +01:00
anhefti
01f37cc3a6 Merge remote-tracking branch 'origin/master' into development 2024-02-29 13:13:53 +01:00
anhefti
73aeda28a3 SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:38:42 +01:00
anhefti
071effbaaf SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:37:17 +01:00
anhefti
613860aaa7 SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:35:41 +01:00
anhefti
ea4900ed33 SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:29:16 +01:00
anhefti
75a56cd829 SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:19:18 +01:00
anhefti
169a709fed SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:18:22 +01:00
anhefti
a9d4424368 SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:15:03 +01:00
anhefti
c96c950f6e SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:11:33 +01:00
anhefti
16d06bd13f SEBSERV-507 added CONTRIBUTION.md 2024-02-29 10:09:52 +01:00
anhefti
93b450fa67 github actions update 2024-02-28 16:23:56 +01:00
anhefti
a753971808 debug minimal docker setup 2024-02-28 14:58:59 +01:00
anhefti
4d55104a0b debug minimal docker setup 2024-02-28 13:39:31 +01:00
anhefti
c520777585 Merge branch 'master' into development 2024-02-28 11:56:19 +01:00
Andreas Hefti
65cb294f28
Merge pull request #109 from SafeExamBrowser/dependabot/pip/docs/readthedocs-sphinx-search-0.3.2
Bump readthedocs-sphinx-search from 0.1.1 to 0.3.2 in /docs
2024-02-28 11:55:52 +01:00
dependabot[bot]
51a0586c58
Bump readthedocs-sphinx-search from 0.1.1 to 0.3.2 in /docs
Bumps [readthedocs-sphinx-search](https://github.com/readthedocs/readthedocs-sphinx-search) from 0.1.1 to 0.3.2.
- [Changelog](https://github.com/readthedocs/readthedocs-sphinx-search/blob/main/CHANGELOG.rst)
- [Commits](https://github.com/readthedocs/readthedocs-sphinx-search/compare/0.1.1...0.3.2)

---
updated-dependencies:
- dependency-name: readthedocs-sphinx-search
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-02-28 10:53:59 +00:00
anhefti
fa5d3fed24 minor fix with quit password change in Exam 2024-02-28 11:07:01 +01:00
anhefti
55501c36d4 SEBSERV-502 added deprecation message 2024-02-28 10:59:42 +01:00
anhefti
eac6bccb5f SEBSERV-408 fixed cache issue 2024-02-28 09:36:25 +01:00
anhefti
4ceaf50385 SEBSERV-408 2024-02-27 16:12:32 +01:00
anhefti
d100a50e1e fixed sps bundle and feature keys 2024-02-22 15:02:07 +01:00
anhefti
684da72060 fixed gui only profile annotations 2024-02-22 14:27:57 +01:00
anhefti
979d4a6e89 SEBSERV-459 implementation 2024-02-22 13:45:29 +01:00
anhefti
29265dd7e1 SEBSERV-469 implementation 2024-02-22 09:01:15 +01:00
Nadim Ritter
cecce64ba0 SEBSLI-9 create new endpoint for light setup to stream exam config 2024-02-21 16:10:59 +01:00
anhefti
074b63580b SEBSERV-499 2024-02-08 15:11:52 +01:00
anhefti
4bf398cb25 code cleanup 2024-02-08 08:42:48 +01:00
Andreas Hefti
8d1d9d8dda
Merge pull request #108 from SafeExamBrowser/SEBSERV-398
Sebserv 398
2024-02-08 08:27:47 +01:00
Nadim Ritter
2c57f2f108 SEBSERV-398 code cleanup 2024-02-07 16:35:01 +01:00
Andreas Hefti
a702d2c907
Merge pull request #107 from SafeExamBrowser/SEBSERV-427
Sebserv 427
2024-02-07 16:33:29 +01:00
Nadim Ritter
f187582a2b Merge branch 'development' of github.com:SafeExamBrowser/seb-server into SEBSERV-398 2024-02-07 16:26:55 +01:00
Nadim Ritter
840b507156 SEBSERV-427 improve getSelectedTableIndices 2024-02-07 16:23:29 +01:00
anhefti
a5e7b6e105 code cleanup 2024-02-07 16:03:23 +01:00
Nadim Ritter
e8a8563508 SEBSERV-398 change button text 2024-02-07 14:19:51 +01:00
Nadim Ritter
a34cc8c667 SEBSERV-398 add transaction rollback to delete function 2024-02-07 13:44:33 +01:00
anhefti
0fd710c7e3 SEBSERV-414 fix migration and DB consistency check for Orientations 2024-02-07 12:56:08 +01:00
Nadim Ritter
f191d59495 SEBSERV-398 - add bulk delete for exam config 2024-02-07 09:31:26 +01:00
anhefti
d3cbc18a09 SEBSERV-497 all domain specific features 2024-02-07 08:28:13 +01:00
anhefti
675d2aad19 fixed quiz password update from Exam on LMS 2024-02-05 13:43:59 +01:00
Nadim Ritter
acc50ee94d make code java 8 compatible 2024-02-01 16:41:40 +01:00
Nadim Ritter
34f8fa1e0a SEBSERV-427 - fix selection issue 2024-02-01 15:57:18 +01:00
anhefti
25e9b9be1e SEBSERV-414 fixed color selector 2024-02-01 14:40:10 +01:00
anhefti
496a8cf52d SEBSERV-504 removed 16b, 24b grayscale 2024-02-01 14:15:37 +01:00
anhefti
b8a7ab279e SEBSERV-427 comments 2024-01-31 16:54:32 +01:00
anhefti
75c559d01a SEBSLI-4 implementation 2024-01-31 15:05:31 +01:00
anhefti
cd9fcff8f0 SEBSERV-478 review and optimizations 2024-01-31 13:37:25 +01:00
anhefti
7ddbb218e6 SEBSERV-478 review and optimizations 2024-01-31 09:35:08 +01:00
anhefti
a43042ce2f SEBSERV-487 implementation 2024-01-30 15:51:06 +01:00
anhefti
12f67149f0 SEBSLI-4 institution feature and full feature message mockup 2024-01-29 15:07:05 +01:00
anhefti
52192619fd SEBSERV-497 institution feature 2024-01-29 13:10:32 +01:00
anhefti
69334cc5d4 SEBSERV-504 and some woring 2024-01-29 09:28:26 +01:00
Andreas Hefti
a9ac87c213
Merge pull request #106 from SafeExamBrowser/SEBSERV-478
add conditions to hide/display issue filters
2024-01-29 08:23:15 +01:00
Nadim Ritter
c662636cc2 add conditions to hide/display issue filters 2024-01-26 15:54:25 +01:00
Andreas Hefti
474eb4f062
Merge pull request #105 from SafeExamBrowser/SEBSERV-478
add issue filters to exam monitoring
2024-01-25 16:03:43 +01:00
anhefti
21530d3b7a SEBSERV-414 fixes 2024-01-25 15:15:18 +01:00
anhefti
6e6022df92 Merge branch 'dev-1.5' into development
# Conflicts:
#	pom.xml
#	src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ClientConnectionDAOImpl.java
#	src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ExamRecordDAO.java
#	src/test/java/ch/ethz/seb/sebserver/gbl/util/UtilsTest.java
2024-01-25 12:44:16 +01:00
anhefti
db1ec20ad3 Merge remote-tracking branch 'origin/master'
# Conflicts:
#	docs/requirements.txt
2024-01-25 12:27:45 +01:00
anhefti
e8587806ef SEBSERV-502 deprecation note 2024-01-25 12:26:00 +01:00
Nadim Ritter
8f0f6918f1 add issue filters to exam monitoring 2024-01-25 11:53:36 +01:00
anhefti
6d47e8f803 SEBSERV-414 lock screen color selector 2024-01-25 09:51:16 +01:00
anhefti
5f6c32ac54 SEBSERV-414 almost finished (no lock screen color) 2024-01-24 12:18:43 +01:00
anhefti
7ffef0938f SEBSERV-497 new impl and prepare for role based features 2024-01-18 17:29:51 +01:00
anhefti
aec6bd6c04 SEBSERV-456 and FeatureService deprecation 2024-01-18 08:46:47 +01:00
anhefti
52e2a83fb3 fixed tests 2024-01-17 15:25:32 +01:00
anhefti
f3d2976045 SEBSERV-414 signature + removed firefox as permitted process 2024-01-17 15:13:05 +01:00
Andreas Hefti
3575db060d
Merge pull request #102 from SafeExamBrowser/dependabot/pip/docs/readthedocs-sphinx-search-0.3.2
Bump readthedocs-sphinx-search from 0.1.1 to 0.3.2 in /docs
2024-01-17 12:54:43 +01:00
anhefti
23643b0f0a SEBSERV-405 2024-01-17 12:48:10 +01:00
dependabot[bot]
18487a0204
Bump readthedocs-sphinx-search from 0.1.1 to 0.3.2 in /docs
Bumps [readthedocs-sphinx-search](https://github.com/readthedocs/readthedocs-sphinx-search) from 0.1.1 to 0.3.2.
- [Changelog](https://github.com/readthedocs/readthedocs-sphinx-search/blob/main/CHANGELOG.rst)
- [Commits](https://github.com/readthedocs/readthedocs-sphinx-search/compare/0.1.1...0.3.2)

---
updated-dependencies:
- dependency-name: readthedocs-sphinx-search
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-01-16 20:48:53 +00:00
anhefti
90401da1ed fixed Exam description 2024-01-16 16:01:56 +01:00
anhefti
f267e9f1b3 SEBSERV-495 only OK button (removed window close) 2024-01-16 15:38:11 +01:00
anhefti
065a4335dc SEBSERV-465 SEB Settings GUI migration 2024-01-16 13:26:40 +01:00
anhefti
9a21ba25c8 SEBSERV-465 SEB Settings GUI migration 2024-01-15 10:35:45 +01:00
anhefti
015cc9c5c9 SEBSERV-482 testing bugfix 2024-01-11 14:20:31 +01:00
anhefti
ac21400388 SEBSERV-482 implementation no testing yet 2024-01-10 16:38:56 +01:00
anhefti
74d4b1ff7d SEBSERV-490 join proctoring in Ready state only for Exam without LMS 2023-12-21 16:02:51 +01:00
anhefti
cfa9fba9cb SEBSERV-495 fixed minor errors 2023-12-21 13:45:40 +01:00
anhefti
c301016d87 SEBSERV-495 implementation and fix special chars in password 2023-12-21 13:24:39 +01:00
anhefti
b837163c79 make actuator optional 2023-12-20 12:19:53 +01:00
anhefti
ea94adf29b SEBSERV-462 implement force delete 2023-12-19 10:15:06 +01:00
anhefti
8484e2f6b5 SEBSERV-457 fixed exam consistency check to exclude SEB lock for Exam without LMS 2023-12-18 10:44:07 +01:00
anhefti
b4b5b6e410 SEBSERV-457 check uses of lmsSetupId 2023-12-16 10:35:26 +01:00
anhefti
cb9900a16d SEBSERV-457 finished implementation 2023-12-14 16:24:08 +01:00
anhefti
fc310597e6 improved SEB Restriction handling error handling and logging 2023-12-14 12:12:49 +01:00
anhefti
0544d7a799 SEBSERV-457 implementation 2023-12-14 08:19:33 +01:00
anhefti
8584ff5312 SEBSERV-486 streamline reset icons 2023-12-14 08:09:44 +01:00
anhefti
a9d272428f SEBSERV-460 implemented 2023-12-06 16:46:22 +01:00
anhefti
3fa60445e0 SEBSERV-487 preparation 2023-12-06 15:25:35 +01:00
anhefti
c861967f5b prepare for improved user privilege system 2023-12-06 13:06:52 +01:00
anhefti
f2a0034150 prepare for improved user privilege system 2023-12-06 09:01:22 +01:00
anhefti
05c7407651 fixed build 2023-12-05 11:52:39 +01:00
anhefti
232f1a2f4e fixed build 2023-12-05 11:28:06 +01:00
anhefti
5bea674ddc SEBSERV-452 applied ExamPrivilege and FeaturePrivilege to UserInfo for future privilege improvements 2023-12-05 11:24:58 +01:00
anhefti
4cc1eca23e SEBSERV-461 fixed 2023-12-04 16:56:27 +01:00
anhefti
dd9a0381cb SEBSERV-493 DB model generation and ORM mapping 2023-12-04 15:51:23 +01:00
anhefti
a055e23538 finished up improved SEB client connection handshake 2023-12-04 12:01:19 +01:00
anhefti
32567a220a SEBSERV-494 fixed 2023-11-29 19:33:24 +01:00
anhefti
e426a7a6e2 SEBSERV-488 2023-11-29 16:34:22 +01:00
anhefti
9bda8630f6 SEBSERV-435 improved SEB Server SPS user account sync 2023-11-29 14:21:28 +01:00
anhefti
6a0d53c8c4 SEBSERV-435 improved SEB Server SPS user account sync 2023-11-28 16:59:18 +01:00
anhefti
50456b8d9b SEBSERV-440 implemented 2023-11-27 13:15:36 +01:00
anhefti
0d5d7b3894 SEBSERV-475 implemented 2023-11-22 12:12:53 +01:00
anhefti
455d9809c3 SEBSERV-479 fixed 2023-11-21 16:46:20 +01:00
anhefti
6be552b8d3 SEBSERV-473 fixed list and sorting 2023-11-21 15:08:57 +01:00
anhefti
73c0c8627c SEBSERV-492 fixed PATCH instead of POST 2023-11-21 13:43:16 +01:00
anhefti
fd0676d2cc SEBSERV-492 fixed PATCH instead of POST 2023-11-21 11:08:07 +01:00
anhefti
f0ab907866 SEBSERV-486 fixed by better usability 2023-11-21 09:16:15 +01:00
anhefti
8b15fddf13 SEBSERV-481 do sorting und most filtering on DB 2023-11-20 15:32:07 +01:00
anhefti
89adc8cd26 added Zoom User Settings (UZH) 2023-11-16 19:31:18 +01:00
anhefti
fda6c80eb4 fixed ping batch strategy 2023-11-16 14:16:47 +01:00
anhefti
01f3517989 fix for java 8 build 2023-11-16 11:30:00 +01:00
anhefti
e89026591e SEBSERV-476 - fixed edge case with config creation from Exam Template (name exists)
Some code cleanup
2023-11-16 11:23:41 +01:00
anhefti
7079a4f112 SEBSERV-487 defined some features 2023-11-15 10:43:00 +01:00
anhefti
a08a72a2a6 setup and tested code generator on new laptop 2023-11-14 15:41:33 +01:00
anhefti
2f1b4eca9e code cleanup 2023-11-10 11:21:42 +01:00
anhefti
8099531756 code cleanup 2023-11-10 11:15:38 +01:00
anhefti
626c90d9b0 code cleanup 2023-11-10 11:13:00 +01:00
anhefti
6ad231f1ed code cleanup 2023-11-10 11:11:01 +01:00
anhefti
1498fa4150 fixed tests and test new laptopinstall 2023-11-10 10:54:09 +01:00
anhefti
8b452a97a4 removed file appender for logging in demo 2023-11-09 15:51:29 +01:00
anhefti
486e10c8c1 fixed tests 2023-11-09 14:32:12 +01:00
anhefti
2af659dd33 SEBSERV-435 finished up bundle and auto login 2023-11-09 13:50:16 +01:00
anhefti
6e5d5e7710 SEBSERV-435 fixes and preparing integration configuration 2023-11-02 15:01:29 +01:00
anhefti
36b2ccb32c Merge remote-tracking branch 'origin/rel-1.5.3' 2023-10-31 10:16:41 +01:00
anhefti
99ea2472f4 added configurable ping strategies 2023-10-31 09:24:07 +01:00
anhefti
0e1ee3330a SEBSERV-435 fix monitoring update, fix group release when assign failed 2023-10-30 13:00:36 +01:00
anhefti
aff3544802 SEBSERV-474 fix 2023-10-30 10:47:04 +01:00
anhefti
cf1a84a38d SEBSERV-435 implements screen proctoring service linking 2023-10-26 16:06:22 +02:00
anhefti
a04c111b59 SEBSERV-435 gui and monitoring implementation 2023-10-05 16:27:11 +02:00
Andreas Hefti
c3bb795840
Update webservice_seb-server.xml added allow 2023-10-04 08:56:03 +02:00
anhefti
429b393949 added quizaccess/sebserver:managesebserver to moodle privileges 2023-10-03 11:57:54 +02:00
anhefti
bf04341cf9 Merge remote-tracking branch 'origin/rel-1.5.2' 2023-10-03 08:17:02 +02:00
anhefti
1cbc97ef8f Merge remote-tracking branch 'origin/rel-1.5.2' into development
Conflicts:
	pom.xml
	src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamUpdateHandler.java
	src/main/resources/config/ehcache.xml
	src/main/resources/messages.properties
2023-10-03 08:13:03 +02:00
anhefti
60bdb38c7b SEBSERV-435 implementation and testing for Exam. TODO Monitoring 2023-09-28 15:49:26 +02:00
anhefti
fb74fb1804 SEBSERV-434 implemented back-end functionality for screen proctoring 2023-09-21 08:49:37 +02:00
anhefti
43dc14609d fixed tests 2023-08-31 14:52:02 +02:00
anhefti
5982a9e864 SEBSERV-405 and SEBSERV-434 SEB Settings 2023-08-31 14:46:13 +02:00
anhefti
6c23bf56bf SEBSERV-405 new migration task and messages 2023-08-28 13:10:58 +02:00
anhefti
48f301a63a fixed certificates 2023-08-24 13:54:21 +02:00
anhefti
b9d3b4522a SEBSERV-369 mybatis update 2023-08-24 13:34:05 +02:00
anhefti
40c6d2b1f3 SEBSERV-405 boot 2.6.15 mybatis 3.5.6 (old) 2023-08-24 13:01:46 +02:00
anhefti
26178f66fb fixed refresh token request 2023-07-18 15:15:48 +02:00
anhefti
cda0ddb926 added support for refresh token 2023-07-17 15:41:14 +02:00
anhefti
4736b9208a Merge remote-tracking branch 'origin/rel-1.5-uzh' into development 2023-07-17 11:13:05 +02:00
anhefti
fe55daa01f SEBSERV-450 fixed. 2023-07-17 10:47:58 +02:00
anhefti
24416e7faa refactoring of Page model Integer --> int 2023-07-12 11:50:05 +02:00
anhefti
77646cd40e added cleanup artifacts task on CI pipline 2023-07-05 09:13:44 +02:00
anhefti
07d568be6f fixed batis mapper registry for batch store? 2023-06-27 16:47:05 +02:00
anhefti
00995bee96 Merge remote-tracking branch 'origin/rel-1.5.1' into dev-1.5 2023-06-19 16:35:22 +02:00
anhefti
3463bf6451 Merge remote-tracking branch 'origin/rel-1.5.1' 2023-06-19 16:33:23 +02:00
anhefti
9c27e6ca60 fixed README 2023-06-19 14:44:55 +02:00
anhefti
ac880674d0 Merge remote-tracking branch 'origin/rel-1.5.1'
Conflicts:
	README.rst
2023-06-19 14:42:53 +02:00
anhefti
62f993ccd5 Merge remote-tracking branch 'origin/dev-1.5' into development
Conflicts:
	pom.xml
2023-06-19 14:37:25 +02:00
anhefti
0616f82c9f Merge remote-tracking branch 'origin/rel-1.5-uzh' into development
Conflicts:
	src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/impl/mockup/MockCourseAccessAPI.java
2023-06-15 15:11:16 +02:00
anhefti
6573b1438b Merge remote-tracking branch 'origin/dev-1.5' into development 2023-06-15 15:09:56 +02:00
anhefti
ae1561a51a SEBSERV-450 better error handling 2023-06-15 15:00:57 +02:00
anhefti
84f20cc866 Merge remote-tracking branch 'origin/rel-1.5-uzh' into development 2023-06-15 11:14:50 +02:00
anhefti
e2aabd4044 Merge remote-tracking branch 'origin/dev-1.5' into development 2023-06-15 11:14:11 +02:00
anhefti
6281634a46 some fixed in GUI from 1.5.1 2023-06-15 11:09:33 +02:00
anhefti
076a54a2c7 Merge remote-tracking branch 'origin/dev-1.5' into development 2023-06-14 15:38:32 +02:00
anhefti
7dd72f27c9 SEBSERV-451 code cleanup 2023-06-14 15:30:42 +02:00
anhefti
aa0e3b3a47 SEBSERV-451 fixed 2023-06-14 15:28:22 +02:00
anhefti
4355f9f47f code cleanup 2023-06-14 15:01:14 +02:00
anhefti
2ffa17b839 Merge remote-tracking branch 'origin/newSEBEventStoreStrategy' into development 2023-06-08 16:10:02 +02:00
anhefti
c44c8265a4 Merge remote-tracking branch 'origin/SEBSERV-449_MoodlePluginLuca' into
dev-1.5
2023-06-08 16:01:32 +02:00
anhefti
87e24b3840 SEBSERV-444 fixed hopefully last time 2023-06-08 15:17:54 +02:00
anhefti
c26f235447 adapt keep alive timeout 2023-06-08 08:45:21 +02:00
anhefti
6354da0f49 seems to work well with 4 workers... consider to add to 1.6 2023-06-06 09:18:45 +02:00
anhefti
886f457438 with logging 2023-06-06 09:12:01 +02:00
anhefti
8322f07cf7 with logging 2023-06-06 09:06:02 +02:00
anhefti
4924c7f125 fix concurrency error 2023-06-06 09:01:18 +02:00
anhefti
f29aa52dd0 only one worker again 2023-06-06 08:54:47 +02:00
anhefti
456b6094f7 try with 4 event batch workers 2023-06-06 08:43:19 +02:00
anhefti
3908d2fca9 Merge remote-tracking branch 'origin/rel-1.5-uzh' into development 2023-06-05 13:45:01 +02:00
anhefti
c06bca1f86 made default SEB client ping interval configurable 2023-06-05 12:44:56 +02:00
anhefti
d99dc58bc9 test logs 2023-06-05 12:22:35 +02:00
anhefti
c4da6672f6 test pings again 2023-06-05 12:13:41 +02:00
anhefti
3c90260fba code cleanup 2023-06-01 16:17:54 +02:00
anhefti
467fdb9c7f Merge remote-tracking branch 'origin/dev-1.5' into development 2023-06-01 16:04:02 +02:00
anhefti
a57e371580 Merge remote-tracking branch 'origin/newSEBEventStoreStrategy' into development 2023-06-01 16:03:23 +02:00
anhefti
933ddaa4d3 removed sync again (seems to has no effect) 2023-06-01 15:47:29 +02:00
anhefti
5dc85f9e73 no sync in ping and event 2023-06-01 14:43:54 +02:00
anhefti
45e01dc0dd re-added synchronization to look if it has effect 2023-06-01 14:29:15 +02:00
anhefti
2c197665f0 fixed task scheduler config 2023-06-01 12:43:41 +02:00
anhefti
8cab729401 SEBSERV-445 code cleanup 2023-06-01 09:03:22 +02:00
anhefti
b344ee22e5 ping with executor 2023-05-31 20:30:12 +02:00
anhefti
2a16813cd7 test tomcat config 2023-05-31 15:21:45 +02:00
anhefti
0bdb91e4c1 adapted tomcat config 2023-05-31 15:19:36 +02:00
anhefti
b7c8f3c1d4 fixed monitoring update delay for indicators? 2023-05-31 13:08:05 +02:00
anhefti
e0708a2be1 try monitoring update everytime 2023-05-31 12:57:33 +02:00
anhefti
62a6db12c6 revert DeferredResult 2023-05-31 12:57:06 +02:00
anhefti
9c82f20763 SEBSERV-445 using DerreferedResult for client connections 2023-05-31 11:34:25 +02:00
anhefti
6ccf74f9c1 SEBSERV-445 better ping batch strategy? 2023-05-31 09:12:46 +02:00
anhefti
9708d8610b SEBSERV-445 removed synchronized SEB connection cache access 2023-05-30 15:40:17 +02:00
anhefti
48d3e5101c SEBSERV-445 adapt Tomcat connector settings 2023-05-30 14:58:39 +02:00
anhefti
527c575eeb removed ping number 2023-05-30 10:42:43 +02:00
anhefti
a5335f1c98 SEBSERV-445 pings go to working queue just after arriving too now 2023-05-30 09:21:53 +02:00
anhefti
e3b44cb60b SEBSERV-445 new SEB event store strategy with background tasks 2023-05-26 13:26:03 +02:00
anhefti
314ce82c00 removed synchronization for check access on SEB ping 2023-05-25 16:15:36 +02:00
anhefti
d63f25fb45 increased SEB connection cache to 100000 entries 2023-05-25 15:08:09 +02:00
anhefti
251dc0b0d0 SEBSERV-446 fixed 2023-05-24 13:08:45 +02:00
Andreas Hefti
38042d4cec
Merge pull request #78 from lucaboesch/sebs15documentation
Safe Exam Browser Server 1.5 documentation
2023-05-17 09:16:26 +02:00
anhefti
9ef49a8560 Merge branch 'dev-1.5' into development 2023-05-16 13:35:31 +02:00
Luca Bösch
ea35b7c0e4 Documentation improvements. 2023-05-15 16:17:28 +02:00
Luca Bösch
659ad0e9ff Moodle plugin repository renamed. 2023-05-15 12:26:58 +02:00
anhefti
7c42974838 SEBSERV-413 removed old LMS Setup code (async loader Moodle) 2023-05-15 09:49:39 +02:00
anhefti
bf6aa19a82 Merge branch 'dev-1.5' into development 2023-05-15 09:07:45 +02:00
anhefti
39e57becc0 setup docker with Java v17 2023-05-11 16:00:57 +02:00
anhefti
0db5c59947 Merge branch 'dev-1.5' into development 2023-05-11 12:12:20 +02:00
anhefti
dcbb279052 update README 2023-05-08 21:44:12 +02:00
anhefti
0eaad0d836 Merge branch 'dev-1.5' into development 2023-05-08 20:23:36 +02:00
anhefti
d01b01d799 foxed docu 2023-05-08 20:21:18 +02:00
anhefti
24dd1b94c0 prepare for release 1.6 2023-05-08 19:45:00 +02:00
1231 changed files with 26255 additions and 10504 deletions

View file

@ -16,89 +16,50 @@ jobs:
maven-build-reporting: maven-build-reporting:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- - name: Get short SHA
name: Checkout repository uses: benjlevesque/short-sha@v3.0
uses: actions/checkout@v3
-
name: Set up JDK 8
uses: actions/setup-java@v3
with:
java-version: '8'
distribution: 'adopt'
-
name: Cache Maven packages
uses: actions/cache@v3
with:
path: ~/.m2
key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-m2
-
name: Build with Maven
run: mvn clean install -e -P let_reporting
-
name: Reporting
uses: codecov/codecov-action@v3
with:
flags: unittests
name: SEB Server Build
fail_ci_if_error: false
verbose: false
maven-build-docker:
needs: maven-build-reporting
# Run only on tagging
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
runs-on: ubuntu-latest
steps:
-
name: Get short SHA
uses: benjlevesque/short-sha@v2.1
id: short-sha id: short-sha
- - name: Store short SHA as environment variable
name: Store short SHA as environment variable
run: echo $SHA run: echo $SHA
env: env:
SHA: ${{ steps.short-sha.outputs.sha }} SHA: ${{ steps.short-sha.outputs.sha }}
- - name: Set env
name: Set env
run: echo "TAG_NAME=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV run: echo "TAG_NAME=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
- - name: Test tag name
name: Test tag name
run: | run: |
echo $TAG_NAME echo $TAG_NAME
echo ${{ env.TAG_NAME }} echo ${{ env.TAG_NAME }}
- -
name: Checkout repository name: Checkout repository
uses: actions/checkout@v3 uses: actions/checkout@v4
- -
name: Set up JDK 11 name: Build Test Reporting
uses: actions/setup-java@v3 uses: actions/setup-java@v4
with: with:
java-version: '11' java-version: '17'
distribution: 'adopt' distribution: 'adopt'
- -
name: Cache Maven packages name: Cache Maven packages
uses: actions/cache@v3 uses: actions/cache@v4
with: with:
path: ~/.m2 path: ~/.m2
key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }} key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-m2 restore-keys: ${{ runner.os }}-m2
- -
name: Build with Maven name: Build with Maven
run: mvn clean install -Dmaven.test.skip=true -Dsebserver-version="${{ env.TAG_NAME }}-${{ env.SHA }}" run: mvn clean install -e -P let_reporting -Dsebserver-version="${{ env.TAG_NAME }}-${{ env.SHA }}"
env: env:
sebserver-version: ${{ env.TAG_NAME }}-${{ env.SHA }} sebserver-version: ${{ env.TAG_NAME }}-${{ env.SHA }}
-
name: Simplify package name - name: Simplify package name
run: mv target/seb-server-${{ env.TAG_NAME }}-${{ env.SHA }}.jar target/seb-server.jar run: mv target/seb-server-${{ env.TAG_NAME }}-${{ env.SHA }}.jar target/seb-server.jar
- - uses: actions/upload-artifact@v4
uses: actions/upload-artifact@v3
with: with:
name: Package name: Package
path: target/seb-server.jar path: target/seb-server.jar
docker-build: docker-build:
needs: maven-build-docker needs: maven-build-reporting
# Run only on tagging # Run only on tagging
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/') if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -120,10 +81,10 @@ jobs:
echo ${{ env.TAG_NAME }} echo ${{ env.TAG_NAME }}
- -
name: Set up QEMU name: Set up QEMU
uses: docker/setup-qemu-action@v2 uses: docker/setup-qemu-action@v3
- -
name: Set up Docker Buildx name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2 uses: docker/setup-buildx-action@v3.2.0
- -
name: Login to DockerHub name: Login to DockerHub
uses: docker/login-action@v2 uses: docker/login-action@v2
@ -132,7 +93,7 @@ jobs:
password: ${{ secrets.DOCKERHUB_TOKEN }} password: ${{ secrets.DOCKERHUB_TOKEN }}
- -
name: Checkout repository name: Checkout repository
uses: actions/checkout@v3 uses: actions/checkout@v4
# Install the cosign tool except on PR # Install the cosign tool except on PR
# https://github.com/sigstore/cosign-installer # https://github.com/sigstore/cosign-installer
@ -142,7 +103,7 @@ jobs:
uses: sigstore/cosign-installer@main uses: sigstore/cosign-installer@main
- -
name: Download a single artifact name: Download a single artifact
uses: actions/download-artifact@v3 uses: actions/download-artifact@v4
with: with:
name: Package name: Package
- -
@ -176,3 +137,15 @@ jobs:
env: env:
COSIGN_EXPERIMENTAL: true COSIGN_EXPERIMENTAL: true
TAGS: ${{ steps.meta.outputs.tags }} TAGS: ${{ steps.meta.outputs.tags }}
cleanup:
needs: [maven-build-reporting, docker-build]
if: |
always()
runs-on: ubuntu-latest
steps:
-
name: Delete Artifacts
uses: geekyeggo/delete-artifact@v5
with:
name: Package

10
Jenkinsfile vendored
View file

@ -14,16 +14,16 @@ pipeline {
stages { stages {
stage('Maven build') { stage('Maven build') {
steps { steps {
withMaven(maven: 'Maven', options: [findbugsPublisher(disabled: true)]) { withMaven(maven: 'Maven3.9.6') {
sh "mvn clean install -e -P let_reporting" sh "mvn clean install -e -P let_reporting"
} }
} }
} }
stage('Reporting') { stage('Reporting') {
steps { steps {
withMaven(maven: 'Maven', options: [findbugsPublisher(disabled: true)]) { withMaven(maven: 'Maven3.9.6') {
sh "mvn --batch-mode -V -U -e -P let_reporting pmd:pmd pmd:cpd findbugs:findbugs spotbugs:spotbugs" sh "mvn --batch-mode -V -U -e -P let_reporting pmd:pmd pmd:cpd spotbugs:spotbugs"
} }
} }
} }
@ -50,6 +50,6 @@ pipeline {
} }
triggers { triggers {
pollSCM('H/5 * * * *') pollSCM('H/5 * * * *')
} }
} }

View file

@ -1,22 +1,13 @@
Master: Safe Exam Browser (SEB) Server
--------------------------------
.. image:: https://github.com/SafeExamBrowser/seb-server/actions/workflows/buildReporting.yml/badge.svg?branch=master .. image:: https://github.com/SafeExamBrowser/seb-server/actions/workflows/buildReporting.yml/badge.svg?branch=master
:target: https://github.com/SafeExamBrowser/seb-server/actions :target: https://github.com/SafeExamBrowser/seb-server/actions
.. image:: https://readthedocs.org/projects/seb-server/badge/?version=latest .. image:: https://readthedocs.org/projects/seb-server/badge/?version=latest
:target: https://seb-server.readthedocs.io/en/latest/?badge=latest :target: https://seb-server.readthedocs.io/en/latest/?badge=latest
.. image:: https://codecov.io/gh/SafeExamBrowser/seb-server/branch/master/graph/badge.svg
:target: https://codecov.io/gh/SafeExamBrowser/seb-server
.. image:: https://img.shields.io/github/languages/code-size/SafeExamBrowser/seb-server .. image:: https://img.shields.io/github/languages/code-size/SafeExamBrowser/seb-server
:target: https://github.com/SafeExamBrowser/seb-server :target: https://github.com/SafeExamBrowser/seb-server
Development:
.. image:: https://github.com/SafeExamBrowser/seb-server/actions/workflows/buildReporting.yml/badge.svg?branch=development
:target: https://github.com/SafeExamBrowser/seb-server/actions
.. image:: https://codecov.io/gh/SafeExamBrowser/seb-server/branch/development/graph/badge.svg
:target: https://codecov.io/gh/SafeExamBrowser/seb-server
.. image:: https://img.shields.io/github/last-commit/SafeExamBrowser/seb-server/development?logo=github
:target: https://github.com/SafeExamBrowser/seb-server/tree/development
The Safe Exam Browser Server web application simplifies and centralizes the configuration of Safe Exam Browser clients for exams. It interacts with a learning management or exam system for setting up and conducting e-assessments with Safe Exam Browser. It also improves security by allowing to monitor connected Safe Exam Browser clients in real time during e-assessments. The Safe Exam Browser Server web application simplifies and centralizes the configuration of Safe Exam Browser clients for exams. It interacts with a learning management or exam system for setting up and conducting e-assessments with Safe Exam Browser. It also improves security by allowing to monitor connected Safe Exam Browser clients in real time during e-assessments.
@ -32,7 +23,7 @@ What is Safe Exam Browser Server (SEB Server)?
While the interaction with SEB is well known in Learning Management Systems (LMS) like `Open edX <https://open.edx.org/>`_, While the interaction with SEB is well known in Learning Management Systems (LMS) like `Open edX <https://open.edx.org/>`_,
`Moodle <https://moodle.org/>`_ etc. the SEB Server is an entirely new component to set up secured online exams. `Moodle <https://moodle.org/>`_ etc. the SEB Server is an entirely new component to set up secured online exams.
It interacts with the assessments system/LMS as well as with SEB on exam clients.It supports exam scenarios on student owned devices (BYOD) It interacts with the assessments system/LMS as well as with SEB on exam clients. It supports exam scenarios on student owned devices (BYOD)
and on managed devices. and on managed devices.
SEB Server is a modern webservice with a REST API and a GUI service on top of it. SEB Server is written in Java and uses Docker for installation and setup. SEB Server is a modern webservice with a REST API and a GUI service on top of it. SEB Server is written in Java and uses Docker for installation and setup.
@ -40,7 +31,7 @@ SEB Server is a modern webservice with a REST API and a GUI service on top of it
SEB Server provides a range of basic functionalities: SEB Server provides a range of basic functionalities:
- Built-in institutional multitenancy - Built-in institutional multitenancy
- Linking of multiple Learning Management Systems (LMS). Currently supported LMS: `Open edX <https://open.edx.org/>`_, `Moodle <https://moodle.org/>`_, `Open Olat <https://www.openolat.com/>`_, `ANS <https://ans.app/>`_ - Linking of multiple Learning Management Systems (LMS). Currently supported LMS: `Open edX <https://open.edx.org/>`_, `Moodle <https://moodle.org/>`_, `OLAT <https://www.olat.org/>`_, `ANS <https://ans.app/>`_
- Accessing the Course/Exam-API of a linked LMS to import a courses or exams for managing with SEB Server - Accessing the Course/Exam-API of a linked LMS to import a courses or exams for managing with SEB Server
- Creation and administration of SEB Client Configurations that can be used to startup a SEB and that contains SEB Server connection information for a SEB Client - Creation and administration of SEB Client Configurations that can be used to startup a SEB and that contains SEB Server connection information for a SEB Client
- Creation and administration of SEB Exam Configurations that can be bound to an imported Exam to automatically configure a SEB Client that connects to an exam that is managed by SEB Server - Creation and administration of SEB Exam Configurations that can be bound to an imported Exam to automatically configure a SEB Client that connects to an exam that is managed by SEB Server
@ -55,74 +46,52 @@ a more automated and secure setup for high-stake exams.
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-1.5/docs/images/setup_1.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-1.5/docs/images/setup_1.png
SEB Server Version 1.5 is out SEB Server Version 2.0 is out
------------------------------- -------------------------------
With the new SEB Server release, SEB Server makes a major version change from 1.x to 2.x. This is mainly because of the new
Screen Proctoring feature for SEB integrated into SEB Server and the removal of live proctoring with Zoom and Jitsi Meet
that is no longer available for SEB Server version 2.x.
For a migration from a running SEB Server setup with version 1.x to new major version 2.0, please also read the `migration guide <https://seb-server-setup.readthedocs.io/en/latest/major-migration.html>`_.
New Features: New Features:
- Screen Proctoring with SEB and SEB Server. Can be enabled and configured for an Exam. SEB takes and sends screen shots plus Metadata to SEB Server. With monitoring and search functionality.
- Moodle Integration: SEB Server Exam creation from Moodle site with new SEB Server Moodle Plugin 2.0.
- Moodle Integration: Auto Login to SEB Server monitoring for Moodle Teacher with dedicated privileges. Comes with Moodle Plugin 2.0
- Exam Test Run. There is now the possibility to apply an test run for an Exam that is in coming up status. Exam is then in "Running" like state and SEB clients can connect as well as supporter can monitor the exam.
- Security: New Application Signature Key (ASK) integration within SEB Server exams and monitoring
- Security: Minimum SEB Client version tracking within SEB Server monitoring
- LMS Integration: Better Moodle integration with new `SEB Server Moodle Plugin <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_
- Exam Maintenance: Added new SEB grouping functionality for Exam (and Exam Template) and Monitoring to be able to view/manage SEB Clients within defined groups (IP range, SEB client OS, ...)
- Exam Maintenance: Batch actions for archive and delete exams
- Exam Maintenance: Added SEB log export for finished and archived exams
- Exam List: Filter for unavailable exams
- Exam Monitoring: Added force SEB Lock Screen feature to be able to send lock screen instruction to SEB client as well as release such from SEB Server
- User Account: Added "Change Password" function also in User Account edit page
Improvements: Improvements:
- Improvement of user ID resolution and handshake completion for SEB connecting with SEB-Server. SEB client now sent as much client information as possible and finish up the SEB Server handshake more quickly.
- Connection Configuration Improve (or remove) Date Filter.
- DB Migration Table charset fix for all tables, set to "utf8mb4_general"
- New SEB Settings in SEB Server GUI for version 2.0
- Table sort direction selection and table column length selection stick to User Session
- LMS Setup Lookup: Improved parallel data fetch of course and quit data from LMS and added notifications to the UI if background job is still fetching data from LMS in the background Bugfixes:
- Zoom Proctoring: Adapted to new Zoom API's, SDK's and Apps - Missing Pending Notification Page Update in Monitoring Detail view
- Zoom Proctoring: Gallery view works now also in the proctoring web-client of the SEB Server - Importing an exam without template throws error
- Open Olat Integration: Added propagation of quit-link and quit-password for exam to Open Olat within the SEB restriction - LMS name resolving sometimes gets "null" values for names
- Monitoring: Improved performance for active monitoring - New Ready State is not involved within the Filter numbers
- Migration: Improved migration and added database table-char-set check - Page of ASK Grants in Exam has table selection action problems
- SEB Settings: Added various new SEB Settings within the SEB Server database and Configuration Template (not yet in Exam Configuration UI) - Sorting of start and end-date in Assessment Tool Lookup not working as expected
- Added Tool-Tips also for list filters / various text and minor UI improvements - Running Exam without LMS is greyed out without reason
Bugfixes:
- Exam Configuration status change to "Archived" is possible for up-coming exams
- Fix handling of invalid SEB Server monitoring UI sessions
- Open Olat LMS Setup access deadlock (serialized token request for LMS Template)
- Fixed exam update background process to update sometimes exams from LMS where nothing changed on LMS side
- Zoom proctoring multiplied participants on room change
- SEB Restriction warning on Exam seems to be not present when restriction fails
- Certificate cannot be imported
- Configuration Template: Filtering column "View": Paging in attribute list shows only one page
- Exam Configuration export SEB Settings should export current settings
- Exam: Name and Date filter does not work correctly
- Export Exam Connection Configuration, special characters in exam name cut of file name
- Zoom proctoring gallery view seems not to work because of cross-origin settings
Docker-Image:
SEB - SEB Server Compatibility SEB - SEB Server Compatibility
------------------------------ ------------------------------
The table below shows available and upcoming SEB client versions that has SEB Server integration support and are compatible with particular The table below shows available and upcoming SEB client versions that has SEB Server integration support and are compatible with particular
SEB Server version. There is an entry for each platform with a beta or testing release date and a official release date. SEB Server versions. There is an entry for each platform with a beta or testing release date and an official release date.
**SEB Server Version 1.5.X** **SEB Server Version 2.0.x**
.. csv-table:: .. csv-table::
:header: "Platform / OS", "Beta/RC Version", "Release Version" :header: "Platform / OS", "Release Version"
"SEB Client for iOS", "ASK: 3.3", "3.1 (ASK: 3.3)" "SEB Client for iOS", "3.4 (3.3.3 without screen proctoring)"
"SEB Client for Mac", "ASK: 3.3pre", "3.1 (Zoom: 3.2/ASK: 3.3)" "SEB Client for Mac", "3.4"
"SEB Client for Windows", "--", "3.5.0 " "SEB Client for Windows", "3.8"
**SEB Server Version 1.4.X**
.. csv-table::
:header: "Platform / OS", "Beta/RC Version", "Release Version"
"SEB Client for iOS", "3.1 Beta", "3.1 (Zoom: 3.2) "
"SEB Client for Mac", "3.1/3.2 Preview", "3.1 (Zoom: 3.2)"
"SEB Client for Windows", "--", "Version 3.3.2 - 3.4.0"
Install SEB Server Install SEB Server
------------------ ------------------
@ -134,7 +103,62 @@ Getting started with SEB Server
For a complete SEB Server user guide please go to `SEB Server User Guide <https://seb-server.readthedocs.io/en/latest/#>`_ For a complete SEB Server user guide please go to `SEB Server User Guide <https://seb-server.readthedocs.io/en/latest/#>`_
Project Background Project Background
------------------ ------------------
The SEB Server is currently build and maintained by `ETH Zürich <https://ethz.ch/en.html>`_ and by the `Swiss MOOC Service <https://www.swissmooc.ch/>`_ that is founded by leading Swiss universities EPFL, ETH, SUPSI, USI and HES-SO. The Swiss MOOC Service was financially supported from 2018-2020 by the `Swissuniversities´ P5 program <https://www.swissuniversities.ch/themen/digitalisierung/p-5-wissenschaftliche-information>`_. The SEB Server is currently build and maintained by `ETH Zürich <https://ethz.ch/en.html>`_ and by the `Swiss MOOC Service <https://www.swissmooc.ch/>`_ that is founded by leading Swiss universities EPFL, ETH, SUPSI, USI and HES-SO. The Swiss MOOC Service was financially supported from 2018-2020 by the `Swissuniversities´ P5 program <https://www.swissuniversities.ch/themen/digitalisierung/p-5-wissenschaftliche-information>`_.
Contributing to SEB Server
---------------------------
We want to make contributing to this project as easy and transparent as possible, whether it's:
- Give us a star
- Reporting a bug
- Submitting a fix
- Proposing new features
- Becoming a SEB Alliance member
We use github to host code, to track issues and feature requests, as well as accept pull requests.
And we use `Github issues <https://github.com/SafeExamBrowser/seb-server/issues>`_ to track public bugs.
Report a bug by [opening a new issue]();
**Before enter a new bug-report, ensure the bug was not already reported**
Please fill and provide all the information suggested by the bug-report template
Great Bug Reports tend to have:
- A quick summary and/or background
- Steps to reproduce
- Be specific and give sample code if you can. Can also be Pseudocode.
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)
**We Use Git-Flow for Code Contributions**
Pull requests are the best way to propose changes to the codebase. We use `Github Flow <https://www.atlassian.com/git/tutorials/comparing-workflows/gitflow-workflow>`_. We actively welcome your pull requests:
1. Fork the repo and create your branch from `development`. The development branch always has the newest changes.
2. If you've added code that should be tested, add tests.
3. If you introduce new API also add clear documentation.
4. Ensure the test suite passes.
5. Make sure your code lints.
6. Issue that pull request!
**Use a Consistent Coding Style**
Have a close look to the existing code stile that is used within SEB Server and adapt to it as close as possible.
We reserve the right to adapt contributed code to the code style matching SEB Server code style before or after a pull request.
**Any contributions you make will be under the Mozilla Public License Version 2.0**
In short, when you submit code changes, your submissions are understood to be under the same `Mozilla Public License <https://github.com/SafeExamBrowser/seb-server?tab=MPL-2.0-1-ov-file>`_ that covers the project. Feel free to contact the maintainers if that's a concern.
**Becoming a SEB Alliance member**
The `SEB Alliance <https://www.safeexambrowser.org/alliance/members.html>`_ is the body which sustains ongoing funding of the Safe Exam Browser open source project to continue its maintenance, development and support activities. ETH Zurich provides the infrastructure for the management and the software engineering of the SEB project and appoints an alliance manager who will provide administrative support to the SEB Alliance, and ensure the day-to-day running of the SEB Alliance. ETH Zurich leads the Alliance and offers different contribution levels to parties interested in the evolution of the SEB open source project.
More information about `joining <https://www.safeexambrowser.org/alliance/join.html>`_ the Alliance is available in our `benefits <https://www.safeexambrowser.org/alliance/benefits.html>`_ and `documents <https://www.safeexambrowser.org/alliance/documents.html>`_ section.

View file

@ -1,15 +0,0 @@
coverage:
precision: 2
round: down
range: "30..70"
status:
project:
default:
threshold: 5%
patch: off
github_checks:
annotations: false
fixes:
-"::seb-server/"

View file

@ -1,4 +1,4 @@
FROM openjdk:11-jre-stretch FROM eclipse-temurin:17-jre
ENV SERVER_PORT="8080" ENV SERVER_PORT="8080"
ENV JMX_PORT= ENV JMX_PORT=
@ -38,4 +38,4 @@ CMD if [ "x${JMX_PORT}" = "x" ] ; \
--spring.config.location=file:/sebserver/config/spring/,classpath:/config/; \ --spring.config.location=file:/sebserver/config/spring/,classpath:/config/; \
fi fi
EXPOSE $SERVER_PORT $JMX_PORT EXPOSE $SERVER_PORT $JMX_PORT

View file

@ -18,7 +18,7 @@ Once a certificate has been uploaded to SEB Server it can be used for various ot
One feature that also comes with the SEB Server version 1.2 is the ability to encrypt a connection configuration with a certificate One feature that also comes with the SEB Server version 1.2 is the ability to encrypt a connection configuration with a certificate
that has the right purpose (Identity) to do so. If you need this feature already, please have a look at: :ref:`connection-configuration-label`. that has the right purpose (Identity) to do so. If you need this feature already, please have a look at: :ref:`connection-configuration-label`.
Other planed features are the import of certificate encrypted exam configurations as well as to embed certificates within an exam configuration Other planed features are the import of certificate encrypted exam configurations as well as to embed certificates within an exam configuration
to allow certificate pinning between SEB and LMS. to allow certificate pinning between SEB and LMS/Assessment Tool.
There is currently certificate upload support for two version of certificates: There is currently certificate upload support for two version of certificates:
@ -39,7 +39,7 @@ This are usually password protected certificates in different file-formats. SEB
.. image:: images/certificates/cert_list.png .. image:: images/certificates/cert_list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/certificates/cert_list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/certificates/cert_list.png
Use Cases Use Cases

View file

@ -16,7 +16,7 @@ a specific template by name for example.
.. image:: images/config_templates/list.png .. image:: images/config_templates/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/config_templates/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/config_templates/list.png
To create a new exam configuration template, use the "Add Configuration Template" action from the right action pane. You will see the creation form To create a new exam configuration template, use the "Add Configuration Template" action from the right action pane. You will see the creation form
with a name and description for the new template. At least a unique name is mandatory, and the description is optional. with a name and description for the new template. At least a unique name is mandatory, and the description is optional.
@ -32,7 +32,7 @@ SEB Server. The name of an attribute is composed of the internal attribute name
.. image:: images/config_templates/templateView.png .. image:: images/config_templates/templateView.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/config_templates/templateView.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/config_templates/templateView.png
The type of the attribute defines the input field type and cannot be changed in any way. The view defines the tab on which the settings attribute is placed. The type of the attribute defines the input field type and cannot be changed in any way. The view defines the tab on which the settings attribute is placed.
And the group defines the named group where a settings attribute belongs to. And the group defines the named group where a settings attribute belongs to.
@ -59,7 +59,7 @@ use the "View Configuration Template" action from the right action pane.
.. image:: images/config_templates/templateAttribute.png .. image:: images/config_templates/templateAttribute.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/config_templates/templateAttribute.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/config_templates/templateAttribute.png
Back in the exam configuration template view you are able to create a new SEB exam configuration directly from this template by using the "Create Exam Configuration" Back in the exam configuration template view you are able to create a new SEB exam configuration directly from this template by using the "Create Exam Configuration"
action from the right action pane. The application will present you a creation dialog within a pop-up where you can define a name and description for the action from the right action pane. The application will present you a creation dialog within a pop-up where you can define a name and description for the
@ -67,7 +67,7 @@ new SEB exam configuration. At least a unique name is mandatory.
.. image:: images/config_templates/createConfig.png .. image:: images/config_templates/createConfig.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/config_templates/createConfig.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/config_templates/createConfig.png
After defining a name and description for the new SEB exam configuration you can click on "OK" to do so, and the application will show you the new created After defining a name and description for the new SEB exam configuration you can click on "OK" to do so, and the application will show you the new created
SEB exam configuration in the usual place. SEB exam configuration in the usual place.

View file

@ -21,7 +21,7 @@ This feature is currently in an experimental state and may be changed and / or e
An new feature since SEB Server version 1.2 is the integrated certificate store where an administrator is able to upload and register An new feature since SEB Server version 1.2 is the integrated certificate store where an administrator is able to upload and register
certificates. The certificates can then be used to encrypt and secure a connection configuration for example. Or as planned for another certificates. The certificates can then be used to encrypt and secure a connection configuration for example. Or as planned for another
SEB Server release, to embed into an exam configuration for SEB to allow certificate pinning on SEB - LMS communication. SEB Server release, to embed into an exam configuration for SEB to allow certificate pinning on SEB - LMS/Assessment Tool communication.
.. toctree:: .. toctree::

View file

@ -34,7 +34,7 @@ of the "Configuration" section on the menu on the left hand side.
.. image:: images/connection_config/list.png .. image:: images/connection_config/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/connection_config/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/connection_config/list.png
The list shows the name, the date of creation and the status of the connection configurations in a column. With SEB Server administrator role The list shows the name, the date of creation and the status of the connection configurations in a column. With SEB Server administrator role
also an institution column is shown because a SEB Server administrator is able to see all connection configurations of all institutions. also an institution column is shown because a SEB Server administrator is able to see all connection configurations of all institutions.
@ -46,7 +46,7 @@ or remove selection to hide all fallback related attributes.
.. image:: images/connection_config/new.png .. image:: images/connection_config/new.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/connection_config/new.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/connection_config/new.png
Short description of all attributes of a connection configuration: Short description of all attributes of a connection configuration:
@ -67,7 +67,8 @@ Short description of all attributes of a connection configuration:
A connection configuration may also contain and define a fallback strategy that takes place when SEB Server service is not available while A connection configuration may also contain and define a fallback strategy that takes place when SEB Server service is not available while
a SEB client tries to connect to the SEB Server. a SEB client tries to connect to the SEB Server.
.. note:: .. note::
A fallback case only takes place when SEB client is within the connection process (handshake) with the SEB Server and the SEB Server service is unavailable. A fallback case only takes place when SEB client is within the connection process (handshake) with the SEB Server and the SEB Server service is unavailable.
If a SEB client is already connected to the SEB Server and the user has started an exam, the SEB will just proceed with the exam even If a SEB client is already connected to the SEB Server and the user has started an exam, the SEB will just proceed with the exam even
when the SEB Server connection is (temporarily) unavailable. when the SEB Server connection is (temporarily) unavailable.
@ -91,6 +92,30 @@ configuration settings in the following ways:
- Connection configuration with "Starting an Exam" setting and fallback strategy: - Connection configuration with "Starting an Exam" setting and fallback strategy:
Show warning with options "retry", "fallback" (load Fallback URL) and "quit". Show warning with options "retry", "fallback" (load Fallback URL) and "quit".
**New: Exam Selection for dedicated Client Configurations**
This is a new feature since SEB Server Version 1.6. and allows to select existing exams within a Connection Configuration to reduce the possible
Exams that SEB presents to a student when a Connection Configuration is loaded by SEB that has no dedicated Exam preselection (downloaded from the Exam view)
In this case SEB always presented all currently running Exams from the SEB Server to the student for selection. With this
feature it is now possible to reduce this choice for a specific Client Configuration by selecting the Exams that shall be shown to a student
when SEB loads the respective Connection Configuration.
.. note::
Since the Exam selection is stored with SEB Server and not exported to an Connection Configuration it is also possible
to change the Exam selection for a certain Connection Configuration after the Connection Configuration was downloaded.
SEB will always present the running exams exclusively from actual Exam selection from Connection Configuration on the SEB Server.
If an Connection Configuration has no Exam selection all still running exams are presented to the student as it was before.
To select dedicated Exams for a Connection Configuration you can go to the Connection Configuration edit view and select
these exams with the multi selector. It is also possible to filter the list by typing in the letters containing in the Exam name of interest.
.. image:: images/connection_config/examSelection.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/connection_config/examSelection.png
Use Cases Use Cases
--------- ---------

View file

@ -1,7 +1,7 @@
Prepare Exam Prepare Exam
============= =============
This chapter is about setting up and prepare a already imported exam on SEB Server. If you don't have imported a course or quiz from LMS This chapter is about setting up and prepare a already imported exam on SEB Server. If you don't have imported a course or quiz from LMS/Assessment Tool
as an exam into SEB Server, please see the previous chapter for detailed guidance about hot to import an exam. as an exam into SEB Server, please see the previous chapter for detailed guidance about hot to import an exam.
To find a specific exam that has already been imported, go to "Exam Administration" / "Exam" on the navigation menu on the left hand side to To find a specific exam that has already been imported, go to "Exam Administration" / "Exam" on the navigation menu on the left hand side to
@ -9,12 +9,12 @@ see a list of all available exams. You are able to filter and sort the list as u
.. note:: .. note::
The Date-Filter above "Start-Time" is usually set to the date one year before now or to some other default date in the past The Date-Filter above "Start-Time" is usually set to the date one year before now or to some other default date in the past
and is applied to the end-date of the exam or quiz. The list shows all running or up-comming exams and only hides finished or and is applied to the end-date of the exam or quiz. The list shows all running or up-coming exams and only hides finished or
archived exams that has an end-date before the Date-Filter date. archived exams that has an end-date before the Date-Filter date.
Double click on the list entry of the exam or select the list entry and use the "View Exam" action of the action pane on the right hand side to Double click on the list entry of the exam or select the list entry and use the "View Exam" action of the action pane on the right hand side to
open the exam in the detail view. Within the detail view of the exam you are able to edit the exam attributes, apply SEB exam configuration and open the exam in the detail view. Within the detail view of the exam you are able to edit the exam attributes, apply SEB exam configuration and
indicators for monitoring as well as defining details of the SEB restriction if this feature is available from the LMS. indicators for monitoring as well as defining details of the SEB restriction if this feature is available from the LMS/Assessment Tool.
.. note:: .. note::
If an exam is already running but is missing some essential setup, this is noted by the system. In the exam detail view the system If an exam is already running but is missing some essential setup, this is noted by the system. In the exam detail view the system
@ -23,17 +23,17 @@ indicators for monitoring as well as defining details of the SEB restriction if
.. image:: images/exam/examNotReady.png .. image:: images/exam/examNotReady.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examNotReady.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examNotReady.png
At the beginning of the page - if there is no note - you see all the details of the exam. At the beginning of the page - if there is no note - you see all the details of the exam.
- **Name**: Is the name of the course, defines on the LMS - **Name**: Is the name of the course, defines on the LMS/Assessment Tool
- **LMS Setup**: Is the name of the LMS Setup on the SEB Server from which the course was imported - **LMS/Assessment Tool Setup**: Is the name of the LMS/Assessment Tool Setup on the SEB Server from which the course was imported
- **Start-Time**: Is the date and time when the exam is starting. This is defined on the LMS - **Start-Time**: Is the date and time when the exam is starting. This is defined on the LMS/Assessment Tool
- **End-Time**: Is the date and time when the exam ends. This is defined on the LMS - **End-Time**: Is the date and time when the exam ends. This is defined on the LMS/Assessment Tool
- **LMS Exam Identifier**: Is the identity of the course on the LMS (external identifier/primary key) - **LMS/Assessment Tool Exam Identifier**: Is the identity of the course on the LMS/Assessment Tool (external identifier/primary key)
- **LMS Exam URL**: Is the start URL of the course/exam - **LMS/Assessment Tool Exam URL**: Is the start URL of the course/exam
To edit the SEB Server relevant attributes you can use To edit the SEB Server relevant attributes you can use
the "Edit Exam" action from the action pane on the right hand side to switch to the exam edit mode. In the exam edit mode you can modify the "Edit Exam" action from the action pane on the right hand side to switch to the exam edit mode. In the exam edit mode you can modify
@ -70,12 +70,22 @@ the pop-up shows the description and the status of the selected configuration.
.. image:: images/exam/addExamConfig.png .. image:: images/exam/addExamConfig.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/addExamConfig.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/addExamConfig.png
There is also the possibility to encrypt the SEB exam configuration by a password. This is done before the SEB configuration is send to a connecting There is also the possibility to encrypt the SEB exam configuration by a password. This is done before the SEB configuration is send to a connecting
SEB client. Since in the moste cases the SEB client connections are over HTTPS / TSL there is alrady a good protection in place and an SEB client. Since in the most cases the SEB client connections are over HTTPS / TSL there is already a good protection in place and an
additional encryption of the SEB exam configuration is not recommended. Anyway, if you decide the use the additional password encryption, the SEB additional encryption of the SEB exam configuration is not recommended. Anyway, if you decide the use the additional password encryption, the SEB
client that receives the encrypted SEB exam configuration will prompt the user for the password to proceed and connect to the LMS. client that receives the encrypted SEB exam configuration will prompt the user for the password to proceed and connect to the LMS/Assessment Tool.
With SEB Server Version 1.6 it is possible to change the Exam Configuration encryption password of an applied Exam Configuration.
The new action "Edit Encryption Password" can be used to open up the original apply dialog and to change the password:
.. note::
The Encryption Password for applied Exam Configuration can only be changes when there are no active SEB clients available for the exam.
.. image:: images/exam/editEncryptionPassword.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/editEncryptionPassword.png
.. note:: .. note::
If you need to use the same SEB exam configuration for different exams, you can just make a copy of a SEB exam configuration that is already used If you need to use the same SEB exam configuration for different exams, you can just make a copy of a SEB exam configuration that is already used
@ -86,19 +96,19 @@ client that receives the encrypted SEB exam configuration will prompt the user f
generate a copy of the original SEB exam configuration with the new name and description and will lead you to the details page of the copy configuration. generate a copy of the original SEB exam configuration with the new name and description and will lead you to the details page of the copy configuration.
Click the "OK" button on the pop-up to apply the selected SEB exam configuration. You will see the applied SEB exam configuration in the list. Click the "OK" button on the pop-up to apply the selected SEB exam configuration. You will see the applied SEB exam configuration in the list.
If the automated SEB restriction feature is supported by the LMS of the exam, the application of a SEB exam configuration will automatically update If the automated SEB restriction feature is supported by the LMS/Assessment Tool of the exam, the application of a SEB exam configuration will automatically update
the SEB restriction details with the generated Config-Key. See :ref:`sebRestriction-label` for more information. the SEB restriction details with the generated Config-Key. See :ref:`sebRestriction-label` for more information.
.. image:: images/exam/examConfig.png .. image:: images/exam/examConfig.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examConfig.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examConfig.png
To just generate the Config-Key for testing purposes or to manually apply it on an LMS without the automated SEB restriction feature you can To just generate the Config-Key for testing purposes or to manually apply it on an LMS/Assessment Tool without the automated SEB restriction feature you can
use the "Export Config-Key" action to generate the key. The Config-Key is presented by a pop-up and can be selected and copied to the clip-board. use the "Export Config-Key" action to generate the key. The Config-Key is presented by a pop-up and can be selected and copied to the clip-board.
For more information about the Config-Key its purpose and use, please visit the `SEB documentation <https://www.safeexambrowser.org/developer/seb-config-key.html>`_. For more information about the Config-Key its purpose and use, please visit the `SEB documentation <https://www.safeexambrowser.org/developer/seb-config-key.html>`_.
To remove an already applied SEB exam configuration from the exam, select the SEB exam configuration in the table and use the "Delete Exam Configuration" To remove an already applied SEB exam configuration from the exam, select the SEB exam configuration in the table and use the "Delete Exam Configuration"
action form the right action pane. If the automated SEB restriction feature is supported by the LMS of the exam, the removal of a SEB exam configuration will action form the right action pane. If the automated SEB restriction feature is supported by the LMS/Assessment Tool of the exam, the removal of a SEB exam configuration will
automatically update the SEB restriction details and remove the Config-Key form the restriction details. See :ref:`sebRestriction-label` for more information. automatically update the SEB restriction details and remove the Config-Key form the restriction details. See :ref:`sebRestriction-label` for more information.
Once you have removed a SEB exam configuration from the exam you are able to apply another one to the exam. Once you have removed a SEB exam configuration from the exam you are able to apply another one to the exam.
@ -152,7 +162,7 @@ your institution use the type information of the exam to set them into context.
**Archive an exam** **Archive an exam**
Since SEB Server version 1.4 it is possible to archive an exam that has been finished. An archived exam and all its data is still available Since SEB Server version 1.4 it is possible to archive an exam that has been finished. An archived exam and all its data is still available
on the SEB Server but read only and the exam is not been updated from the LMS data anymore and it is not possible to run this exam again. on the SEB Server but read only and the exam is not been updated from the LMS/Assessment Tool data anymore and it is not possible to run this exam again.
This is a good use-case to organize your exams since archived exam are not shown in the Exam list with the default filter anymore. They are This is a good use-case to organize your exams since archived exam are not shown in the Exam list with the default filter anymore. They are
only shown if the status filter of the exam list is explicitly set to Archived status. An they are shown within the new "Finished Exam" only shown if the status filter of the exam list is explicitly set to Archived status. An they are shown within the new "Finished Exam"
@ -160,10 +170,10 @@ section in the monitoring view.
.. image:: images/exam/archiveExamsFilter.png .. image:: images/exam/archiveExamsFilter.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/archiveExamsFilter.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/archiveExamsFilter.png
This is also a good use-case if you want to remove an LMS and LMS Setup but still want to be able to access the exams data on the SEB Server. This is also a good use-case if you want to remove an LMS/Assessment Tool and LMS/Assessment Tool Setup but still want to be able to access the exams data on the SEB Server.
In this case you can archive all exams from that LMS Setup before deactivating or deleting the respective LMS Setup. In this case you can archive all exams from that LMS/Assessment Tool Setup before deactivating or deleting the respective LMS/Assessment Tool Setup.
To archive a finished exam you just have to use the "Archive Exam" action on the right action pane of the exam view: To archive a finished exam you just have to use the "Archive Exam" action on the right action pane of the exam view:
@ -186,7 +196,7 @@ If you have "Exam Administrator" privileges you are able to entirely delete an e
.. image:: images/exam/deleteExam.png .. image:: images/exam/deleteExam.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/deleteExam.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/deleteExam.png
- Within the delete exam dialog you see a list of a dependencies that also will be deleted. Please check them carefully before deletion. - Within the delete exam dialog you see a list of a dependencies that also will be deleted. Please check them carefully before deletion.
- Use the below action to either delete the exam or cancel the action and go back to the exam view. - Use the below action to either delete the exam or cancel the action and go back to the exam view.

View file

@ -24,7 +24,7 @@ for this feature.
.. image:: images/exam/examASK.png .. image:: images/exam/examASK.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASK.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASK.png
Within this settings page you can enable or disable the feature any time also during a running exam. On the exam page you can see if the feature is enabled Within this settings page you can enable or disable the feature any time also during a running exam. On the exam page you can see if the feature is enabled
when the shield-icon is not strike-through. when the shield-icon is not strike-through.
@ -36,7 +36,7 @@ ASK for the same build.
.. image:: images/exam/examASKedit.png .. image:: images/exam/examASKedit.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASKedit.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASKedit.png
In the following list you can see all APK that has been sent to the SEB Server by connected SEB clients. For a particular ASK you can also see In the following list you can see all APK that has been sent to the SEB Server by connected SEB clients. For a particular ASK you can also see
how many SEB Clients has been sent this ASK and has the same signature. how many SEB Clients has been sent this ASK and has the same signature.
@ -47,7 +47,7 @@ below. You can give a name for the grant and save the grant by using "OK" action
.. image:: images/exam/examASKgrant.png .. image:: images/exam/examASKgrant.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASKgrant.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASKgrant.png
You see all granted ASKs within the second list with the ASK hash and the name that was given on grant. All explicitly granted ASKs from that list are You see all granted ASKs within the second list with the ASK hash and the name that was given on grant. All explicitly granted ASKs from that list are
considered trusted for the exam. And future SEB client connection that connects with one of the ASKs from this list are granted. All SEB clients that considered trusted for the exam. And future SEB client connection that connects with one of the ASKs from this list are granted. All SEB clients that
@ -65,7 +65,7 @@ SEB connections are marked red and with the tag "- ASK Grant Denied" after the s
.. image:: images/exam/examASKMonitoring1.png .. image:: images/exam/examASKMonitoring1.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASKMonitoring1.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASKMonitoring1.png
In the detail view of a SEB client connection you can see this too and you are able to apply a grant for a denied APK afterwards by using the In the detail view of a SEB client connection you can see this too and you are able to apply a grant for a denied APK afterwards by using the
"Grant App Signature Key" action from the right action pane. This will open a pop-up with the ASK hash and an input field for the name of the "Grant App Signature Key" action from the right action pane. This will open a pop-up with the ASK hash and an input field for the name of the
@ -73,11 +73,11 @@ grant.
.. image:: images/exam/examASKMonitoring2.png .. image:: images/exam/examASKMonitoring2.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASKMonitoring2.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASKMonitoring2.png
.. image:: images/exam/examASKMonitoring3.png .. image:: images/exam/examASKMonitoring3.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examASKMonitoring3.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examASKMonitoring3.png
After you have granted a unknown ASK, the grant is also applied to the respective SEB connection and to all following SEB connections that After you have granted a unknown ASK, the grant is also applied to the respective SEB connection and to all following SEB connections that

View file

@ -33,7 +33,7 @@ Client groups are located on an Exam setup page after the indicators at the end
.. image:: images/exam/examClientgroupAdd.png .. image:: images/exam/examClientgroupAdd.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroupAdd.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroupAdd.png
To add a new SEB Client Group use the respective action from the right action pane. You will be presented with the SEB Client Group edit page To add a new SEB Client Group use the respective action from the right action pane. You will be presented with the SEB Client Group edit page
where you are able to give the new SEB Client Group a name and choose a type of the client group that you want to create. where you are able to give the new SEB Client Group a name and choose a type of the client group that you want to create.
@ -45,7 +45,7 @@ the group type. With the additional, specific inputs, the SEB Client Group can b
.. image:: images/exam/examClientgroupIP.png .. image:: images/exam/examClientgroupIP.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroupIP.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroupIP.png
For the IP range group type you can give a valid IP range defined with a start IP address and an end IP address. This two inputs are mandatory For the IP range group type you can give a valid IP range defined with a start IP address and an end IP address. This two inputs are mandatory
and must be valid IPv4 addresses. The range must be a valid range and will be inclusive on the IP match (range-start >= IP <= range-end). and must be valid IPv4 addresses. The range must be a valid range and will be inclusive on the IP match (range-start >= IP <= range-end).
@ -54,7 +54,7 @@ For the SEB OS grouping type you have to choose the OS type from the given types
.. image:: images/exam/examClientgroupWin.png .. image:: images/exam/examClientgroupWin.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroupWin.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroupWin.png
If you have finished up your SEB Client Group definition you can save it with the "Save" action from the right action pane or cancel the modifications and If you have finished up your SEB Client Group definition you can save it with the "Save" action from the right action pane or cancel the modifications and
go back to the Exam page. You will see your created SEB Client Groups within its respective section on the Exam page and are able to edit them again, or delete go back to the Exam page. You will see your created SEB Client Groups within its respective section on the Exam page and are able to edit them again, or delete
@ -62,7 +62,7 @@ a certain SEB Client group from the list.
.. image:: images/exam/examClientgroups.png .. image:: images/exam/examClientgroups.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroups.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroups.png
Monitoring with SEB Client Groups Monitoring with SEB Client Groups
--------------------------------- ---------------------------------
@ -73,7 +73,7 @@ depending on what group(s) a particular SEB applies to.
.. image:: images/exam/examClientgroupMonitoring1.png .. image:: images/exam/examClientgroupMonitoring1.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroupMonitoring1.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroupMonitoring1.png
With the "Client Group Filter" on the right action pane, you are able to show/hide individual groups. With this filtering you can adapt your monitoring view With the "Client Group Filter" on the right action pane, you are able to show/hide individual groups. With this filtering you can adapt your monitoring view
for specialized monitoring view, to only see SEB client connection from one particular room for example or of one particular client OS. for specialized monitoring view, to only see SEB client connection from one particular room for example or of one particular client OS.
@ -86,4 +86,4 @@ for specialized monitoring view, to only see SEB client connection from one part
.. image:: images/exam/examClientgroupMonitoring2.png .. image:: images/exam/examClientgroupMonitoring2.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examClientgroupMonitoring2.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examClientgroupMonitoring2.png

View file

@ -8,7 +8,7 @@ Overview
An exam configuration defines all the SEB settings for an exam. A SEB client that is connecting to SEB Server An exam configuration defines all the SEB settings for an exam. A SEB client that is connecting to SEB Server
and an exam defined by the SEB Server is downloading this exam configuration from SEB Server and reconfigure itself before accessing the and an exam defined by the SEB Server is downloading this exam configuration from SEB Server and reconfigure itself before accessing the
exam on the learning management system (LMS) and present it to the user. exam on the learning management system (LMS/Assessment Tool) and present it to the user.
.. note:: .. note::
For more information and detailed description of the SEB settings, see `SEB Configuration <https://www.safeexambrowser.org/windows/win_usermanual_en.html#configuration>`_. For more information and detailed description of the SEB settings, see `SEB Configuration <https://www.safeexambrowser.org/windows/win_usermanual_en.html#configuration>`_.
@ -26,7 +26,7 @@ filter use the clear symbol right to the lens symbol. See :ref:`gui-label` for m
.. image:: images/exam_config/list.png .. image:: images/exam_config/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/list.png
To view details of a specific exam configuration either double-click on a list entry or select a list entry and use the "View Exam Configuration" To view details of a specific exam configuration either double-click on a list entry or select a list entry and use the "View Exam Configuration"
action from the right action pane. In the detail view all general settings are shown and also a list of exams that uses this exam configuration. action from the right action pane. In the detail view all general settings are shown and also a list of exams that uses this exam configuration.
@ -46,7 +46,7 @@ is assigned to an exam, the status changes automatically to "In Use" and the SEB
.. image:: images/exam_config/view.png .. image:: images/exam_config/view.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/view.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/view.png
An exam configuration has a general settings part (like other domain objects has within SEB Server) that defines the name, description and status An exam configuration has a general settings part (like other domain objects has within SEB Server) that defines the name, description and status
of the exam configuration that are used to maintain the exam configurations SEB Server internally. And an exam configuration has, separated from of the exam configuration that are used to maintain the exam configurations SEB Server internally. And an exam configuration has, separated from
@ -64,7 +64,7 @@ while also publish them to exams that uses this exam configuration.
.. image:: images/exam_config/settings.png .. image:: images/exam_config/settings.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/settings.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/settings.png
.. note:: .. note::
Changes in SEB settings must be published to be available on exports, exams, or other uses. Before publishing they are not Changes in SEB settings must be published to be available on exports, exams, or other uses. Before publishing they are not
@ -86,14 +86,14 @@ from the right action pane in the SEB settings view. This will start a usual bro
of the file of an exam configuration is "SEBExamSettings.seb". of the file of an exam configuration is "SEBExamSettings.seb".
SEB Server supports also the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ that is used to validate the SEB configuration SEB Server supports also the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ that is used to validate the SEB configuration
on the LMS and adds a higher security level to the exam. This is supported if the specific type of LMS supports the automated SEB restriction feature. Anyways on the LMS/Assessment Tool and adds a higher security level to the exam. This is supported if the specific type of LMS/Assessment Tool supports the automated SEB restriction feature. Anyways
sometimes it may be needed to manually extract the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ for an exam configuration. sometimes it may be needed to manually extract the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ for an exam configuration.
Therefore, one can use the "Export Client-Key" action from the right action pane to generate the Config-Key from the actual saved SEB settings revision Therefore, one can use the "Export Client-Key" action from the right action pane to generate the Config-Key from the actual saved SEB settings revision
of the exam configuration. The key will be presented by a pop-up dialog where it can be copied for further use. of the exam configuration. The key will be presented by a pop-up dialog where it can be copied for further use.
.. image:: images/exam_config/config_key.png .. image:: images/exam_config/config_key.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/config_key.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/config_key.png
Batch Actions Batch Actions
@ -110,7 +110,7 @@ For list multi-selection documentation see :ref:`List Multi-Selection <listmulti
.. image:: images/exam_config/batch-actions.png .. image:: images/exam_config/batch-actions.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/batch-actions.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/batch-actions.png
@ -121,7 +121,7 @@ With this batch action you are able to change the state of all selected exam con
.. image:: images/exam_config/batch-actions_statechange.png .. image:: images/exam_config/batch-actions_statechange.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/batch-actions_statechange.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/batch-actions_statechange.png
Within the batch-action pop-up you can see how many exam configurations you have selected for the action. Now you are able to select the target state Within the batch-action pop-up you can see how many exam configurations you have selected for the action. Now you are able to select the target state
to where you would like to change all selected exam configurations state to. Then you can apply the batch action with "Change State" or cancel the batch-action. to where you would like to change all selected exam configurations state to. Then you can apply the batch action with "Change State" or cancel the batch-action.
@ -131,7 +131,7 @@ has been applied and how many has failed.
.. image:: images/exam_config/batch-actions_statechange_finished.png .. image:: images/exam_config/batch-actions_statechange_finished.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_config/batch-actions_statechange_finished.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_config/batch-actions_statechange_finished.png
**Reset To Template Settings** **Reset To Template Settings**
@ -223,8 +223,8 @@ to another exam that has to be configured for SEB.
**Generate and Export the Config-Key of an Exam Configuration** **Generate and Export the Config-Key of an Exam Configuration**
Usually the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ that is used to validate the SEB configuration Usually the `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ that is used to validate the SEB configuration
on the LMS is propagated automatically to a LMS by the SEB Server with the automated SEB restriction feature. But For testing purposes you need to generate and export the on the LMS/Assessment Tool is propagated automatically to a LMS/Assessment Tool by the SEB Server with the automated SEB restriction feature. But For testing purposes you need to generate and export the
`SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ and set it manually on the LMS. `SEB Config-Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ and set it manually on the LMS/Assessment Tool.
- Sign into SEB Server with your exam administrator role account. - Sign into SEB Server with your exam administrator role account.
- Navigate to the "Exam Configuration" menu within the SEB Configuration section on the left-hand side. - Navigate to the "Exam Configuration" menu within the SEB Configuration section on the left-hand side.
@ -281,7 +281,7 @@ In the current version of SEB Server, there are some differences to some SEB set
- Additional Dictionaries: There are only the SEB client default dictionaries available in the current SEB Server version. - Additional Dictionaries: There are only the SEB client default dictionaries available in the current SEB Server version.
- Additional Resources: Additional resources are currently not available in the current SEB Server version. - Additional Resources: Additional resources are currently not available in the current SEB Server version.
- Embedded Certificates: There is currently no certificate management possible on current SEB Server version. - Embedded Certificates: There is currently no certificate management possible on current SEB Server version.
- Browser Exam Key: There is currently no possibility to generate the Browser Exam Key on the SEB Server. But an already generated Browser Exam Key may be used within the SEB restriction feature on the exam configuration if this feature is supported by the LMS in use. - Browser Exam Key: There is currently no possibility to generate the Browser Exam Key on the SEB Server. But an already generated Browser Exam Key may be used within the SEB restriction feature on the exam configuration if this feature is supported by the LMS/Assessment Tool in use.
**SEB settings that have a slightly different form or handling in SEB Server comparing to the SEB configuration tool** **SEB settings that have a slightly different form or handling in SEB Server comparing to the SEB configuration tool**

View file

@ -1,15 +1,15 @@
Import LMS Course as Exam in SEB Server Import LMS/Assessment Tool Course as Exam in SEB Server
======================================= =======================================
To be able to configure and manage a course or parts of a course existing on a LMS as an exam on SEB Server we first need to import To be able to configure and manage a course or parts of a course existing on a LMS/Assessment Tool as an exam on SEB Server we first need to import
an exam from the one of the available courses from a LMS that has been setup to use within the SEB Server. an exam from the one of the available courses from a LMS/Assessment Tool that has been setup to use within the SEB Server.
.. note:: .. note::
If you don't have already set up a LMS binding within SEB Server and your institution, you have to do this first. If you don't have already set up a LMS/Assessment Tool binding within SEB Server and your institution, you have to do this first.
More information about setting up a LMS binding can be found in the chapter :ref:`lms-setup-label` More information about setting up a LMS/Assessment Tool binding can be found in the chapter :ref:`lms-setup-label`
You will find the list of available courses provided from all LMS that are bound within your institution by going to the "Exam Administration" You will find the list of available courses provided from all LMS/Assessment Tool that are bound within your institution by going to the "Exam Administration"
section on the left hand side and choosing "LMS Exam Lookup". The SEB Server will present you the list of all available courses and you section on the left hand side and choosing "LMS/Assessment Tool Exam Lookup". The SEB Server will present you the list of all available courses and you
are able to filter and sort the list as usual to find to right course for import. are able to filter and sort the list as usual to find to right course for import.
.. note:: .. note::
@ -20,12 +20,12 @@ are able to filter and sort the list as usual to find to right course for import
.. image:: images/exam/lmsExamLookup.png .. image:: images/exam/lmsExamLookup.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/lmsExamLookup.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/lmsExamLookup.png
You can view more details of a course by double-click on the specific list entry or by selecting the list entry and click the "Show LMS Exam Details" You can view more details of a course by double-click on the specific list entry or by selecting the list entry and click the "Show LMS/Assessment Tool Exam Details"
action form the action pane on the right hand side. The application will open a pop-up with available detail information of the course. action form the action pane on the right hand side. The application will open a pop-up with available detail information of the course.
Since SEB Server version 1.5 the data-fetching-process to get all course data from bounded LMSs works as a background task and Since SEB Server version 1.5 the data-fetching-process to get all course data from bounded LMS/Assessment Tools works as a background task and
the UI request will return anyway no matter if all data has been fetched already and presents the already available data. the UI request will return anyway no matter if all data has been fetched already and presents the already available data.
If the background task is still running and fetching data, SEB Server will indicate that with a message note on top of the page If the background task is still running and fetching data, SEB Server will indicate that with a message note on top of the page
with the ability to reload the page by clicking on the respective icon in the note. With this approach you can now see whether all data with the ability to reload the page by clicking on the respective icon in the note. With this approach you can now see whether all data
@ -33,7 +33,7 @@ are available and fetched or not.
.. image:: images/exam/lmsExamLookupLate.png .. image:: images/exam/lmsExamLookupLate.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/lmsExamLookupLate.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/lmsExamLookupLate.png
To import a course as an exam find the specific course on the list by using the filter and select the list entry. Use the "Import As Exam" action To import a course as an exam find the specific course on the list by using the filter and select the list entry. Use the "Import As Exam" action
from the action pane on the right hand side. from the action pane on the right hand side.
@ -41,19 +41,19 @@ from the action pane on the right hand side.
.. note:: .. note::
If a course has already ended (End-Time passed) it is not possible to import this course and an appropriate message is shown. If a course has already ended (End-Time passed) it is not possible to import this course and an appropriate message is shown.
On import, the application is creating an exam on SEB Server with a reference to the imported course on the LMS. All course specific data On import, the application is creating an exam on SEB Server with a reference to the imported course on the LMS/Assessment Tool. All course specific data
like name, description, start-, end-time and course-identifier will not be stored on the SEB Server but always be referenced by the underling course. like name, description, start-, end-time and course-identifier will not be stored on the SEB Server but always be referenced by the underling course.
This means, that the course data has to be modified on the LMS side as usual and the SEB Server always takes the actual data from the LMS for the This means, that the course data has to be modified on the LMS/Assessment Tool side as usual and the SEB Server always takes the actual data from the LMS/Assessment Tool for the
course. This has the advantages of the principle of single responsibility and prevents synchronization issues. course. This has the advantages of the principle of single responsibility and prevents synchronization issues.
You will see the creation page of the new exam with additional information: You will see the creation page of the new exam with additional information from LMS/Assessment Tool:
- **Name**: Is the name of the course, defines on the LMS - **Name**: Is the name of the course, defines on the LMS/Assessment Tool
- **LMS Setup**: Is the name of the LMS Setup on the SEB Server from which the course was imported - **LMS/Assessment Tool Setup**: Is the name of the LMS/Assessment Tool Setup on the SEB Server from which the course was imported
- **Start-Time**: Is the date and time when the exam is starting. This is defined on the LMS - **Start-Time**: Is the date and time when the exam is starting. This is defined on the LMS/Assessment Tool
- **End-Time**: Is the date and time when the exam ends. This is defined on the LMS - **End-Time**: Is the date and time when the exam ends. This is defined on the LMS/Assessment Tool
- **LMS Exam Identifier**: Is the identity of the course on the LMS (external identifier/primary key) - **LMS/Assessment Tool Exam Identifier**: Is the identity of the course on the LMS/Assessment Tool (external identifier/primary key)
- **LMS Exam URL**: Is the start URL of the course/exam - **LMS/Assessment Tool Exam URL**: Is the start URL of the course/exam
You are now able to either choose an existing :ref:`exam-template-label` to initialize the new exam with the settings defined within the template You are now able to either choose an existing :ref:`exam-template-label` to initialize the new exam with the settings defined within the template
or to set the needed settings only for this exam. If you choose a template, the settings from the template will automatically be added to the exam or to set the needed settings only for this exam. If you choose a template, the settings from the template will automatically be added to the exam
@ -63,7 +63,7 @@ Initially choose a type for the exam - "Exam Type" - that is currently only used
.. image:: images/exam/importExam.png .. image:: images/exam/importExam.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/importExam.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/importExam.png
Furthermore you can select and apply all exam supporter that shall be able to see and support this exam while running. To do so, click in the Furthermore you can select and apply all exam supporter that shall be able to see and support this exam while running. To do so, click in the
input field of the attribute "Exam Supporter" to see a drop down list of all available users for selection. To filter the drop down list, start input field of the attribute "Exam Supporter" to see a drop down list of all available users for selection. To filter the drop down list, start
@ -71,17 +71,14 @@ typing characters of the name of the user-account you want to apply to automatic
specified user that will be added to the list below the input field. To add another user to the selection just click again into the input field specified user that will be added to the list below the input field. To add another user to the selection just click again into the input field
and select another user. To remove a selected user from the selection-list, double-click on the specified entry of the selection-list. and select another user. To remove a selected user from the selection-list, double-click on the specified entry of the selection-list.
.. note::
At least one user account must be selected for the attribute "Exam Supporter". You are able to change this also later on by editing the exam.
To confirm the import use the "Save Exam" action of the action pane on the right hand side or use "Cancel" if you want to abort the import of the To confirm the import use the "Save Exam" action of the action pane on the right hand side or use "Cancel" if you want to abort the import of the
exam and go back to the course list. If you have confirmed and successfully imported the exam, you will see the exam overview page where you are able exam and go back to the course list. If you have confirmed and successfully imported the exam, you will see the exam overview page where you are able
to edit the details of the exam, apply SEB restrictions of supported by the LMS, apply a SEB exam configuration for the exam and define indicators to edit the details of the exam, apply SEB restrictions of supported by the LMS/Assessment Tool, apply a SEB exam configuration for the exam and define indicators
for monitoring the exam later on. for monitoring the exam later on.
.. image:: images/exam/examReady.png .. image:: images/exam/examReady.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examReady.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examReady.png
How all this different aspects of the exam are defined and prepared is part of the next chapters. How all this different aspects of the exam are defined and prepared is part of the next chapters.
@ -91,11 +88,11 @@ Use Cases
**Import a course as exam** **Import a course as exam**
To start setting up a course or quiz form an existing LMS as e-assessment with SEB and SEB Server you have to find this course or quiz on the To start setting up a course or quiz form an existing LMS/Assessment Tool as e-assessment with SEB and SEB Server you have to find this course or quiz on the
SEB Server and import it as exam. Define a type and apply exam supporter. SEB Server and import it as exam. Define a type and apply exam supporter.
- Login as an exam administrator and go to the "LMS Exam Lookup" page under the "Exam Administration" section. - Login as an exam administrator and go to the "LMS/Assessment Tool Exam Lookup" page under the "Exam Administration" section.
- If you are not sure if the LMS that runs your course has already been setup within the SEB Server, go first to the "LMS Setup" page and try to find the particular LMS in the list. If you can't find it, please contact an institutional administrator or setup the LMS by yourself as described in :ref:`lms-setup-label`. - If you are not sure if the LMS/Assessment Tool that runs your course has already been setup within the SEB Server, go first to the "LMS/Assessment Tool Setup" page and try to find the particular LMS/Assessment Tool in the list. If you can't find it, please contact an institutional administrator or setup the LMS/Assessment Tool by yourself as described in :ref:`lms-setup-label`.
- Find your course or quiz by using the filter of the list and the list navigation as usual. - Find your course or quiz by using the filter of the list and the list navigation as usual.
- Double click on the list entries to get all information about a particular course or quiz. - Double click on the list entries to get all information about a particular course or quiz.
- Once you have found the course or quiz, select it on the list and use the "Import Exam" action on the right action pane. - Once you have found the course or quiz, select it on the list and use the "Import Exam" action on the right action pane.

View file

@ -9,7 +9,7 @@ add some other indicators to the exam to be able to get notified while monitorin
.. image:: images/exam/examIndicators.png .. image:: images/exam/examIndicators.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examIndicators.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examIndicators.png
To add a new indicator to the exam you can use the "Add Indicator" action from the right action pane. In the indicator edit page you are able to give the To add a new indicator to the exam you can use the "Add Indicator" action from the right action pane. In the indicator edit page you are able to give the
new indicator a name. This name will be displayed in the SEB client connection table on monitoring section as column name for the column of this new indicator a name. This name will be displayed in the SEB client connection table on monitoring section as column name for the column of this
@ -18,7 +18,7 @@ If you have selected one indicator type, a description will be shown just below
.. image:: images/exam/editIndicator.png .. image:: images/exam/editIndicator.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/editIndicator.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/editIndicator.png
The type of indicators are pre-defined within the SEB Server and restricts the number of available indicators that can be used. Currently following The type of indicators are pre-defined within the SEB Server and restricts the number of available indicators that can be used. Currently following
indicators are supported: indicators are supported:

View file

@ -3,20 +3,20 @@ Exam List
The exam list is shown directly within the "Exam" entry of the "Exam Administration" menu. You will have the usual filter and sort functionality The exam list is shown directly within the "Exam" entry of the "Exam Administration" menu. You will have the usual filter and sort functionality
of lists within SEB Server. You can see exams that are running but has not complete setup yet, marked in read in the list. Additionally you see of lists within SEB Server. You can see exams that are running but has not complete setup yet, marked in read in the list. Additionally you see
Exams that currently has no connection to its origin LMS grayed in the list. This exams are not available on the LMS either because they didn't Exams that currently has no connection to its origin LMS/Assessment Tool grayed in the list. This exams are not available on the LMS/Assessment Tool either because they didn't
exists anymore on the LMS or the SEB Server cannot connect to the LMS anymore. As soon as the SEB Server is able to get the LMS data again for a exists anymore on the LMS/Assessment Tool or the SEB Server cannot connect to the LMS/Assessment Tool anymore. As soon as the SEB Server is able to get the LMS/Assessment Tool data again for a
once unreachable exam, the respective exam would change back to normal and is not grayed anymore. once unreachable exam, the respective exam would change back to normal and is not grayed anymore.
.. image:: images/exam/examList.png .. image:: images/exam/examList.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examList.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examList.png
Sometimes an entire LMS is not available and a lot of exams are grayed. In this case you can use the new filter "Show/Hide Missing Exams" from the Sometimes an entire LMS/Assessment Tool is not available and a lot of exams are grayed. In this case you can use the new filter "Show/Hide Missing Exams" from the
action pane on the right to filter out this exams from the list. action pane on the right to filter out this exams from the list.
.. image:: images/exam/examListHideMissing.png .. image:: images/exam/examListHideMissing.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examListHideMissing.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examListHideMissing.png
To get more information about what is missing for an exam that is marked in red, just open the exam by select and use "View Exam" or by double-click To get more information about what is missing for an exam that is marked in red, just open the exam by select and use "View Exam" or by double-click
on the list entry. In the Exam view page you will see a warning message pointing out all the missing things to setup the exam. on the list entry. In the Exam view page you will see a warning message pointing out all the missing things to setup the exam.
@ -34,14 +34,14 @@ you want to archive or delete, select the respective batch action on the right a
.. image:: images/exam/examBatchArchive.png .. image:: images/exam/examBatchArchive.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/examBatchArchive.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examBatchArchive.png
You see your selection again within a list on the pop-up and when ready you can start the batch action and apply it to every selected exam You see your selection again within a list on the pop-up and when ready you can start the batch action and apply it to every selected exam
that is in a valid state to apply the action. that is in a valid state to apply the action.
.. note:: .. note::
For batch-action the same validation is done like for the single action delete and archive. Archive of an exam is only possible if it For batch-action the same validation is done like for the single action delete and archive. Archive of an exam is only possible if it
is not currently running but finished or up-coming. Delete is always possible and you habe to be cearfull while deleting exams in batch. is not currently running but finished or up-coming. Delete is always possible and you have to be carefully while deleting exams in batch.
After you have started the batch-action the result pop-up of the batch-action will show you the progress and how many has been processed and After you have started the batch-action the result pop-up of the batch-action will show you the progress and how many has been processed and
also how many as failed due to invalid state for batch-action or due to an error. also how many as failed due to invalid state for batch-action or due to an error.

View file

@ -1,151 +0,0 @@
.. _sebProctoringSettings-label:
Optional Live Proctoring
========================
.. attention::
Deprecation
The SEB Server live proctoring integration with Zoom and Jitsi Meet will be deprecated within the next upcoming version of SEB Server 1.6.
This means live proctoring is still available for dedicated SEB versions, but not actively maintained and supported any more.
Live proctoring is a new and yet experimental feature of SEB and SEB Server. The feature is fully optional and not enabled by default.
The main goal of the live proctoring feature is to support the integration
of an external meeting service like Jitsi Meet or Zoom for example, within a SEB and SEB Server setup for an exam.
In this scenario a SEB client is able to join a meeting and send audio and video data to the meeting where a proctor can watch the students during
an exam within this meeting(s). The role of SEB Server in this scenario is mainly to bind a particular meeting service and automatically create
meeting rooms, instruct connected SEB clients to join a certain meeting room. SEB Server can also instruct SEB clients to participate in the meeting by
allowing connected SEB clients to receive audio and video as well as enabling chat functionality.
.. note::
This feature is still in a prototype state and not all functionality might work as expected. Basically the meeting features
are given or restricted by the meeting service that is used and the API and GUI that is given by that meeting service client
To be able to use the integrated live proctoring feature with SEB and SEB Server you need an external meeting service that can be used by the SEB Server to automatically create meetings.
If this feature is enabled, you are able to setup a live proctoring service for a specified exam that can be used in the monitoring later on while the exam is running and SEB clients are connected.
Currently supported meeting services are:
- `Jitsi Meet <https://jitsi.org/jitsi-meet/>`_ with JWT token authentication enabled.
- `Zoom meeting service <https://zoom.us/>`_ with an account plan that fits your need and supports the `Zoom API and Client SDKs <https://marketplace.zoom.us/docs/sdk/native-sdks/developer-accounts>`_.
To bind and setup a live proctoring service in SEB Server for an exam, go to the view page of the exam and use the "Proctoring Settings" action on the right action pane to open up the proctoring settings dialog.
.. image:: images/exam/proctoringSettingsJITSI.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/proctoringSettingsJITSI.png
Within the proctoring settings dialog you are able to switch the service on and off by using the "Proctoring enabled" checkbox. You also see if the proctoring service is enabled within
the action icon that is either an eye when active or a slashed eye when not active.
To define and bind a service you have to choose a service type from the available service types. And you need to give the API access credentials like "Application Key" and "Secret" for
the external meeting service. SEB Server will then try to connect to the meeting service with these credentials to automatically create meetings/rooms for proctoring.
Within the "Collecting Room Size" field you can define the number of maximal participants that shall be collected within one proctoring room. SEB Server will automatically
create these collecting rooms while SEB clients are connecting to the running exam in the monitoring view.
.. note::
If you choose Zoom as your proctoring service and you also want to conduct your exam with Mac and/or iOS SEB Clients you will also need a Zoom SDK-Key and -Secret since SEB Mac/iOS uses Zoom SDK for proctoring integration.
Scroll down the Proctoring Settings window to see more settings for SEB Server based proctoring features:
.. image:: images/exam/proctoringSettings2.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/proctoringSettings2.png
- Use Zoom App-Client: Enable this setting to use a Zoom App/Desktop client for the origin proctoring room. This needs an existing Zoom Desktop App installation on the proctor's desktop.
- Broadcasting Feature: Enable this to see the broadcasting features buttons in the opened proctoring windows. E.g. "Enable/Disable Audio" and "Enable/Disable Video" buttons.
- Chat Feature: Enable this to see the "Enable/Disable Chat" feature buttons in the opened proctoring windows.
- One to One Room: Enable this to see the One to One Room feature button during an exam monitoring within a SEB Client detail view
- Town-Hall Room: Enable this to see the Town-Hall Room feature button in the exam monitoring view
To read more about this proctoring features, please have a look at `Exam Monitoring <https://seb-server.readthedocs.io/en/latest/monitoring.html#live-proctoring>`_.
After you have all the settings done, use "OK" to confirm the settings. SEB Server will then try to connect to the meeting service with the given settings and check the access.
.. note::
Once a proctoring service is integrated for an exam, it is currently not possible to switch it to another service anymore.
This is because different services needs different meeting reference data on SEB Server and there is no conversion supported.
In the future we will make it possible to at least delete an already existing proctoring setup and to start from scratch.
The SEB client settings for proctoring can be found in the "Exam Configuration" "SEB Settings". There is a new tab with the name "Proctoring" where all SEB settings for proctoring are available.
These settings are directly used by a SEB client that supports the proctoring feature. SEB will initialize with this settings when connecting to SEB Server and also will use this settings as default settings during an exam.
.. image:: images/exam/proctoringSEBSettings.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/proctoringSEBSettings.png
Since SEB Server version 1.2 there is also an Zoom service section that let you define the default SEB settings for a Zoom proctoring setup.
Please be aware that not all of the settings are functioning yet. Please refer to the settings tool-tip to get a actual description of
a particular SEB feature setting
**Jitsi Meet**
To setup and configure a Jitsi Meet service for testing you can refer to the `Docker installation documentation <https://jitsi.github.io/handbook/docs/devops-guide/devops-guide-docker>`_
.. note::
The Jitsi Meet integration works only with JWT authentication. Please refer to the above documentation for how to setup JWT authentication.
.. image:: images/exam/proctoringSettingsJITSI.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/proctoringSettingsJITSI.png
**Zoom**
.. image:: images/exam/proctoringSettingsZoom.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/proctoringSettingsZoom.png
To integrate Zoom meetings as a live proctoring service within SEB Server you need to have an appropriate Zoom account with API and SDK access.
`Zoom API and Client SDKs <https://marketplace.zoom.us/docs/sdk/native-sdks/developer-accounts>`_.
Then you need to setup the Zoom account to run with JWT apps as described:
- Login into your Zoom account and use "App Marketplace" to setup an API app account
.. image:: images/exam/zoom1.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoom1.png
- Within the Zoom Marketplace use "Develop" and select "Build App".
.. image:: images/exam/zoom2.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoom2.png
.. image:: images/exam/zoom3.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoom3.png
- Choose "MeetingSDK" fist to create a meeting SDK app that is been used SEB to connect to Zoom meetings.
- Follow the instructions to create the API account and use the "SDK Key" and "SDK Secret" within the setup in SEB Server proctoring settings
.. image:: images/exam/zoom4.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoom4.png
- Then choose the "Server-toServer OAuth" to create a API access for SEB Server to connect to Zoom service API. This is needed on SEB Server do create and maintain users and meetings
- Follow the instructions to create the "Server-toServer OAuth" app on the page and make sure you have and set needed privileges as shown below.
.. image:: images/exam/zoomauth1.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoomauth1.png
.. image:: images/exam/zoomauth2.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoomauth2.png
.. image:: images/exam/zoomauth3.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/zoomauth3.png
Reset Rooms
-----------
This functionality is new since SEB Server version 1.5 and allows you to reset already created but collecting rooms for an exam. This action is only
available if you already have collecting rooms for an running exam and if there is no active SEB client connected to the exam. Then you can reset your
proctoring rooms with this actions and also do some proctoring settings changes.
.. image:: images/exam/proctoringSettingsZoom.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/proctoringSettingsZoom.png

View file

@ -0,0 +1,42 @@
.. _sebExamQuitPassword-label:
Exam Quit Password (New)
========================
Since SEB Server Version 1.6 it is possible to set the quit-password (usually set in the Exam Configuration/SEB Settings) while
creating or importing an Exam as well as for an existing exam. This is convenient if you want to use a different quit password for each exam
and when using Exam Templates to create Exams.
The quit password within the exam corresponds with the quit-password of an applied Exam Configuration. Thies means, if you change the
password on either site, it will be reflected on the other site. And, in the case a new Exam Configuration is applied an already set
quit password in Exam will have prior order against the a quit password set in the Exam Configuration. In any case the there
is no different quit password in the Exam Configuration then in the Exam. SEB Server guarantees that the quit password is always synchronized
within the following rules:
- Exam has no Exam Configuration but defines the quit password
- An Exam Configuration that is applied to the Exam will get the quit password from the Exam in the SEB Settings.
- An Exam Configuration that already has a quit password set and gets applied to the Exam will also get the quit password from the Exam with notify the user about the change.
- Exam has no Exam Configuration and no quit password set
- The Exam will get the quit password from the Exam Configuration if the Exam Configuration has defined such
- Quit Password is changed in the Exam edit view
- On save of the exam the applied Exam Configuration also gets the new quit-password
- Quit Password is changed in the Exam Configuration SEB Settings
- On Save / Publish of the Exam Configuration SEB Settings, an applied Exam will get the newly set quit password from the configuration
The quit password can be set on Exam creation or import:
.. image:: images/exam/quitPasswordImport.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/quitPasswordImport.png
As well as in the Exam edit view:
.. image:: images/exam/quitPasswordEdit.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/quitPasswordEdit.png
If the Exam was created from an LMS/Assessment Tool with SEB Server integration that allows to send the quit-password
to the LMS/Assessment Tool for display, SEB Server sends a new quit-password as on save. The LMS/Assessment Tool should
therefore also display always the actual quit password.

View file

@ -3,7 +3,7 @@
Automated SEB Restriction Automated SEB Restriction
========================= =========================
If the corresponding LMS of an exam supports the automated SEB restriction feature, the SEB restriction can be managed within the exam details page. If the corresponding LMS/Assessment Tool of an exam supports the automated SEB restriction feature, the SEB restriction can be managed within the exam details page.
To navigate to the exam details page of an exam go to the "Exam" page under the "Exam Administration", find the specified exam in the list by using To navigate to the exam details page of an exam go to the "Exam" page under the "Exam Administration", find the specified exam in the list by using
the list filter and double click on the list entry of the exam you want to open the details page. the list filter and double click on the list entry of the exam you want to open the details page.
@ -11,35 +11,35 @@ In the exam details page you will see two action related to the SEB restriction
.. image:: images/exam/sebRestriction.png .. image:: images/exam/sebRestriction.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/sebRestriction.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/sebRestriction.png
Use the "Apply SEB Lock" on an exam that has not already locked the course for SEB on the LMS to do apply the restriction and lock the course or quiz Use the "Apply SEB Lock" on an exam that has not already locked the course for SEB on the LMS/Assessment Tool to do apply the restriction and lock the course or quiz
for SEB access only. This will call the SEB course restriction API on the LMS and will send all information to lock the course on the LMS. for SEB access only. This will call the SEB course restriction API on the LMS/Assessment Tool and will send all information to lock the course on the LMS/Assessment Tool.
On an exam where the restriction lock is already in place, use the "Release SEB Lock" action to remove the restriction in the LMS and unlock the course. On an exam where the restriction lock is already in place, use the "Release SEB Lock" action to remove the restriction in the LMS/Assessment Tool and unlock the course.
.. note:: .. note::
If the exam is already running on import the system will automatically restrict the course on the LMS with the available restriction details. If the exam is already running on import the system will automatically restrict the course on the LMS/Assessment Tool with the available restriction details.
Use the "SEB Restriction Details" action to open up a dialog to define all SEB restriction details that the LMS of the exam and its SEB course Use the "SEB Restriction Details" action to open up a dialog to define all SEB restriction details that the LMS/Assessment Tool of the exam and its SEB course
restriction API is supporting. There are two global restriction details that are SEB specific and should be supported by every LMS that serves restriction API is supporting. There are two global restriction details that are SEB specific and should be supported by every LMS/Assessment Tool that serves
a course restriction API for SEB. The `Config Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ and the `Browser Exam Key <https://safeexambrowser.org/developer/documents/SEB-Specification-BrowserExamKey.pdf>`_. a course restriction API for SEB. The `Config Key <https://safeexambrowser.org/developer/seb-config-key.html>`_ and the `Browser Exam Key <https://safeexambrowser.org/developer/documents/SEB-Specification-BrowserExamKey.pdf>`_.
The Config Key is automatically generated by the exam configuration that is applied to the exam. And the Browser Exam Key can be applied within a The Config Key is automatically generated by the exam configuration that is applied to the exam. And the Browser Exam Key can be applied within a
comma separated list if needed. comma separated list if needed.
.. image:: images/exam/sebRestrictionDetails.png .. image:: images/exam/sebRestrictionDetails.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam/sebRestrictionDetails.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/sebRestrictionDetails.png
**SEB restriction on Open edX** **SEB restriction on Open edX**
To be able to use the SEB restriction feature with an Open edX LMS, you need to install the `SEB Open edX plugin <https://seb-openedx.readthedocs.io/en/latest/index.html>`_ To be able to use the SEB restriction feature with an Open edX LMS/Assessment Tool, you need to install the `SEB Open edX plugin <https://seb-openedx.readthedocs.io/en/latest/index.html>`_
from eduNEXT. Please consult the documentation for installing the `SEB Open edX plugin <https://seb-openedx.readthedocs.io/en/latest/index.html>`_ as well as for the from eduNEXT. Please consult the documentation for installing the `SEB Open edX plugin <https://seb-openedx.readthedocs.io/en/latest/index.html>`_ as well as for the
use of all additional supported restriction attributes. use of all additional supported restriction attributes.
.. note:: .. note::
If you change the attached exam configuration either by changing the attachment or by changing the attributes of a attached exam configuration If you change the attached exam configuration either by changing the attachment or by changing the attributes of a attached exam configuration
for an exam that has the SEB restriction in place, the Config Key generated from the exam config that is also changing, will automatically be for an exam that has the SEB restriction in place, the Config Key generated from the exam config that is also changing, will automatically be
updated on the LMS. Therefore such an action that triggers an update may take some more time to complete as when the restriction is not in place. updated on the LMS/Assessment Tool. Therefore such an action that triggers an update may take some more time to complete as when the restriction is not in place.
Use Cases Use Cases
@ -53,7 +53,7 @@ Use Cases
- Use the "SEB Restriction Details" action from the right action pane to open the restriction details dialog. - Use the "SEB Restriction Details" action from the right action pane to open the restriction details dialog.
- In the restriction details dialog you will see all supported restriction attributes and you can define the restriction for your needs. - In the restriction details dialog you will see all supported restriction attributes and you can define the restriction for your needs.
- To apply the new restriction details use the "OK" action of the dialog or use the "Cancel" action to abort and close the dialog. - To apply the new restriction details use the "OK" action of the dialog or use the "Cancel" action to abort and close the dialog.
- When the SEB restriction is active on the LMS, the system will automatically update the SEB restriction with the new details on the LMS. - When the SEB restriction is active on the LMS/Assessment Tool, the system will automatically update the SEB restriction with the new details on the LMS/Assessment Tool.
- If the SEB restriction is not active in this moment, the details will be saved and applied when the restriction is activated. - If the SEB restriction is not active in this moment, the details will be saved and applied when the restriction is activated.
@ -62,9 +62,9 @@ Use Cases
- Login as an exam administrator and go to the "Exam" page under the "Exam Administration" section. - Login as an exam administrator and go to the "Exam" page under the "Exam Administration" section.
- Use the filter to find the exam on that you have to change the supporter assignments. - Use the filter to find the exam on that you have to change the supporter assignments.
- Double click the list entry of the exam to go to the exam details page. Check if you are on the right exam. - Double click the list entry of the exam to go to the exam details page. Check if you are on the right exam.
- Use the "Apply SEB Lock" action from the right action pane to activate the SEB restriction lock for this course on the LMS. - Use the "Apply SEB Lock" action from the right action pane to activate the SEB restriction lock for this course on the LMS/Assessment Tool.
- Use the "Release SEB Lock" action from the right action pane to deactivate the SEB restriction lock for this course on the LMS. - Use the "Release SEB Lock" action from the right action pane to deactivate the SEB restriction lock for this course on the LMS/Assessment Tool.
.. note:: .. note::
If a SEB restriction lock is active on the LMS, every change on the exam or related components that will affect a change on the restriction If a SEB restriction lock is active on the LMS/Assessment Tool, every change on the exam or related components that will affect a change on the restriction
details will automatically be updated on the LMS. You don't have to apply the SEB restriction lock again for update. details will automatically be updated on the LMS/Assessment Tool. You don't have to apply the SEB restriction lock again for update.

View file

@ -7,7 +7,7 @@ Overview
-------- --------
Exam templates are a new, useful feature available since SEB Server version 1.3. Within exam templates it is possible to create specific named templates that can be Exam templates are a new, useful feature available since SEB Server version 1.3. Within exam templates it is possible to create specific named templates that can be
used by an exam import from LMS course/quiz and define default settings and indicators that are automatically be applied on the exam import. used by an exam import from LMS/Assessment Tool course/quiz and define default settings and indicators that are automatically be applied on the exam import.
Furthermore, exam templates gives you the possibility to map exam configuration template to automatically create and map an exam configuration for an exam on import. Furthermore, exam templates gives you the possibility to map exam configuration template to automatically create and map an exam configuration for an exam on import.
This is very convenient if you have a lot of exams to set up that all have the same or similar settings. In such a case you can create an exam template This is very convenient if you have a lot of exams to set up that all have the same or similar settings. In such a case you can create an exam template
with all the common settings for that exams and use it on exam import. with all the common settings for that exams and use it on exam import.
@ -17,7 +17,7 @@ and also shows which one is the default for the institution.
.. image:: images/exam_template/list.png .. image:: images/exam_template/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_template/list.png
.. note:: .. note::
The "Default Template" flag indicates the one exam template that is the default template for an institution. This just means that this template The "Default Template" flag indicates the one exam template that is the default template for an institution. This just means that this template
@ -32,7 +32,7 @@ SEB Server will then present you the exam template creation view on that some in
.. image:: images/exam_template/new.png .. image:: images/exam_template/new.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/new.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_template/new.png
- **Name** The name of the exam template to identify it in the list/library - **Name** The name of the exam template to identify it in the list/library
- **Description** A short description ideally describing the purpose of the exam template - **Description** A short description ideally describing the purpose of the exam template
@ -46,7 +46,7 @@ view that looks similar to the exam administration view.
.. image:: images/exam_template/view.png .. image:: images/exam_template/view.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/view.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_template/view.png
Here you can edit the settings done before by using the "Edit Exam Template" action form the right action pane. Here you can edit the settings done before by using the "Edit Exam Template" action form the right action pane.
You can also delete an exam template entirely by using the "Delete Exam Template" action from the right action pane. You can also delete an exam template entirely by using the "Delete Exam Template" action from the right action pane.
@ -54,25 +54,20 @@ And you are able to add/edit/remove monitoring indicators for the exam template
.. image:: images/exam_template/indicator.png .. image:: images/exam_template/indicator.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/indicator.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_template/indicator.png
There are also proctoring settings available since SEB Server version 1.4 for the exam template. They just have the same settings and TODO Screen Proctoring Settings
look like the ones on the Exam and will get copied for an exam imported with the respective template that defines the proctoring settings.
.. image:: images/exam_template/proctoringSettings.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/proctoringSettings.png
Import Exam with Template Import Exam with Template
------------------------- -------------------------
Once one or more exam template exists, you are able to select one while importing an exam from the LMS in the "LMS Exam Lookup" section. Just as usual Once one or more exam template exists, you are able to select one while importing an exam from the LMS/Assessment Tool in the "LMS/Assessment Tool Exam Lookup" section. Just as usual
use the "Import as Exam" action for a LMS exam that you want to import. use the "Import as Exam" action for a LMS/Assessment Tool exam that you want to import.
.. image:: images/exam_template/select1.png .. image:: images/exam_template/select1.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/exam_template/select1.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam_template/select1.png
Now there is a new selector field named "Exam Template" where you can choose the exam template to use on import. When you select one the template attributes Now there is a new selector field named "Exam Template" where you can choose the exam template to use on import. When you select one the template attributes
like "Exam Type" or "Exam Supporter" are automatically applied from the template settings. You are still able to edit the settings e.g. add more or remove supporter. like "Exam Type" or "Exam Supporter" are automatically applied from the template settings. You are still able to edit the settings e.g. add more or remove supporter.
@ -119,9 +114,9 @@ a of great help while shorten the setup process and reduces the work that must b
**Use an existing Exam Template on Exam import** **Use an existing Exam Template on Exam import**
- Sign in as an Exam Administrator and select the "LMS Exam Lookup" sub-menu of the "Exam Administration" section in the left menu pane. - Sign in as an Exam Administrator and select the "LMS/Assessment Tool Exam Lookup" sub-menu of the "Exam Administration" section in the left menu pane.
- Here you can see all exams form the LMS that are bound to the SEB Server. Select the specific exam that you want to import. - Here you can see all exams form the LMS/Assessment Tool that are bound to the SEB Server. Select the specific exam that you want to import.
- Use "Import as Exam" from the right action pane to import that exam from the LMS as usual. - Use "Import as Exam" from the right action pane to import that exam from the LMS/Assessment Tool as usual.
- In the exam import initialization step you now have a new selector to select an Exam Template that shall be applied. - In the exam import initialization step you now have a new selector to select an Exam Template that shall be applied.
- If there is a default Exam Template defined for the institution, this is pre-selected and already applied. If not you have to select the template of your choice. - If there is a default Exam Template defined for the institution, this is pre-selected and already applied. If not you have to select the template of your choice.
- By selecting an Exam Template the template attributes are already applied and you see the respective attributes in the exam settings. - By selecting an Exam Template the template attributes are already applied and you see the respective attributes in the exam settings.

30
docs/exam_testrun.rst Normal file
View file

@ -0,0 +1,30 @@
Exam Test-Run (New)
--------------------------------
With the new SEB Server version 2.0 there is a new feature Test-Run for none running / upcoming exams. Since upcoming
Exams on SEB Server are not available for SEB connections and Monitoring one have to has to change the course start date
to apply testing beforehand of an Exam.Server
With new new Rest-Run feature it is now possible to change an Exam in upcoming status to a dedicated Test-Run status where
SEB clients are able to connect and SEB Server Exam Administrator or Supporter are able to Monitor the Exam as long a
the Exam stays within this Test-Run status.
You can set an Exam into Test-Run status by using the respective action on the Exam view:
.. image:: images/exam/examEnableTestrun.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examEnableTestrun.png
After enable Test-Run for an Exam, you can see an information at the top if the Exam view that informs you about the
Test Run status of the Exam.
After testing is done you can disable the Test-Run status just by using the respective action on the right and the Exam
goes back to up-coming status and is not available anymore for SEB connections and Monitoring.
.. image:: images/exam/examEnableTestrun.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examEnableTestrun.png
.. note::
If an Exam changes to Running status due to the start time passing and is still in status Test-Run, SEB Sever will
automatically change the Exam from Test-Run to Running status and all features of a running Exam are available.

69
docs/exam_with_url.rst Normal file
View file

@ -0,0 +1,69 @@
.. _sebExamWithURL-label:
Exam With URL (New)
========================
This is a new feature since SEB Server Version 1.6 and allows to create SEB Server Exams without the need of a
dedicated LMS/Assessment Tool integration but by providing an course URL, start- and end-type by its own.
SEB will then the given URL use as a start URL and just forward to the given URL page as usual. This of course has
some limitations in comparison to a Exam with LMS/Assessment Tool integration that are described at the end of
this chapter.
To create a new Exam with URL please select the Exam tab on the left menu pane and the "Add Exam with URL" Action
on the right action pane. Click on the action to open the creation view. This is the same view as on Exam import
put with some fields you have to provide instead of they coming from LMS/Assessment Tool.
.. image:: images/exam/examWithURL.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examWithURL.png
.. image:: images/exam/examWithURLNew.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examWithURLNew.png
You are now able to either choose an existing :ref:`exam-template-label` to initialize the new exam with the settings defined within the template
or to set the needed settings only for this exam. If you choose a template, the settings from the template will automatically be added to the exam
on creation and you are still able to modify them afterwards.
For this kind of Exam you also have to provide additional data that usually comes from LMS/Assessment Tool.
- The name of the Exam - mandatory
- A description of the Exam - optional
- The start date and time of the Exam - mandatory
- The end date and time of the Exam - optional
Initially also choose a type for the exam - "Exam Type" - that is currently only used for informational purpose and has no further restrictions or consequences on handling on in SEB Server.
Furthermore you can select and apply all exam supporter that shall be able to see and support this exam while running. To do so, click in the
input field of the attribute "Exam Supporter" to see a drop down list of all available users for selection. To filter the drop down list, start
typing characters of the name of the user-account you want to apply to automatically filter the list. Click on the drop-down list entry to select the
specified user that will be added to the list below the input field. To add another user to the selection just click again into the input field
and select another user. To remove a selected user from the selection-list, double-click on the specified entry of the selection-list.
To finally create the new Exam use the save action from the right action pane. New you are in the usual Exam view and can
go one with setting up your Exam.
.. image:: images/exam/examWithURLView.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/exam/examWithURLView.png
If you want to edit the Exam settings please use the edit action on the right action pane. Here you can also modify
the data that usually comes from LMS/Assessment Tool. You can change name, start- and end-date directly here within
the Exam on the SEB Server.
**Restrictions**
There are a few restrictions for an Exam with URL. First of all, since there os no LMS/Assessment Tool binding available,
SEB Server cannot call an LMS/Assessment Tool and restrict access for SEB only with either Config Key or Browser Exam key.
If an LMS/Assessment Tool supports such, one is of course be able to put the Config Key from SEB Server to the LMS manually
by copy und past it.
The other restriction is about the student login name resolving that is used and shown in the monitoring view of SEB Server.
Since this login name resolving needs a LMS/Assessment Tool binding to request the students LMS account name by SEB Server
this is not possible with this setup. But SEB Server will display other information within the User Name or Session column
of the SEB Server monitoring. SEB Server will show either the client IP address or the client machine name or the client
user device login, depending on what SEB is able to sends to the SEB Server.

View file

@ -2,9 +2,9 @@ Exams
===== =====
Within an exam in SEB Server all threads come together to set up a e-assessment with Safe Exam Browser and SEB Server. An exam can be imported Within an exam in SEB Server all threads come together to set up a e-assessment with Safe Exam Browser and SEB Server. An exam can be imported
from a course that exists on an LMS that was bound with a LMS Setup. An exam configuration that was formerly created can be attached to the exam by from a course that exists on an LMS/Assessment Tool that was bound with a LMS/Assessment Tool Setup. An exam configuration that was formerly created can be attached to the exam by
choosing one from the library. Indicators can be defined that are shown in the monitoring section while monitoring a running exam. And if choosing one from the library. Indicators can be defined that are shown in the monitoring section while monitoring a running exam. And if
the API of the specified LMS integration supports individual SEB restriction attributes for a e-assessment, this can also be defined and managed the API of the specified LMS/Assessment Tool integration supports individual SEB restriction attributes for a e-assessment, this can also be defined and managed
on the exam management of SEB Server. on the exam management of SEB Server.
We will go through all the steps to setting up an exam for Safe Exam Browser with SEB Server one by one. We will go through all the steps to setting up an exam for Safe Exam Browser with SEB Server one by one.
@ -13,11 +13,16 @@ We will go through all the steps to setting up an exam for Safe Exam Browser wit
:maxdepth: 1 :maxdepth: 1
exam_import exam_import
exam_with_url
exam exam
exam_quit_password
exam_indicator exam_indicator
exam_clientgroups exam_clientgroups
exam_ask exam_ask
exam_restriction exam_restriction
exam_proctoring exam_screen_proctoring
exam_list exam_list
exam_template exam_template
exam_testrun
screen_proctoring

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 102 KiB

After

Width:  |  Height:  |  Size: 83 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 47 KiB

After

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 54 KiB

After

Width:  |  Height:  |  Size: 55 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 54 KiB

After

Width:  |  Height:  |  Size: 56 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 58 KiB

After

Width:  |  Height:  |  Size: 62 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 50 KiB

After

Width:  |  Height:  |  Size: 62 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 96 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 54 KiB

After

Width:  |  Height:  |  Size: 56 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 66 KiB

After

Width:  |  Height:  |  Size: 67 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 105 KiB

After

Width:  |  Height:  |  Size: 86 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 54 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 95 KiB

After

Width:  |  Height:  |  Size: 77 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 72 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 59 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 101 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 103 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 47 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 53 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 192 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 99 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 29 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 41 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 106 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 29 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 65 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 84 KiB

After

Width:  |  Height:  |  Size: 58 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 47 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 34 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 848 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 690 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 486 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 586 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 68 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 787 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 681 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 547 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 632 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 660 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 119 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 667 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 319 KiB

View file

@ -21,5 +21,6 @@ Table of Content
configurations configurations
exams exams
monitoring monitoring
screen_proctoring
troubleshooting troubleshooting

View file

@ -34,7 +34,7 @@ Currently an institution has a name, an optional url-suffix and an optional logo
.. image:: images/institution/list.png .. image:: images/institution/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/institution/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/institution/list.png
As an institutional administrator only the institution one belongs to can be seen and be modified by the user. As an institutional administrator only the institution one belongs to can be seen and be modified by the user.
The user will see the institution form in view mode by clicking on the "Institution" section on the left hand menu The user will see the institution form in view mode by clicking on the "Institution" section on the left hand menu
@ -44,7 +44,7 @@ therefore a SEB Server administrator role is needed.
.. image:: images/institution/view_institutional.png .. image:: images/institution/view_institutional.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/institution/view_institutional.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/institution/view_institutional.png
@ -69,7 +69,7 @@ access the application with a web-browser and have the own logo.
.. image:: images/institution/new.png .. image:: images/institution/new.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/institution/new.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/institution/new.png
**Change the name/logo of an existing or own Institution** **Change the name/logo of an existing or own Institution**
@ -94,7 +94,7 @@ access the application with a web-browser and have the own logo.
.. image:: images/institution/view_institutional.png .. image:: images/institution/view_institutional.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/institution/view_institutional.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/institution/view_institutional.png
**Activate / Deactivate an existing institution** **Activate / Deactivate an existing institution**
@ -109,7 +109,7 @@ the form.
To deactivate an institution one can use the "Deactivate Institution" action form the action pane on the right side. To deactivate an institution one can use the "Deactivate Institution" action form the action pane on the right side.
When an institution is been deactivated, also all existing and active entities that belongs to this institution are deactivated too. When an institution is been deactivated, also all existing and active entities that belongs to this institution are deactivated too.
This affects user-accounts, configurations and LMS Setups. On deactivation action, the application will search the affected entities This affects user-accounts, configurations and LMS/Assessment Tool Setups. On deactivation action, the application will search the affected entities
and will inform the administrator about the number of the affected entities and asks for confirmation. and will inform the administrator about the number of the affected entities and asks for confirmation.
After Confirm the deactivation the institution and all affected entities will be deactivated. This means also the user-accounts that has After Confirm the deactivation the institution and all affected entities will be deactivated. This means also the user-accounts that has
not an institutional role or the SEB Server administration role, will not be able to log in anymore. not an institutional role or the SEB Server administration role, will not be able to log in anymore.

16
docs/lms_ans.rst Normal file
View file

@ -0,0 +1,16 @@
SEB Server Ans Delft Integration
===============================
The `Ans Delft <https://ans.app>`_ Assessment Tool can be integrated with SEB Server for the most common features like
- Course Access
- SEB Course Restriction
- Login Name Resolving
SEB Server uses the existing `Ans Delft API <https://ans.app/api/docs/index.html>`_ to apply the integration.
As usual you need a valid Ans client API account from Ans Delft to be able to connect SEB Server with your
Ans server. Please create or request such an account from the Ans team, and use either the given credentials or
a given access-token to connect SEB Server to the Ans API.
All the above listed Assessment Tool integration features should then work as described within SEB Server.

130
docs/lms_edx.rst Normal file
View file

@ -0,0 +1,130 @@
.. _lms-api-account-edx-label:
SEB Server Open edX Integration
===============================
SEB Server integrates with Open edX standard API for the following features:
- Course Access
- Login Name Resolving
.. note::
If you want to use the automated SEB Client Restriction feature too, the `Open edX SEB Plugin <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-setup-rest-plugin-label>`_ must be installed properly on the Assessment Tool.
Also refer to the Open edX API documentation for more information about the `Open edX REST API <https://courses.edx.org/api-docs/>`_
Create Open edX API Access Account
-----------------------------------
To be able to create an API access-account on Open edX you need a user-account with staff and administration privileges.
**For Open edX Hawthorn and Ironwood versions following the steps below::**
- Login to Open edX Assessment Tool Administration with an appropriate user-account that has administration rights. And find the Users section:
.. image:: images/lmssetup/openEdxAPIAccess1.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess1.bmp
- Create a new User-Account that acts as an API account. The account must at least have the permissions to query the course API of Open edX and to access the seb_openedx plugin permission.
- Make sure that "Staff" status is checked for the account.
.. image:: images/lmssetup/openEdxAPIAccess2.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess2.bmp
- Back in the administration homepage, find the OAUT2 - Client section and create a new API Client Access for the given User-Account. The Client id and Client secret are automatically generated by Open edx.
.. image:: images/lmssetup/openEdxAPIAccess3.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess3.bmp
.. image:: images/lmssetup/openEdxAPIAccess4.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess4.bmp
Once the client registration was successful the client id and client secret can be used within the SEB Server to access the course- and SEB-restriction API of Open edX as described in the next step section
.. note::
Since Open edX Juniper is using Django Oauth Toolkit instead of Django Oauth Provider the last step in the above guide looks slightly different. Please see below the last step for setting up on an Open edX Juniper version.
- Back in the administration homepage, find the DJANGO OAUTH TOOLKIT - Applications section and create a new API Application Access for the given User-Account. The Client id can be defined and the Client secret is automatically be generated by Open edx.
.. image:: images/lmssetup/openEdxAPIAccess5.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess5.png
.. image:: images/lmssetup/openEdxAPIAccess6.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/openEdxAPIAccess6.png
.. _lms-setup-rest-plugin-label:
Install SEB restriction API plugin
----------------------------------
.. _lms-setup-edx-plugin-label:
**Open edX SEB Plugin**
There is a SEB integration plugin developed and supported by `eduNEXT <https://www.edunext.co/>`_.
- `Documentation <https://seb-openedx.readthedocs.io/en/latest/>`_
- `Repository <https://github.com/eduNEXT/seb-openedx>`_
.. _lms-setup-moodle-plugin-label:
**Moodle Plugin for SEB Server**
There is a new SEB Server integration plugin for Moodle available since SEB Server 1.5 that can be used with the Assessment Tool Setup type Moodle with SEB Server Plugin.
This Plugin supports and improves all common SEB Server Assessment Tool binding features such as Course-Access, SEB Restriction and Assessment Tool Session Name Resolving.
It is also planed to extend and improve this plugin with new Moodle specific feature for further releases of SEB Server.
- `Documentation <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_
- `Repository <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_
Create a new Assessment Tool Setup for Open edX
-----------------------------------------------
A new Open edX system has been installed within your institution and to be able to use the system also for e-assessments with SEB and SEB Server,
you have to bind the Assessment Tool to the SEB Server.
- If not already done, install the `Open edX SEB Plugin <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-setup-rest-plugin-label>`_ on the Open edX system first.
- If you don't already have an API access account on Open edX side, `create one <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-api-account-edx-label>`_
- Sign into SEB Server with your institutional administrator role account.
- Navigate to "Exam Administration" / "Assessment Tool Setup" within the navigation on the left hand side.
- Use the "Add Assessment Tool Setup" action from the right action pane to open a Assessment Tool Setup creation form.
- Give a unique name to the new Assessment Tool Setup for internally identification.
- Set the main URL that points to the new Assessment Tool system. This is usually the URL that is also used with the Browser to connect to the main page of the Assessment Tool system
- Set the API credentials that has been creates within step two (client-id, secret).
- Use the "Activate Assessment Tool Setup" action on the right action pane to test, save and activate the new Assessment Tool Setup within one step.
.. note::
If some form attributes are missing or not correct, the SEB Server system will respond with the usual form validation errors.
If the connection to the Assessment Tool is failing because of missing or wrong credentials or for any other reason the system is not able to connect to the Assessment Tool
the SEB Server will notify an error dialog to the user.
**Change API Credentials of an Active Assessment Tool Setup**
The API access account on the Assessment Tool has been expired and you have to create a new one or update the old one which both result in new API access credentials
that has to be set on the existing Assessment Tool Setup on the SEB Server.
.. image:: images/lmssetup/list.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/list.png
- Sign into SEB Server with your institutional administrator role account.
- Navigate to "Exam Administration" / "Assessment Tool Setup" within the navigation on the left hand side.
- Use the Filter above the list to find the specified Assessment Tool Setup.
- Select the Assessment Tool Setup from the list and use the "Edit Assessment Tool Setup" action from the right action pane to open the Assessment Tool Setup in edit mode.
- Set the new credentials and make sure, the Assessment Tool Setup is still active.
- Use the "Save Assessment Tool Setup" action form the right action pane to save the changes and test the connection.
.. note::
If some form attributes are missing or not correct, the SEB Server system will respond with the usual form validation errors.
If the connection to the Assessment Tool is failing because of missing or wrong credentials or for any other reason the system is not able to connect to the Assessment Tool
the SEB Server will notify an error dialog to the user.

168
docs/lms_moodle.rst Normal file
View file

@ -0,0 +1,168 @@
SEB Server Moodle Integration
===============================
SEB Server has two different Moodle integration methods or features. One for bare Moodle without any additional Plugin
installed and one for Moodle instances that has the SEB Server Moodle Plugin installed.
For more information about the Moodle standard Rest API, please also have a look at: `Moodle REST API <https://docs.moodle.org/dev/Web_service_API_functions>`_
Moodle without SEB Server Plugin
---------------------------------
Without any plugin, Moodle supports the following standard integration features:
- Course Access
- SEB Course Restriction
.. note::
If you want to use Moodle with SEB Server, we recommend to install the new Moodle Plugin for SEB Server for better integration with Moodle.
This plugin comes with the common SEB Server integration features and improved Moodle binding. For more information see the section below.
** Moodle Client API Account**
To be able to create an Assessment Tool Setup for Moodle you need a Moodle API client account. You can then use this account in the Assessment Tool Setup to connect to the Assessment Tool.
Since SEB Server uses some functions from the Moodle's mobile API, you have to make sure the web services for mobile apps are enabled within your Moodle setup.
To do so please login to Moodle with an administrator account and go to "Side Administration", scroll down to "Mobile App" and choose "Mobile Settings.
.. image:: images/lmssetup/moodle_mobile.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/moodle_mobile.png
If you have a restrictive Moodle setup and troubles with the Moodle API account to use with SEB Server, please try to import the following
Moodle role profile within your Moodle instance. This profile will create a SEB Server role within Moodle that can be used to apply to an
API account to be used with SEB Server. The role defines only the necessary privileges and functions needed for SEB Server communication.
Moodle role and account settings: :download:`XML <files/webservice_seb-server.xml>`
Moodle with new SEB Server Plugin 2.0
--------------------------------------
For SEB Server version 2.0 there is also a new version of the Moodle SEB Server Plugin 2.0 that can be installed on Moodle
and has many new features to integrate even more with SEB Server as the existing version 1.0.the
.. note::
We strongly recommend to update to the newest Moodle SEB Server Plugin version 2.0 for SEB Server version 2.0. The older
plugin version 1.0 might still work as expected but we cannot guarantee that and also version 1.0 will not be supported
anymore. If you still have the old version of Moodle SEB Server Plugin 1.0 installed, SEB Server would recognize this and
inform you about this when testing or creating a new Assessment Tool Setup for Moodle with Plugin.
We also recommend to make a transition from existing Assessment Tool Setups with old Plugin to new Assessment Tool Setup with new Moodle Plugin.
This would mean that you delete all existing Assessment Tool Setups with Moodle (after archived your Exams you want to hold on SEB Server).
And after deletion of old Assessment Tools Setup with Moodle Plugin, install the new Moodle Plugin on Moodle site and setup
the Assessment Tool Setup for it in SEB Server.
The SEB Server Moodle Plugin 2.0 still supports the usual functionality:
- Course Access
- SEB Course Restriction
- Login Name Resolving
Additionally the full Moodle integration also comes with the following new features:
- SEB Server Admin can prepare Exam Template that can be used by Moodle Teacher Account to import Exams from Moodle site
- Moodle Teacher Account can automatically import an Exam on SEB Server from Moodle without having to go the SEB Server
- Moodle Teacher Account can automatically login to SEB Server Monitoring for a running quiz from Moodle site
- Moodle Teacher Account can also monitor the screen proctoring of a running quiz if available
To create or get a proper Moodle API Client account that is needed to connect SEB Server to Moodle, please have a look
at the above chapter ** Moodle Client API Account**
.. note::
One important change with Moodle SEB Server Plugin 2.0 comes with the fact that for this version it is only possible
to bind a Moodle instance to one SEB Server instance. It is not possible anymore to bind to the same Moodle from
different SEB Server instances or to bind the same Moodle instance twice for a singe SEB Server instance. This is due
to the full integration of SEB Server to Moodle and that Moodle can operate on a bound SEB Server.
For more information about the SEB Server Moodle Plugin and installation, please visit the following sites:
- `Documentation <https://github.com/ethz-let/moodle-quizaccess_sebserver>`_
- `Repository <https://github.com/ethz-let/moodle-quizaccess_sebserver>`_
**Usage of new SEB Server Moodle integration features**
After you have successfully applied a Assessment Tool Setup for Moodle with Plugin 2.0, you can now use the new integration
features among the other usual features like Course Access, SEB Client Restriction and Login Name Resolving.Plugin
A SEB Server Exam Admin can now create and mark Exam Templates that are then recognized by Moodle for later selection.
So a Exam Administrator is able to create a set of Exam Templates that then will be able to choose from a Moodle Teacher
when he/she sets up a quiz in Moodle. The following images shows the setting that indicated a Exam Template for use with
Moodle integration:
.. image:: images/moodle_full/exam_template.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/exam_template.png
On the Moodle site, a Teacher can then create a new quiz within a course:
.. image:: images/moodle_full/moodle_new1.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/moodle_new1.png
An within the quiz settings a Moodle Teacher should see a new settings sections "SEB Server" among with the already known
"Safe Exam Browser" section:
.. image:: images/moodle_full/moodle1.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/moodle1.png
If a Moodle Teacher wants to setup an Exam with SEB Server for the quiz, he/she can now activate SEB Server integration
for that quiz by selecting "yes" for "Enable SEB Server". The "Safe Exam Browser" section will then automatically switch
to the right settings to use with SEB Server.with
.. image:: images/moodle_full/moodle2.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/moodle2.png
Now the Moodle Teacher can select from the available Exam Templates that has been prepared and marked for Assessment Tool
use on SEB Server site. The Moodle Teacher can also enable a SEB quit button or quit-link and set a SEB quit password for the Exam.
After saving all the settings, this might take a while, Moodle automatically imports the Exam for the quiz within SEB Server
and applies all the presetting from the selected Exam Template. When the Exam is running also the SEB Client Restriction
is automatically set on the Exam. If the Exam is not running yet, the SEB Client Restriction will be set from SEB Server
as soon as the Exam becomes running.
.. image:: images/moodle_full/imported_exam.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/imported_exam.png
After all this has successfully been created and applied, the Moodle Teacher can go to the quit preview and sees the following
features:
.. image:: images/moodle_full/moodle3.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/moodle3.png
In the students view, the student will only see the two buttons:
- Start Safe Exam Browser: This installs and starts the SEB Client for the student
- Download SEB Server configuration file: This will download the SEB Server configuration file and start it with SEB
Only the Moodle Teacher is able to see the third button:
- SEB Server monitoring: This opens up an autologin for the Teacher to SEB ServerMonitoring within a new browser tab.student
SEB Server therefore creates an ad-hoc teacher role account on SEB Server site for this teacher. The Teacher is able to see
the monitoring if its exams as well as screen proctoring monitoring and search for all the exams he/she has created from
Moodle site.
.. image:: images/moodle_full/teacher_autologin.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/teacher_autologin.png
An already imported Exam can also be deleted either from the SEB Server side or from the Moodle side. On the SEB Server
site, a Exam Administrator can just delete the Exam as usual and SEB Server would reset all the integration settings
in Moodle for the respective quiz.
.. image:: images/moodle_full/delete_exam.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/delete_exam.png
While on the Moodle side, a Moodle Teacher can disable SEB Server for a particular quiz and Moodle will trigger a deletion
of the Exam on SEB Server and also reset all SEB Server settings on Moodle side.
.. image:: images/moodle_full/deleted_exam_moodle.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/moodle_full/deleted_exam_moodle.png

16
docs/lms_olat.rst Normal file
View file

@ -0,0 +1,16 @@
SEB Server OLAT Integration
===============================
The `OLAT <https://www.olat.org/>`_ Assessment Tool can be integrated with SEB Server for the most common features:
- Course Access
- SEB Course Restriction
- Login Name Resolving
SEB Server integration with OLAT was built with close coworking with the OLAT development team and uses the
existing OLAT API to apply the integration. As usual you need a valid client API account from you OLAT server instance
to be able to connect SEB Server. Please create or request such an account from the OLAT team, and use either the
given credentials or a given access-token to connect SEB Server to the Ans API.
For more information please contact the OLAT Development-Team at `OLAT UZH <https://www.zi.uzh.ch/en/support/e-learning-and-examination/staff/olat.html>`_

View file

@ -1,265 +1,113 @@
.. _lms-setup-label: .. _lms-setup-label:
Learning Management System Setup Assessment Tool Setup
================================ ================================
Overview Overview
-------- --------
To be able to connect to a learning management system (LMS), to view and manage the courses provided by a LMS is an essential feature of the SEB Server. To be able to connect to a learning management system (Assessment Tool), to view and manage the courses provided by a Assessment Tool is an essential feature of the SEB Server.
To setup an exam or e-assessment for SEB on SEB Server that is based on a course from a LMS, we have to make a binding to the course on the LMS. To setup an exam or e-assessment for SEB on SEB Server that is based on a course from a Assessment Tool, we have to make a binding to the course on the Assessment Tool.
This is also used to always get the actual course data from LMS like start- end-time, name and others. This is also used to always get the actual course data from Assessment Tool like start- end-time, name and others.
Another feature of SEB Server that needs a LMS communication is the SEB restriction. A SEB restriction will restrict course access on the LMS only Another feature of SEB Server that needs a Assessment Tool communication is the SEB restriction. A SEB restriction will restrict course access on the Assessment Tool only
for connection with Safe Exam Browser and will also check if a Safe Exam Browser of trust is used and the right configuration is used by the for connection with Safe Exam Browser and will also check if a Safe Exam Browser of trust is used and the right configuration is used by the
Safe Exam Browser that was defines for the exam on the SEB Server. Safe Exam Browser that was defines for the exam on the SEB Server.
**Course API** **Course API**
This API, provided by the LMS, is used by the SEB Server to query the available courses and the needed data for each course. This API This API, provided by the Assessment Tool, is used by the SEB Server to query the available courses and the needed data for each course. This API
is needed to be able to import a course from the LMS as an exam into SEB Server and configure the course as an e-assessment with SEB. is needed to be able to import a course from the Assessment Tool as an exam into SEB Server and configure the course as an e-assessment with SEB.
Usually this API comes as a REST or SOAP API with the core LMS implementation or a plugin. Usually this API comes as a REST or SOAP API with the core Assessment Tool implementation or a plugin.
SEB Server supports this course API's so far: **SEB Restriction API**
- Open edX: The standard system `Open edX REST API <https://courses.edx.org/api-docs/>`_. The SEB Server uses the "courses" endpoints to get course data.
- Moodle (Course Access): The standard system `Moodle REST API <https://docs.moodle.org/dev/Web_service_API_functions>`_. The SEB Server uses the standard Moodle rest endpoints to get course data. If the automated SEB restriction functionality is available for a Assessment Tool depends on the following requirements:
Please note that a second Moodle integration part for SEB access restriction with Config-Key will follow together with a Moodle plugin in a future version of SEB Server
- There must exist a SEB integration plugin that offers an API to put and pull SEB restrictions in the form of Config-Keys and/or Browser-Exam-Keys
To the Assessment Tool and a specific course on the Assessment Tool to restrict the access. Such a plugin may also offer additional restriction features like restricting
**SEB Restriction API** on course section or course components or only for specified user roles.
- The SEB integration plugin must be installed on the Assessment Tool that is used by the SEB Server.
If the automated SEB restriction functionality is available for a LMS depends on the following requirements:
For more information about known SEB integration plugins that are supported by the SEB Server see the respective Assessment Tool integration section.
- There must exist a SEB integration plugin that offers an API to put and pull SEB restrictions in the form of Config-Keys and/or Browser-Exam-Keys
To the LMS and a specific course on the LMS to restrict the access. Such a plugin may also offer additional restriction features like restricting Regardless if a supported Assessment Tool is missing the SEB integration plugin installation, the Assessment Tool can be used with the Course API and an exam
on course section or course components or only for specified user roles. setup will be possible but without automated SEB restriction feature.
- The SEB integration plugin must be installed on the LMS that is used by the SEB Server.
To be able to connect to an Assessment Tool from SEB Server, we need to create an API access account on the Assessment Tool side that can be used by the SEB Server to
For more information about known SEB integration plugins that are supported by the SEB Server see :ref:`lms-setup-rest-plugin-label` access the API of the Assessment Tool. How to do this for the different supported types of Assessment Tool see :ref:`lms-api-account-label`.
After such an account was created, the account credentials, username and password, can be used by the SEB Server to connect to the Assessment Tool.
Regardless if a supported LMS is missing the SEB integration plugin installation, the LMS can be used with the Course API and an exam Therefore we need to create a Assessment Tool Setup on the SEB Server.
setup will be possible but without automated SEB restriction feature.
.. image:: images/lmssetup/new.png
To be able to connect to an LMS from SEB Server, we need to create an API access account on the LMS side that can be used by the SEB Server to :align: center
access the API of the LMS. How to do this for the different supported types of LMS see :ref:`lms-api-account-label`. :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/lmssetup/new.png
After such an account was created, the account credentials, username and password, can be used by the SEB Server to connect to the LMS.
Therefore we need to create a LMS Setup on the SEB Server. A SEB Server administrator role will be able to see the institution to which the Assessment Tool Setup belongs to while an institutional administrator
is only able to see and create Assessment Tool Setup for its own institution. The name of the Assessment Tool Setup should be unique and is to identify a Assessment Tool
.. image:: images/lmssetup/new.png SEB Server internally. Use the **"Type"** selector to specify the type of the Assessment Tool to bind to the SEB Server within the Assessment Tool Setup. Currently supported are:
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/new.png - **Testing**: This is for testing purposes only and can be used to mock a Assessment Tool to test exam settings. This type provides some mock-up courses within the
Assessment Tool API of the SEB Server that can be seen in the Assessment Tool Exam Lookup once the Assessment Tool text setup is active. This mock-up courses can be imported and configured
A SEB Server administrator role will be able to see the institution to which the LMS Setup belongs to while an institutional administrator as exams like they would exist. But note the a SEB client that is trying to connect to such a course would not be able to connect to the Assessment Tool since it
is only able to see and create LMS Setup for its own institution. The name of the LMS Setup should be unique and is to identify a LMS is not existing. But a SEB client is able to download the defined exam configuration for testing.
SEB Server internally. Use the **"Type"** selector to specify the type of the LMS to bind to the SEB Server within the LMS Setup. Currently supported are:
- **Open edX**: This type is to bind an existing `Open edX <https://open.edx.org/>`_ Assessment Tool system that is available on the Internet or intranet.
- **Testing**: This is for testing purposes only and can be used to mock a LMS to test exam settings. This type provides some mock-up courses within the - **Moodle**: This type is to bind an existing `Moodle <https://moodle.org//>`_ Assessment Tool system that is available on the Internet or intranet.
LMS API of the SEB Server that can be seen in the LMS Exam Lookup once the LMS text setup is active. This mock-up courses can be imported and configured - **Moodle with SEB Server Plugin**: This type is to bind SEB Server with an Moodle Assessment Tool that has SEB Server Plugin for Moodle <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_ installed.
as exams like they would exist. But note the a SEB client that is trying to connect to such a course would not be able to connect to the LMS since it - **Ans Delft**: This type is to bind SEB Server with an `Ans Delft <https://ans.app/>`_ Assessment Tool.
is not existing. But a SEB client is able to download the defined exam configuration for testing. - **OLAT**: This type is to bind SEB Server with an `OLAT <https://www.olat.org/>`_ Assessment Tool.
- **Open edX**: This type is to bind an existing `Open edX <https://open.edx.org/>`_ LMS system that is available on the Internet or intranet. The SEB
Server tries to make use of the above described API's of the Open edX system. The **"Assessment Tool Server Address"** is the root URL to connect to the Assessment Tool server with HTTP over the Internet or intranet. This is usually the URL that is
also used with the Browser to connect to the main page of the Assessment Tool system. And additionally the credentials that have been created with the creation of the :ref:`lms-api-account-label` has to be set in the Assessment Tool Setup the make the SEB Server
.. note:: able to securely connect to the Assessment Tool. The API credentials that consists of a client-name and a client-secret must be used with the **"Assessment Tool Server Username"**
If you want to use the automated SEB restriction feature too, the `Open edX SEB Plugin <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-setup-rest-plugin-label>`_ must be installed properly on the LMS. and the **"Assessment Tool Server Password"** fields of the Assessment Tool Setup form on SEB Server.
- **Moodle**: This type is to bind an existing `Moodle <https://moodle.org//>`_ LMS system that is available on the Internet or intranet. The SEB Alternatively to **"Assessment Tool Server Username"** and **"Assessment Tool Server Password"** you can use a direct **Access Token** to connect to the Assessment Tool API if the respective Assessment Tool allows to
Server tries to make use of the described API's of the Moodle system but there is currently no SEB restriction plugin available that works generate and use an access token directly.
with SEB Server. Note that Moodle integration is implemented partially within SEB Server version 1.1.x. Only the course access feature is implemented and the course restriction feature will come with a future SEB Server release
If the SEB Server running behind a proxy server or a firewall between SEB Server den Assessment Tool, the additional proxy settings can be used to setup the proxy-connection.
- **Moodle with SEB Server Plugin**: The `SEB Server Plugin for Moodle <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_ is new and supported by SEB Server since version 1.5.
With this plugin installed on Moodle side, SEB Server is able to more efficiently communicate with Moodle to fetch course data as well as restricting the quiz on Moodle side .. note::
For SEB only access, using a auto-generated Browser Exam Key (BEK) for SEB restriction. Also the Moodle user name resolving for SEB Server monitoring is less error prone especially To Setup a Test Assessment Tool Setup (of type "Test") only a correct URL pattern must be set like "http://test" for example. And API credentials can be anything but must be set.
if Single Sign On some kind of login provider for Moodle is involved. Furthermore the new SEB Server Plugin for Moodle will be constantly extended and improved with new features in the future.
After all the settings for a Assessment Tool Setup have been set, one can use either the "Save Assessment Tool Setup" action to save the Assessment Tool Setup without activation or the
- **Ans Delft**: This type is to bind SEB Server with an `Ans Delft <https://ans.app/>`_ LMS. With the API credentials from an Ans Delft instance, SEB Server is able "Activate Assessment Tool Setup" action to also activate the settings right after they has been successfully saved. Anyway, for both action there is an initial test
to connect to the Ans LMS and provide the common features for Course-Access, SEB Restriction and LMS User Session resolving. that, additionally to the usual field validation that takes place first, tries to connect to the Assessment Tool with the given API details. If the connection
wasn't successful, the SEB Server will inform the user about a possible reason of failure. Otherwise SEB Server shows a success message and the created
- **Open Olat**: This type is to bind SEB Server with an `Open Olat <https://www.openolat.com/>`_ LMS. With the API credentials from an Open Olat instance, SEB Server is able Assessment Tool Setup can be used.
to connect to the Olat LMS and provide the common features for Course-Access, SEB Restriction and LMS User Session resolving. For more information please contact the Olat Development-Team at `OpenOLAT UZH <https://www.zi.uzh.ch/en/teaching-and-research/software-elearning/olat.html>`_
Use the "Activate / Deactivate Assessment Tool Setup" action to activate an inactive Assessment Tool Setup or the deactivate an active Assessment Tool Setup.
The **"LMS Server Address"** is the root URL to connect to the LMS server with HTTP over the Internet or intranet. This is usually the URL that is
also used with the Browser to connect to the main page of the LMS system. And additionally the credentials that have been created with the creation of the :ref:`lms-api-account-label` has to be set in the LMS Setup the make the SEB Server .. note::
able to securely connect to the LMS. The API credentials that consists of a client-name and a client-secret must be used with the **"LMS Server Username"** On deactivation of an Assessment Tool Setup, the system checks on depending object and will show a confirmation to the user asking that all depending
and the **"LMS Server Password"** fields of the LMS Setup form on SEB Server. objects will also been deactivated. Depending objects of an Assessment Tool Setup are exams that has been imported from the specified Assessment Tool Setup in the past.
Alternatively to **"LMS Server Username"** and **"LMS Server Password"** you can use a direct **Access Token** to connect to the LMS API if the respective LMS allows to For detailed information for each Assessment Tool type and how to bind and use it with SEB Server, please refer to the respective section:
generate and use an access token directly.
.. toctree::
If the SEB Server running behind a proxy server or a firewall between SEB Server den LMS, the additional proxy settings can be used to setup the proxy-connection. :maxdepth: 1
.. note:: lms_moodle
To Setup a Test LMS Setup (of type "Test") only a correct URL pattern must be set like "http://test" for example. And API credentials can be anything but must be set. lms_edx
lms_olat
After all the settings for a LMS Setup have been set, one can use either the "Save LMS Setup" action to save the LMS Setup without activation or the lms_ans
"Activate LMS Setup" action to also activate the settings right after they has been successfully saved. Anyway, for both action there is an initial test
that, additionally to the usual field validation that takes place first, tries to connect to the LMS with the given API details. If the connection
wasn't successful, the SEB Server will inform the user about a possible reason of failure. Otherwise SEB Server shows a success message and the created
LMS Setup can be used. Use Cases
---------
Use the "Activate / Deactivate LMS Setup" action to activate an inactive LMS Setup or the deactivate an active LMS Setup.
**Deactivate Assessment Tool Setup**
.. note::
On deactivation of an LMS Setup, the system checks on depending object and will show a confirmation to the user asking that all depending A Assessment Tool system that was running on your campus to provide e-assessment with SEB and SEB Server has been shut down and you need to also deactivate
objects will also been deactivated. Depending objects of an LMS Setup are exams that has been imported from the specified LMS Setup in the past. the setup and exams on the SEB Server for this Assessment Tool.
- Sign into SEB Server with your institutional administrator role account.
Use Cases - Navigate to "Exam Administration" / "Assessment Tool Setup" within the navigation on the left hand side.
--------- - Use the Filter above the list to find the specified Assessment Tool Setup.
- Select the specified Assessment Tool Setup from the list and use the "Deactivate Assessment Tool Setup" action from the right action pane.
**Create a new LMS Setup for Open edX** - Alternatively you can also double-click on the Assessment Tool Setup to fist go into the detailed view of the Assessment Tool setup and use the "Deactivate Assessment Tool Setup" action there.
- The system informs you about the number of depending exams that also will be deactivated within the deactivation of the Assessment Tool Setup.
A new Open edX system has been installed within your institution and to be able to use the system also for e-assessments with SEB and SEB Server, - Confirm the deactivation and notify that the Assessment Tool Setup now is listed as "Inactive" in the list.
you have to bind the LMS to the SEB Server. - Navigate to "Assessment Tool Exam Lookup" to make sure the courses form the deactivated Assessment Tool Setup are not available anymore.
- Navigate also to "Exam" and make sure that all previously imported exams from the deactivated Assessment Tool Setup are not available anymore.
- If not already done, install the `Open edX SEB Plugin <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-setup-rest-plugin-label>`_ on the Open edX system first.
- If you don't already have an API access account on Open edX side, `create one <https://seb-server.readthedocs.io/en/latest/lmssetup.html#lms-api-account-edx-label>`_
- Sign into SEB Server with your institutional administrator role account.
- Navigate to "Exam Administration" / "LMS Setup" within the navigation on the left hand side.
- Use the "Add LMS Setup" action from the right action pane to open a LMS Setup creation form.
- Give a unique name to the new LMS Setup for internally identification.
- Set the main URL that points to the new LMS system. This is usually the URL that is also used with the Browser to connect to the main page of the LMS system
- Set the API credentials that has been creates within step two (client-id, secret).
- Use the "Activate LMS Setup" action on the right action pane to test, save and activate the new LMS Setup within one step.
.. note::
If some form attributes are missing or not correct, the SEB Server system will respond with the usual form validation errors.
If the connection to the LMS is failing because of missing or wrong credentials or for any other reason the system is not able to connect to the LMS
the SEB Server will notify an error dialog to the user.
**Change API Credentials of an Active LMS Setup**
The API access account on the LMS has been expired and you have to create a new one or update the old one which both result in new API access credentials
that has to be set on the existing LMS Setup on the SEB Server.
.. image:: images/lmssetup/list.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/list.png
- Sign into SEB Server with your institutional administrator role account.
- Navigate to "Exam Administration" / "LMS Setup" within the navigation on the left hand side.
- Use the Filter above the list to find the specified LMS Setup.
- Select the LMS Setup from the list and use the "Edit LMS Setup" action from the right action pane to open the LMS Setup in edit mode.
- Set the new credentials and make sure, the LMS Setup is still active.
- Use the "Save LMS Setup" action form the right action pane to save the changes and test the connection.
.. note::
If some form attributes are missing or not correct, the SEB Server system will respond with the usual form validation errors.
If the connection to the LMS is failing because of missing or wrong credentials or for any other reason the system is not able to connect to the LMS
the SEB Server will notify an error dialog to the user.
**Deactivate LMS Setup**
A LMS system that was running on your campus to provide e-assessment with SEB and SEB Server has been shut down and you need to also deactivate
the setup and exams on the SEB Server for this LMS.
- Sign into SEB Server with your institutional administrator role account.
- Navigate to "Exam Administration" / "LMS Setup" within the navigation on the left hand side.
- Use the Filter above the list to find the specified LMS Setup.
- Select the specified LMS Setup from the list and use the "Deactivate LMS Setup" action from the right action pane.
- Alternatively you can also double-click on the LMS Setup to fist go into the detailed view of the LMS setup and use the "Deactivate LMS Setup" action there.
- The system informs you about the number of depending exams that also will be deactivated within the deactivation of the LMS Setup.
- Confirm the deactivation and notify that the LMS Setup now is listed as "Inactive" in the list.
- Navigate to "LMS Exam Lookup" to make sure the courses form the deactivated LMS Setup are not available anymore.
- Navigate also to "Exam" and make sure that all previously imported exams from the deactivated LMS Setup are not available anymore.
.. _lms-api-account-label:
API Access Account on LMS
--------------------------
.. _lms-api-account-edx-label:
**Create Open edX API Access Account**
To be able to create an API access-account on Open edX you need a user-account with staff and administration privileges.
**For Open edX Hawthorn and Ironwood versions following the steps below::**
- Login to Open edX LMS Administration with an appropriate user-account that has administration rights. And find the Users section:
.. image:: images/lmssetup/openEdxAPIAccess1.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/openEdxAPIAccess1.bmp
- Create a new User-Account that acts as an API account. The account must at least have the permissions to query the course API of Open edX and to access the seb_openedx plugin permission.
- Make sure that "Staff" status is checked for the account.
.. image:: images/lmssetup/openEdxAPIAccess2.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/openEdxAPIAccess2.bmp
- Back in the administration homepage, find the OAUT2 - Client section and create a new API Client Access for the given User-Account. The Client id and Client secret are automatically generated by Open edx.
.. image:: images/lmssetup/openEdxAPIAccess3.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/openEdxAPIAccess3.bmp
.. image:: images/lmssetup/openEdxAPIAccess4.bmp
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/lmssetup/openEdxAPIAccess4.bmp
Once the client registration was successful the client id and client secret can be used within the SEB Server to access the course- and SEB-restriction API of Open edX as described in the next step section
.. note::
Since Open edX Juniper is using Django Oauth Toolkit instead of Django Oauth Provider the last step in the above guide looks slightly different. Please see below the last step for setting up on an Open edX Juniper version.
- Back in the administration homepage, find the DJANGO OAUTH TOOLKIT - Applications section and create a new API Application Access for the given User-Account. The Client id can be defined and the Client secret is automatically be generated by Open edx.
.. image:: images/lmssetup/openEdxAPIAccess5.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/documentation/docs/images/lmssetup/openEdxAPIAccess5.png
.. image:: images/lmssetup/openEdxAPIAccess6.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/documentation/docs/images/lmssetup/openEdxAPIAccess6.png
**Create Moodle API Access Account**
To be able to create an LMS Setup for Moodle you need a Moodle administrator or manager account. You can then use this account in the LMS Setup to connect to the LMS.
Since SEB Server uses some functions from the Moodle's mobile API, you have to make sure the web services for mobile apps are enabled within your Moodle setup.
To do so please login to Moodle with an administrator account and go to "Side Administration", scroll down to "Mobile App" and choose "Mobile Settings.
.. image:: images/lmssetup/moodle_mobile.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/documentation/docs/images/lmssetup/moodle_mobile.png
If you have a restrictive Moodle setup and troubles with the Moodle API account to use with SEB Server, please try to import the following
Moodle role profile within your Moodle instance. This profile will create a SEB Server role within Moodle that can be used to apply to an
API account to be used with SEB Server. The role defines only the necessary privileges and functions needed for SEB Server communication.
Moodle role and account settings: :download:`XML <files/webservice_seb-server.xml>`
.. note::
If you want to use Moodle with SEB Server, we recomend to install the new Moodle Plugin for SEB Server for better integration with Moodle.
This plugin comes with the common SEB Server integration features and improved Moodle bining. For more information see :ref:`lms-setup-moodle-plugin-label`
.. _lms-setup-rest-plugin-label:
Install SEB restriction API plugin
----------------------------------
.. _lms-setup-edx-plugin-label:
**Open edX SEB Plugin**
There is a SEB integration plugin developed and supported by `eduNEXT <https://www.edunext.co/>`_.
- `Documentation <https://seb-openedx.readthedocs.io/en/latest/>`_
- `Repository <https://github.com/eduNEXT/seb-openedx>`_
.. _lms-setup-moodle-plugin-label:
**Moodle Plugin for SEB Server**
There is a new SEB Server integration plugin for Moodle available since SEB Server 1.5 that can be used with the LMS Setup type Moodle with SEB Server Plugin.
This Plugin supports and improves all common SEB Server LMS binding features such as Course-Access, SEB Restriction and LMS Session Name Resolving.
It is also planed to extend and improve this plugin with new Moodle specific feature for further releases of SEB Server.
- `Documentation <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_
- `Repository <https://github.com/ethz-let/moodle-quizzaccess_sebserver>`_

View file

@ -10,7 +10,7 @@ As an exam supporter you see all running exams where you have been assigned to b
.. image:: images/monitoring/runningExams.png .. image:: images/monitoring/runningExams.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/runningExams.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/runningExams.png
To navigate to this list, click on the "Running Exams" menu within the "Monitoring" category. And you will see the list with the name of the To navigate to this list, click on the "Running Exams" menu within the "Monitoring" category. And you will see the list with the name of the
exam, the type and start- and end-time of the exam. If the exam you are looking for is not on the list, please check the start-time filter exam, the type and start- and end-time of the exam. If the exam you are looking for is not on the list, please check the start-time filter
@ -27,19 +27,23 @@ As default you should see at least all active connections instantly.
.. image:: images/monitoring/examMonitoring.png .. image:: images/monitoring/examMonitoring.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/examMonitoring.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/examMonitoring.png
The list is automatically sorted in the way that SEB connections with incidents came to the top of the list and are then sorted by the The list is automatically sorted in the way that SEB connections with incidents came to the top of the list and are then sorted by the
"User Name or Session" identifier criteria. The general SEB client connection attributes are: "User Name or Session" identifier criteria. The general SEB client connection attributes are:
- **User Name or Session** The user account or user session identifier sent by the LMS to the SEB client and from SEB client to the SEB Server. This identifier may vary depending on the LMS that is involved. For Open edX it is the user account identifier (username). - **User Name or Session** This shows the the available user identification as soon as it is available in the following order:
- The IP Address of the device of the SEB client as long as the SEB has sent any user authentication yet.
- The machine name of the client device as soon as the SEB has sent it to SEB Server.
- The user login on the client machine as soon as the SEB has sent it to SEB Server.
- The user login on the LMS/Assessment Tool as soon as the SEB has sent it to SEB Server and SEB Server was able to resolve the login name via LMS/Assessment Tool
- **Connection Info** The IP address of the device the connected SEB client is running plus some additional information about the operating system and the SEB version. - **Connection Info** The IP address of the device the connected SEB client is running plus some additional information about the operating system and the SEB version.
- **Status** The status of the SEB client connection. - **Status** The status of the SEB client connection.
The following SEB connection states are defined: The following SEB connection states are defined:
- **Connection Requested** This state appears from when a SEB client contacted to SEB Server the first time until the SEB client has finished up the hand-shake protocol with the SEB Server and the student has logged into the LMS. - **Connection Requested** This state appears from when a SEB client contacted to SEB Server the first time until the SEB client has finished up the hand-shake protocol with the SEB Server and the student has logged into the LMS/Assessment Tool.
- **Active** This state appears after successful hand-shake and login into LMS and stays as long as the SEB connection is available and not closed or terminated - **Active** This state appears after successful hand-shake and login into LMS/Assessment Tool and stays as long as the SEB connection is available and not closed or terminated
- **Missing** This state appears when a SEB connection is currently in active state but has missing ping (last ping last longer than the highest ping threshold of the ping indicator). - **Missing** This state appears when a SEB connection is currently in active state but has missing ping (last ping last longer than the highest ping threshold of the ping indicator).
- **Closed** This state marks a closed SEB connection that was once active. - **Closed** This state marks a closed SEB connection that was once active.
- **Canceled** This state marks a SEB connection that has been canceled. - **Canceled** This state marks a SEB connection that has been canceled.
@ -57,7 +61,7 @@ Double-click on an entry to go to the detail view of the specified SEB client co
.. image:: images/monitoring/search.png .. image:: images/monitoring/search.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/search.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/search.png
**Instructions** **Instructions**
@ -87,6 +91,37 @@ are there for an exam and in which state.
.. note:: .. note::
When a certain state filter is set to hide, and a particular SEB client connection switches into that state, it will automatically disappear from the list. When a certain state filter is set to hide, and a particular SEB client connection switches into that state, it will automatically disappear from the list.
**New Issue and Group Filter**
A new SEB client group filter was added in SEB Server Version 1.6 to filter out certain configured SEB client groups. And since SEB Server Version 1.6
there is a new Issue filter for ASK (Application Security Key) checks as well as vor SEB client Version checks if they are enabled for an exam.
- For more information about SEB client groups, go to: :ref:`examClientgroups-label`
- For more information about ASK (Application Security Key), go to: :ref:`examASK-label`
- for more information about SEB client version restriction, please have a look into the :ref:`exam-configuration-label` SEB Settings
With the new Issue Filter it is possible to quickly filter out all SEB connections that do not have a certain issue. Or the other way
around, if you quickly want to show only the SEB client connections with a certain issue, you can use this filter.
- **ASK Issue Filter** This issue filter can be used to show only the SEB clients that has an ASK grant deny.
This is also possible for already closed SEB connections where you don's see the state of ASK grant within the status column anymore.
The image below shows active and inactive filter for active SEB connection as well as for inactive SEB connections.
.. image:: images/monitoring/issueFilter2.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/issueFilter2.png
.. image:: images/monitoring/issueFilter3.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/issueFilter3.png
- **SEB Client Group Filter** This issue filter filter all SEB client connection that are attached to a certain SEB client group.
.. image:: images/monitoring/issueFilter1.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/issueFilter1.png
Detailed View Detailed View
------------- -------------
@ -96,7 +131,7 @@ in a form and additional a list of all events and logs the SEB client has sent t
.. image:: images/monitoring/clientMonitoring.png .. image:: images/monitoring/clientMonitoring.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/clientMonitoring.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/clientMonitoring.png
The table shows the event type that for all log-events is the log-level, The text and a value that has been sent with the event. The Value may be empty The table shows the event type that for all log-events is the log-level, The text and a value that has been sent with the event. The Value may be empty
and marked as "Not a Number" (NaN). In this table we also have the client- and the server-time of the event. The client-time is the time the SEB client and marked as "Not a Number" (NaN). In this table we also have the client- and the server-time of the event. The client-time is the time the SEB client
@ -105,100 +140,13 @@ overview temporary network latency or other irregularities, when those two time
In the detail view you are also able to use the instructions "Quit SEB Client" and "Mark as Canceled" for the selected SEB client connection. In the detail view you are also able to use the instructions "Quit SEB Client" and "Mark as Canceled" for the selected SEB client connection.
Optional Live Proctoring Screen Proctoring
------------------------ -----------------
.. attention:: With SEB Server version 2.0 there is not Live Proctoring support for Zoom and Jitsi Meet anymore but a while new and
fully integrated Screen Proctoring feature where SEB Clients take screen shots and send it to SEB Server for proctoring
Deprecation Please visit the :ref:`screenprocotring-label` section for more information about Screen Proctoring with SEB Server.
The SEB Server live proctoring integration with Zoom and Jitsi Meet will be deprecated within the next upcoming version of SEB Server 1.6.
This means live proctoring is still available for dedicated SEB versions, but not actively maintained and supported any more.
Live proctoring is a new and yet experimental feature of SEB and SEB Server. The feature is fully optional and not enabled by default.
This section is about the live proctoring on monitoring a running exam and using the optional live proctoring within.
To configure the optional live proctoring for a specific exam please have a look at `Optional Live Proctoring <https://seb-server.readthedocs.io/en/latest/exam_proctoring.html#sebProctoringSettings>`_
.. note::
This feature is still in a prototype state and not all functionality might work as expected. Basically, the meeting features
are given or restricted by the meeting service that is used and the API and GUI that is given by that meeting service client
**Proctoring (Collecting) Rooms**
When the exam live proctoring feature is enabled for the running exam (see :ref:`sebProctoringSettings-label`), SEB Server will automatically create and collect
connected SEB clients into so called collecting rooms. The size of this collecting rooms can be defined within the proctoring settings in the exam.
One proctor can then open such a collecting room by left-clicking on the room action.
SEB Server will then open a proctoring window and join the proctor to the meeting where the participants of this room can be seen.
.. image:: images/monitoring/proctoringExam.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/proctoringExam.png
A proctor is also able to view the names of all participants of a room by right-clicking on the specified room action.
SEB Server will then open a dialog with a list of all participants. Double-clicking on a particular participant will automatically
load the detailed monitoring view of that participant.
.. note::
A collecting room, once created, will live as long as the exam is running and not has been deleted. When the exam ends or is been deleted,
the collecting room will automatically get deleted on the SEB Server's persistent storage as well as on the meeting service side if needed.
**Town-Hall Feature**
Besides the usual collecting room, there is a town-hall room feature. By using the "Open Townhall" action from the right action pane, SEB Server enforce all SEB clients that
are in collecting rooms as well as new connecting SEB clients to leave their current meeting and join the town-hall meeting for as long as the town-hall is active.
Within the town-hall a proctor has the same features as in the collecting room but can connect to all participants at the same time.
When the town-hall is closed all connected SEB clients are enforced to leave the town-room and go back to its collecting room meetings again.
.. note::
This feature is only available if it is enabled within the exam proctoring settings in the exam administration.
**Single Room or One-to-One Room Feature**
Another live proctoring feature can be found in the detailed monitoring view of one particular SEB client connection. The single room features allows a proctor to connect to a single
participant and being able to view or communication with just this one participant. You can initiate this single room connection by using the "Single Room Proctoring" action on
the right action pane. SEB Server will then enforce the involved SEB client to leave its collecting room and join a newly created room with the proctor.
Within the single room a proctor has the same features as in the collecting room to communicate with the student or participant.
When the single room is closed the connected SEB clients is enforced to leave the single room and go back to its collecting room meetings again.
.. image:: images/monitoring/proctoringClient.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/proctoringClient.png
.. note::
This feature is only available if it is enabled within the exam proctoring settings in the exam administration.
**Broadcast Features**
Within a live proctoring window, a proctor can use the enabled features of the integrated meeting service and is able to communicate with the SEB clients by using one
of the following features if available for the service:
- **Start Audio Broadcast** Will enforce the SEB clients within the particular room to enable receive audio and a proctor can speak to the students that are in the meeting.
- **Start Video Broadcast** Will enforce the SEB clients within the particular room to enable receive audio and video and proctor is shown to the students that are in the meeting and can speak to them as well.
- **Enable Chat** Will enforce the SEB clients within the particular room to enable the chat feature and a proctor is able to chat with all students in the meeting.
While a broadcast feature is enabled by a proctor, the SEB Server sends an instruction to each SEB client that is within the same meeting to display the meeting client.
A student as well as a proctor is then able to use all the features of the meeting client of the integrated meeting service.
.. image:: images/monitoring/proctoringWindow.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/proctoringWindow.png
.. note::
Each of this features is only available if it is enabled within the exam proctoring settings in the exam administration.
**Known Issues with Live Proctoring**
- Within the Zoom service it often happens that a participant appears twice in a room or meeting. This is probably caused by SEB clients rejoining the meetings while rooms or feature settings are changed.
- In Zoom it is not possible to fully control a participant microphone. Therefore, it may happen that participant can hear each other even if no proctor is in the meeting.
- Within Jitsi Meet service when a proctor leaves the room it currently happens that a random participant became host/moderator since it is not possible in Jitsi Meet to have a meeting without host. We try to mitigate the problem with the `moderator plugin <https://github.com/nvonahsen/jitsi-token-moderation-plugin>`_
- In both services while broadcasting, it is not guaranteed that a student always sees the proctor. Usually, the meeting service shows or pins the participant that is currently speaking automatically.
.. note::
The above listed points are issues within the current proctoring integration and not solutions. We are working hard to improve the
proctoring integration but due to limited resources this can take its time. And please consider that proctoring integration with
SEB Server is still in prototype state.
Finished Exams Finished Exams
-------------- --------------
@ -212,7 +160,7 @@ In the "Finished Exams" list you can see all finished or archived exams and filt
.. image:: images/monitoring/finishedExams.png .. image:: images/monitoring/finishedExams.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/finishedExams.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/finishedExams.png
To see a particular finished or archived exam you can just double-click in the list entry or use the View action on the right action pane. To see a particular finished or archived exam you can just double-click in the list entry or use the View action on the right action pane.
In the exam view you see all SEB connections that has been connected to the exam during the exam run just like in the usual monitoring view In the exam view you see all SEB connections that has been connected to the exam during the exam run just like in the usual monitoring view
@ -221,7 +169,7 @@ User or Session Info, Connection Info or Status and are also able to sort the li
.. image:: images/monitoring/finishedExam.png .. image:: images/monitoring/finishedExam.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/finishedExam.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/finishedExam.png
As in the usual monitoring view, you can show SEB client connection details by double-clicking on a list entry or by selecting a list entry As in the usual monitoring view, you can show SEB client connection details by double-clicking on a list entry or by selecting a list entry
and use the View action on the right action pane. and use the View action on the right action pane.
@ -244,14 +192,14 @@ of an exam for example.
.. image:: images/monitoring/sebClientLogs.png .. image:: images/monitoring/sebClientLogs.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/sebClientLogs.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/sebClientLogs.png
To show a detailed view of a specific SEB client log, just double click on the list entry or select the specific list entry and use the "Show Details" To show a detailed view of a specific SEB client log, just double click on the list entry or select the specific list entry and use the "Show Details"
action form the right action pane to open up a pop-up containing all related information about the SEB client log event. action form the right action pane to open up a pop-up containing all related information about the SEB client log event.
.. image:: images/monitoring/sebClientLogDetail.png .. image:: images/monitoring/sebClientLogDetail.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/monitoring/sebClientLogDetail.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/monitoring/sebClientLogDetail.png
Currently there is no export functionality to export all interesting SEB client logs to a CSV table for example. But such a feature will probably come Currently there is no export functionality to export all interesting SEB client logs to a CSV table for example. But such a feature will probably come
with a next version of SEB Server. with a next version of SEB Server.

View file

@ -27,8 +27,8 @@ The key features of SEB Server are:
- Track user activities within user-activity logs for the whole SEB Server or a client. - Track user activities within user-activity logs for the whole SEB Server or a client.
- Create, export, and maintain SEB connection configurations. Those are needed to startup a Safe Exam Browser client with and contain all information to connect securely to the SEB Server. - Create, export, and maintain SEB connection configurations. Those are needed to startup a Safe Exam Browser client with and contain all information to connect securely to the SEB Server.
- Create and maintain SEB exam configurations. Those are sent to a SEB client on connection setup and contain all SEB settings for a particular e-assessment. - Create and maintain SEB exam configurations. Those are sent to a SEB client on connection setup and contain all SEB settings for a particular e-assessment.
- Setup and maintain Learning Management Systems (LMS) and e-assessment systems like Open edX, Moodle, OpenOlat or ANS to be able to navigate and find courses or quizzes on the system and to push access restrictions to it if supported by the particular LMS/e-assessment suite. - Setup and maintain Learning Management Systems (LMS/Assessment Tool) and e-assessment systems like Open edX, Moodle, OpenOlat or ANS to be able to navigate and find courses or quizzes on the system and to push access restrictions to it if supported by the particular LMS/Assessment Tool.
- Import and maintain courses or quizzes from an LMS. Setup everything that is needed for an e-assessment that is based on a course or quiz from the LMS - Import and maintain courses or quizzes from an LMS/Assessment Tool. Setup everything that is needed for an e-assessment that is based on a course or quiz from the LMS/Assessment Tool
- Apply indicators to the exams to indicate incidences while monitoring running e-assessments. - Apply indicators to the exams to indicate incidences while monitoring running e-assessments.
- Monitor running e-assessment and have an overview of all connected SEB clients. Manage SEB client connections and view logs sent by individual SEB clients. - Monitor running e-assessment and have an overview of all connected SEB clients. Manage SEB client connections and view logs sent by individual SEB clients.
@ -64,7 +64,7 @@ Another use-case would be to maintain registered user accounts and to give more
An institutional administrator has overall read access for its institution and can modify the institution properties as well as An institutional administrator has overall read access for its institution and can modify the institution properties as well as
create new or maintain existing user accounts for the belonging institution. Furthermore, an institutional administrator can create and maintain create new or maintain existing user accounts for the belonging institution. Furthermore, an institutional administrator can create and maintain
learning management system (LMS) setups and SEB connection configurations for the belonging institution. learning management system (LMS/Assessment Tool) setups and SEB connection configurations for the belonging institution.
A typical use-case for an institutional administrator would be to give the appropriate roles and privileges to newly registered users of the institution. A typical use-case for an institutional administrator would be to give the appropriate roles and privileges to newly registered users of the institution.
Or another use-case would be to create and maintain SEB connection configurations for the institutions and set up and maintain learning management systems Or another use-case would be to create and maintain SEB connection configurations for the institutions and set up and maintain learning management systems
@ -99,7 +99,7 @@ What one will see first when applying to a SEB Server application is the login-s
.. image:: images/overview/login.png .. image:: images/overview/login.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/login.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/login.png
If you are already registered you can use your username and password to log in. Or use the "Register" button to go to the registration If you are already registered you can use your username and password to log in. Or use the "Register" button to go to the registration
page to create a new user account. The newly created user account will only have the Exam Supporter role assigned. If you need another page to create a new user account. The newly created user account will only have the Exam Supporter role assigned. If you need another
@ -107,7 +107,7 @@ role or more privileges, this must be given and granted by an institutional admi
.. image:: images/overview/register.png .. image:: images/overview/register.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/register.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/register.png
Fill in the registration form and create a new account. After the user account has been successfully created, the application redirects to the login page for login. Fill in the registration form and create a new account. After the user account has been successfully created, the application redirects to the login page for login.
On the current version, an e-mail confirmation is not a feature of the SEB Server application and therefore the e-mail address is currently just informative. On the current version, an e-mail confirmation is not a feature of the SEB Server application and therefore the e-mail address is currently just informative.
@ -125,7 +125,7 @@ the main content section will show the activity content and the action that are
.. image:: images/overview/overview.png .. image:: images/overview/overview.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/overview.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/overview.png
In the header above on the right hand, we see the username of the currently logged-in user and an action button to sign out and go back to the login page. In the header above on the right hand, we see the username of the currently logged-in user and an action button to sign out and go back to the login page.
@ -151,7 +151,7 @@ there are different types of filters:
.. image:: images/overview/list.png .. image:: images/overview/list.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/list.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/list.png
A list can be sorted within a column by clicking on the column header. The order of sorting can be changed by clicking again on the same A list can be sorted within a column by clicking on the column header. The order of sorting can be changed by clicking again on the same
column header of the sorted column. If sorting functionality is available for a column depends on the column type. There are a few columns column header of the sorted column. If sorting functionality is available for a column depends on the column type. There are a few columns
@ -173,7 +173,7 @@ To deselect a selected row just click it again then it will be removed from the
.. note:: .. note::
Some actions on the right action pane are used only for single objects but also enabled on multi-selection. If you have multiple selections Some actions on the right action pane are used only for single objects but also enabled on multi-selection. If you have multiple selections
and use a single object action like "View", "Edit" or "Copy" for exmaple, then the system will take the fist selected object/row to work with. and use a single object action like "View", "Edit" or "Copy" for example, then the system will take the fist selected object/row to work with.
**Forms** **Forms**
@ -189,12 +189,12 @@ The following images show the same form, once in read-only mode and once in edit
.. image:: images/overview/form_readonly.png .. image:: images/overview/form_readonly.png
:alt: Form in read-only mode :alt: Form in read-only mode
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/form_readonly.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/form_readonly.png
.. image:: images/overview/form_edit.png .. image:: images/overview/form_edit.png
:alt: Form in edit mode :alt: Form in edit mode
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/form_edit.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/form_edit.png
There usually is a tooltip on a form field element for almost all attributes that can be activated by either going over and staying on the form There usually is a tooltip on a form field element for almost all attributes that can be activated by either going over and staying on the form
field label or the input section. field label or the input section.
@ -218,8 +218,8 @@ Actions are usually placed on the right action pane of the application and belon
.. note:: .. note::
List action are disabled when nothing is selected from the list and get enabled as soon as one or more list items are selected. List action are disabled when nothing is selected from the list and get enabled as soon as one or more list items are selected.
Actions that are considdered single selection actions, and are used with a multi selection on the list will only affect the first selected item in the list. Actions that are considered single selection actions, and are used with a multi selection on the list will only affect the first selected item in the list.
.. image:: images/overview/list_multiselect_actions.png .. image:: images/overview/list_multiselect_actions.png
:align: center :align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/list_multiselect_actions.png :target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/overview/list_multiselect_actions.png

View file

@ -1,5 +1,5 @@
docutils<0.18 docutils<0.18
sphinx==5.3.0 sphinx==5.3.0
sphinx_rtd_theme==2.0.0 sphinx_rtd_theme==2.0.0
readthedocs-sphinx-search==0.1.1 readthedocs-sphinx-search==0.3.2
urllib3==1.26.13 urllib3==1.26.19

220
docs/screen_proctoring.rst Normal file
View file

@ -0,0 +1,220 @@
Screen Proctoring (New)
=======================
.. _screenprocotring-label:
Overview
---------
SEB Screen Proctoring is an integral component of the SEB Ecosystem, designed to monitor student screens during digital examinations.
This tool captures and displays screenshots taken by SEB, ensuring a secure and controlled testing environment.
Enable Screen Proctoring after an exam is created in the exam view.
.. image:: images/screen_proctoring/enable_screen_proctoring.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/enable_screen_proctoring.png
SEB Server needs to send an instruction to SEB to capture the screen and send the screenshot back to the server.
| To do this, enable screen proctoring in the SEB Settings.
.. image:: images/screen_proctoring/enable_screen_proctoring_seb_settings.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/enable_screen_proctoring_seb_settings.png
SEB-Server and SEB are now ready to capture and to display screenshots.
Navigate to exam monitoring and click the button in the Screen Proctoring section. A new tab will be opened.
.. image:: images/screen_proctoring/open_screen_proctoring.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/open_screen_proctoring.png
|
|
Gallery View
---------
- When a SEB is connected to SEB-Server and the user is logged into LMS, a tile with the latest screenshot will appear.
- Press the "Grid-Size" dropdown to change the displayable sessions per screen to 4, 9 or 16.
- Use the arrow buttons and the left and right on the screen to change windows. The current page and the number of live sessions / total sessions is display next to the grid selection.
.. image:: images/screen_proctoring/gallery_view_live_grid_selection.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/gallery_view_live_grid_selection.png
- Use your mouse to hover over a tile or press the tab key. A "selected" tile reveals information and actions for the session.
- To change view preferences press the settings icon in the top right corner.
- Toggling "Show Name" and "Show IP" reveals the the Name and IP of the selected session.
- By default, all the sessions are sorted by lastname in ascending order. To change this press the "Sort by Name" button.
- The camera icon opens the Proctoring View in a new tab. See chapter "Proctoring View" for more infos.
- Click on the "expand"-icon to enlarge the screenshot.
.. image:: images/screen_proctoring/gallery_view_settings.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/gallery_view_settings.png
- The SEB-Client additionally sends metadata about the screenshot
- Metadata changes according to the content displayed on the screenshot
- Refer to the chapter "Metadata" for more details
- The camera icon opens the Proctoring View in a new tab. See chapter "Proctoring View" for more infos.
- Close the expanded view either by clicking on the collapse button or somewhere outside of the screenshot
.. image:: images/screen_proctoring/gallery_view_expanded.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/gallery_view_expanded.png
- A message box indicates that there are no live sessions available
- As soon as a sessions are connected the message box will disappear
|
|
Running Exams
---------
To get an overview of all running exams which your user has access to click on the "Running Exams" item in the navigation bar on the left side.
- By default, the exams are sorted by "Exam Start-Time" in ascending order
- Click on any table header to change the sorting according to your needs
- Click on the link the "Group" column to get to the gallery view of the group
.. image:: images/screen_proctoring/running_exam_no_selection.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/running_exam_no_selection.png
By clicking on the settings icon in the menu bar two options are displayed.
- Select "Show past exams" to display all finished exams (red)
- Select "Show upcoming exams" to display all exams which are planned for the future (orange)
.. image:: images/screen_proctoring/running_exam_selection.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/running_exam_selection.png
|
|
Proctoring View
---------
The proctoring view shows a recorded or live session in more detail.
To open a proctoring view of a sessions, either:
- Click on the camera icon in the gallery view
- Use the search feature
- Directly type in the url in the address bar: https://<your host>/recording/<sessionUuid>
A session can either be live or recorded.
- A live session is indicated by the "Live" button
- Navigating to the proctoring view during a live session always displays the latest screenshot and updates it accordingly
- Use the slider like any other video player
- This is also possible during a live session
- Click on the "Live" button to jump to the latest screenshot
.. image:: images/screen_proctoring/proctoring_overview_live.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/proctoring_overview_live.png
- The "Details"-Box on the right side displays information about the session and the current screenshot
- "SEB Session Info" is static
- "Screenshot Metadata" dynamically changes for every Screenshot
- Refer to the chapter "Metadata" for more details
.. image:: images/screen_proctoring/proctoring_overview.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/proctoring_overview.png
- The "Live" button disappears when the sessions disconnects from the server
- Set the playback speed with the "settings"-icon according to you preferences
- The current screenshot and the total amount of screenshot is display in the "Total"-Row
|
|
Search
---------
The search functionality is a powerful feature for finding sessions and screenshots.
Click on the "Search" item in the navigation bar on the left side.
**Form**
The upper part of the page is the search form.
There are four different categories of search criteria:
- Exam data
- Session / user data
- Screenshot metadata
- Time data
Use the form fields and the time / date selection to tailor the search result to your needs.
.. image:: images/screen_proctoring/search_form.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/images/screen_proctoring/search_form.png
**Search Results**
The search results are grouped into days and sorted by date in descending order.
Use the "date" button on the right side to change the sort oder.
- Clicking on any date expands the panel and displays all sessions (a session is a student using SEB) with recordings on that day
- By default, the sessions are sorted by "Start-Time" in descending order
- Click on the table header to change the sorting according to your preferences
- A click on the down facing arrow on the right side lists all screenshots of the given student
.. image:: images/screen_proctoring/search_results_sessions.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/dev-2.0/docs/images/screen_proctoring/search_results_sessions.png
- By default, the screenshot are sorted by "Capture-Time" in ascending order
- The screenshots are grouped into the metadata "Application / Website"
- Grouping means that each successive screenshot that has the same "Application / Website" metadata is placed in the same group
- Click on the camera icon on the right side to open the proctoring view at this exact time
.. note::
If the session is still live the proctoring view won't open at the given time but instead jumps to the latest image.
|
|
Metadata
---------
Metadata in context of the Screen Proctoring component are data which belong to a screenshot.
They describe the content of the captured screen.
Currently the SEB-Client captures the following 5 metadata (additional values might follow in future releases):
- Focused Application: The name of the application that is currently in use and focused
- e.g. "SafeExamBrowser.Client.exe", "calc.exe"
- SEB-Browser-Title: The title of the SEB-Browser
- e.g. "Exam Moodle 12", "Moodle Exam Mathematics 3"
- Activity Details: The activity that triggered the screenshot
- e.g. "A key has been pressed", "Left mouse button has been pressed"
- SEB-Browser URL: The URL of the SEB-Browser
- e.g. "http://google.com", "http://moodle.com/exam123"
- Focused Window Title: The title of the focused window
- e.g. "Google Homepage", "Moodle Exam 123", "Calculator"

743
pom.xml
View file

@ -1,414 +1,395 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" <modelVersion>4.0.0</modelVersion>
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>ch.ethz.seb</groupId> <groupId>ch.ethz.seb</groupId>
<artifactId>seb-server</artifactId> <artifactId>seb-server</artifactId>
<version>${revision}</version> <version>${revision}</version>
<name>seb-server</name> <name>seb-server</name>
<description>web-service for SEB maintenance and monitoring active SEB sessions</description> <description>web-service for SEB maintenance and monitoring active SEB sessions</description>
<parent> <parent>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId> <artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.7.RELEASE</version> <version>2.6.15</version>
</parent> </parent>
<packaging>jar</packaging> <packaging>jar</packaging>
<properties> <properties>
<sebserver-version>1.5.4-SNAPSHOT</sebserver-version> <sebserver-version>2.0.0</sebserver-version>
<build-version>${sebserver-version}</build-version> <build-version>${sebserver-version}</build-version>
<revision>${sebserver-version}</revision> <revision>${sebserver-version}</revision>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>
<!-- Fix CVE-2021-44228 : https://spring.io/blog/2021/12/10/log4j2-vulnerability-and-spring-boot -->
<log4j2.version>2.17.0</log4j2.version>
</properties>
<!-- NOTE: There currently are two profiles, a default one to build on
<!-- NOTE: There currently are two profiles, a default one to build on
Java 11 (from eclipse and command-line) and one to build still on Java 8 Java 11 (from eclipse and command-line) and one to build still on Java 8
to support the Jenkins build on CI-Server that still no Java 11 installed --> to support the Jenkins build on CI-Server that still no Java 11 installed -->
<profiles> <profiles>
<profile> <profile>
<id>Java 11</id> <id>Java 17</id>
<activation> <activation>
<activeByDefault>true</activeByDefault> <activeByDefault>true</activeByDefault>
</activation> </activation>
<properties> <properties>
<java.version>11</java.version> <java.version>17</java.version>
</properties> </properties>
<build> <build>
<finalName>${project.artifactId}-${build-version}</finalName> <finalName>${project.artifactId}-${build-version}</finalName>
<plugins> <plugins>
<plugin> <plugin>
<groupId>org.apache.maven.plugins</groupId> <groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId> <artifactId>maven-compiler-plugin</artifactId>
<configuration> <configuration>
<release>${java.version}</release> <release>${java.version}</release>
<encoding>UTF-8</encoding> <encoding>UTF-8</encoding>
</configuration> </configuration>
</plugin> </plugin>
<plugin> <plugin>
<groupId>org.apache.maven.plugins</groupId> <groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId> <artifactId>maven-surefire-plugin</artifactId>
<configuration> <configuration>
<encoding>UTF-8</encoding> <encoding>UTF-8</encoding>
<systemPropertyVariables> <systemPropertyVariables>
<file.encoding>UTF-8</file.encoding> <file.encoding>UTF-8</file.encoding>
</systemPropertyVariables> </systemPropertyVariables>
</configuration> </configuration>
</plugin> </plugin>
</plugins> </plugins>
</build> </build>
<dependencies> <dependencies>
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.4.0-b180830.0438</version><!--$NO-MVN-MAN-VER$ --> <!-- TODO move to stable version when available -->
</dependency>
</dependencies>
</profile>
<profile>
<id>let_reporting</id>
<properties>
<java.version>1.8</java.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-failsafe-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-pmd-plugin</artifactId>
<version>3.10.0</version>
<configuration>
<skipEmptyReport>false</skipEmptyReport>
<failOnViolation>false</failOnViolation>
<targetJdk>${java.version}</targetJdk>
<linkXRef>false</linkXRef>
<rulesets>
<ruleset>pmd-rulesets.xml</ruleset>
</rulesets>
</configuration>
<executions>
<execution>
<goals>
<goal>check</goal>
<goal>cpd-check</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- <plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>findbugs-maven-plugin</artifactId>
<version>3.0.4</version>
<configuration>
<effort>Max</effort>
<failOnError>false</failOnError>
<threshold>Low</threshold>
<xmlOutput>true</xmlOutput>
<excludeFilterFile>findbugs-excludes.xml</excludeFilterFile>
</configuration>
<executions>
<execution>
<id>analyze-compile</id>
<phase>compile</phase>
<goals>
<goal>check</goal>
</goals>
</execution>
</executions>
</plugin>-->
<plugin>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-maven-plugin</artifactId>
<version>4.5.3.0</version>
<configuration>
<effort>Max</effort>
<failOnError>false</failOnError>
<threshold>Low</threshold>
<xmlOutput>true</xmlOutput>
<excludeFilterFile>findbugs-excludes.xml</excludeFilterFile>
</configuration>
<dependencies>
<!-- overwrite dependency on spotbugs if you want to specify the version of spotbugs -->
<dependency> <dependency>
<groupId>com.github.spotbugs</groupId> <groupId>org.glassfish.jaxb</groupId>
<artifactId>spotbugs</artifactId> <artifactId>jaxb-runtime</artifactId>
<version>4.6.0</version> <version>2.4.0-b180830.0438</version> <!--$NO-MVN-MAN-VER$ --> <!-- TODO move to stable version when available -->
</dependency> </dependency>
</dependencies> </dependencies>
</profile>
<profile>
<id>let_reporting</id>
<properties>
<java.version>1.8</java.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
<systemPropertyVariables>
<file.encoding>UTF-8</file.encoding>
</systemPropertyVariables>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-failsafe-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-pmd-plugin</artifactId>
<version>3.10.0</version>
<configuration>
<skipEmptyReport>false</skipEmptyReport>
<failOnViolation>false</failOnViolation>
<targetJdk>${java.version}</targetJdk>
<linkXRef>false</linkXRef>
<rulesets>
<ruleset>pmd-rulesets.xml</ruleset>
</rulesets>
</configuration>
<executions>
<execution>
<goals>
<goal>check</goal>
<goal>cpd-check</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-maven-plugin</artifactId>
<version>4.5.3.0</version>
<configuration>
<effort>Max</effort>
<failOnError>false</failOnError>
<threshold>Low</threshold>
<xmlOutput>true</xmlOutput>
<excludeFilterFile>findbugs-excludes.xml</excludeFilterFile>
</configuration>
<dependencies>
<!-- overwrite dependency on spotbugs if you want to specify the version of spotbugs -->
<dependency>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs</artifactId>
<version>4.6.0</version>
</dependency>
</dependencies>
</plugin>
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.8.12</version>
<executions>
<execution>
<id>prepare-agent</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<execution>
<id>report</id>
<phase>prepare-package</phase>
<goals>
<goal>report</goal>
</goals>
<configuration>
<excludes>
<exclude>ch/ethz/seb/sebserver/gui/**/*</exclude>
<exclude>ch/ethz/seb/sebserver/webservice/datalayer/batis/mapper/**/*</exclude>
<exclude>ch/ethz/seb/sebserver/webservice/datalayer/batis/model/**/*</exclude>
</excludes>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.4.0-b180830.0438</version> <!--$NO-MVN-MAN-VER$ --> <!-- TODO move to stable version when available -->
</dependency>
</dependencies>
</profile>
</profiles>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin> </plugin>
<plugin> <plugin>
<groupId>org.jacoco</groupId> <groupId>org.apache.maven.plugins</groupId>
<artifactId>jacoco-maven-plugin</artifactId> <artifactId>maven-compiler-plugin</artifactId>
<version>0.8.3</version>
<executions>
<execution>
<id>prepare-agent</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<execution>
<id>report</id>
<phase>prepare-package</phase>
<goals>
<goal>report</goal>
</goals>
<configuration> <configuration>
<excludes> <release>17</release>
<exclude>ch/ethz/seb/sebserver/gui/**/*</exclude> <encoding>UTF-8</encoding>
<exclude>ch/ethz/seb/sebserver/webservice/datalayer/batis/mapper/**/*</exclude>
<exclude>ch/ethz/seb/sebserver/webservice/datalayer/batis/model/**/*</exclude>
</excludes>
</configuration> </configuration>
</execution> </plugin>
</executions>
</plugin>
</plugins> </plugins>
</build> </build>
</profile>
</profiles>
<build> <dependencies>
<plugins> <!-- Data Base -->
<plugin> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.mariadb.jdbc</groupId>
<artifactId>spring-boot-maven-plugin</artifactId> <artifactId>mariadb-java-client</artifactId>
<executions> </dependency>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>10</source>
<target>10</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies> <!-- MyBatis -->
<!-- Data Base --> <dependency>
<dependency> <groupId>org.mybatis</groupId>
<groupId>org.mariadb.jdbc</groupId> <artifactId>mybatis</artifactId>
<artifactId>mariadb-java-client</artifactId> <version>3.5.6</version>
</dependency> </dependency>
<dependency>
<groupId>org.mybatis.dynamic-sql</groupId>
<artifactId>mybatis-dynamic-sql</artifactId>
<version>1.1.2</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.4.6</version>
</dependency>
<!-- MyBatis --> <!-- Spring / Spring Boot -->
<dependency> <dependency>
<groupId>org.mybatis</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>mybatis</artifactId> <artifactId>spring-boot-starter-web</artifactId>
<version>3.5.6</version> </dependency>
</dependency> <dependency>
<dependency> <groupId>org.springframework.boot</groupId>
<groupId>org.mybatis.dynamic-sql</groupId> <artifactId>spring-boot-starter-actuator</artifactId>
<artifactId>mybatis-dynamic-sql</artifactId> </dependency>
<version>1.1.0</version> <dependency>
</dependency> <groupId>org.springframework.boot</groupId>
<dependency> <artifactId>spring-boot-starter-tomcat</artifactId>
<groupId>org.mybatis.spring.boot</groupId> </dependency>
<artifactId>mybatis-spring-boot-starter</artifactId> <dependency>
<version>1.3.2</version> <groupId>org.springframework.boot</groupId>
</dependency> <artifactId>spring-boot-starter-jdbc</artifactId>
<dependency> </dependency>
<groupId>com.github.pagehelper</groupId> <dependency>
<artifactId>pagehelper-spring-boot-starter</artifactId> <groupId>org.springframework.boot</groupId>
<version>1.2.10</version> <artifactId>spring-boot-starter-security</artifactId>
</dependency> </dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<!-- Spring / Spring Boot --> <!-- NOTE since org.springframework.security.oauth is not fully migrated
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
</dependency>
<!-- <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
<exclusions>
<exclusion>
<artifactId>spring-boot-starter-reactor-netty</artifactId>
<groupId>org.springframework.boot</groupId>
</exclusion>
</exclusions>
</dependency>-->
<!-- NOTE since org.springframework.security.oauth is not fully migrated
to spring-boot-starter-security we have to declare a separate version here. to spring-boot-starter-security we have to declare a separate version here.
This refers to the latest version of spring-security-oauth2 and should be This refers to the latest version of spring-security-oauth2 and should be
compatible with the overall version of spring boot SEE: https://github.com/spring-projects/spring-boot/wiki/Spring-Boot-2.0.0-M5-Release-Notes#oauth-20-support compatible with the overall version of spring boot SEE: https://github.com/spring-projects/spring-boot/wiki/Spring-Boot-2.0.0-M5-Release-Notes#oauth-20-support
TODO: once spring-security-oauth2 is fully migrated we should be able to TODO: once spring-security-oauth2 is fully migrated we should be able to
remove this dependency --> remove this dependency -->
<dependency> <dependency>
<groupId>org.springframework.security.oauth</groupId> <groupId>org.springframework.security.oauth</groupId>
<artifactId>spring-security-oauth2</artifactId> <artifactId>spring-security-oauth2</artifactId>
<version>2.3.6.RELEASE</version> <version>2.3.6.RELEASE</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.security</groupId> <groupId>org.springframework.security</groupId>
<artifactId>spring-security-jwt</artifactId> <artifactId>spring-security-jwt</artifactId>
<version>1.0.9.RELEASE</version> <version>1.0.9.RELEASE</version>
</dependency> </dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<!-- Springdoc-openapi -->
<dependency>
<groupId>org.springdoc</groupId>
<artifactId>springdoc-openapi-ui</artifactId>
<version>1.5.10</version>
</dependency>
<!-- Springdoc-openapi -->
<dependency>
<groupId>org.springdoc</groupId>
<artifactId>springdoc-openapi-ui</artifactId>
<version>1.5.10</version>
</dependency>
<!-- Flyway --> <!-- Flyway -->
<dependency> <dependency>
<groupId>org.flywaydb</groupId> <groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId> <artifactId>flyway-core</artifactId>
<version>7.8.2</version> <version>7.8.2</version>
</dependency> </dependency>
<!-- EHCache --> <!-- EHCache -->
<dependency> <dependency>
<groupId>org.ehcache</groupId> <groupId>org.ehcache</groupId>
<artifactId>ehcache</artifactId> <artifactId>ehcache</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>javax.cache</groupId> <groupId>javax.cache</groupId>
<artifactId>cache-api</artifactId> <artifactId>cache-api</artifactId>
</dependency> </dependency>
<!-- Apache HTTP --> <!-- Apache HTTP -->
<dependency> <dependency>
<groupId>org.apache.httpcomponents</groupId> <groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId> <artifactId>httpclient</artifactId>
</dependency> </dependency>
<!-- Eclipse RAP / RWT --> <!-- Eclipse RAP / RWT -->
<dependency> <dependency>
<groupId>org.eclipse.rap</groupId> <groupId>org.eclipse.rap</groupId>
<artifactId>org.eclipse.rap.rwt</artifactId> <artifactId>org.eclipse.rap.rwt</artifactId>
<version>3.15.0</version> <version>3.15.0</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.eclipse.rap</groupId> <groupId>org.eclipse.rap</groupId>
<artifactId>org.eclipse.rap.fileupload</artifactId> <artifactId>org.eclipse.rap.fileupload</artifactId>
<version>3.7.0</version> <version>3.7.0</version>
</dependency> </dependency>
<!-- Misc --> <!-- Misc -->
<dependency> <dependency>
<groupId>joda-time</groupId> <groupId>joda-time</groupId>
<artifactId>joda-time</artifactId> <artifactId>joda-time</artifactId>
<version>2.10.9</version> <version>2.10.9</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.fasterxml.jackson.datatype</groupId> <groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-joda</artifactId> <artifactId>jackson-datatype-joda</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.apache.commons</groupId> <groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId> <artifactId>commons-lang3</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.cryptonode.jncryptor</groupId> <groupId>org.cryptonode.jncryptor</groupId>
<artifactId>jncryptor</artifactId> <artifactId>jncryptor</artifactId>
<version>1.2.0</version> <version>1.2.0</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.apache.commons</groupId> <groupId>org.apache.commons</groupId>
<artifactId>commons-text</artifactId> <artifactId>commons-text</artifactId>
<version>1.8</version> <version>1.10.0</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.github.vladimir-bukhtoyarov</groupId> <groupId>com.github.vladimir-bukhtoyarov</groupId>
<artifactId>bucket4j-core</artifactId> <artifactId>bucket4j-core</artifactId>
<version>4.10.0</version> <version>4.10.0</version>
</dependency> </dependency>
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>0.9.1</version>
</dependency>
<!-- Testing --> <!-- Testing -->
<dependency> <dependency>
<groupId>junit</groupId> <groupId>junit</groupId>
<artifactId>junit</artifactId> <artifactId>junit</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.junit.vintage</groupId>
<artifactId>spring-boot-starter-test</artifactId> <artifactId>junit-vintage-engine</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.security</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>spring-security-test</artifactId> <artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.h2database</groupId> <groupId>org.springframework.security</groupId>
<artifactId>h2</artifactId> <artifactId>spring-security-test</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>test</scope>
</dependency>
</dependencies> </dependencies>
</project> </project>

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2019 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this
@ -122,9 +122,14 @@ public class ClientHttpRequestFactoryService {
log.debug("Initialize ClientHttpRequestFactory with proxy: {}", proxy); log.debug("Initialize ClientHttpRequestFactory with proxy: {}", proxy);
} }
final SSLContext sslContext = org.apache.http.ssl.SSLContexts
.custom()
.loadTrustMaterial(null, new TrustAllStrategy())
.build();
final HttpComponentsClientHttpRequestFactory factory = final HttpComponentsClientHttpRequestFactory factory =
new HttpComponentsClientHttpRequestFactory(); new HttpComponentsClientHttpRequestFactory();
factory.setHttpClient(this.createProxiedClient(proxy, null)); factory.setHttpClient(this.createProxiedClient(proxy, sslContext));
factory.setBufferRequestBody(false); factory.setBufferRequestBody(false);
factory.setConnectionRequestTimeout(this.connectionRequestTimeout); factory.setConnectionRequestTimeout(this.connectionRequestTimeout);
factory.setConnectTimeout(this.connectTimeout); factory.setConnectTimeout(this.connectTimeout);
@ -133,8 +138,14 @@ public class ClientHttpRequestFactoryService {
} else { } else {
final HttpComponentsClientHttpRequestFactory devClientHttpRequestFactory = final SSLContext sslContext = org.apache.http.ssl.SSLContexts
new HttpComponentsClientHttpRequestFactory(); .custom()
.loadTrustMaterial(null, new TrustAllStrategy())
.build();
final HttpClient client = HttpClients.custom()
.setSSLContext(sslContext)
.build();
final HttpComponentsClientHttpRequestFactory devClientHttpRequestFactory = new HttpComponentsClientHttpRequestFactory(client);
devClientHttpRequestFactory.setBufferRequestBody(false); devClientHttpRequestFactory.setBufferRequestBody(false);
devClientHttpRequestFactory.setConnectionRequestTimeout(this.connectionRequestTimeout); devClientHttpRequestFactory.setConnectionRequestTimeout(this.connectionRequestTimeout);
@ -163,7 +174,7 @@ public class ClientHttpRequestFactoryService {
final String truststoreFilePath = this.environment final String truststoreFilePath = this.environment
.getProperty("server.ssl.trust-store", ""); .getProperty("server.ssl.trust-store", "");
SSLContext sslContext; final SSLContext sslContext;
if (StringUtils.isBlank(truststoreFilePath)) { if (StringUtils.isBlank(truststoreFilePath)) {
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
@ -263,6 +274,8 @@ public class ClientHttpRequestFactoryService {
if (sslContext != null) { if (sslContext != null) {
clientBuilder.setSSLContext(sslContext); clientBuilder.setSSLContext(sslContext);
} else {
} }
return clientBuilder.build(); return clientBuilder.build();

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2019 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2018 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2018 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this
@ -27,7 +27,7 @@ import ch.ethz.seb.sebserver.gbl.profile.ProdWebServiceProfile;
/** SEB-Server (Safe Exam Browser Server) is a server component to maintain and support /** SEB-Server (Safe Exam Browser Server) is a server component to maintain and support
* Exams running with SEB (Safe Exam Browser). TODO add link(s) * Exams running with SEB (Safe Exam Browser). TODO add link(s)
* * <p>
* SEB-Server uses Spring Boot as main framework is divided into two main components, * SEB-Server uses Spring Boot as main framework is divided into two main components,
* a webservice component that implements the business logic, persistence management * a webservice component that implements the business logic, persistence management
* and defines a REST API to expose the services over HTTP. The second component is a * and defines a REST API to expose the services over HTTP. The second component is a
@ -49,7 +49,7 @@ public class SEBServer {
} }
/* /*
* Add an additional redirect Connector on http port to redirect all http calls * Add a redirect Connector on http port to redirect all http calls
* to https. * to https.
* *
* NOTE: This works with TomcatServletWebServerFactory and embedded tomcat. * NOTE: This works with TomcatServletWebServerFactory and embedded tomcat.

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2019 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2019 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2018 ETH Zürich, Educational Development and Technology (LET) * Copyright (c) 2018 ETH Zürich, IT Services
* *
* This Source Code Form is subject to the terms of the Mozilla Public * This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this
@ -40,9 +40,6 @@ import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
@Order(7) @Order(7)
public class WebSecurityConfig extends WebSecurityConfigurerAdapter implements ErrorController { public class WebSecurityConfig extends WebSecurityConfigurerAdapter implements ErrorController {
private static final String ERROR_PATH = "/sebserver/error";
private static final String CHECK_PATH = "/sebserver/check";
@Value("${sebserver.webservice.http.redirect.gui}") @Value("${sebserver.webservice.http.redirect.gui}")
private String guiRedirect; private String guiRedirect;
@Value("${sebserver.webservice.api.exam.endpoint.discovery}") @Value("${sebserver.webservice.api.exam.endpoint.discovery}")
@ -77,31 +74,15 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter implements E
return new BCryptPasswordEncoder(4); return new BCryptPasswordEncoder(4);
} }
@Override @RequestMapping(API.CHECK_PATH)
public void configure(final WebSecurity web) {
web
.ignoring()
.antMatchers(ERROR_PATH)
.antMatchers(CHECK_PATH)
.antMatchers(this.examAPIDiscoveryEndpoint)
.antMatchers(this.adminAPIEndpoint + API.INFO_ENDPOINT + API.LOGO_PATH_SEGMENT + "/**")
.antMatchers(this.adminAPIEndpoint + API.INFO_ENDPOINT + API.INFO_INST_PATH_SEGMENT + "/**")
.antMatchers(this.adminAPIEndpoint + API.REGISTER_ENDPOINT);
}
@RequestMapping(CHECK_PATH)
public void check() throws IOException { public void check() throws IOException {
} }
@RequestMapping(ERROR_PATH) @RequestMapping(API.ERROR_PATH)
public void handleError(final HttpServletResponse response) throws IOException { public void handleError(final HttpServletResponse response) throws IOException {
response.getOutputStream().print(response.getStatus()); response.getOutputStream().print(response.getStatus());
response.setHeader(HttpHeaders.LOCATION, this.guiRedirect); response.setHeader(HttpHeaders.LOCATION, this.guiRedirect);
response.flushBuffer(); response.flushBuffer();
} }
@Override
public String getErrorPath() {
return ERROR_PATH;
}
} }

Some files were not shown because too many files have changed in this diff Show more