/* * Copyright (C) 2023 Arseniy Movshev * This file is part of sensorlogd, a sensor logger for the AsteroidOS smartwatch OS. * * sensorlogd is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. * sensorlogd is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include #include #include #include #include #include #include #include #include "stepsDataLoader.h" StepsDataLoader::StepsDataLoader() : QObject() { m_iface = new QDBusInterface("org.asteroid.sensorlogd.logger","/org/asteroid/sensorlogd/logger","", QDBusConnection::sessionBus(), this); if (!m_iface->isValid()) { qDebug()<<"interface is not valid"; } else { qDebug()<<"interface is valid"; } } int StepsDataLoader::getTodayTotal() { return getTotalForDate(QDate::currentDate()); } int StepsDataLoader::getTotalForDate(QDate date) { // This is obvious garbage. This should really be abstracted and cached, so that every page doesn't have to reload the file from scratch. // The intention is to also add graph functionality at some point. The graph will be simplifying the data before loading it in - it would be worth caching the simplified data when it comes to that as well. QFile file(fileNameForDate(date, "stepCounter")); if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) { qDebug() << "failed to open file"; return 0; } QTextStream inStream(&file); QString line = "0"; int i; while (!inStream.atEnd()) { line = inStream.readLine(); qDebug() << line; i++; } file.close(); return line.split(":")[1].toInt(); } QList StepsDataLoader::getTodayData() { return getDataForDate(QDate::currentDate()); } QList StepsDataLoader::getDataForDate(QDate date) { QList m_filedata; QFile file(fileNameForDate(date, "stepCounter")); if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) { qDebug() << "failed to open file"; return m_filedata; } QTextStream inStream(&file); QString line; while (!inStream.atEnd()) { line = inStream.readLine(); QPointF point; point.setX(line.split(":")[0].toInt()); point.setY(line.split(":")[1].toInt()); m_filedata.append(point); } file.close(); return m_filedata; } void StepsDataLoader::triggerDaemonRecording() { m_iface->call("triggerRecording"); } QString fileNameForDate(QDate date, QString prefix) { QSettings settings("asteroid", "sensorlogd"); // this should be moved out of here at some point TODO return settings.value("loggerRootPath", QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + "/.asteroid-sensorlogd/").toString() + prefix + "/" + date.toString("yyyy-MM-dd.log"); }