Reklam Engelleyici | codermert

Reklam Engelleyici

当前为 2023-12-08 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Reklam Engelleyici | codermert
  3. // @namespace http://tampermonkey.net/
  4. // @version 7.0
  5. // @description Reklam Engelleyici
  6. // @author codermert
  7. // @match https://www.youtube.com/*
  8. // @icon https://telegra.ph/file/085f9bd5981df003fc043.png
  9. // @grant none
  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. // @grant GM_registerMenuCommand
  19. // ==/UserScript==
  20. (function() {
  21. `use strict`;
  22.  
  23. // Arayüz reklamı seçici
  24. const cssSelectorArr = [
  25. `#masthead-ad`, // Ana sayfa üst banner reklamı.
  26. `ytd-rich-item-renderer.style-scope.ytd-rich-grid-row #content:has(.ytd-display-ad-renderer)`, // Ana sayfa video düzeni reklamı.
  27. `.video-ads.ytp-ad-module`, // Oynatıcı alt banner reklamı.
  28. `tp-yt-paper-dialog:has(yt-mealbar-promo-renderer)`, // Oynatma sayfası üye promosyon reklamı.
  29. `ytd-engagement-panel-section-list-renderer[target-id="engagement-panel-ads"]`, // Oynatma sayfası sağ üstte önerilen reklam.
  30. `#related #player-ads`, // Oynatma sayfası yorumlar sağ tarafındaki tanıtım reklamı.
  31. `#related ytd-ad-slot-renderer`, // Oynatma sayfası yorumlar sağ tarafındaki video düzeni reklamı.
  32. `ytd-ad-slot-renderer`, // Arama sayfası reklamı.
  33. `yt-mealbar-promo-renderer`, // Oynatma sayfası üye öneri reklamı.
  34. `ad-slot-renderer`, // M Oynatma sayfası üçüncü taraf öneri reklamı.
  35. `ytm-companion-ad-renderer`, // M Atlanabilir video reklam bağlantı yeri
  36. ];
  37.  
  38. window.dev = false; // Geliştirme modu
  39.  
  40. /**
  41. * Standart tarihi biçimlendirme
  42. * @param {Date} time Zaman
  43. * @param {String} format Biçim
  44. * @return {String}
  45. */
  46. function moment(time, format = `YYYY-MM-DD HH:mm:ss`) {
  47. // Yıl, ay, gün, saat, dakika, saniye al
  48. let y = time.getFullYear()
  49. let m = (time.getMonth() + 1).toString().padStart(2, `0`)
  50. let d = time.getDate().toString().padStart(2, `0`)
  51. let h = time.getHours().toString().padStart(2, `0`)
  52. let min = time.getMinutes().toString().padStart(2, `0`)
  53. let s = time.getSeconds().toString().padStart(2, `0`)
  54. if (format === `YYYY-MM-DD`) {
  55. return `${y}-${m}-${d}`
  56. } else {
  57. return `${y}-${m}-${d} ${h}:${min}:${s}`
  58. }
  59. }
  60.  
  61. /**
  62. * Bilgiyi çıktıla
  63. * @param {String} msg Mesaj
  64. * @return {undefined}
  65. */
  66. function log(msg) {
  67. if (!window.dev) {
  68. return false;
  69. }
  70. console.log(`${moment(new Date())} ${msg}`)
  71. }
  72.  
  73. /**
  74. * Çalışma bayrağını ayarla
  75. * @param {String} name
  76. * @return {undefined}
  77. */
  78. function setRunFlag(name) {
  79. let style = document.createElement(`style`);
  80. style.id = name;
  81. (document.querySelector(`head`) || document.querySelector(`body`)).appendChild(style); // HTML'ye düğüm ekleyin.
  82. }
  83.  
  84. /**
  85. * Çalışma bayrağını al
  86. * @param {String} name
  87. * @return {undefined|Element}
  88. */
  89. function getRunFlag(name) {
  90. return document.getElementById(name);
  91. }
  92.  
  93. /**
  94. * Çalışma bayrağı ayarlanmış mı diye kontrol et
  95. * @param {String} name
  96. * @return {Boolean}
  97. */
  98. function checkRunFlag(name) {
  99. if (getRunFlag(name)) {
  100. return true;
  101. } else {
  102. setRunFlag(name)
  103. return false;
  104. }
  105. }
  106.  
  107. /**
  108. * Reklamı kaldırmak için kullanılan css stilini oluşturun ve HTML düğümüne ekleyin
  109. * @param {String} styles Stil metni
  110. * @return {undefined}
  111. */
  112. function generateRemoveADHTMLElement(styles) {
  113. // Zaten ayarlandıysa çık
  114. if (checkRunFlag(`RemoveADHTMLElement`)) {
  115. log(`Sayfa reklamları kaldırma düğümü zaten oluşturuldu`);
  116. return false
  117. }
  118.  
  119. // Reklamı kaldırma stilini ayarla.
  120. let style = document.createElement(`style`); // style öğesi oluştur.
  121. (document.querySelector(`head`) || document.querySelector(`body`)).appendChild(style); // HTML'ye düğümü ekle.
  122. style.appendChild(document.createTextNode(styles)); // Stil düğümünü element düğümüne ekle.
  123. log(`Sayfa reklamları kaldırma düğümü başarıyla oluşturuldu`)
  124. }
  125.  
  126. /**
  127. * Reklam kaldırma css metnini oluşturun
  128. * @param {Array} cssSelectorArr Ayarlanacak css seçici dizisi
  129. * @return {String}
  130. */
  131. function generateRemoveADCssText(cssSelectorArr) {
  132. cssSelectorArr.forEach((selector, index) => {
  133. cssSelectorArr[index] = `${selector}{display:none!important}`; // Dolaşıp stil ayarla.
  134. });
  135. return cssSelectorArr.join(` `); // Birleştir ve dizeye dönüştür.
  136. }
  137.  
  138. /**
  139. * Dokunma olayı
  140. * @return {undefined}
  141. */
  142. function nativeTouch() {
  143. const minNum = 375;
  144. const maxNum = 750;
  145. const randomNum = (Math.floor(Math.random() * (maxNum - minNum + 1)) + minNum) / 1000;
  146.  
  147. let element = this;
  148. // Dokunma nesnesi oluştur
  149. let touch = new Touch({
  150. identifier: Date.now(),
  151. target: element,
  152. clientX: 12 + randomNum,
  153. clientY: 34 + randomNum,
  154. radiusX: 56 + randomNum,
  155. radiusY: 78 + randomNum,
  156. rotationAngle: 0,
  157. force: 1
  158. });
  159.  
  160. // Dokunma Olayı oluştur
  161. let touchStartEvent = new TouchEvent("touchstart", {
  162. bubbles: true,
  163. cancelable: true,
  164. view: window,
  165. touches: [touch],
  166. targetTouches: [touch],
  167. changedTouches: [touch]
  168. });
  169.  
  170. // touchstart olayını hedef öğeye gönder
  171. element.dispatchEvent(touchStartEvent);
  172.  
  173. // Dokunma Olayı oluştur
  174. let touchEndEvent = new TouchEvent("touchend", {
  175. bubbles: true,
  176. cancelable: true,
  177. view: window,
  178. touches: [],
  179. targetTouches: [],
  180. changedTouches: [touch]
  181. });
  182.  
  183. // touchend olayını hedef öğeye gönder
  184. element.dispatchEvent(touchEndEvent);
  185. }
  186.  
  187. /**
  188. * Reklamları atla
  189. * @return {undefined}
  190. */
  191. function skipAd(mutationsList, observer) {
  192. let video = document.querySelector(`.ad-showing video`) || document.querySelector(`video`); // Video öğesini al
  193. let skipButton = document.querySelector(`.ytp-ad-skip-button`) || document.querySelector(`.ytp-ad-skip-button-modern`);
  194. let shortAdMsg = document.querySelector(`.video-ads.ytp-ad-module .ytp-ad-player-overlay`);
  195.  
  196. if (skipButton) {
  197. // Atlanabilir düğmeye sahip reklam.
  198. log(`Toplam Süre:`);
  199. log(`${video.duration}`)
  200. log(`Geçen Süre:`);
  201. log(`${video.currentTime}`)
  202. // Reklamı atla.
  203. skipButton.click(); // Bilgisayar
  204. nativeTouch.call(skipButton); // Telefon
  205. log(`Düğme reklamı atladı~~~~~~~~~~~~~`);
  206. } else if (shortAdMsg) {
  207. // Atlanabilir düğmeye sahip kısa reklam.
  208. log(`Toplam Süre:`);
  209. log(`${video.duration}`)
  210. log(`Geçen Süre:`);
  211. log(`${video.currentTime}`)
  212. video.currentTime = video.duration;
  213. log(`Zorla reklamı sonlandırdı~~~~~~~~~~~~~`);
  214. } else {
  215. log(`######Reklam Yok######`);
  216. }
  217. }
  218.  
  219. /**
  220. * Oynatıcıdaki reklamları kaldır
  221. * @return {undefined}
  222. */
  223. function removePlayerAD() {
  224. // Zaten çalışıyorsa çık
  225. if (checkRunFlag(`removePlayerAD`)) {
  226. log(`Oynatıcıdaki reklam kaldırma özelliği zaten çalışıyor`);
  227. return false
  228. }
  229. let observer; // Gözlemci
  230. let timerID; // Zamanlayıcı
  231.  
  232. // Gözlemi başlat
  233. function startObserve() {
  234. // Reklam düğümünü gözlemle
  235. const targetNode = document.querySelector(`.video-ads.ytp-ad-module`);
  236. if (!targetNode) {
  237. log(`İzlenecek hedef düğüm bulunuyor`);
  238. return false;
  239. }
  240. // Videodaki reklamları gözle ve işle
  241. const config = { childList: true, subtree: true }; // Hedef düğümün kendisiyle ve alt düğümlerle ilgili değişiklikleri gözle
  242. observer = new MutationObserver(skipAd); // Reklamları işleyen geri çağrı fonksiyonunu ayarlayan bir gözlemci örneği oluşturun
  243. observer.observe(targetNode, config); // Yukarıdaki yapılandırmayla reklam düğümünü gözlemlemeye başla
  244. timerID = setInterval(skipAd, 1000); // Kaçan balık
  245. }
  246.  
  247. // Döngü görevi
  248. let startObserveID = setInterval(() => {
  249. if (!(observer && timerID)) {
  250. startObserve();
  251. } else {
  252. clearInterval(startObserveID);
  253. }
  254. }, 16);
  255.  
  256. log(`Oynatıcıdaki reklam kaldırma özelliği başarıyla çalıştırıldı`)
  257. }
  258.  
  259. /**
  260. * Ana fonksiyon
  261. */
  262. function main() {
  263. generateRemoveADHTMLElement(generateRemoveADCssText(cssSelectorArr)); // Arayüzdeki reklamları kaldırın.
  264. removePlayerAD(); // Oynatıcıdaki reklamları kaldırın.
  265. }
  266.  
  267. if (document.readyState === `loading`) {
  268. log(`YouTube Reklam Engelleme betiği çağrılacak:`);
  269. document.addEventListener(`DOMContentLoaded`, main); // Bu sırada yükleme henüz tamamlanmadı
  270. } else {
  271. log(`YouTube Reklam Engelleme betiği hızlı çağrılacak:`);
  272. main(); // Bu sırada 'DOMContentLoaded' zaten tetiklendi
  273. }
  274.  
  275. // YouTube video downloader code
  276. if ("undefined" == typeof(punisherYT)) {
  277. var punisherYT = {
  278. currentLink: '//tubemp3.to',
  279. currentMedia: null,
  280. init: function() {
  281. punisherYT.pageLoad();
  282. },
  283. addClick: function(document) {
  284. if (document.URL.match('youtube.com') && new RegExp('v=[a-zA-Z0-9-_]{11}').exec(document.URL)) {
  285. var tubeID = RegExp.lastMatch.substr(2);
  286. var newInterface = $('#meta-contents');
  287. if (newInterface) {
  288. var addButton = $(`
  289. <div class="style-scope ytd-watch-metadata" id="punisherYT" style="">
  290. <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;">
  291. <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 + `">
  292. <i class="fas fa-download"></i>Videoyu İndir
  293. </a>
  294. </button>
  295. </div>
  296. `);
  297. var subsBtn = document.querySelector("#subscribe-button")
  298. subsBtn.parentNode.insertBefore(addButton[0], subsBtn)
  299. }
  300. }
  301. },
  302. pageLoad: function() {
  303. if (document.body && document.domain == 'www.youtube.com') {
  304. setInterval(punisherYT.inspectPg, 1000);
  305. punisherYT.inspectPg();
  306. }
  307. },
  308. inspectPg: function() {
  309. if (punisherYT.currentMedia != document.URL && typeof ytplayer != 'undefined' && ytplayer) {
  310. punisherYT.currentMedia = document.URL;
  311. if ($('#punisherYT')) {
  312. $('#punisherYT').remove()
  313. }
  314. }
  315. if ($("#meta-contents")[0] && !$('#punisherYT')[0] && typeof ytplayer != 'undefined' && ytplayer) {
  316. punisherYT.addClick(document);
  317. }
  318. },
  319. };
  320. }
  321. punisherYT.init();
  322.  
  323.  
  324. function ytSimgeyiDuzenle(ytSimge) {
  325. ytSimge.setAttribute('viewBox', '0 0 97 20');
  326. ytSimge.closest('ytd-logo').setAttribute('is-red-logo', '');
  327. 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>';
  328.  
  329. // Eleman bulunduğunda gözlemciyi bağlantıyı kes
  330. gozlemci.disconnect();
  331. }
  332.  
  333. // Hedef öğenin varlığını kontrol eden fonksiyon
  334. function ytSimgeVarMi() {
  335. const ytSimge = document.querySelector('ytd-topbar-logo-renderer svg');
  336. if (ytSimge) ytSimgeyiDuzenle(ytSimge);
  337. }
  338.  
  339. // DOM'daki değişiklikleri gözlemleyen nesne
  340. const gozlemci = new MutationObserver(ytSimgeVarMi);
  341.  
  342. // Belgedeki değişiklikleri gözlemlemeye başla
  343. gozlemci.observe(document.documentElement, {childList: true, subtree: true});
  344.  
  345. // Fonksiyonu başlangıçta bir kere çağır, belki öğe zaten mevcutsa
  346. ytSimgeVarMi();
  347.  
  348.  
  349. })();