phishing-score-source.ts 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import { createRetrieKeywordFilter as createKeywordFilter } from 'foxts/retrie';
  2. export const BLACK_TLD = new Set([
  3. 'accountant', 'art', 'autos',
  4. 'bar', 'beauty', 'bid', 'bio', 'biz', 'bond', 'business', 'buzz',
  5. 'cc', 'cf', 'cfd', 'click', 'cloud', 'club', 'cn', 'codes',
  6. 'co.uk', 'co.in', 'com.br', 'com.cn', 'com.pl', 'com.vn',
  7. 'cool', 'cricket', 'cyou',
  8. 'date', 'design', 'digital', 'download',
  9. 'faith', 'fit', 'fun',
  10. 'ga', 'gd', 'gives', 'gq', 'group', 'host',
  11. 'icu', 'id', 'info', 'ink',
  12. 'lat', 'life', 'live', 'link', 'loan', 'lol', 'ltd',
  13. 'me', 'men', 'ml', 'mobi', 'mom', 'monster',
  14. 'net.pl',
  15. 'one', 'online',
  16. 'party', 'pro', 'pl', 'pw',
  17. 'racing', 'rest', 'review', 'rf.gd',
  18. 'sa.com', 'sbs', 'science', 'shop', 'site', 'skin', 'space', 'store', 'stream', 'su', 'support', 'surf',
  19. 'tech', 'tk', 'tokyo', 'top', 'trade',
  20. 'vip', 'vn',
  21. 'webcam', 'website', 'win',
  22. 'xyz',
  23. 'za.com'
  24. ]);
  25. export const WHITELIST_MAIN_DOMAINS = new Set([
  26. // 'w3s.link', // ipfs gateway
  27. // 'dweb.link', // ipfs gateway
  28. // 'nftstorage.link', // ipfs gateway
  29. 'fleek.cool', // ipfs gateway
  30. 'flk-ipfs.xyz', // ipfs gateway
  31. 'business.site', // Drag'n'Drop site building platform
  32. 'page.link', // Firebase URL Shortener
  33. // 'notion.site', d
  34. // 'vercel.app',
  35. 'gitbook.io',
  36. 'zendesk.com',
  37. 'ipfs.eth.aragon.network',
  38. 'wordpress.com',
  39. 'cloud.microsoft', // actually owned by Microsoft
  40. 'windows.net', // Microsoft refuses to add web.core.windows.net to the Public Suffix List
  41. 'myqcloud.com', // curben phishing-filter contains many entries
  42. 'surge.sh' // caused by phishing-filter, also no public suffix
  43. ]);
  44. export const leathalKeywords = createKeywordFilter([
  45. 'vinted-',
  46. 'inpost-pl',
  47. 'vlnted-',
  48. 'allegrolokalnie',
  49. 'thetollroads',
  50. 'getipass',
  51. '.secure.txtag',
  52. '00lx.',
  53. '0-lx.',
  54. '01-x',
  55. '0llx',
  56. '0lx.',
  57. 'olx.o',
  58. // Fake TLD
  59. '.pl-',
  60. '-pl.',
  61. '.com-',
  62. '-com.',
  63. '.net-',
  64. '.org-',
  65. '.gov-',
  66. '-gov.',
  67. '.au-',
  68. '.co.uk-',
  69. '.de-',
  70. '.eu-',
  71. '.us-',
  72. '.uk-',
  73. '.ru-'
  74. ]);
  75. export const sensitiveKeywords = createKeywordFilter([
  76. 'amazon',
  77. 'fb-com',
  78. 'focebaak',
  79. 'facebook',
  80. 'metamask',
  81. 'apple',
  82. 'icloud',
  83. 'coinbase',
  84. 'booking.',
  85. 'booking-',
  86. 'vinted.',
  87. 'vinted-',
  88. 'inpost-pl',
  89. 'microsoft',
  90. 'google',
  91. 'minecraft',
  92. 'staemco',
  93. 'oferta',
  94. 'txtag',
  95. 'paypal',
  96. 'dropbox',
  97. 'payment',
  98. 'instagram'
  99. ]);
  100. export const lowKeywords = createKeywordFilter([
  101. 'transactions',
  102. 'wallet',
  103. '-faceb', // facebook fake
  104. '.faceb', // facebook fake
  105. 'virus-',
  106. '-roblox',
  107. '-co-jp',
  108. 'customer.',
  109. 'customer-',
  110. '.www-',
  111. '.www.',
  112. '.www2',
  113. 'microsof',
  114. 'password',
  115. 'recover',
  116. 'banking',
  117. 'shop'
  118. ]);