604 lines
23 KiB
Markdown
604 lines
23 KiB
Markdown
---
|
|
name: weeknotes-blog-post-composer
|
|
description: Compose weeknotes blog posts in Jekyll-style Markdown from multiple data sources including Mastodon and Linkding. Use this skill when the user requests to create, draft, or generate weeknotes content for a blog post.
|
|
---
|
|
|
|
# Weeknotes Blog Post Composer
|
|
|
|
## Overview
|
|
|
|
This skill enables composing weeknotes blog posts by automatically fetching content from multiple sources (Mastodon posts and Linkding bookmarks) and combining them into a well-formatted Jekyll-style Markdown document with YAML frontmatter. The skill handles data collection, formatting, and composition into a ready-to-publish blog post. Optionally, the skill can reference past weeknotes to match the user's personal writing style and voice.
|
|
|
|
## Quick Start
|
|
|
|
When a user first requests to create weeknotes, check if the skill is configured:
|
|
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
|
|
# Check if config exists
|
|
if [ ! -f "./config/config.json" ]; then
|
|
echo "First-time setup required."
|
|
./scripts/setup.sh
|
|
fi
|
|
```
|
|
|
|
If configuration doesn't exist:
|
|
1. Inform the user that first-time setup is needed
|
|
2. Ask for their Mastodon server URL and access token
|
|
3. Ask for their Linkding instance URL and API token
|
|
4. Optionally ask for their weeknotes archive URL for style reference
|
|
5. Run `scripts/setup.sh` with their inputs
|
|
|
|
### Getting API Credentials
|
|
|
|
**Mastodon Access Token:**
|
|
1. Log into the Mastodon instance
|
|
2. Go to Settings → Development → New Application
|
|
3. Give it a name (e.g., "Weeknotes Composer")
|
|
4. Grant "read" permissions
|
|
5. Copy the access token
|
|
|
|
**Linkding API Token:**
|
|
1. Log into the Linkding instance
|
|
2. Go to Settings → Integrations
|
|
3. Click "Create Token"
|
|
4. Copy the generated token
|
|
|
|
## Composing Weeknotes
|
|
|
|
The primary workflow for composing weeknotes follows these steps:
|
|
|
|
### Step 1: Determine Date Range
|
|
|
|
By default, use the last 7 days (from 7 days ago to today). If the user specifies a different timeframe, parse their request and extract start/end dates.
|
|
|
|
Examples of user requests:
|
|
- "Draft weeknotes for this week" → 7 days ago to today
|
|
- "Create weeknotes for last week" → 14 days ago to 7 days ago
|
|
- "Generate weeknotes from November 4-10" → 2025-11-04 to 2025-11-10
|
|
|
|
**Default date calculation:**
|
|
```python
|
|
from datetime import datetime, timedelta
|
|
today = datetime.now()
|
|
end_date = today.strftime("%Y-%m-%d")
|
|
start_date = (today - timedelta(days=7)).strftime("%Y-%m-%d")
|
|
```
|
|
|
|
So if today is Thursday November 14, 2025:
|
|
- Start date: Thursday November 7, 2025
|
|
- End date: Thursday November 14, 2025
|
|
|
|
### Step 2: Fetch Source Data
|
|
|
|
Run the fetch script to collect data from all configured sources:
|
|
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
|
|
# For current week (automatic date calculation)
|
|
./scripts/fetch-sources.sh
|
|
|
|
# For specific date range
|
|
./scripts/fetch-sources.sh --start YYYY-MM-DD --end YYYY-MM-DD
|
|
|
|
# For custom output directory
|
|
./scripts/fetch-sources.sh --start YYYY-MM-DD --end YYYY-MM-DD --output-dir ./data/custom
|
|
```
|
|
|
|
This fetches:
|
|
- Mastodon posts from the specified date range
|
|
- Linkding bookmarks from the specified date range
|
|
|
|
Output files are saved to `data/latest/` (or specified directory):
|
|
- `mastodon.md` - Formatted Mastodon posts
|
|
- `linkding.md` - Formatted bookmarks
|
|
|
|
### Step 3: Read and Analyze Source Data
|
|
|
|
Verify the fetched data is ready and understand what content is available:
|
|
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
./scripts/prepare-sources.py
|
|
```
|
|
|
|
This shows which source files are available and their sizes.
|
|
|
|
Then read the fetched markdown files to understand the content:
|
|
|
|
```bash
|
|
# Read Mastodon posts
|
|
cat data/latest/mastodon.md
|
|
|
|
# Read Linkding bookmarks
|
|
cat data/latest/linkding.md
|
|
```
|
|
|
|
### Step 3.5: Review Past Weeknotes for Style Reference (Optional)
|
|
|
|
**Check for configured style reference:**
|
|
|
|
```bash
|
|
# Check if weeknotes_archive URL is configured
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
cat config/config.json
|
|
```
|
|
|
|
If the config contains a `weeknotes_archive` URL, fetch and review 1-2 of the user's past weeknotes to understand their writing style and voice. Use the WebFetch tool to analyze the archive page and individual posts.
|
|
|
|
If no `weeknotes_archive` is configured, skip this step and compose in a conversational blog post style.
|
|
|
|
**Key style elements to look for in past weeknotes:**
|
|
|
|
1. **Voice & Tone:**
|
|
- Conversational and self-deprecating
|
|
- Frequent parenthetical asides and tangents
|
|
- Playful language (e.g., "Ope", casual interjections)
|
|
- Self-aware meta-commentary about the writing process itself
|
|
|
|
2. **Structure:**
|
|
- Starts with an opening paragraph containing inline "TL;DR: ..." summary
|
|
- Followed by `<!--more-->` on its own line (marks intro for Jekyll excerpt)
|
|
- 2-3 deeper dives into specific projects or topics (main body)
|
|
- **"Miscellanea" section near the end** (just before conclusion) for brief observations and items that didn't fit elsewhere
|
|
- **CRITICAL:** Use bullet points for each item in Miscellanea
|
|
- **CRITICAL:** Include ALL bookmarks/links here as bullet points, not in a separate section
|
|
- **CRITICAL:** Wrap the Miscellanea bullet points in `<div class="weeknote-miscellanea">` tags
|
|
- Miscellanea is a catch-all grab bag for everything else: short observations, bookmarks, reading, random thoughts
|
|
- Concluding reflection on the week
|
|
|
|
3. **Content Balance:**
|
|
- Equal weighting of technical depth and personal reflection
|
|
- Mixed technical projects, personal observations, and humor
|
|
- Philosophy embedded in technical writing
|
|
- Comfortable with digression and associative thinking
|
|
|
|
4. **Transitions:**
|
|
- Uses bullet points and whitespace rather than formal prose bridges
|
|
- Ideas progress through thematic gravity or personal relevance
|
|
- Stream-of-consciousness feel ("notes accumulated throughout the week")
|
|
|
|
5. **Distinctive Elements:**
|
|
- Metaphorical thinking (uses analogies to explain technical challenges)
|
|
- Acknowledges when feeling scattered or self-doubting
|
|
- References to ongoing projects and past posts
|
|
- Comfortable admitting uncertainty or work-in-progress status
|
|
|
|
When composing, aim to match this voice rather than writing in a generic blog style.
|
|
|
|
### Step 4: Compose Conversational Weeknotes
|
|
|
|
**Important:** Do not use template substitution. Instead, read the source markdown and compose it into readable prose.
|
|
|
|
**Style guidance:** Match the user's voice from past weeknotes (see Step 3.5) - conversational, self-deprecating, with parenthetical asides and comfortable with tangents. Start with an opening paragraph containing an inline "TL;DR: ..." summary (not a header), followed by `<!--more-->` on its own line. Use a "Miscellanea" section near the end (just before the conclusion) as a grab-bag for brief observations and items that didn't fit under other thematic sections. **CRITICAL:** Format ALL Miscellanea items as bullet points, including bookmarks and links - do NOT create a separate "Bookmarks and Reading" section.
|
|
|
|
Analyze the fetched content and compose a conversational weeknotes post that:
|
|
|
|
1. **Summarizes Mastodon activity** - Don't just list every post. Instead:
|
|
- Identify themes and topics from the week
|
|
- Highlight interesting conversations or thoughts
|
|
- Group related posts together
|
|
- Write in a natural, conversational tone
|
|
- Include specific details that are interesting or noteworthy
|
|
- **Link to actual Mastodon posts** using the URLs from the source (e.g., `[posted about X](https://masto.hackers.town/@user/12345)`)
|
|
- **CRITICAL - AVOID PLAGIARISM:** Only use the user's own words from "My Posts" sections directly in prose. Content from "Posts I Boosted" or "Posts I Favorited" should ONLY be:
|
|
- Referenced/cited with attribution (e.g., "Someone on Mastodon pointed out that...")
|
|
- Summarized in your own words, not quoted verbatim as if the user wrote them
|
|
- Alternatively, include blocks of text using blockquotes where it seems interesting
|
|
- Linked to without incorporating their text into the narrative
|
|
- This is extremely important to avoid unintentional plagiarism
|
|
- **IMPORTANT: Embed images inline** when they add value (e.g., ``)
|
|
- **Look for posts with Media entries** in the mastodon.md file - these contain images that should be included
|
|
- Images are especially important for: cats, interesting screenshots, funny visuals, project photos, etc.
|
|
|
|
2. **Integrates bookmarks meaningfully** - Don't just list links. Instead:
|
|
- **CRITICAL: ALL bookmarks MUST go in the Miscellanea section as bullet points**
|
|
- Do NOT create a separate "Bookmarks and Reading" section
|
|
- Group related bookmarks together within Miscellanea bullets when possible
|
|
- Explain why things were interesting or relevant in the bullet text
|
|
- Connect bookmarks to larger thoughts or projects
|
|
- **Include actual bookmark URLs** with descriptive link text (e.g., `[Article title](https://example.com)`)
|
|
- Format as bullet points with links in the Miscellanea section
|
|
|
|
3. **Creates a cohesive narrative** - The post should read like a blog post, not a data dump:
|
|
- Write in first person
|
|
- Use conversational language
|
|
- Connect different activities together
|
|
- Add context and reflection
|
|
- Include section headings that make sense for the content
|
|
|
|
4. **Uses proper formatting**:
|
|
- Jekyll-style YAML frontmatter with title, date, tags ("weeknotes" should always be used, along with 3-7 additional tags relevant to the content), and layout
|
|
- **Opening paragraph** with inline "TL;DR: ..." summary (NOT a header)
|
|
- **`<!--more-->`** comment on its own line immediately after the opening paragraph (marks excerpt boundary)
|
|
- **Table of contents nav** on its own line after `<!--more-->` if there are multiple sections (2+ headings): `<nav role="navigation" class="table-of-contents"></nav>`
|
|
- Markdown headings (##, ###) for structure in the main body
|
|
- Links to interesting posts or bookmarks
|
|
- Inline images from Mastodon posts where relevant
|
|
- Code blocks or quotes where appropriate
|
|
|
|
**Example opening structure:**
|
|
```markdown
|
|
TL;DR: Our 15-year-old solar inverter died this week, which kicked off a lot of thinking about technology longevity and IoT device lifecycles. Also spent time tinkering with Claude Code skills and bookmarking way too many articles about AI coding tools.
|
|
|
|
<!--more-->
|
|
|
|
<nav role="navigation" class="table-of-contents"></nav>
|
|
|
|
## Technology Longevity
|
|
...
|
|
```
|
|
|
|
**Critical: Always include the actual URLs!**
|
|
|
|
When referencing content:
|
|
- **Mastodon posts**: Link to the post URL with **short link text (3-5 words)** for aesthetics (e.g., `This week I [posted](https://masto.hackers.town/@user/12345) about solar inverters...`)
|
|
- **Bookmarks**: Include the bookmark URL with descriptive text (e.g., `I found [this article about AI coding](https://example.com/article) particularly interesting...`)
|
|
- **Images**: Embed Mastodon images inline using `` when they're interesting or funny
|
|
- **For multiple consecutive images** (3+), wrap them in `<image-gallery>` tags with newlines before/after the opening and closing tags:
|
|
```markdown
|
|
|
|
<image-gallery>
|
|
|
|

|
|
|
|

|
|
|
|

|
|
|
|
</image-gallery>
|
|
|
|
```
|
|
|
|
**Example composition approach:**
|
|
|
|
Instead of listing every post, write something like:
|
|
|
|
> This week I [spent a lot](https://masto.hackers.town/@user/12345) of time thinking about technology longevity. Our 15-year-old solar inverter died, which [kicked off](https://masto.hackers.town/@user/12346) a whole thread about IoT devices and how frustrating it is when tech doesn't have a 15-20 year plan.
|
|
|
|
**CRITICAL - Only use the user's own posts this way!** If you want to reference a boosted/favorited post or bookmark:
|
|
|
|
> There's been this interesting [article making the rounds](https://example.com/article) about BBS-era communication patterns - explaining how those carefully drafted essay-like responses created a distinctive writing style. But nope, it's just how we learned to write when bandwidth was scarce.
|
|
|
|
Then for bookmarks in Miscellanea, reference them naturally wrapped in the `weeknote-miscellanea` div:
|
|
|
|
```markdown
|
|
## Miscellanea
|
|
|
|
<div class="weeknote-miscellanea">
|
|
|
|
* [*Thinking About Thinking With LLMs*](https://example.com/article) - explores how new tools make it easier to code with shallower understanding
|
|
* [Another piece](https://example.com/article2) argues that the best programmers still dig deep to understand what's happening underneath
|
|
|
|
</div>
|
|
```
|
|
|
|
**IMPORTANT: Always scan the mastodon.md for images!**
|
|
|
|
The mastodon.md file includes `Media:` entries with image URLs and descriptions. Look for these and include them in your weeknotes. Example from the source:
|
|
|
|
```
|
|
Media: [image](https://cdn.masto.host/.../image.jpg) - Description of the image
|
|
```
|
|
|
|
When you find these, embed them in the weeknotes like this:
|
|
|
|
**Single image:**
|
|
> Miss Biscuits [discovered a new perch](https://masto.hackers.town/@user/12347):
|
|
>
|
|
> 
|
|
|
|
**Multiple images (3+) - use image gallery:**
|
|
> I [shared some photos](https://masto.hackers.town/@user/12348) of my 3D printing projects:
|
|
>
|
|
> <image-gallery>
|
|
>
|
|
> 
|
|
>
|
|
> 
|
|
>
|
|
> 
|
|
>
|
|
> </image-gallery>
|
|
|
|
### Step 5: Review and Revise the Draft
|
|
|
|
Before finalizing, review the composed weeknotes and make light revisions:
|
|
|
|
1. **Structure check:**
|
|
- Ensure Miscellanea section is at the end (just before the conclusion)
|
|
- Move any straggling bookmark bullets that didn't fit into main sections into Miscellanea
|
|
- Verify all sections flow logically
|
|
|
|
2. **Prose polish:**
|
|
- Tighten up verbose sentences
|
|
- Remove unnecessary repetition
|
|
- Ensure transitions between sections make sense
|
|
- Check that the voice remains conversational and natural
|
|
|
|
3. **Content verification:**
|
|
- All Mastodon post links are present (3-5 word link text)
|
|
- All bookmark URLs are included
|
|
- Images are properly embedded (single images inline, 3+ images in `<image-gallery>`)
|
|
- Opening has inline "TL;DR: ..." followed by `<!--more-->`
|
|
- Table of contents nav is present if there are multiple sections
|
|
|
|
4. **Final touches:**
|
|
- Verify 3-7 tags (including "weeknotes")
|
|
- Check that conclusion ties things together
|
|
- Ensure Miscellanea items are formatted as bullet points
|
|
|
|
### Step 6: Write the Final Blog Post
|
|
|
|
Create the Jekyll blog post file with:
|
|
|
|
1. **YAML frontmatter:**
|
|
```yaml
|
|
---
|
|
title: "[Date Range]"
|
|
date: YYYY-MM-DD
|
|
tags:
|
|
- weeknotes
|
|
- [contextual-tag-1]
|
|
- [contextual-tag-2]
|
|
- [contextual-tag-3]
|
|
layout: post
|
|
---
|
|
```
|
|
|
|
**Important - Title Format:** Use the date range format without the word "Weeknotes" (e.g., "2025 Week 48" or "November 22-26, 2025"). The "weeknotes" tag already categorizes the post, so the title should be concise.
|
|
|
|
**Important - Tags:** Always include "weeknotes" as the first tag, then add 2-6 additional contextually appropriate tags based on the content (3-7 tags total). Tags should reflect major themes, technologies, topics, or projects discussed in the post. Examples:
|
|
- Technical topics: `ai`, `javascript`, `golang`, `docker`, `apis`
|
|
- Project types: `side-projects`, `open-source`, `blogging`
|
|
- Activities: `learning`, `refactoring`, `debugging`
|
|
- Themes: `productivity`, `tools`, `workflows`
|
|
|
|
Analyze the composed content and choose tags that genuinely reflect what the post is about.
|
|
|
|
2. **Composed content** - The conversational weeknotes you composed in Step 4 and revised in Step 5
|
|
|
|
**CRITICAL:** Do NOT include "Generated with Claude Code" or similar AI attribution footer in weeknotes posts. These are personal blog posts that should maintain the author's authentic voice throughout.
|
|
|
|
3. **Save** to the appropriate location and filename:
|
|
|
|
**Detecting the blog directory:**
|
|
Check if the current working directory contains `content/posts/` - if so, you're in the blog directory.
|
|
|
|
```bash
|
|
if [ -d "content/posts" ]; then
|
|
echo "In blog directory - using blog naming convention"
|
|
fi
|
|
```
|
|
|
|
**If running from the user's blog directory**, use this naming convention:
|
|
```
|
|
content/posts/{YYYY}/{YYYY-MM-DD-wWW}.md
|
|
```
|
|
|
|
Where:
|
|
- `{YYYY}` = 4-digit year (of today's date)
|
|
- `{YYYY-MM-DD}` = Today's date (the publication date)
|
|
- `{wWW}` = ISO week number for today (e.g., w16, w17, w42)
|
|
|
|
Examples:
|
|
- `content/posts/2025/2025-04-18-w16.md` (Week 16, published April 18, 2025)
|
|
- `content/posts/2025/2025-11-13-w46.md` (Week 46, published November 13, 2025)
|
|
|
|
**To calculate the week number and filename**, use the helper script:
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
./scripts/calculate-week.py
|
|
|
|
# Or for a specific date:
|
|
./scripts/calculate-week.py --date 2025-11-13
|
|
|
|
# Or get JSON output:
|
|
./scripts/calculate-week.py --json
|
|
```
|
|
|
|
This script uses **today's date** (not the start date) and calculates the ISO week number, generating the correct filename format: `content/posts/{year}/{date}-w{week}.md`
|
|
|
|
**Important:** Ensure the year directory exists before saving:
|
|
```python
|
|
import os
|
|
year_dir = f"content/posts/{start_date.year}"
|
|
os.makedirs(year_dir, exist_ok=True)
|
|
```
|
|
|
|
**If not in the blog directory**, save to a temporary location (e.g., `/tmp/weeknotes-YYYY-MM-DD.md`) and ask the user where they'd like to move it
|
|
|
|
### Step 7: Select Cover Image Thumbnail
|
|
|
|
Review the images already embedded in the post and select one to use as the cover thumbnail:
|
|
|
|
1. **Analyze embedded images:**
|
|
- Review all images included in the post (from Mastodon posts)
|
|
- Consider their alt text/descriptions
|
|
- Evaluate which image best represents the overall themes of the weeknotes
|
|
|
|
2. **Selection criteria:**
|
|
- **Thematic relevance**: Image should represent main topics/themes, not just incidental content
|
|
- **Visual interest**: Choose images that are visually distinct and engaging
|
|
- **Quality**: Avoid low-quality screenshots or purely text-based images
|
|
- **Context**: Consider the image's role in the narrative - is it central to a main section or just a side note?
|
|
|
|
3. **Priority order:**
|
|
- Images related to primary themes/topics in the post
|
|
- Project photos, interesting technical subjects
|
|
- Noteworthy screenshots or visual examples
|
|
- Cat photos (only if cats are a significant theme of the week)
|
|
- Last resort: use the first image in the post
|
|
|
|
4. **Add to frontmatter:**
|
|
- Update the YAML frontmatter to include the `thumbnail:` property
|
|
- Use the full URL of the selected image
|
|
|
|
```yaml
|
|
---
|
|
title: "Weeknotes: [Date Range]"
|
|
date: YYYY-MM-DD
|
|
thumbnail: "https://cdn.masto.host/.../selected-image.jpg"
|
|
tags:
|
|
- weeknotes
|
|
- [other-tags]
|
|
layout: post
|
|
---
|
|
```
|
|
|
|
5. **If no suitable images exist in the post:**
|
|
- Omit the `thumbnail:` property for now
|
|
- The blog software will use the first image as a fallback
|
|
- Note: Future enhancement will add public domain image search
|
|
|
|
### Step 8: User Feedback and Final Refinement
|
|
|
|
1. Present the composed weeknotes to the user
|
|
2. Ask if they want any adjustments:
|
|
- Different tone or style
|
|
- More/less detail in certain areas
|
|
- Additional context or reflection
|
|
- Restructuring of content
|
|
3. Make requested edits
|
|
4. Offer to add a final reflection section if desired
|
|
|
|
## Additional Operations
|
|
|
|
### Updating Binaries
|
|
|
|
To update the Go CLI binaries to the latest releases:
|
|
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
./scripts/download-binaries.sh
|
|
```
|
|
|
|
This downloads the latest versions of:
|
|
- `mastodon-to-markdown`
|
|
- `linkding-to-markdown`
|
|
|
|
For all supported platforms (darwin-arm64, darwin-amd64, linux-amd64).
|
|
|
|
### Reconfiguring
|
|
|
|
To update API credentials, change data source settings, or add/update style reference URL:
|
|
|
|
```bash
|
|
cd /path/to/weeknotes-blog-post-composer
|
|
./scripts/setup.sh
|
|
```
|
|
|
|
The setup script will detect existing configuration and ask for confirmation before reconfiguring. This includes:
|
|
- Mastodon server URL and access token
|
|
- Linkding URL and API token
|
|
- Weeknotes archive URL for style reference (optional)
|
|
|
|
### Customizing the Output Style
|
|
|
|
The composition process is flexible and can be customized based on user preferences:
|
|
|
|
1. **Tone and Style:**
|
|
- More formal or casual
|
|
- Technical vs. personal
|
|
- Detailed vs. high-level summaries
|
|
|
|
2. **Structure:**
|
|
- Different section organization
|
|
- Thematic groupings vs. chronological
|
|
- Depth of technical detail
|
|
|
|
3. **Content Selection:**
|
|
- Which topics to emphasize
|
|
- What to skip or summarize briefly
|
|
- Which links/posts deserve more attention
|
|
|
|
Ask the user about their preferences for these aspects when composing weeknotes.
|
|
|
|
### Adding New Data Sources
|
|
|
|
To extend the skill with additional data sources:
|
|
|
|
1. Add the new Go CLI binary to `bin/{platform}-{arch}/`
|
|
2. Update `scripts/fetch-sources.sh` to fetch from the new source
|
|
3. Update the SKILL.md Step 3 to instruct Claude to read the new source files
|
|
4. Update Step 4 composition guidance to explain how to integrate the new content
|
|
|
|
## Platform Detection
|
|
|
|
All scripts automatically detect the current platform and use the appropriate binary:
|
|
|
|
- **macOS ARM64**: `bin/darwin-arm64/`
|
|
- **macOS Intel**: `bin/darwin-amd64/`
|
|
- **Linux AMD64**: `bin/linux-amd64/`
|
|
|
|
Platform detection is handled automatically via `uname` commands. No manual configuration needed.
|
|
|
|
## Resources
|
|
|
|
### scripts/
|
|
|
|
- `setup.sh` - First-time configuration for API credentials
|
|
- `fetch-sources.sh` - Fetch data from all configured sources
|
|
- `prepare-sources.py` - Verify fetched data and prepare for composition
|
|
- `calculate-week.py` - Calculate ISO week number and generate filename for weeknotes
|
|
- `download-binaries.sh` - Update Go CLI binaries to latest releases
|
|
|
|
### bin/
|
|
|
|
Pre-compiled Go CLI binaries organized by platform:
|
|
- `mastodon-to-markdown` - Fetch Mastodon posts as markdown
|
|
- `linkding-to-markdown` - Fetch Linkding bookmarks as markdown
|
|
|
|
Binaries are platform-specific and automatically selected at runtime.
|
|
|
|
### config/
|
|
|
|
- `config.json` - User configuration with API credentials and optional settings (created by setup.sh)
|
|
- Contains Mastodon server URL and access token
|
|
- Contains Linkding URL and API token
|
|
- Optionally contains weeknotes_archive URL for style reference
|
|
- This file contains sensitive tokens and is secured with 600 permissions
|
|
|
|
### data/
|
|
|
|
- `latest/` - Most recently fetched source data
|
|
- Other directories for historical or custom fetches
|
|
- Contains `mastodon.md` and `linkding.md` after fetching
|
|
|
|
## Troubleshooting
|
|
|
|
### Configuration Issues
|
|
|
|
If setup fails:
|
|
- Verify API credentials are correct
|
|
- Check that server URLs are accessible
|
|
- Ensure tokens have appropriate permissions
|
|
|
|
### Binary Not Found
|
|
|
|
If platform detection fails:
|
|
```bash
|
|
# Check current platform
|
|
uname -s # Should show: Darwin or Linux
|
|
uname -m # Should show: arm64, x86_64, etc.
|
|
|
|
# Verify binary exists
|
|
ls -la bin/darwin-arm64/ # Or appropriate platform directory
|
|
```
|
|
|
|
### Empty Content
|
|
|
|
If fetched data is empty:
|
|
- Verify the date range includes actual activity
|
|
- Check that API credentials have read permissions
|
|
- Run fetch scripts with `--verbose` flag for debugging
|
|
|
|
### Template Errors
|
|
|
|
If composition fails with template errors:
|
|
- Verify `assets/weeknotes-template.md` exists and is readable
|
|
- Check that all required placeholders are present
|
|
- Ensure no syntax errors in template YAML frontmatter
|