Skip to content

christiangemesi/bachelorarbeit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Please note that this is a fork of thekre (https://gitlab.fhnw.ch/thekre/ThekRe). The instructions for installations might not work since they are tailored for the official thekre repository.

ThekRe

ThekRe is a web application for the FHNW campus library to manage their theme boxes. It got setup by Maurice Meier and Nick Koch in the course of an IP5 Project and now got extended with Features by Christian Gémesi and Ramanan Rasaiah in the course of an IP6 Project.

Table of content

Installation

Architecture

Installation

Installation Development Environment with XAMPP

In the following section, we will guide you through the installation of the development environment via XAMPP on your local machine. We prefer this method for development as the application loads quicker and it has hot-reloading.

  1. Install XAMPP
    Download xampp-windows-x64-8.2.4-0-VS16-installer.exe from the above Link and run the installer.
  • At Selected Components only MySQL and phpMyAdmin are required.
  • The Installation folder needs to be C:\xampp
  • Language: Choose your preferred language
  • Click Next and wait for the installation to finish.
  1. Install Composer
    Download Composer-Setup.exe from the Link above and run the installer. (direct Download Link: here)
  • Developer mode: Uncheck the box
  • The Installation path needs to be C:\xampp\php\php.exe
  • Add PHP to PATH: Check the box, if existent
  • No Proxy settings needed
  • Click Next and wait for the installation to finish.
  1. Install IDE
    We used PhpStorm as our IDE. You can download it here
    Note: As a student/teacher you can apply to get a free premium license
  • No special settings needed
  1. Clone the Repository
    Open your IDE (in our case PHPStorm) and copy the HTTPS Link from the Project here
    Clone via HTTP Link
    In PHPStorm go to File -> New -> Project from Version Control -> Git and paste the Link into the URL field. Clone the Project into the Directory "C:\xampp\htdocs\thek-re-2" (thek-re-2 Folder needs to be created)

    If phpstorm just got installed, the setup is slightly different. After opening PHPStorm you need to click on "Get from Version Control" and paste the Link into the URL field. The directory will also need to be created manually and selected. See images below:
    img.png
    img_1.png
  1. Setup Development EMail
  • We used Gmail as our Email provider. Ensure you create a new fresh Gmail account, as we will place our password in plain text within the .env file. This precaution is taken to mitigate potential issues if the file is accidently pushed to Git.
  • To setup, you first need to enable 2-Step Verification on your Gmail account. You can do this here
  • Direct Link to 2-Step Verification: here
  • After that you can create an App Password. This password will be placed in your .env file. You can get the Password here by setting an App name. Copy the password into fresh txt file to store it until we have the .env file created.
  1. Setup .env file
    Create a new file called .env in C:\xampp\htdocs\thek-re-2 (Since you have the PHPStorm IDE Open you can rightclick on the thek-re-2 folder and select New -> File -> .env) and add the following values:
    Replace <<YOUR NAME HERE>> with the name which your emails will be sent by. (We used Development)
    Replace <<YOUR EMAIL HERE>> with the email address you created in step 5
    Replace <<YOUR APP PASSWORD HERE>> with the app password you created in step 5
APP_NAME=ThekRe
APP_ENV=local
APP_KEY=base64:OXiQSLCrUXYKg8PH2U7ulTM8cg8e5POG+H+wX4hXK4A=
APP_DEBUG=false
APP_LOG_LEVEL=debug
APP_URL=http://127.0.0.1:8000

UNIQUE_SERVER_URL=themenkisten/

BROADCAST_DRIVER=log
CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=sync

REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=

EMAILS_FROM_NAME="<<YOUR NAME HERE>>"
MAIL_DRIVER=smtp
MAIL_HOST=smtp.gmail.com
MAIL_PORT=587
MAIL_USERNAME="<<YOUR EMAIL HERE>>"
MAIL_PASSWORD="<<YOUR APP PASSWORD HERE>>"
MAIL_ENCRYPTION=tls

DATABASE_DRIVER=mysql
DATABASE_HOST=127.0.0.1
DATABASE_PORT=3306
DATABASE=thekre
DATABASE_USERNAME=thekre_admin
DATABASE_PASSWORD=cSCdrkd1VNEbk8PW

DATABASE_ROOT_PASSWORD="156deq1ws56dwq5e245864e5w6qe45w61cw5dw"
  1. Setup Database
  • Open XAMPP Control Panel and start Apache and MySQL
  • Go to http://127.0.0.1/phpmyadmin/ and create a new database called "thekre" and select "utf8_general_ci"
    create_database_thekre.JPG
  • Import the database from the file database\thekre_empty.sql
    import_db_phpmyadmin.png
  • Now the database thekre with the 11 tables got generated.
    tables_thekre.png
  • After that we have to create a new database user for the system access. Go back to the homepage and then choose "Benutzerkonten" in the navigation bar and klick Benutzerkonten hinzufügen.
    add_user_phpmyadmin.png
  • The hostname is localhost. The username and password are defined in the .env file.
    add_user_name_password_phpmyadmin.png
  • Choose the following user privilege's and klick OK. user_privileges_phpmyadmin.png
  1. Run the application
  • Open the file C:\xampp\php\php.ini with any texteditor (we chose editor.txt) and search for the line ";extension=zip". Remove the ";" at the beginning of the line to enable the extension.
  • In Your IDE open the terminal (if not already open, the terminal is located on the bottom) change into the cloned repository directory (cd <> if not already inside), and run the following commands:
  • composer install
  • php artisan key:generate
  • php artisan serve
  • Now you can open the application in your browser at http://127.0.0.1:8000/ You should see the following page:
    homepage.jpg
  • PS: the username and password for the admin under http://127.0.0.1:8000/admin/loginForm are: username: "root@localhost", password: "root@localhost"
  • PS: the password for the poweruser under http://127.0.0.1:8000/poweruser/loginForm is: "poweruser"

Installation Development Environment with Docker

In the following section, we will guide you through the installation of the dockerized environment on your local machine. Docker is used to set the application live on the FHNW Server. So it is good to also have set it up once locally for better understanding.
To make the installation easier we mainly used the User Interface of the Windows OS.
Keep in mind that there is no hot-reload for the dockerized environment. If you want to see changes you need to stop the container and start it again.

  1. Install Docker
    • Download the Docker Desktop Installer from here and run the installer.
    • You can verify the installation by running docker --version in a Terminal or run Docker Desktop on Windows
  1. Preparing the Folder Structure
    The Following steps should be done in your IDE, since otherwise youd be needed to download additional software to create a .sh file.

    1. right click on the root directory (thek-re-2) -> New -> Directory (Name: thekre_webportal)

    2. In the folder create a new file called thekre_docker.sh and paste the content from the file below:

      #!/bin/bash
      echo "Creating a new folder..."
      mkdir thekre && cd thekre || { echo "Error: Unable to create or change into thekre folder"; exit 1; }
      echo "Folder 'thekre' created and switched to."
      
      echo "Cloning the repository..."
      git clone https://gitlab.fhnw.ch/thekre/ThekRe.git || { echo "Error: Unable to clone the repository"; exit 1; }
      cd thekre || { echo "Error: Unable to change into thek-re-2 folder"; exit 1; }
      echo "Repository cloned and switched to 'thek-re-2' folder."
      
      echo "Copying the .env file into the folder..."
      cp '..\..\.env' . || { echo "Error: Unable to copy the .env.production file"; exit 1; }
      echo ".env file copied."
      
      echo "Building the Docker image..."
      docker compose build || { echo "Error: Unable to build the Docker image"; exit 1; }
      echo "Docker image built successfully."
      
      echo "Moving back to the parent folder..."
      cd .. || { echo "Error: Unable to change into the parent folder"; exit 1; }
      echo "Successfully moved back to the parent folder."
      
      echo "Creating a new folder for deployment..."
      mkdir deployment || { echo "Error: Unable to create the deployment folder"; exit 1; }
      echo "Deployment folder created."
      
      echo "Copying docker-compose.yml into the deployment folder..."
      cp 'thekre/docker-compose.yml' deployment/ || { echo "Error: Unable to copy docker-compose.yml"; exit 1; }
      echo "docker-compose.yml copied into the deployment folder."
      
      echo "Copying .env into the deployment folder..."
      cp 'thekre/.env' deployment/ || { echo "Error: Unable to copy the .env.production file"; exit 1; }
      echo ".env file copied into the deployment folder."
      
      echo "Removing the 'thek-re-2' folder..."
      rm -rf thekre || { echo "Error: Unable to remove thek-re-2 folder"; exit 1; }
      echo "'thekre' folder removed."
      
      echo "Changing into the deployment folder..."
      cd deployment || { echo "Error: Unable to change into the deployment folder"; exit 1; }
      
      echo "Starting the Docker container in the background..."
      docker compose up -d || { echo "Error: Unable to start the Docker container"; exit 1; }
      echo "Docker container started successfully."
      
    3. In the folder create a new file called .env and paste the content from the file below:

      APP_NAME=ThekRe
      APP_ENV=local
      APP_KEY=base64:OXiQSLCrUXYKg8PH2U7ulTM8cg8e5POG+H+wX4hXK4A=
      APP_DEBUG=true
      APP_LOG_LEVEL=debug
      APP_URL=http://127.0.0.1
      
      UNIQUE_SERVER_URL=themenkisten/
      
      BROADCAST_DRIVER=log
      CACHE_DRIVER=file
      SESSION_DRIVER=file
      QUEUE_DRIVER=sync
      
      REDIS_HOST=127.0.0.1
      REDIS_PASSWORD=null
      REDIS_PORT=6379
      
      PUSHER_APP_ID=
      PUSHER_APP_KEY=
      PUSHER_APP_SECRET=
      
      EMAILS_FROM_NAME="<<YOUR NAME HERE>>"
      MAIL_DRIVER=smtp
      MAIL_HOST=smtp.gmail.com
      MAIL_PORT=587
      MAIL_USERNAME="<<YOUR EMAIL HERE>>"
      MAIL_PASSWORD="<<YOUR APP PASSWORD HERE>>"
      MAIL_ENCRYPTION=tls
      
      DATABASE_DRIVER=mysql
      DATABASE_HOST=mysql
      DATABASE_PORT=3306
      DATABASE=thekre
      DATABASE_USERNAME=thekre_admin
      DATABASE_PASSWORD=cSCdrkd1VNEbk8PW
      
      DATABASE_ROOT_PASSWORD="156deq1ws56dwq5e245864e5w6qe45w61cw5dw"
      
    4. Replace all the "<< >>" with the respective values. See 5. and 6. of the Installation Development Environment with XAMPP.

    5. After doing the steps above for the respective OS, the folder structure should look like this:

     -folder
     |-thekre_docker.sh
     |-.env
    
  1. Run docker
    Open Docker Desktop and wait for the service to start. After the service is running, Docker Desktop should look like this:
    img.png
  1. Run the thekre_docker.sh

    1. Open git bash and change into the directory where thekre_werbportal is located. (cd Path/From/C/To/thekre_webportal)
      Note that git bash needs to be installed. You can download it here
    2. type "./thekre_docker" (This will execute the script)
      You can see the running container in the Docker Desktop
      img.png

Note: You might be asked to enter login credentials for git (You can not use your Password, you need to create a Personal Access Token. See the instructions here)

  1. Open the application in your browser
    http://127.0.0.1/user

    If the application is run for the first time the database needs to be imported manually. (see step 7 of the Installation Development Environment with XAMPP)

  1. Take the application offline
    To take the application offline you need to stop the Docker container. You can do this by clicking the "Stop" button in the Docker Desktop
    img.png
  1. Notes to keep in mind:
    1. If the application is run for the first time the thekre_admin user does also need to be created. (see step 7 of the Installation Development Environment with XAMPP)
    2. If the Website is not shown correctly (e.g. no CSS) clear the browser cache and, or history and reload the page.
    3. If the application got taken offline, and you want to start it again, you can do so by deleting the thekre folder and running the thekre_docker.sh again or by clicking the "Start" button in the Docker Desktop
      img.png

Set the Application Live on the FHNW Server

In the following section, we will guide you through the installation of the dockerized environment. This will set the application Live on the FHNW Server. This setup is only needed to do once.

  1. Connect to the FHNW Server
    • Connect to the FHNW Server via SSH
  1. Install Docker
    • Check if Docker is already installed by running docker --version in the Terminal. If so, skip to the next step.
    • Install Docker by running this command sudo snap install docker
  1. Preparing the Folder Structure

    1. mkdir thekre_webportal (to create a new folder)
    2. cd thekre_webportal (to change into the folder)
    3. vim thekre_script_run_once.sh (to create a new file and open it with vim)
    4. click i to enter insert mode and enter the content from /scripts/thekre_script_run_once.sh
    5. click esc to exit insert mode and type :wq to save the file
    6. type vim .env (to create a new file and open it with vim)
    7. click i to enter the insert mode and paste the content from the file below. (Replace all login Credentials with new ones!)
    • Replace the <<HERE_COMES_URL>> with the URL of the application. (liveserver: https://www.fhnw.ch/de/die-fhnw/bibliotheken/bibliothek-brugg-windisch/themenkisten, testserver: server1120.cs.technik.fhnw.ch)
    • Replace the <<HERE COMES DATABASE USERNAME>> with the username of the database user. (like: thekre_admin)
    • Replace the <<HERE COMES DATABASE PASSWORD>> with the password of the database user. (like: dajlskjlklk232lkjSD)
    • Replace the <<HERE COMES DATABASE ROOT PASSWORD>> with the password of the root user in mysql. (like: sdljkapsdj2kjkld2lkjdjl22j2JD=FDSJKLD231)
      APP_NAME=ThekRe
      APP_ENV=local
      APP_KEY=base64:OXiQSLCrUXYKg8PH2U7ulTM8cg8e5POG+H+wX4hXK4A=
      APP_DEBUG=true
      APP_LOG_LEVEL=debug
      APP_URL=<<HERE_COMES_URL>>
      
      UNIQUE_SERVER_URL=themenkisten/
      
      BROADCAST_DRIVER=log
      CACHE_DRIVER=file
      SESSION_DRIVER=file
      QUEUE_DRIVER=sync
      
      REDIS_HOST=127.0.0.1
      REDIS_PASSWORD=null
      REDIS_PORT=6379
      
      PUSHER_APP_ID=
      PUSHER_APP_KEY=
      PUSHER_APP_SECRET=
      
      EMAILS_FROM_NAME='Campusbibliothek Brugg-Windisch'
      MAIL_USERNAME="[email protected]"
      MAIL_PASSWORD=
      MAIL_DRIVER=smtp
      MAIL_HOST=lmailer.ict.fhnw.ch
      MAIL_PORT=25
      MAIL_ENCRYPTION=null
      
      DATABASE_DRIVER=mysql
      DATABASE_HOST=mysql
      DATABASE_PORT=3306
      DATABASE=thekre
      DATABASE_USERNAME="<<HERE COMES DATABASE USERNAME>>"
      DATABASE_PASSWORD="<<HERE COMES DATABASE PASSWORD>>"
      #Database root user in mysql per default is root
      DATABASE_ROOT_PASSWORD="<<HERE COMES DATABASE ROOT PASSWORD>>"
      
    1. click esc to exit insert mode and type :wq to save the file

    2. type vim clone_address.txt (to create a new file and open it with vim)

    3. click i to enter the insert mode and paste the content from the file below. This file contains the clone address of the repository with the token. This is required to automatically clone the repository. (so the Server doesnt ask for login credentials)

    4. https://user:<<TOKEN>>@gitlab.fhnw.ch/thekre/ThekRe.git

      Replace << TOKEN>> with the Project Access Token. That token can be generated by going to the project in Gitlab, On the left side clickiing on Settings -> Access Tokens:
      img.png
      Click "Add new token" and fill in the form as followed as shown in the picture below. Choose the Expiration date to be 1 year in the future (thats the maximum) and click "Create project access token".
      img.png
      Now you can copy the token and paste it into the clone_address.txt file.
      img_1.png After pasting the token into the file, click esc to exit insert mode and type :wq to save the file

      Note: This Token as we created it is only valid for 1 year. (this is also the maximum duration) After that you need to create a new one. Any pushes to the repository will not be possible without a valid token.

    5. After doing the steps above the folder structure should look like this:

         -folder  
         |-thekre_script_run_once.sh  
         |-.env  
         |-clone_address.txt  
    
    Explanations for the files:
    - thekre_script_run_once.sh: creates the deploymend folder, runs the docker containers, creates rebuild_docker_container.sh which will be scheduled with a cronjob to run every day at 00:00
    - .env: contains the environment variables for the application like logindata
    - clone_address.txt: contains the clone address of the repository with the token
    
  1. Add User to the Docker Group
    To run Docker commands without sudo, add your user to the docker group. You can do this by running the following command:
    sudo groupadd docker
    sudo usermod -a -G docker $USER
    sudo chown root:docker /var/run/docker.sock
    sudo chown -R root:docker /var/run/docker

    After that you need to logout and login again to apply the changes.
    You can test it by running docker run hello-world in the terminal. If you get a "Hello from Docker!" message, everything is set up correctly. (src: https://askubuntu.com/questions/477551/how-can-i-use-docker-without-sudo)
  1. Setup the Mail Server (LMailer)
    The Setup of this Mail Server is a combination of our findings and the official documentation of the FHNW from the official_documention_lmailer.pdf
    To send the order confirmation e-mail we use the FHNW intern LMailer. This setup only needs to be done once. If youd change to another server, youd need to follow theese steps:

    1. Unistall exim4: sudo apt-get remove exim4 exim4-base
    2. Install postfix: sudo apt-get install postfix libsasl2-modules ca-certificates

    3. typesudo vim /etc/postfix/main.cf (to open the file and paste the content from the file below with vim and Replace HERE_COMES_THE_HOSTNAME_OF_THE_SERVER with the hostname of the server. (liveserver: server1121.cs.technik.fhnw.ch, testserver: server1120.cs.technik.fhnw.ch))
     # See /usr/share/postfix/main.cf.dist for a commented, more complete version
     
     
     # Debian specific:  Specifying a file name will cause the first
     # line of that file to be used as the name.  The Debian default
     # is /etc/mailname.
     #myorigin = /etc/mailname
     
     smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)
     biff = no
     
     # appending .domain is the MUA's job.
     append_dot_mydomain = no
     
     # Uncomment the next line to generate "delayed mail" warnings
     #delay_warning_time = 4h
     
     readme_directory = no
     
     # See http://www.postfix.org/COMPATIBILITY_README.html -- default to 2 on
     # fresh installs.
     compatibility_level = 2
     
     # TLS parameters
     smtpd_tls_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
     smtpd_tls_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
     smtpd_tls_security_level=may
     
     smtp_tls_CApath=/etc/ssl/certs
     smtp_tls_security_level=may
     smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
     
     
     smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination
     myhostname = HERE_COMES_THE_HOSTNAME_OF_THE_SERVER
     alias_maps = hash:/etc/aliases
     alias_database = hash:/etc/aliases
     myorigin = /etc/mailname
     mydestination = $myhostname, server1121.cs.technik.fhnw.ch, localhost.cs.technik.fhnw.ch, , localhost
     relayhost =
     mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
     mailbox_size_limit = 0
     recipient_delimiter = +
     inet_interfaces = all
     inet_protocols = all
     
    1. type sudo vim /etc/postfix/sender_canonical (to open the file with vim and add the lines below. This has to be done, so that all local E-Mails get forwarded to the collective address.)
    @<hostname>.imvs.technik.fhnw.ch [email protected]
    @<hostname> [email protected]
    @localhost [email protected]
    1. Now execute the following commands to create the hash files:
 postmap hash:/etc/aliases
 postmap hash:/etc/postfix/recipient_canonical
 postmap hash:/etc/postfix/sender_canonical

After every change of the files the hashes have to generated again.

  1. Run docker
    1. you can check if the service is running with docker ps, if no service is running start it with sudo systemctl start docker
  1. Run the thekre_script_run_once.sh
    1. sudo chmod +x thekre_script_run_once.sh (to make the file executable)
    2. ./thekre_script_run_once.sh (to run the file)
  1. Setup automatic updates
    For the application to always have the lates version running, we need to setup a cronjob. The cronjob will run the rebuild_docker_container.sh script every day at 00:00. Execute the following command to set it up:
    1. crontab -e (to open the file)
    2. click i to enter the insert mode and add the following line to the file:
      0 0 * * * cd /home/thekre/thekre_webportal && sh rebuild_docker_container.sh >> /home/thekre/thekre_webportal/rebuild.log (this will also log any errors into rebuild.log)
    3. click esc to exit insert mode and type :wq to save the file

This will run the rebuild_docker_container.sh script every day at 00:00. The script looks for changes in git, pulls them, rebuilds and reruns the containers and removes the previous images so that we dont run out of space.

  1. Open the application in your browser
    liveserver: https://www.fhnw.ch/de/die-fhnw/bibliotheken/bibliothek-brugg-windisch/themenkisten/user
    testserver: server1120.cs.technik.fhnw.ch/user

    If the application is run for the very first time the database needs to be imported manually. (see step 7 of the Installation Development Environment with XAMPP)
    Setup is now complete.
    9. Can be skipped and only needs to be done whenever you want to take the application offline.

  1. Take the application offline
    To take the application offline you need to stop the Docker container. You need to change into the deployment folder and run the following command:
    docker compose down
    You also need to remove the cronjob. You can do this by running crontab -e click i to change to insert mode and deleting the line we added in step 6. (or you can comment it out by adding a # at the beginning of the line, esc to exit insert mode and type :wq to save the file)
  1. Notes to keep in mind:
    1. If the application is run for the very first time the thekre_admin user does also need to be created. (see step 7 of the Installation Development Environment with XAMPP)
    2. If the Website is not shown correctly (e.g. no CSS) and you get 404 errors, compose down the containers, and delete everything (inclusive the thekre_webportal folder). That problem seems to occur if you run the script multiple times.
    3. Note the docker containers will not be started again after a server restart. Please type the following command to start the containers again:
      cd /home/thekre/thekre_webportal && docker compose up -d

Architecture

Information to the Classes

Class Name Description
UserController The class UserController is used to provide all the functionality for the user, like to see the availability from theme boxes or create an order.
AdminController The class AdminController is used to provide all the functionality for the administrator, like the login or view the theme boxes.
Themebox The class Themebox provides all the theme box data.
Order The class Order provide all the order data.
HourlyOrder The class HourlyOrder provides all data to hourly Orders.
Order Type The class Order Type provides all the different order type data.
Delivery The class Delivery provides all the different delivery type data.
Status The class Status provides all the different status type data.
Blocked_Period The class Blocked_Period provides all the different blocked period type data.
EditMail The class Edit Mail provides all the different data for editing the mail templates.
PasswordReset The class PasswordReset provides all the different password reset type data.
Login The class Login provides all the different Login type data.

Database

Table Description
tbl_themebox The table tbl_themebox represents a renting object.
tbl_status The table tbl_status represents a status from an order. There are five different status which an order can have:
  • “Neu” (a new order is created in the database)
  • “Bereit” (the theme box is ready to be supplied)
  • “im Umlauf” (the person, who created the order, has the theme box)
  • “zurück gekommen” (the theme box is back at the FHNW li-brary
  • “abgeschlossen” (the theme box is checked form a library staff and the order is completed)
tbl_delivery The table tbl_delivery represents the different delivery types:
  • “Abholung an Ort” (the theme box will be picked up)
  • “Lieferung an Aargauer Schulen” (the theme box will be delivered to a school)
tbl_order The table tbl_order represents an order.
tbl_hourly_order The table tbl_hourly_order represents an hourly order.
tbl_mail The table tbl_mail represents the different mail template types:
  • "mail_delivery_school" (the theme box will be delivered to a school)
  • "mail_delivery_pickup" (the theme box will be picked up)
  • "mail_ready_pickup" (mail template, for sending pickup mail when delivery status gets changed to "Bereit")
tbl_blocked_period The table tbl_blocked_period represents the blocked periods.
tbl_login In the tbl_login the hashed and salted administrator password gets stored.
tbl_password_reset The table tbl_password_reset represents the password reset.
tbl_order_type The table tbl_order_type represents the different order types:
  • “Tagesbestellung” (a daily order)
  • “Stundenbestellung” (an hourly order)
tbl_category The table tbl_category represents the different categories of renting objects.

Order Status

When a user orders a box, a new order record will be created in the database. An order refers always to one theme box. Each order has a status. There are 6 different statuses: new, ready, running, returned, closed and cancelled. In the following image, we can see the sequence from the order statuses. Those statuses are recorded in German in the database.

status_diagram.png

  1. A new order is created, when the user places an order for a theme box over the order form. New is the initial status from an order.

  2. The administrator sees the new order in their administration section.

  3. The administrator prepares the theme box and check if its content is complete.

  4. When the theme box is complete, the administrator sets the status from new to ready. When an item is missing in the theme box, the replacement is done in few hours.

  5. The user comes to the library and picks the theme box up. The administrator sets the status from ready to running. The status is also set to running when the theme box is delivered to the customer.

  6. On the end-date of the order, the user brings the theme box back to the library. The administrator sets the status from running to returned.

  7. When the theme box content is complete, the administrator sets the status from returned to closed.

  8. When the order gets cancelled, the administrator sets the status from closed to cancelled.

  9. When there is a missing part in the theme box, the administrator marks the theme box as incomplete in the order tool.

External Libraries

The following external libraries are used.

Library Description
jQuery
v1.12.4
jQuery is a JavaScript library which offers the opportunity to manipulate the DOM. jQuery contains the module AJAX, which allows asynchronous JavaScript calls. The asynchronous JavaScript is used to load data from the back end without reloading the page.
https://jquery.com/
Bootstrap
v3.3.7
Bootstrap is a CSS library which offers a lot of different pattern for HTML elements. Bootstrap is used for different user interface elements such as but-tons or callback modals.
https://getbootstrap.com/
Fullcalendar
v3.5.1
Fullcalendar is an external JavaScript library to generate a month-view based calendar. This calendar is used as view element to create and edit an order.
https://fullcalendar.io/
DataTable
v1.10.16
DataTable is an external JavaScript library to generate a data table with a search module. This table is used to show all the orders and theme boxes.
https://datatables.net/
Summernote
v0.8.9
Summernote is a JavaScript library that helps you create WYSIWYG editors online.
https://summernote.org/

Coding Conventions

Boundaries and Parameter

Parameter Boundary / Value
theme box block days before order 7 days
theme box block days after the return 7 days
personal data text length 0 - 100 characters
order data text length 0 - 100 characters
plz length 4 digit
phone number length 10 digit
order number 8 characters
amount of administrator accounts 1
calendar Gregorian

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published