$ date
--- stdout ---
Sat Jun 21 07:18:16 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 ---
53aab1b73fcf1e1b692fda94bc58e4855c9e82be refs/heads/master
--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
"auditReportVersion": 2,
"vulnerabilities": {
"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.25.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": 0,
"moderate": 7,
"high": 3,
"critical": 0,
"total": 10
},
"dependencies": {
"prod": 247,
"dev": 397,
"optional": 15,
"peer": 1,
"peerOptional": 0,
"total": 657
}
}
}
--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
"auditReportVersion": 2,
"vulnerabilities": {
"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.25.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": 0,
"moderate": 7,
"high": 3,
"critical": 0,
"total": 10
},
"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": {
"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.25.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": 0,
"moderate": 7,
"high": 3,
"critical": 0,
"total": 10
},
"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": {"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.25.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": 0, "moderate": 7, "high": 3, "critical": 0, "total": 10}, "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 8s
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.25.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 9s
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 (196ms)
✔ 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 (45ms)
✔ translates bePress metadata from song file
✔ translates highwirePress metadata from movie file
✔ translates highwirePress metadata from article file (39ms)
✔ 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 (582ms)
4 pending
address restrictions
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:18:49.306Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"fa96ab40-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2Flocalhost%3A1970","headers":{"user-agent":"undici","x-request-id":"fa96ab40-4e6f-11f0-befc-0904ed928ca2"},"method":"GET","params":{"0":"/mediawiki/http://localhost:1970"},"query":{"format":"mediawiki","search":"http://localhost:1970"},"remoteAddress":"127.0.0.1","remotePort":57212},"msg":"http://localhost:1970 is not public, and is disallowed","time":"2025-06-21T07:18:50.103Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for http://localhost:1970","outgoingReqResult":{"error":"AddressError"},"request_id":"fa96ab40-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2Flocalhost%3A1970","headers":{"user-agent":"undici","x-request-id":"fa96ab40-4e6f-11f0-befc-0904ed928ca2"},"method":"GET","params":{"0":"/mediawiki/http://localhost:1970"},"query":{"format":"mediawiki","search":"http://localhost:1970"},"remoteAddress":"127.0.0.1","remotePort":57212},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:50.107Z","v":0}
✔ http://localhost:1970 (90ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"faa159a0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F127.0.0.1%3A1970","headers":{"user-agent":"undici","x-request-id":"faa159a0-4e6f-11f0-befc-0904ed928ca2"},"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":57212},"msg":"http://127.0.0.1:1970 is not public, and is disallowed","time":"2025-06-21T07:18:50.172Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for http://127.0.0.1:1970","outgoingReqResult":{"error":"AddressError"},"request_id":"faa159a0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F127.0.0.1%3A1970","headers":{"user-agent":"undici","x-request-id":"faa159a0-4e6f-11f0-befc-0904ed928ca2"},"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":57212},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:50.173Z","v":0}
✔ http://127.0.0.1:1970
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for http://foobarbaz.example.com/","outgoingReqResult":{"error":"AddressError"},"request_id":"faa32e60-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2Ffoobarbaz.example.com%2F","headers":{"user-agent":"undici","x-request-id":"faa32e60-4e6f-11f0-befc-0904ed928ca2"},"method":"GET","params":{"0":"/mediawiki/http://foobarbaz.example.com/"},"query":{"format":"mediawiki","search":"http://foobarbaz.example.com/"},"remoteAddress":"127.0.0.1","remotePort":57200},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:50.194Z","v":0}
✔ non-existing
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"faa5c670-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F10.0.0.5%2F","headers":{"user-agent":"undici","x-request-id":"faa5c670-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"msg":"http://10.0.0.5/ is not public, and is disallowed","time":"2025-06-21T07:18:50.200Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for http://10.0.0.5/","outgoingReqResult":{"error":"AddressError"},"request_id":"faa5c670-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F10.0.0.5%2F","headers":{"user-agent":"undici","x-request-id":"faa5c670-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:50.201Z","v":0}
✔ 10.0.0.5
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"faa6b0d0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"faa6b0d0-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-21T07:18:50.206Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"faa6b0d0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2F192.168.1.2","headers":{"user-agent":"undici","x-request-id":"faa6b0d0-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:50.208Z","v":0}
✔ private ip
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"faa7c240-4e6f-11f0-befc-0904ed928ca2","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":"faa7c240-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"msg":"No Zot response available for https://en.wikipedia.org/w/index.php?title=Internet_Assigned_Numbers_Authority&oldid=664999436","time":"2025-06-21T07:18:50.422Z","v":0}
✔ acceptable domain, with scheme (492ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"faf2fc10-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/en.wikipedia.org%2Fw%2Findex.php%3Ftitle%3DInternet_Assigned_Numbers_Authority%26oldid%3D664999436","headers":{"user-agent":"undici","x-request-id":"faf2fc10-4e6f-11f0-befc-0904ed928ca2"},"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":57200},"msg":"No Zot response available for https://en.wikipedia.org/w/index.php?title=internet_assigned_numbers_authority&oldid=664999436","time":"2025-06-21T07:18:50.772Z","v":0}
✔ acceptable domain, without scheme (261ms)
encoding
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:18:50.972Z","v":0}
✔ javascript in format
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"fb1f1520-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/10.1000%2Ff%3Cscript%3Ealert(1)%3B%3C%2Fscript%3E","headers":{"user-agent":"undici","x-request-id":"fb1f1520-4e6f-11f0-befc-0904ed928ca2"},"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":57222},"msg":"Unknown pubmed error","time":"2025-06-21T07:18:51.033Z","v":0}
✔ javascript in doi (109ms)
✔ json in format
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fb30ef70-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2Fwww.example.com%2Fspaces%20in%20url","headers":{"user-agent":"undici","x-request-id":"fb30ef70-4e6f-11f0-befc-0904ed928ca2"},"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":57218},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.352Z","v":0}
✔ spaces in fully qualified url (249ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fb571510-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/www.example.com%2Fspaces%20in%20url","headers":{"user-agent":"undici","x-request-id":"fb571510-4e6f-11f0-befc-0904ed928ca2"},"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":57218},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.374Z","v":0}
✔ spaces in url missing http://
errors
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:18:51.384Z","v":0}
✔ missing search in query
✔ missing format in query
✔ bad format in query
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for https://example./com","outgoingReqResult":{"error":"AddressError"},"request_id":"fb5f0450-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/example.%2Fcom","headers":{"user-agent":"undici","x-request-id":"fb5f0450-4e6f-11f0-befc-0904ed928ca2"},"method":"GET","params":{"0":"/mediawiki/example./com"},"query":{"format":"mediawiki","search":"example./com"},"remoteAddress":"127.0.0.1","remotePort":57224},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.417Z","v":0}
✔ bad domain
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fb603cd0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/https%3A%2F%2Fen.wikipedia.org%2F404","headers":{"user-agent":"undici","x-request-id":"fb603cd0-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.444Z","v":0}
✔ resource has http errors
✔ unknown doi (55ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.555Z","v":0}
✔ doi url with single quote (122ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fb7ff9d0-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68%22","headers":{"user-agent":"undici","x-request-id":"fb7ff9d0-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:51.695Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"msg":"Unknown pubmed error","time":"2025-06-21T07:18:51.711Z","v":0}
✔ doi url with double quote (151ms)
✔ doi with single quote (87ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/http%3A%2F%2FDOI.org%2F10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"fb6d0e10-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"msg":"Unknown pubmed error","time":"2025-06-21T07:18:51.905Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/CitoidService","request_id":"fba423a0-4e6f-11f0-befc-0904ed928ca2","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":"fba423a0-4e6f-11f0-befc-0904ed928ca2"},"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":57224},"msg":"requestFromURL failed with 415 error","time":"2025-06-21T07:18:51.968Z","v":0}
✔ PDF contentType unsupported (109ms)
- bad pmid
- bad pmcid
redirects
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:18:51.977Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/pubmed","request_id":"fb96dd30-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/10.1007%2F11926078_68'","headers":{"user-agent":"undici","x-request-id":"fb96dd30-4e6f-11f0-befc-0904ed928ca2"},"method":"GET","params":{"0":"/mediawiki/10.1007/11926078_68'"},"query":{"format":"mediawiki","search":"10.1007/11926078_68'"},"remoteAddress":"127.0.0.1","remotePort":57224},"msg":"Unknown pubmed error","time":"2025-06-21T07:18:51.995Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"fbb75d80-4e6f-11f0-befc-0904ed928ca2","request":{"url":"/mediawiki/https%3A%2F%2Fhttpbin.org%2Fredirect-to%3Furl%3Dhttp%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"fbb75d80-4e6f-11f0-befc-0904ed928ca2"},"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":57254},"msg":"No Zot response available for http://www.example.com","time":"2025-06-21T07:18:52.060Z","v":0}
✔ redirect supported (106ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"fbc6ede0-4e6f-11f0-befc-0904ed928ca2","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":"fbc6ede0-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-21T07:18:52.101Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"msg":"requestFromURL failed for https://httpbin.org/redirect-to?url=http://192.168.1.2","outgoingReqResult":{"error":"AddressError"},"request_id":"fbc6ede0-4e6f-11f0-befc-0904ed928ca2","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":"fbc6ede0-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:52.102Z","v":0}
✔ redir-to-private
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"fbc89b90-4e6f-11f0-befc-0904ed928ca2","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":"fbc89b90-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-21T07:18:52.117Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fbc89b90-4e6f-11f0-befc-0904ed928ca2","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":"fbc89b90-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:52.118Z","v":0}
✔ redir-to-redir-private
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"fbcb0c90-4e6f-11f0-befc-0904ed928ca2","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":"fbcb0c90-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"No Zot response available for http://example.com","time":"2025-06-21T07:18:52.288Z","v":0}
✔ follows relative redirects (328ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/hostIsAllowed","request_id":"fbfd6730-4e6f-11f0-befc-0904ed928ca2","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":"fbfd6730-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"http://192.168.1.2 is not public, and is disallowed","time":"2025-06-21T07:18:52.478Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fbfd6730-4e6f-11f0-befc-0904ed928ca2","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":"fbfd6730-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:52.479Z","v":0}
✔ redir-to-redir-to-redir-to-private
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"fc027040-4e6f-11f0-befc-0904ed928ca2","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":"fc027040-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"No Zot response available for https://en.wikipedia.org/wiki/Zotero","time":"2025-06-21T07:18:52.720Z","v":0}
✔ five-redirect-max-by-default-under (383ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":434,"level":40,"levelPath":"warn/zotero","request_id":"fc3d0840-4e6f-11f0-befc-0904ed928ca2","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":"fc3d0840-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"msg":"No Zot response available for https://en.wikipedia.org/wiki/Zotero","time":"2025-06-21T07:18:52.922Z","v":0}
✔ five-redirect-max-by-default-equal (143ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"fc530140-4e6f-11f0-befc-0904ed928ca2","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":"fc530140-4e6f-11f0-befc-0904ed928ca2"},"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":57244},"levelPath":"warn/CitoidService","time":"2025-06-21T07:18:53.048Z","v":0}
✔ five-redirect-max-by-default-over (40ms)
30 passing (4s)
2 pending
citoid routing
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:18:58.557Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"001141c0-4e70-11f0-9b86-ff1f39345d97","request":{"url":"/api?format=mediawiki&search=http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"001141c0-4e70-11f0-9b86-ff1f39345d97"},"method":"GET","params":{"0":"/api"},"query":{"format":"mediawiki","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":45486},"msg":"No Zot response available for http://www.example.com","time":"2025-06-21T07:18:59.364Z","v":0}
✔ should get query style request for uri (154ms)
✔ should error for missing search param query style request
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"00253ef0-4e70-11f0-9b86-ff1f39345d97","request":{"url":"/api?format=mediawiki&search=10.1371%2Fjournal.pcbi.1002947","headers":{"user-agent":"undici","x-request-id":"00253ef0-4e70-11f0-9b86-ff1f39345d97"},"method":"GET","params":{"0":"/api"},"query":{"format":"mediawiki","search":"10.1371/journal.pcbi.1002947"},"remoteAddress":"127.0.0.1","remotePort":45476},"msg":"No Zot response available for https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1002947","time":"2025-06-21T07:18:59.738Z","v":0}
✔ should get query style request for doi (961ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":40,"levelPath":"warn/zotero","request_id":"00b7e200-4e70-11f0-9b86-ff1f39345d97","request":{"url":"/mediawiki/http%3A%2F%2Fexample.com","headers":{"user-agent":"undici","x-request-id":"00b7e200-4e70-11f0-9b86-ff1f39345d97"},"method":"GET","params":{"0":"/mediawiki/http://example.com"},"query":{"format":"mediawiki","search":"http://example.com"},"remoteAddress":"127.0.0.1","remotePort":45476},"msg":"No Zot response available for http://example.com","time":"2025-06-21T07:19:00.517Z","v":0}
✔ should get restbase style request for uri (302ms)
express app
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:00.690Z","v":0}
✔ should get robots.txt
✔ get landing page (1622ms)
✔ should set CORS headers
✔ should set CSP headers
service information
{"name":"citoid","hostname":"35bc01b7b0b3","pid":445,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:02.350Z","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 (4s)
correctly gets base fields instead of more specific fields (no zotero)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:06.497Z","v":0}
✔ webpage (187ms)
Native scraper:
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:07.270Z","v":0}
- doi in url with query parameters
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"msg":"requestFromURL failed for https://web.archive.org/web/20131021085548/http://www.nbcnews.com/health/75-percent-breast-milk-bought-online-contaminated-analysis-shows-8C11421794","outgoingReqResult":{"status":504,"error":"HTTPError","hostname":"web.archive.org","uri":"https://web.archive.org/web/20131021085548/http://www.nbcnews.com/health/75-percent-breast-milk-bought-online-contaminated-analysis-shows-8C11421794"},"request_id":"04d3f9f0-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/https%3A%2F%2Fweb.archive.org%2Fweb%2F20131021085548%2Fhttp%3A%2F%2Fwww.nbcnews.com%2Fhealth%2F75-percent-breast-milk-bought-online-contaminated-analysis-shows-8C11421794","headers":{"user-agent":"undici","x-request-id":"04d3f9f0-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/https://web.archive.org/web/20131021085548/http://www.nbcnews.com/health/75-percent-breast-milk-bought-online-contaminated-analysis-shows-8C11421794"},"query":{"format":"mediawiki","search":"https://web.archive.org/web/20131021085548/http://www.nbcnews.com/health/75-percent-breast-milk-bought-online-contaminated-analysis-shows-8C11421794"},"remoteAddress":"127.0.0.1","remotePort":47388},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:07.383Z","v":0}
1) Adds extra parameters for archive.org
Languages (no zotero):
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:07.400Z","v":0}
✔ open graph locale converted to language code (1463ms)
✔ non-native to node encoding in response (1165ms)
- 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":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:10.047Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"067d8b40-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/bibtex/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"067d8b40-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/bibtex/http://www.example.com"},"query":{"format":"bibtex","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":47436},"msg":"No Zot response available for http://www.example.com","time":"2025-06-21T07:19:10.090Z","v":0}
✔ Get error for bibtex export (62ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"068616c0-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"068616c0-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/http://www.example.com"},"query":{"format":"mediawiki","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":47426},"msg":"No Zot response available for http://www.example.com","time":"2025-06-21T07:19:10.131Z","v":0}
✔ Success with mediawiki export
Zotero service down or disabled:
unreachable
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:10.143Z","v":0}
✔ PMID not in doi id converter api (58ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/CitoidService","request_id":"0692e800-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.26656%2Ffr.2017.4(s1).s12","headers":{"user-agent":"undici","x-request-id":"0692e800-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"requestFromURL failed with 415 error","time":"2025-06-21T07:19:10.446Z","v":0}
✔ doi that points to pdf (375ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"06cbd250-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/PMC3605911","headers":{"user-agent":"undici","x-request-id":"06cbd250-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/PMC3605911"},"query":{"format":"mediawiki","search":"PMC3605911"},"remoteAddress":"127.0.0.1","remotePort":47448},"msg":"No Zot response available for https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1002947","time":"2025-06-21T07:19:10.920Z","v":0}
✔ PMCID present in doi id converter api (622ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"072ae240-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"072ae240-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:11.311Z","v":0}
✔ JSTOR page (273ms)
- requires JS to be enabled
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0754d870-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fdoi.org%2F10.1002%2Fjlac.18571010113","headers":{"user-agent":"undici","x-request-id":"0754d870-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://chemistry-europe.onlinelibrary.wiley.com/doi/10.1002/jlac.18571010113","time":"2025-06-21T07:19:11.917Z","v":0}
✔ doi spage and epage fields in crossRef coins data (967ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"07e865e0-4e70-11f0-bde5-8d3fe023e8b7","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":"07e865e0-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://www.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.082289-0","time":"2025-06-21T07:19:13.697Z","v":0}
✔ successfully uses highwire press metadata (2694ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"09837840-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fuknowledge.uky.edu%2Fupk_african_history%2F1%2F","headers":{"user-agent":"undici","x-request-id":"09837840-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://uknowledge.uky.edu/upk_african_history/1/","time":"2025-06-21T07:19:15.571Z","v":0}
✔ successfully uses bepress press metadata alone (783ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"09faf230-4e70-11f0-bde5-8d3fe023e8b7","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":"09faf230-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:15.934Z","v":0}
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"09faf230-4e70-11f0-bde5-8d3fe023e8b7","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":"09faf230-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://www.microbiologyresearch.org/content/journal/micro/10.1099/mic.0.26954-0","time":"2025-06-21T07:19:16.179Z","v":0}
✔ Dead url with correct doi (728ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0a6a2ec0-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/bibtex/http%3A%2F%2Fwww.example.com","headers":{"user-agent":"undici","x-request-id":"0a6a2ec0-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/bibtex/http://www.example.com"},"query":{"format":"bibtex","search":"http://www.example.com"},"remoteAddress":"127.0.0.1","remotePort":47448},"msg":"No Zot response available for http://www.example.com","time":"2025-06-21T07:19:16.673Z","v":0}
✔ Get error for bibtex export (43ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"0a70be70-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"0a70be70-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:16.775Z","v":0}
✔ requires cookie handling (235ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0a94c130-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.1038%2Fscientificamerican0200-90","headers":{"user-agent":"undici","x-request-id":"0a94c130-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/10.1038/scientificamerican0200-90"},"query":{"format":"mediawiki","search":"10.1038/scientificamerican0200-90"},"remoteAddress":"127.0.0.1","remotePort":47448},"msg":"No Zot response available for https://www.scientificamerican.com/article/uprooting-the-tree-of-life/","time":"2025-06-21T07:19:17.819Z","v":0}
✔ DOI pointing to resource that can't be scraped - uses crossRef (1011ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"0b2f5380-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"0b2f5380-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:18.108Z","v":0}
✔ dx.DOI link - uses crossRef (346ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0b644630-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.14344%2FIOC.ML.4.4","headers":{"user-agent":"undici","x-request-id":"0b644630-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://www.worldbirdnames.org/ioc-lists/crossref/","time":"2025-06-21T07:19:23.534Z","v":0}
✔ Case sensitive DOI with 5 digit registrant code and unknown genre in crossRef (5621ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0ebdf880-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.1016%2FS0305-0491(98)00022-4","headers":{"user-agent":"undici","x-request-id":"0ebdf880-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://linkinghub.elsevier.com/retrieve/pii/S0305049198000224","time":"2025-06-21T07:19:24.303Z","v":0}
✔ gets date from crossRef REST API (480ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"0f073680-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.1017%2Fisbn-9780511132971.eh1-7","headers":{"user-agent":"undici","x-request-id":"0f073680-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://hsus.cambridge.org/HSUSWeb/jsp/Intermediate.jsp?id=Eh1-7","time":"2025-06-21T07:19:26.107Z","v":0}
✔ gets editors from crossRef REST API for book-tract type (2283ms)
✔ gets proceedings from crossRef REST API (195ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"1081c890-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fwww.google.com","headers":{"user-agent":"undici","x-request-id":"1081c890-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/http://www.google.com"},"query":{"format":"mediawiki","search":"http://www.google.com"},"remoteAddress":"127.0.0.1","remotePort":47448},"msg":"No Zot response available for http://www.google.com","time":"2025-06-21T07:19:26.915Z","v":0}
✔ uses original url (140ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"10972550-4e70-11f0-bde5-8d3fe023e8b7","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":"10972550-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://www.woorank.com/en/blog/dublin-core-metadata-for-seo-and-usability","time":"2025-06-21T07:19:27.209Z","v":0}
✔ websiteTitle but no publicationTitle (273ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"10c0a650-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fapps.who.int%2Firis%2Fhandle%2F10665%2F70863","headers":{"user-agent":"undici","x-request-id":"10c0a650-4e70-11f0-bde5-8d3fe023e8b7"},"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":47448},"msg":"No Zot response available for https://iris.who.int/handle/10665/70863","time":"2025-06-21T07:19:29.033Z","v":0}
✔ dublinCore data with multiple identifiers in array (2000ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"11f22170-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.1017%2Fs0305004100013554","headers":{"user-agent":"undici","x-request-id":"11f22170-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/10.1017/s0305004100013554"},"query":{"format":"mediawiki","search":"10.1017/s0305004100013554"},"remoteAddress":"127.0.0.1","remotePort":47448},"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-21T07:19:30.871Z","v":0}
✔ has page range in direct scrape (2441ms)
✔ Only PMCID but no PMID or DOI; does not scrape (62ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/zotero","request_id":"13700ee0-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.1029%2F94WR00436","headers":{"user-agent":"undici","x-request-id":"13700ee0-4e70-11f0-bde5-8d3fe023e8b7"},"method":"GET","params":{"0":"/mediawiki/10.1029/94WR00436"},"query":{"format":"mediawiki","search":"10.1029/94WR00436"},"remoteAddress":"127.0.0.1","remotePort":47448},"msg":"No Zot response available for https://agupubs.onlinelibrary.wiley.com/doi/10.1029/94WR00436?cookieSet=1","time":"2025-06-21T07:19:32.168Z","v":0}
✔ DOI with redirect - Wiley (457ms)
disabled in conf
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:32.250Z","v":0}
✔ PMID not in doi id converter api (78ms)
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":40,"levelPath":"warn/CitoidService","request_id":"13c3fb40-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/10.26656%2Ffr.2017.4(s1).s12","headers":{"user-agent":"undici","x-request-id":"13c3fb40-4e70-11f0-bde5-8d3fe023e8b7"},"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":45132},"msg":"requestFromURL failed with 415 error","time":"2025-06-21T07:19:32.515Z","v":0}
✔ doi that points to pdf (216ms)
✔ PMCID present in doi id converter api (518ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"1433fb20-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fwww.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"1433fb20-4e70-11f0-bde5-8d3fe023e8b7"},"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":45132},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:33.176Z","v":0}
✔ JSTOR page with tabs in natively scraped title (276ms)
- requires JS to be enabled
✔ doi spage and epage fields in crossRef coins data (1013ms)
✔ successfully uses highwire press metadata (2679ms)
✔ successfully uses bepress press metadata alone (760ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"1705b8c0-4e70-11f0-bde5-8d3fe023e8b7","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":"1705b8c0-4e70-11f0-bde5-8d3fe023e8b7"},"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":45132},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:37.807Z","v":0}
✔ Dead url with doi (1031ms)
✔ Get error for bibtex export (93ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"17b18920-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/www.jstor.org%2Fdiscover%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"17b18920-4e70-11f0-bde5-8d3fe023e8b7"},"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":45132},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:39.037Z","v":0}
✔ requires cookie handling (286ms)
✔ DOI pointing to resource that can't be scraped - uses crossRef (273ms)
{"name":"citoid","hostname":"35bc01b7b0b3","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":"1806d510-4e70-11f0-bde5-8d3fe023e8b7","request":{"url":"/mediawiki/http%3A%2F%2Fdx.DOI.org%2F10.2307%2F3677029","headers":{"user-agent":"undici","x-request-id":"1806d510-4e70-11f0-bde5-8d3fe023e8b7"},"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":45132},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:39.669Z","v":0}
✔ dx.DOI link - uses crossRef (334ms)
✔ Case sensitive DOI with 5 digit registrant code and unknown genre in crossRef (1987ms)
✔ gets date from crossRef REST API (253ms)
✔ gets editors from crossRef REST API for book-tract type (2217ms)
✔ gets proceedings from crossRef REST API (85ms)
✔ No PMID or DOI; does not scrape (44ms)
✔ DOI with redirect - Wiley (4014ms)
Freetext or ambiguous search, classified as "any" input type, i.e. title or citation
Default config
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:48.429Z","v":0}
✔ spaces in url missing http:// and www (249ms)
✔ json in search (360ms)
✔ javascript in search (297ms)
✔ localhost:1970 (85ms)
✔ Open search for Schrodinger (195ms)
✔ Open search containing <> works; but gets wrong results from crossRef (196ms)
✔ Open search with www but no protocol (396ms)
- Open search with doi
{"name":"citoid","hostname":"35bc01b7b0b3","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":"1e6bf2a0-4e70-11f0-bde5-8d3fe023e8b7","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":"1e6bf2a0-4e70-11f0-bde5-8d3fe023e8b7"},"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":38024},"levelPath":"warn/CitoidService","time":"2025-06-21T07:19:50.966Z","v":0}
✔ Open search with url (955ms)
✔ Open search with single term (468ms)
✔ Harry Potter (49ms)
Tests using a very short timeout - all use crossRef - zotero disabled
{"name":"citoid","hostname":"35bc01b7b0b3","pid":456,"level":50,"levelPath":"error/metrics","msg":"No such metrics client: 'undefined'","time":"2025-06-21T07:19:51.694Z","v":0}
DOI
✔ DOI- missing PMCID (56ms)
✔ direct DOI (51ms)
✔ DOI with redirect
- non-dx.DOI link with DOI pointing to resource in zotero with no DOI
✔ DOI pointing to resource in zotero with no DOI (59ms)
- DOI.org link pointing to resource in zotero with no DOI
✔ DOI which requires cookie to properly follow redirect to Zotero (74ms)
✔ doi pointing to conferencePaper
- doi in url with query parameters
✔ doi with US style date (93ms)
62 passing (46s)
9 pending
1 failing
1) Native scraper:
Adds extra parameters for archive.org:
Error: HTTP 404: Not Found
at /src/repo/test/utils/server.js:141:20
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 1.