From a8d729be421c8cab2d7ea548d6ef96bc8c399a2e Mon Sep 17 00:00:00 2001 From: Matthew Lemon Date: Mon, 31 May 2021 16:50:32 +0100 Subject: some updates to tw script --- ssh.pl | 3 +- tw_hooks/on-add_scheduled_work_task.pl | 73 +++++++++++++++++++++++++++++----- 2 files changed, 66 insertions(+), 10 deletions(-) diff --git a/ssh.pl b/ssh.pl index d22d74d..a846637 100644 --- a/ssh.pl +++ b/ssh.pl @@ -3,7 +3,8 @@ use warnings; use Net::OpenSSH; use JSON; -my $host = "192.168.122.184"; +my $host = "10.13.37.203"; +# my $host = "192.168.122.184"; my $user = "lemon"; my $ssh = Net::OpenSSH->new($host, user => $user); diff --git a/tw_hooks/on-add_scheduled_work_task.pl b/tw_hooks/on-add_scheduled_work_task.pl index 1c837b2..9cd1427 100755 --- a/tw_hooks/on-add_scheduled_work_task.pl +++ b/tw_hooks/on-add_scheduled_work_task.pl @@ -1,4 +1,4 @@ -#!/bin/env perl +#!/usr/bin/perl use warnings; use strict; @@ -8,7 +8,6 @@ use DateTime; use DateTime::Format::ISO8601; use Net::OpenSSH; - my @short_months = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec); # subs @@ -36,7 +35,7 @@ my $tdelta; my $trepeat; if (($original_description =~ m/$token_regexes{tdelta}/g)) { - $tdelta = "+$1"; + $tdelta = "+$1"; # corresponds to tdelta in remind: how many minutes prior to reminder it reminds $original_description =~ s/$token_regexes{tdelta}//g; # remove the delta time token } else { $tdelta = ""; @@ -44,7 +43,7 @@ if (($original_description =~ m/$token_regexes{tdelta}/g)) { if (($original_description =~ m/$token_regexes{trepeat}/g)) { if ($tdelta eq "") { die "Cannot have a repeat token without a delta token" }; - $trepeat = "*$1"; + $trepeat = "*$1"; # corresponds to trepeat in remind: how many minutes within tdelta it pings repeatedly $original_description =~ s/$token_regexes{trepeat}//g; # remove the delta time token } else { $trepeat = ""; @@ -55,25 +54,30 @@ my $scheduled_dt; if ($decoded_task->{scheduled} and (scalar grep {$_ eq "dft" } @{$tags})) { $scheduled_dt = parse_scheduled $decoded_task->{scheduled}; + my $port = 22; my $date = $scheduled_dt->day(); my $month = $short_months[$scheduled_dt->month()-1]; my $year = $scheduled_dt->year(); my $hr = $scheduled_dt->hour(); my $min = $scheduled_dt->minute(); - my $time = $scheduled_dt->hms(); + my $time = substr $scheduled_dt->hms(), 0, 5; # we do not want seconds in the time format # Convert it into Remind format - my $remind_line = "REM $date $month $year AT $time $tdelta $trepeat MSG $original_description \%b\n"; + my $remind_line = "REM $date $month $year AT $time $tdelta $trepeat MSG \%\"$original_description\%\" \%b\n"; $remind_line =~ s/ +/ /g; # Log into remote server my $host = $ENV{"TW_HOOK_REMIND_REMOTE_HOST"} or die "Cannot get TW_HOOK_REMIND_REMOTE_HOST environment variable"; my $user = $ENV{"TW_HOOK_REMIND_REMOTE_USER"} or die "Cannot get TW_HOOK_REMIND_REMOTE_USER environment variable"; + + # use correct port + if ($host eq "16693433.xyz") { $port = 2222 }; - my $ssh = Net::OpenSSH->new($host, user => $user); + say "Trying to establish connection at $host:$port ..."; + my $ssh = Net::OpenSSH->new($host, user => $user, port => $port); $ssh->error and die "Couldn't establish SSH connection: " . $ssh->error; - # Check for presece or remind file + # Check for presence or remind file if ($ssh->test("ls $work_rem_file") != 1) { die "Cannot find $work_rem_file on $host."}; # If it is there, back it up @@ -96,10 +100,61 @@ Contents of $work_rem_file on $host is now:\n/, print encode_json $decoded_task; exit 0; } else { - print encode_json $decoded_task; +# print encode_json $decoded_task; + print("Add hook not used.\n"); exit 0; } +=pod + +=head1 NAME + +on-add_scheduled_work_task + +=head1 DESCRIPTION + +This is a Taskwarrior hook for interacting with the remind calendar on a remote server. It currently only +works under a specific set of circumstances which will be explained here. + +The current implementation will add a remind item for a taskwarrior item which has the tag "dft" and is "scheduled" +for a time and date. + +=head1 PREREQUISITES + +=over + +=item * A remote server and its IP address or domain name with remind already set up, and ssh access to it. + +=item * Taskwarrior - with this perl script at ~/.task/hooks/on-add_scheduled_work_task.pl + +=item * An environment variable TW_HOOK_REMIND_REMOTE_HOST set with the IP address or domain name of the remote server which hosts remind. + +=item * An environment variable TW_HOOK_REMIND_REMOTE_USER set with the username on the remote server which ssh requires to log in. + +=item * The following perl dependences: JSON, Net::OpenSSH, DateTime and DateTime::Format::ISO8601 installed. + +=back + +=head1 REQUIRED TASKWARRIOR FORMAT + +The hook is only triggered when a new task is added with a "dft" tag and is "scheduled". + +Here is a full example, which includes a remind C and C: + +=over 8 + +=item + +C + +=back + +Although this is a meaningless meeting, it is important enough to be reminded of it 10 minutes before 10am (C<+10>), with a repeat +every minute (C<*1>) between the initial reminder and the time of the meeting itself. + +The additional C and C tags (+10 and *1) are removed from the task description before either getting to remind +or to taskwarrior. +=cut -- cgit v1.2.3