← Back to Skills Marketplace
daryn-louw

claude-session-warmer

by daryn-louw · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ Security Clean
17
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install claude-session-warmer
Description
Align your Claude Pro/Max usage window to your working hours. Claude's 5-hour usage window is anchored to your FIRST message of a session, so claude-session-...
README (SKILL.md)

claude-session-warmer

Make your Claude Pro/Max usage window start when you want it to — not whenever your first prompt of the day happens to land.

What it does (and explicitly does not do)

Claude meters usage in a rolling 5-hour window anchored to your first message. Start at 09:40 and your window is 09:40–14:40; your afternoon reset is pinned there. Send one trivial primer at 05:00 instead and the window opens 05:00–10:00 — a fresh window is already waiting when you sit down, and every reset that day lines up with your working hours.

claude-session-warmer sends that primer through the official claude CLI, on a schedule, on your always-on box — the same VPS where you already run OpenClaw and an authenticated Claude Code. (A laptop is the wrong host: it's asleep when you're not working, so it can't fire the early primer. The whole point is a machine that's always on.)

It does not bypass or beat any limit. You cannot exceed the 5-hour cap or the weekly cap, and this skill does not try to — it only changes when the window opens. That distinction is what keeps it inside Anthropic's terms; read references/tos.md before publishing or sharing.

Prerequisite (you almost certainly already have this)

The box must have the official Claude Code CLI installed and logged in to your Pro/Max subscription — exactly the setup you already use to develop with OpenClaw on that VPS. If claude -p "hi" answers on that box, you're ready. Do not copy auth tokens from another machine — log in on the box itself via the official flow (that token-copying is the one thing Anthropic enforces against; see references/tos.md).

Setup — 1, 2, 3

Run these on the VPS, from the skill's folder.

1. Tell it your timezone and start time.

cp config.example.json config.json
# edit config.json: set "timezone" (e.g. "Africa/Johannesburg"), your "anchor"
# start time (e.g. "05:00"), then set "enabled": true

2. Check the box can warm the window, and preview the plan.

node bin/session-warmer.mjs check      # confirms claude is installed + logged in here
node bin/session-warmer.mjs schedule   # shows the primer times (e.g. 05:00 10:05 15:10 20:15)

If check fails, it tells you exactly what to fix (install the CLI, or run claude once to log in).

3. Schedule it.

node bin/session-warmer.mjs install    # prints a ready-to-paste cron block
crontab -e                             # paste the block; save

Done — the VPS now warms your Claude window every day so your windows align to your hours. (Prefer OpenClaw/Cowork scheduled tasks? install also prints that recipe — one task per primer time running node bin/session-warmer.mjs warm.)

Hard constraints (do not violate)

  1. Official CLI only. The primer is sent via the real claude -p binary. Never extract or reuse OAuth tokens, never spoof the Claude Code client, never route the primer through the Agent SDK with subscription auth or any third-party harness.
  2. The user's own subscription, logged in on the box itself. No token copying between machines, no shared accounts.
  3. One trivial prompt per primer. The point is to open the window, not do work.
  4. Opt-in. enabled ships false. Do not arm it without the user setting it true.
  5. Honest framing. Describe it as window alignment, never as "bypassing limits."

How the math works

schedule walks from anchor to day_end in steps of window_minutes + buffer_minutes. Each step lands just after a window closes, so the primer at that time starts a brand-new 5-hour window. With the defaults (anchor 05:00, window 300m, buffer 5m): 05:00, 10:05, 15:10, 20:15. All clock math is timezone-aware via Intl — set your IANA timezone and DST/travel are handled; no extra dependencies.

Commands

  • check — verify the CLI is installed + authenticated on this box (run this first).
  • schedule — print today's primer times (no side effects).
  • warm — fire one primer now (respects enabled + dry_run); this is what cron runs.
  • install [--cron-only] — print cron / scheduled-task lines (--cron-only is pipeable).
  • status — show config + the next primer time.

Files

  • bin/session-warmer.mjs — the engine (Node, no deps).
  • config.example.json — copy to config.json and edit.
  • references/tos.md — why the official-CLI path is permitted and what is not. Read before publishing.
  • README.md — user-facing overview for the public repo.
Usage Guidance
Install only if you intentionally want unattended Claude CLI prompts from your own logged-in VPS. Review the cron block before adding it, keep enabled=false until ready, avoid copying tokens between machines, and verify current Claude/Anthropic terms because this consumes account quota and depends on subscription policy.
Capability Tags
requires-oauth-tokenrequires-sensitive-credentials
Capability Assessment
Purpose & Capability
The artifact's purpose and implementation match: it reads local config, computes primer times, and uses the configured Claude CLI to send a small prompt for usage-window alignment.
Instruction Scope
The invocation cues are broad around Claude limits and window alignment, but the skill consistently frames the behavior as scheduled authenticated CLI activity rather than disguising it.
Install Mechanism
Installation is manual: copy config, set enabled, run checks, and paste printed cron lines. The check command does send a real Claude prompt to verify auth, which users should understand before running it.
Credentials
An always-on VPS with a logged-in Claude CLI is sensitive, but it is directly required for the stated scheduling purpose and is repeatedly disclosed.
Persistence & Privilege
Cron persistence and use of an existing authenticated Claude session are expected for the skill; the default config has enabled=false and the script does not install cron automatically.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install claude-session-warmer
  3. After installation, invoke the skill by name or use /claude-session-warmer
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release — align your Claude usage window to your working hours via a scheduled official-CLI primer. Timezone-aware, zero deps, opt-in.
Metadata
Slug claude-session-warmer
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is claude-session-warmer?

Align your Claude Pro/Max usage window to your working hours. Claude's 5-hour usage window is anchored to your FIRST message of a session, so claude-session-... It is an AI Agent Skill for Claude Code / OpenClaw, with 17 downloads so far.

How do I install claude-session-warmer?

Run "/install claude-session-warmer" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is claude-session-warmer free?

Yes, claude-session-warmer is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does claude-session-warmer support?

claude-session-warmer is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created claude-session-warmer?

It is built and maintained by daryn-louw (@daryn-louw); the current version is v1.0.0.

💬 Comments