/**
* @file codec-utils.js
*/
/**
* Check if a codec string refers to an audio codec.
*
* @param {String} codec codec string to check
* @return {Boolean} if this is an audio codec
* @private
*/
const isAudioCodec = function(codec) {
return (/mp4a\.\d+.\d+/i).test(codec);
};
/**
* Check if a codec string refers to a video codec.
*
* @param {String} codec codec string to check
* @return {Boolean} if this is a video codec
* @private
*/
const isVideoCodec = function(codec) {
return (/avc1\.[\da-f]+/i).test(codec);
};
/**
* Parse a content type header into a type and parameters
* object
*
* @param {String} type the content type header
* @return {Object} the parsed content-type
* @private
*/
const parseContentType = function(type) {
let object = {type: '', parameters: {}};
let parameters = type.trim().split(';');
// first parameter should always be content-type
object.type = parameters.shift().trim();
parameters.forEach((parameter) => {
let pair = parameter.trim().split('=');
if (pair.length > 1) {
let name = pair[0].replace(/"/g, '').trim();
let value = pair[1].replace(/"/g, '').trim();
object.parameters[name] = value;
}
});
return object;
};
export default {
isAudioCodec,
parseContentType,
isVideoCodec
};