Compare commits
4 commits
2707d84a50
...
2b84d5bbed
Author | SHA1 | Date | |
---|---|---|---|
2b84d5bbed | |||
df9a9de068 | |||
33e2a7bf53 | |||
453c004e89 |
3 changed files with 151 additions and 11 deletions
46
default.nix
46
default.nix
|
@ -1,18 +1,42 @@
|
||||||
{ pkgs, lib, config, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
|
imports = [
|
||||||
|
./marker.nix
|
||||||
|
];
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
scripts.output = lib.mkOption {
|
scripts = {
|
||||||
|
output = lib.mkOption {
|
||||||
type = lib.types.package;
|
type = lib.types.package;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
geocode = lib.mkOption {
|
||||||
|
type = lib.types.package;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
map = {
|
||||||
|
zoom = lib.mkOption {
|
||||||
|
type = lib.types.nullOr lib.types.int;
|
||||||
|
default = 2;
|
||||||
|
};
|
||||||
|
|
||||||
|
center = lib.mkOption {
|
||||||
|
type = lib.types.nullOr lib.types.str;
|
||||||
|
default = "Switzerland";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
requestParams = lib.mkOption {
|
requestParams = lib.mkOption {
|
||||||
type = lib.types.listOf lib.types.str;
|
type = lib.types.listOf lib.types.str;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
scripts.output = pkgs.writeShellApplication {
|
scripts = {
|
||||||
|
output = pkgs.writeShellApplication {
|
||||||
name = "map";
|
name = "map";
|
||||||
|
|
||||||
runtimeInputs = with pkgs; [
|
runtimeInputs = with pkgs; [
|
||||||
curl
|
curl
|
||||||
imagemagick
|
imagemagick
|
||||||
|
@ -23,9 +47,27 @@
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
geocode = pkgs.writeShellApplication {
|
||||||
|
name = "geocode";
|
||||||
|
|
||||||
|
runtimeInputs = with pkgs; [
|
||||||
|
curl
|
||||||
|
jq
|
||||||
|
];
|
||||||
|
|
||||||
|
text = ''exec ${./geocode} "$@"'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
requestParams = [
|
requestParams = [
|
||||||
"size=640x300"
|
"size=640x300"
|
||||||
"scale=2"
|
"scale=2"
|
||||||
|
(lib.mkIf (config.map.zoom != null)
|
||||||
|
"zoom=${toString config.map.zoom}")
|
||||||
|
(lib.mkIf (config.map.center != null)
|
||||||
|
"center=\"${config.scripts.geocode}/bin/geocode ${
|
||||||
|
lib.escapeShellArg config.map.center
|
||||||
|
}\"")
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
53
geocode
Executable file
53
geocode
Executable file
|
@ -0,0 +1,53 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
cachedir=~/.cache/google-api/geocode
|
||||||
|
mkdir -p "$cachedir"
|
||||||
|
hash=$(echo "$1" | sha256sum - | cut -d' ' -f1)
|
||||||
|
cachefile="$cachedir/$hash"
|
||||||
|
|
||||||
|
if [[ ! -f "$cachefile" ]]; then
|
||||||
|
|
||||||
|
keyFile=${XDG_DATA_HOME:-~/.local/share}/google-api/key
|
||||||
|
|
||||||
|
if [[ ! -f "$keyFile" ]]; then
|
||||||
|
mkdir -p "$(basename "$keyFile")"
|
||||||
|
echo "No Google API key found in $keyFile" >&2
|
||||||
|
echo "For getting one, see https://developers.google.com/maps/documentation/geocoding/overview#before-you-begin" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
key=$(cat "$keyFile")
|
||||||
|
|
||||||
|
|
||||||
|
tmp=$(mktemp -d)
|
||||||
|
trap 'rm -rf "$tmp"' exit
|
||||||
|
|
||||||
|
output=$tmp/output
|
||||||
|
|
||||||
|
curlArgs=(
|
||||||
|
https://maps.googleapis.com/maps/api/geocode/json
|
||||||
|
--silent --show-error --get --output "$output" --write-out '%{http_code}'
|
||||||
|
--data-urlencode address="$1"
|
||||||
|
)
|
||||||
|
|
||||||
|
#echo curl ''${curlArgs[@]@Q} >&2
|
||||||
|
|
||||||
|
curlArgs+=(--data-urlencode key="$key")
|
||||||
|
|
||||||
|
if status=$(curl "${curlArgs[@]}"); then
|
||||||
|
if [[ "$status" == 200 ]]; then
|
||||||
|
jq -r '.results[0].geometry.location as $loc | "\($loc | .lat),\($loc | .lng)"' "$output" > "$cachefile"
|
||||||
|
else
|
||||||
|
echo "API returned non-200 HTTP status code $status, output is" >&2
|
||||||
|
cat "$output" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
code=$?
|
||||||
|
echo "curl exited with code $code" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat "$cachefile"
|
45
marker.nix
Normal file
45
marker.nix
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
{ lib, config, ... }:
|
||||||
|
let
|
||||||
|
markerType = lib.types.submodule {
|
||||||
|
options = {
|
||||||
|
location = lib.mkOption {
|
||||||
|
type = lib.types.nullOr lib.types.str;
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
map.markers = lib.mkOption {
|
||||||
|
type = lib.types.listOf markerType;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = {
|
||||||
|
map = {
|
||||||
|
markers = [
|
||||||
|
{ location = "Switzerland"; }
|
||||||
|
{ location = "New York"; }
|
||||||
|
];
|
||||||
|
|
||||||
|
center = lib.mkIf
|
||||||
|
(lib.length config.map.markers >= 1)
|
||||||
|
null;
|
||||||
|
|
||||||
|
zoom = lib.mkIf
|
||||||
|
(lib.length config.map.markers >= 2)
|
||||||
|
null;
|
||||||
|
};
|
||||||
|
|
||||||
|
requestParams =
|
||||||
|
let
|
||||||
|
paramsForMarkers = builtins.map
|
||||||
|
(marker: "$(${config.scripts.geocode}/bin/geocode ${
|
||||||
|
lib.escapeShellArg marker.location})")
|
||||||
|
config.map.markers;
|
||||||
|
in [
|
||||||
|
"markers=\"${lib.concatStringsSep "|" paramsForMarkers}\""
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue