Skip to content

Unzip

Unstable API 0.10.0 @project-lakechain/zip-processor TypeScript

The Zip inflate processor makes it possible to extract the content of Zip archives and map each file within them to other middlewares in a pipeline. This makes it possible for customers to process documents stored within Zip archives in a Lakechain pipeline.


🗄ī¸ Inflating Archives

To use this middleware, you import it in your CDK stack and connect it to a data source that provides Zip archives, such as the S3 Trigger if your Zip archives are stored in S3.

ℹī¸ The below example shows how to create a pipeline that inflates Zip archives uploaded to an S3 bucket.

import { S3EventTrigger } from '@project-lakechain/s3-event-trigger';
import { ZipInflateProcessor } from '@project-lakechain/zip-processor';
import { CacheStorage } from '@project-lakechain/core';
class Stack extends cdk.Stack {
constructor(scope: cdk.Construct, id: string) {
// Sample bucket.
const bucket = new s3.Bucket(this, 'Bucket', {});
// The cache storage.
const cache = new CacheStorage(this, 'Cache');
// Create the S3 event trigger.
const trigger = new S3EventTrigger.Builder()
.withScope(this)
.withIdentifier('Trigger')
.withCacheStorage(cache)
.withBucket(bucket)
.build();
// Create the Zip inflate processor.
const zipProcessor = new ZipInflateProcessor.Builder()
.withScope(this)
.withIdentifier('ZipProcessor')
.withCacheStorage(cache)
.withSource(trigger)
.build();
}
}

Streaming Processing

💁 The Zip inflate processor processes Zip archives in streaming, meaning that the compute driving archive inflation do not need to hold the entire archive in memory. This makes it possible to process large archives without having to worry about memory constraints.



🏗ī¸ Architecture

The Zip inflate processor uses AWS Lambda as a compute for inflating archives. The compute can run up to 15 minutes to extract the files part of a compressed archives, and provides the next middlewares in the pipeline with the extracted files.

Zip Inflate Architecture



🏷ī¸ Properties


Supported Inputs
Mime TypeDescription
application/zipZip archives
Supported Outputs
Mime TypeDescription
*/*The Zip inflate processor will publish each file within archives to the next middlewares in the pipeline.
Supported Compute Types
TypeDescription
CPUThis middleware only supports CPU compute.


📖 Examples