@ridi/comic-parser
Common comic data parser for Ridibooks services
Features
Install
npm install @ridi/comic-parser
Usage
Basic:
import { ComicParser } from '@ridi/comic-parser';
const parser = new ComicParser('./foo/bar.zip' or './unzippedPath');
parser.parse().then((items) => {
parser.readItems(items).then((results) => {
...
});
...
});
with Cryptor:
import { CryptoProvider, Cryptor } from '@ridi/comic-parser';
const { Status } = CryptoProvider;
const { Modes, Padding } = Cryptor;
class ContentCryptoProvider extends CryptoProvider {
constructor(key) {
super();
this.cryptor = new Cryptor(Modes.ECB, { key, padding: Padding.PKCS7 });
}
run(data, filePath) {
if (this.status === Status.UNZIP) {
return this.encrypt(data);
} else if (this.status === Status.READ) {
return Buffer.from(this.decrypt(data));
}
return data;
}
encrypt(data, filePath) {
return this.cryptor.encrypt(data);
}
decrypt(data, filePath) {
return this.cryptor.decrypt(data);
}
}
const cryptoProvider = new ContentCryptoProvider(key);
const parser = new ComicParser('./foo/bar.zip' or './unzippedPath', cryptoProvider);
API
parse(parseOptions)
Returns Promise<Book>
with:
- Book: Instance with image path, size, etc.
Or throw exception.
readItem(item, readOptions)
Returns string
or Buffer
in Promise
with:
or throw exception.
readItems(items, readOptions)
Returns string[]
or Buffer[]
in Promise
with:
or throw exception.
Model
- index: ?string
- path: ?string
- size: ?number
Parse Options
unzipPath: ?string
If specified, uncompress to that path.
only using if input is Zip file.
Default: undefined
overwrite: boolean
If true, overwrite to unzipPath when uncompress.
only using if unzipPath specified.
Default: true
ext: string[]
File extension to allow when extracting lists.
Default: ['jpg', 'jpeg', 'png', 'bmp', 'gif']
Read Options
base64: boolean
If false, reads image into a buffer.
Default: false