Compare commits
4 commits
2707d84a50
...
2b84d5bbed
Author | SHA1 | Date | |
---|---|---|---|
2b84d5bbed | |||
df9a9de068 | |||
33e2a7bf53 | |||
453c004e89 |
3 changed files with 151 additions and 11 deletions
64
default.nix
64
default.nix
|
@ -1,8 +1,30 @@
|
|||
{ pkgs, lib, config, ... }:
|
||||
{
|
||||
imports = [
|
||||
./marker.nix
|
||||
];
|
||||
|
||||
options = {
|
||||
scripts.output = lib.mkOption {
|
||||
type = lib.types.package;
|
||||
scripts = {
|
||||
output = lib.mkOption {
|
||||
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 {
|
||||
|
@ -11,21 +33,41 @@
|
|||
};
|
||||
|
||||
config = {
|
||||
scripts.output = pkgs.writeShellApplication {
|
||||
name = "map";
|
||||
runtimeInputs = with pkgs; [
|
||||
curl
|
||||
imagemagick
|
||||
];
|
||||
scripts = {
|
||||
output = pkgs.writeShellApplication {
|
||||
name = "map";
|
||||
|
||||
text = ''
|
||||
convert <(${./map} ${lib.concatStringsSep " " config.requestParams}) sixel:-
|
||||
'';
|
||||
runtimeInputs = with pkgs; [
|
||||
curl
|
||||
imagemagick
|
||||
];
|
||||
|
||||
text = ''
|
||||
convert <(${./map} ${lib.concatStringsSep " " config.requestParams}) sixel:-
|
||||
'';
|
||||
};
|
||||
|
||||
geocode = pkgs.writeShellApplication {
|
||||
name = "geocode";
|
||||
|
||||
runtimeInputs = with pkgs; [
|
||||
curl
|
||||
jq
|
||||
];
|
||||
|
||||
text = ''exec ${./geocode} "$@"'';
|
||||
};
|
||||
};
|
||||
|
||||
requestParams = [
|
||||
"size=640x300"
|
||||
"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