graphql-yoga
Version:
<div align="center"><img src="./website/public/cover.png" width="720" /></div>
31 lines (30 loc) • 1.22 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.isMatchingMediaType = exports.getMediaTypesForRequestInOrder = void 0;
function getMediaTypesForRequestInOrder(request) {
const accepts = (request.headers.get('accept') || '*/*')
.replace(/\s/g, '')
.toLowerCase()
.split(',');
const mediaTypes = [];
for (const accept of accepts) {
const [mediaType, ...params] = accept.split(';');
const charset = params?.find((param) => param.includes('charset=')) || 'charset=utf-8'; // utf-8 is assumed when not specified;
if (charset !== 'charset=utf-8') {
// only utf-8 is supported
continue;
}
mediaTypes.push(mediaType);
}
return mediaTypes.reverse();
}
exports.getMediaTypesForRequestInOrder = getMediaTypesForRequestInOrder;
function isMatchingMediaType(askedMediaType, processorMediaType) {
const [askedPre, askedSuf] = askedMediaType.split('/');
const [pre, suf] = processorMediaType.split('/');
if ((pre === '*' || pre === askedPre) && (suf === '*' || suf === askedSuf)) {
return true;
}
return false;
}
exports.isMatchingMediaType = isMatchingMediaType;
;