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

  • Inilah Cara Mengatasi OneDrive yang Suka Mengubah atau Menghapus Metadata File Kalian
  • Inilah Cara Menonaktifkan Antivirus Pihak Ketiga di Windows 11 dengan Aman
  • Inilah Cara Mengatur Raspberry Pi 5 dengan Ubuntu Server untuk Python dan Desktop GUI Tanpa Ribet
  • Inilah Alasan Kenapa Galaxy Z Fold 8 Ultra Bisa Jadi Produk yang Mengecewakan
  • Inilah Alasan Intel Merilis Raptor Lake Next di Socket LGA 1700, Masih Setia dengan DDR4!
  • Gini Caranya Menghilangkan Recycle Bin dari Desktop Windows 11 Supaya Lebih Bersih!
  • Inilah Huawei AirEngine 8771-X1T, Solusi Wi-Fi 7 Super Cepat untuk Bisnis Masa Kini
  • Inilah Cara Mengatasi Error Koneksi VMware Horizon Akibat Intersepsi SSL Proxy
  • Inilah Cara Mengatasi Connection Server Authentication Failed di VMware Horizon Client
  • Cara Laptop Nggak Lemot Pas Colok SD Card, Gampang Banget!
  • Inilah Caranya Mengatasi SD Card Reader yang Tidak Terbaca di Laptop
  • Inilah Cara Ampuh Atasi Perangkat USB yang Sering Terputus di Windows 10 dan 11
  • Cara Atasi USB Error dengan Update USB Root Hub dan Chipset Driver
  • Inilah Cara Mengatasi Unknown USB Device Descriptor Request Failed yang Paling Ampuh
  • Inilah 20 Kampus Swasta Terbaik di Bandung Versi EduRank 2026 untuk Referensi Kuliah Kalian
  • Inilah Syarat dan Cara Daftar Sekolah Kedinasan STPN 2026, Kuota Terbatas!
  • Inilah Cara Daftar PPKB UI 2026 Lengkap dengan Rincian Uang Pangkal Semua Jurusan S1
  • Inilah Aturan Resmi MPLS 2026 dari Kemendikdasmen, Guru dan Sekolah Wajib Catat Pedoman Lengkap Ini!
  • Inilah Cara Daftar Beasiswa S1/D4 Guru Kemendikdasmen 2026, Masa Pendaftaran Diperpanjang!
  • Inilah Cara Mengatasi Unknown USB Device (Device Descriptor Request Failed) dan Penjelasan Lengkapnya
  • Inilah Cara Membuat File Koneksi RDP Secara Manual Biar Akses Remote Kalian Nggak Error Lagi
  • Inilah Cara Clear RDP Cache dan Registry MRU Biar Remote Desktop Kalian Kembali Segar
  • Cara Restore File Association .rdp Agar Remote Desktop Bisa Terbuka Otomatis Lagi
  • Apa itu Probabilistic Methods dalam Klasifikasi Data?
  • Apa itu Klasifikasi Data dengan Metode Feature Selection?
  • Inilah Panduan Lengkap Jalur Afirmasi Disabilitas SPMB Kota Malang 2026, Simak Syarat dan Jadwalnya!
  • Inilah Cara Lengkap Daftar UM Undip 2026: Panduan Teknis, Jadwal, dan Syarat Biar Nggak Salah Langkah!
  • Inilah Daftar Kampus Swasta Terbaik di Indonesia 2026 Versi Webometrics dan QS WUR, Nggak Kalah Sama Negeri!
  • Inilah Cara Daftar PPKB UI 2026, Kesempatan Emas Masuk Kampus Jaket Kuning Tanpa Tes!
  • Inilah Tampilan Baru Aplikasi Cek Bansos Kemensos 2026, Cara Cek Status dan Nominal Bantuan yang Cair!
  • How to Sandboxing Browser on Linux Desktop with Flatpak
  • How to Hardening Journald on Linux Server (Fedora/AlmaLinux)
  • Block Bad USB on Linux Server with USBGuard
  • How to Secure NetworkManager on Fedora/AlmaLinux
  • How to Secure DNS and NTP in Fedora Linux
  • How to Automate Your Entire SEO Strategy Using a Swarm of 100 Free AI Agents Working in Parallel
  • How to create professional presentations easily using NotebookLM’s AI power for school projects and beyond
  • How to Master SEO Automation with Google Gemini 3.1 Flash-Lite in Google AI Studio
  • How to create viral AI video ads and complete brand assets using the Claude and Higgsfield MCP integration
  • How to Transform Your Mac Into a Supercharged AI Assistant with Perplexity Personal Computer
  • Inilah Update Pasar Saham AS 31 Mei 2026: Menakar Peluang S&P 500 dan Nasib Sektor Teknologi Saat Inflasi Belum Jinak
  • Sinyal Update Kondisi Pasar IHSG 31 Mei 2026: Strategi Cerdas Menghadapi Gejolak IHSG dan Rupiah di Awal Juni
  • Inilah Alasan Ilmiah Kenapa Kita Menguap, Ternyata Bukan Cuma Kurang Oksigen!
  • Inilah Alasan China Larang PR Berlebihan dan Ujian Berat, Ternyata Demi Kesehatan Mental Siswa!
  • Inilah Cara Cek Peluang Lolos SNBT Unair 2026 dan Daftar Lengkap Daya Tampungnya

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