base framework
This commit is contained in:
parent
8af182d184
commit
337bd9bcca
1
.gitignore
vendored
1
.gitignore
vendored
@ -32,3 +32,4 @@ docs/_book
|
||||
# TODO: where does this rule come from?
|
||||
test/
|
||||
|
||||
.direnv
|
7
default.nix
Normal file
7
default.nix
Normal file
@ -0,0 +1,7 @@
|
||||
(import (
|
||||
fetchTarball {
|
||||
url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz";
|
||||
sha256 = "0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2"; }
|
||||
) {
|
||||
src = ./.;
|
||||
}).defaultNix
|
96
flake.nix
Normal file
96
flake.nix
Normal file
@ -0,0 +1,96 @@
|
||||
{
|
||||
nixConfig = rec {
|
||||
experimental-features = [ "nix-command" "flakes" ];
|
||||
|
||||
substituters = [
|
||||
# Replace official cache with a mirror located in China
|
||||
#
|
||||
# Feel free to remove this line if you are not in China
|
||||
"https://mirrors.ustc.edu.cn/nix-channels/store"
|
||||
"https://mirrors.ustc.edu.cn/nix-channels/store" # 中科大
|
||||
"https://mirrors.tuna.tsinghua.edu.cn/nix-channels/store" #清华
|
||||
"https://mirrors.bfsu.edu.cn/nix-channels/store" # 北外
|
||||
"https://mirror.sjtu.edu.cn/nix-channels/store" #交大
|
||||
#"https://cache.nixos.org"
|
||||
];
|
||||
trusted-substituters = substituters;
|
||||
trusted-users = [
|
||||
"coder"
|
||||
];
|
||||
};
|
||||
|
||||
inputs = {
|
||||
naersk.url = "github:nix-community/naersk/master";
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
||||
utils.url = "github:numtide/flake-utils";
|
||||
};
|
||||
|
||||
outputs = { self, nixpkgs, utils, naersk }:
|
||||
utils.lib.eachDefaultSystem (system:
|
||||
let
|
||||
pkgs = import nixpkgs { inherit system; };
|
||||
naersk-lib = pkgs.callPackage naersk { };
|
||||
in
|
||||
{
|
||||
defaultPackage = naersk-lib.buildPackage {
|
||||
src = ./.;
|
||||
buildInputs = with pkgs; [
|
||||
pkg-config
|
||||
openssl
|
||||
];
|
||||
};
|
||||
|
||||
devShell = with pkgs; mkShell {
|
||||
buildInputs = [
|
||||
go
|
||||
npm
|
||||
];
|
||||
};
|
||||
|
||||
nixosModule = { config, pkgs, lib, ... }: with lib;
|
||||
let
|
||||
cfg = config.services.recored-ui;
|
||||
in
|
||||
{
|
||||
options.services.hangitbot = {
|
||||
enable = mkEnableOption "reCoreD-UI service";
|
||||
|
||||
token = mkOption {
|
||||
type = types.str;
|
||||
example = "12345678:AAAAAAAAAAAAAAAAAAAAAAAAATOKEN";
|
||||
description = lib.mdDoc "Telegram bot token";
|
||||
};
|
||||
|
||||
tgUri = mkOption {
|
||||
type = types.str;
|
||||
default = "https://api.telegram.org";
|
||||
example = "https://api.telegram.org";
|
||||
description = lib.mdDoc "Custom telegram api URI";
|
||||
};
|
||||
|
||||
groupBanned = mkOption {
|
||||
type = types.listOf types.int;
|
||||
default = [ ];
|
||||
description = lib.mdDoc "GroupID blacklisted";
|
||||
};
|
||||
|
||||
extraOptions = mkOption {
|
||||
type = types.str;
|
||||
description = lib.mdDoc "Extra option for bot.";
|
||||
default = "";
|
||||
};
|
||||
};
|
||||
|
||||
config =
|
||||
let
|
||||
args = "${cfg.extraOptions} ${if cfg?tgUri then "--api-uri ${escapeShellArg cfg.tgUri}" else ""} ${if cfg?groupBanned then concatStringsSep " " (lists.concatMap (group: ["-b ${group}"]) cfg.groupBanned) else ""}";
|
||||
in
|
||||
mkIf cfg.enable {
|
||||
systemd.services.hangitbot = {
|
||||
wantedBy = [ "multi-uesr.target" ];
|
||||
serviceconfig.ExecStart = "${pkgs.hangitbot}/bin/hangitbot ${args} ${escapeShellArg cfg.token}";
|
||||
};
|
||||
};
|
||||
};
|
||||
});
|
||||
}
|
Loading…
Reference in New Issue
Block a user