Compare commits

..

19 Commits

Author SHA1 Message Date
Marko Schrempf
07ab4695ad added dependabot 2025-01-09 22:39:59 +01:00
Marko Schrempf
e8f727955b implemented workflows for repo change to GitHub 2025-01-09 22:28:48 +01:00
Marko Schrempf
86361a8183 add hunspell-en-us 2025-01-09 13:19:41 +01:00
Marko Schrempf
98785355d3 update doku 2025-01-09 12:31:51 +01:00
Marko Schrempf
e5b7874031 added caching 2025-01-09 11:30:35 +01:00
Marko Schrempf
b7faab0dcd functional docker action 2025-01-09 09:22:28 +01:00
Marko Schrempf
09d03710d1 update github actions and doku for it 2025-01-08 23:35:09 +01:00
Marko Schrempf
3f093df850 fixed github action ubuntu version 2025-01-08 15:04:31 +01:00
Günther Hutter
3c63de6edb Added info about docker and github workflow 2024-12-21 15:34:34 +01:00
Günther Hutter
8a9ffa43ac Fixed names of the container 2024-12-21 15:03:55 +01:00
Günther Hutter
105c21562f Added Docker support 2024-12-21 15:02:27 +01:00
Günther Hutter
b2ae73e538 Updated Logo and added a ithub workflow to build the image as workflow 2024-12-21 14:19:42 +01:00
Günther Hutter
51251c0bae Changed filenames to have no underscores. Updated makefile to wrtie a warning if there are underscores in filenames which are used during the build process. Closes #36 2024-04-17 23:03:28 +02:00
Günther Hutter
f6b7290893 Better namings in templates 2024-04-17 22:50:39 +02:00
Günther Hutter
c2d6bb0c10 Weitere Formulare und Vorlagen die im Laufe einer DA gebraucht werden eingecheckt 2024-04-17 22:45:08 +02:00
Günther Hutter
5b095573c0 Beispieldateien für DA Dokumentation als PDF hochgeladen
Diese sollten in der DA durch ein PDF des Formulars under doc ersetzt werden
2024-04-17 22:39:37 +02:00
Günther Hutter
4746e4ee0a Info wg. DA Vereinbarungen in yaml übernommen 2024-04-17 22:35:01 +02:00
Günther Hutter
1befba5364 Englische DA Doku eingecheckt 2024-04-17 22:32:07 +02:00
Günther Hutter
a2d4ccbb04 KI tools section corrected 2024-03-13 15:06:58 +01:00
31 changed files with 419 additions and 9 deletions

9
.github/dependabot.yml vendored Normal file
View File

@ -0,0 +1,9 @@
version: 2
updates:
- package-ecosystem: "docker"
directory: "tools/docker"
schedule:
interval: "monthly"
commit-message:
prefix: "deps"
include: "scope"

30
.github/workflows/image-build.yml vendored Normal file
View File

@ -0,0 +1,30 @@
name: Build and push docker image
on:
push:
branches:
- main
paths:
- tools/docker/Dockerfile
workflow_dispatch:
jobs:
build-push:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Docker hub login
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v6
with:
context: tools/docker
push: true
tags: ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY }}:latest

28
.github/workflows/release.yml vendored Normal file
View File

@ -0,0 +1,28 @@
name: Release
on:
push:
tags:
- v*
permissions:
contents: write
jobs:
release:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Create release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref_name }}
release_name: ${{ github.ref_name }}
draft: false
prerelease: false

View File

@ -47,6 +47,18 @@ build-stage:
@echo "Merging style files into the staging directory"
@rsync -av $(STYLEDIR)/ $(STAGINGDIR)/style --quiet
# Prüfen auf Dateien mit Unterstrichen im Namen
@echo "Checking for files containing underscores in $(STAGINGDIR)..."
@files=$$(find $(STAGINGDIR) -type f -name '*_*'); \
if [ -n "$$files" ]; then \
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"; \
echo "WARNING: Found files with underscores:"; \
echo " -> $$files"; \
echo "These files are very likely to cause issues during the build process"; \
echo "Remove or rename them to build the thesis safely"; \
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"; \
fi
compile-output:
# Bauen der Arbeit aus dem staging verzeichnis heraus
@echo "Compiling the thesis into: $(OUTPUTFILE)"

View File

@ -57,6 +57,11 @@ $ sudo apt-get install git build-essential make-guile texlive-full pandoc pandoc
Bei einer englischen Diplomarbeit muss außerdem entweder das Paket `hunspell-en-gb` oder `hunspell-en-us` installiert werden.
## Alternative platformen
Sie können die Diplomarbeit auch mit Hilfe von Docker oder Github WOrkflow bauen. Nähere Details dazu finden Sie im Verzeichnis `tools`.
# Grundlegende Schritte
## Manuelles erstellen einer Diplomarbeit
@ -334,14 +339,8 @@ Bei speziellen Fragen zu diesem Vorgehen wenden Sie sich bitte an den Programmie
## Tipps & Tricks
**ES WIRD DRINGEND EMPFOHLEN DAS JEDER DIPLOMAND SEINE DIPLOMARBEIT LOKAL AUF SEINEM EIGENEN RECHNER BAUEN KANN**
### Generell
* Man kann ToDo Blöcke in die DA einfügen indem man folgenden Block verwendet `\todo{Was noch zu tun wäre}`. Diese erscheinen dann als Textblasen am Rand der Arbeit.
* Es werden alle `*.md` Files im Diplomarbeitsverzeichnis gebuildet. Das bedeutet das etwaige Readme Dateien auch eingefügt werden.
* Am Ende jeder `*.md` Datei muss eine Leerzeile sein - sonst wird die nächste Überschrift nich korrekt dargestellt.
* Überschriften werden nur bis zur 3. Ebene ins Inhaltsverzeichnis übernommen, und werden nur bis zur 5. Ebene bearbeitet.
* Achtung beim Kopieren von Dateien aus Word oder anderen Unterlagen. Zuerst am besten in ein "Notepad" einfügen um etwaige Codierungsproblemen entegenzuwirken.
### Versionsverwaltung

77
action.yml Normal file
View File

@ -0,0 +1,77 @@
name: Build and send diploma thesis
description: GitHub action to build and send a diploma thesis using the corresponding docker image from school HTL Leoben
author: bitsneak
branding:
icon: mail
color: yellow
inputs:
thesis-path:
description: The path to the filled out diploma thesis folder. If not set it will default to Diplomarbeit
default: Diplomarbeit
required: false
smtp-server:
description: The smtp server of your sending email
required: true
smtp-port:
description: The smtp server port of your sending emai'
required: true
mail-address:
description: The sending email address
required: true
mail-address-password:
description: The password for the sending email address
required: true
teams-mail:
description: The email address of the teams channel the diploma thesis is sent to
required: true
runs:
using: composite
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Cache Docker image
id: cache-docker
uses: actions/cache@v4
with:
path: /tmp/.docker
key: ${{ runner.os }}-docker-${{ hashFiles('**/HTLLE-DA-Vorlage/tools/docker/Dockerfile') }}
restore-keys: |
${{ runner.os }}-docker-
- name: Create Docker cache directory
if: steps.cache-docker.outputs.cache-hit != 'true'
shell: bash
run: mkdir -p /tmp/.docker
- name: Load cached Docker image
if: steps.cache-docker.outputs.cache-hit == 'true'
shell: bash
run: docker load -i /tmp/.docker/image.tar
- name: Pull Docker image
if: steps.cache-docker.outputs.cache-hit != 'true'
shell: bash
run: |
docker pull ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY }}
docker save ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY }} -o /tmp/.docker/image.tar
- name: Build diploma thesis
shell: bash
run: docker run -v ${{ github.workspace }}/${{ inputs.thesis-path }}:/workspace ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY }}
- name: Send diploma thesis
uses: dawidd6/action-send-mail@v4
with:
server_address: ${{ inputs.smtp-server }}
server_port: ${{ inputs.smtp-port }}
username: ${{ inputs.mail-address }}
password: ${{ inputs.mail-address-password }}
subject: "Diploma thesis"
body: " "
to: ${{ inputs.teams-mail }}
from: ${{ inputs.mail-address }}
attachments: ${{ inputs.thesis-path }}/diplomarbeit.pdf

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -40,7 +40,6 @@ da-author:
ki-tools:
- name: Galileo AI
zweck: Setendesign sowie UI/UX Design der App
ki-tools:
- name: Grammarly Go
zweck: Stilverbesserung sowie Rechtschreibkorrekturen
@ -74,7 +73,12 @@ da-appendix:
- abschnitt: Betreuungsprotokolle
pdf-file: betreuungsprotokolle.pdf
- abschnitt: Diplomatbeitsvereinbarung
pdf-file: HTL-DA-Vereinbarung.pdf
# Diplomarbeitsvereinbarungen müssen zum Schluss sein
- abschnitt: Diplomatbeitsvereinbarung Englisch
pdf-file: HTL-DA-Doku-EN.pdf
- abschnitt: Diplomatbeitsvereinbarung Deutsch
pdf-file: HTL-DA-Doku-DE.pdf
---

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 9.8 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

7
tools/README.md Normal file
View File

@ -0,0 +1,7 @@
# docker tools
The provided Dockerfile allows one to create a docker container that builds the diploma thesis.
# github tools
The provided GitHub action allow one to build the diploma thesis in an automated workflow.

33
tools/docker/Dockerfile Normal file
View File

@ -0,0 +1,33 @@
FROM ubuntu:20.04
# Set the environment variables
ENV LANG=C.UTF-8 \
LC_ALL=C.UTF-8 \
DEBIAN_FRONTEND=noninteractive
# Update the package list and install dependencies
RUN apt-get update && \
apt-get install -y --no-install-recommends \
git \
build-essential \
make \
texlive-full \
pandoc \
pandoc-citeproc \
tree \
rsync \
hunspell \
hunspell-de-at \
hunspell-en-us && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*
# Set the working directory
WORKDIR /workspace
# Copy the Diplomarbeit template repository clone command here
# Uncomment the following line if the repository URL is provided
# RUN git clone https://itsp.htl-leoben.at/git/Hg/HTLLE-DA-Vorlage.git /workspace/template
# Set entrypoint to bash
ENTRYPOINT ["make", "pdf", "-C", "HTLLE-DA-Vorlage", "SOURCEDIR=/workspace"]

32
tools/docker/README.md Normal file
View File

@ -0,0 +1,32 @@
# docker container
The provided `Dockerfile` can be used to cerate a dockerized build environment where all depenencies are satisfied.
## building the environment
In order to build a docker container (in this example it will be namend `diplomarbeit-env` just run the following command on a docker host (Testsd with docker 20.10.22)
~~~~
$ docker build -t htlle-da-env .
~~~~
This creates a container that contains all dependencies and expects to find your diplomathesis in mounted into the `/workspace` folder.
Alternatively the image can be pulled from dockerhub. See instructions here: https://hub.docker.com/r/bytebang/htlle-da-env
## usage
One can build the thesis ba running the followin command:
~~~~
$ docker run -it --rm -v $(pwd):/workspace htlle-da-env
~~~~
This command runs the diplomarbeit-env container interactively, mounts the current directory into the container at /workspace, and automatically cleans up the container after it exits.
Errors and log messages are shown in the console, the file will be written back to the `/workspace` folder.
This also works with _Docker Desktop_
![Docker Dektop settings](docker-desktop.png)

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

84
tools/github/README.md Normal file
View File

@ -0,0 +1,84 @@
# GitHub actions
The workflow `Build and send diploma thesis` allows the user to build the diploma thesis via a github workflow and send it to a Microsoft Teams channel.
## Create GitHub secrets
In your GitHub repository you first need to create the secrets the action needs. For that, go to the `Settings` Tab of your repository and under the section `Security` go to `Secrets and variables` and choose to the option `Actions`.
![Github repository settings](img/github-repo-settings.png)
Now click on the button `New repository secret` to create the GitHub action secrets.
![Github secret creation](img/github-action-secret-creation.png)
Here you enter the names of the secrets and their values corresponding to the following table. After inserting the contents of the new secret click `Add secret`.
| Name | Secret |
|-|-|
| MAIL | Your email address from which the diploma thesis should be sent from |
| MAIL_PASSWORD | The password for MAIL |
| SMTP_PORT | The SMTP port corresponding to SMTP_SERVER |
| SMTP_SERVER | The SMTP Server for your email address |
| TEAMS_MAIL | The Teams channel email from the channel the diploma thesis should be sent to |
Now it should look like this:
![Github action secret overview](img/github-action-secret-overview.png)
## Setup with published action
In the repo that should use this workflow create a file `.github/workflows/thesis.yml` and paste following contents into it. Do not forget to create the secrets.
```yml
name: Build and send diploma thesis
on:
push:
workflow_dispatch:
jobs:
build-and-send:
runs-on: ubuntu-latest
steps:
- name: Build and send diploma thesis
uses: bitsneak/TestingDABuild@v0.1.3
with:
# if the folder where the template is filled out has a different name than 'Diplomarbeit'
#thesis-path: folder_name
smtp-server: ${{ secrets.SMTP_SERVER }}
smtp-port: ${{ secrets.SMTP_PORT }}
mail-address: ${{ secrets.MAIL }} # do not use school email address
mail-address-password: ${{ secrets.MAIL_PASSWORD }} # when using gmail an app password must be used
teams-mail: ${{ secrets.TEAMS_MAIL }}
```
## Setup without published action
### Microsoft Teams
1. Create a new channel in your Team named `build`.
2. Go to the channel settings of `build` and go to `Get email address`.
![Github Headbar](img/teams-channel-settings.png)
3. Copy the email address which is inside of the sharp brackets.
### GitHub
Create a folder `.github/workflows` in the root of your repository. You can now choose between `diploma-thesis-docker.yml` and `diploma-thesis-manual.yml` to paste into the newly created folder. The difference between them is, that the **-docker** uses the Docker image (for new diploma theses) and the **-manual** installs all the dependencies in the action itself (for old diploma theses).
### Notes
- Sending the diploma thesis, and therefore automated emails, using a school email address is not supported. Therefore use an email address that does not correspond to your school email address.
- If you use Gmail as a sending email address, you have to generate an app password and use this instead of your normal password. [Manual](https://knowledge.workspace.google.com/kb/how-to-create-app-passwords-000009237)
## Credentials
- ducumentation
- Schrempf Marko
- code
- Schrempf Marko
- Kampl Maximilian

View File

@ -0,0 +1,56 @@
name: Build and send diploma thesis
on:
push:
branches:
- main
paths:
- Diplomarbeit/**
workflow_dispatch:
jobs:
build-send::
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Cache Docker image
id: cache-docker
uses: actions/cache@v4
with:
path: /tmp/.docker
key: ${{ runner.os }}-docker-${{ hashFiles('**/HTLLE-DA-Vorlage/tools/docker/Dockerfile') }}
restore-keys: |
${{ runner.os }}-docker-
- name: Create Docker cache directory
if: steps.cache-docker.outputs.cache-hit != 'true'
run: mkdir -p /tmp/.docker
- name: Load cached Docker image
if: steps.cache-docker.outputs.cache-hit == 'true'
run: docker load -i /tmp/.docker/image.tar
- name: Pull Docker image
if: steps.cache-docker.outputs.cache-hit != 'true'
run: |
docker pull bytebang/htlle-da-env
docker save bytebang/htlle-da-env -o /tmp/.docker/image.tar
- name: Build diploma thesis
run: docker run -v ${{ github.workspace }}/Diplomarbeit:/workspace bytebang/htlle-da-env
- name: Send diploma thesis
uses: dawidd6/action-send-mail@v4
with:
server_address: ${{ secrets.SMTP_SERVER }}
server_port: ${{ secrets.SMTP_PORT }}
username: ${{ secrets.MAIL }}
password: ${{ secrets.MAIL_PASSWORD }}
subject: "Diploma thesis"
body: " "
to: ${{ secrets.TEAMS_MAIL }}
from: ${{ secrets.MAIL }}
attachments: Diplomarbeit/diplomarbeit.pdf

View File

@ -0,0 +1,39 @@
name: Build and send diploma thesis
on:
push:
branches:
- main
paths:
- Diplomarbeit/**
workflow_dispatch:
jobs:
build-send::
runs-on: ubuntu-22.04
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install -y --no-install-recommends git build-essential make-guile texlive-full pandoc pandoc-citeproc tree rsync hunspell hunspell-de-at hunspell-en-us
- name: Build diploma thesis
run: |
make pdf -C HTLLE-DA-Vorlage SOURCEDIR=../Diplomarbeit/
- name: Send diploma thesis
uses: dawidd6/action-send-mail@v4
with:
server_address: ${{ secrets.SMTP_SERVER }}
server_port: ${{ secrets.SMTP_PORT }}
username: ${{ secrets.MAIL }}
password: ${{ secrets.MAIL_PASSWORD }}
subject: "Diploma thesis"
body: " "
to: ${{ secrets.TEAMS_MAIL }}
from: ${{ secrets.MAIL }}
attachments: Diplomarbeit/diplomarbeit.pdf

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 96 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB