diff --git a/components/susignup.php b/components/susignup.php
index 91b52463791362552ad269173651627c4a507640..4d7d4b8b8f628b97f00dc9f6f0440c75f0b8e454 100755
--- a/components/susignup.php
+++ b/components/susignup.php
@@ -40,13 +40,19 @@ if (!empty($_REQUEST['sid']) && !empty($_REQUEST['transactionID'])) {
         if ($tmpresult->fields["sid"] == $sid && $tmpresult->fields["paid"] == paidUntil(time())) {
             // let them know they are already signed up and renewed
             message_flash("You are a numpty and have already signed up and paid for this year.");
-        // else if check to see if they have signedup and paid for the new year but haven't renewed
+            // else if check to see if they have signedup and paid for the new year but haven't renewed
         } else if ($tmpresult->fields["sid"] == $sid && $tmpresult->fields["paid"] != paidUntil(time())) {
             // renew them!
             renew_membership($tmpresult->fields["username"]);
             // let them know that their account has been renewed
             message_flash("Your SUCS account has been renewed.");
-        // else if they aren't in the SUCS DB, then bootstrap signup process
+            // else if they aren't in the SUCS DB but have a signup slip, take them back to that part of signup
+            // I don't know how you would end up in a state like this but the old code dealt with it so I will as well
+        } else if ($tmpresult->fields == false && $signuptmpresult->fields["sid"] == $sid) {
+            $mode = "form";
+            $smarty->assign("id", $signuptmpresult->fields["id"]);
+            $smarty->assign("pass", $signuptmpresult->fields["password"]);
+            // else if they aren't in the SUCS DB, then bootstrap signup process
         } else if ($tmpresult->fields == false && $signuptmpresult->fields == false) {
             $mode = "form";
             $pass = make_password();