Oblig 2. Inf5120. Gruppe 21. Espen Stensund (estensun) Nguyen Tran (nguyent) Hung Huynh (qhhuynh)

Like dokumenter
University of Oslo Department of Informatics. INF Modellering med objekter Oblig 2, V2004. Skrevet av:

INF Oblig 2. Hour Registration System (HRS)

INF5120 Oblig 2 - Timeregistreringssystem Gruppe 25 Annette Kristin Levine Nils-Kristian Liborg Unni Nyhamar Hinkel

INF 5120 Obligatorisk oppgave Nr 2

INF 5120 Obligatorisk oppgave 2

Oblig2 i INF5120 Modellering med objekter UiO V04, Timelisteføringssystem Ver

INF Modellering med objekter (Oblig 2) **TimeregistreringSystem** (Designet av Alen Cemer

University of Oslo Department of Informatics. Hours Registration System (HRS) INF 5120 Oblig 2. Skrevet av:

Forslag til løsning. Oppgave 1

Hour Registration System (HRS) Oblig 2. DEL 1: COMET Business Modelling

Use case modellen. Use case modellering i analysefasen. Hva er en Aktør? Hva er et Use case? Use case modellering. Eksempel

Spesifikasjon av Lag emne

Eksamen i Internetteknologi Fagkode: IVA1379

Ansvarsdrevet OO: CRC og UML Sekvensdiagrammer

Use case modellen. Use case modellering i analysefasen. Hva er en Aktør? Hva er et Use case?

1 Innledning Plattformspesifikk modell Komponent Implementasjonsmodell Deployment Modell... 29

Kenneth A. Hansen (kennetah) Anders Gravdal (andergra) Thomas H. Espe (thomases)

Produktrapport Gruppe 9

Ressursallokering. Grunnlag for beregning av arbeidskapasitet

Use Case-modellering. INF1050: Gjennomgang, uke 04

Conference Centre Portal (CCP)

Team2 Requirements & Design Document Værsystem

Requirements & Design Document

Kravspesifikasjon. 14. oktober 2002

Leveranse 2. September 27, 2002

Timeregistrering I Agresso. Brukerveiledning (Verson 1.0 PML)

Inf5120. Obligatorisk innlevering nr 2, 3.mai Obligatorisk innlevering nr 2. Inf 5120: 5/11/2004

Stikkord: Java EE, EJB, JSF, JPA, SWT, klient/tjener, Glassfish server, Application Client.

Bachelorprosjekt i informasjonsteknologi, vår 2017

Brukermanual. System for oversiktslister. Entreprenører

UKE 11 UML modellering og use case. Gruppetime INF1055

TDT4140. Systemutvikling. Øving 1. gruppe 215. Kristoffer Hagen. Sondre Løberg Sæter. Håvard Geithus. Bjørnar Valle. Henrik Knutsen.

Funksjonsliste. Sist oppdatert februar 2019

Oversikt over flervalgstester på Ifi

Eksamen INF

UNIVERSITETET I OSLO Institutt for Informatikk. INF5120 Modellering med objekter Oblig 2 Time Master. Skrevet av: Kristrun Arnarsdottir. 03.

Brukermanual. System for oversiktslister. Entreprenører

INF5120 Obligatorisk innleving 2 Gruppe 7. Ole Tommy, Tor Eric, Audun og Kai

BRUKERDOKUMENTASJON WEB for Avdelingsleder En beskrivelse av hvordan avdelingsledere benytter. WEB-løsningen i Bluegarden Tidregistrering

Brukermanual. System for oversiktslister. Entreprenører

Løsningsskisse, eksamen J2EE og distribuerte systemer 19.mai 2004

Innsending av timelister. Timeliste. Innsending

WP-WATCHER WORDPRESS SIKKERHET

1 Inledning. 1.1 Presentasjon. Tittel Informasjonsplattform for NorgesGruppen. Oppgave Utvikle en informasjonsplattform for butikkene i NorgesGruppen

BRUKERDOKUMENTASJON WEB for Medarbeider En beskrivelse av hvordan medarbeidere benytter. WEB-løsningen i Bluegarden Tidregistrering

(MVC - Model, View, Control)

INF1010 MVC i tekstbaserte programmer

1 Introduksjon til designmodellen - del B 2

Beskrivelse av skjermbilder og funksjoner i PayBack SingelUser.

Månedsoversikt gjennom hele året.

Månedsoversikt gjennom hele året.

Prosjektgruppen: Gjermund Gartmann Tommy Jansson Margrethe Store. Prosjektledelse: Margrethe Store Kvalitetssikring: Tommy Jansson

Guide - mintimebank.no

SRD GLIS. Cecilie Dortea Gløsmyr, Espen Buø og Henrik Lie

Hjelp til Registrer arbeidstid

MARE NOSTRUM. Del 2 Kravspesifikasjon

Entobutikk 5.BRUKERMANUAL VÅR 2011

INF 5120 Modellering med objekter

4.1. Kravspesifikasjon

Spesifikasjon av Lag emne. Kursregistrering bruksmønstermodell. Dagens forelesning. Fra krav til objekter

HJELPEGUIDE TIL WEB-TIME

Følgende skal registreres i Min Tid

Use Case-modell. Vurdering av oppdragsgivers krav

BRUKERVEILEDNING TIDBANK

UML- Use case drevet analyse og design. Domenemodeller Sekvensdiagrammer Use case realisering med GRASP patterns Klassediagram - designmodeller

Innholdsfortegnelse INNHOLDSFORTEGNELSE... 2 REVISJONSOVERSIKT...4 INTRODUKSJON MED FORUTSETNINGER... 5

System Dokumentasjon. Team2. Høgskolen i Sørøst-Norge Fakultet for teknologi, naturvitenskap og maritime fag Institutt for elektro, IT og kybernetikk

Egenregistrering av timelønn (web) Rutiner for Oppland fylkeskommune

Eksamen i fag TDT4140 Systemutvikling. 6. juni, 2006 kl

!!!!!!!!!!!! !!!!!!!!!!! WP-WATCHER WORDPRESS SIKKERHET

Brukermanual AquaLog Loggføringsverktøy. Brukermanual AquaLog. Aqualog Loggførgingsverktøy

Presentasjon 2 Gruppe 2 Oppgave 2 Oppdragsgiver 2. Sammendrag 3. Dagens situasjon 3 ServiceNow 3 Coop 3. Mål og rammebetingelser 3 Mål 3 Teknologier 4

Planlegging og dokumentasjon

Årsavslutningsveiledning Visma.net Payroll

Proplan Time -Enkel webbasert timeregistrering

SRD GLIS. Cecilie Dortea Gløsmyr, Espen Buø og Henrik Lie

Brukermanual. Studentevalueringssystem

Kravspesifikasjon. Utvikling av moduler til CMS for bonefish.no. Gruppe 08-23

Applikasjonsutvikling med databaser

GJENNOMGANG OBLIGATORISK OPPGAVE 1

Vi vil gjerne vise noen eksempler! 9/13/2016. Hvilke muligheter har vi for oppfølging av rammer og handlingsrom regulert av lover, avtaler og tariffer

Brukerdokumentasjon for Administrator og andre brukere fra PT

Obligatorisk oppgave 2

UNIVERSITETET I OSLO Institutt for informatikk. INF2120: ICU - a surveillance system, Drop 1. gisleal, eivindjo, tanxn, behrozm

student s104111, s107911, s122357

De første skrittene med Norlønn

Brukerveiledning. Arbeidsvarsling

UML-Unified Modeling Language

Forprosjektrapport. Presentasjon. Oslo, den 29. Januar Gorm Eirik Svendsen Nicolai Mellbye Marius Auerdahl Per Gustav Løwenborg

Rapporter Vaktplaner Timelister Lønnskjøring Dokumenter HMS Oppgrader din virksomhet med

Håndtering av elever etter at det ikke lengre er mulig å Re-Registrere. Redigert 26/5-2014

MinTid web brukerdokumentasjon

Brukerveiledning for tidsregisteringsskjema.

Månedsoversikt gjennom hele året.

WinTid g2. Dashbord Oppfølging

Månedsoversikt gjennom hele året.

Mamut Open Services. Mamut Kunnskapsserie. Kom i gang med Mamut Online Survey

Månedsoversikt gjennom hele året.

1.0 Funksjonalitet for medarbeidere i fanen Min Info Status Sende melding om ferdig registrering CV...

Transkript:

Oblig 2 Inf5120 Gruppe 21 Espen Stensund (estensun) Nguyen Tran (nguyent) Hung Huynh (qhhuynh)

Innholdsfortegnelse. Innholdsfortegnelse. 2 Buisness Modell. 3 Visjon. 3 Aktører og interesser. 3 Risikoanalyse. 4 Goal modell. 5 Resurs klassediagram. 6 Process and role modell. 8 Sende timeliste. 9 Oppdater timeliste. 10 Requirements modell. 12 System boundary modell. 12 USE CASE BESKRIVELSE 13 Sub system grouping modell. 14 Use case. 16 Komponent infrastruktur. 21 Architecture modell. 22 Komponent interface. 22 Komponent operasjoner. 23 Timeregistrering Editor. 23 PSM. 25 Teknologi spesifisering. 25 Skjermbilder. 26 Internal design. 28 Sekvensdiagrammer. 29

Buisness Modell. Visjon. Hvorfor skal systemet utvikles? Bedriften ønsker å holde oversikt over hvor ressursene brukes og har derfor besluttet å innføre timeliste. Hver ansatt må da hver uke registrere timene de jobber på de ulike prosjektene som pågår i bedriften slik at man kan holde oversiktet over påløpte timer per prosjekt. Dette vil være enklere og mer tidsbesparende for prosjektleder. Bedriften vil også ha timebudsjett til hver enkel ansatt, slik at prosjektleder eller ledelsen ønsker å se oversikten over ansattes feriedager eller avspaseringer. Aktører og interesser. Ansatt Drift/support Økonomi HRS Prosjektleder Systemutvikler Avdelingsleder Kunder Adm./ledelse Figur 1. Omfanget av HRS.

Stakeholder Ansatte Økonomi Prosjektleder Avdelingsleder Adm./ledelse Kunder Systemutvikler Drift/support Beskrivelse Hovedbruker av systemet. Skal registrere timeforbruket sitt. Bruker systemet for å finne ferie og avspaseringsdager for hvert enkelt ansatt, og beregner lønn etter det. Lettere for ham å holde oversikt over prosjektet. Han kan enkelt finne ut hvor mye prosjektet har kostet. Ansvar for å tildele prosjekter og bestemmer budsjettet for denne. Ønsker at bedriften tjener på systemet. Ønsker at bedriften tjener på systemet. Ønsker at prosjektene koster mindre og blir fortere ferdig. Ønsker at systemet skal tilfredsstille oppdragsgiver og at systemet er lett å oppgradere og modifisere. Skal sørge for den daglige driften og brukersupport. Risikoanalyse. Nedenfor har vi listet opp de viktigste farene og kommentarene med systemet. Dette er langt i fra en komplett liste. Dette er kun ment som en pekepinn for ting som vi må være obs på. En komplett liste vil også inneholde run-time scenario, risikograd og omfang. Dessuten burde det inneholde eventuelle tiltak. Vi har valgt å ikke ta med en komplett liste ennå, fordi vi mener at den først kan lages når vi har kommet lenger ut i utviklingsfasen. Det er da vi kan virkelig se potensielle farer og feller. Risiko System blir ikke levert innen tidsfristen. Systemet har lav ytelse. Sikkerhet. Teknologi endres Antall brukere økes. Virus Systemet blir hacket. Kommentar Systemet må være klar innen tidsfristen for å få maksimalt betalt. Det stilles ingen strenge krav på ytelsen utover normal bruk. Systemet skal inneholde info som berører den enkeltes feriedager og avspaseringer. Viktig at backup blir foretatt på en skikkelig måte. Systemet har ingen krav om å bruke det nyeste innen teknologi. Systemet bygges på klient-tjener prinsipp og skal kunne håndtere mange brukere. Systemet har ingen direkte kontakt med omverden. Gode backup og sikkerhetsrutiner er nødvendige. Systemet har ingen direkte kontakt med omverden. Gode backup og sikkerhetsrutiner er nødvendige.

Goal modell. Tjene mer penger Bedre allokering av resurser Bedre oversikt over ferie og avspasering. Registrere resursforbruk Registrere timeforbruk Holde prosjekt til budsjett Figur 2. De viktigste målene. Ovenfor ser vi de viktigste målene for stakeholdere i forhold til HRS. Målene Registrere timeforbruk, Holde prosjekt til budsjett og Bedre oversikt over ferie og avspasering er nettopp motivasjonen for å opprette HRS. Vi ser her hvordan de underbygger det øverste må for bedriften.

Tjene mer Bedre allokering av resurser. Bedre oversikt over ferie og avspaseringer. Registrere all timeforbruk. Registrere resursforbruk. Registrere all timeforbruk. Holde prosjektet til budsjett. All vil ha mer penger, eller opprettholde dagens nivå. For å unngå svinn og ineffektivt organisering. Prosjektene blir fortere ferdig og dermed mer tid til å jobbe med andre prosjekt. Dagens rutine er rotete og holder ikke mål. Lettere å holde oversikt over resurser. Prosjektleder kan lett se om prosjektet snart overstrider budsjettet. Unngå svinn og ineffektivitet. Lettere å holde oversikt over resurser. Prosjektleder kan lett se om prosjektet snart overstrider budsjettet. Hjelper til å holde utgiftene nede. Resurs klassediagram. 1..1 Ferieplan Timeliste 1..* 1..* 1..1 1..1 Ansatt 1..1 1..1 Avspaserings plan 1..1 0..* Styringsplan 1..1 1..1 Prosjekt Figur 3. Resurs diagram.

Nedenfor har vi beskrevet resursene. Resurs Kommentar Ansatt Dette er en direkte mapping av den virkelige ansatt i bedriften. Han er hovedbruker av systemet. Avspaseringsplan Forteller om hvor mange timer ansatt har til gode. Det gies ikke overtid i bedriften. Ferieplan Forteller om hvor mange dager ansatt har opptjent til nå. Timeliste Ansatt har en timeliste for hvert prosjekt han er involvert i. Styringsplan Forteller mange timer som prosjektet er beregnet til å ta og hvor mange som er faktisk brukt til nå. Prosjekt Representerer et oppdrag som bedriften har. Forteller også hvem som er involvert.

Process and role modell. Lag timeliste [Ikke godkjent] Send timeliste [Stop] Oppdater timeliste Figur 4. Prosess overblikk for timeregistrering. Lag timeliste: subprosessen beskriver rutinen for å lage en timeliste. Send timeliste: subprosessen beskriver rutinen for å få godkjent timelisten og for sende den inn til systemet for oppdatering. Oppdater timeliste: subprosessen beskriver hvordan systemet oppdaterer timelisten.

Sende timeliste. Ansatte Prosjektleder Manuelt Send til prosjektleder Timeliste Godkjenne timeliste Lag timeliste [ Ikke godkjent ] Send til system for oppdatering Godkjent timeliste Figur 5. Subprosessen "Send timeliste". Aktivitet Send til prosjektleder Kommentar Timelistene for hver enkelt ansatt må være godkjent av prosjektleder. Hindrer at noen tilegner seg urettmessige goder på grunn av feil i timelistene. Godkjenne timeliste Prosjektleder har ansvaret for at timelistene er riktig utført og ført timeforbruk stemmer med faktiske timeforbruk. Send til system for oppdatering Systemet skal ha listene for å oppdatere sine informasjon.

Oppdater timeliste. Timelistehåndterer Feriehåndterer Avspaseringhåndterer Oppdatere timeliste Oppdatere prosjektplan Feriedager Oppdatere feriedager Avspaseringer Oppdatere avspasering Figur 6. Subprosessen "Oppdater timeliste".

Aktivitet Oppdatere timeliste Oppdater prosjektplan Oppdatere feriedager Oppdatere avspasering Kommentar Hver ansatt er pliktet til å rapportere inn oversikt over timeforbruk etter endt uke. En ansatt har en timeliste for hvert enkelt prosjekt som han er involvert i. Timelistene må være godkjent av prosjektleder før de blir lagret. Timelisten til den enkelte ansatt vil øke det totale timeforbruket for det aktuelle prosjektet. Det totale timeforbruk for et prosjekt er summen av timelistene til alle som er involvert i prosjektet. Prosjektleder kan hele tiden følge med utviklingen av prosjektet m.h.t. økonomi og tidsforbruk. Den samlede sum av alle timelister til en ansatt bestemmer hvor mye ferie han har rett til. Normalt vil alle heltidsansatte få maksimalt med feriedager i henhold til norsk lov. Deltidsansatte eller andre ansatte som av andre grunner ikke arbeider fullt, vil få beregnet feriedager og feriepenger ettersom hvor mye de har jobbet. Timelistene skal stå som grunnlag for disse beregningene. En arbeidsuke består av 37.5 timers betalt arbeidstid. Timeforbruk utover dette blir ikke regnet som overtid, men den ansatte skal avspasere.

Requirements modell. System boundary modell. 1 Registrere timer include 2 Oppdater timeliste Ansatt include include 3 Oppdatere feriedager 4 Oppdater avspasering Oppdateringsserver 5 Nytt Prosjekt 6 Endre Prosjekt 11 Vis Rapport feriedager Prosjekt leder 7 Avslutt Prosjekt 12 Vis Rapport avspasering Ledelse/ Økonomi 8 Vis Styringsplan 13 Ny bruker 9 Oppdater Styringsplan 14 Endre bruker 10 Vis Status rap for prosjekt 15 Slette bruker Drift Figur 7. Overordnet use case diagram.

USE CASE BESKRIVELSE Nedenfor har vi oppsummert alle use casene. Navn Beskrivelse Aktører 1. Registrere time Ansatt fører antall timer Ansatt, prosjektleder. brukt på forskjellige prosjekter 2. Oppdatere timeliste Timelisten blir oppdatert Oppdateringsserver etter godkjenning av prosjektleder 3. Oppdatere feriedager Sørger for at den ansatte har riktig antall feriedager Oppdateringsserver, ansatt, prosjektleder 4. Oppdatere avspaseringsdag Sørger for at den ansatte har riktig antall Oppdateringsserver, ansatt, prosjektleder avspaseringsdager 5. Ny prosjekt Et nytt prosjekt blir Prosjektleder opprettet 6. Endre prosjekt Prosjektleder ønsker å gjøre Prosjektleder endringer på prosjektet 7. Avslutt prosjekt Et prosjekt er ferdig eller Prosjektleder blir avbrutt 8. Vis styringsplan Styringsplanen viser antall Prosjektleder, ledelsen timer som har blitt brukt på prosjektet 9. Oppdatere styringsplan Sørger for at styringsplanen Prosjektleder, ledelsen blir oppdatert 10. Vis statusrapport for Muligheten for å se på Prosjektleder, ledelsen prosjekt nøkkel tall for prosjektet 11. Vis rapport feriedager Rapport som viser oversikt Ansatt, prosjektleder, 12. Vis rapport avspaseringsdager over feriedager til gode Rapport som viser oversikt over avspaseringsdager til gode 13. Ny bruker Bedriften ansetter en ny person 14. Endre bruker Sørge for å kunne endre data på de ansatte 15. Slette bruker Kunne fjerne en ansatt fra systemet ledelsen Ansatt, prosjektleder, ledelsen Drift Drift Drift

Sub system grouping modell. Subsystemgrupering. TimelisteEditor LokaloppdateringService 1 Registrere timer include 2 Oppdater timeliste Ansatt ProsjektstyringEditor include include 3 Oppdatere feriedager 4 Oppdater avspasering Oppdatering server 5 Nytt Prosjekt Avspasering og ferieviewer 6 Endre Prosjekt 11 Vis Rapport feriedager Prosjekt leder 7 Avslutt Prosjekt 12 Vis Rapport avspasering Ledelse/ Økonomi 8 Vis Styringsplan BrukerEditor 9 Oppdater Styringsplan 13 Ny bruker 10 Vis Status rap for prosjekt 14 Endre bruker 15 Slette bruker Drift Figur 8. Subsystemer. TimeregisterEditor.

TimeregisterEditoren er ett tool-komponent og det er brukt av de ansatte. Denne komponenten inneholder bare en use case, registrere timer. Her vil den ansatte registrere timene som han har jobbet på et prosjekt. LokaloppdateringServices. LokaloppdateringServices er en business-service komponent som implementerer server siden av timeregistereditoren. Den inneholder tre use cases, oppdatere timeliste for styringsplan, oppdatere ferie til gode og oppdatere avspasering. ProsjektstyringEditor. ProsjektstyringEditoren er ett tool-komponent og der brukes hovedsakelig av prosjektlederen, men også litt av ledelsen. ProsjektstyringEditoren brukes for å styre et prosjekt. Den inneholder 6 use cases, opprette prosjekt, endre prosjekt, avslutte prosjekt, vise styringsplan, oppdatere styringsplan og vis status rap for prosjekt. Alle oppdateringer og lagringer av informasjon om prosjektene skjer her. Avspasering og ferieviewer Avspasering og ferievieweren er ett tool-kompoent som brukes av den ansatte, prosjektleder og økonomiberta. Denne inneholder to use cases vis rapport feriedager og vis rapport avspasering. Denne innholder ingen funksjonalitet kun for innsyn. BrukerEditor. BrukerEditoren er en business-service-component som blir brukt av drift. Den inneholder tre use cases ny bruker, endre bruker og slette bruker.

Use case. 1 Registre timer Ansatt Figur 9. Subsystem: TimelisteEditor. Use case 1 Registrere time Prioritet 1 Mål Registrer timer som den ansatte har jobbet på et prosjekt Aktører Ansatt Pre-betingelser Ansatt må ha jobbet på et prosjekt Post-betingelser Timene den ansatte har jobbet på prosjektet blir sendt til prosjektleder Senario Ansatte registrer timer etter endt uke Beskrivelse: 1 Ansatte velger prosjektet han ønsker å registrere timer på. 2 Fyller ut timer han har jobbet den uken. 3 Sender timelisten til prosjektleder. Variasjoner: 1.1a Ansatte er ikke registrert på et prosjekt. Får ikke reg. timer. 1.1b Ansatte må kontakte prosjektleder for prosjektet. 3.1a Får ikke sendt på grunn av feil på nettet. Prøve igjen senere.

2 Oppdater timeliste 3 Oppdatere feriedager 4 Oppdater avspasering Oppdateringsserver Figur 10. Subsystem: LokaleoppdateringerService. Use case 2 Oppdatere timeliste Prioritet 1 Mål Registrer timer som den ansatte har jobbet på et prosjekt Aktører Oppdateringsserver Pre-betingelser Prosjekt leder må ha godkjent timelisten Post-betingelser Timene den ansatte har jobbet på prosjektet blir registrert Senario Oppdaterer timelisten til den ansatte Beskrivelse: 1 Systemet oppdaterer timelisten til den ansatte Variasjoner: 1.1a Systemet er nede. 1.1b Må oppdatere senere.

5 Nytt Prosjekt 6 Endre Prosjekt 10 Vis Status rap for prosjekt Prosjekt leder 8 Vis Styringsplan 7 Avslutt Prosjekt 9 Oppdater Styringsplan Figur 9. Subsystem: ProsjektstyringEditor. Use case 5 Nytt prosjekt Prioritet 1 Mål Opprette et nytt prosjekt Aktører Prosjektleder Pre-betingelser Prosjektleder har fått et prosjekt fra ledelsen Post-betingelser Prosjektet vil bli opprettet Senario Prosjektleder oppretter det nye prosjektet Beskrivelse: 1 Prosjektleder gir prosjektet et unikt navn som er allerede tildelt. 2 Registrerer informasjon som han har fått fra ledelsen. 3 Melder ansatte inn i prosjektet 4 Oppretter prosjektet Variasjoner: Use case 6 1.1a Prosjektet finnes fra før. 2.1a Mangler info for å opprette prosjektet. 3.1a Finner ikke ansatte i basen. 4.1a Mangler informasjon 4.1b Systemet gir beskjed om hva som er galt. Endre prosjekt

Prioritet 1 Mål Endre data for et prosjekt Aktører Prosjektleder Pre-betingelser Prosjektleder ønsker å endre data for et prosjekt Post-betingelser Prosjektet vil bli endret Senario Prosjektleder endrer dataen han ønsker. Beskrivelse: 1 Prosjektleder søker/velger prosjektet han ønsker å forandre. 2 Prosjektlederen får opp informasjon om prosjektet. 3 Han gjør de endringene han ønsker. 4 Lagrer Variasjoner: 1.1a Finner ikke prosjektet. 3.1a Finner ikke ansatt som prosjektleder vil melde på prosjektet. 4.1a Disken er full 4.2a Får ikke lagret pågrunn av tekniske ting. 11 Vis Rapport feriedager 12 Vis Rapport avspasering Ledelse/ Økonomi Figur 10. Subsystem: Avspasering og ferie Viewer. Use case 11 Vis rapport feriedager Prioritet 1 Mål Vise rapport over feriedager Aktører Leder/økonomi, prosjektleder, ansatt Pre-betingelser Ansatte har jobbet med et eller feler prosjekter Post-betingelser Vise ansattes feriedager Senario Aktøren ønsker info om feriedager tilgode Beskrivelse: 1 Aktør skriver in ønsket navn 2 Systemet viser antall feriedager den ansatte har tilgode. Variasjoner: 2.1a Ansatt har ikke jobbet nok til å få feriedager.

13 Ny bruker 14 Endre bruker 15 Slette bruker Drift Figur 11. Subsystem: BrukerEditor. Use case 13 Ny bruker Prioritet 1 Mål Registrere ny bruker Aktører Drift Pre-betingelser Ansatt har ikke tilgang til systemet. Post-betingelser Ny ansatt er lagret i basen Senario Bedriften tar inn en ny ansatt Beskrivelse: 1 Drift registrer in data fra bruker 2 Generer passord til brukeren 3 Legger ny bruker til databasen 4 Lagrer Variasjoner: 1.1a Bruker mangler viktige punkter

Komponent infrastruktur. Timeregistrering Avspasering og ferie Prosjektstyring Bruker adm. Komponent infrastruktur BrukerAdm service Oppdatering service BrukerInfo TimeListeInfo Figur 12. Komponent spesifisering. Systemet vårt bygger på klient-tjener prinsippet. Som vist ovenfor er Timeregistrering, Avspasering og ferie, Prosjektstyring og Bruker Adm ment for klientsiden. Forbindelsen vil skje via lokal nettverk.

Architecture modell. Komponent interface. Diagrammet nedenfor beskriver den interne infrastruktur for HRS. Bruker Editor Timeregistrering Editor Avspasering og ferie Viewer Prosjektstyring Editor IBrukerAdmService IOppdateringService BrukerAdmService OppdateringService IBrukerInfo ITimeListeInfo BrukerInfo TimeListeInfo Figur 13. Komponent struktur. Komponentene BrukerEditor, BrukerAdmService og BrukerInfo og interfacene IBrukerAdmService og IBrukerInfo blir beskrevet ytterligere i senere kapitel.

Komponent operasjoner. IBrukerAdmService + newuser (UserInfo: info) : Boolean + edituser (UserInfo: info ) : Boolean + deleteuser (UserInfo: info) : Boolean + getuserinfo (UserNavn: String) : Boolean IOppdateringService + regtime (Prosjekt: String, anttime: Int) : Boolean + showvacation() : String + showfreedays() : String + visstyringsplan (Prosjektnavn: String) : Prosjekt + editplan ( Prosjektnavn: String, Plan: String) : Boolean + avsluttprosjekt (Prosjektnavn: String): Boolean + newprosjekt(prosjektnavn: String): Boolean + editprosjekt(prosjektnavn: String, Prosjekt: String) : Boolean Timeregistrering Editor. Nedenfor beskrives den interne oppbyggingen av TimeregistreringEditor. Timeregistrering UI TimeregistreringUS ITimeregistrering TilstandsInfo ITilstandsInfo Figur 16. Timeregistrering komponent struktur.

ITimeregistrering + setprojectfocus() : void + setregistrationfocus() : void + setperiodfocus() : void + submitregistration( RegistrationInfo: String) : boolean + selectproject(projectname: String): boolean + selectperiod(period: String) : boolean

PSM. Teknologi spesifisering. Vi vil her klargjøre for hvilke teknologi vi har tenkt for hvert enkelt komponent. Det bygges hovedsakelig rundt Java og HTML. Bruker Editor Timeregistrering Editor Avspasering og ferie Viewer Prosjektstyring Editor IBrukerAdmService IOppdateringService BrukerAdmService OppdateringService IBrukerInfo ITimeListeInfo BrukerInfo TimeListeInfo Figur 17 Komponent struktur for HRS. Komponent Interface Kommentar BrukerEditor Skal bli implementert som Java Server Page (JSP). Klientsiden vil bare trenge en vanlig webbrowser. Denne delen av systemet vil bli beskyttet v.h.a. ny innlogging. Bare drift og support som kan opprette/endre/slette en bruker. Timeregistrering Skal bli implementert JSP. Editor Avspasering og ferie Viewer Skal bli implementert i ren html.

Prosjektstyring Editor BrukerAdmService OppdateringService BrukerInfo TimeListeInfo Skal bli implementert i JSP. IBrukerAdmService Skal bli implementert i Servlet tunneling framwork. IOppdateringService Skal bli implementert i Servlet tunneling framwork. Skal bli implementert som en Java server med Java Servlet. Skal bli implementert som en Java server med Java Servlet. IBrukerInfo Skal bli implementert v.h.a. JDBC. ITimeListeInfo Skal bli implementert v.h.a. JDBC. Skal bli implementert av MySQL. Skal bli implementert av MySQL. Skjermbilder. Figur 14. Registrere time skjermbilde.

Registrere timer. I dette skjermbilde vil brukere kunne gjøre fem ting, velge prosjekt, velge periode, registrere timer, sende timelisten eller avbryte. Det vil bli lastet inn en drop-down meny over alle prosjektene den ansatte er deltaker av. Her kan han velge hvilket prosjekt han ønsker å registrere timer på. I periode feltet vil det komme automatisk opp inneværende periode det skal registreres timer for, men her vil også brukeren kunne velge fritt hvilken uke han vil registrere timer for. Det eneste den ansatte trenger å skrive inn er antall timer han har jobbet, dag og dato vil komme automatisk opp. Hvis ikke brukeren fyller inn noen timer for en dag vil timeantallet bli satt til 0. Brukeren kan avbryte eller sende skjema når han vil. Figur 15. Ny bruker skjermbilde. Ny bruker. I dette skjermbilde må drift registrere informasjon om brukeren. Det vil være obligatorisk å fylle ut alle feltene. Brukeren vil få en feilmelding hvis ikke alt er fylt ut. Passordet må gjentas for å være sikker på at det ikke er noen skrivefeil.

Internal design. BrukerEditor (UI) [ Frame ] LoginDialog [ Frame ] NewUserDialog [ Frame ] EditUserDialog [ Frame ] DeleteUserDialog [ Focus ] EditorManager IBrukerAdmService BrukerAdmService [ Auxiliary] NewUserSQL [ Auxiliary] DeleteUserSQL [ Auxiliary] GetUserSQL [ Auxiliary] EditUserSQL [ Focus ] ServiceManager [ Entity] JDBC-manager IBrukerInfo BrukerInfo [ Entity ] Password 1..1 1..1 [ Focus] InfoManager [ Entity ] PersonalInfo 1..1 1..1 [ Entity ] User 1..* Figur 20. Intern struktur for bruker administrasjonsdelen av systemet.

Sekvensdiagrammer. Use Case 1. i()ansatt Timeregistrering kontrollerer Timelistekontroller Timeliste Starter systemet Hente timelister Hente timelister Generer timelister {velger prosjekt} Vis timeliste {fyller inn timer} Sender timeliste {avslutter} Figur 21. Use Case: Timeregistreing.

Use case2 {Mottar timelise} Oppdatering server Starter oppdateringen Oppdaterings kontroller Oppdaterer Oppdatere timeliste for styreplan Oppdatere ferie tilgode Oppdatere avspasering tilgode Oppdaterer Oppdaterer Figur 22. Use Case: Oppdatere timeliste.

Use case 5 Prosjektleder Prosjektkontroller Prosjekt Styringsplan Ansatt {Mottar prosjekt informasjon} Starter reg. av nytt prosjekt Taster inn informasjon om prosjektet Oppretter nytt prosjekt Registrerer info Registrer info Oppretter Styrings plan Registrerer prosjektmedlemmer Figur 23. Use Case: Nytt prosjekt.

Use case 6 Prosjektleder Prosjektkontroller Prosjekt Ansatt {Ønsker slette ansatt fra prosjekt} Finner prosjektet Henter inn info om prosjektet Sletter valgt ansatt fra prosjektet Sletter timeliste Figur 24. Use Case: Endre prosjekt.

Use Case 11 Aktør Feriedager til gode kontroller Ansatt Ferieplan {Ønsker info om feriedager tilgode} Taster inn ansattes navn Finner ansatt Hent plan Figur 25. Use Case: Vise rapport feriedager.

Use case 13 Drift Bruker kontroller Databasen {Ønsker å legge til ny bruker} Taster inn data Lagrer bruker Sjekk om bruker finnes fra før Figur 16. User Case: Ny bruker.