Skip to content

emka.web.id

menulis pengetahuan – merekam peradaban

Menu
  • Home
  • Tutorial
  • Search
Menu

Buka dan Kelola File Tarball Langsung di Javascript, tanpa NodeJS

Posted on June 16, 2024

Dunia pemrograman web semakin berkembang pesat. Saat ini, JavaScript tidak hanya bisa berinteraksi dengan elemen antarmuka web, tapi juga mampu memproses file secara langsung! Artikel ini membahas mengenai pustaka JsExt, yang memungkinkan JavaScript untuk membuka dan mengelola file terkompresi berformat .tar (tarball) tanpa memerlukan server.

Melewati Batasan: Memproses Tarball dengan Javascript

Sebelumnya, memproses file tarball membutuhkan server untuk menjalankan program seperti tar. Namun, JsExt hadir sebagai solusi inovatif. Pustaka ini menyediakan API Tarball yang canggih, memungkinkan kita untuk memanipulasi file tarball secara langsung di Javascript.

API Tarball: Fleksibel dan Universal

API Tarball dirancang untuk menjadi fleksibel dan universal. Ia tidak hanya bisa mengekstrak file dari tarball, tetapi juga memungkinkan kita untuk menambah file baru, menghapus file yang ada, dan bahkan melihat daftar isi tarball, layaknya aplikasi pengelola file biasa.

Keunggulan Utama API Tarball:

  • Tidak Bergantung pada Server: API Tarball tidak bergantung pada pustaka atau runtime server tertentu. Ia memanfaatkan Web API modern, terutama ReadableStream, yang tersedia di semua browser dan runtime modern seperti Node.js, Deno, Bun, Cloudflare Workers, dan lain sebagainya.
  • Mudah Digunakan: JsExt menawarkan abstraksi yang mudah dipahami. Kita dapat berinteraksi dengan file tarball melalui API yang intuitif, tanpa perlu menulis kode rumit yang memanipulasi struktur file secara manual.
  • Beragam Fitur: API Tarball menyediakan berbagai fitur yang memudahkan pengelolaan file tarball, seperti:
    • Menambah file baru ke tarball
    • Menghapus file yang ada di tarball
    • Melihat daftar isi tarball (nama file, ukuran, dan lain-lain)
    • Menyimpan tarball yang sudah dimodifikasi

Memulai dengan JsExt

Untuk menggunakan API Tarball, kita perlu memuat pustaka JsExt terlebih dahulu. Metode pemuatan tergantung pada lingkungan pengembangan yang digunakan. Berikut beberapa contoh:

  • Node.js, Deno, Bun, Cloudflare Workers, dan Browser (dengan bundler atau import map):
import { Tarball } from "@ayonli/jsext/archive";
  • Deno dengan URL import:
import { Tarball } from "https://ayonli.github.io/jsext/archive.ts";
  • Browser dengan URL import:
import { Tarball } from "https://ayonli.github.io/jsext/esm/archive.js";

Membuat Instance Tarball

Ada dua cara untuk membuat instance Tarball:

  1. Membuat Tarball Kosong:
const tarball = new Tarball();
  1. Memuat File Tarball yang Ada:
// Memuat dari file system (termasuk OPFS di browser)
import { createReadableStream } from "@ayonli/jsext/fs";

const stream = createReadableStream("/file/to/archive.tar");
const tarball = await Tarball.load(stream);

// Memuat dari response HTTP
const res = await fetch("https://example.com/file/to/archive.tar");
const tarball = await Tarball.load(res.body!);

Menambahkan File ke Tarball

Setelah memiliki instance Tarball, kita bisa dengan mudah menambahkan file baru ke dalamnya. Bahkan, kita bisa menambah file ke tarball yang sudah terisi sebelumnya.

const file = new File(["Hello, World!"], "hello.txt", { type: "text/plain" });
tarball.appen(file);

Kita juga dapat menambahkan direktori atau file beserta jalurnya. JsExt akan secara otomatis membuat direktori yang diperlukan jika belum ada.

const file = new Blob(["This is some content"], { type: "text/plain" });
tarball.append(file, { relativePath: "foo/bar.txt" });

// Sekarang tarball akan memiliki direktori `foo` dan file `bar.txt` di dalamnya.

Mengelola File di Dalam Tarball

Kita bisa melihat daftar file yang ada di dalam tarball, atau bahkan mengambil isi dari sebuah file tertentu.

import { readAsText } from "@ayonli/jsext/reader";

const entry = tarball.retrieve("hello.txt")!;
const content = await readAsText(entry.stream);

console.log(content); // Hello,

Melanjutkan Jelajah Tarball dengan Javascript: Mengintip Isi dan Menyimpannya

Menjelajahi Isi Tarball

API Tarball menyediakan dua cara untuk melihat isi tarball:

  1. Iterasi Manual:
for (const entry of tarball) {
  if (entry.kind === "directory") {
    console.log(`Directory: ${entry.name}; Path: ${entry.relativePath}`);
  } else {
    console.log(`File: ${entry.name}; Path: ${entry.relativePath}; Size: ${entry.size}; Last-Modified: ${entry.mtime}`);
  }
}
  1. Tampilan Pohon:
const tree = tarball.treeView();
console.log(tree);

Menyimpan Tarball yang Telah Dimodifikasi

Sama seperti memuat tarball, kita dapat menyimpan tarball yang telah dimodifikasi ke file atau mengunggahnya ke URL.

// Menyimpan tarball ke file system (termasuk OPFS di browser)
import { createWritableStream } from "@ayonli/jsext/fs";

const stream = createWritableStream("/file/to/save.tar");
await tarball.stream().pipeTo(stream);

// Mengunggah tarball ke URL
const res = await fetch("https://example.com/path/to/save.tar", {
  method: "PUT",
  body: tarball.stream(),
  headers: {
    "Content-Type": "application/x-tar",
  },
});

Kompresi Tarball (Opsional)

Sebelum menyimpan tarball, kita dapat mengompresnya menjadi format .tar.gz untuk menghemat ruang penyimpanan.

const res = await fetch("https://example.com/path/to/save.tar.gz", {
  method: "PUT",
  body: tarball.stream({ gzip: true }),
  headers: {
    "Content-Type": "application/gzip",
  },
});

Fitur Tambahan API Tarball

API Tarball menyediakan beberapa fitur tambahan untuk mengelola file tarball, seperti:

  • remove: Menghapus file dari tarball
  • replace: Mengganti file yang sudah ada di tarball
  • stat: Mendapatkan informasi statistik tentang file di tarball

JsExt: Lebih dari Sekedar Tarball

JsExt adalah pustaka Javascript yang kaya akan fitur, tidak hanya untuk mengelola tarball. Berikut beberapa fitur menarik lainnya:

  • Fungsi bawaan untuk berbagai tipe data yang tidak tersedia secara default di Javascript
  • Fungsi utilitas untuk memperluas kontrol alur program
  • Pemrosesan multi-thread untuk Javascript
  • API file system untuk server dan browser
  • Kotak dialog terbuka di aplikasi CLI dan web
  • Manipulasi jalur file system dan URL dengan cara yang sama
  • Penanganan array byte dan aliran yang dapat dibaca dengan mudah
  • Pembuatan, ekstraksi, dan pratinjau arsip di semua runtime

JsExt dan API Tarball-nya membuka peluang baru bagi pengembang Javascript untuk mengelola file tarball secara langsung di browser atau server tanpa memerlukan server. Hal ini memungkinkan aplikasi web yang lebih canggih dan interaktif, seperti aplikasi pengelola file online atau alat kompresi file.

Terbaru

  • Ngefans Maxwell Clash of Champions? Begini Cara Masuk Saluran WA-nya Biar Update Terus!
  • Ini Cara Pakai greatonlinetools.com buat Nambah Likes dan Iseng ke Teman!
  • Cara Pakai Bug Token M7 Mobile Legends, Banjir Skin Prime Cuma Modal Browser!
  • Pusing Gagal Simpan Data Internet Dapodik 2026.b? Ini Trik Jitu Mengatasinya!
  • Mau Cuan Tambahan? Ini Cara Mudah Jadi Clipper di Ternak Klip Modal HP Doang!
  • Akun PTK Silang Merah di Dapodik 2026.b Bikin Panik? Jangan Dihapus, Coba Trik Ini Dulu!
  • Ini Trik Supaya Bisa Mancing Otomatis di Fish It Roblox Pakai GG Game Space
  • Sering Stuck Saat Registrasi Dapodik 2026.b? Coba Cara Offline Ini, Dijamin Lancar!
  • Belum Tahu? Ini Trik Isi Data Internet Dapodik 2026.B Biar Validasi Aman!
  • Belum Tahu? Inilah Cara Dapat Saldo E-Wallet Cuma Modal Tidur di Sleep Time Tracker
  • Padahal Negara Maju, Kenapa Selandia Baru Nggak Bangun Jembatan Antar Pulau? Ini Alasannya!
  • Nonton Drama Bisa Dapat 1 Juta? Cek Dulu Fakta dan Bukti Penarikan Aplikasi Gold Drama Ini!
  • Takut Saldo Habis? Gini Cara Stop Langganan CapCut Pro Sebelum Perpanjangan Otomatis
  • Gini Caranya Hilangkan Invalid Peserta Didik di Dapodik 2026 B Tanpa Ribet, Cuma Sekali Klik!
  • Rombel Hilang di Dapodik 2026 B? Tenang, Gini Cara Mudah Mengatasinya Tanpa Menu Aksi!
  • Pusing Lihat Ratusan Invalid Sarpras di Dapodik 2026 B? Tenang, Ini Cara Membereskan Datanya
  • Validasi Merah Terus? Ini Cara Tuntas Isi Data Listrik & Internet di Dapodik 2026 B
  • Inilah Trik Install Dapodik 2026.B Tanpa Patch, Wajib Uninstall Versi Lama!
  • Apakah APK PinjamAja Penipu?
  • Ini Trik Cepat Cuan di Clear Blast Tanpa Undang Teman
  • Belum Tahu? Inilah Suku Bajau Punya Gen “Mutan” Mirip Fishman One Piece, Ini Faktanya!
  • Inilah Paket PLTS Hybrid 6kVA Aspro DML 600 yang Paling Powerful!
  • Suku Tsaatan: Suku Mongolia Penggembala Rusa Kutub
  • Game Happy Rush Terbukti Membayar atau Cuma Scam Iklan?
  • Cara Nonton Drama Dapat Duit di Free Flick, Tapi Awas Jangan Sampai Tertipu Saldo Jutaan!
  • APK Pinjol Rajindompet Penipu? Ini Review Aslinya
  • Keganggu Iklan Pop-Up Indosat Pas Main Game? Ini Trik Ampuh Matikannya!
  • Belum Tahu? Inilah Cara Upload Reels Instagram Sampai 20 Menit, Konten Jadi Lebih Puas!
  • Apa itu Negara Somaliland? Apa Hubungannya dengan Israel?
  • Apa itu Game TheoTown? Game Simulasi Jadi Diktator
  • What is DeepSeek’s Engram?
  • How to Installing Zabbix 7.2 on Ubuntu 25.10 for Real-Time Monitoring
  • Review MySQL Database Recovery Tool by Stellar
  • RQuickShare Tutorial: How to Bring Android’s Quick Share Feature to Your Linux Desktop
  • Why Storage & Memory Price Surges | Self-hosting Podcast January 14th, 2026
  • Tutorial AI Lengkap Strategi Indexing RAG
  • Cara Membuat AI Voice Agent Cerdas untuk Layanan Pelanggan Menggunakan Vapi
  • Inilah Cara Belajar Cepat Model Context Protocol (MCP) Lewat 7 Proyek Open Source Terbaik
  • Inilah Cara Menguasai Tracing dan Evaluasi Aplikasi LLM Menggunakan LangSmith
  • Begini Cara Menggabungkan LLM, RAG, dan AI Agent untuk Membuat Sistem Cerdas
  • Kronologi Serangan Gentlemen Ransomware di Oltenia Energy
  • Apa itu CVE-2020-12812? Ini Penjelasan Celah Keamanan Fortinet FortiOS 2FA yang Masih Bahaya
  • Apa itu CVE-2025-14847? Ini Penjelasan Lengkap MongoBleed
  • Ini Kronologi & Resiko Kebocoran Data WIRED
  • Apa itu Grubhub Crypto Scam? Ini Pengertian dan Kronologi Penipuan yang Catut Nama Grubhub
Beli Pemotong Rumput dengan Baterai IRONHOOF 588V Mesin Potong Rumput 88V disini https://s.shopee.co.id/70DBGTHtuJ
Beli Morning Star Kursi Gaming/Kantor disini: https://s.shopee.co.id/805iTUOPRV

©2026 emka.web.id | Design: Newspaperly WordPress Theme