From 9b20ea083324aacd05e362ccd61e0b323a7204d3 Mon Sep 17 00:00:00 2001 From: Diego Villanueva <98838739+UO283615@users.noreply.github.com> Date: Fri, 9 Feb 2024 18:20:20 +0100 Subject: [PATCH] chore: Updated section 8 Written first draft of the section 8 of the documentation, the domain model is temporal. --- docs/src/08_concepts.adoc | 116 +++++++++++++++++--------------------- 1 file changed, 53 insertions(+), 63 deletions(-) diff --git a/docs/src/08_concepts.adoc b/docs/src/08_concepts.adoc index 591ccf1f..6aa3a652 100644 --- a/docs/src/08_concepts.adoc +++ b/docs/src/08_concepts.adoc @@ -6,68 +6,58 @@ ifndef::imagesdir[:imagesdir: ../images] [role="arc42help"] **** -.Content -This section describes overall, principal regulations and solution ideas that are relevant in multiple parts (= cross-cutting) of your system. -Such concepts are often related to multiple building blocks. -They can include many different topics, such as -* models, especially domain models -* architecture or design patterns -* rules for using specific technology -* principal, often technical decisions of an overarching (= cross-cutting) nature -* implementation rules - -.Motivation -Concepts form the basis for _conceptual integrity_ (consistency, homogeneity) of the architecture. -Thus, they are an important contribution to achieve inner qualities of your system. - -Some of these concepts cannot be assigned to individual building blocks, e.g. security or safety. - - -.Form -The form can be varied: - -* concept papers with any kind of structure -* cross-cutting model excerpts or scenarios using notations of the architecture views -* sample implementations, especially for technical concepts -* reference to typical usage of standard frameworks (e.g. using Hibernate for object/relational mapping) - -.Structure -A potential (but not mandatory) structure for this section could be: - -* Domain concepts -* User Experience concepts (UX) -* Safety and security concepts -* Architecture and design patterns -* "Under-the-hood" -* development concepts -* operational concepts - -Note: it might be difficult to assign individual concepts to one specific topic -on this list. - -image::08-Crosscutting-Concepts-Structure-EN.png["Possible topics for crosscutting concepts"] - - -.Further Information - -See https://docs.arc42.org/section-8/[Concepts] in the arc42 documentation. -**** - - -=== __ - -__ - - - -=== __ - -__ - -... - -=== __ - -__ +.Domain Model +These diagram is just a sketch, it should be replaced by a more accurate version upon discussion. + +[plantuml,"ConceptsDomainModel1",png] +---- +@startuml + +enum Category { + HISTORY + GEOGRAPHY + MATHS +} + +class Question{ + id: int + content: String + category: Category + language: String +} + +class User{ + id: int + name: String + email: String + password: String + answered: List +} + +class Score{ + user: User + rightRate: float + timeAvg: float + answeredQuestions: int +} + +User o--> Question +User --> Score + +@enduml +---- + +|=== +| Class | Explanation +| Question | The model of the questions +| User | The people using the application +| Score | A class that keeps tracks of each user scores +|=== + +.Architecture and design patterns +We decided to use a React based frontend with BootSpring for the backend, which will follow the model view controller pattern to make the code clear. + +.User Experience +As this is a game, the focus must be in user experience so players can have an enjoyable experience, for achieving this, the response time should be as low as possible and the interfaces should be intuitive and beautiful.