CPANscan logo

CPANscan

Recent Perl modules, releases and favorites.
Last updated 17 March 2026 10:30 PM
Perl logo

Modern-Perl-Prelude

Release | 17 Mar 2026 07:59 PM | Author: SKOV | Version: 0.005
CPAN Testers: Pass 92.9%N/A 7.1%
Project prelude for modern Perl style on Perl 5.30+
Modern::Perl::Prelude is a small lexical prelude that gives you a ready set of modern Perl conveniences while staying runnable on Perl 5.30 and later. It enables strict and warnings, brings features like say, state and fc into the caller, provides try/catch compatibility and imports handy functions such as blessed, refaddr, reftype, trim, ceil, floor, true/false and weakref helpers so you can write cleaner, more idiomatic code without hand-rolling boilerplate. You can opt into source-level UTF-8 or into backported class and defer syntax with the -utf8, -class and -defer flags and those extra compatibility layers are lazy-loaded so they only load when you ask for them. no Modern::Perl::Prelude reliably turns off the native pragmata it manages but backported feature modules are treated as import-only and may not be symmetrically undone. Recent updates added the optional -class and -defer imports and improved unimport behavior while keeping default behavior unchanged.
Perl logo

Bitcoin-Crypto

Release | 17 Mar 2026 07:20 PM | Author: BRTASTIC | Version: 4.004
Upvotes: 8 | CPAN Testers: Pass 96.2%N/A 3.8%
Bitcoin cryptography in Perl
Bitcoin::Crypto is a Perl library that provides the cryptographic building blocks and utilities needed to work with Bitcoin keys, mnemonics, address formats, scripts, transactions, PSBTs, blocks and UTXOs. It supports generating BIP39 mnemonics and deriving BIP32/BIP44 extended keys and also exposes lower level primitives for public and private keys, signatures, encodings and script handling so you can create, parse and manipulate raw Bitcoin data structures. The distribution offers convenient shortcut imports that load the relevant object classes on demand, making it easy to instantiate extprv/extpub, basic keys, script trees, transactions and PSBTs without boilerplate. This module is a good fit for Perl developers building wallets, signing tools, transaction constructors or any application that needs direct control over Bitcoin cryptography and data formats. For network RPC work see Bitcoin::RPC::Client and consult Bitcoin::Crypto::Manual for detailed usage.
Perl logo

Config-Model-Itself

Release | 17 Mar 2026 05:59 PM | Author: DDUMONT | Version: 2.028
Upvotes: 1 | CPAN Testers: Pass 71.4%N/A 28.6%
Model (or schema) editor for Config::Model
Config::Model::Itself is a helper library for people who build and maintain Config::Model schemas; it gives you a programmatic way to load, edit and save the model files that describe the structure and rules of configuration data. The module exposes an object for reading all model files from a directory tree, filtering or force-loading broken files, writing models back while preserving layout, emitting model plugins, and producing Graphviz dot diagrams and class/element listings. It is useful if you create, test or distribute Config::Model-based configuration schemas or want to drive the model editor from scripts or the cme tool and its Tk or Curses UIs. One known limitation is that test menu entries are generated from the application list and cannot be updated without restarting cme. Recent work keeps compatibility with evolving Config::Model and UI components and release 2.028 fixes a backend detection problem introduced in 2.027.
Perl logo

Net-Async-HTTP

Favorite | 17 Mar 2026 05:33 PM | Author: PEVANS | Version: 0.50
Upvotes: 8 | CPAN Testers: Pass 99.2%Fail 0.2%N/A 0.6%
Use HTTP with IO::Async
Net::Async::HTTP is an asynchronous HTTP client built for IO::Async that returns Future objects and also supports callback-style usage, making it ideal for event‑driven Perl programs that need nonblocking HTTP I/O. It manages multiple concurrent connections with configurable per‑host pooling and optional HTTP/1.1 pipelining, supports streaming request and response bodies, per‑request and stall timeouts, cookie jars, and optional SSL when IO::Async::SSL is available. The module also supports proxies including SOCKS5 and UNIX socket proxies, can optionally decode compressed response bodies when the right decompression modules are installed, and provides convenience methods such as GET, POST, PUT, PATCH and DELETE for common operations. Recent releases added support for proxying via UNIX sockets and a DELETE convenience method and continue to refine documentation and tests.
Perl logo

Test2-Harness

Favorite | 17 Mar 2026 03:46 PM | Author: EXODIST | Version: 1.000163
Upvotes: 21 | CPAN Testers
A new and improved test harness with better Test2 integration
Test2::Harness is the powerful backend that runs and processes Test2/TAP test suites, providing the orchestration, event parsing, logging, parallel job scheduling, resource management and plugin hooks that higher-level tools need to run tests reliably at scale. It is not a user-facing command line tool by itself but is the engine behind App::Yath, which provides the interactive and command-driven UI most people use. Over the years it has gained features for persistent runners, smarter reloading, coverage and rerun support, shared job slots and advanced scheduling, while focusing on robust handling of TAP/Test2 events and integrator-friendly hooks. Recent maintenance adds a --no-final-table display option and fixes for several edge-case bugs to improve output control and stability.
Perl logo

Imager-QRCode

Favorite | 17 Mar 2026 03:36 PM | Author: KURIHARA | Version: 0.035
Upvotes: 3 | CPAN Testers: Pass 100.0%
Generate QR Code with Imager using libqrencode
Imager::QRCode is a small Perl wrapper that generates QR Code images by combining the libqrencode library with the Imager image toolkit. You create a generator object or call the exportable plot_qrcode function, supply the text to encode and a few options such as module size, margin, error-correction level, symbol version, encoding mode and case sensitivity, and you get back an Imager object ready to write to GIF, PNG or other formats. The module supports kanji mode (encoded as Shift-JIS) and an 8-bit mode that lets you embed UTF-8 data, and you can control foreground and background colors via Imager::Color. It requires libqrencode 2.0.0 or newer and has seen updates to support newer libqrencode releases and a 2016 bugfix to handle defined-but-zero text values, making it a good choice if you already use Imager and need simple, configurable QR generation in Perl.
Perl logo

DBIx-Class-MockData

Release | 17 Mar 2026 03:33 PM | Author: MANWAR | Version: 0.04
CPAN Testers: Pass 83.3%N/A 16.7%
Generate mock test data for DBIx::Class schemas
DBIx::Class::MockData generates realistic test rows for DBIx::Class schemas by inspecting a connected Schema, resolving foreign key insertion order, and creating values that match each column's declared data_type. It offers chainable actions to deploy or wipe test schemas, perform dry runs, and populate tables while honoring nullability and unique constraints, and it can target or skip specific tables. You can control the volume and shape of data with a global row count, per-table row counts, custom per-column generator callbacks, and an optional seed for reproducible output. The 0.04 release added rows_per_table and generators, switched to bulk insert for much faster population, and improved salt and unique-constraint handling so reproducible runs stay distinct and safe for parallel testing. Connection and schema loading are left to the caller and the distribution includes a dbic-mockdata CLI for scripting.
Perl logo

Amazon-Sites

Release | 17 Mar 2026 02:51 PM | Author: DAVECROSS | Version: v0.1.10
Upvotes: 1 | CPAN Testers: Pass 73.2%N/A 26.8%
A class to represent Amazon sites
Amazon::Sites is a lightweight Perl class that models Amazon's regional storefronts and makes it easy to work with country codes, domains, currencies and affiliate codes. You create an Amazon::Sites object and can get lists or hashes of site objects, fetch a single site by its two-letter code, or obtain the canonical two-letter codes for all supported markets. The constructor lets you restrict the sites with include or exclude lists and you can supply associate codes so generated links include your affiliate tracking. It also builds per-country ASIN URLs for easy cross-market linking, which is handy for building localized links, feeds, or affiliate tools that must handle multiple Amazon locales.
Perl logo

Alien-nghttp2

Release | 17 Mar 2026 02:26 PM | Author: JJNAPIORK | Version: 0.002
CPAN Testers: Pass 88.2%N/A 11.8%
Find or build the nghttp2 HTTP/2 C library
Alien::nghttp2 is a Perl Alien module that makes the nghttp2 HTTP/2 C library available to Perl build scripts. It will detect a system installation or download and build nghttp2 for you so downstream modules can compile and link against it. You call it from ExtUtils::MakeMaker or Alien::Build to obtain compiler and linker flags via methods such as cflags and libs. It also exposes dynamic_libs to list runtime library paths and install_type to report whether the library is from the system or built locally. Use this module when you need the native nghttp2 implementation for Perl extensions so you do not have to install or configure the HTTP/2 C library manually.
Perl logo

Data-Hash-Diff-Smart

Release | 17 Mar 2026 12:03 PM | Author: NHORNE | Version: 0.01
CPAN Testers: Pass 100.0%
Smart structural diff for Perl data structures
Data::Hash::Diff::Smart is a modern, recursive diff engine for Perl data structures that produces a stable, structured list of change operations for nested hashes, arrays, scalars and objects and can render those changes as human-readable text, JSON, YAML or Test2 diagnostics. It is configurable with ignore rules, path-specific comparator callbacks and multiple array diff strategies including index-based comparison, minimal diffs via LCS and unordered multiset mode, making it useful for generating readable diffs, producing test diagnostics or creating machine-readable change sets for configuration and data migration. This is the initial 0.01 release and the distribution is provided as-is with a licensing note that personal single-user use is under GPL2 while other uses require contacting the author for a licence.
Perl logo

Business-ISBN-Data

Release | 17 Mar 2026 10:49 AM | Author: BRIANDFOY | Version: 20260317.001
Upvotes: 3 | CPAN Testers: Pass 100.0%
Data pack for Business::ISBN
Business::ISBN::Data is a support module that supplies the ISBN range data used by Business::ISBN, so you normally do not load it directly. It bundles the ISBN RangeMessage.xml from the ISBN Agency and will automatically be loaded by Business::ISBN, but you can point the module at a different RangeMessage.xml by setting the ISBN_RANGE_MESSAGE environment variable before loading Business::ISBN. If no external file is available it falls back to embedded data or looks in the current directory, though those fallbacks may be older than the official feed. Note that Business::ISBN 3.005 or later is required because the data structure changed to fix an ISBN-13 issue. The source and updates are on GitHub, so you can fetch newer range files or contribute fixes if you need the latest allocation information.
Perl logo

App-mdee

Release | 17 Mar 2026 02:31 AM | Author: UTASHIRO | Version: 1.07
Upvotes: 1 | CPAN Testers
Em·dee, Markdown Easy on the Eyes
mdee (em-dee) is a terminal-focused, multi-column Markdown viewer that makes raw Markdown easy to read by applying syntax highlighting, hiding most markup characters by default, wrapping long list items, and aligning tables with ANSI-aware formatting. It can produce paged n-up output or simpler pager/filter styles, keeps links clickable via OSC 8 when the terminal supports it, and offers light/dark themes plus fine-grained color and element overrides so you can tune headings, code, emphasis, and other elements. The tool is a small Bash pipeline that coordinates App::Greple::md, ansifold, ansicolumn, and nup to perform highlighting, folding, table formatting, and layout rather than converting Markdown to another format. It intentionally does not reflow paragraphs and has a few limitations such as no multi-line emphasis, no reference-style links, HTML comments are only matched at line start, and OSC 8 hyperlinks require terminal and pager support. The recent 1.07 release added the "nomark" theme to the default set for a cleaner reading experience and adjusted pagination behavior (requires App::nup 1.07).
Perl logo

Dist-Zilla-PluginBundle-Author-DBOOK

Release | 17 Mar 2026 02:28 AM | Author: DBOOK | Version: v1.0.6
CPAN Testers: Pass 97.5%N/A 2.5%
A plugin bundle for distributions built by DBOOK
Dist::Zilla::PluginBundle::Author::DBOOK is a ready-made collection of Dist::Zilla plugins that codifies Dan Book's preferred workflow for building and releasing Perl distributions. It wires together metadata creation, README and CONTRIBUTING generation from POD, dependency extraction from cpanfile or prereqs files, Git-based commit, tag and release handling, version bumping, and test and packaging steps so you can automate consistent releases with minimal setup. The bundle assumes your repo contains a prereqs file and a populated Changes entry and a sensible .gitignore, and it can copy useful files like INSTALL, LICENSE, Makefile.PL and META.json into the repository during regenerate or release. You can tweak which installer plugin to use, enable optional pod tests, slice or remove individual subplugins, and run a dry run of the whole release process with FAKE_RELEASE=1. Use this if you want a well-integrated, opinionated Dist::Zilla configuration that saves time and reduces release friction.
Perl logo

Image-PNG-Libpng

Release | 17 Mar 2026 02:10 AM | Author: BKB | Version: 0.60
CPAN Testers: Pass 100.0%
Perl interface to libpng
Image::PNG::Libpng is a mature Perl wrapper around the C libpng library that lets you read, write and manipulate PNG images from Perl using both a direct libpng-like API and higher-level convenience helpers. It exposes most libpng functionality in a Perl-friendly way so you can read files or scalars, write to files or scalars, copy PNG structures, inspect and set the IHDR and all common chunks (text, palette, gAMA, tIME, tRNS and many extensions), apply built-in libpng transforms, tune compression and compare image data. The module does not bundle libpng, so you must have a compatible libpng installed and some features or tests depend on the libpng version you compile against. A number of lower-level or deprecated libpng functions are intentionally omitted and the documentation flags several untested or version-dependent routines, but everyday tasks like reading image rows, changing metadata, stripping or handling alpha, and round-trip chunk copying are well supported. It is actively maintained and stable for production use, with the most recent release 0.60 (2026-03-17) providing a bug fix to keep things reliable.
Perl logo

CPAN-Maker

Release | 17 Mar 2026 01:23 AM | Author: BIGFOOT | Version: v1.7.0
CPAN Testers: Pass 100.0%
CPAN distribution maker
CPAN::Maker is a command line utility for packaging a Perl project as a CPAN distribution. It reads a YAML "buildspec" that describes your module layout, tests, scripts and extra files, discovers dependencies (using scandeps or Module::ScanDeps::Static), generates a Makefile.PL and can invoke a companion bash script to assemble a release tarball. You can also run it without a buildspec to emit a Makefile.PL for manual tweaking. It supports control over author, abstract, required/test/build dependencies, minimum Perl version, provided modules, postambles and a variety of packaging paths so you can tailor what gets included. If you publish modules to CPAN or need a repeatable way to produce CPAN-ready tarballs, this tool automates the common steps while letting you tweak the inputs. The recent 1.7.0 release added a recommends option to record optional/recommended dependencies for installers that support them.
Perl logo

App-cpanminus

Release | 17 Mar 2026 12:38 AM | Author: MIYAGAWA | Version: 1.7049
Upvotes: 286 | CPAN Testers: Pass 100.0%
Get, unpack, build and install modules from CPAN
cpanminus, or cpanm, is a tiny, dependency-free command line tool for fetching, unpacking, building and installing Perl modules from CPAN with zero configuration and minimal memory usage. It can bootstrap itself via a simple curl one-liner or be installed from distribution packages, or used as a standalone executable, and it respects local::lib, perlbrew and plenv installs or will automatically create a per-user install path when you lack system permissions. cpanm uses the CPAN Meta DB and MetaCPAN APIs to locate distributions, unpacks temporary files under ~/.cpanm, and relies only on standard system tools such as tar, make and a C compiler when building XS modules. It intentionally keeps features to a minimum, so it does not provide CPAN testers reporting, RPM packaging, outdated-module listings or interactive build handling, and it can struggle with distributions that prompt for input or use nonstandard VERSION values. If you want a fast, simple installer for adding modules to a Perl environment without the complexity of CPAN or CPANPLUS, cpanm is an excellent choice.
Perl logo

PAGI-Middleware-Session-Store-Cookie

Release | 16 Mar 2026 11:36 PM | Author: JJNAPIORK | Version: 0.001001
CPAN Testers: Pass 86.8%N/A 13.2%
Encrypted cookie-based session store for PAGI
PAGI::Middleware::Session::Store::Cookie provides a stateless session backend that encrypts and authenticates session data into a cookie so no server-side storage is required. You create it with a secret key and use its set method to produce an encrypted blob to put in the response cookie and its get method to decode that blob back into a session hash. Encryption uses AES-256-GCM with the key derived from your secret and a random IV so the same data looks different each time. This makes it a good fit when you want simple, serverless session management and can keep session payloads small. Be aware of practical limits though because browsers cap cookies at around 4KB and large sessions will fail. Also revoking a client session still requires server-side state such as a blocklist. On systems without /dev/urandom the module falls back to a weaker random source and emits a warning, and installing Crypt::URandom is recommended.
Perl logo

PAGI

Release | 16 Mar 2026 10:48 PM | Author: JJNAPIORK | Version: 0.001020
Upvotes: 7 | CPAN Testers: Pass 86.2%Fail 1.7%N/A 12.1%
PAGI Specification, Utilities and Reference Server
PAGI is an async web application specification and toolkit for Perl that modernizes PSGI for evented servers and supports HTTP/1.1, WebSocket, and Server-Sent Events. It defines a simple async app signature of async sub { my ($scope, $receive, $send) = @_; ... } so servers, frameworks, and apps can interoperate while giving you helpers like a reference PAGI::Server, request/response wrappers, WebSocket and SSE helpers, routers, middleware and bundled apps for static files, health checks and more. The spec itself is stable and intended for developers who want to write loop-agnostic, async-capable Perl services, but the distribution is beta so some convenience modules may evolve and the reference server is not yet battle tested so running behind a reverse proxy is recommended for production. Recent work focuses on hardening and usability, including security fixes for transfer-encoding and header validation, improved TLS 1.3 support, and a refactored session middleware with pluggable state and store backends. Requirements include Perl 5.18+, an event loop like IO::Async for the server, and Future::AsyncAwait for async/await support.
Perl logo

Data-Path-XS

Release | 16 Mar 2026 10:01 PM | Author: EGOR | Version: 0.02
Upvotes: 1 | CPAN Testers: Pass 81.0%N/A 15.2%Unknown 3.8%
Fast path-based access to nested data structures
Data::Path::XS is a small, C-backed Perl module that makes it easy and fast to read, write, delete, and test values deep inside nested hashes and arrays using slash-separated paths. It offers four APIs to suit different needs: a string-based API for general use, an arrayref API for components that include special characters or empty keys, a compiled-path API you can reuse for max speed, and a keywords API that compiles to very low-overhead ops for hot code paths. pathset will autovivify intermediate containers and will replace non-reference scalars as needed while pathget and pathexists do not autovivify, numeric components map to array indices (including negative indices) and numeric strings with leading zeros or very large integers are treated as hash keys, so use the array API when keys contain slashes or empty strings. The module is designed for single-threaded use and compiled path objects should not be shared across threads. It is substantially faster than pure-Perl solutions for deep access, and the recent 0.02 update fixed a keyword pathset void-context overhead issue and improved validation, documentation, and tests.
Perl logo

EAI-Wrap

Release | 16 Mar 2026 09:23 PM | Author: RKAPL | Version: 1.921
CPAN Testers: Pass 100.0%
Framework for easy creation of Enterprise Application Integration tasks
EAI::Wrap is a Perl framework for building enterprise integration and ETL jobs without writing low level plumbing code. It lets you declare site, common and per-load settings in simple hashes and then run a standard extract, transform and load loop that handles FTP/SFTP transfers, file parsing (CSV, Excel, XML), database reads and writes, logging, retries, history and error notifications. The module wires together Log4perl, DBI/ODBC, Net::SFTP::Foreign and common file parsers and writers so you can concentrate on mapping and business rules rather than connection and file handling. It supports environment-aware configuration, command line overrides, redo/archive handling and hooks for custom field or line processing, making it useful for ops teams and developers who need reliable, repeatable automated data exchanges between systems.
Perl logo

IO-Compress

Favorite | 16 Mar 2026 08:18 PM | Author: PMQS | Version: 2.219
Upvotes: 20 | CPAN Testers: Pass 99.3%Fail 0.7%
IO Interface to compressed data files/buffers
IO::Compress is the umbrella module in the IO-Compress distribution that exposes Perl-friendly facilities for compressing and decompressing streams and files across many formats such as gzip, zip (including Zip64), bzip2, xz, lzma and zstd. This file is a stub and contains no implementation code, so in practice you use the format-specific modules like IO::Compress::Gzip, IO::Compress::Zip or the IO::Uncompress::* family and IO::Uncompress::AnyUncompress for automatic format detection. The distribution emphasizes robust, interoperable handling of compressed data in both one‑shot and streaming scenarios and is actively maintained by Paul Marquess with regular fixes, new format support and tooling updates. Recent changes include adding this stub module, refreshing bundled utilities such as zipdetails and a number of small fixes and consistency updates through the 2026 releases.
Perl logo

MIDI-RtController-Filter-Tonal

Favorite | 16 Mar 2026 03:08 PM | Author: GENE | Version: 0.0501
Upvotes: 1 | CPAN Testers: Pass 100.0%
Tonal RtController filters
MIDI::RtController::Filter::Tonal is a collection of ready-made tonal filters you can plug into MIDI::RtController to turn incoming note events into musical material like pedal tones, diatonic chords, delayed echoes, offset notes, arpeggios and walking melodies. Each filter is configurable with musical parameters such as pedal note, delay time, feedback, velocity, key, scale, intervals and arpeggiation type so you can shape behavior for live performance or generative accompaniment without writing low-level MIDI handling. Filters are used as callbacks on a controller instance and return a boolean to control further processing, and a helper function lets you declaratively add lists of filters to controllers. The recent 0.0500 release adds a simple single_tone filter for triggering individual notes. This module is handy if you want quick, musically informed MIDI processing for performance, composition experiments or automated backing parts.
Perl logo

Alien-libwebsockets

Release | 16 Mar 2026 02:26 PM | Author: EGOR | Version: 0.01
CPAN Testers: Pass 37.5%Fail 6.2%N/A 6.2%Unknown 50.0%
Find or build libwebsockets C library
Alien::libwebsockets helps Perl distributions find or build the libwebsockets C library so you can link it into XS or other compiled code. The module will use a system installation if one is available or download and compile libwebsockets from source with libev, SSL, zlib, and permessage-deflate extension support, and it exposes compiler flags and linker flags for use with ExtUtils::MakeMaker. It also provides a has_extensions method to detect permessage-deflate support, though that detection uses symbol inspection and is reliable only for the module's own shared installs and may return false for untracked system libraries. The initial release bundles libwebsockets 4.3.3 and is intended to make it easier to consume libwebsockets from Perl distributions.
Perl logo

NBI-Slurm

Release | 16 Mar 2026 02:03 PM | Author: PROCH | Version: 0.17.0
CPAN Testers: Pass 94.2%N/A 5.8%
NBI Slurm module
NBI::Slurm is a Perl toolkit for preparing and submitting jobs to SLURM-based HPC clusters. It gives you NBI::Job to model a job and NBI::Opts to build SLURM options such as queue, threads, memory, runtime and output file paths, and to generate the job script header. You can submit jobs programmatically, inspect queues and squeue availability, run system commands while capturing stdout and stderr, and use the accompanying command-line utilities for common workflows. Recent releases added an energy-aware scheduler module NBI::EcoScheduler, support for SLURM --begin via start_time and start_date, and --eco/--no-eco flags with configurable eco windows, making it easy to defer work to low-energy slots by default. The package is actively maintained and distributed under the MIT license.
Perl logo

Log-Any

Release | 16 Mar 2026 01:54 PM | Author: PREACTION | Version: 1.719
Upvotes: 69 | CPAN Testers: Pass 98.1%Fail 1.9%
Bringing loggers and listeners together
Log::Any is a tiny, dependency-light logging façade for Perl that lets CPAN modules produce log messages without forcing applications to pick a logging backend. Module authors use a simple logger object (for example via use Log::Any '$log') and call familiar methods like debug, info, warn, and error or their printf-style variants, and applications choose where those messages go by configuring Log::Any::Adapter to route logs to Log::Log4perl, Log::Dispatch, files, syslog, or other consumers. It supports structured and contextual logging, standard log levels and aliases, level checks for efficiency, and a null default so libraries can safely emit logs even when an application has not configured a consumer. The project is deliberately minimal to encourage wide adoption and avoid adding heavy dependencies, and recent maintenance releases fixed test issues on Windows and cleaned up documentation and a few adapter-related bugs. If you write libraries that should be polite about logging or build applications that want flexible control over where logs end up, Log::Any is a relevant, low-friction choice.
Perl logo

Syntax-Feature-With

Release | 16 Mar 2026 12:22 PM | Author: NHORNE | Version: 0.01
CPAN Testers: Pass 100.0%
Simulate Pascal's "with" statement in Perl
Syntax::Feature::With provides a lightweight way to emulate Pascal's with statement in Perl by temporarily aliasing hash entries to lexical variables inside a coderef, so you can read and write %hash entries simply by using lexicals declared in the outer scope. It uses PadWalker and requires no XS, parser hooks, or syntax changes, and supports nested with() calls and a small convenience wrapper with_hash for cleaner call sites. Built-in modes let you enforce correctness with -strict where every hash key must have a matching declared lexical, debug to print which keys were aliased or ignored, and trace to show entry and exit with nesting depth. Limitations include the need for outer-scope lexicals, only hashrefs are supported, and only keys matching /^[A-Za-z_]\w*$/ are eligible. The distribution is hosted on GitHub and this 0.01 release is the initial draft, and licensing is GPL2 for personal single-user use while other uses should contact the author for licensing.
Perl logo

Plack-App-DirectoryIndex

Release | 16 Mar 2026 11:20 AM | Author: DAVECROSS | Version: v0.2.3
CPAN Testers: Pass 51.4%N/A 48.6%
Serve static files from document root with an index file
Plack::App::DirectoryIndex is a small PSGI/Plack application that serves static files from a document root and provides Apache-style directory listings while automatically serving a default index file such as index.html. It is configured with a root directory and an optional dir_index filename, and can render directory listings with optional Font Awesome icons and an enhanced CSS theme for a prettier appearance. Use it when you need a simple standalone static file server for development or lightweight hosting that falls back to an index file before showing a listing. If you do not want automatic index files you can use Plack::App::Directory or Plack::App::File instead.
Perl logo

WebServer-DirIndex

Release | 16 Mar 2026 11:16 AM | Author: DAVECROSS | Version: v0.1.4
CPAN Testers: Pass 81.1%N/A 18.9%
Directory index data for web server listings
WebServer::DirIndex reads a filesystem directory and builds the data needed to render a web server directory listing, and it can also produce a ready-to-serve HTML index page. You create an object with the directory path and its URL and control presentation with the pretty and icons options, then inspect entries via files (each a WebServer::DirIndex::File) or call to_html to get a complete HTML page. The module can add MIME-aware Font Awesome icons and an enhanced CSS theme for a more attractive listing, or produce a plain listing if you disable icons. Note that as of 0.1.0 the pretty option is set when constructing the object rather than when calling to_html and enabling pretty now also turns on icons unless you explicitly pass icons => 0; the distribution targets modern Perls (Perl 5.26+). This is a lightweight, easy way to generate customizable directory indexes for static sites or simple web applications.
Perl logo

MetaCPAN-API

Release | 16 Mar 2026 11:02 AM | Author: HAARG | Version: 0.52
Upvotes: 26 | CPAN Testers: Pass 100.0%
(DEPRECATED) A comprehensive, DWIM-featured API to MetaCPAN
MetaCPAN::API is a now-deprecated Perl client that wraps the MetaCPAN REST API and gave Perl programs simple, DWIM-style methods to look up authors, releases, modules and other CPAN metadata while also exposing low-level fetch and post helpers. It uses HTTP::Tiny as its user agent by default, lets you point it at a custom base_url (defaulting to https://fastapi.metacpan.org/v1) and pass ua arguments, and can be used with cached user agents for offline or faster access. This module has been superseded and rewritten as MetaCPAN::Client, so you should not start new code with MetaCPAN::API; use MetaCPAN::Client instead. For historical users, the recent 2026 update fixed tests against the current MetaCPAN API, improved error messages by including response content, and updated author tooling.
Perl logo

DBD-Mock-Session-GenerateFixtures

Release | 16 Mar 2026 09:35 AM | Author: UXYZAB | Version: 1.15
Upvotes: 1 | CPAN Testers: Pass 87.0%N/A 13.0%
This distribution generates fixtures for DBD-Mock-Session module
DBD::Mock::Session::GenerateFixtures captures real DBI interactions and produces reusable fixtures so you can run your tests against a DBD::Mock::Session without touching the live database. You can generate fixtures from a real DBI handle, load them from a JSON file, or pass a data structure directly, then obtain a mocked DBI handle that overrides prepare, execute, fetch variants and transaction methods so application code and ORMs like Rose::DB can run unmodified. The module exposes helper methods to get the mocked dbh and the override object and to restore original DBI behavior when testing is finished. Recent updates added MySQL and Rose::DB support, improved cursor management, mocked bind_params_inout, and better handling of named parameters and fetch behavior to make the mocks more accurate and reliable.