ECE 4180 Final Project

Dependencies:   mbed

Committer:
nyengele
Date:
Fri May 06 16:08:47 2016 +0000
Revision:
13:3d521aa61e6a
Parent:
12:5cb9ffad1ad7
republishing

Who changed what in which revision?

UserRevisionLine numberNew contents of line
nyengele 0:f0e40bf44ffe 1 #include "mbed.h"
nyengele 12:5cb9ffad1ad7 2 #include "keypad.h"
nyengele 12:5cb9ffad1ad7 3 #include "cryst_lcd.h"
nyengele 12:5cb9ffad1ad7 4 #include "FPScanner.h"
nyengele 1:0e5e9821d89d 5 #include "lib.h"
nyengele 12:5cb9ffad1ad7 6 #include <cstring>
nyengele 9:48e93bcd1d5c 7
nyengele 12:5cb9ffad1ad7 8 Serial mag_card(p9, p10);
nyengele 12:5cb9ffad1ad7 9 Serial android(USBTX, USBRX);
nyengele 12:5cb9ffad1ad7 10 FPScanner fp(p28, p27);
nyengele 12:5cb9ffad1ad7 11 Cryst_LCD lcd(p20, p19, p18, p17, p16, p15, Cryst_LCD::LCD20x4);
nyengele 12:5cb9ffad1ad7 12 PwmOut speaker(p21);
nyengele 12:5cb9ffad1ad7 13 //Create the keypad ky values
nyengele 12:5cb9ffad1ad7 14 char mat[][3] = {{'1', '2', '3'}, {'4', '5', '6'}, {'7', '8', '9'}, {'*', '0', '#'}};
nyengele 12:5cb9ffad1ad7 15 // Create the bus for use with the keypad's columns
nyengele 12:5cb9ffad1ad7 16 BusInOut colPins(p24, p22, p26); // increasing order (column 1 ....n)
nyengele 12:5cb9ffad1ad7 17 // Create the bus for use with the keypad's rows
nyengele 12:5cb9ffad1ad7 18 BusInOut rowPins(p23, p30, p29, p25); // increasing order (row 1 ....n)
nyengele 12:5cb9ffad1ad7 19 // Create the keypad object
nyengele 12:5cb9ffad1ad7 20 Keypad<4, 3> pad(mat, &rowPins, &colPins);
nyengele 12:5cb9ffad1ad7 21 LocalFileSystem local_fs("local");
nyengele 12:5cb9ffad1ad7 22 DigitalOut door_lock(p8);
nyengele 12:5cb9ffad1ad7 23 DigitalIn sys_reset(p14);
nyengele 0:f0e40bf44ffe 24
nyengele 12:5cb9ffad1ad7 25 enum STATE {STANDBY, ENROLL, AUTH, FP_ENROLL, FP_AUTH, MC_ENROLL, MC_AUTH, FACE_ENROLL, FACE_AUTH, SPEECH_ENROLL, SPEECH_AUTH,
nyengele 12:5cb9ffad1ad7 26 ENROLL_SUCCESS, AUTH_SUCCESS, VOICE_ENROLL, VOICE_AUTH
nyengele 11:1d7021c0739d 27 };
nyengele 11:1d7021c0739d 28
nyengele 11:1d7021c0739d 29 char user_id[4];
nyengele 11:1d7021c0739d 30 char mag_card_data[250];
nyengele 12:5cb9ffad1ad7 31 char keyboard_input[20];
nyengele 11:1d7021c0739d 32 int mc_bytes = 0;
nyengele 12:5cb9ffad1ad7 33 char temp_char;
nyengele 12:5cb9ffad1ad7 34 int temp_int;
nyengele 12:5cb9ffad1ad7 35 bool flag;
nyengele 0:f0e40bf44ffe 36
nyengele 1:0e5e9821d89d 37 int main()
nyengele 1:0e5e9821d89d 38 {
nyengele 12:5cb9ffad1ad7 39 sys_reset.mode(PullUp);
nyengele 12:5cb9ffad1ad7 40 if (sys_reset == 0) fp_clearAll(&fp);
nyengele 12:5cb9ffad1ad7 41 speaker.period(1.0/440);
nyengele 12:5cb9ffad1ad7 42 door_lock = 0;
nyengele 11:1d7021c0739d 43 STATE current_state = STANDBY;
nyengele 11:1d7021c0739d 44 while (true) {
nyengele 11:1d7021c0739d 45 switch (current_state) {
nyengele 12:5cb9ffad1ad7 46 case STANDBY: {
nyengele 12:5cb9ffad1ad7 47 clear_serial_buffer(&android);
nyengele 11:1d7021c0739d 48 greeting(&lcd);
nyengele 12:5cb9ffad1ad7 49 temp_char = pad.getKeyChar();
nyengele 12:5cb9ffad1ad7 50 while (temp_char != '#' && temp_char != '*') {
nyengele 12:5cb9ffad1ad7 51 temp_char = pad.getKeyChar();
nyengele 11:1d7021c0739d 52 }
nyengele 12:5cb9ffad1ad7 53 if (temp_char == '*') current_state = AUTH;
nyengele 12:5cb9ffad1ad7 54 else current_state = ENROLL;
nyengele 11:1d7021c0739d 55 break;
nyengele 12:5cb9ffad1ad7 56 }
nyengele 12:5cb9ffad1ad7 57 case ENROLL: {
nyengele 12:5cb9ffad1ad7 58 if (read_pin(user_id, 4, &lcd, &pad)) {
nyengele 12:5cb9ffad1ad7 59 if (is_valid_user(user_id)) {
nyengele 12:5cb9ffad1ad7 60 display_msg(&lcd, "USER ALREADY\nENROLLED.");
nyengele 12:5cb9ffad1ad7 61 wait(3);
nyengele 12:5cb9ffad1ad7 62 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 63 } else current_state = FACE_ENROLL;
nyengele 12:5cb9ffad1ad7 64 } else {
nyengele 12:5cb9ffad1ad7 65 display_msg(&lcd, "INVALID PIN.");
nyengele 12:5cb9ffad1ad7 66 wait(3);
nyengele 12:5cb9ffad1ad7 67 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 68 }
nyengele 11:1d7021c0739d 69 break;
nyengele 12:5cb9ffad1ad7 70 }
nyengele 12:5cb9ffad1ad7 71 case FP_ENROLL: {
nyengele 12:5cb9ffad1ad7 72 display_msg(&lcd, "PLACE YOUR FINGER\nON SCANNER.");
nyengele 11:1d7021c0739d 73 if (fp_enroll(&fp)) {
nyengele 11:1d7021c0739d 74 current_state = MC_ENROLL;
nyengele 11:1d7021c0739d 75 } else {
nyengele 12:5cb9ffad1ad7 76 display_msg(&lcd, "FINGERPRINT FAILED.");
nyengele 12:5cb9ffad1ad7 77 wait(3);
nyengele 12:5cb9ffad1ad7 78 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 79 }
nyengele 12:5cb9ffad1ad7 80 break;
nyengele 12:5cb9ffad1ad7 81 }
nyengele 12:5cb9ffad1ad7 82 case MC_ENROLL: {
nyengele 12:5cb9ffad1ad7 83 flag = false;
nyengele 12:5cb9ffad1ad7 84 while (!flag) {
nyengele 12:5cb9ffad1ad7 85 display_msg(&lcd, "SWIPE CARD NOW");
nyengele 12:5cb9ffad1ad7 86 read_mag_card(&mag_card, mag_card_data, &mc_bytes);
nyengele 12:5cb9ffad1ad7 87 if (prompt("SUCCESSFUL SWIPE?", &lcd, &pad)) flag = true;
nyengele 12:5cb9ffad1ad7 88 }
nyengele 12:5cb9ffad1ad7 89 temp_int = hashcode(mag_card_data, mc_bytes);
nyengele 12:5cb9ffad1ad7 90 if (write_hash_to_file(user_id, temp_int)) current_state = ENROLL_SUCCESS;
nyengele 12:5cb9ffad1ad7 91 else {
nyengele 12:5cb9ffad1ad7 92 display_msg(&lcd, "AN ERROR OCCURED.");
nyengele 12:5cb9ffad1ad7 93 wait(3);
nyengele 12:5cb9ffad1ad7 94 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 95 }
nyengele 12:5cb9ffad1ad7 96 break;
nyengele 12:5cb9ffad1ad7 97 }
nyengele 12:5cb9ffad1ad7 98 case FACE_ENROLL: {
nyengele 12:5cb9ffad1ad7 99 display_msg(&lcd, "PROCEED TO\nFACE ENROLLMENT.");
nyengele 12:5cb9ffad1ad7 100 wait(2);
nyengele 12:5cb9ffad1ad7 101 if (face_enroll(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 102 current_state = SPEECH_ENROLL;
nyengele 12:5cb9ffad1ad7 103 } else {
nyengele 12:5cb9ffad1ad7 104 display_msg(&lcd, "FACE ENROLLMENT\nFAILED.");
nyengele 12:5cb9ffad1ad7 105 wait(3);
nyengele 12:5cb9ffad1ad7 106 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 107 }
nyengele 12:5cb9ffad1ad7 108 break;
nyengele 12:5cb9ffad1ad7 109 }
nyengele 12:5cb9ffad1ad7 110 case SPEECH_ENROLL: {
nyengele 12:5cb9ffad1ad7 111 display_msg(&lcd, "PROCEED TO\nSPEECH ENROLLMENT.");
nyengele 12:5cb9ffad1ad7 112 wait(2);
nyengele 12:5cb9ffad1ad7 113 if (speech_enroll(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 114 current_state = FP_ENROLL;
nyengele 12:5cb9ffad1ad7 115 } else {
nyengele 12:5cb9ffad1ad7 116 display_msg(&lcd, "SPEECH ENROLLMENT\nFAILED.");
nyengele 12:5cb9ffad1ad7 117 wait(3);
nyengele 12:5cb9ffad1ad7 118 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 119 }
nyengele 12:5cb9ffad1ad7 120 break;
nyengele 12:5cb9ffad1ad7 121 }
nyengele 12:5cb9ffad1ad7 122 //case VOICE_ENROLL: {
nyengele 12:5cb9ffad1ad7 123 // display_msg(&lcd, "PROCEED TO\nVOICE ENROLLMENT.");
nyengele 12:5cb9ffad1ad7 124 // wait(3);
nyengele 12:5cb9ffad1ad7 125 // if (voice_enroll(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 126 // current_state = FP_ENROLL;
nyengele 12:5cb9ffad1ad7 127 // } else {
nyengele 12:5cb9ffad1ad7 128 // display_msg(&lcd, "VOICE ENROLLMENT\nFAILED.");
nyengele 12:5cb9ffad1ad7 129 // wait(3);
nyengele 12:5cb9ffad1ad7 130 // current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 131 // }
nyengele 12:5cb9ffad1ad7 132 // break;
nyengele 12:5cb9ffad1ad7 133 // }
nyengele 12:5cb9ffad1ad7 134 case ENROLL_SUCCESS: {
nyengele 12:5cb9ffad1ad7 135 display_msg(&lcd, "ENROLLMENT\nSUCCESSFUL.");
nyengele 12:5cb9ffad1ad7 136 wait(3);
nyengele 12:5cb9ffad1ad7 137 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 138 break;
nyengele 12:5cb9ffad1ad7 139 }
nyengele 12:5cb9ffad1ad7 140 case AUTH: {
nyengele 12:5cb9ffad1ad7 141 if (read_pin(user_id, 4, &lcd, &pad) && is_valid_user(user_id)) {
nyengele 13:3d521aa61e6a 142 current_state = MC_AUTH;
nyengele 12:5cb9ffad1ad7 143 } else {
nyengele 12:5cb9ffad1ad7 144 display_msg(&lcd, "INVALID PIN.");
nyengele 12:5cb9ffad1ad7 145 wait(3);
nyengele 12:5cb9ffad1ad7 146 current_state = STANDBY;
nyengele 11:1d7021c0739d 147 }
nyengele 11:1d7021c0739d 148 break;
nyengele 12:5cb9ffad1ad7 149 }
nyengele 13:3d521aa61e6a 150 //case FP_AUTH: {
nyengele 13:3d521aa61e6a 151 // display_msg(&lcd, "PLACE YOUR FINGER\nON SCANNER.");
nyengele 13:3d521aa61e6a 152 // if (fp_auth(&fp)) {
nyengele 13:3d521aa61e6a 153 // current_state = MC_AUTH;
nyengele 13:3d521aa61e6a 154 // } else {
nyengele 13:3d521aa61e6a 155 // display_msg(&lcd, "FINGERPRINT FAILED.");
nyengele 13:3d521aa61e6a 156 // wait(3);
nyengele 13:3d521aa61e6a 157 // current_state = STANDBY;
nyengele 13:3d521aa61e6a 158 // }
nyengele 13:3d521aa61e6a 159 // break;
nyengele 13:3d521aa61e6a 160 // }
nyengele 12:5cb9ffad1ad7 161 case MC_AUTH: {
nyengele 12:5cb9ffad1ad7 162 flag = false;
nyengele 12:5cb9ffad1ad7 163 while (!flag) {
nyengele 12:5cb9ffad1ad7 164 display_msg(&lcd, "SWIPE CARD NOW");
nyengele 12:5cb9ffad1ad7 165 read_mag_card(&mag_card, mag_card_data, &mc_bytes);
nyengele 12:5cb9ffad1ad7 166 if (prompt("SUCCESSFUL SWIPE?", &lcd, &pad)) flag = true;
nyengele 12:5cb9ffad1ad7 167 }
nyengele 12:5cb9ffad1ad7 168 temp_int = hashcode(mag_card_data, mc_bytes);
nyengele 12:5cb9ffad1ad7 169 int saved_hash = 0;
nyengele 12:5cb9ffad1ad7 170 if (read_hash_from_file(user_id, &saved_hash) && temp_int == saved_hash) {
nyengele 12:5cb9ffad1ad7 171 current_state = FACE_AUTH;
nyengele 12:5cb9ffad1ad7 172 } else {
nyengele 12:5cb9ffad1ad7 173 display_msg(&lcd, "AUTH FAILED.");
nyengele 12:5cb9ffad1ad7 174 wait(3);
nyengele 12:5cb9ffad1ad7 175 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 176 }
nyengele 11:1d7021c0739d 177 break;
nyengele 12:5cb9ffad1ad7 178 }
nyengele 12:5cb9ffad1ad7 179 case FACE_AUTH: {
nyengele 12:5cb9ffad1ad7 180 display_msg(&lcd, "PROCEED TO FACE\nAUTHENTICATION.");
nyengele 12:5cb9ffad1ad7 181 wait(2);
nyengele 12:5cb9ffad1ad7 182 if (face_auth(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 183 current_state = SPEECH_AUTH;
nyengele 12:5cb9ffad1ad7 184 } else {
nyengele 12:5cb9ffad1ad7 185 display_msg(&lcd, "FACE AUTH FAILED.");
nyengele 12:5cb9ffad1ad7 186 wait(3);
nyengele 12:5cb9ffad1ad7 187 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 188 }
nyengele 12:5cb9ffad1ad7 189 break;
nyengele 12:5cb9ffad1ad7 190 }
nyengele 12:5cb9ffad1ad7 191 case SPEECH_AUTH: {
nyengele 12:5cb9ffad1ad7 192 display_msg(&lcd, "PROCEED TO SPEECH\nAUTHENTICATION.");
nyengele 12:5cb9ffad1ad7 193 wait(2);
nyengele 12:5cb9ffad1ad7 194 if (speech_auth(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 195 current_state = AUTH_SUCCESS;
nyengele 12:5cb9ffad1ad7 196 } else {
nyengele 12:5cb9ffad1ad7 197 display_msg(&lcd, "SPEECH AUTH FAILED.");
nyengele 12:5cb9ffad1ad7 198 wait(3);
nyengele 12:5cb9ffad1ad7 199 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 200 }
nyengele 11:1d7021c0739d 201 break;
nyengele 12:5cb9ffad1ad7 202 }
nyengele 12:5cb9ffad1ad7 203 //case VOICE_AUTH: {
nyengele 12:5cb9ffad1ad7 204 // display_msg(&lcd, "PROCEED TO VOICE\nAUTHENTICATION.");
nyengele 12:5cb9ffad1ad7 205 // wait(2);
nyengele 12:5cb9ffad1ad7 206 // if (voice_auth(user_id, &android)) {
nyengele 12:5cb9ffad1ad7 207 // current_state = AUTH_SUCCESS;
nyengele 12:5cb9ffad1ad7 208 // } else {
nyengele 12:5cb9ffad1ad7 209 // display_msg(&lcd, "VOICE AUTH FAILED.");
nyengele 12:5cb9ffad1ad7 210 // wait(3);
nyengele 12:5cb9ffad1ad7 211 // current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 212 // }
nyengele 12:5cb9ffad1ad7 213 // break;
nyengele 12:5cb9ffad1ad7 214 // }
nyengele 12:5cb9ffad1ad7 215 case AUTH_SUCCESS: {
nyengele 12:5cb9ffad1ad7 216 speaker = 0.5;
nyengele 12:5cb9ffad1ad7 217 door_lock = 1;
nyengele 12:5cb9ffad1ad7 218 display_msg(&lcd, "ACCESS GRANTED!");
nyengele 12:5cb9ffad1ad7 219 wait(3);
nyengele 12:5cb9ffad1ad7 220 door_lock = 0;
nyengele 12:5cb9ffad1ad7 221 speaker = 0;
nyengele 11:1d7021c0739d 222 current_state = STANDBY;
nyengele 12:5cb9ffad1ad7 223 }
nyengele 11:1d7021c0739d 224 }
nyengele 11:1d7021c0739d 225 }
nyengele 0:f0e40bf44ffe 226 }