1
0
mirror of https://gitlab.com/Anson-Projects/projects.git synced 2025-09-19 03:52:37 +00:00

8 Commits

Author SHA1 Message Date
bbeb71b1b5 Fix RSS feed generation by moving site-url to top level 2025-08-23 14:18:46 -06:00
fb197830aa Debug RSS feed generation in CI 2025-08-23 14:04:14 -06:00
1a7ecc1acd Add comprehensive RSS feed configuration 2025-08-23 14:03:26 -06:00
f81c2a6e21 Enable RSS feed generation and remove debug code 2025-08-23 11:47:05 -06:00
cf5021e682 Debug CI artifacts to locate RSS feed file 2025-08-23 00:43:59 -06:00
54f2a1bc53 Fix RSS feed parsing by reading from local artifacts
- Change fetch_feed to read from local file instead of HTTP request
- Update feed path to use ../public/index.xml from GitLab CI artifacts
- Add better error messages for file reading and parsing failures
- Resolves ParseError(NoFeedRoot) by avoiding 404 from live website
2025-08-22 23:34:32 -06:00
a6dd33ce5f Merge branch 'ghost-content-extraction' into 'master'
Claude: Ghost Content Extraction

See merge request Anson-Projects/projects!11
2025-08-22 11:32:50 -07:00
556c56fee4 Claude: Ghost Content Extraction 2025-08-22 11:32:49 -07:00
4 changed files with 20 additions and 52 deletions

View File

@@ -16,6 +16,8 @@ staging:
script: script:
- echo "Building the main website with Quarto..." - echo "Building the main website with Quarto..."
- quarto render --to html --output-dir public - quarto render --to html --output-dir public
- echo "Checking for RSS feed after render..."
- ls -la public/ | grep -E "\.xml|index\.xml" || echo "No XML files found in public directory"
- echo "Building Ghost-optimized version..." - echo "Building Ghost-optimized version..."
- quarto render --profile ghost --to html --output-dir public/ghost-content - quarto render --profile ghost --to html --output-dir public/ghost-content
artifacts: artifacts:

View File

@@ -1,12 +1,18 @@
project: project:
type: website type: website
website:
title: "Anson's Projects"
site-url: https://projects.ansonbiggs.com
description: A Blog for Technical Topics
profiles: profiles:
default: default:
website: website:
title: "Anson's Projects" title: "Anson's Projects"
site-url: https://projects.ansonbiggs.com site-url: https://projects.ansonbiggs.com
description: A Blog for Technical Topics description: A Blog for Technical Topics
author: "Anson Biggs"
navbar: navbar:
left: left:
- text: "About" - text: "About"
@@ -17,6 +23,11 @@ profiles:
# - icon: gitlab # - icon: gitlab
# href: https://gitlab.com/MisterBiggs # href: https://gitlab.com/MisterBiggs
open-graph: true open-graph: true
feed:
title: "Anson's Projects"
description: "A Blog for Technical Topics"
author: "Anson Biggs"
items: 10
format: format:
html: html:
theme: zephyr theme: zephyr

View File

@@ -5,8 +5,6 @@ publish:
- cd ./ghost-upload - cd ./ghost-upload
- cargo run - cargo run
needs: needs:
- job: pages - pages
optional: true
rules: rules:
- if: "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH" - if: "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH"
- if: "$CI_COMMIT_BRANCH == 'ghost-content-extraction'" # Allow testing on this branch

View File

@@ -227,48 +227,12 @@ async fn get_existing_post_id(slug: &str, token: &str) -> Option<String> {
} }
} }
async fn fetch_feed(url: &str) -> Vec<Entry> { async fn fetch_feed(path: &str) -> Vec<Entry> {
println!("Fetching RSS feed from: {}", url); // Read from local file instead of HTTP request
let content = std::fs::read_to_string(path).expect("Failed to read RSS feed file");
let response = reqwest::get(url).await;
let response = match response { let feed = parser::parse(content.as_bytes()).expect("Failed to parse RSS feed");
Ok(resp) => resp,
Err(e) => {
println!("Failed to fetch RSS feed: {}", e);
return vec![];
}
};
if !response.status().is_success() {
println!("RSS feed request failed with status: {}", response.status());
return vec![];
}
let content = match response.text().await {
Ok(text) => text,
Err(e) => {
println!("Failed to read RSS feed content: {}", e);
return vec![];
}
};
if content.trim().is_empty() {
println!("RSS feed content is empty");
return vec![];
}
println!("RSS feed content preview: {}", &content[..content.len().min(200)]);
let feed = match parser::parse(content.as_bytes()) {
Ok(f) => f,
Err(e) => {
println!("Failed to parse RSS feed: {:?}", e);
println!("Feed content starts with: {}", &content[..content.len().min(500)]);
return vec![];
}
};
println!("Successfully parsed RSS feed with {} entries", feed.entries.len());
feed.entries feed.entries
} }
@@ -333,7 +297,7 @@ async fn main() {
let feed = "https://projects.ansonbiggs.com/index.xml"; let feed = "../public/index.xml";
// Split the key into ID and SECRET // Split the key into ID and SECRET
let (id, secret) = ghost_admin_api_key let (id, secret) = ghost_admin_api_key
@@ -365,13 +329,6 @@ async fn main() {
// Prepare the post data // Prepare the post data
let entries = fetch_feed(feed).await; let entries = fetch_feed(feed).await;
if entries.is_empty() {
println!("No entries found in RSS feed or feed parsing failed. Exiting.");
return;
}
println!("Processing {} entries from RSS feed", entries.len());
let post_exists_futures = entries.into_iter().map(|entry| { let post_exists_futures = entries.into_iter().map(|entry| {
let entry_clone = entry.clone(); let entry_clone = entry.clone();