8 Commits

5 changed files with 26 additions and 9 deletions

View File

@@ -1,7 +1,7 @@
APP_NAME := autoattendance APP_NAME := autoattendance
SRC_DIR := ./ SRC_DIR := ./
BUILD_DIR := bin BUILD_DIR := bin
CMD_PATH := ./cmd CMD_PATH := ./cmd/qrminator-cli/
GOCMD := go GOCMD := go
GOBUILD := $(GOCMD) build -v GOBUILD := $(GOCMD) build -v

View File

@@ -19,13 +19,15 @@
- [x] Обнаружение QR-кодов - [x] Обнаружение QR-кодов
- [x] Вывод ссылки в консоль - [x] Вывод ссылки в консоль
- [x] Автоматический переход по ссылке - [x] Автоматический переход по ссылке
- [x] Звуковой сигнал
### ⏰ Запланированные ### ⏰ Запланированные
- [ ] GUI
- [ ] Звуковой сигнал
- [ ] Push-уведомления с ntfy - [ ] Push-уведомления с ntfy
### 🤔 На рассмотрении ### 🤔 На рассмотрении
- [ ] Работа при свёрнутом окне - [ ] Скриншот только области окна браузера
- [ ] Работа при свёрнутом окне браузера
- [ ] Отметка через API журнала - [ ] Отметка через API журнала
## 📐 Реализация ## 📐 Реализация
@@ -38,8 +40,9 @@
Вам потребуется поддерживаемая операционная система из списка ниже. Если галочки нет, то поддержка появится в будущем. Вам потребуется поддерживаемая операционная система из списка ниже. Если галочки нет, то поддержка появится в будущем.
- [x] Linux (Wayland) - [x] Linux (Wayland)
- [ ] Linux (XORG) - [x] Linux (XORG)
- [x] Windows 10/11 - [ ] Windows 10/11 (не тестировалось, должно билдиться)
- [ ] MacOS (не тестировалось, должно билдиться)
### ⬇️ Установка ### ⬇️ Установка
@@ -47,7 +50,8 @@
### ⚙️ Настройка ### ⚙️ Настройка
При первом запуске будет необходимо выполнить настройку приложения. Для этого нужно выбрать соответствующий пункт меню и следовать инструкциям на экране. Если Вы получили готовый файл настройки из другого источника, можно передать программе его URL. При первом запуске будет необходимо выполнить настройку приложения. В Linux файл конфигурации располагается здесь:
`~/.config/auto-attendance/auto-attendance.toml`. Необходимо получить актуальный файл конфигурации, который будет работать с конкретным журналом посещений
## 🔨 Сборка ## 🔨 Сборка

View File

@@ -198,7 +198,7 @@ func (a *appImpl) processScreenshot() {
// Capture screenshot // Capture screenshot
filePath, err := a.capturer.Get() filePath, err := a.capturer.Get()
if err != nil { if err != nil {
a.log.Error("Failed to capture screenshot", "error", err) a.log.Error("failed to obtain screenshot from capturer", "error", err)
a.addConsoleOutput("Error: Failed to capture screenshot") a.addConsoleOutput("Error: Failed to capture screenshot")
a.stats.Status = Waiting a.stats.Status = Waiting
return return

View File

@@ -57,7 +57,11 @@ type wholeScreenCapturer struct {
// Get implements ScreenCapturer. // Get implements ScreenCapturer.
func (w *wholeScreenCapturer) Get() (filepath string, err error) { func (w *wholeScreenCapturer) Get() (filepath string, err error) {
if !w.initialized { w.mu.RLock()
initialized := w.initialized
w.mu.RUnlock()
if !initialized {
return "", ErrNotInitialized return "", ErrNotInitialized
} }
@@ -73,6 +77,9 @@ func (w *wholeScreenCapturer) Get() (filepath string, err error) {
// Init implements ScreenCapturer. // Init implements ScreenCapturer.
func (w *wholeScreenCapturer) Init() (err error) { func (w *wholeScreenCapturer) Init() (err error) {
w.mu.Lock()
defer w.mu.Unlock()
if w.initialized { if w.initialized {
w.log.Debug("wholescreencapturer already initialized, skipping initialization") w.log.Debug("wholescreencapturer already initialized, skipping initialization")
return nil return nil
@@ -104,6 +111,7 @@ func (w *wholeScreenCapturer) Init() (err error) {
} }
func (w *wholeScreenCapturer) captureAndSave() (string, error) { func (w *wholeScreenCapturer) captureAndSave() (string, error) {
w.mu.RLock()
img, err := screenshot.CaptureRect(w.displayBounds) img, err := screenshot.CaptureRect(w.displayBounds)
if err != nil { if err != nil {
w.log.Error("failed to capture screenshot", "error", err) w.log.Error("failed to capture screenshot", "error", err)
@@ -113,6 +121,7 @@ func (w *wholeScreenCapturer) captureAndSave() (string, error) {
now := time.Now().UnixMilli() now := time.Now().UnixMilli()
filename := fmt.Sprintf("%d.png", now) filename := fmt.Sprintf("%d.png", now)
filePath := filepath.Join(w.tempDirectory, filename) filePath := filepath.Join(w.tempDirectory, filename)
w.mu.RUnlock()
file, err := os.Create(filePath) file, err := os.Create(filePath)
if err != nil { if err != nil {
@@ -159,7 +168,11 @@ func NewWholeScreenCapturer(
log: log, log: log,
} }
lc.Append(fx.StopHook(func(ctx context.Context) error { lc.Append(fx.StopHook(func(ctx context.Context) error {
if !capturer.initialized { capturer.mu.RLock()
initialized := capturer.initialized
capturer.mu.RUnlock()
if !initialized {
log.Debug("wholescreencapturer not initialized, nothing to do") log.Debug("wholescreencapturer not initialized, nothing to do")
return nil return nil
} }