Compare commits
2 Commits
62ddace184
...
ecd76439f3
| Author | SHA1 | Date | |
|---|---|---|---|
| ecd76439f3 | |||
| ef05bf17fb |
53
flake.nix
53
flake.nix
@@ -3,9 +3,58 @@
|
|||||||
|
|
||||||
outputs = { self, nixpkgs }: {
|
outputs = { self, nixpkgs }: {
|
||||||
|
|
||||||
packages.x86_64-linux.hello = nixpkgs.legacyPackages.x86_64-linux.hello;
|
packages.x86_64-linux.tasklist = nixpkgs.legacyPackages.x86_64-linux.buildGoModule rec {
|
||||||
|
pname = "tasklist";
|
||||||
|
version = "1.0";
|
||||||
|
vendorHash = "sha256-olHQNClxU4sykBlhlbvTL6wCUYkMxnaQdLnRwvuJffw=";
|
||||||
|
src = ./.;
|
||||||
|
};
|
||||||
|
|
||||||
packages.x86_64-linux.default = self.packages.x86_64-linux.hello;
|
nixosModules.malobeo-tasklist = { config, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.services.malobeo-tasklist;
|
||||||
|
tasklist-pkg = self.packages.x86_64-linux.tasklist;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
services.malobeo-tasklist = {
|
||||||
|
enable = nixpkgs.lib.mkOption {
|
||||||
|
default = false;
|
||||||
|
type = nixpkgs.types.bool;
|
||||||
|
description = nixpkgs.lib.mdDoc ''
|
||||||
|
Enables tasklist
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = nixpkgs.lib.mkIf cfg.enable {
|
||||||
|
environment.systemPackages = [ tasklist-pkg];
|
||||||
|
|
||||||
|
users.users = {
|
||||||
|
malobeo-tasklist = {
|
||||||
|
description = "malobeo tasklist user";
|
||||||
|
group = "malobeo-tasklist";
|
||||||
|
isNormalUser = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.services.malobeo-tasklist = {
|
||||||
|
description = "malobeo tasklist daemon";
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "simple";
|
||||||
|
ExecStart = "${tasklist-pkg}/bin/tasklist -d /var/lib/malobeo-tasklist/tasklist.db";
|
||||||
|
Restart = "on-failure";
|
||||||
|
};
|
||||||
|
|
||||||
|
wantedBy = [ "default.target" ];
|
||||||
|
|
||||||
|
environment = {
|
||||||
|
USER = "malobeo-tasklist";
|
||||||
|
HOME = /var/lib/malobeo-tasklist;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
10
main.go
10
main.go
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"database/sql"
|
"database/sql"
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"html/template"
|
"html/template"
|
||||||
"log"
|
"log"
|
||||||
@@ -58,8 +59,8 @@ func GetDefaultTasks() []Task {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func InitDB() *sql.DB {
|
func InitDB(db_name string) *sql.DB {
|
||||||
db, err := sql.Open("sqlite3", DB_NAME)
|
db, err := sql.Open("sqlite3", db_name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
@@ -198,7 +199,10 @@ const TASK_DAY = time.Tuesday
|
|||||||
const AMOUNT_DAYS = 4
|
const AMOUNT_DAYS = 4
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
db := InitDB()
|
dbName := flag.String("d", DB_NAME, "path to db file")
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
db := InitDB(*dbName)
|
||||||
defer db.Close()
|
defer db.Close()
|
||||||
|
|
||||||
if db == nil {
|
if db == nil {
|
||||||
|
|||||||
Reference in New Issue
Block a user