@mediafish/flv

0.2.2 • Public • Published

Build Status Coverage Status Dependency Status Development Dependency Status Known Vulnerabilities npm Downloads XO code style

flv

A library to read/write Flash Video file format (only supports AAC/AVC)

Install

NPM

Usage

Example of reading FLV file

const {readFile, print} = require('@mediafish/flv');

const buf = fs.readFileSync('test.flv');
const [offset, flv] = readFile(buf, offset);
print(flv);
/*
FLVFile {
  FLVHeader: {
    version: 1,
    hasAudio: true,
    hasVideo: true
  },
  body: [
    FLVTag: {
      timestamp: 0,
      AVC: {
        frameType: 'keyframe',
        codec: 'AVC',
        packetType: 'NALU',
        data: <Buffer length=1024 >
      }
    },
    FLVTag: {
      timestamp: 0,
      AAC: {
        format: 'AAC',
        sampleRate: '44kHz',
        size: '16Bit',
        isStereo: true,
        packetType: 'raw',
        data: <Buffer length=1024 >
      }
    },
    ...
  ]
}
*/

Example of reading Video and Audio

const {readVideo, readAudio, print} = require('@mediafish/flv');

const [offset, video] = readVideo(buf1, offset);
print(video);
/*
AVC: {
  frameType: 'keyframe',
  codec: 'AVC',
  packetType: 'NALU',
  data: <Buffer length=1024 >
}
*/

const [offset, audio] = readAudio(buf2, offset);
print(audio);
/*
AAC: {
  format: 'AAC',
  sampleRate: '44kHz',
  size: '16Bit',
  isStereo: true,
  packetType: 'raw',
  data: <Buffer length=1024 >
}
*/

Example of writing FLV

const {writeData, type: {Video, AVC, Audio, AAC, FLVFile, FLVHeader, FLVTag}} = require('@mediafish/flv');

const video = new AVC({
  frameType: Video.FrameType.keyframe,
  codec: Video.Codec.AVC,
  packetType: AVC.PacketType.NALU,
  compositionTimeOffset: 0,
  data: buf1
});


const audio = new AAC({
  format: Audio.SoundFormat.AAC,
  sampleRate: Audio.SampleRate._44kHz,
  size: Audio.SampleLength._16Bit,
  isStereo: true,
  packetType: AAC.PacketType.Raw,
  data: buf2
});

const header = new FLVHeader({version: 1, hasAudio: true, hasVideo: true});

const tags = [
  new FLVTag({type: FLVTag.TagType.audio, timestamp: 0, data: audio}),
  new FLVTag({type: FLVTag.TagType.video, timestamp: 0, data: video})
];

const flv = new FLVFile(header, tags);

// First, pass null instead of a buffer to detect how many bytes are needed
const byteLength = writeData(flv, null, 0);
// And then alloc a buff
const buffer = Buffer.alloc(byteLength);
// Finally, write the data actually to the buffer
writeData(flv, buffer, 0);

Example of writing Video and Audio

const {writeData, type: {Video, AVC, Audio, AAC}} = require('@mediafish/flv');

const video = new AVC({
  frameType: Video.FrameType.keyframe,
  codec: Video.Codec.AVC,
  packetType: AVC.PacketType.NALU,
  compositionTimeOffset: 0,
  data: buf1
});


const audio = new AAC({
  format: Audio.SoundFormat.AAC,
  sampleRate: Audio.SampleRate._44kHz,
  size: Audio.SampleLength._16Bit,
  isStereo: true,
  packetType: AAC.PacketType.Raw,
  data: buf2
});

// First, pass null instead of a buffer to detect how many bytes are needed
const videoLength = writeData(video, null, 0);
const audioLength = writeData(audio, null, 0);
// And then alloc a buff
const buffer = Buffer.alloc(videoLength + audioLength);
// Finally, write the data actually to the buffer
let offset = 0;
offset = writeData(video, buffer, offset);
offset = writeData(audio, buffer, offset);

API

readFile(buffer, offset)

Read FLV file from the buffer

params

Name Type Required Default Description
buffer Buffer or Uint8Array Yes N/A The buffer from which the data is read
offset number Yes N/A An integer to specify the position within the buffer

return value

An array containing the following pair of values

Index Type Description
[0] number An integer to indicate the position from which the next data should be read
[1] FLVFile The read data (See Data format)

readVideo(buffer, offset, length)

Read video data from the buffer

params

Name Type Required Default Description
buffer Buffer or Uint8Array Yes N/A The buffer from which the data is read
offset number Yes N/A An integer to specify the position within the buffer
length number Yes N/A An integer to specify how many bytes to read

return value

An array containing the following pair of values

Index Type Description
[0] number An integer to indicate the position from which the next data should be read
[1] AVC The read data (See Data format)

readAudio(buffer, offset)

Read audio data from the buffer

params

Name Type Required Default Description
buffer Buffer or Uint8Array Yes N/A The buffer from which the data is read
offset number Yes N/A An integer to specify the position within the buffer
length number Yes N/A An integer to specify how many bytes to read

return value

An array containing the following pair of values

Index Type Description
[0] number An integer to indicate the position from which the next data should be read
[1] AAC The read data (See Data format)

writeData(data, buffer, offset)

Write data to the buffer

params

Name Type Required Default Description
data AVC/AAC/FLVHeader/FLVTag/FLVFile Yes N/A The data to be written to the buffer
buffer Buffer No null The buffer to which the data is written. If null, only the necessary buffer size is calculated
offset number Yes N/A An integer to specify the position within the buffer

return value

An integer to indicate the position from which the next data should be read

setOptions(obj)

Updates the option values

params

Name Type Required Default Description
obj Object Yes {} An object holding option values which will be used to overwrite the internal option values.
supported options
Name Type Default Description
strictMode boolean false If true, the function throws an error when the method invocations failed. If false, the function just logs the error and continues to run.

getOptions()

Retrieves the current option values

return value

A cloned object containing the current option values

Data format

This section describes the structure of the data that can be read / written using readFile/readAudio/readVideo

FLVFile

Property Type Description
header FLVHeader An instance of FLVHeader
body [FLVTag] An array of FLVTag

FLVHeader

Property Type Description
version number FLV version
hasAudio boolean Audio tags are present
hasVideo boolean Video tags are present

FLVTag

Property Type Description
type enum FLVTag.TagType Type of this tag
timestamp number Time in milliseconds at which the data in this tag applies
data Audio or Video An instance of Audio / Video

Audio

Property Type Description
format enum Audio.SoundFormat Type of this tag. Only AAC is supported.
sampleRate enum Audio.SampleRate sample rate
size enum Audio.SampleLength bits per sample
isStereo boolean mono / stereo
data Buffer or Uint8Array Format specific data.

AAC extends Audio

Property Type Description
packetType enum AAC.PacketType AAC packet type

Video

Property Type Description
frameType enum Video.FrameType Type of the frame included in this tag
codec enum Video.Codec Type of codec used to compress the frame. Only AVC is supported.
data Buffer or Uint8Array Codec specific data.

AVC extends Video

Property Type Description
packetType enum AVC.PacketType AVC packet type
compositionTimeOffset number Composition time offset

Readme

Keywords

Package Sidebar

Install

npm i @mediafish/flv

Weekly Downloads

1

Version

0.2.2

License

MIT

Unpacked Size

28.7 kB

Total Files

6

Last publish

Collaborators

  • kuu