{"id":19960,"date":"2025-07-20T10:34:21","date_gmt":"2025-07-20T07:04:21","guid":{"rendered":"https:\/\/liangroup.net\/blog\/?p=19960"},"modified":"2025-07-20T09:39:03","modified_gmt":"2025-07-20T06:09:03","slug":"popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware","status":"publish","type":"post","link":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/","title":{"rendered":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af"},"content":{"rendered":"<p><span style=\"font-size: 10pt\">\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0628\u0633\u062a\u0647\u200c\u06cc npm \u0628\u0627 \u0646\u0627\u0645 <a href=\"https:\/\/www.npmjs.com\/package\/eslint-config-prettier\">eslint-config-prettier<\/a> \u06a9\u0647 \u0628\u0647\u200c\u0637\u0648\u0631 \u0647\u0641\u062a\u06af\u06cc \u0628\u06cc\u0634 \u0627\u0632 \u06f3\u06f0 \u0645\u06cc\u0644\u06cc\u0648\u0646 \u0628\u0627\u0631 \u062f\u0627\u0646\u0644\u0648\u062f \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u067e\u0633 \u0627\u0632 \u0622\u0646\u200c\u06a9\u0647 \u0646\u06af\u0647\u062f\u0627\u0631\u0646\u062f\u0647 \u0622\u0646 \u0642\u0631\u0628\u0627\u0646\u06cc \u062d\u0645\u0644\u0647 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0634\u062f\u060c \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a. \u0633\u0627\u06cc\u0631 \u0628\u0633\u062a\u0647\u200c\u0647\u0627 \u0634\u0627\u0645\u0644 <a href=\"https:\/\/www.npmjs.com\/package\/eslint-plugin-prettier?activeTab=versions\">eslint-plugin-prettier<\/a>\u060c synckit\u060c @pkgr\/core \u0648 <a href=\"https:\/\/www.npmjs.com\/package\/napi-postinstall?activeTab=versions\">napi-postinstall<\/a> \u06a9\u0647 \u0647\u0645\u06af\u06cc \u062a\u0648\u0633\u0637 \u0647\u0645\u06cc\u0646 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u0645\u06cc\u200c\u0634\u062f\u0646\u062f \u0646\u06cc\u0632 \u0647\u062f\u0641 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0645\u0647\u0627\u062c\u0645 \u06cc\u0627 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u0633\u0631\u0642\u062a\u200c\u0634\u062f\u0647\u060c \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u0648 \u0622\u0644\u0648\u062f\u0647\u200c\u0627\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u0628\u0633\u062a\u0647\u200c\u0647\u0627 \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f\u0646\u062f \u06a9\u0647 \u062d\u0627\u0648\u06cc \u06a9\u062f\u0647\u0627\u06cc \u0645\u062e\u0631\u0628 \u0628\u0631\u0627\u06cc \u0622\u0644\u0648\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0633\u06cc\u0633\u062a\u0645\u200c\u0647\u0627\u06cc \u0648\u06cc\u0646\u062f\u0648\u0632\u06cc \u0628\u0648\u062f\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><strong>\u0641\u0631\u06cc\u0628 \u0646\u06af\u0647\u062f\u0627\u0631\u0646\u062f\u0647\u060c \u0646\u0641\u0648\u0630 \u0628\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627<\/strong><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u062a\u0627\u0631\u06cc\u062e \u06f1\u06f8 \u062c\u0648\u0644\u0627\u06cc\u060c \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u067e\u0633 \u0627\u0632 \u0646\u0635\u0628 \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u06f8\u066b\u06f1\u06f0\u066b\u06f1\u060c \u06f9\u066b\u06f1\u066b\u06f1\u060c \u06f1\u06f0\u066b\u06f1\u066b\u06f6 \u0648 \u06f1\u06f0\u066b\u06f1\u066b\u06f7 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u06cc eslint-config-prettier \u0645\u062a\u0648\u062c\u0647 \u0631\u0641\u062a\u0627\u0631\u0647\u0627\u06cc \u0645\u0634\u06a9\u0648\u06a9\u06cc \u0634\u062f\u0646\u062f. \u0627\u06cc\u0646 \u0646\u0633\u062e\u0647\u200c\u0647\u0627 \u062f\u0631 \u0645\u062e\u0632\u0646 npm \u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u0628\u0648\u062f\u0646\u062f\u060c \u0627\u0645\u0627 \u0647\u06cc\u0686 \u062a\u063a\u06cc\u06cc\u0631\u06cc \u0645\u062a\u0646\u0627\u0638\u0631 \u0628\u0627 \u0622\u0646\u200c\u0647\u0627 \u062f\u0631 \u0645\u062e\u0632\u0646 GitHub \u062b\u0628\u062a \u0646\u0634\u062f\u0647 \u0628\u0648\u062f\u060c \u06a9\u0647 \u0628\u0644\u0627\u0641\u0627\u0635\u0644\u0647 \u0645\u0648\u062c\u0628 \u062c\u0644\u0628 \u062a\u0648\u062c\u0647 \u0648 \u0634\u06a9 \u062c\u0627\u0645\u0639\u0647 \u0645\u062a\u0646\u200c\u0628\u0627\u0632 \u0634\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f eslint-config-prettier \u0648 eslint-plugin-prettier \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u06a9\u0647 \u0628\u0627 Prettier \u0648 ESLint \u0628\u0647\u200c\u0635\u0648\u0631\u062a \u0647\u0645\u0627\u0647\u0646\u06af \u06a9\u0627\u0631 \u06a9\u0631\u062f\u0647 \u0648 \u0642\u0648\u0627\u0639\u062f \u0642\u0627\u0644\u0628\u200c\u0628\u0646\u062f\u06cc \u06a9\u062f (code formatting rules) \u0631\u0627 \u062f\u0631 \u06a9\u0644 \u067e\u0631\u0648\u0698\u0647 \u0628\u062f\u0648\u0646 \u062a\u0636\u0627\u062f \u06cc\u0627 linting \u062a\u06a9\u0631\u0627\u0631\u06cc\u060c \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0646\u06af\u0647 \u062f\u0627\u0631\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647\u200c\u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 Dasa Paddock \u0627\u0648\u0644\u06cc\u0646 \u0628\u0627\u0631 \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 issue \u062f\u0631 \u0645\u062e\u0632\u0646 <a href=\"https:\/\/github.com\/prettier\/eslint-config-prettier\/issues\/339\">GitHub<\/a> \u0627\u06cc\u0646 \u067e\u0631\u0648\u0698\u0647\u060c \u0645\u0648\u0636\u0648\u0639 \u0631\u0627 \u0645\u0637\u0631\u062d \u06a9\u0631\u062f \u06a9\u0647 \u0628\u0627 \u0648\u0627\u06a9\u0646\u0634 \u0633\u0631\u06cc\u0639 \u0627\u0639\u0636\u0627\u06cc \u062c\u0627\u0645\u0639\u0647 \u0647\u0645\u0631\u0627\u0647 \u0634\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u06a9\u0645\u06cc \u0628\u0639\u062f\u060c \u0646\u06af\u0647\u062f\u0627\u0631\u0646\u062f\u0647 \u0628\u0633\u062a\u0647\u060c JounQin\u060c \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0631\u062f \u06a9\u0647 \u0642\u0631\u0628\u0627\u0646\u06cc \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0634\u062f\u0647 \u0627\u0633\u062a. \u0627\u06cc\u0646 \u062d\u0645\u0644\u0647 \u0645\u0646\u062c\u0631 \u0628\u0647 \u0627\u0641\u0634\u0627\u06cc \u062a\u0648\u06a9\u0646 npm \u0648\u06cc \u0634\u062f \u0648 \u0645\u0647\u0627\u062c\u0645 \u062a\u0648\u0627\u0646\u0633\u062a \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u0622\u0644\u0648\u062f\u0647 \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u06a9\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">JounQin \u062f\u0631 <a href=\"https:\/\/github.com\/prettier\/eslint-config-prettier\/issues\/339#issuecomment-3090304490\">GitHub<\/a> \u0646\u0648\u0634\u062a:<\/span><br \/>\n<span style=\"font-size: 10pt\">\u00ab\u0627\u06cc\u0646 \u0647\u0645\u0627\u0646 \u0627\u06cc\u0645\u06cc\u0644 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0628\u0648\u062f\u00bb\u060c \u0648 \u062a\u0635\u0648\u06cc\u0631\u06cc \u0627\u0632 \u0627\u06cc\u0645\u06cc\u0644 \u062c\u0639\u0644\u06cc \u0628\u0627 \u0639\u0646\u0648\u0627\u0646 &#8220;Verify your account&#8221; \u06a9\u0647 \u0638\u0627\u0647\u0631\u06cc \u0645\u0639\u062a\u0628\u0631 \u062f\u0627\u0634\u062a\u060c \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><img fetchpriority=\"high\" decoding=\"async\" class=\"alignnone  wp-image-19965\" src=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-300x178.jpg\" alt=\"\" width=\"530\" height=\"314\" srcset=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-300x178.jpg 300w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-1024x608.jpg 1024w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-768x456.jpg 768w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-1536x912.jpg 1536w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12-150x89.jpg 150w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/2-12.jpg 1540w\" sizes=\"(max-width: 530px) 100vw, 530px\" \/><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0627\u06cc\u0646 \u0627\u06cc\u0645\u06cc\u0644 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0628\u0647\u200c\u06af\u0648\u0646\u0647\u200c\u0627\u06cc spoof \u0634\u062f\u0647 \u0628\u0648\u062f \u06a9\u0647 \u06af\u0648\u06cc\u0627 \u0627\u0632 \u0622\u062f\u0631\u0633 &#8220;<a href=\"mailto:support@npmjs.com\">support@npmjs.com<\/a>&#8221; \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647\u060c \u0627\u0645\u0627 \u0644\u06cc\u0646\u06a9 \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0622\u0646\u060c \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647 \u062f\u0627\u0645\u0646\u0647 \u062c\u0639\u0644\u06cc npnjs[.]com \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc\u200c\u06a9\u0631\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">JounQin \u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0646\u0648\u0634\u062a:<\/span><br \/>\n<span style=\"font-size: 10pt\">\u00ab\u0645\u0646 \u062a\u0648\u06a9\u0646 npm \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0631\u062f\u0647\u200c\u0627\u0645 \u0648 \u0628\u0647\u200c\u0632\u0648\u062f\u06cc \u0646\u0633\u062e\u0647 \u062c\u062f\u06cc\u062f\u06cc \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f.\u00bb<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0627\u0648 \u062f\u0631 \u0647\u0645\u0627\u0646 \u0631\u0634\u062a\u0647 \u0627\u0641\u0632\u0648\u062f:<\/span><br \/>\n<span style=\"font-size: 10pt\">\u00ab\u0627\u0632 \u0647\u0645\u0647 \u0633\u067e\u0627\u0633\u06af\u0632\u0627\u0631\u0645 \u0648 \u0628\u0627\u0628\u062a \u0633\u0647\u0644\u200c\u0627\u0646\u06af\u0627\u0631\u06cc\u200c\u0627\u0645 \u0639\u0630\u0631\u062e\u0648\u0627\u0647\u06cc \u0645\u06cc\u200c\u06a9\u0646\u0645.\u00bb<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><strong>\u0627\u062c\u0631\u0627\u06cc<\/strong><strong> DLL <\/strong><strong>\u0645\u062e\u0631\u0628 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<\/strong><strong> postinstall<\/strong><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u0645\u062e\u0631\u0628 \u0645\u0646\u062a\u0634\u0631\u0634\u062f\u0647\u060c \u06cc\u06a9 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a npm postinstall \u0628\u0627 \u0646\u0627\u0645 &#8220;install.js&#8221; \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a \u062a\u0627 \u0628\u0644\u0627\u0641\u0627\u0635\u0644\u0647 \u067e\u0633 \u0627\u0632 \u0646\u0635\u0628 \u0628\u0633\u062a\u0647 \u0627\u062c\u0631\u0627 \u0634\u0648\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 &#8220;install.js&#8221; \u0634\u0627\u0645\u0644 \u062a\u0627\u0628\u0639\u06cc \u0645\u0634\u06a9\u0648\u06a9 \u0628\u0647 \u0646\u0627\u0645 logDiskSpace() \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u062e\u0644\u0627\u0641 \u0646\u0627\u0645\u0634\u060c \u0647\u06cc\u0686 \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u0628\u0627 \u067e\u0627\u06cc\u0634 \u0641\u0636\u0627\u06cc \u062f\u06cc\u0633\u06a9 \u0646\u062f\u0627\u0631\u062f. \u062f\u0631 \u0639\u0648\u0636\u060c \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u062a\u0644\u0627\u0634 \u0645\u06cc\u200c\u06a9\u0646\u062f \u062a\u0627 \u0641\u0627\u06cc\u0644 DLL \u0628\u0627 \u0646\u0627\u0645 &#8220;node-gyp.dll&#8221; \u06a9\u0647 \u062f\u0631\u0648\u0646 \u0628\u0633\u062a\u0647 \u06af\u0646\u062c\u0627\u0646\u062f\u0647 \u0634\u062f\u0647\u060c \u0627\u0632 \u0637\u0631\u06cc\u0642 \u067e\u0631\u062f\u0627\u0632\u0634 \u0633\u06cc\u0633\u062a\u0645\u06cc rundll32 \u062f\u0631 \u0648\u06cc\u0646\u062f\u0648\u0632 \u0627\u062c\u0631\u0627 \u06af\u0631\u062f\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><img decoding=\"async\" class=\"alignnone  wp-image-19966\" src=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4-300x147.jpg\" alt=\"\" width=\"559\" height=\"274\" srcset=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4-300x147.jpg 300w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4-1024x501.jpg 1024w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4-768x376.jpg 768w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4-150x73.jpg 150w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/3-4.jpg 1320w\" sizes=\"(max-width: 559px) 100vw, 559px\" \/><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u0632\u0645\u0627\u0646 \u0646\u06af\u0627\u0631\u0634 \u0627\u06cc\u0646 \u06af\u0632\u0627\u0631\u0634\u060c \u0641\u0627\u06cc\u0644 DLL \u0645\u0630\u06a9\u0648\u0631 \u06a9\u0647 \u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062a\u0631\u0648\u062c\u0627\u0646 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0634\u062f\u0647\u060c \u062f\u0631 \u0633\u0631\u0648\u06cc\u0633 <a href=\"https:\/\/www.virustotal.com\/gui\/file\/c68e42f416f482d43653f36cd14384270b54b68d6496a8e34ce887687de5b441\">VirusTotal<\/a> \u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u06f1\u06f9 \u0627\u0632 \u06f7\u06f2 \u0631\u0627 \u062f\u0627\u0631\u062f\u061b \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u0627 \u06a9\u0647 \u0647\u0646\u0648\u0632 \u0627\u06a9\u062b\u0631\u06cc\u062a \u0645\u0648\u062a\u0648\u0631\u0647\u0627\u06cc \u0622\u0646\u062a\u06cc\u200c\u0648\u06cc\u0631\u0648\u0633 \u0645\u0648\u0641\u0642 \u0628\u0647 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0622\u0646 \u0646\u0634\u062f\u0647\u200c\u0627\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><strong>\u0686\u0647 \u0627\u0642\u062f\u0627\u0645\u0627\u062a\u06cc \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f\u061f<\/strong><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0627\u0632 \u0646\u0635\u0628 \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u0632\u06cc\u0631 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0622\u0633\u06cc\u0628\u200c\u062f\u06cc\u062f\u0647 \u062e\u0648\u062f\u062f\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f:<\/span><\/p>\n<ul>\n<li><span style=\"font-size: 10pt\">eslint-config-prettier: \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u06f8\u066b\u06f1\u06f0\u066b\u06f1\u060c \u06f9\u066b\u06f1\u066b\u06f1\u060c \u06f1\u06f0\u066b\u06f1\u066b\u06f6 \u0648 \u06f1\u06f0\u066b\u06f1\u066b\u06f7<\/span><\/li>\n<li><span style=\"font-size: 10pt\">eslint-plugin-prettier: \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u06f4\u066b\u06f2\u066b\u06f2 \u0648 \u06f4\u066b\u06f2\u066b\u06f3<\/span><\/li>\n<li><span style=\"font-size: 10pt\">synckit: \u0646\u0633\u062e\u0647 \u06f0\u066b\u06f1\u06f1\u066b\u06f9<\/span><\/li>\n<li><span style=\"font-size: 10pt\">@pkgr\/core: \u0646\u0633\u062e\u0647 \u06f0\u066b\u06f2\u066b\u06f8<\/span><\/li>\n<li><span style=\"font-size: 10pt\">napi-postinstall: \u0646\u0633\u062e\u0647 \u06f0\u066b\u06f3\u066b\u06f1<\/span><\/li>\n<\/ul>\n<p><span style=\"font-size: 10pt\">\u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc package-lock.json \u06cc\u0627 yarn.lock \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0631\u0627\u06cc \u0648\u062c\u0648\u062f \u0627\u0631\u062c\u0627\u0639 \u0628\u0647 \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u0641\u0648\u0642 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u0635\u0648\u0631\u062a\u06cc\u200c\u06a9\u0647 \u0628\u06cc\u0644\u062f\u0647\u0627\u06cc\u06cc \u067e\u0633 \u0627\u0632 \u062a\u0627\u0631\u06cc\u062e \u06f1\u06f8 \u062c\u0648\u0644\u0627\u06cc \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u062f\u060c \u0644\u0627\u06af\u200c\u0647\u0627\u06cc CI \u0648 \u0645\u062d\u06cc\u0637\u200c\u0647\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc\u06cc (runtime) \u0631\u0627 \u0628\u0647\u200c\u0648\u06cc\u0698\u0647 \u062f\u0631 \u0633\u06cc\u0633\u062a\u0645\u200c\u0647\u0627\u06cc \u0648\u06cc\u0646\u062f\u0648\u0632\u06cc \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0627\u062d\u062a\u0645\u0627\u0644\u06cc \u0646\u0641\u0648\u0630 \u0628\u0631\u0631\u0633\u06cc \u0646\u0645\u0627\u06cc\u06cc\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u0646\u0638\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0647\u0631\u06af\u0648\u0646\u0647 secrets (\u062a\u0648\u06a9\u0646\u200c\u0647\u0627\u060c \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc API\u060c \u0631\u0645\u0632\u0647\u0627\u06cc \u0639\u0628\u0648\u0631 \u0648 &#8230;) \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062f\u0631 \u0641\u0631\u0622\u06cc\u0646\u062f build \u0622\u0633\u06cc\u0628\u200c\u062f\u06cc\u062f\u0647 \u0627\u0641\u0634\u0627 \u0634\u062f\u0647 \u0628\u0627\u0634\u0646\u062f \u0631\u0627 \u062a\u0639\u0648\u06cc\u0636 (rotate) \u06a9\u0646\u06cc\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0646\u06af\u0647\u062f\u0627\u0631\u0646\u062f\u0647 \u0628\u0633\u062a\u0647\u060c \u0646\u0633\u062e\u0647\u200c\u0647\u0627\u06cc \u0622\u0644\u0648\u062f\u0647 \u0631\u0627 \u062f\u0631 \u0645\u062e\u0632\u0646 npmjs \u0628\u0647\u200c\u0635\u0648\u0631\u062a \u0631\u0633\u0645\u06cc deprecated \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a. \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 GitHub \u0647\u0634\u062f\u0627\u0631 \u062f\u0627\u062f\u0647 \u06a9\u0647 \u062a\u0645\u0627\u0645\u06cc \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0645\u0646\u062a\u0634\u0631\u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0627\u06cc\u0646 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 \u0646\u06cc\u0632 \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u0627\u062d\u062a\u0645\u0627\u0644 \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u06cc\u0627 \u0622\u0644\u0648\u062f\u06af\u06cc \u0645\u0648\u0631\u062f \u0628\u0631\u0631\u0633\u06cc \u0642\u0631\u0627\u0631 \u06af\u06cc\u0631\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\"><img decoding=\"async\" class=\"alignnone  wp-image-19967\" src=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1-300x220.jpg\" alt=\"\" width=\"558\" height=\"409\" srcset=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1-300x220.jpg 300w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1-1024x750.jpg 1024w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1-768x563.jpg 768w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1-150x110.jpg 150w, https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/4-1.jpg 1376w\" sizes=\"(max-width: 558px) 100vw, 558px\" \/><\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u0627\u06cc\u0646 \u0646\u0641\u0648\u0630 \u062f\u0631 \u0627\u062f\u0627\u0645\u0647\u200c\u06cc \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0627\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a \u0645\u0647\u0646\u062f\u0633\u06cc \u0627\u062c\u062a\u0645\u0627\u0639\u06cc \u0645\u0634\u0627\u0628\u0647 \u0631\u062e \u062f\u0627\u062f\u0647 \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0645\u0627\u0647\u200c\u0647\u0627\u06cc \u0627\u062e\u06cc\u0631\u060c \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 \u0631\u0627 \u0647\u062f\u0641 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0647\u200c\u0627\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062f\u0631 \u0645\u0627\u0647 \u0645\u0627\u0631\u0633\u060c \u0628\u06cc\u0634 \u0627\u0632 \u062f\u0647 \u0628\u0633\u062a\u0647\u200c\u06cc \u067e\u0631\u06a9\u0627\u0631\u0628\u0631\u062f \u062f\u0631 \u0645\u062e\u0632\u0646 npm \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646\u062f \u0648 \u0628\u0647 info-stealer \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f. \u062f\u0631 \u0645\u0627\u0647 \u06af\u0630\u0634\u062a\u0647 \u0646\u06cc\u0632\u060c \u062a\u0639\u062f\u0627\u062f \u06f1\u06f7 \u0628\u0633\u062a\u0647 \u0627\u0632 Gluestack \u06a9\u0647 \u0645\u062c\u0645\u0648\u0639\u0627\u064b \u0628\u06cc\u0634 \u0627\u0632 \u06cc\u06a9 \u0645\u06cc\u0644\u06cc\u0648\u0646 \u0628\u0627\u0631 \u062f\u0631 \u0647\u0641\u062a\u0647 \u062f\u0627\u0646\u0644\u0648\u062f \u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u0628\u0647\u200c\u0645\u0646\u0638\u0648\u0631 \u0627\u0646\u062a\u0634\u0627\u0631 \u06cc\u06a9 Remote Access Trojan (RAT) \u0645\u0648\u0631\u062f \u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646\u062f.<\/span><\/p>\n<p><span style=\"font-size: 10pt\">\u062a\u0646\u0647\u0627 \u06cc\u06a9 \u06a9\u0644\u06cc\u06a9 \u0627\u0634\u062a\u0628\u0627\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0645\u06cc\u0644\u06cc\u0648\u0646\u200c\u0647\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062f\u0631 \u0645\u0639\u0631\u0636 \u062e\u0637\u0631 \u0642\u0631\u0627\u0631 \u062f\u0647\u062f.<\/span><\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f. \u0628\u0633\u062a\u0647\u200c\u06cc npm \u0628\u0627 \u0646\u0627\u0645 eslint-config-prettier \u06a9\u0647 \u0628\u0647\u200c\u0637\u0648\u0631 \u0647\u0641\u062a\u06af\u06cc \u0628\u06cc\u0634 \u0627\u0632 \u06f3\u06f0 \u0645\u06cc\u0644\u06cc\u0648\u0646 \u0628\u0627\u0631 \u062f\u0627\u0646\u0644\u0648\u062f \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u067e\u0633 \u0627\u0632 &hellip;<\/p>\n","protected":false},"author":14,"featured_media":19964,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[21,349],"tags":[],"class_list":["post-19960","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-news","category-slides"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v26.5 (Yoast SEO v27.6) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af - \u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646<\/title>\n<meta name=\"description\" content=\"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/\" \/>\n<meta property=\"og:locale\" content=\"fa_IR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af\" \/>\n<meta property=\"og:description\" content=\"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646\" \/>\n<meta property=\"article:published_time\" content=\"2025-07-20T07:04:21+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1600\" \/>\n\t<meta property=\"og:image:height\" content=\"900\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@liansecurity\" \/>\n<meta name=\"twitter:site\" content=\"@liansecurity\" \/>\n<meta name=\"twitter:label1\" content=\"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 \u062f\u0642\u06cc\u0642\u0647\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/\"},\"author\":{\"name\":\"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/#\\\/schema\\\/person\\\/e328f67a35a843fd3accc4666b5eab0a\"},\"headline\":\"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af\",\"datePublished\":\"2025-07-20T07:04:21+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/\"},\"wordCount\":86,\"commentCount\":0,\"image\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/07\\\/1-32.jpg\",\"articleSection\":[\"\u0627\u062e\u0628\u0627\u0631\",\"\u06cc\u06cc\u06cc\u06cc \u0627\u0633\u0644\u0627\u06cc\u062f\"],\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/\",\"url\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/\",\"name\":\"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af - \u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/07\\\/1-32.jpg\",\"datePublished\":\"2025-07-20T07:04:21+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/#\\\/schema\\\/person\\\/e328f67a35a843fd3accc4666b5eab0a\"},\"description\":\"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#breadcrumb\"},\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#primaryimage\",\"url\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/07\\\/1-32.jpg\",\"contentUrl\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/07\\\/1-32.jpg\",\"width\":1600,\"height\":900,\"caption\":\"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u062e\u0627\u0646\u0647\",\"item\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646\",\"description\":\"\u0622\u062e\u0631\u06cc\u0646 \u0627\u062e\u0628\u0627\u0631\u060c\u0645\u0642\u0627\u0644\u0627\u062a \u0648 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc \u062d\u0648\u0632\u0647 \u0627\u0645\u0646\u06cc\u062a \u0633\u0627\u06cc\u0628\u0631\u06cc\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"fa-IR\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/#\\\/schema\\\/person\\\/e328f67a35a843fd3accc4666b5eab0a\",\"name\":\"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc\",\"sameAs\":[\"https:\\\/\\\/liangroup.net\"],\"url\":\"https:\\\/\\\/liangroup.net\\\/blog\\\/author\\\/s-teymouri\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af - \u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646","description":"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/","og_locale":"fa_IR","og_type":"article","og_title":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af","og_description":"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.","og_url":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/","og_site_name":"\u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646","article_published_time":"2025-07-20T07:04:21+00:00","og_image":[{"width":1600,"height":900,"url":"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg","type":"image\/jpeg"}],"author":"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc","twitter_card":"summary_large_image","twitter_creator":"@liansecurity","twitter_site":"@liansecurity","twitter_misc":{"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a":"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc","\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646":"5 \u062f\u0642\u06cc\u0642\u0647"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#article","isPartOf":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/"},"author":{"name":"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc","@id":"https:\/\/liangroup.net\/blog\/#\/schema\/person\/e328f67a35a843fd3accc4666b5eab0a"},"headline":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af","datePublished":"2025-07-20T07:04:21+00:00","mainEntityOfPage":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/"},"wordCount":86,"commentCount":0,"image":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#primaryimage"},"thumbnailUrl":"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg","articleSection":["\u0627\u062e\u0628\u0627\u0631","\u06cc\u06cc\u06cc\u06cc \u0627\u0633\u0644\u0627\u06cc\u062f"],"inLanguage":"fa-IR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/","url":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/","name":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af - \u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646","isPartOf":{"@id":"https:\/\/liangroup.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#primaryimage"},"image":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#primaryimage"},"thumbnailUrl":"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg","datePublished":"2025-07-20T07:04:21+00:00","author":{"@id":"https:\/\/liangroup.net\/blog\/#\/schema\/person\/e328f67a35a843fd3accc4666b5eab0a"},"description":"\u062f\u0631 \u062c\u0631\u06cc\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 \u0632\u0646\u062c\u06cc\u0631\u0647 \u062a\u0623\u0645\u06cc\u0646 (Supply Chain Attack) \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af \u0647\u062f\u0641\u0645\u0646\u062f \u0648 \u0633\u0631\u0642\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 JavaScript \u0627\u06cc\u0646 \u0647\u0641\u062a\u0647 \u0645\u0648\u0631\u062f \u0646\u0641\u0648\u0630 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u0647 \u0646\u0627\u0634\u0631\u0627\u0646 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 (malware droppers) \u062a\u0628\u062f\u06cc\u0644 \u0634\u062f\u0646\u062f.","breadcrumb":{"@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#breadcrumb"},"inLanguage":"fa-IR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/"]}]},{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#primaryimage","url":"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg","contentUrl":"https:\/\/liangroup.net\/blog\/wp-content\/uploads\/2025\/07\/1-32.jpg","width":1600,"height":900,"caption":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af"},{"@type":"BreadcrumbList","@id":"https:\/\/liangroup.net\/blog\/popular-npm-linter-packages-hijacked-via-phishing-to-drop-malware\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u062e\u0627\u0646\u0647","item":"https:\/\/liangroup.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u0633\u0648\u0621\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0632 \u0628\u0633\u062a\u0647\u200c\u0647\u0627\u06cc \u0645\u062d\u0628\u0648\u0628 npm \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u062f\u0627\u0641\u0632\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0641\u06cc\u0634\u06cc\u0646\u06af"}]},{"@type":"WebSite","@id":"https:\/\/liangroup.net\/blog\/#website","url":"https:\/\/liangroup.net\/blog\/","name":"\u0628\u0644\u0627\u06af \u06af\u0631\u0648\u0647 \u0644\u06cc\u0627\u0646","description":"\u0622\u062e\u0631\u06cc\u0646 \u0627\u062e\u0628\u0627\u0631\u060c\u0645\u0642\u0627\u0644\u0627\u062a \u0648 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc \u062d\u0648\u0632\u0647 \u0627\u0645\u0646\u06cc\u062a \u0633\u0627\u06cc\u0628\u0631\u06cc","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/liangroup.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"fa-IR"},{"@type":"Person","@id":"https:\/\/liangroup.net\/blog\/#\/schema\/person\/e328f67a35a843fd3accc4666b5eab0a","name":"\u0633\u062c\u0627\u062f \u062a\u06cc\u0645\u0648\u0631\u06cc","sameAs":["https:\/\/liangroup.net"],"url":"https:\/\/liangroup.net\/blog\/author\/s-teymouri\/"}]}},"_links":{"self":[{"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/posts\/19960","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/users\/14"}],"replies":[{"embeddable":true,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/comments?post=19960"}],"version-history":[{"count":0,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/posts\/19960\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/media\/19964"}],"wp:attachment":[{"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/media?parent=19960"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/categories?post=19960"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/liangroup.net\/blog\/wp-json\/wp\/v2\/tags?post=19960"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}