00000000 00000018 00000030 00000048 00000060 00000078 00000090 000000A8 000000C0 000000D8 000000F0 00000108 00000120 00000138 00000150 00000168 00000180 00000198 000001B0 000001C8 000001E0 000001F8 00000210 00000228 00000240 00000258 00000270 00000288 000002A0 000002B8 000002D0 000002E8 00000300 00000318 00000330 00000348 00000360 00000378 00000390 000003A8 000003C0 000003D8 000003F0 00000408 00000420 00000438 00000450 00000468 00000480 00000498 000004B0 000004C8 000004E0 000004F8 00000510 00000528 00000540 00000558 00000570 00000588 000005A0 000005B8 000005D0 000005E8 00000600 00000618 00000630 00000648 00000660 00000678 00000690 000006A8 000006C0 000006D8 000006F0 00000708 00000720 00000738 00000750 00000768 00000780 00000798 000007B0 000007C8 000007E0 000007F8 00000810 00000828 00000840 00000858 00000870 00000888 000008A0 000008B8 000008D0 000008E8 00000900 00000918 00000930 00000948 00000960 00000978 00000990 000009A8 000009C0 000009D8 000009F0 00000A08 00000A20 00000A38 00000A50 00000A68 00000A80 00000A98 00000AB0 00000AC8 00000AE0 00000AF8 00000B10 00000B28 00000B40 00000B58 00000B70 00000B88 00000BA0 00000BB8 00000BD0 00000BE8 00000C00 00000C18 00000C30 00000C48 00000C60 00000C78 00000C90 00000CA8 00000CC0 00000CD8 00000CF0 00000D08 00000D20 00000D38 00000D50 00000D68 00000D80 00000D98 00000DB0 00000DC8 00000DE0 00000DF8 00000E10 00000E28 00000E40 00000E58 00000E70 00000E88 00000EA0 00000EB8 00000ED0 00000EE8 00000F00 00000F18 00000F30 00000F48 00000F60 00000F78 00000F90 00000FA8 00000FC0 00000FD8 00000FF0 00001008 00001020 00001038 00001050 00001068 00001080 00001098 000010B0 000010C8 000010E0 000010F8 00001110 00001128 00001140 00001158 00001170 00001188 000011A0 000011B8 000011D0 000011E8 00001200 00001218 00001230 00001248 00001260 00001278 00001290 000012A8 000012C0 000012D8 000012F0 00001308 00001320 00001338 00001350 00001368 00001380 00001398 000013B0 000013C8 000013E0 000013F8 00001410 00001428 00001440 00001458 00001470 00001488 000014A0 000014B8 000014D0 000014E8 00001500 00001518 00001530 00001548 00001560 00001578 00001590 000015A8 000015C0 000015D8 000015F0 00001608 00001620 00001638 00001650 00001668 00001680 00001698 000016B0 000016C8 000016E0 000016F8 00001710 00001728 00001740 00001758 00001770 00001788 000017A0 000017B8 000017D0 000017E8 00001800 00001818 00001830 00001848 00001860 00001878 00001890 000018A8 000018C0 000018D8 000018F0 00001908 00001920 00001938 00001950 00001968 00001980 00001998 000019B0
| 23 21 2F 62 69 6E 2F 73 68 0A 0A 23 20 43 6F 70 79 72 69 67 68 74 20 28 43 29 20 32 30 30 32 20 4D 79 53 51 4C 20 41 42 20 61 6E 64 20 4A 65 72 65 6D 79 20 43 6F 6C 65 0A 23 20 0A 23 20 54 68 69 73 20 70 72 6F 67 72 61 6D 20 69 73 20 66 72 65 65 20 73 6F 66 74 77 61 72 65 3B 20 79 6F 75 20 63 61 6E 20 72 65 64 69 73 74 72 69 62 75 74 65 20 69 74 20 61 6E 64 2F 6F 72 20 6D 6F 64 69 66 79 0A 23 20 69 74 20 75 6E 64 65 72 20 74 68 65 20 74 65 72 6D 73 20 6F 66 20 74 68 65 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 20 61 73 20 70 75 62 6C 69 73 68 65 64 20 62 79 0A 23 20 74 68 65 20 46 72 65 65 20 53 6F 66 74 77 61 72 65 20 46 6F 75 6E 64 61 74 69 6F 6E 3B 20 76 65 72 73 69 6F 6E 20 32 20 6F 66 20 74 68 65 20 4C 69 63 65 6E 73 65 2E 0A 23 20 0A 23 20 54 68 69 73 20 70 72 6F 67 72 61 6D 20 69 73 20 64 69 73 74 72 69 62 75 74 65 64 20 69 6E 20 74 68 65 20 68 6F 70 65 20 74 68 61 74 20 69 74 20 77 69 6C 6C 20 62 65 20 75 73 65 66 75 6C 2C 0A 23 20 62 75 74 20 57 49 54 48 4F 55 54 20 41 4E 59 20 57 41 52 52 41 4E 54 59 3B 20 77 69 74 68 6F 75 74 20 65 76 65 6E 20 74 68 65 20 69 6D 70 6C 69 65 64 20 77 61 72 72 61 6E 74 79 20 6F 66 0A 23 20 4D 45 52 43 48 41 4E 54 41 42 49 4C 49 54 59 20 6F 72 20 46 49 54 4E 45 53 53 20 46 4F 52 20 41 20 50 41 52 54 49 43 55 4C 41 52 20 50 55 52 50 4F 53 45 2E 20 20 53 65 65 20 74 68 65 0A 23 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 20 66 6F 72 20 6D 6F 72 65 20 64 65 74 61 69 6C 73 2E 0A 23 20 0A 23 20 59 6F 75 20 73 68 6F 75 6C 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64 20 61 20 63 6F 70 79 20 6F 66 20 74 68 65 20 47 4E 55 20 47 65 6E 65 72 61 6C 20 50 75 62 6C 69 63 20 4C 69 63 65 6E 73 65 0A 23 20 61 6C 6F 6E 67 20 77 69 74 68 20 74 68 69 73 20 70 72 6F 67 72 61 6D 3B 20 69 66 20 6E 6F 74 2C 20 77 72 69 74 65 20 74 6F 20 74 68 65 20 46 72 65 65 20 53 6F 66 74 77 61 72 65 0A 23 20 46 6F 75 6E 64 61 74 69 6F 6E 2C 20 49 6E 63 2E 2C 20 35 39 20 54 65 6D 70 6C 65 20 50 6C 61 63 65 2C 20 53 75 69 74 65 20 33 33 30 2C 20 42 6F 73 74 6F 6E 2C 20 4D 41 20 20 30 32 31 31 31 2D 31 33 30 37 20 20 55 53 41 0A 0A 63 6F 6E 66 69 67 3D 22 2E 6D 79 2E 63 6E 66 2E 24 24 22 0A 63 6F 6D 6D 61 6E 64 3D 22 2E 6D 79 73 71 6C 2E 24 24 22 0A 0A 74 72 61 70 20 22 69 6E 74 65 72 72 75 70 74 22 20 32 0A 0A 72 6F 6F 74 70 61 73 73 3D 22 22 0A 65 63 68 6F 5F 6E 3D 0A 65 63 68 6F 5F 63 3D 0A 0A 73 65 74 5F 65 63 68 6F 5F 63 6F 6D 70 61 74 28 29 20 7B 0A 20 20 20 20 63 61 73 65 20 60 65 63 68 6F 20 22 74 65 73 74 69 6E 67 5C 63 22 60 2C 60 65 63 68 6F 20 2D 6E 20 74 65 73 74 69 6E 67 60 20 69 6E 0A 09 2A 63 2A 2C 2D 6E 2A 29 20 65 63 68 6F 5F 6E 3D 20 20 20 65 63 68 6F 5F 63 3D 20 20 20 20 20 3B 3B 0A 09 2A 63 2A 2C 2A 29 20 20 20 65 63 68 6F 5F 6E 3D 2D 6E 20 65 63 68 6F 5F 63 3D 20 20 20 20 20 3B 3B 0A 09 2A 29 20 20 20 20 20 20 20 65 63 68 6F 5F 6E 3D 20 20 20 65 63 68 6F 5F 63 3D 27 5C 63 27 20 3B 3B 0A 20 20 20 20 65 73 61 63 0A 7D 0A 0A 70 72 65 70 61 72 65 28 29 20 7B 0A 20 20 20 20 74 6F 75 63 68 20 24 63 6F 6E 66 69 67 20 24 63 6F 6D 6D 61 6E 64 0A 20 20 20 20 63 68 6D 6F 64 20 36 30 30 20 24 63 6F 6E 66 69 67 20 24 63 6F 6D 6D 61 6E 64 0A 7D 0A 0A 64 6F 5F 71 75 65 72 79 28 29 20 7B 0A 20 20 20 20 65 63 68 6F 20 24 31 20 3E 24 63 6F 6D 6D 61 6E 64 0A 20 20 20 20 6D 79 73 71 6C 20 2D 2D 64 65 66 61 75 6C 74 73 2D 66 69 6C 65 3D 24 63 6F 6E 66 69 67 20 3C 24 63 6F 6D 6D 61 6E 64 0A 20 20 20 20 72 65 74 75 72 6E 20 24 3F 0A 7D 0A 0A 6D 61 6B 65 5F 63 6F 6E 66 69 67 28 29 20 7B 0A 20 20 20 20 65 63 68 6F 20 22 23 20 6D 79 73 71 6C 5F 73 65 63 75 72 65 5F 69 6E 73 74 61 6C 6C 61 74 69 6F 6E 20 63 6F 6E 66 69 67 20 66 69 6C 65 22 20 3E 24 63 6F 6E 66 69 67 0A 20 20 20 20 65 63 68 6F 20 22 5B 6D 79 73 71 6C 5D 22 20 3E 3E 24 63 6F 6E 66 69 67 0A 20 20 20 20 65 63 68 6F 20 22 75 73 65 72 3D 72 6F 6F 74 22 20 3E 3E 24 63 6F 6E 66 69 67 0A 20 20 20 20 65 63 68 6F 20 22 70 61 73 73 77 6F 72 64 3D 24 72 6F 6F 74 70 61 73 73 22 20 3E 3E 24 63 6F 6E 66 69 67 0A 7D 0A 0A 67 65 74 5F 72 6F 6F 74 5F 70 61 73 73 77 6F 72 64 28 29 20 7B 0A 20 20 20 20 73 74 61 74 75 73 3D 31 0A 20 20 20 20 77 68 69 6C 65 20 5B 20 24 73 74 61 74 75 73 20 2D 65 71 20 31 20 5D 3B 20 64 6F 0A 09 73 74 74 79 20 2D 65 63 68 6F 0A 09 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 45 6E 74 65 72 20 63 75 72 72 65 6E 74 20 70 61 73 73 77 6F 72 64 20 66 6F 72 20 72 6F 6F 74 20 28 65 6E 74 65 72 20 66 6F 72 20 6E 6F 6E 65 29 3A 20 24 65 63 68 6F 5F 63 22 0A 09 72 65 61 64 20 70 61 73 73 77 6F 72 64 0A 09 65 63 68 6F 0A 09 73 74 74 79 20 65 63 68 6F 0A 09 69 66 20 5B 20 22 78 24 70 61 73 73 77 6F 72 64 22 20 3D 20 22 78 22 20 5D 3B 20 74 68 65 6E 0A 09 20 20 20 20 68 61 64 70 61 73 73 3D 30 0A 09 65 6C 73 65 0A 09 20 20 20 20 68 61 64 70 61 73 73 3D 31 0A 09 66 69 0A 09 72 6F 6F 74 70 61 73 73 3D 24 70 61 73 73 77 6F 72 64 0A 09 6D 61 6B 65 5F 63 6F 6E 66 69 67 0A 09 64 6F 5F 71 75 65 72 79 20 22 22 0A 09 73 74 61 74 75 73 3D 24 3F 0A 20 20 20 20 64 6F 6E 65 0A 20 20 20 20 65 63 68 6F 20 22 4F 4B 2C 20 73 75 63 63 65 73 73 66 75 6C 6C 79 20 75 73 65 64 20 70 61 73 73 77 6F 72 64 2C 20 6D 6F 76 69 6E 67 20 6F 6E 2E 2E 2E 22 0A 20 20 20 20 65 63 68 6F 0A 7D 0A 0A 73 65 74 5F 72 6F 6F 74 5F 70 61 73 73 77 6F 72 64 28 29 20 7B 0A 20 20 20 20 73 74 74 79 20 2D 65 63 68 6F 0A 20 20 20 20 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 4E 65 77 20 70 61 73 73 77 6F 72 64 3A 20 24 65 63 68 6F 5F 63 22 0A 20 20 20 20 72 65 61 64 20 70 61 73 73 77 6F 72 64 31 0A 20 20 20 20 65 63 68 6F 0A 20 20 20 20 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 52 65 2D 65 6E 74 65 72 20 6E 65 77 20 70 61 73 73 77 6F 72 64 3A 20 24 65 63 68 6F 5F 63 22 0A 20 20 20 20 72 65 61 64 20 70 61 73 73 77 6F 72 64 32 0A 20 20 20 20 65 63 68 6F 0A 20 20 20 20 73 74 74 79 20 65 63 68 6F 0A 0A 20 20 20 20 69 66 20 5B 20 22 24 70 61 73 73 77 6F 72 64 31 22 20 21 3D 20 22 24 70 61 73 73 77 6F 72 64 32 22 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 53 6F 72 72 79 2C 20 70 61 73 73 77 6F 72 64 73 20 64 6F 20 6E 6F 74 20 6D 61 74 63 68 2E 22 0A 09 65 63 68 6F 0A 09 72 65 74 75 72 6E 20 31 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 69 66 20 5B 20 22 24 70 61 73 73 77 6F 72 64 31 22 20 3D 20 22 22 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 53 6F 72 72 79 2C 20 79 6F 75 20 63 61 6E 27 74 20 75 73 65 20 61 6E 20 65 6D 70 74 79 20 70 61 73 73 77 6F 72 64 20 68 65 72 65 2E 22 0A 09 65 63 68 6F 0A 09 72 65 74 75 72 6E 20 31 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 55 50 44 41 54 45 20 6D 79 73 71 6C 2E 75 73 65 72 20 53 45 54 20 50 61 73 73 77 6F 72 64 3D 50 41 53 53 57 4F 52 44 28 27 24 70 61 73 73 77 6F 72 64 31 27 29 20 57 48 45 52 45 20 55 73 65 72 3D 27 72 6F 6F 74 27 3B 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 50 61 73 73 77 6F 72 64 20 75 70 64 61 74 65 64 20 73 75 63 63 65 73 73 66 75 6C 6C 79 21 22 0A 09 65 63 68 6F 20 22 52 65 6C 6F 61 64 69 6E 67 20 70 72 69 76 69 6C 65 67 65 20 74 61 62 6C 65 73 2E 2E 22 0A 09 69 66 20 21 20 72 65 6C 6F 61 64 5F 70 72 69 76 69 6C 65 67 65 5F 74 61 62 6C 65 73 3B 20 74 68 65 6E 0A 09 20 20 20 20 65 78 69 74 20 31 0A 09 66 69 0A 09 65 63 68 6F 0A 09 72 6F 6F 74 70 61 73 73 3D 24 70 61 73 73 77 6F 72 64 31 0A 09 6D 61 6B 65 5F 63 6F 6E 66 69 67 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 50 61 73 73 77 6F 72 64 20 75 70 64 61 74 65 20 66 61 69 6C 65 64 21 22 0A 09 65 78 69 74 20 31 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 30 0A 7D 0A 0A 72 65 6D 6F 76 65 5F 61 6E 6F 6E 79 6D 6F 75 73 5F 75 73 65 72 73 28 29 20 7B 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 44 45 4C 45 54 45 20 46 52 4F 4D 20 6D 79 73 71 6C 2E 75 73 65 72 20 57 48 45 52 45 20 55 73 65 72 3D 27 27 3B 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 53 75 63 63 65 73 73 21 22 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 46 61 69 6C 65 64 21 22 0A 09 65 78 69 74 20 31 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 30 0A 7D 0A 0A 72 65 6D 6F 76 65 5F 72 65 6D 6F 74 65 5F 72 6F 6F 74 28 29 20 7B 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 44 45 4C 45 54 45 20 46 52 4F 4D 20 6D 79 73 71 6C 2E 75 73 65 72 20 57 48 45 52 45 20 55 73 65 72 3D 27 72 6F 6F 74 27 20 41 4E 44 20 48 6F 73 74 21 3D 27 6C 6F 63 61 6C 68 6F 73 74 27 3B 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 53 75 63 63 65 73 73 21 22 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 46 61 69 6C 65 64 21 22 0A 20 20 20 20 66 69 0A 7D 0A 0A 72 65 6D 6F 76 65 5F 74 65 73 74 5F 64 61 74 61 62 61 73 65 28 29 20 7B 0A 20 20 20 20 65 63 68 6F 20 22 20 2D 20 44 72 6F 70 70 69 6E 67 20 74 65 73 74 20 64 61 74 61 62 61 73 65 2E 2E 2E 22 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 44 52 4F 50 20 44 41 54 41 42 41 53 45 20 74 65 73 74 3B 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 53 75 63 63 65 73 73 21 22 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 46 61 69 6C 65 64 21 20 20 4E 6F 74 20 63 72 69 74 69 63 61 6C 2C 20 6B 65 65 70 20 6D 6F 76 69 6E 67 2E 2E 2E 22 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 65 63 68 6F 20 22 20 2D 20 52 65 6D 6F 76 69 6E 67 20 70 72 69 76 69 6C 65 67 65 73 20 6F 6E 20 74 65 73 74 20 64 61 74 61 62 61 73 65 2E 2E 2E 22 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 44 45 4C 45 54 45 20 46 52 4F 4D 20 6D 79 73 71 6C 2E 64 62 20 57 48 45 52 45 20 44 62 3D 27 74 65 73 74 27 20 4F 52 20 44 62 3D 27 74 65 73 74 5C 5C 5F 25 27 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 53 75 63 63 65 73 73 21 22 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 46 61 69 6C 65 64 21 20 20 4E 6F 74 20 63 72 69 74 69 63 61 6C 2C 20 6B 65 65 70 20 6D 6F 76 69 6E 67 2E 2E 2E 22 0A 20 20 20 20 66 69 0A 0A 20 20 20 20 72 65 74 75 72 6E 20 30 0A 7D 0A 0A 72 65 6C 6F 61 64 5F 70 72 69 76 69 6C 65 67 65 5F 74 61 62 6C 65 73 28 29 20 7B 0A 20 20 20 20 64 6F 5F 71 75 65 72 79 20 22 46 4C 55 53 48 20 50 52 49 56 49 4C 45 47 45 53 3B 22 0A 20 20 20 20 69 66 20 5B 20 24 3F 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 53 75 63 63 65 73 73 21 22 0A 09 72 65 74 75 72 6E 20 30 0A 20 20 20 20 65 6C 73 65 0A 09 65 63 68 6F 20 22 20 2E 2E 2E 20 46 61 69 6C 65 64 21 22 0A 09 72 65 74 75 72 6E 20 31 0A 20 20 20 20 66 69 0A 7D 0A 0A 69 6E 74 65 72 72 75 70 74 28 29 20 7B 0A 20 20 20 20 65 63 68 6F 0A 20 20 20 20 65 63 68 6F 20 22 41 62 6F 72 74 69 6E 67 21 22 0A 20 20 20 20 65 63 68 6F 0A 20 20 20 20 63 6C 65 61 6E 75 70 0A 20 20 20 20 73 74 74 79 20 65 63 68 6F 0A 20 20 20 20 65 78 69 74 20 31 0A 7D 0A 0A 63 6C 65 61 6E 75 70 28 29 20 7B 0A 20 20 20 20 65 63 68 6F 20 22 43 6C 65 61 6E 69 6E 67 20 75 70 2E 2E 2E 22 0A 20 20 20 20 72 6D 20 2D 66 20 24 63 6F 6E 66 69 67 20 24 63 6F 6D 6D 61 6E 64 0A 7D 0A 0A 0A 23 20 54 68 65 20 61 63 74 75 61 6C 20 73 63 72 69 70 74 20 73 74 61 72 74 73 20 68 65 72 65 0A 0A 70 72 65 70 61 72 65 0A 73 65 74 5F 65 63 68 6F 5F 63 6F 6D 70 61 74 0A 0A 65 63 68 6F 0A 65 63 68 6F 0A 65 63 68 6F 0A 65 63 68 6F 0A 65 63 68 6F 20 22 4E 4F 54 45 3A 20 52 55 4E 4E 49 4E 47 20 41 4C 4C 20 50 41 52 54 53 20 4F 46 20 54 48 49 53 20 53 43 52 49 50 54 20 49 53 20 52 45 43 4F 4D 4D 45 4E 44 45 44 20 46 4F 52 20 41 4C 4C 20 4D 79 53 51 4C 22 0A 65 63 68 6F 20 22 20 20 20 20 20 20 53 45 52 56 45 52 53 20 49 4E 20 50 52 4F 44 55 43 54 49 4F 4E 20 55 53 45 21 20 20 50 4C 45 41 53 45 20 52 45 41 44 20 45 41 43 48 20 53 54 45 50 20 43 41 52 45 46 55 4C 4C 59 21 22 0A 65 63 68 6F 0A 65 63 68 6F 0A 0A 65 63 68 6F 20 22 49 6E 20 6F 72 64 65 72 20 74 6F 20 6C 6F 67 20 69 6E 74 6F 20 4D 79 53 51 4C 20 74 6F 20 73 65 63 75 72 65 20 69 74 2C 20 77 65 27 6C 6C 20 6E 65 65 64 20 74 68 65 20 63 75 72 72 65 6E 74 22 0A 65 63 68 6F 20 22 70 61 73 73 77 6F 72 64 20 66 6F 72 20 74 68 65 20 72 6F 6F 74 20 75 73 65 72 2E 20 20 49 66 20 79 6F 75 27 76 65 20 6A 75 73 74 20 69 6E 73 74 61 6C 6C 65 64 20 4D 79 53 51 4C 2C 20 61 6E 64 22 0A 65 63 68 6F 20 22 79 6F 75 20 68 61 76 65 6E 27 74 20 73 65 74 20 74 68 65 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 20 79 65 74 2C 20 74 68 65 20 70 61 73 73 77 6F 72 64 20 77 69 6C 6C 20 62 65 20 62 6C 61 6E 6B 2C 22 0A 65 63 68 6F 20 22 73 6F 20 79 6F 75 20 73 68 6F 75 6C 64 20 6A 75 73 74 20 70 72 65 73 73 20 65 6E 74 65 72 20 68 65 72 65 2E 22 0A 65 63 68 6F 0A 0A 67 65 74 5F 72 6F 6F 74 5F 70 61 73 73 77 6F 72 64 0A 0A 0A 23 0A 23 20 53 65 74 20 74 68 65 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 0A 23 0A 0A 65 63 68 6F 20 22 53 65 74 74 69 6E 67 20 74 68 65 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 20 65 6E 73 75 72 65 73 20 74 68 61 74 20 6E 6F 62 6F 64 79 20 63 61 6E 20 6C 6F 67 20 69 6E 74 6F 20 74 68 65 20 4D 79 53 51 4C 22 0A 65 63 68 6F 20 22 72 6F 6F 74 20 75 73 65 72 20 77 69 74 68 6F 75 74 20 74 68 65 20 70 72 6F 70 65 72 20 61 75 74 68 6F 72 69 73 61 74 69 6F 6E 2E 22 0A 65 63 68 6F 0A 0A 69 66 20 5B 20 24 68 61 64 70 61 73 73 20 2D 65 71 20 30 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 53 65 74 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 65 6C 73 65 0A 20 20 20 20 65 63 68 6F 20 22 59 6F 75 20 61 6C 72 65 61 64 79 20 68 61 76 65 20 61 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 20 73 65 74 2C 20 73 6F 20 79 6F 75 20 63 61 6E 20 73 61 66 65 6C 79 20 61 6E 73 77 65 72 20 27 6E 27 2E 22 0A 20 20 20 20 65 63 68 6F 0A 20 20 20 20 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 43 68 61 6E 67 65 20 74 68 65 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 66 69 0A 0A 72 65 61 64 20 72 65 70 6C 79 0A 69 66 20 5B 20 22 24 72 65 70 6C 79 22 20 3D 20 22 6E 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 22 20 2E 2E 2E 20 73 6B 69 70 70 69 6E 67 2E 22 0A 65 6C 73 65 0A 20 20 20 20 73 74 61 74 75 73 3D 31 0A 20 20 20 20 77 68 69 6C 65 20 5B 20 24 73 74 61 74 75 73 20 2D 65 71 20 31 20 5D 3B 20 64 6F 0A 09 73 65 74 5F 72 6F 6F 74 5F 70 61 73 73 77 6F 72 64 0A 09 73 74 61 74 75 73 3D 24 3F 0A 20 20 20 20 64 6F 6E 65 0A 66 69 0A 65 63 68 6F 0A 0A 0A 23 0A 23 20 52 65 6D 6F 76 65 20 61 6E 6F 6E 79 6D 6F 75 73 20 75 73 65 72 73 0A 23 0A 0A 65 63 68 6F 20 22 42 79 20 64 65 66 61 75 6C 74 2C 20 61 20 4D 79 53 51 4C 20 69 6E 73 74 61 6C 6C 61 74 69 6F 6E 20 68 61 73 20 61 6E 20 61 6E 6F 6E 79 6D 6F 75 73 20 75 73 65 72 2C 20 61 6C 6C 6F 77 69 6E 67 20 61 6E 79 6F 6E 65 22 0A 65 63 68 6F 20 22 74 6F 20 6C 6F 67 20 69 6E 74 6F 20 4D 79 53 51 4C 20 77 69 74 68 6F 75 74 20 68 61 76 69 6E 67 20 74 6F 20 68 61 76 65 20 61 20 75 73 65 72 20 61 63 63 6F 75 6E 74 20 63 72 65 61 74 65 64 20 66 6F 72 22 0A 65 63 68 6F 20 22 74 68 65 6D 2E 20 20 54 68 69 73 20 69 73 20 69 6E 74 65 6E 64 65 64 20 6F 6E 6C 79 20 66 6F 72 20 74 65 73 74 69 6E 67 2C 20 61 6E 64 20 74 6F 20 6D 61 6B 65 20 74 68 65 20 69 6E 73 74 61 6C 6C 61 74 69 6F 6E 22 0A 65 63 68 6F 20 22 67 6F 20 61 20 62 69 74 20 73 6D 6F 6F 74 68 65 72 2E 20 20 59 6F 75 20 73 68 6F 75 6C 64 20 72 65 6D 6F 76 65 20 74 68 65 6D 20 62 65 66 6F 72 65 20 6D 6F 76 69 6E 67 20 69 6E 74 6F 20 61 22 0A 65 63 68 6F 20 22 70 72 6F 64 75 63 74 69 6F 6E 20 65 6E 76 69 72 6F 6E 6D 65 6E 74 2E 22 0A 65 63 68 6F 0A 0A 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 52 65 6D 6F 76 65 20 61 6E 6F 6E 79 6D 6F 75 73 20 75 73 65 72 73 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 0A 72 65 61 64 20 72 65 70 6C 79 0A 69 66 20 5B 20 22 24 72 65 70 6C 79 22 20 3D 20 22 6E 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 22 20 2E 2E 2E 20 73 6B 69 70 70 69 6E 67 2E 22 0A 65 6C 73 65 0A 20 20 20 20 72 65 6D 6F 76 65 5F 61 6E 6F 6E 79 6D 6F 75 73 5F 75 73 65 72 73 0A 66 69 0A 65 63 68 6F 0A 0A 0A 23 0A 23 20 44 69 73 61 6C 6C 6F 77 20 72 65 6D 6F 74 65 20 72 6F 6F 74 20 6C 6F 67 69 6E 0A 23 0A 0A 65 63 68 6F 20 22 4E 6F 72 6D 61 6C 6C 79 2C 20 72 6F 6F 74 20 73 68 6F 75 6C 64 20 6F 6E 6C 79 20 62 65 20 61 6C 6C 6F 77 65 64 20 74 6F 20 63 6F 6E 6E 65 63 74 20 66 72 6F 6D 20 27 6C 6F 63 61 6C 68 6F 73 74 27 2E 20 20 54 68 69 73 22 0A 65 63 68 6F 20 22 65 6E 73 75 72 65 73 20 74 68 61 74 20 73 6F 6D 65 6F 6E 65 20 63 61 6E 6E 6F 74 20 67 75 65 73 73 20 61 74 20 74 68 65 20 72 6F 6F 74 20 70 61 73 73 77 6F 72 64 20 66 72 6F 6D 20 74 68 65 20 6E 65 74 77 6F 72 6B 2E 22 0A 65 63 68 6F 0A 0A 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 44 69 73 61 6C 6C 6F 77 20 72 6F 6F 74 20 6C 6F 67 69 6E 20 72 65 6D 6F 74 65 6C 79 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 72 65 61 64 20 72 65 70 6C 79 0A 69 66 20 5B 20 22 24 72 65 70 6C 79 22 20 3D 20 22 6E 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 22 20 2E 2E 2E 20 73 6B 69 70 70 69 6E 67 2E 22 0A 65 6C 73 65 0A 20 20 20 20 72 65 6D 6F 76 65 5F 72 65 6D 6F 74 65 5F 72 6F 6F 74 0A 66 69 0A 65 63 68 6F 0A 0A 0A 23 0A 23 20 52 65 6D 6F 76 65 20 74 65 73 74 20 64 61 74 61 62 61 73 65 0A 23 0A 0A 65 63 68 6F 20 22 42 79 20 64 65 66 61 75 6C 74 2C 20 4D 79 53 51 4C 20 63 6F 6D 65 73 20 77 69 74 68 20 61 20 64 61 74 61 62 61 73 65 20 6E 61 6D 65 64 20 27 74 65 73 74 27 20 74 68 61 74 20 61 6E 79 6F 6E 65 20 63 61 6E 22 0A 65 63 68 6F 20 22 61 63 63 65 73 73 2E 20 20 54 68 69 73 20 69 73 20 61 6C 73 6F 20 69 6E 74 65 6E 64 65 64 20 6F 6E 6C 79 20 66 6F 72 20 74 65 73 74 69 6E 67 2C 20 61 6E 64 20 73 68 6F 75 6C 64 20 62 65 20 72 65 6D 6F 76 65 64 22 0A 65 63 68 6F 20 22 62 65 66 6F 72 65 20 6D 6F 76 69 6E 67 20 69 6E 74 6F 20 61 20 70 72 6F 64 75 63 74 69 6F 6E 20 65 6E 76 69 72 6F 6E 6D 65 6E 74 2E 22 0A 65 63 68 6F 0A 0A 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 52 65 6D 6F 76 65 20 74 65 73 74 20 64 61 74 61 62 61 73 65 20 61 6E 64 20 61 63 63 65 73 73 20 74 6F 20 69 74 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 72 65 61 64 20 72 65 70 6C 79 0A 69 66 20 5B 20 22 24 72 65 70 6C 79 22 20 3D 20 22 6E 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 22 20 2E 2E 2E 20 73 6B 69 70 70 69 6E 67 2E 22 0A 65 6C 73 65 0A 20 20 20 20 72 65 6D 6F 76 65 5F 74 65 73 74 5F 64 61 74 61 62 61 73 65 0A 66 69 0A 65 63 68 6F 0A 0A 0A 23 0A 23 20 52 65 6C 6F 61 64 20 70 72 69 76 69 6C 65 67 65 20 74 61 62 6C 65 73 0A 23 0A 0A 65 63 68 6F 20 22 52 65 6C 6F 61 64 69 6E 67 20 74 68 65 20 70 72 69 76 69 6C 65 67 65 20 74 61 62 6C 65 73 20 77 69 6C 6C 20 65 6E 73 75 72 65 20 74 68 61 74 20 61 6C 6C 20 63 68 61 6E 67 65 73 20 6D 61 64 65 20 73 6F 20 66 61 72 22 0A 65 63 68 6F 20 22 77 69 6C 6C 20 74 61 6B 65 20 65 66 66 65 63 74 20 69 6D 6D 65 64 69 61 74 65 6C 79 2E 22 0A 65 63 68 6F 0A 0A 65 63 68 6F 20 24 65 63 68 6F 5F 6E 20 22 52 65 6C 6F 61 64 20 70 72 69 76 69 6C 65 67 65 20 74 61 62 6C 65 73 20 6E 6F 77 3F 20 5B 59 2F 6E 5D 20 24 65 63 68 6F 5F 63 22 0A 72 65 61 64 20 72 65 70 6C 79 0A 69 66 20 5B 20 22 24 72 65 70 6C 79 22 20 3D 20 22 6E 22 20 5D 3B 20 74 68 65 6E 0A 20 20 20 20 65 63 68 6F 20 22 20 2E 2E 2E 20 73 6B 69 70 70 69 6E 67 2E 22 0A 65 6C 73 65 0A 20 20 20 20 72 65 6C 6F 61 64 5F 70 72 69 76 69 6C 65 67 65 5F 74 61 62 6C 65 73 0A 66 69 0A 65 63 68 6F 0A 0A 63 6C 65 61 6E 75 70 0A 0A 65 63 68 6F 0A 65 63 68 6F 0A 65 63 68 6F 0A 65 63 68 6F 20 22 41 6C 6C 20 64 6F 6E 65 21 20 20 49 66 20 79 6F 75 27 76 65 20 63 6F 6D 70 6C 65 74 65 64 20 61 6C 6C 20 6F 66 20 74 68 65 20 61 62 6F 76 65 20 73 74 65 70 73 2C 20 79 6F 75 72 20 4D 79 53 51 4C 22 0A 65 63 68 6F 20 22 69 6E 73 74 61 6C 6C 61 74 69 6F 6E 20 73 68 6F 75 6C 64 20 6E 6F 77 20 62 65 20 73 65 63 75 72 65 2E 22 0A 65 63 68 6F 0A 65 63 68 6F 20 22 54 68 61 6E 6B 73 20 66 6F 72 20 75 73 69 6E 67 20 4D 79 53 51 4C 21 22 0A 65 63 68 6F 0A 65 63 68 6F 0A 0A 0A | #!/bin/sh # Copyright ( C) 2002 MySQL AB and Jer emy Cole # # This progr am is free software; you can redistribute it and /or modify # it under th e terms of the GNU Gener al Public License as pub lished by # the Free Sof tware Foundation; versio n 2 of the License. # # This program is distrib uted in the hope that it will be useful, # but W ITHOUT ANY WARRANTY; wit hout even the implied wa rranty of # MERCHANTABIL ITY or FITNESS FOR A PAR TICULAR PURPOSE. See th e # GNU General Public L icense for more details. # # You should have re ceived a copy of the GNU General Public License # along with this progra m; if not, write to the Free Software # Foundati on, Inc., 59 Temple Plac e, Suite 330, Boston, MA 02111-1307 USA confi g=".my.cnf.$$" command=" .mysql.$$" trap "interr upt" 2 rootpass="" echo _n= echo_c= set_echo_co mpat() { case `echo "testing\c"`,`echo -n te sting` in *c*,-n*) echo _n= echo_c= ;; *c *,*) echo_n=-n echo_c= ;; *) echo_n = echo_c='\c' ;; e sac } prepare() { t ouch $config $command chmod 600 $config $com mand } do_query() { echo $1 >$command m ysql --defaults-file=$co nfig <$command retur n $? } make_config() { echo "# mysql_secure _installation config fil e" >$config echo "[m ysql]" >>$config ech o "user=root" >>$config echo "password=$root pass" >>$config } get_r oot_password() { sta tus=1 while [ $statu s -eq 1 ]; do stty -ech o echo $echo_n "Enter c urrent password for root (enter for none): $echo _c" read password echo stty echo if [ "x$pas sword" = "x" ]; then hadpass=0 else h adpass=1 fi rootpass=$ password make_config d o_query "" status=$? done echo "OK, suc cessfully used password, moving on..." echo } set_root_password() { stty -echo echo $echo_n "New password: $echo_c" read passwo rd1 echo echo $e cho_n "Re-enter new pass word: $echo_c" read password2 echo s tty echo if [ "$pas sword1" != "$password2" ]; then echo "Sorry, pa sswords do not match." echo return 1 fi if [ "$password1" = " " ]; then echo "Sorry, you can't use an empty p assword here." echo re turn 1 fi do_qu ery "UPDATE mysql.user S ET Password=PASSWORD('$p assword1') WHERE User='r oot';" if [ $? -eq 0 ]; then echo "Password updated successfully!" echo "Reloading privile ge tables.." if ! reloa d_privilege_tables; then exit 1 fi echo rootpass=$password1 mak e_config else echo "Password update failed! " exit 1 fi re turn 0 } remove_anonymo us_users() { do_quer y "DELETE FROM mysql.use r WHERE User='';" if [ $? -eq 0 ]; then ech o " ... Success!" el se echo " ... Failed!" exit 1 fi retu rn 0 } remove_remote_ro ot() { do_query "DEL ETE FROM mysql.user WHER E User='root' AND Host!= 'localhost';" if [ $ ? -eq 0 ]; then echo " ... Success!" else echo " ... Failed!" fi } remove_test_databa se() { echo " - Drop ping test database..." do_query "DROP DATABA SE test;" if [ $? -e q 0 ]; then echo " ... Success!" else echo " ... Failed! Not crit ical, keep moving..." fi echo " - Remov ing privileges on test d atabase..." do_query "DELETE FROM mysql.db W HERE Db='test' OR Db='te st\\_%'" if [ $? -eq 0 ]; then echo " ... S uccess!" else echo " ... Failed! Not criti cal, keep moving..." fi return 0 } rel oad_privilege_tables() { do_query "FLUSH PRI VILEGES;" if [ $? -e q 0 ]; then echo " ... Success!" return 0 else echo " ... Failed! " return 1 fi } in terrupt() { echo echo "Aborting!" ec ho cleanup stty echo exit 1 } clean up() { echo "Cleanin g up..." rm -f $conf ig $command } # The ac tual script starts here prepare set_echo_compat echo echo echo echo ec ho "NOTE: RUNNING ALL PA RTS OF THIS SCRIPT IS RE COMMENDED FOR ALL MySQL" echo " SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY !" echo echo echo "In o rder to log into MySQL t o secure it, we'll need the current" echo "passw ord for the root user. If you've just installed MySQL, and" echo "you h aven't set the root pass word yet, the password w ill be blank," echo "so you should just press en ter here." echo get_roo t_password # # Set the root password # echo " Setting the root passwor d ensures that nobody ca n log into the MySQL" ec ho "root user without th e proper authorisation." echo if [ $hadpass -eq 0 ]; then echo $ech o_n "Set root password? [Y/n] $echo_c" else echo "You already have a root password set, so y ou can safely answer 'n' ." echo echo $ec ho_n "Change the root pa ssword? [Y/n] $echo_c" f i read reply if [ "$rep ly" = "n" ]; then ec ho " ... skipping." else status=1 while [ $status -eq 1 ]; do s et_root_password status =$? done fi echo # # Remove anonymous user s # echo "By default, a MySQL installation has an anonymous user, allow ing anyone" echo "to log into MySQL without havi ng to have a user accoun t created for" echo "the m. This is intended onl y for testing, and to ma ke the installation" ech o "go a bit smoother. Y ou should remove them be fore moving into a" echo "production environment ." echo echo $echo_n "R emove anonymous users? [ Y/n] $echo_c" read repl y if [ "$reply" = "n" ]; then echo " ... ski pping." else remove_ anonymous_users fi echo # # Disallow remote ro ot login # echo "Normal ly, root should only be allowed to connect from 'localhost'. This" echo "ensures that someone c annot guess at the root password from the networ k." echo echo $echo_n " Disallow root login remo tely? [Y/n] $echo_c" rea d reply if [ "$reply" = "n" ]; then echo " . .. skipping." else r emove_remote_root fi ech o # # Remove test data base # echo "By default , MySQL comes with a dat abase named 'test' that anyone can" echo "access . This is also intended only for testing, and s hould be removed" echo " before moving into a pro duction environment." ec ho echo $echo_n "Remove test database and acces s to it? [Y/n] $echo_c" read reply if [ "$reply" = "n" ]; then echo " ... skipping." else remove_test_database f i echo # # Reload priv ilege tables # echo "Re loading the privilege ta bles will ensure that al l changes made so far" e cho "will take effect im mediately." echo echo $ echo_n "Reload privilege tables now? [Y/n] $echo _c" read reply if [ "$re ply" = "n" ]; then e cho " ... skipping." els e reload_privilege_t ables fi echo cleanup echo echo echo echo "All done! If you've comple ted all of the above ste ps, your MySQL" echo "in stallation should now be secure." echo echo "Tha nks for using MySQL!" ec ho echo |