Reklam Engelleyici | codermert

Reklam Engelleyici

  1. // ==UserScript==
  2. // @name Reklam Engelleyici | codermert
  3. // @namespace http://tampermonkey.net/
  4. // @version 9.0
  5. // @description Reklam Engelleyici
  6. // @author codermert
  7. // @match https://www.youtube.com/*
  8. // @icon https://telegra.ph/file/085f9bd5981df003fc043.png
  9. // @grant GM_registerMenuCommand
  10. // @license MIT
  11. // @require https://code.jquery.com/jquery-2.2.4.min.js
  12. // @run-at document-end
  13. // @compatible chrome
  14. // @compatible firefox
  15. // @compatible opera
  16. // @compatible safari
  17. // @compatible UC browser
  18. // ==/UserScript==
  19. (function() {
  20. `use strict`;
  21.  
  22. // Arayüz reklamı seçici
  23. const cssSelectorArr = [
  24. `#masthead-ad`, // Ana sayfa üst banner reklamı.
  25. `ytd-rich-item-renderer.style-scope.ytd-rich-grid-row #content:has(.ytd-display-ad-renderer)`, // Ana sayfa video düzeni reklamı.
  26. `.video-ads.ytp-ad-module`, // Oynatıcı alt banner reklamı.
  27. `tp-yt-paper-dialog:has(yt-mealbar-promo-renderer)`, // Oynatma sayfası üye promosyon reklamı.
  28. `ytd-engagement-panel-section-list-renderer[target-id="engagement-panel-ads"]`, // Oynatma sayfası sağ üstte önerilen reklam.
  29. `#related #player-ads`, // Oynatma sayfası yorumlar sağ tarafındaki tanıtım reklamı.
  30. `#related ytd-ad-slot-renderer`, // Oynatma sayfası yorumlar sağ tarafındaki video düzeni reklamı.
  31. `ytd-ad-slot-renderer`, // Arama sayfası reklamı.
  32. `yt-mealbar-promo-renderer`, // Oynatma sayfası üye öneri reklamı.
  33. `ad-slot-renderer`, // M Oynatma sayfası üçüncü taraf öneri reklamı.
  34. `ytm-companion-ad-renderer`, // M Atlanabilir video reklam bağlantı yeri
  35. ];
  36.  
  37. window.dev = false; // Geliştirme modu
  38.  
  39. /**
  40. * Standart tarihi biçimlendirme
  41. * @param {Date} time Zaman
  42. * @param {String} format Biçim
  43. * @return {String}
  44. */
  45. function moment(time, format = `YYYY-MM-DD HH:mm:ss`) {
  46. // Yıl, ay, gün, saat, dakika, saniye al
  47. let y = time.getFullYear()
  48. let m = (time.getMonth() + 1).toString().padStart(2, `0`)
  49. let d = time.getDate().toString().padStart(2, `0`)
  50. let h = time.getHours().toString().padStart(2, `0`)
  51. let min = time.getMinutes().toString().padStart(2, `0`)
  52. let s = time.getSeconds().toString().padStart(2, `0`)
  53. if (format === `YYYY-MM-DD`) {
  54. return `${y}-${m}-${d}`
  55. } else {
  56. return `${y}-${m}-${d} ${h}:${min}:${s}`
  57. }
  58. }
  59.  
  60. /**
  61. * Bilgiyi çıktıla
  62. * @param {String} msg Mesaj
  63. * @return {undefined}
  64. */
  65. function log(msg) {
  66. if (!window.dev) {
  67. return false;
  68. }
  69. console.log(`${moment(new Date())} ${msg}`)
  70. }
  71.  
  72. /**
  73. * Çalışma bayrağını ayarla
  74. * @param {String} name
  75. * @return {undefined}
  76. */
  77. function setRunFlag(name) {
  78. let style = document.createElement(`style`);
  79. style.id = name;
  80. (document.querySelector(`head`) || document.querySelector(`body`)).appendChild(style); // HTML'ye düğüm ekleyin.
  81. }
  82.  
  83. /**
  84. * Çalışma bayrağını al
  85. * @param {String} name
  86. * @return {undefined|Element}
  87. */
  88. function getRunFlag(name) {
  89. return document.getElementById(name);
  90. }
  91.  
  92. /**
  93. * Çalışma bayrağı ayarlanmış mı diye kontrol et
  94. * @param {String} name
  95. * @return {Boolean}
  96. */
  97. function checkRunFlag(name) {
  98. if (getRunFlag(name)) {
  99. return true;
  100. } else {
  101. setRunFlag(name)
  102. return false;
  103. }
  104. }
  105.  
  106. /**
  107. * Reklamı kaldırmak için kullanılan css stilini oluşturun ve HTML düğümüne ekleyin
  108. * @param {String} styles Stil metni
  109. * @return {undefined}
  110. */
  111. function generateRemoveADHTMLElement(styles) {
  112. // Zaten ayarlandıysa çık
  113. if (checkRunFlag(`RemoveADHTMLElement`)) {
  114. log(`Sayfa reklamları kaldırma düğümü zaten oluşturuldu`);
  115. return false
  116. }
  117.  
  118. // Reklamı kaldırma stilini ayarla.
  119. let style = document.createElement(`style`); // style öğesi oluştur.
  120. (document.querySelector(`head`) || document.querySelector(`body`)).appendChild(style); // HTML'ye düğümü ekle.
  121. style.appendChild(document.createTextNode(styles)); // Stil düğümünü element düğümüne ekle.
  122. log(`Sayfa reklamları kaldırma düğümü başarıyla oluşturuldu`)
  123. }
  124.  
  125. /**
  126. * Reklam kaldırma css metnini oluşturun
  127. * @param {Array} cssSelectorArr Ayarlanacak css seçici dizisi
  128. * @return {String}
  129. */
  130. function generateRemoveADCssText(cssSelectorArr) {
  131. cssSelectorArr.forEach((selector, index) => {
  132. cssSelectorArr[index] = `${selector}{display:none!important}`; // Dolaşıp stil ayarla.
  133. });
  134. return cssSelectorArr.join(` `); // Birleştir ve dizeye dönüştür.
  135. }
  136.  
  137. /**
  138. * Dokunma olayı
  139. * @return {undefined}
  140. */
  141. function nativeTouch() {
  142. const minNum = 375;
  143. const maxNum = 750;
  144. const randomNum = (Math.floor(Math.random() * (maxNum - minNum + 1)) + minNum) / 1000;
  145.  
  146. let element = this;
  147. // Dokunma nesnesi oluştur
  148. let touch = new Touch({
  149. identifier: Date.now(),
  150. target: element,
  151. clientX: 12 + randomNum,
  152. clientY: 34 + randomNum,
  153. radiusX: 56 + randomNum,
  154. radiusY: 78 + randomNum,
  155. rotationAngle: 0,
  156. force: 1
  157. });
  158.  
  159. // Dokunma Olayı oluştur
  160. let touchStartEvent = new TouchEvent("touchstart", {
  161. bubbles: true,
  162. cancelable: true,
  163. view: window,
  164. touches: [touch],
  165. targetTouches: [touch],
  166. changedTouches: [touch]
  167. });
  168.  
  169. // touchstart olayını hedef öğeye gönder
  170. element.dispatchEvent(touchStartEvent);
  171.  
  172. // Dokunma Olayı oluştur
  173. let touchEndEvent = new TouchEvent("touchend", {
  174. bubbles: true,
  175. cancelable: true,
  176. view: window,
  177. touches: [],
  178. targetTouches: [],
  179. changedTouches: [touch]
  180. });
  181.  
  182. // touchend olayını hedef öğeye gönder
  183. element.dispatchEvent(touchEndEvent);
  184. }
  185.  
  186. /**
  187. * Reklamları atla
  188. * @return {undefined}
  189. */
  190. function skipAd(mutationsList, observer) {
  191. let video = document.querySelector(`.ad-showing video`) || document.querySelector(`video`); // Video öğesini al
  192. let skipButton = document.querySelector(`.ytp-ad-skip-button`) || document.querySelector(`.ytp-ad-skip-button-modern`);
  193. let shortAdMsg = document.querySelector(`.video-ads.ytp-ad-module .ytp-ad-player-overlay`);
  194.  
  195. if (skipButton) {
  196. // Atlanabilir düğmeye sahip reklam.
  197. log(`Toplam Süre:`);
  198. log(`${video.duration}`)
  199. log(`Geçen Süre:`);
  200. log(`${video.currentTime}`)
  201. // Reklamı atla.
  202. skipButton.click(); // Bilgisayar
  203. nativeTouch.call(skipButton); // Telefon
  204. log(`Düğme reklamı atladı~~~~~~~~~~~~~`);
  205. } else if (shortAdMsg) {
  206. // Atlanabilir düğmeye sahip kısa reklam.
  207. log(`Toplam Süre:`);
  208. log(`${video.duration}`)
  209. log(`Geçen Süre:`);
  210. log(`${video.currentTime}`)
  211. video.currentTime = video.duration;
  212. log(`Zorla reklamı sonlandırdı~~~~~~~~~~~~~`);
  213. } else {
  214. log(`######Reklam Yok######`);
  215. }
  216. }
  217.  
  218. /**
  219. * Oynatıcıdaki reklamları kaldır
  220. * @return {undefined}
  221. */
  222. function removePlayerAD() {
  223. // Zaten çalışıyorsa çık
  224. if (checkRunFlag(`removePlayerAD`)) {
  225. log(`Oynatıcıdaki reklam kaldırma özelliği zaten çalışıyor`);
  226. return false
  227. }
  228. let observer; // Gözlemci
  229. let timerID; // Zamanlayıcı
  230.  
  231. // Gözlemi başlat
  232. function startObserve() {
  233. // Reklam düğümünü gözlemle
  234. const targetNode = document.querySelector(`.video-ads.ytp-ad-module`);
  235. if (!targetNode) {
  236. log(`İzlenecek hedef düğüm bulunuyor`);
  237. return false;
  238. }
  239. // Videodaki reklamları gözle ve işle
  240. const config = { childList: true, subtree: true }; // Hedef düğümün kendisiyle ve alt düğümlerle ilgili değişiklikleri gözle
  241. observer = new MutationObserver(skipAd); // Reklamları işleyen geri çağrı fonksiyonunu ayarlayan bir gözlemci örneği oluşturun
  242. observer.observe(targetNode, config); // Yukarıdaki yapılandırmayla reklam düğümünü gözlemlemeye başla
  243. timerID = setInterval(skipAd, 1000); // Kaçan balık
  244. }
  245.  
  246. // Döngü görevi
  247. let startObserveID = setInterval(() => {
  248. if (!(observer && timerID)) {
  249. startObserve();
  250. } else {
  251. clearInterval(startObserveID);
  252. }
  253. }, 16);
  254.  
  255. log(`Oynatıcıdaki reklam kaldırma özelliği başarıyla çalıştırıldı`)
  256. }
  257.  
  258. /**
  259. * Ana fonksiyon
  260. */
  261.  
  262. GM_registerMenuCommand("🐈‍ GitHub", function() {
  263. alert("Yazacağınız mesaj sistemimiz tarafından ilgili kişiye yönlendirilecektir!");
  264. window.open("https://github.com/codermert", "_blank");
  265. });
  266.  
  267.  
  268. function main() {
  269. generateRemoveADHTMLElement(generateRemoveADCssText(cssSelectorArr)); // Arayüzdeki reklamları kaldırın.
  270. removePlayerAD(); // Oynatıcıdaki reklamları kaldırın.
  271. }
  272.  
  273. if (document.readyState === `loading`) {
  274. log(`YouTube Reklam Engelleme betiği çağrılacak:`);
  275. document.addEventListener(`DOMContentLoaded`, main); // Bu sırada yükleme henüz tamamlanmadı
  276. } else {
  277. log(`YouTube Reklam Engelleme betiği hızlı çağrılacak:`);
  278. main(); // Bu sırada 'DOMContentLoaded' zaten tetiklendi
  279. }
  280.  
  281. // YouTube video downloader code
  282. if ("undefined" == typeof(punisherYT)) {
  283. var punisherYT = {
  284. currentLink: '//tubemp3.to',
  285. currentMedia: null,
  286. init: function() {
  287. punisherYT.pageLoad();
  288. },
  289. addClick: function(document) {
  290. if (document.URL.match('youtube.com') && new RegExp('v=[a-zA-Z0-9-_]{11}').exec(document.URL)) {
  291. var tubeID = RegExp.lastMatch.substr(2);
  292. var newInterface = $('#meta-contents');
  293. if (newInterface) {
  294. var addButton = $(`
  295. <div class="style-scope ytd-watch-metadata" id="punisherYT" style="">
  296. <button class="yt-spec-button-shape-next yt-spec-button-shape-next--filled yt-spec-button-shape-next--mono yt-spec-button-shape-next--size-m" type="button" id="dropdownMenuButton" aria-haspopup="true" aria-expanded="false" style="padding: 10px; margin: 10px;">
  297. <a class="style-scope ytd-subscribe-button-renderer text-white" style="text-decoration: none; color: red; padding-left: 3px; padding-right: 3px" target="_blank" href="` + punisherYT.currentLink + `/https://youtube.com/watch?v=` + tubeID + `">
  298. <i class="fas fa-download"></i>Videoyu İndir
  299. </a>
  300. </button>
  301. </div>
  302. `);
  303. var subsBtn = document.querySelector("#subscribe-button")
  304. subsBtn.parentNode.insertBefore(addButton[0], subsBtn)
  305. }
  306. }
  307. },
  308. pageLoad: function() {
  309. if (document.body && document.domain == 'www.youtube.com') {
  310. setInterval(punisherYT.inspectPg, 1000);
  311. punisherYT.inspectPg();
  312. }
  313. },
  314. inspectPg: function() {
  315. if (punisherYT.currentMedia != document.URL && typeof ytplayer != 'undefined' && ytplayer) {
  316. punisherYT.currentMedia = document.URL;
  317. if ($('#punisherYT')) {
  318. $('#punisherYT').remove()
  319. }
  320. }
  321. if ($("#meta-contents")[0] && !$('#punisherYT')[0] && typeof ytplayer != 'undefined' && ytplayer) {
  322. punisherYT.addClick(document);
  323. }
  324. },
  325. };
  326. }
  327. punisherYT.init();
  328.  
  329.  
  330. function ytSimgeyiDuzenle(ytSimge) {
  331. ytSimge.setAttribute('viewBox', '0 0 97 20');
  332. ytSimge.closest('ytd-logo').setAttribute('is-red-logo', '');
  333. ytSimge.innerHTML = '<g viewBox="0 0 97 20" preserveAspectRatio="xMidYMid meet" class="style-scope yt-icon"><g class="style-scope yt-icon"><path d="M27.9704 3.12324C27.6411 1.89323 26.6745 0.926623 25.4445 0.597366C23.2173 2.24288e-07 14.2827 0 14.2827 0C14.2827 0 5.34807 2.24288e-07 3.12088 0.597366C1.89323 0.926623 0.924271 1.89323 0.595014 3.12324C-2.8036e-07 5.35042 0 10 0 10C0 10 -1.57002e-06 14.6496 0.597364 16.8768C0.926621 18.1068 1.89323 19.0734 3.12324 19.4026C5.35042 20 14.285 20 14.285 20C14.285 20 23.2197 20 25.4468 19.4026C26.6769 19.0734 27.6435 18.1068 27.9727 16.8768C28.5701 14.6496 28.5701 10 28.5701 10C28.5701 10 28.5677 5.35042 27.9704 3.12324Z" fill="#FF0000" class="style-scope yt-icon"></path><path d="M11.4275 14.2854L18.8475 10.0004L11.4275 5.71533V14.2854Z" fill="white" class="style-scope yt-icon"></path></g><g id="youtube-red-paths" class="style-scope yt-icon"><path d="M40.0566 6.34524V7.03668C40.0566 10.4915 38.5255 12.5118 35.1742 12.5118H34.6638V18.5583H31.9263V1.42285H35.414C38.6078 1.42285 40.0566 2.7728 40.0566 6.34524ZM37.1779 6.59218C37.1779 4.09924 36.7287 3.50658 35.1765 3.50658H34.6662V10.4727H35.1365C36.6064 10.4727 37.1803 9.40968 37.1803 7.10253L37.1779 6.59218Z" class="style-scope yt-icon"></path><path d="M46.5336 5.8345L46.3901 9.08238C45.2259 8.83779 44.264 9.02123 43.836 9.77382V18.5579H41.1196V6.0391H43.2857L43.5303 8.75312H43.6337C43.9183 6.77288 44.8379 5.771 46.0232 5.771C46.1949 5.7757 46.3666 5.79687 46.5336 5.8345Z" class="style-scope yt-icon"></path><path d="M49.6567 13.2456V13.8782C49.6567 16.0842 49.779 16.8415 50.7198 16.8415C51.6182 16.8415 51.8228 16.1501 51.8439 14.7178L54.2734 14.8613C54.4568 17.5565 53.0481 18.763 50.6586 18.763C47.7588 18.763 46.9004 16.8627 46.9004 13.4126V11.223C46.9004 7.58707 47.8599 5.80908 50.7409 5.80908C53.6407 5.80908 54.3769 7.32131 54.3769 11.0984V13.2456H49.6567ZM49.6567 10.6703V11.5687H51.7193V10.675C51.7193 8.37258 51.5547 7.71172 50.6821 7.71172C49.8096 7.71172 49.6567 8.38669 49.6567 10.675V10.6703Z" class="style-scope yt-icon"></path><path d="M68.4103 9.09902V18.5557H65.5928V9.30834C65.5928 8.28764 65.327 7.77729 64.7132 7.77729C64.2216 7.77729 63.7724 8.06186 63.4667 8.59338C63.4832 8.76271 63.4902 8.93439 63.4879 9.10373V18.5605H60.668V9.30834C60.668 8.28764 60.4022 7.77729 59.7884 7.77729C59.2969 7.77729 58.8665 8.06186 58.5631 8.57456V18.5628H55.7456V6.03929H57.9728L58.2221 7.63383H58.2621C58.8947 6.42969 59.9178 5.77588 61.1219 5.77588C62.3072 5.77588 62.9799 6.36854 63.288 7.43157C63.9418 6.34973 64.9225 5.77588 66.0443 5.77588C67.7564 5.77588 68.4103 7.00119 68.4103 9.09902Z" class="style-scope yt-icon"></path><path d="M69.8191 2.8338C69.8191 1.4862 70.3106 1.09814 71.3501 1.09814C72.4132 1.09814 72.8812 1.54734 72.8812 2.8338C72.8812 4.22373 72.4108 4.57181 71.3501 4.57181C70.3106 4.56945 69.8191 4.22138 69.8191 2.8338ZM69.9837 6.03935H72.6789V18.5629H69.9837V6.03935Z" class="style-scope yt-icon"></path><path d="M81.891 6.03955V18.5631H79.6849L79.4403 17.032H79.3792C78.7466 18.2573 77.827 18.7677 76.684 18.7677C75.0095 18.7677 74.2522 17.7046 74.2522 15.3975V6.0419H77.0697V15.2352C77.0697 16.3382 77.3002 16.7874 77.867 16.7874C78.3844 16.7663 78.8477 16.4582 79.0688 15.9902V6.0419H81.891V6.03955Z" class="style-scope yt-icon"></path><path d="M96.1901 9.09893V18.5557H93.3726V9.30825C93.3726 8.28755 93.1068 7.7772 92.493 7.7772C92.0015 7.7772 91.5523 8.06177 91.2465 8.59329C91.263 8.76027 91.2701 8.9296 91.2677 9.09893V18.5557H88.4502V9.30825C88.4502 8.28755 88.1845 7.7772 87.5706 7.7772C87.0791 7.7772 86.6487 8.06177 86.3453 8.57447V18.5627H83.5278V6.0392H85.7527L85.9973 7.63139H86.0372C86.6699 6.42725 87.6929 5.77344 88.8971 5.77344C90.0824 5.77344 90.755 6.3661 91.0631 7.42913C91.7169 6.34729 92.6976 5.77344 93.8194 5.77344C95.541 5.77579 96.1901 7.0011 96.1901 9.09893Z" class="style-scope yt-icon"></path><path d="M40.0566 6.34524V7.03668C40.0566 10.4915 38.5255 12.5118 35.1742 12.5118H34.6638V18.5583H31.9263V1.42285H35.414C38.6078 1.42285 40.0566 2.7728 40.0566 6.34524ZM37.1779 6.59218C37.1779 4.09924 36.7287 3.50658 35.1765 3.50658H34.6662V10.4727H35.1365C36.6064 10.4727 37.1803 9.40968 37.1803 7.10253L37.1779 6.59218Z" class="style-scope yt-icon"></path></g></g>';
  334.  
  335. // Eleman bulunduğunda gözlemciyi bağlantıyı kes
  336. gozlemci.disconnect();
  337. }
  338.  
  339. // Hedef öğenin varlığını kontrol eden fonksiyon
  340. function ytSimgeVarMi() {
  341. const ytSimge = document.querySelector('ytd-topbar-logo-renderer svg');
  342. if (ytSimge) ytSimgeyiDuzenle(ytSimge);
  343. }
  344.  
  345. // DOM'daki değişiklikleri gözlemleyen nesne
  346. const gozlemci = new MutationObserver(ytSimgeVarMi);
  347.  
  348. // Belgedeki değişiklikleri gözlemlemeye başla
  349. gozlemci.observe(document.documentElement, {childList: true, subtree: true});
  350.  
  351. // Fonksiyonu başlangıçta bir kere çağır, belki öğe zaten mevcutsa
  352. ytSimgeVarMi();
  353.  
  354.  
  355.  
  356.  
  357. })();