This run took 445 seconds.
$ date --- stdout --- Tue Jun 17 08:36:45 UTC 2025 --- end --- $ git clone file:///srv/git/mediawiki-services-citoid.git repo --depth=1 -b master --- stderr --- Cloning into 'repo'... --- stdout --- --- end --- $ git config user.name libraryupgrader --- stdout --- --- end --- $ git config user.email tools.libraryupgrader@tools.wmflabs.org --- stdout --- --- end --- $ git submodule update --init --- stdout --- --- end --- $ grr init --- stdout --- Installed commit-msg hook. --- end --- $ git show-ref refs/heads/master --- stdout --- 53618007f17f3731b88c24bf8dafc1f5ba4ac039 refs/heads/master --- end --- $ /usr/bin/npm audit --json --- stdout --- { "auditReportVersion": 2, "vulnerabilities": { "brace-expansion": { "name": "brace-expansion", "severity": "low", "isDirect": false, "via": [ { "source": 1105443, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=1.0.0 <=1.1.11" }, { "source": 1105444, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=2.0.0 <=2.0.1" } ], "effects": [], "range": "1.0.0 - 1.1.11 || 2.0.0 - 2.0.1", "nodes": [ "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion", "node_modules/brace-expansion", "node_modules/eslint-plugin-n/node_modules/brace-expansion", "node_modules/glob/node_modules/brace-expansion", "node_modules/mocha/node_modules/brace-expansion" ], "fixAvailable": true }, "ip": { "name": "ip", "severity": "high", "isDirect": true, "via": [ { "source": 1101851, "name": "ip", "dependency": "ip", "title": "ip SSRF improper categorization in isPublic", "url": "https://github.com/advisories/GHSA-2p57-rm9w-gvfp", "severity": "high", "cwe": [ "CWE-918" ], "cvss": { "score": 8.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H" }, "range": "<=2.0.1" } ], "effects": [], "range": "*", "nodes": [ "node_modules/ip" ], "fixAvailable": false }, "limitation": { "name": "limitation", "severity": "moderate", "isDirect": false, "via": [ "wikimedia-kad-fork" ], "effects": [ "service-runner" ], "range": ">=0.2.3", "nodes": [ "node_modules/limitation" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "ms": { "name": "ms", "severity": "moderate", "isDirect": false, "via": [ { "source": 1094419, "name": "ms", "dependency": "ms", "title": "Vercel ms Inefficient Regular Expression Complexity vulnerability", "url": "https://github.com/advisories/GHSA-w9mr-4mfr-499f", "severity": "moderate", "cwe": [ "CWE-1333" ], "cvss": { "score": 5.3, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L" }, "range": "<2.0.0" } ], "effects": [ "wikimedia-kad-fork" ], "range": "<2.0.0", "nodes": [ "node_modules/wikimedia-kad-fork/node_modules/ms" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "preq": { "name": "preq", "severity": "high", "isDirect": true, "via": [ "request", "requestretry" ], "effects": [], "range": "*", "nodes": [ "node_modules/preq" ], "fixAvailable": false }, "request": { "name": "request", "severity": "moderate", "isDirect": true, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "preq", "requestretry" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": false }, "requestretry": { "name": "requestretry", "severity": "high", "isDirect": false, "via": [ { "source": 1090420, "name": "requestretry", "dependency": "requestretry", "title": "Cookie exposure in requestretry", "url": "https://github.com/advisories/GHSA-hjp8-2cm3-cc45", "severity": "high", "cwe": [ "CWE-200" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N" }, "range": "<7.0.0" }, "request" ], "effects": [ "preq" ], "range": "*", "nodes": [ "node_modules/requestretry" ], "fixAvailable": false }, "service-runner": { "name": "service-runner", "severity": "moderate", "isDirect": true, "via": [ "limitation" ], "effects": [], "range": ">=3.1.0", "nodes": [ "node_modules/service-runner" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "swagger-ui-dist": { "name": "swagger-ui-dist", "severity": "moderate", "isDirect": true, "via": [ { "source": 1088759, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Spoofing attack in swagger-ui-dist", "url": "https://github.com/advisories/GHSA-6c9x-mj3g-h47x", "severity": "moderate", "cwe": [ "CWE-1021" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<4.1.3" }, { "source": 1092160, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Server side request forgery in SwaggerUI", "url": "https://github.com/advisories/GHSA-qrmm-w75w-3wpx", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 0, "vectorString": null }, "range": "<4.1.3" } ], "effects": [], "range": "<=4.1.2", "nodes": [ "node_modules/swagger-ui-dist" ], "fixAvailable": { "name": "swagger-ui-dist", "version": "5.24.2", "isSemVerMajor": true } }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "request" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": false }, "wikimedia-kad-fork": { "name": "wikimedia-kad-fork", "severity": "moderate", "isDirect": false, "via": [ "ms" ], "effects": [ "limitation" ], "range": "*", "nodes": [ "node_modules/wikimedia-kad-fork" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 1, "moderate": 7, "high": 3, "critical": 0, "total": 11 }, "dependencies": { "prod": 247, "dev": 397, "optional": 15, "peer": 1, "peerOptional": 0, "total": 657 } } } --- end --- $ /usr/bin/npm audit --json --- stdout --- { "auditReportVersion": 2, "vulnerabilities": { "brace-expansion": { "name": "brace-expansion", "severity": "low", "isDirect": false, "via": [ { "source": 1105443, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=1.0.0 <=1.1.11" }, { "source": 1105444, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=2.0.0 <=2.0.1" } ], "effects": [], "range": "1.0.0 - 1.1.11 || 2.0.0 - 2.0.1", "nodes": [ "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion", "node_modules/brace-expansion", "node_modules/eslint-plugin-n/node_modules/brace-expansion", "node_modules/glob/node_modules/brace-expansion", "node_modules/mocha/node_modules/brace-expansion" ], "fixAvailable": true }, "ip": { "name": "ip", "severity": "high", "isDirect": true, "via": [ { "source": 1101851, "name": "ip", "dependency": "ip", "title": "ip SSRF improper categorization in isPublic", "url": "https://github.com/advisories/GHSA-2p57-rm9w-gvfp", "severity": "high", "cwe": [ "CWE-918" ], "cvss": { "score": 8.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H" }, "range": "<=2.0.1" } ], "effects": [], "range": "*", "nodes": [ "node_modules/ip" ], "fixAvailable": false }, "limitation": { "name": "limitation", "severity": "moderate", "isDirect": false, "via": [ "wikimedia-kad-fork" ], "effects": [ "service-runner" ], "range": ">=0.2.3", "nodes": [ "node_modules/limitation" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "ms": { "name": "ms", "severity": "moderate", "isDirect": false, "via": [ { "source": 1094419, "name": "ms", "dependency": "ms", "title": "Vercel ms Inefficient Regular Expression Complexity vulnerability", "url": "https://github.com/advisories/GHSA-w9mr-4mfr-499f", "severity": "moderate", "cwe": [ "CWE-1333" ], "cvss": { "score": 5.3, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L" }, "range": "<2.0.0" } ], "effects": [ "wikimedia-kad-fork" ], "range": "<2.0.0", "nodes": [ "node_modules/wikimedia-kad-fork/node_modules/ms" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "preq": { "name": "preq", "severity": "high", "isDirect": true, "via": [ "request", "requestretry" ], "effects": [], "range": "*", "nodes": [ "node_modules/preq" ], "fixAvailable": false }, "request": { "name": "request", "severity": "moderate", "isDirect": true, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "preq", "requestretry" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": false }, "requestretry": { "name": "requestretry", "severity": "high", "isDirect": false, "via": [ { "source": 1090420, "name": "requestretry", "dependency": "requestretry", "title": "Cookie exposure in requestretry", "url": "https://github.com/advisories/GHSA-hjp8-2cm3-cc45", "severity": "high", "cwe": [ "CWE-200" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N" }, "range": "<7.0.0" }, "request" ], "effects": [ "preq" ], "range": "*", "nodes": [ "node_modules/requestretry" ], "fixAvailable": false }, "service-runner": { "name": "service-runner", "severity": "moderate", "isDirect": true, "via": [ "limitation" ], "effects": [], "range": ">=3.1.0", "nodes": [ "node_modules/service-runner" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "swagger-ui-dist": { "name": "swagger-ui-dist", "severity": "moderate", "isDirect": true, "via": [ { "source": 1088759, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Spoofing attack in swagger-ui-dist", "url": "https://github.com/advisories/GHSA-6c9x-mj3g-h47x", "severity": "moderate", "cwe": [ "CWE-1021" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<4.1.3" }, { "source": 1092160, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Server side request forgery in SwaggerUI", "url": "https://github.com/advisories/GHSA-qrmm-w75w-3wpx", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 0, "vectorString": null }, "range": "<4.1.3" } ], "effects": [], "range": "<=4.1.2", "nodes": [ "node_modules/swagger-ui-dist" ], "fixAvailable": { "name": "swagger-ui-dist", "version": "5.24.2", "isSemVerMajor": true } }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "request" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": false }, "wikimedia-kad-fork": { "name": "wikimedia-kad-fork", "severity": "moderate", "isDirect": false, "via": [ "ms" ], "effects": [ "limitation" ], "range": "*", "nodes": [ "node_modules/wikimedia-kad-fork" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 1, "moderate": 7, "high": 3, "critical": 0, "total": 11 }, "dependencies": { "prod": 247, "dev": 397, "optional": 15, "peer": 1, "peerOptional": 0, "total": 657 } } } --- end --- Attempting to npm audit fix $ /usr/bin/npm audit fix --dry-run --only=dev --json --- stderr --- npm WARN invalid config only="dev" set in command line options npm WARN invalid config Must be one of: null, prod, production npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: 'citoid@2.0.0', npm WARN EBADENGINE required: { node: '20' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } --- stdout --- { "added": 657, "removed": 0, "changed": 0, "audited": 658, "funding": 117, "audit": { "auditReportVersion": 2, "vulnerabilities": { "brace-expansion": { "name": "brace-expansion", "severity": "low", "isDirect": false, "via": [ { "source": 1105443, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=1.0.0 <=1.1.11" }, { "source": 1105444, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": [ "CWE-400" ], "cvss": { "score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L" }, "range": ">=2.0.0 <=2.0.1" } ], "effects": [], "range": "1.0.0 - 1.1.11 || 2.0.0 - 2.0.1", "nodes": [ "", "", "", "", "" ], "fixAvailable": true }, "ip": { "name": "ip", "severity": "high", "isDirect": true, "via": [ { "source": 1101851, "name": "ip", "dependency": "ip", "title": "ip SSRF improper categorization in isPublic", "url": "https://github.com/advisories/GHSA-2p57-rm9w-gvfp", "severity": "high", "cwe": [ "CWE-918" ], "cvss": { "score": 8.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H" }, "range": "<=2.0.1" } ], "effects": [], "range": "*", "nodes": [ "node_modules/ip" ], "fixAvailable": false }, "limitation": { "name": "limitation", "severity": "moderate", "isDirect": false, "via": [ "wikimedia-kad-fork" ], "effects": [ "service-runner" ], "range": ">=0.2.3", "nodes": [ "node_modules/limitation" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "ms": { "name": "ms", "severity": "moderate", "isDirect": false, "via": [ { "source": 1094419, "name": "ms", "dependency": "ms", "title": "Vercel ms Inefficient Regular Expression Complexity vulnerability", "url": "https://github.com/advisories/GHSA-w9mr-4mfr-499f", "severity": "moderate", "cwe": [ "CWE-1333" ], "cvss": { "score": 5.3, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L" }, "range": "<2.0.0" } ], "effects": [ "wikimedia-kad-fork" ], "range": "<2.0.0", "nodes": [ "node_modules/wikimedia-kad-fork/node_modules/ms" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "preq": { "name": "preq", "severity": "high", "isDirect": true, "via": [ "request", "requestretry" ], "effects": [], "range": "*", "nodes": [ "node_modules/preq" ], "fixAvailable": false }, "request": { "name": "request", "severity": "moderate", "isDirect": true, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "preq", "requestretry" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": false }, "requestretry": { "name": "requestretry", "severity": "high", "isDirect": false, "via": [ { "source": 1090420, "name": "requestretry", "dependency": "requestretry", "title": "Cookie exposure in requestretry", "url": "https://github.com/advisories/GHSA-hjp8-2cm3-cc45", "severity": "high", "cwe": [ "CWE-200" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N" }, "range": "<7.0.0" }, "request" ], "effects": [ "preq" ], "range": "*", "nodes": [ "node_modules/requestretry" ], "fixAvailable": false }, "service-runner": { "name": "service-runner", "severity": "moderate", "isDirect": true, "via": [ "limitation" ], "effects": [], "range": ">=3.1.0", "nodes": [ "node_modules/service-runner" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } }, "swagger-ui-dist": { "name": "swagger-ui-dist", "severity": "moderate", "isDirect": true, "via": [ { "source": 1088759, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Spoofing attack in swagger-ui-dist", "url": "https://github.com/advisories/GHSA-6c9x-mj3g-h47x", "severity": "moderate", "cwe": [ "CWE-1021" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<4.1.3" }, { "source": 1092160, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Server side request forgery in SwaggerUI", "url": "https://github.com/advisories/GHSA-qrmm-w75w-3wpx", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 0, "vectorString": null }, "range": "<4.1.3" } ], "effects": [], "range": "<=4.1.2", "nodes": [ "node_modules/swagger-ui-dist" ], "fixAvailable": { "name": "swagger-ui-dist", "version": "5.24.2", "isSemVerMajor": true } }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "request" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": false }, "wikimedia-kad-fork": { "name": "wikimedia-kad-fork", "severity": "moderate", "isDirect": false, "via": [ "ms" ], "effects": [ "limitation" ], "range": "*", "nodes": [ "node_modules/wikimedia-kad-fork" ], "fixAvailable": { "name": "service-runner", "version": "3.0.0", "isSemVerMajor": true } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 1, "moderate": 7, "high": 3, "critical": 0, "total": 11 }, "dependencies": { "prod": 247, "dev": 397, "optional": 15, "peer": 1, "peerOptional": 0, "total": 657 } } } } --- end --- {"added": 657, "removed": 0, "changed": 0, "audited": 658, "funding": 117, "audit": {"auditReportVersion": 2, "vulnerabilities": {"brace-expansion": {"name": "brace-expansion", "severity": "low", "isDirect": false, "via": [{"source": 1105443, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": ["CWE-400"], "cvss": {"score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L"}, "range": ">=1.0.0 <=1.1.11"}, {"source": 1105444, "name": "brace-expansion", "dependency": "brace-expansion", "title": "brace-expansion Regular Expression Denial of Service vulnerability", "url": "https://github.com/advisories/GHSA-v6h2-p8h4-qcjw", "severity": "low", "cwe": ["CWE-400"], "cvss": {"score": 3.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L"}, "range": ">=2.0.0 <=2.0.1"}], "effects": [], "range": "1.0.0 - 1.1.11 || 2.0.0 - 2.0.1", "nodes": ["", "", "", "", ""], "fixAvailable": true}, "ip": {"name": "ip", "severity": "high", "isDirect": true, "via": [{"source": 1101851, "name": "ip", "dependency": "ip", "title": "ip SSRF improper categorization in isPublic", "url": "https://github.com/advisories/GHSA-2p57-rm9w-gvfp", "severity": "high", "cwe": ["CWE-918"], "cvss": {"score": 8.1, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H"}, "range": "<=2.0.1"}], "effects": [], "range": "*", "nodes": ["node_modules/ip"], "fixAvailable": false}, "limitation": {"name": "limitation", "severity": "moderate", "isDirect": false, "via": ["wikimedia-kad-fork"], "effects": ["service-runner"], "range": ">=0.2.3", "nodes": ["node_modules/limitation"], "fixAvailable": {"name": "service-runner", "version": "3.0.0", "isSemVerMajor": true}}, "ms": {"name": "ms", "severity": "moderate", "isDirect": false, "via": [{"source": 1094419, "name": "ms", "dependency": "ms", "title": "Vercel ms Inefficient Regular Expression Complexity vulnerability", "url": "https://github.com/advisories/GHSA-w9mr-4mfr-499f", "severity": "moderate", "cwe": ["CWE-1333"], "cvss": {"score": 5.3, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}, "range": "<2.0.0"}], "effects": ["wikimedia-kad-fork"], "range": "<2.0.0", "nodes": ["node_modules/wikimedia-kad-fork/node_modules/ms"], "fixAvailable": {"name": "service-runner", "version": "3.0.0", "isSemVerMajor": true}}, "preq": {"name": "preq", "severity": "high", "isDirect": true, "via": ["request", "requestretry"], "effects": [], "range": "*", "nodes": ["node_modules/preq"], "fixAvailable": false}, "request": {"name": "request", "severity": "moderate", "isDirect": true, "via": [{"source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": ["CWE-918"], "cvss": {"score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N"}, "range": "<=2.88.2"}, "tough-cookie"], "effects": ["preq", "requestretry"], "range": "*", "nodes": ["node_modules/request"], "fixAvailable": false}, "requestretry": {"name": "requestretry", "severity": "high", "isDirect": false, "via": [{"source": 1090420, "name": "requestretry", "dependency": "requestretry", "title": "Cookie exposure in requestretry", "url": "https://github.com/advisories/GHSA-hjp8-2cm3-cc45", "severity": "high", "cwe": ["CWE-200"], "cvss": {"score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N"}, "range": "<7.0.0"}, "request"], "effects": ["preq"], "range": "*", "nodes": ["node_modules/requestretry"], "fixAvailable": false}, "service-runner": {"name": "service-runner", "severity": "moderate", "isDirect": true, "via": ["limitation"], "effects": [], "range": ">=3.1.0", "nodes": ["node_modules/service-runner"], "fixAvailable": {"name": "service-runner", "version": "3.0.0", "isSemVerMajor": true}}, "swagger-ui-dist": {"name": "swagger-ui-dist", "severity": "moderate", "isDirect": true, "via": [{"source": 1088759, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Spoofing attack in swagger-ui-dist", "url": "https://github.com/advisories/GHSA-6c9x-mj3g-h47x", "severity": "moderate", "cwe": ["CWE-1021"], "cvss": {"score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N"}, "range": "<4.1.3"}, {"source": 1092160, "name": "swagger-ui-dist", "dependency": "swagger-ui-dist", "title": "Server side request forgery in SwaggerUI", "url": "https://github.com/advisories/GHSA-qrmm-w75w-3wpx", "severity": "moderate", "cwe": ["CWE-918"], "cvss": {"score": 0, "vectorString": null}, "range": "<4.1.3"}], "effects": [], "range": "<=4.1.2", "nodes": ["node_modules/swagger-ui-dist"], "fixAvailable": {"name": "swagger-ui-dist", "version": "5.24.2", "isSemVerMajor": true}}, "tough-cookie": {"name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [{"source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": ["CWE-1321"], "cvss": {"score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N"}, "range": "<4.1.3"}], "effects": ["request"], "range": "<4.1.3", "nodes": ["node_modules/tough-cookie"], "fixAvailable": false}, "wikimedia-kad-fork": {"name": "wikimedia-kad-fork", "severity": "moderate", "isDirect": false, "via": ["ms"], "effects": ["limitation"], "range": "*", "nodes": ["node_modules/wikimedia-kad-fork"], "fixAvailable": {"name": "service-runner", "version": "3.0.0", "isSemVerMajor": true}}}, "metadata": {"vulnerabilities": {"info": 0, "low": 1, "moderate": 7, "high": 3, "critical": 0, "total": 11}, "dependencies": {"prod": 247, "dev": 397, "optional": 15, "peer": 1, "peerOptional": 0, "total": 657}}}} $ /usr/bin/npm audit fix --only=dev --- stderr --- npm WARN invalid config only="dev" set in command line options npm WARN invalid config Must be one of: null, prod, production npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: 'citoid@2.0.0', npm WARN EBADENGINE required: { node: '20' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } npm WARN deprecated kad-fs@0.0.4: This package is no longer maintained. npm WARN deprecated har-validator@5.1.5: this library is no longer supported npm WARN deprecated kad-memstore@0.0.1: This package is no longer maintained. npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142 --- stdout --- added 657 packages, and audited 658 packages in 9s 117 packages are looking for funding run `npm fund` for details # npm audit report ip * Severity: high ip SSRF improper categorization in isPublic - https://github.com/advisories/GHSA-2p57-rm9w-gvfp No fix available node_modules/ip ms <2.0.0 Severity: moderate Vercel ms Inefficient Regular Expression Complexity vulnerability - https://github.com/advisories/GHSA-w9mr-4mfr-499f fix available via `npm audit fix --force` Will install service-runner@3.0.0, which is a breaking change node_modules/wikimedia-kad-fork/node_modules/ms wikimedia-kad-fork * Depends on vulnerable versions of ms node_modules/wikimedia-kad-fork limitation >=0.2.3 Depends on vulnerable versions of wikimedia-kad-fork node_modules/limitation service-runner >=3.1.0 Depends on vulnerable versions of limitation node_modules/service-runner request * Severity: moderate Server-Side Request Forgery in Request - https://github.com/advisories/GHSA-p8p7-x288-28g6 Depends on vulnerable versions of tough-cookie No fix available node_modules/request preq * Depends on vulnerable versions of request Depends on vulnerable versions of requestretry node_modules/preq requestretry * Depends on vulnerable versions of request node_modules/requestretry swagger-ui-dist <=4.1.2 Severity: moderate Spoofing attack in swagger-ui-dist - https://github.com/advisories/GHSA-6c9x-mj3g-h47x Server side request forgery in SwaggerUI - https://github.com/advisories/GHSA-qrmm-w75w-3wpx fix available via `npm audit fix --force` Will install swagger-ui-dist@5.24.2, which is a breaking change node_modules/swagger-ui-dist tough-cookie <4.1.3 Severity: moderate tough-cookie Prototype Pollution vulnerability - https://github.com/advisories/GHSA-72xf-g2v4-qvf3 No fix available node_modules/tough-cookie 10 vulnerabilities (7 moderate, 3 high) To address all issues possible (including breaking changes), run: npm audit fix --force Some issues need review, and may require choosing a different dependency. --- end --- Verifying that tests still pass $ /usr/bin/npm ci --- stderr --- npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: 'citoid@2.0.0', npm WARN EBADENGINE required: { node: '20' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } npm WARN deprecated kad-fs@0.0.4: This package is no longer maintained. npm WARN deprecated har-validator@5.1.5: this library is no longer supported npm WARN deprecated kad-memstore@0.0.1: This package is no longer maintained. npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142 --- stdout --- added 657 packages, and audited 658 packages in 10s 117 packages are looking for funding run `npm fund` for details 10 vulnerabilities (7 moderate, 3 high) To address all issues possible (including breaking changes), run: npm audit fix --force Some issues need review, and may require choosing a different dependency. Run `npm audit` for details. --- end --- $ /usr/bin/npm test --- stdout --- > citoid@2.0.0 test > npm run lint && mocha ./test/features/unit/* && mocha ./test/features/errors/* && mocha ./test/features/app/* && mocha --exit ./test/features/scraping/* > citoid@2.0.0 lint > eslint --max-warnings 0 --cache . cachedTypes zotero methods ✔ returns false if no base types exist ✔ gets base types - no creators ✔ gets base types - with creators creator types methods ✔ gets creator type ids ✔ returns empty list if no create type ids exist ✔ gets primary creator id from type ✔ gets creator name from id ✔ gets primary creator id from name ✔ determines if creatorType valid for type- true ✔ determines if creatorType valid for type- false item fields methods ✔ determines if id is valid for type- false ✔ determines if id is valid for type- true ✔ determines if creator field is valid for type- true ✔ determines if creator field is valid for type- false ✔ get field id from type and base ✔ get base id from type and field ✔ get item type fields ✔ gets field name from id ✔ gets id from field name lib/Exporter.js functions: validation functions: fixURL: ✔ discards url with no host ✔ adds protocol to url when missing fixWebsiteTitle: ✔ Adds missing website title ✔ Does not add missing website title if itemType is missing ✔ Does not add missing website title if url is relative addIDSToCitation: ✔ cleans script and html out of title stripCitation: ✔ cleans script and html out of title ✔ does not clean doi fixDate: ✔ Contains copyright symbol ✔ Is in brackets for some unfathomable reason ✔ Contains copyright symbol & whitespace ✔ Contains c symbol ✔ sets year only date to year only date ✔ converts American style date to ISO ✔ Unable to parse so leaves as written; season (237ms) ✔ Chooses worldcat publication year ✔ Multilingual date - Spanish - leaves as written ✔ Multilingual date - Russian - leaves as written ✔ Normal date ✔ Normal date with ordinal indicator ✔ Correctly sets normal date with ordinal number ✔ Date on the fence: ISO with - notation ✔ Date on the fence; ISO with + notation ✔ Date on the fence; toString output ✔ Date on the fence; ISO with Z notation ✔ Year first date ✔ Partial ISO date no preceeding 0 ✔ Full ISO date no preceeding 0 ✔ Full ISO date no preceeding 0 month or day ✔ Slashes full date ✔ Slashes partial date ✔ Slashes partial date with 0 month - Slashes partial date with 00s ✔ Slashes partial year with 00s ✔ XX partial date ✔ XX partial year ✔ unix timestamp ✔ unix timestamp with space fixDOI: ✔ Correctly gets DOI from full citation ✔ Correctly removes DOI that is not a DOI ✔ Correctly gets DOI when only DOI is present fixISBN: ✔ Correctly hyphenates single ISBN-10 ✔ Correctly handles ISBN-13s that have spaces in them ✔ Correctly extracts two ISBN-10s ✔ Correctly extracts ISBN-13 ✔ Correctly extracts ISBN-10 and ISBN-13 ✔ Correctly handles and normalizes hyphenated ISBN ✔ Correctly handles ISBNs with and without hyphens ✔ Correctly handles multiple ISBN-13s that have spaces in them ✔ Correctly handles out comma separated ISBNs fixISSN: ✔ Correctly ignores None ISSN ✔ Correctly adds valid ISSN ✔ Correctly adds valid ISSN with X ✔ Correctly adds valid ISSN with x ✔ Correctly ignores invalid ISSN without hyphen ✔ Correctly ignores invalid ISSN fixPages: ✔ converts hyphen minus to en dash replaceCreators: ✔ Correctly adds name with firstName and lastName present ✔ Correctly adds names with only lastName or firstName present ✔ Adds names with name field ✔ Doesn't add names with incorrect field name export formats: wikibase: different search term types ✔ url from search, doi from result ✔ doi from search, no url ✔ qid, no url ✔ pmid, no url ✔ pmcid, no url different item types ✔ itemType webpage ✔ itemType book ✔ itemType journalArticle lib/Scraper.js functions: matchIDs function: ✔ gets doi from bePress string ✔ gets doi from bePress Array ✔ gets doi from highwirePress string ✔ gets doi from highwirePress Array ✔ gets doi from dublinCore string ✔ gets doi from dublinCore Array ✔ Returns empty metadata from empty object ✔ Multiple metadata types parsing ✔ should scrape meta tag charset content Tests for Translator.js : translate function on html: ✔ translates bePress metadata from movie file ✔ translates bePress metadata from article file ✔ translates bePress metadata from song file ✔ translates highwirePress metadata from movie file ✔ translates highwirePress metadata from article file ✔ translates highwirePress metadata from song file ✔ translates coins metadata from movie file ✔ translates coins metadata from article file ✔ translates coins metadata from song file ✔ translates dublinCore metadata from movie file ✔ translates dublinCore metadata from article file ✔ translates dublinCore metadata from song file ✔ translates general metadata from movie file ✔ translates general metadata from article file ✔ translates general metadata from song file ✔ translates openGraph metadata from movie file ✔ translates openGraph metadata from article file ✔ translates openGraph metadata from song file translate function on json: ✔ sets right info from journal-article crossRef metadata ✔ sets right info from book-section crossRef metadata ✔ tests every itemType for crossRef translator on every sample crossRef file addItemType function: ✔ sets videoRecording itemType ✔ sets article itemType ✔ sets audioRecording itemType from openGraph ✔ sets itemType webpage if no relevant metadata available check specific results: ✔ sets right info from webpage for general metadata ✔ sets right info from webpage for bepress metadata coins metadata ✔ Correctly adds pages from spage and epage ✔ Correctly fixes en dash in pages fields ✔ Correctly adds date exports.other.addCreators function ✔ Doesn't add empty creators field ✔ Doesn't add creators field if missing itemType - Doesn't add duplicate author names - Doesn't add duplicate author names with nbsp present ✔ Correctly adds name with missing firstname ✔ Correctly adds name with missing lastname ✔ Correctly uses aulast, auinit1 and auinitm ✔ Correctly uses auinit1 and auinitm ✔ Correctly adds corporation names ✔ Does split names in au field crossRef translator unit ✔ Creator translate function adds lists of strings dateParts function ✔ Translates full date ✔ Translates year and day ✔ Translates year only ✔ Fails with object ✔ Fails with list not nested ✔ Works with strings date - Does not work with unexpected input dublinCore translator unit ✔ Creator translate function adds lists of strings ✔ Correctly adds an author string with one word ✔ Correctly adds an author string with two words ✔ Correctly adds an author string with three words general translator unit ✔ Author function adds lists of strings ✔ Correctly adds an author string with one word ✔ Correctly adds an author string with two words ✔ Correctly adds an author string with three words ✔ Does not try to split Harry Potter author field from worldcat translator utilities: makeTranslator function: ✔ strips leading and trailing whitespace ✔ replaces nonbreaking space characters with spaces ✔ correctly adds date with fixDate validate function ✔ correctly uses fixLang validate function makePagesTranslator function: ✔ Uses spage and epage ✔ Uses optional pages arg and converts - to en dash makeListTranslator function: ✔ Correctly adds one isbn ✔ Correctly uses isbn validate function ✔ Correctly uses issn validate function ✔ Correctly adds two issn and one eissn ✔ Correctly adds two isbn makeCreatorsTranslator function: ✔ Name as written ✔ Has multiple authors in the field ✔ Format Last name, first name ✔ Adds two different contributor types lib/unshorten.js debug/unshorten Unshortening: http://www.example.com debug/unshorten Already unshortened to: http://www.example.com ✔ Returns successful Promise if already unshortened 166 passing (636ms) 4 pending address restrictions {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:37:22.533Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4a49b320-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2Flocalhost%3A1970","headers":{"user-agent":"undici","x-request-id":"4a49b320-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://localhost:1970"},"query":{"format":"mediawiki","search":"http://localhost:1970"},"remoteAddress":"127.0.0.1","remotePort":45818},"msg":"http://localhost:1970 is not public, and is disallowed","time":"2025-06-17T08:37:23.413Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://localhost:1970","outgoingReqResult":{"error":"AddressError"},"request_id":"4a49b320-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2Flocalhost%3A1970","headers":{"user-agent":"undici","x-request-id":"4a49b320-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://localhost:1970"},"query":{"format":"mediawiki","search":"http://localhost:1970"},"remoteAddress":"127.0.0.1","remotePort":45818},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:23.416Z","v":0} ✔ http://localhost:1970 (78ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4a4fcda0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F127.0.0.1%3A1970","headers":{"user-agent":"undici","x-request-id":"4a4fcda0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://127.0.0.1:1970"},"query":{"format":"mediawiki","search":"http://127.0.0.1:1970"},"remoteAddress":"127.0.0.1","remotePort":45818},"msg":"http://127.0.0.1:1970 is not public, and is disallowed","time":"2025-06-17T08:37:23.451Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://127.0.0.1:1970","outgoingReqResult":{"error":"AddressError"},"request_id":"4a4fcda0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F127.0.0.1%3A1970","headers":{"user-agent":"undici","x-request-id":"4a4fcda0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://127.0.0.1:1970"},"query":{"format":"mediawiki","search":"http://127.0.0.1:1970"},"remoteAddress":"127.0.0.1","remotePort":45818},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:23.452Z","v":0} ✔ http://127.0.0.1:1970 {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://foobarbaz.example.com/","outgoingReqResult":{"error":"AddressError"},"request_id":"4a512d30-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2Ffoobarbaz.example.com%2F","headers":{"user-agent":"undici","x-request-id":"4a512d30-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://foobarbaz.example.com/"},"query":{"format":"mediawiki","search":"http://foobarbaz.example.com/"},"remoteAddress":"127.0.0.1","remotePort":45812},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:23.470Z","v":0} ✔ non-existing {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4a539e30-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F10.0.0.5%2F","headers":{"user-agent":"undici","x-request-id":"4a539e30-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://10.0.0.5/"},"query":{"format":"mediawiki","search":"http://10.0.0.5/"},"remoteAddress":"127.0.0.1","remotePort":45812},"msg":"http://10.0.0.5/ is not public, and is disallowed","time":"2025-06-17T08:37:23.476Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://10.0.0.5/","outgoingReqResult":{"error":"AddressError"},"request_id":"4a539e30-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F10.0.0.5%2F","headers":{"user-agent":"undici","x-request-id":"4a539e30-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://10.0.0.5/"},"query":{"format":"mediawiki","search":"http://10.0.0.5/"},"remoteAddress":"127.0.0.1","remotePort":45812},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:23.477Z","v":0} ✔ 10.0.0.5 {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4a548890-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4a548890-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://192.168.1.2"},"query":{"format":"mediawiki","search":"http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45812},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-17T08:37:23.482Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"4a548890-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4a548890-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://192.168.1.2"},"query":{"format":"mediawiki","search":"http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45812},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:23.483Z","v":0} ✔ private ip {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4a5572f0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fen.wikipedia.org%2Fw%2Findex.php%3Ftitle%3DInternet_Assigned_Numbers_Authority%26oldid%3D664999436","headers":{"user-agent":"undici","x-request-id":"4a5572f0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436"},"query":{"format":"mediawiki","search":"https://en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436"},"remoteAddress":"127.0.0.1","remotePort":45812},"msg":"No Zot response available for https://en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436","time":"2025-06-17T08:37:24.521Z","v":0} ✔ acceptable domain, with scheme (1335ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4b214e70-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/en.wikipedia.org%2Fw%2Findex.php%3Ftitle%3DInternet_Assigned_Numbers_Authority%26oldid%3D664999436","headers":{"user-agent":"undici","x-request-id":"4b214e70-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436"},"query":{"format":"mediawiki","search":"en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436"},"remoteAddress":"127.0.0.1","remotePort":45812},"msg":"No Zot response available for https://en.wikipedia.org/w/index.php?title=internet_assigned_numbers_authority&oldid=664999436","time":"2025-06-17T08:37:25.029Z","v":0} ✔ acceptable domain, without scheme (388ms) encoding {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:37:25.218Z","v":0} ✔ javascript in format {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"4b60a160-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/10.1000%2Ff%3Cscript%3Ealert(1)%3B%3C%2Fscript%3E","headers":{"user-agent":"undici","x-request-id":"4b60a160-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/10.1000/f<script>alert(1);</script>"},"query":{"format":"mediawiki","search":"10.1000/f<script>alert(1);</script>"},"remoteAddress":"127.0.0.1","remotePort":45830},"msg":"Unknown pubmed error","time":"2025-06-17T08:37:25.278Z","v":0} ✔ javascript in doi (159ms) ✔ json in format {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://www.example.com/spaces%20in%20url","outgoingReqResult":{"status":404,"error":"HTTPError","hostname":"www.example.com","uri":"http://www.example.com/spaces%20in%20url"},"request_id":"4b79ceb0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2Fwww.example.com%2Fspaces%20in%20url","headers":{"user-agent":"undici","x-request-id":"4b79ceb0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://www.example.com/spaces in url"},"query":{"format":"mediawiki","search":"http://www.example.com/spaces in url"},"remoteAddress":"127.0.0.1","remotePort":45826},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:25.717Z","v":0} ✔ spaces in fully qualified url (323ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://www.example.com/spaces%20in%20url","outgoingReqResult":{"status":404,"error":"HTTPError","hostname":"www.example.com","uri":"http://www.example.com/spaces%20in%20url"},"request_id":"4bab6600-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/www.example.com%2Fspaces%20in%20url","headers":{"user-agent":"undici","x-request-id":"4bab6600-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/www.example.com/spaces in url"},"query":{"format":"mediawiki","search":"www.example.com/spaces in url"},"remoteAddress":"127.0.0.1","remotePort":45826},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:25.744Z","v":0} ✔ spaces in url missing http:// errors {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:37:25.752Z","v":0} ✔ missing search in query ✔ missing format in query ✔ bad format in query {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://example./com","outgoingReqResult":{"error":"AddressError"},"request_id":"4bb30720-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/example.%2Fcom","headers":{"user-agent":"undici","x-request-id":"4bb30720-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/example./com"},"query":{"format":"mediawiki","search":"example./com"},"remoteAddress":"127.0.0.1","remotePort":45844},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:25.781Z","v":0} ✔ bad domain {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://en.wikipedia.org/404","outgoingReqResult":{"status":404,"error":"HTTPError","hostname":"en.wikipedia.org","uri":"https://en.wikipedia.org/404"},"request_id":"4bb3ca70-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fen.wikipedia.org%2F404","headers":{"user-agent":"undici","x-request-id":"4bb3ca70-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://en.wikipedia.org/404"},"query":{"format":"mediawiki","search":"https://en.wikipedia.org/404"},"remoteAddress":"127.0.0.1","remotePort":45844},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:25.797Z","v":0} ✔ resource has http errors ✔ unknown doi (115ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://DOI.org/10.1007/11926078_68'","outgoingReqResult":{"status":404,"error":"HTTPError","hostname":"doi.org","uri":"https://doi.org/10.1007/11926078_68%27"},"request_id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://DOI.org/10.1007/11926078_68'"},"query":{"format":"mediawiki","search":"http://DOI.org/10.1007/11926078_68'"},"remoteAddress":"127.0.0.1","remotePort":45844},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:25.992Z","v":0} ✔ doi url with single quote (205ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for http://DOI.org/10.1007/11926078_68%22","outgoingReqResult":{"status":404,"error":"HTTPError","hostname":"doi.org","uri":"https://doi.org/10.1007/11926078_68%22"},"request_id":"4be7abb0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68%22","headers":{"user-agent":"undici","x-request-id":"4be7abb0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://DOI.org/10.1007/11926078_68\""},"query":{"format":"mediawiki","search":"http://DOI.org/10.1007/11926078_68\""},"remoteAddress":"127.0.0.1","remotePort":45844},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:26.189Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://DOI.org/10.1007/11926078_68'"},"query":{"format":"mediawiki","search":"http://DOI.org/10.1007/11926078_68'"},"remoteAddress":"127.0.0.1","remotePort":45844},"msg":"Unknown pubmed error","time":"2025-06-17T08:37:26.208Z","v":0} ✔ doi url with double quote (145ms) ✔ doi with single quote (77ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/CitoidService","request_id":"4c098b90-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fupload.wikimedia.org%2Fwikipedia%2Fcommons%2F9%2F98%2FColoring_page_for_Wikipedia_Day_2019_in_NYC.pdf","headers":{"user-agent":"undici","x-request-id":"4c098b90-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://upload.wikimedia.org/wikipedia/commons/9/98/Coloring_page_for_Wikipedia_Day_2019_in_NYC.pdf"},"query":{"format":"mediawiki","search":"https://upload.wikimedia.org/wikipedia/commons/9/98/Coloring_page_for_Wikipedia_Day_2019_in_NYC.pdf"},"remoteAddress":"127.0.0.1","remotePort":45844},"msg":"requestFromURL failed with 415 error","time":"2025-06-17T08:37:26.472Z","v":0} ✔ PDF contentType unsupported (134ms) - bad pmid - bad pmcid redirects {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:37:26.483Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4c20bd10-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"4c20bd10-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=http://www.example.com"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":45870},"msg":"No Zot response available for http://www.example.com","time":"2025-06-17T08:37:26.549Z","v":0} ✔ redirect supported (83ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4c2cf210-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c2cf210-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-17T08:37:26.584Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://httpbin.org/redirect-to?url=http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"4c2cf210-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c2cf210-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:26.584Z","v":0} ✔ redir-to-private {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4c2e78b0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c2e78b0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-17T08:37:26.600Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"4c2e78b0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c2e78b0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:26.600Z","v":0} ✔ redir-to-redir-private {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"4bfda4b0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"4bfda4b0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/10.1007/11926078_68'"},"query":{"format":"mediawiki","search":"10.1007/11926078_68'"},"remoteAddress":"127.0.0.1","remotePort":45844},"msg":"Unknown pubmed error","time":"2025-06-17T08:37:26.625Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4c30e9b0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3D%2Fredirect-to%3Furl%3Dhttp%3A%2F%2Fexample.com","headers":{"user-agent":"undici","x-request-id":"4c30e9b0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=/redirect-to?url=http://example.com"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=/redirect-to?url=http://example.com"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"No Zot response available for http://example.com","time":"2025-06-17T08:37:26.643Z","v":0} ✔ follows relative redirects (56ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"4c399c40-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c399c40-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-17T08:37:26.680Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"4c399c40-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"4c399c40-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=http://192.168.1.2"},"remoteAddress":"127.0.0.1","remotePort":45868},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:26.681Z","v":0} ✔ redir-to-redir-to-redir-to-private {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4c3d45c0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fen.wikipedia.org%2Fwiki%2FZotero","headers":{"user-agent":"undici","x-request-id":"4c3d45c0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"No Zot response available for https://en.wikipedia.org/wiki/Zotero","time":"2025-06-17T08:37:26.724Z","v":0} ✔ five-redirect-max-by-default-under (188ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"4c59f580-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fen.wikipedia.org%2Fwiki%2FZotero","headers":{"user-agent":"undici","x-request-id":"4c59f580-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"remoteAddress":"127.0.0.1","remotePort":45868},"msg":"No Zot response available for https://en.wikipedia.org/wiki/Zotero","time":"2025-06-17T08:37:26.933Z","v":0} ✔ five-redirect-max-by-default-equal (197ms) {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"msg":"requestFromURL failed for https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero","outgoingReqResult":{"error":"AddressError"},"request_id":"4c782be0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttps%3A%2F%2Fen.wikipedia.org%2Fwiki%2FZotero","headers":{"user-agent":"undici","x-request-id":"4c782be0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"query":{"format":"mediawiki","search":"https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://httpbin.org/redirect-to?url=https://en.wikipedia.org/wiki/Zotero"},"remoteAddress":"127.0.0.1","remotePort":45868},"levelPath":"warn/CitoidService","time":"2025-06-17T08:37:27.112Z","v":0} ✔ five-redirect-max-by-default-over (45ms) 30 passing (5s) 2 pending {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"4bc863e0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://DOI.org/10.1007/11926078_68'"},"query":{"format":"mediawiki","search":"http://DOI.org/10.1007/11926078_68'"},"remoteAddress":"127.0.0.1","remotePort":45844},"msg":"Unknown pubmed error","time":"2025-06-17T08:38:26.161Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"4be7abb0-4b56-11f0-bea2-6133c963e7ca","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68%22","headers":{"user-agent":"undici","x-request-id":"4be7abb0-4b56-11f0-bea2-6133c963e7ca"},"method":"GET","params":{"0":"/mediawiki/http://DOI.org/10.1007/11926078_68\""},"query":{"format":"mediawiki","search":"http://DOI.org/10.1007/11926078_68\""},"remoteAddress":"127.0.0.1","remotePort":45844},"msg":"Unknown pubmed error","time":"2025-06-17T08:38:26.366Z","v":0} citoid routing {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:38:27.110Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"70beaba0-4b56-11f0-8b82-434ad7c1baa8","request":{"url":"/api?format=mediawiki&search=http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"70beaba0-4b56-11f0-8b82-434ad7c1baa8"},"method":"GET","params":{"0":"/api"},"query":{"format":"mediawiki","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":51240},"msg":"No Zot response available for http://www.example.com","time":"2025-06-17T08:38:28.044Z","v":0} ✔ should get query style request for uri (192ms) ✔ should error for missing search param query style request {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"70d8ea60-4b56-11f0-8b82-434ad7c1baa8","request":{"url":"/api?format=mediawiki&search=10.1371%2Fjournal.pcbi.1002947","headers":{"user-agent":"undici","x-request-id":"70d8ea60-4b56-11f0-8b82-434ad7c1baa8"},"method":"GET","params":{"0":"/api"},"query":{"format":"mediawiki","search":"10.1371/journal.pcbi.1002947"},"remoteAddress":"127.0.0.1","remotePort":51226},"msg":"No Zot response available for https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1002947","time":"2025-06-17T08:38:28.574Z","v":0} ✔ should get query style request for doi (1364ms) {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"71a932b0-4b56-11f0-8b82-434ad7c1baa8","request":{"url":"/mediawiki/http%3A%2F%2Fexample.com","headers":{"user-agent":"undici","x-request-id":"71a932b0-4b56-11f0-8b82-434ad7c1baa8"},"method":"GET","params":{"0":"/mediawiki/http://example.com"},"query":{"format":"mediawiki","search":"http://example.com"},"remoteAddress":"127.0.0.1","remotePort":51226},"msg":"No Zot response available for http://example.com","time":"2025-06-17T08:38:29.623Z","v":0} ✔ should get restbase style request for uri (339ms) express app {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:38:29.811Z","v":0} ✔ should get robots.txt ✔ get landing page ✔ should set CORS headers ✔ should set CSP headers service information {"name":"citoid","hostname":"28851b2bd473","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:38:29.855Z","v":0} ✔ should get the service name ✔ should get the service version ✔ should redirect to the service home page ✔ should get the service info ✔ should fail to get the service info for invalid endpoint 13 passing (3s) correctly gets base fields instead of more specific fields (no zotero) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:39:00.378Z","v":0} ✔ webpage (155ms) Native scraper: {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:39:01.274Z","v":0} - doi in url with query parameters ✔ Adds extra parameters for archive.org (2332ms) Languages (no zotero): {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:39:03.618Z","v":0} ✔ open graph locale converted to language code (1386ms) ✔ non-native to node encoding in response (1345ms) - content-type header present in body but not in response headers - Language present in html tag mock Zotero service that cannot export {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:39:06.364Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"87a89b50-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/bibtex/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"87a89b50-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/bibtex/http://www.example.com"},"query":{"format":"bibtex","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":57984},"msg":"No Zot response available for http://www.example.com","time":"2025-06-17T08:39:06.427Z","v":0} ✔ Get error for bibtex export (94ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"87b67e00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"87b67e00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.example.com"},"query":{"format":"mediawiki","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":57972},"msg":"No Zot response available for http://www.example.com","time":"2025-06-17T08:39:06.473Z","v":0} ✔ Success with mediawiki export Zotero service down or disabled: unreachable {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:39:06.486Z","v":0} 1) PMID not in doi id converter api {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/CitoidService","request_id":"999e1470-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.26656%2Ffr.2017.4(s1).s12","headers":{"user-agent":"undici","x-request-id":"999e1470-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.26656/fr.2017.4(s1).s12"},"query":{"format":"mediawiki","search":"10.26656/fr.2017.4(s1).s12"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"requestFromURL failed with 415 error","time":"2025-06-17T08:39:36.851Z","v":0} ✔ doi that points to pdf (422ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"87bb11e0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/14656957","headers":{"user-agent":"undici","x-request-id":"87bb11e0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/14656957"},"query":{"format":"mediawiki","search":"14656957"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:40:06.752Z","v":0} 2) PMCID present in doi id converter api {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://www.jstor.org/discover/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"http://www.jstor.org/stable/10.2307/3677029"},"request_id":"abc069f0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"abc069f0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"levelPath":"warn/CitoidService","time":"2025-06-17T08:40:07.040Z","v":0} ✔ JSTOR page (301ms) - requires JS to be enabled {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"abee30b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdoi.org%2F10.1002%2Fjlac.18571010113","headers":{"user-agent":"undici","x-request-id":"abee30b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://doi.org/10.1002/jlac.18571010113"},"query":{"format":"mediawiki","search":"http://doi.org/10.1002/jlac.18571010113"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://chemistry-europe.onlinelibrary.wiley.com/doi/10.1002/jlac.18571010113","time":"2025-06-17T08:40:12.664Z","v":0} ✔ doi spage and epage fields in crossRef coins data (6822ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"affefe00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.microbiologyresearch.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.082289-0","headers":{"user-agent":"undici","x-request-id":"affefe00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"query":{"format":"mediawiki","search":"http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://www.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0","time":"2025-06-17T08:40:15.271Z","v":0} ✔ successfully uses highwire press metadata (2814ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b1ac86f0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fuknowledge.uky.edu%2Fupk_african_history%2F1%2F","headers":{"user-agent":"undici","x-request-id":"b1ac86f0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://uknowledge.uky.edu/upk_african_history/1/"},"query":{"format":"mediawiki","search":"http://uknowledge.uky.edu/upk_african_history/1/"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://uknowledge.uky.edu/upk_african_history/1/","time":"2025-06-17T08:40:17.323Z","v":0} ✔ successfully uses bepress press metadata alone (859ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0","outgoingReqResult":{"error":"AddressError"},"request_id":"b22f99a0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.sgmjournals.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.26954-0","headers":{"user-agent":"undici","x-request-id":"b22f99a0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"query":{"format":"mediawiki","search":"http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"remoteAddress":"127.0.0.1","remotePort":58004},"levelPath":"warn/CitoidService","time":"2025-06-17T08:40:17.733Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b22f99a0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.sgmjournals.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.26954-0","headers":{"user-agent":"undici","x-request-id":"b22f99a0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"query":{"format":"mediawiki","search":"http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://www.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.26954-0","time":"2025-06-17T08:40:18.285Z","v":0} ✔ Dead url with correct doi (1948ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b358fe70-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/bibtex/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"b358fe70-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/bibtex/http://www.example.com"},"query":{"format":"bibtex","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for http://www.example.com","time":"2025-06-17T08:40:19.692Z","v":0} ✔ Get error for bibtex export (56ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://www.jstor.org/discover/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"http://www.jstor.org/stable/10.2307/3677029"},"request_id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"levelPath":"warn/CitoidService","time":"2025-06-17T08:40:19.820Z","v":0} ✔ requires cookie handling (267ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b38a95c0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1038%2Fscientificamerican0200-90","headers":{"user-agent":"undici","x-request-id":"b38a95c0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1038/scientificamerican0200-90"},"query":{"format":"mediawiki","search":"10.1038/scientificamerican0200-90"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://www.scientificamerican.com/article/uprooting-the-tree-of-life/","time":"2025-06-17T08:40:20.719Z","v":0} ✔ DOI pointing to resource that can't be scraped - uses crossRef (841ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://dx.DOI.org/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"https://www.jstor.org/stable/3677029?origin=crossref"},"request_id":"b40ac240-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"b40ac240-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.DOI.org/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://dx.DOI.org/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"levelPath":"warn/CitoidService","time":"2025-06-17T08:40:20.965Z","v":0} ✔ dx.DOI link - uses crossRef (311ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"99de03a0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/PMC3605911","headers":{"user-agent":"undici","x-request-id":"99de03a0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/PMC3605911"},"query":{"format":"mediawiki","search":"PMC3605911"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1002947","time":"2025-06-17T08:40:24.393Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b43a36b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.14344%2FIOC.ML.4.4","headers":{"user-agent":"undici","x-request-id":"b43a36b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.14344/IOC.ML.4.4"},"query":{"format":"mediawiki","search":"10.14344/IOC.ML.4.4"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"No Zot response available for https://www.worldbirdnames.org/ioc-lists/crossref/","time":"2025-06-17T08:40:25.937Z","v":0} ✔ Case sensitive DOI with 5 digit registrant code and unknown genre in crossRef (6875ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b8536870-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1016%2FS0305-0491(98)00022-4","headers":{"user-agent":"undici","x-request-id":"b8536870-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1016/S0305-0491(98)00022-4"},"query":{"format":"mediawiki","search":"10.1016/S0305-0491(98)00022-4"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://linkinghub.elsevier.com/retrieve/pii/S0305049198000224","time":"2025-06-17T08:40:28.176Z","v":0} ✔ gets date from crossRef REST API (313ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"b8832b00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1017%2Fisbn-9780511132971.eh1-7","headers":{"user-agent":"undici","x-request-id":"b8832b00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1017/isbn-9780511132971.eh1-7"},"query":{"format":"mediawiki","search":"10.1017/isbn-9780511132971.eh1-7"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://hsus.cambridge.org/HSUSWeb/jsp/Intermediate.jsp?id=Eh1-7","time":"2025-06-17T08:40:30.140Z","v":0} ✔ gets editors from crossRef REST API for book-tract type (2548ms) ✔ gets proceedings from crossRef REST API (185ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"ba2457e0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.google.com","headers":{"user-agent":"undici","x-request-id":"ba2457e0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.google.com"},"query":{"format":"mediawiki","search":"http://www.google.com"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for http://www.google.com","time":"2025-06-17T08:40:31.093Z","v":0} ✔ uses original url (129ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"ba382e00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fblog.woorank.com%2F2013%2F04%2Fdublin-core-metadata-for-seo-and-usability%2F","headers":{"user-agent":"undici","x-request-id":"ba382e00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://blog.woorank.com/2013/04/dublin-core-metadata-for-seo-and-usability/"},"query":{"format":"mediawiki","search":"http://blog.woorank.com/2013/04/dublin-core-metadata-for-seo-and-usability/"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://www.woorank.com/en/blog/dublin-core-metadata-for-seo-and-usability","time":"2025-06-17T08:40:31.388Z","v":0} ✔ websiteTitle but no publicationTitle (264ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"ba609d90-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fapps.who.int%2Firis%2Fhandle%2F10665%2F70863","headers":{"user-agent":"undici","x-request-id":"ba609d90-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://apps.who.int/iris/handle/10665/70863"},"query":{"format":"mediawiki","search":"http://apps.who.int/iris/handle/10665/70863"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://iris.who.int/handle/10665/70863","time":"2025-06-17T08:40:32.943Z","v":0} ✔ dublinCore data with multiple identifiers in array (1759ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"bb6d2b90-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1017%2Fs0305004100013554","headers":{"user-agent":"undici","x-request-id":"bb6d2b90-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1017/s0305004100013554"},"query":{"format":"mediawiki","search":"10.1017/s0305004100013554"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://www.cambridge.org/core/journals/mathematical-proceedings-of-the-cambridge-philosophical-society/article/abs/discussion-of-probability-relations-between-separated-systems/C1C71E1AA5BA56EBE6588AAACB9A222D","time":"2025-06-17T08:40:35.980Z","v":0} ✔ has page range in direct scrape (4311ms) ✔ Only PMCID but no PMID or DOI; does not scrape (15531ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"c744f060-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1029%2F94WR00436","headers":{"user-agent":"undici","x-request-id":"c744f060-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1029/94WR00436"},"query":{"format":"mediawiki","search":"10.1029/94WR00436"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"No Zot response available for https://agupubs.onlinelibrary.wiley.com/doi/10.1029/94WR00436?cookieSet=1","time":"2025-06-17T08:40:53.502Z","v":0} ✔ DOI with redirect - Wiley (502ms) disabled in conf {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:40:53.608Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"abee30b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdoi.org%2F10.1002%2Fjlac.18571010113","headers":{"user-agent":"undici","x-request-id":"abee30b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://doi.org/10.1002/jlac.18571010113"},"query":{"format":"mediawiki","search":"http://doi.org/10.1002/jlac.18571010113"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:07.682Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:19.962Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"b36189f0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:20.057Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"b40ac240-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"b40ac240-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.DOI.org/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://dx.DOI.org/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:28.319Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"b8832b00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1017%2Fisbn-9780511132971.eh1-7","headers":{"user-agent":"undici","x-request-id":"b8832b00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1017/isbn-9780511132971.eh1-7"},"query":{"format":"mediawiki","search":"10.1017/isbn-9780511132971.eh1-7"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:28.577Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"affefe00-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.microbiologyresearch.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.082289-0","headers":{"user-agent":"undici","x-request-id":"affefe00-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"query":{"format":"mediawiki","search":"http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"remoteAddress":"127.0.0.1","remotePort":58004},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:29.616Z","v":0} 3) PMID not in doi id converter api {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/CitoidService","request_id":"df6eb310-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.26656%2Ffr.2017.4(s1).s12","headers":{"user-agent":"undici","x-request-id":"df6eb310-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.26656/fr.2017.4(s1).s12"},"query":{"format":"mediawiki","search":"10.26656/fr.2017.4(s1).s12"},"remoteAddress":"127.0.0.1","remotePort":57748},"msg":"requestFromURL failed with 415 error","time":"2025-06-17T08:41:33.923Z","v":0} ✔ doi that points to pdf (414ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/14656957","headers":{"user-agent":"undici","x-request-id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/14656957"},"query":{"format":"mediawiki","search":"14656957"},"remoteAddress":"127.0.0.1","remotePort":40710},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:53.894Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/14656957","headers":{"user-agent":"undici","x-request-id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/14656957"},"query":{"format":"mediawiki","search":"14656957"},"remoteAddress":"127.0.0.1","remotePort":40710},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:53.897Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/14656957","headers":{"user-agent":"undici","x-request-id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/14656957"},"query":{"format":"mediawiki","search":"14656957"},"remoteAddress":"127.0.0.1","remotePort":40710},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:53.901Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/14656957","headers":{"user-agent":"undici","x-request-id":"c79644b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/14656957"},"query":{"format":"mediawiki","search":"14656957"},"remoteAddress":"127.0.0.1","remotePort":40710},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:53.910Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"c744f060-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1029%2F94WR00436","headers":{"user-agent":"undici","x-request-id":"c744f060-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1029/94WR00436"},"query":{"format":"mediawiki","search":"10.1029/94WR00436"},"remoteAddress":"127.0.0.1","remotePort":56122},"msg":"Unknown pubmed error","time":"2025-06-17T08:41:56.418Z","v":0} 4) PMCID present in doi id converter api {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://www.jstor.org/discover/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"http://www.jstor.org/stable/10.2307/3677029"},"request_id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"levelPath":"warn/CitoidService","time":"2025-06-17T08:42:14.155Z","v":0} ✔ JSTOR page with tabs in natively scraped title (365ms) - requires JS to be enabled ✔ doi spage and epage fields in crossRef coins data (1375ms) ✔ successfully uses highwire press metadata (2694ms) ✔ successfully uses bepress press metadata alone (696ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0","outgoingReqResult":{"error":"AddressError"},"request_id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.sgmjournals.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.26954-0","headers":{"user-agent":"undici","x-request-id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"query":{"format":"mediawiki","search":"http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"remoteAddress":"127.0.0.1","remotePort":55108},"levelPath":"warn/CitoidService","time":"2025-06-17T08:42:19.199Z","v":0} ✔ Dead url with doi (1090ms) ✔ Get error for bibtex export (45ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://www.jstor.org/discover/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"http://www.jstor.org/stable/10.2307/3677029"},"request_id":"fb430730-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb430730-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"levelPath":"warn/CitoidService","time":"2025-06-17T08:42:20.412Z","v":0} ✔ requires cookie handling (255ms) ✔ DOI pointing to resource that can't be scraped - uses crossRef (333ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://dx.DOI.org/10.2307/3677029","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"www.jstor.org","uri":"https://www.jstor.org/stable/3677029?origin=crossref"},"request_id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.DOI.org/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://dx.DOI.org/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"levelPath":"warn/CitoidService","time":"2025-06-17T08:42:21.060Z","v":0} ✔ dx.DOI link - uses crossRef (292ms) ✔ Case sensitive DOI with 5 digit registrant code and unknown genre in crossRef (4413ms) ✔ gets date from crossRef REST API (270ms) ✔ gets editors from crossRef REST API for book-tract type (2382ms) ✔ gets proceedings from crossRef REST API (142ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"df6eb310-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.26656%2Ffr.2017.4(s1).s12","headers":{"user-agent":"undici","x-request-id":"df6eb310-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.26656/fr.2017.4(s1).s12"},"query":{"format":"mediawiki","search":"10.26656/fr.2017.4(s1).s12"},"remoteAddress":"127.0.0.1","remotePort":57748},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:33.901Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"dfad42b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/PMC3605911","headers":{"user-agent":"undici","x-request-id":"dfad42b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/PMC3605911"},"query":{"format":"mediawiki","search":"PMC3605911"},"remoteAddress":"127.0.0.1","remotePort":57748},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:34.283Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"dfad42b0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/PMC3605911","headers":{"user-agent":"undici","x-request-id":"dfad42b0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/PMC3605911"},"query":{"format":"mediawiki","search":"PMC3605911"},"remoteAddress":"127.0.0.1","remotePort":57748},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:34.293Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fe6b4940-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1016%2FS0305-0491(98)00022-4","headers":{"user-agent":"undici","x-request-id":"fe6b4940-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1016/S0305-0491(98)00022-4"},"query":{"format":"mediawiki","search":"10.1016/S0305-0491(98)00022-4"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:55.830Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"00161310-4b57-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/PMC2096233","headers":{"user-agent":"undici","x-request-id":"00161310-4b57-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/PMC2096233"},"query":{"format":"mediawiki","search":"PMC2096233"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:58.616Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"00161310-4b57-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/PMC2096233","headers":{"user-agent":"undici","x-request-id":"00161310-4b57-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/PMC2096233"},"query":{"format":"mediawiki","search":"PMC2096233"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:58.621Z","v":0} ✔ No PMID or DOI; does not scrape (30211ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"1217e840-4b57-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1029%2F94WR00436","headers":{"user-agent":"undici","x-request-id":"1217e840-4b57-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1029/94WR00436"},"query":{"format":"mediawiki","search":"10.1029/94WR00436"},"remoteAddress":"127.0.0.1","remotePort":53376},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:58.653Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"00001a10-4b57-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.4271%2F2015-01-0821","headers":{"user-agent":"undici","x-request-id":"00001a10-4b57-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.4271/2015-01-0821"},"query":{"format":"mediawiki","search":"10.4271/2015-01-0821"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:42:59.462Z","v":0} ✔ DOI with redirect - Wiley (1433ms) Freetext or ambiguous search, classified as "any" input type, i.e. title or citation Default config {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:43:00.072Z","v":0} ✔ spaces in url missing http:// and www (6627ms) ✔ json in search (7567ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:17.497Z","v":0} ✔ javascript in search (6269ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fb430730-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb430730-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:20.564Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fb6a1730-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1038%2Fscientificamerican0200-90","headers":{"user-agent":"undici","x-request-id":"fb6a1730-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1038/scientificamerican0200-90"},"query":{"format":"mediawiki","search":"10.1038/scientificamerican0200-90"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:20.796Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"f78785d0-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:21.444Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fbc9c360-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.14344%2FIOC.ML.4.4","headers":{"user-agent":"undici","x-request-id":"fbc9c360-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.14344/IOC.ML.4.4"},"query":{"format":"mediawiki","search":"10.14344/IOC.ML.4.4"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:21.449Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.DOI.org/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://dx.DOI.org/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:22.162Z","v":0} 5) localhost:1970 ✔ Open search for Schrodinger (2172ms) {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fb430730-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb430730-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/www.jstor.org/discover/10.2307/3677029"},"query":{"format":"mediawiki","search":"www.jstor.org/discover/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:27.740Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"fb9d3520-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.DOI.org/10.2307/3677029"},"query":{"format":"mediawiki","search":"http://dx.DOI.org/10.2307/3677029"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:28.402Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"f7bec270-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fdx.doi.org%2F10.1002%2Fjlac.18571010113","headers":{"user-agent":"undici","x-request-id":"f7bec270-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://dx.doi.org/10.1002/jlac.18571010113"},"query":{"format":"mediawiki","search":"http://dx.doi.org/10.1002/jlac.18571010113"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:33.311Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.sgmjournals.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.26954-0","headers":{"user-agent":"undici","x-request-id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"query":{"format":"mediawiki","search":"http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:34.621Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"f8909160-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.microbiologyresearch.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.082289-0","headers":{"user-agent":"undici","x-request-id":"f8909160-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"query":{"format":"mediawiki","search":"http://mic.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:34.625Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/http%3A%2F%2Fmic.sgmjournals.org%2Fcontent%2Fjournal%2Fmicro%2F10.1099%2Fmic.0.26954-0","headers":{"user-agent":"undici","x-request-id":"fa95fe50-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"query":{"format":"mediawiki","search":"http://mic.sgmjournals.org/content/journal/micro/10.1099/mic.0.26954-0"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:34.970Z","v":0} {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"levelPath":"warn/pubmed","request_id":"fe94a330-4b56-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/10.1017%2Fisbn-9780511132971.eh1-7","headers":{"user-agent":"undici","x-request-id":"fe94a330-4b56-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/10.1017/isbn-9780511132971.eh1-7"},"query":{"format":"mediawiki","search":"10.1017/isbn-9780511132971.eh1-7"},"remoteAddress":"127.0.0.1","remotePort":55108},"msg":"Unknown pubmed error","time":"2025-06-17T08:43:41.595Z","v":0} ✔ Open search containing <> works; but gets wrong results from crossRef (16568ms) ✔ Open search with www but no protocol (7419ms) - Open search with doi {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":40,"msg":"requestFromURL failed for http://hdl.handle.net/1902.1/UOVMCPSWOL","outgoingReqResult":{"status":403,"error":"HTTPError","hostname":"dataverse.harvard.edu","uri":"https://dataverse.harvard.edu/dataset.xhtml?persistentId=hdl:1902.1/UOVMCPSWOL"},"request_id":"314e0500-4b57-11f0-8948-1ba6fdb85a43","request":{"url":"/mediawiki/Frederico%20Girosi%3B%20Gary%20King%2C%202006%2C%20%E2%80%98Cause%20of%20Death%20Data%E2%80%99%2C%20http%3A%2F%2Fhdl.handle.net%2F1902.1%2FUOVMCPSWOL%20UNF%3A3%3A9JU%2BSmVyHgwRhAKclQ85Cg%3D%3D%20IQSS%20Dataverse%20Network%20%5BDistributor%5D%20V3%20%5BVersion%5D.","headers":{"user-agent":"undici","x-request-id":"314e0500-4b57-11f0-8948-1ba6fdb85a43"},"method":"GET","params":{"0":"/mediawiki/Frederico Girosi; Gary King, 2006, ‘Cause of Death Data’, http://hdl.handle.net/1902.1/UOVMCPSWOL UNF:3:9JU+SmVyHgwRhAKclQ85Cg== IQSS Dataverse Network [Distributor] V3 [Version]."},"query":{"format":"mediawiki","search":"Frederico Girosi; Gary King, 2006, ‘Cause of Death Data’, http://hdl.handle.net/1902.1/UOVMCPSWOL UNF:3:9JU+SmVyHgwRhAKclQ85Cg== IQSS Dataverse Network [Distributor] V3 [Version]."},"remoteAddress":"127.0.0.1","remotePort":46890},"levelPath":"warn/CitoidService","time":"2025-06-17T08:43:51.776Z","v":0} ✔ Open search with url (6063ms) ✔ Open search with single term (4402ms) ✔ Harry Potter (4712ms) Tests using a very short timeout - all use crossRef - zotero disabled {"name":"citoid","hostname":"28851b2bd473","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-17T08:44:06.176Z","v":0} DOI ✔ DOI- missing PMCID (109ms) ✔ direct DOI (41ms) ✔ DOI with redirect (54ms) - non-dx.DOI link with DOI pointing to resource in zotero with no DOI ✔ DOI pointing to resource in zotero with no DOI (55ms) - DOI.org link pointing to resource in zotero with no DOI ✔ DOI which requires cookie to properly follow redirect to Zotero (134ms) ✔ doi pointing to conferencePaper (95ms) - doi in url with query parameters ✔ doi with US style date (57ms) 58 passing (5m) 9 pending 5 failing 1) Zotero service down or disabled: unreachable PMID not in doi id converter api: Error: Timeout of 30000ms exceeded. For async tests and hooks, ensure "done()" is called; if returning a Promise, ensure it resolves. (/src/repo/test/features/scraping/no-zotero.js) at listOnTimeout (node:internal/timers:569:17) at process.processTimers (node:internal/timers:512:7) 2) Zotero service down or disabled: unreachable PMCID present in doi id converter api: Error: Timeout of 30000ms exceeded. For async tests and hooks, ensure "done()" is called; if returning a Promise, ensure it resolves. (/src/repo/test/features/scraping/no-zotero.js) at listOnTimeout (node:internal/timers:569:17) at process.processTimers (node:internal/timers:512:7) 3) Zotero service down or disabled: disabled in conf PMID not in doi id converter api: Error: Timeout of 40000ms exceeded. For async tests and hooks, ensure "done()" is called; if returning a Promise, ensure it resolves. (/src/repo/test/features/scraping/no-zotero.js) at listOnTimeout (node:internal/timers:569:17) at process.processTimers (node:internal/timers:512:7) 4) Zotero service down or disabled: disabled in conf PMCID present in doi id converter api: Error: Timeout of 40000ms exceeded. For async tests and hooks, ensure "done()" is called; if returning a Promise, ensure it resolves. (/src/repo/test/features/scraping/no-zotero.js) at listOnTimeout (node:internal/timers:569:17) at process.processTimers (node:internal/timers:512:7) 5) Freetext or ambiguous search, classified as "any" input type, i.e. title or citation Default config localhost:1970: Expected status to be 200, but was 500 + expected - actual -500 +200 at /src/repo/test/features/scraping/search.js:42:12 at process.processTicksAndRejections (node:internal/process/task_queues:95:5) --- end --- Traceback (most recent call last): File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 2026, in main libup.run(args.repo, args.output, args.branch) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 1968, in run self.npm_audit_fix(new_npm_audit) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 275, in npm_audit_fix self.npm_test() File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 325, in npm_test self.check_call(["npm", "test"]) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/shell2.py", line 63, in check_call res.check_returncode() File "/usr/lib/python3.11/subprocess.py", line 502, in check_returncode raise CalledProcessError(self.returncode, self.args, self.stdout, subprocess.CalledProcessError: Command '['/usr/bin/npm', 'test']' returned non-zero exit status 5.