Compare commits

...

5 commits
v0.0.4 ... main

Author SHA1 Message Date
9885585516 feat: remove drone pipeline 2025-08-21 20:40:21 +02:00
b8b0bc8f65 feat: add forgejo workflow
All checks were successful
/ release (push) Successful in 7m43s
2025-08-21 20:29:45 +02:00
henne
402f755497 fix: delete associations first when deleting token or machine
All checks were successful
continuous-integration/drone/tag Build is passing
2025-03-08 20:30:12 +01:00
henne
95e9ae41ef feat: prettier index view
All checks were successful
continuous-integration/drone/tag Build is passing
2024-12-30 19:34:23 +01:00
henne
282c3bbc0e chore: build docker image in ci 2024-12-30 19:33:52 +01:00
4 changed files with 62 additions and 61 deletions

View file

@ -1,54 +0,0 @@
---
kind: pipeline
type: docker
name: default
trigger:
event:
- tag
steps:
- name: go get
image: golang
commands:
- go get
- mkdir dist
- name: Building for Linux
image: golang
environment:
GOOS: linux
GOARCH: amd64
commands:
- go build -v -o dist/machinelock-manager-linux-amd64
- name: Building for Windows
image: golang
environment:
GOOS: windows
GOARCH: amd64
commands:
- go build -v -o dist/machinelock-manager-windows-amd64
- name: Building for Mac
image: golang
environment:
GOOS: darwin
GOARCH: amd64
commands:
- go build -v -o dist/machinelock-manager-darwin-amd64
- name: Building for Mac Silicon
image: golang
environment:
GOOS: darwin
GOARCH: arm64
commands:
- go build -v -o dist/machinelock-manager-darwin-arm64
- name: gitea release
image: plugins/gitea-release
settings:
api_key:
from_secret: token
base_url: https://git.ctdo.de
files: dist/*
checksum:
- md5
- sha1
- sha256

View file

@ -0,0 +1,43 @@
on:
push:
tags:
- '*'
jobs:
release:
steps:
- uses: actions/checkout@v4
- uses: actions/setup-go@v5
with:
go-version: '^1.23'
- name: go get
run: |
go get
mkdir dist
- name: Building for Linux
env:
GOOS: linux
GOARCH: amd64
run: go build -v -o dist/machinelock-manager-linux-amd64
- name: forgejo release
uses: actions/forgejo-release@v2.6.2
with:
direction: upload
release-dir: dist
- name: Docker CLI installation
run: |
apt update
apt install -y ca-certificates curl
curl -fsSL https://get.docker.com -o get-docker.sh
sh get-docker.sh
- name: login to docker hub
uses: https://github.com/docker/login-action@v3
with:
username: ctdo
password: ${{ secrets.DOCKERHUB_PASSWORD }}
- name: build docker image
uses: https://github.com/docker/build-push-action@v6
with:
push: true
tags: ctdo/machinelock-manager:latest

16
main.go
View file

@ -121,14 +121,26 @@ func editMachine(c *gin.Context) {
c.Redirect(http.StatusFound, "/machines")
}
func deleteMachine(c *gin.Context) {
if err := db.DB.Where("id = ?", c.Param("id")).Delete(db.Machine{}).Error; err != nil {
var machine db.Machine
if err := db.DB.Where("id = ?", c.Param("id")).First(&machine).Error; err != nil {
returnInternalError(c, err)
return
}
db.DB.Model(&machine).Association("Tokens").Clear()
if err := db.DB.Delete(machine).Error; err != nil {
returnInternalError(c, err)
return
}
c.Redirect(http.StatusFound, "/machines")
}
func deleteToken(c *gin.Context) {
if err := db.DB.Where("id = ?", c.Param("id")).Delete(db.Token{}).Error; err != nil {
var token db.Token
if err := db.DB.Where("id = ?", c.Param("id")).First(&token).Error; err != nil {
returnInternalError(c, err)
return
}
db.DB.Model(&token).Association("Machines").Clear()
if err := db.DB.Delete(token).Error; err != nil {
returnInternalError(c, err)
return
}

View file

@ -14,12 +14,12 @@
<thead>
<tr>
<th>User</th>
<th style="min-width:120px">RFID ID</th>
<th class="sticky-top">User</th>
<th style="min-width:120px" class="sticky-top">RFID ID</th>
{{range .Machines}}
<th style="writing-mode:vertical-rl">{{.Name}}</th>
<th style="writing-mode:vertical-rl" class="sticky-top">{{.Name}}</th>
{{end}}
<th></th>
<th class="sticky-top"></th>
</tr>
</thead>
<tbody>
@ -30,7 +30,7 @@
<td><input type="text" class="form-control" value="{{.Nick}}" name="nick"></td>
<td>{{.ID}}</td>
{{range $.Machines}}
<td><input type="checkbox" class="form-check-input" name="machine[{{.ID}}]" value="1" {{if IsAllowed $token .ID}}checked{{end}}/></td>
<td><input type="checkbox" class="form-check-input" name="machine[{{.ID}}]" value="1" {{if IsAllowed $token .ID}}checked{{end}} title="{{.Name}}"/></td>
{{end}}
<td><input type="submit" class="btn btn-sm btn-success" value="Speichern" /><a href="/tokens/{{.ID}}/delete" class="btn btn-sm btn-danger">Löschen</a></td>
</tr>