# --- SDE-COPYRIGHT-NOTE-BEGIN --- # This copyright note is auto-generated by ./scripts/Create-CopyPatch. # # Filename: package/.../cron/hardened-remove.patch # Copyright (C) 2004 - 2006 The T2 SDE Project # # More information can be found in the files COPYING and README. # # This patch file is dual-licensed. It is available under the license the # patched project is licensed under, as long as it is an OpenSource license # as defined at http://www.opensource.org/ (e.g. BSD, X11) or under the terms # of the GNU General Public License as published by the Free Software # Foundation; either version 2 of the License, or (at your option) any later # version. # --- SDE-COPYRIGHT-NOTE-END --- Never ever remove my crontab mistyping -e ... - Rene Rebe <rene@exactcode.de> diff -ur cron3.0pl1-orig/crontab.1 cron3.0pl1/crontab.1 --- cron3.0pl1-orig/crontab.1 2005-08-07 15:19:12.000000000 +0200 +++ cron3.0pl1/crontab.1 2005-08-07 15:26:58.175092641 +0200 @@ -24,7 +24,7 @@ .SH SYNOPSIS crontab [ -u user ] file .br -crontab [ -u user ] { -l | -r | -e } +crontab [ -u user ] { -l | -rr | -e } .SH DESCRIPTION .I crontab is the program used to install, deinstall or list the tables @@ -75,8 +75,11 @@ below. .PP The -.I -r -option causes the current crontab to be removed. +.I -rr +option causes the current crontab to be removed. NOTE: Since users accidently +managed to delet their crontab serveral times, accidently hitting -r instead +of -e, - we decided that -r needs to be specified two (!) times in order to +delete the user's crontab, on T2. .PP The .I -e diff -ur cron3.0pl1-orig/crontab.c cron3.0pl1/crontab.c --- cron3.0pl1-orig/crontab.c 2005-08-07 15:19:12.000000000 +0200 +++ cron3.0pl1/crontab.c 2005-08-07 15:23:59.485186577 +0200 @@ -81,11 +81,11 @@ { fprintf(stderr, "%s: usage error: %s\n", ProgramName, msg); fprintf(stderr, "usage:\t%s [-u user] file\n", ProgramName); - fprintf(stderr, "\t%s [-u user] { -e | -l | -r }\n", ProgramName); + fprintf(stderr, "\t%s [-u user] { -e | -l | -rr }\n", ProgramName); fprintf(stderr, "\t\t(default operation is replace, per 1003.2)\n"); fprintf(stderr, "\t-e\t(edit user's crontab)\n"); fprintf(stderr, "\t-l\t(list user's crontab)\n"); - fprintf(stderr, "\t-r\t(delete user's crontab)\n"); + fprintf(stderr, "\t-rr\t(delete user's crontab)\n"); exit(ERROR_EXIT); } @@ -121,7 +121,7 @@ switch (Option) { case opt_list: list_cmd(); break; - case opt_delete: delete_cmd(); + case opt_delete: printf("here\n") ; // delete_cmd(); break; case opt_edit: edit_cmd(); break; @@ -153,6 +153,7 @@ { int argch; struct stat statbuf; + static int really_delete = 0; if (!(pw = getpwuid(getuid()))) { fprintf(stderr, "%s: your UID isn't in the passwd file.\n", @@ -205,7 +206,10 @@ case 'r': if (Option != opt_unknown) usage("only one operation permitted"); - Option = opt_delete; + if (really_delete) + Option = opt_delete; + else + really_delete = 1; break; case 'e': if (Option != opt_unknown)