WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange...

40
The Mobility Project WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION AND MOBILITY BETWEEN HIGHER EDUCATION INSTITUTIONS RS 3 G workshop, Uppsala, November 16th 2009

Transcript of WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange...

Page 1: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

The Mobility Project

WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION AND MOBILITY BETWEEN HIGHER

EDUCATION INSTITUTIONS

RS3G workshop, Uppsala, November 16th 2009

Page 2: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

2

Janina [email protected]

affiliations:MUCI, Poland, consortium of Polish universities, owner of

USOS (University Study-Oriented System), project leader University of Warsaw, Faculty of Mathematics, Computer

Science and Mechanics, Assistant Professor (operating systems, parallel programming, system programming, software engineering, ...)

Page 3: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

3

Agenda

Real life scenarios and needsWSDL – format of exchanged data (ver. 2)Mobility web node (ver. 2)

architecturetestbed

Problems to solve

Page 4: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

4

Real life scenario

International Relations Office at the University of Warsaw

Faculty of Mathematics, Computer Science and Mechanics

University Study-Oriented System (USOS)

Page 5: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

5

USOS – module for IRO

Page 6: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

6

IRO – International cooperationAgreements

Page 7: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

7

IRO – Agreement Conditions of cooperation

Page 8: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

8

Faculty – Offers available for students

Page 9: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

9

Faculty – Student’s application

Page 10: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

10

Faculty – Nominations

Page 11: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

11

IRO – Outgoing mobility

Page 12: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

12

IRO – What happens next ...

Nominations are:• typed manually into partner’s system (many different systems, many different styles andrequirements)

• scanned,• faxed,• delivered by phone call• ...Usually many times(updates are common)

Page 13: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

13

IRO – We would prefer to do it with ... one click SEND button...

Page 14: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

14

IRO – partner would send us his students in a similar way this is the result of the remote invocation of

sendNominatedStudents()

Page 15: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

15

Signing agreement (organization’s information record, cooperation conditions of the agreement)Sending Learning Agreements (sending token vs sending structured data)Getting Transcripts of Records (grades)Sending departure/arrival dates of mobile students (important scholarships)Sending course catalog

Other scenarios

Page 16: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

16

Learning Agreement

Page 17: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

17

Learning Agreement Transcript of Records

Page 18: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

18

Grades from the University of Edinburgh

Page 19: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

19

Diploma supplement

Page 20: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

20

IRO – Scholarships(final amount depends on dates of arrival/departures)

Page 21: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

21

GOAL

STOP SENDING PAPER, EXCHANGE ELECTRONICALLY

STRUCTURED DATABY CALLING WEB-SERVICES

Page 22: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

22

Establishing format for data exchange

Standardisation committees and on-going projectsCEN (European Commission for Standardization)

Metadata for Learning Opportunities (MLO) – e.g. programme of study, course catalog European Learner Mobility (ELM) – e.g. Europass portfolio (Diploma Supplement, Certificate Supplement, Curriculum Vitae, Mobility, Language Passport)

R3SG (Rome Student System and Standard Group)National initiatives

OODI FinlandGerman universities, sending eToRs using OSCI protocol

Vendor initiativesunisolution – web services for moveon users

and many others ...

Page 23: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

23

WSDL for the Mobility project

Such diversity of standards does not make things easier Mobility project has specific objectives and specific needs

Data should be well structuredPieces of data should be uniquely identifiable (on a database level)Each party may want to use own identifiersEach party may want to use own language

Some possible solutions are presented on the following slides ...

Page 24: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

24

WSDL – some details 1List of strings in various languages

ISO-based types

Identifiers (global)•an organization – domain name, e.g. uw.edu.pl (inspired by SCHAC)•a person – national

identifier

Page 25: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

25

WSDL – some details 2

Agreement(localidentifiers)

Student(localidentifiers)

Page 26: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

26

WSDL – some details 3Organization data

Example

Page 27: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

27

WSDL – some details 4

Coursedataexample

Page 28: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

28

WSDL – some details 5

Courseinstance

Grade(s)

Subjectareacode

Page 29: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

29

WSDL – methods (web services)

sendOrganizationData()getOrganizationData()sendAgreementData(), getAgreementData()sendNominatedStudents()getNominatedStudents()sendArrivalDate(), getArrivalDate()sendDepartureDate(), getDepartureDate()sendLearningAgreement()getLearningAgreement()sendTranscriptOfRecords()getTranscriptOfRecords()getCourseData()validateNationalPersonalID()

Page 30: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

30

Architecture of the prototype (ver. 2)

Page 31: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

31

Testbed for the project (ver. 2)

Page 32: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

32

UDDI – Universal Description, Discovery and Integration (registry of Mobility nodes)

Page 33: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

33

Web client (client= WARSAW, server= PARMA)http://usosphp.mimuw.edu.pl:7979/mobility-client-web/index.jsp

Page 34: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

34

Web server (server=PARMA)http://usosphp.mimuw.edu.pl:7878/mobility-server-web/

Page 35: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

35

Web client (client= PARMA, server= WARSAW)http://usosphp.mimuw.edu.pl:7979/mobility-client-web/index.jsp

Page 36: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

36

Web server (server=WARSAW)http://usosphp.mimuw.edu.pl:7979/mobility-server-web/

Page 37: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

37

Integration with USOS (Oracle database, Oracle forms)

1. Web service called by the local usersend() – gather context data, create XML message, enque it into Advanced Message Queue for outgoing messages,read the answer from Advanced Message Queue forincoming messagesget() – create XML message, enque it into the Advanced Message Queue for outgoing messages, read the answer from Advanced Message Queue for incoming messages, display it in user interface

2. Web service called by the remote usersend() – store incoming messages in XML buffer insideOracle database, use database views for selecting messages corresponding to specific methods, display them on demand in user interfaceget() – invoke a procedure from Oracle package, which selects data from the database and sends to the caller

Page 38: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

38

IRO – result of the remote invocation ofsendOrganizationData()

Page 39: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

39

Questions and problemsMobility project has specific objectives and specific needs concerning exchanged data – how to integrate its WSDL with other standardsSoftware for mobility nodes distributed as open-sourceSoftware for local system developed by local vendors, consortia, ...UDDI – one or many, who should administer?Authorisation and authentication in global scale(federated IDM or bilateral authorisation agreements)Security and privacy of data – legal aspectsNext steps ...

Page 40: WEB-SERVICES FOR EXCHANGE OF DATA ON COOPERATION … · 22 Establishing format for data exchange Standardisation committees and on-going projects CEN (European Commission for Standardization)

40

Links and readings

Project home pagehttp://usos.edu.pl/MobilityWeb clienthttp://usosphp.mimuw.edu.pl:7979/mobility-client-web/Web serverhttp://usosphp.mimuw.edu.pl:7979/mobility-server-web/Rafał Nagrodzki, The Mobility Project, Master Thesis in Computer Science, University of Warsaw