{"id":19934747,"url":"https://github.com/lydia-ath/eclass_advanced_programming","last_synced_at":"2026-06-11T15:31:25.285Z","repository":{"id":192227898,"uuid":"448379571","full_name":"lydia-ath/eclass_advanced_programming","owner":"lydia-ath","description":null,"archived":false,"fork":false,"pushed_at":"2022-01-15T20:11:46.000Z","size":377,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"main","last_synced_at":"2025-03-08T12:44:24.357Z","etag":null,"topics":["hibernate-jpa","java","jax-rs-jersey","jpa-persistence-applications","junit-test"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/lydia-ath.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2022-01-15T20:07:17.000Z","updated_at":"2022-03-07T22:10:48.000Z","dependencies_parsed_at":"2023-09-03T14:33:45.977Z","dependency_job_id":"247aa81b-7d9f-4788-97cc-9a16cb897e37","html_url":"https://github.com/lydia-ath/eclass_advanced_programming","commit_stats":null,"previous_names":["lydia-ath/eclass_advanced_programming"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/lydia-ath/eclass_advanced_programming","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lydia-ath%2Feclass_advanced_programming","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lydia-ath%2Feclass_advanced_programming/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lydia-ath%2Feclass_advanced_programming/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lydia-ath%2Feclass_advanced_programming/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/lydia-ath","download_url":"https://codeload.github.com/lydia-ath/eclass_advanced_programming/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/lydia-ath%2Feclass_advanced_programming/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34206487,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-11T02:00:06.485Z","response_time":57,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["hibernate-jpa","java","jax-rs-jersey","jpa-persistence-applications","junit-test"],"created_at":"2024-11-12T23:17:48.196Z","updated_at":"2026-06-11T15:31:25.217Z","avatar_url":"https://github.com/lydia-ath.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"Σύστημα Διαχείρησης Σχολικής Μονάδας\r\n==============================================================================================================\r\nΠεδίο προβλήματος: \r\n\r\n* Tο σύστημα θα υποστηρίζει μια σχολική μονάδα μεσης εκπαίδευσης (γυμνάσιο).\r\n* Tο σύστημα θα έχει τη δυνατότητα καταχώρησης-εγγραφής μαθητών-καθηγητών (όνομα, επώνυμο, φύλο, διεύθυνση κατοικίας κτλ).\r\n* Tο σύστημα θα έχει τη δυνατότητα  διαγραφής μαθητών-καθηγητών από το σύστημα (οριστική διαγραφή, επανεγγραφή ή απλή διόρθωση/ενημέρωση στοιχείων).\r\n* Το σύστημα θα καταχωρεί τους μαθητές σε αίθουσες συγκεκριμένης χωρητικότητας (15 άτομα)  λόγω των μέτρων της πανδημίας, οπότε όταν μια αίθουσα γεμίζει οι \r\nυπόλοιποι μαθητές τοποθετούνται στην επόμενη κτλ.\r\n* Το σύστημα θα κάνει αυτόματη ανάθεση μαθητών σε τμήματα των 15 ατόμων.\r\n* Η γραμματεία θα έχει δυνατότητα καταχώρισης των μαθημάτων για κάθε τάξη (1η, 2α, 3η γυμνασίου).\r\n* Το σύστημα θα υποστηρίζει συγκεκριμένες ειδικότητες Μαθηματικά, Φιλολογικά, Φυσικές Επιστήμες, Φυσική Αγωγή \r\nκαι Καλλιτεχνικά.\r\n* Το σύστημα θα υποστηρίζει ανάθεση καθηγητών για διδασκαλία των μαθημάτων του κάθε τμήματος.\r\nεξασφαλίζοντας την συμβατότητα μεταξύ μαθήματος και ειδικότητας καθηγητή καθώς και το μέγιστο ωράριο του \r\nκάθε διδάσκοντας (20 ώρες).\r\n* Το σύστημα θα υποστηρίζει την καταχώριση βαθμολογίας για συγκεκριμένο μάθημα και τμήμα από διδάσκοντά του\r\n* Το σύστημα θα εκδίδει αναφορές με τη βαθμολογία κάθε μαθητή.\r\n\r\n\r\n\r\nΟικοδόμηση \r\n---------------------------------------------------------------------------------------------------------------\r\n\r\nΗ οικοδόμηση (build) του λογισμικού γίνεται με το εργαλείο [Maven 3](https://maven.apache.org/)\r\nΗ εγκατάσταση του Maven είναι σχετικά απλή. Αφού κατεβάσουμε το Maven (π.χ. έκδοση 3.5.0) και τα αποσυμπιέσουμε σε κατάλληλους καταλόγους \r\nπ.χ. \u003ccode\u003e C:\\\\Program Files\\\\apache-maven-3.5.0\\\\ \u003c/code\u003e αντίστοιχα θα πρέπει:\r\n\r\n* να ορίσουμε τη μεταβλητή περιβάλλοντος JAVA_HOME η οποία θα δείχνει στον κατάλογο εγκατάστασης του JDK,\r\n* να προσθέσουμε τον κατάλογο \u003ccode\u003e C:\\\\Program Files\\\\apache-maven-3.5.0\\\\bin \u003c/code\u003e στη μεταβλητή περιβάλλοντος PATH.\r\n* να ορίσουμε τη μεταβλητή περιβάλλοντος M2_HOME. Στο παράδειγμά μας είναι ο κατάλογος \u003ccode\u003eC:\\\\Program Files\\\\apache-maven-3.5.0\\\\\u003c/code\u003e.\r\n\r\nΓια να εκτελέσουμε από τη γραμμή εντολών εργασίες οικοδόμησης του λογισμικού χρησιμοποιούμε το Maven μέσω της εντολής \u003ccode\u003emvn\u003c/code\u003e, \r\nαφού μετακινηθούμε στον κατάλογο όπου βρίσκεται το αρχείο pom.xml. Η τυπική εκτέλεση του Maven είναι:\r\n\r\n\u003ccode\u003emvn [options] [target [target2 [target3] … ]]\u003c/code\u003e\r\n\r\nΤα παραγόμενα αρχεία δημιουργούνται από το Maven στο κατάλογο \u003ccode\u003e/target\u003c/code\u003e. \r\n\r\nΤυπικές εργασίες με το Maven είναι:\r\n* \u003ccode\u003emvn clean\u003c/code\u003e καθαρισμός του project. Διαγράφονται όλα τα αρχεία του καταλόγου \u003ccode\u003e/target\u003c/code\u003e.\r\n* \u003ccode\u003emvn compile\u003c/code\u003e μεταγλώττιση του πηγαίου κώδικα. Τα αρχεία \u003ccode\u003e.class\u003c/code\u003e παράγονται στον κατάλογο \u003ccode\u003e/target/classes\u003c/code\u003e.\r\n* \u003ccode\u003emvn test-compile\u003c/code\u003e μεταγλώττιση του κώδικα ελέγχου. Τα αρχεία .class παράγονται στον κατάλογο \u003ccode\u003e/target/test-classes\u003c/code\u003e.\r\n* \u003ccode\u003emvn test\u003c/code\u003e εκτέλεση των ελέγχων με το JUnit framework. \r\n* \u003ccode\u003emvn site\u003c/code\u003e παραγωγή στο site του έργου το οποίο περιλαμβάνει την τεκμηρίωση του έργου.\r\n* \u003ccode\u003emvn umlet:convert -Dumlet.targetDir=src/site/markdown/uml\u003c/code\u003e παράγει αρχεία εικόνας png για όλα τα διαγράμματα που βρίσκονται στην τοποθεσία `src/site/markdown/uml`. Συστήνεται η κλήση της εντολής πριν την υποβολή μιας νέας έκδοσης διαγραμμάτων στο git repository (`git commit`). Ως αποτέλεσμα τα παραγόμενα αρχεία εικόνας των διαγραμμάτων συνοδεύουν τα πηγαία αρχεία έτσι ώστε να είναι εύκολη η πλοήγηση στην τεκμηρίωση του project  μέσω του github.\r\n\r\nΗ τεκμηρίωση περιλαμβάνει:\r\n* Ένα πρότυπο εγγράφου προδιαγραφών απαιτήσεων λογισμικού. Τα πηγαία αρχεία του εγγράφου βρίσκονται στον φάκελο \u003ccode\u003e/src/site\u003c/code\u003e.\r\n* Το έγγραφο περιγραφής σχεδίασης λογισμικού. Τα πηγαία αρχεία του εγγράφου βρίσκονται στον φάκελο \u003ccode\u003e/src/site\u003c/code\u003e.\r\n* Η τεκμηρίωση του κώδικα με το JavaDoc.\r\n* Αναφορές καλύψεων κώδικα με χρήση του εργαλείου JaCoCo.\r\n* Αναφορά αυτόματης επιθεώρησης κώδικα με το εργαλείο CheckStyle.\r\n* Αναφορά αυτόματης επιθεώρησης κώδικα με το εργαλείο SpotBugs.\r\n* Αναφορά αντιγραφής/επικόλλησης κώδικα με το εργαλείο CPD/PMD.\r\n* Αναφορά αυτόματης επιθεώρησης κώδικα με το εργαλείο PMD.\r\n\r\n\r\nEclipse\r\n-------------------------------------------------------------------------------------------------------------\r\nΗ εισαγωγή του project στο Eclipse γίνεται με την επιλογή \u003ccode\u003eFile/Import/Maven/Existing Maven Projects\u003c/code\u003e με την επιλογή του καταλόγου που περιλαμβάνει το project.  \r\n\r\n\r\nΤεκμηρίωση\r\n-------------------------------------------------------------------------------------------------------------\r\nΓια την τεκμηρίωση του λογισμικού χρησιμοποιήθηκε το Markdown markup για τη συγγραφή των κειμένων και το εργαλείο UMLet για την κατασκευή των διαγραμμάτων UML.\r\n \r\n\r\n## Χρήσιμες εντολές:\r\nΗ διαχείριση της οικοδόμησης του έργου μπορεί να γίνει με μια σειρά βασικών εντολών:\r\n- `mvn`: εκτελεί τον προκαθορισμένο κύκλο οικοδόμησης\r\n- `mvn test`: εκτελεί τα unit tests του project\r\n- `mvn site`: παράγει την τεκμηρίωση του project σε μορφή HTML. Τα παραγόμενα αρχεία \r\n  είναι διαθέσιμα στην τοποθεσία `target/site/`\r\n- `mvn umlet:convert -Dumlet.targetDir=src/site/markdown/uml`: παράγει αρχεία εικόνας png για όλα τα διαγράμματα που βρίσκονται στην τοποθεσία `src/site/markdown/uml`. Συστήνεται η κλήση της εντολής πριν την υποβολή μιας νέας έκδοσης διαγραμμάτων στο git repository (`git commit`). Ως αποτέλεσμα τα παραγόμενα αρχεία εικόνας των διαγραμμάτων συνοδεύουν τα πηγαία αρχεία έτσι ώστε να είναι εύκολη η πλοήγηση στην τεκμηρίωση του project  μέσω του github.  \r\n\r\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flydia-ath%2Feclass_advanced_programming","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flydia-ath%2Feclass_advanced_programming","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flydia-ath%2Feclass_advanced_programming/lists"}