1.0.5 • Published 6 months ago

medium-exfiltrator v1.0.5

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

Medium Exfiltrator 🥷

Helps you clean up exported Medium posts into a nicer format, ready for use on your own blog or for backup purposes

Whether you want to keep backups, maintain your blog on the side of Medium, or even leave Medium altogether, this tool will help you.

Features:

  • Reformat posts:
    • Comes with improved, mobile-optimized CSS...
    • ...or replace the styling with your own CSS!
    • Remove all extraneous tag attributes, such as data-, name, IDs, and classes
    • Strip away the 12-character random string from the end of your HTML file name
    • Strip away the footer
    • Include or exclude drafts
  • Get all used images and use local image URLs instead of Medium's URLs
  • Also:
    • Zero dependencies
    • High test coverage

Here's a zoomed-out example of how a post could look:

Zoomed-out example of post after processing with Medium Exfiltrator

Prerequisites and good-to-know

You need to first export your Medium data, including posts, which is a prerequisite for this tool to do anything.

Note that it will not retrieve any articles—it will only reformat the posts you provide it with. However, if you choose to, you can opt into downloading all images from the posts—this is the only thing where this tool makes any outbound calls to Medium.

Installation

As dependency

Run npm install medium-exfiltrator --save-dev. See usage example below.

As source

Git clone this repository.

Run npm install to install.

Usage

import { MediumExfiltrator, MediumExfiltratorConfiguration } from 'medium-exfiltrator';

// Your own CSS you want to inject
// Medium Exfiltrator already comes with some improved default CSS
const css = `
h1 {
  font-size: 12rem;
}`

const config: MediumExfiltratorConfiguration = {
  // Required
  contentDirectory: 'posts',
  outputDirectory: 'posts-reformated',

  // Optional
  css,
  removeFooter: true,      // Default: false
  useOriginalHtml: false,  // Default: false
  useLocalImages: true,    // Default: false
  includeDrafts: false,    // Default: false
  stripRandom: true        // Default: false
};

// Create instance
const exfil = new MediumExfiltrator(config);
// Run it
exfil.exfiltrate();

Note that if you want to retain the exact same styling and HTML as the original Medium post, then you need to set useOriginalHtml: true.

1.0.5

6 months ago

1.0.4

10 months ago

1.0.3

10 months ago

1.0.2

10 months ago

1.0.1

10 months ago

1.0.0

10 months ago

0.0.3

10 months ago

0.0.2

10 months ago

0.0.1

10 months ago