PDO::ERRMODE_EXCEPTION, PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8mb4", ] ); // --- Fetch newest completed CA entry --- // Assumes h305_ca77_entries is either a view or table already filtered to "completed" rows $sql = " SELECT model_year, model, ADM_StateOrProvince, ADM_Country, condition_value, opinion_value_today FROM h305_ca77_entries ORDER BY submitdate DESC, id DESC LIMIT 1 "; $row = $pdo->query($sql)->fetch(PDO::FETCH_ASSOC); // --- Helpers for casing normalization (same pattern as CB / CL) --- $keepCaps = static function (string $w): bool { // Keep original word case if it's already an acronym (2+ caps) or has a digit return (bool)preg_match('/[A-Z]{2,}/', $w) || (bool)preg_match('/\d/', $w); }; $word = static function (?string $w) use ($keepCaps): string { if ($w === null || $w === '') { return ''; } // Respect hyphenated parts independently if (strpos($w, '-') !== false) { $parts = explode('-', $w); foreach ($parts as &$x) { $x = $keepCaps($x) ? $x : ucfirst(strtolower($x)); } return implode('-', $parts); } // Already looks like an acronym or has digits -> leave alone if ($keepCaps($w)) { return $w; } $dot = substr($w, -1) === '.'; $base = $dot ? substr($w, 0, -1) : $w; $done = ucfirst(strtolower($base)); return $dot ? ($done . '.') : $done; }; $titleCase = static function (?string $s) use ($word): string { if ($s === null) { return ''; } $s = trim($s); if ($s === '') { return ''; } $t = preg_split('/\s+/', $s) ?: []; foreach ($t as &$x) { $x = $word($x); } return trim(implode(' ', $t), ", "); }; // --- Build display line --- if (!$row) { $line = 'Latest Registry Entry: No completed entries found.'; } else { // Location: "WA, Australia" (skip empties, title-case each part) $region = $titleCase($row['ADM_StateOrProvince'] ?? ''); $country = $titleCase($row['ADM_Country'] ?? ''); $loc = trim( implode(', ', array_filter([$region, $country], static fn($v) => $v !== '')), ', ' ); // Normalize opinion_value_today using CL rules: // >=1000 => use as-is ($12500 => $12,500) // 100..999 => treat as dollars ($750 => $750) // 1..99 => treat as thousands (6 => $6,000) // otherwise => "Not Entered" $valFinal = 'Not Entered'; if (isset($row['opinion_value_today']) && $row['opinion_value_today'] !== '') { $n = (float)$row['opinion_value_today']; if ($n >= 1000) { $valFinal = '$' . number_format($n, 0); } elseif ($n >= 100) { $valFinal = '$' . number_format($n, 0); } elseif ($n > 0) { $valFinal = '$' . number_format($n * 1000, 0); } } // Condition decoding (same mapping you provided, with fallback) $condRaw = $row['condition_value'] ?? ''; $condMap = [ 'E' => 'Excellent', 'Exc' => 'Excellent', 'G' => 'Good', 'Goo' => 'Good', 'F' => 'Fair', 'P' => 'Poor', 'Par' => 'Parts Bike', 'R' => 'Restored', 'Res' => 'Restored', 'Rat' => 'Rat', ]; $condNice = $condMap[$condRaw] ?? ($condRaw !== '' ? $condRaw : 'Not Entered'); // Gracefully handle blanks so we don't get double-spaces like " Honda " $yr = isset($row['model_year']) ? trim((string)$row['model_year']) : ''; $model = isset($row['model']) ? trim((string)$row['model']) : ''; $bikePart = trim($yr . ' Honda ' . $model); $locPart = $loc !== '' ? (' — ' . $loc) : ''; $line = 'Latest Registry Entry: ' . $bikePart . $locPart . ' — Condition: ' . $condNice . ' — Value: ' . $valFinal; } // --- Build final HTML snippet (static, safe to INCLUDEPHP in phpBB) --- $builtTs = (new DateTime('now'))->format('Y-m-d H:i:s T'); // These first two lines are harmless in phpBB output: and $charset = ''; $stamp = ''; $htmlOut = $charset . "\n" . $stamp . "\n" . $line . "\n"; // --- Write atomically to shared include dir --- $jobDir = __DIR__; // wherever this script lives $includeDir = '/home/mstoic3/public_html/shared/include'; $includeTmp = $includeDir . '/latest_ca77.tmp'; $includeDst = $includeDir . '/latest_ca77.html'; $jsonPath = $jobDir . '/latest_ca77.json'; $logPath = $jobDir . '/logs/latest_ca77.log'; // reserved for future logging if (!is_dir($includeDir)) { if (!mkdir($includeDir, 0755, true) && !is_dir($includeDir)) { throw new RuntimeException("Failed to create include dir: $includeDir"); } } if (file_put_contents($includeTmp, $htmlOut, LOCK_EX) === false) { throw new RuntimeException('Failed to write temp include file'); } if (!rename($includeTmp, $includeDst)) { @unlink($includeTmp); throw new RuntimeException('Failed to move include into place'); } // --- Optional JSON breadcrumb for debugging / external consumption --- @file_put_contents( $jsonPath, json_encode( [ 'line' => $line, 'stamp' => $builtTs, 'ts' => date('c'), ], JSON_UNESCAPED_UNICODE ) ); // --- Done --- echo "OK\n"; exit(0); } catch (Throwable $e) { // Minimal error surface; log server-side, generic public output error_log("[generate_latest_ca77.php] " . $e->getMessage()); if (function_exists('http_response_code')) { @http_response_code(500); } echo "ERROR\n"; exit(1); }

How to tell the year of a CA77

Post Reply
curtf
honda305.com Member
Posts: 7
Joined: Sat Apr 15, 2006 4:45 pm

How to tell the year of a CA77

Post by curtf » Fri May 05, 2006 12:04 pm

I am looking for some assistance within the forum and am confident that someone out there can tell me what year my CA77/CA78 is. The engine has VIN# CA77E-1022852 and the frame has CA78-1022744. It may be possible that the engine was replaced but I have no clue and the previous owner is unaware as well.

Thanks in advance for your help.

Curt

joeweir1
honda305.com Member
Posts: 761
Joined: Wed Mar 08, 2006 9:35 am
Location: middletown,pa

year

Post by joeweir1 » Fri May 05, 2006 4:24 pm

This seems to be a 65' I believe maybe 66'. Some people go by a small white tag on the wiring harness. It is usually hard to see and runs up thru the frame above the engine.Also, on the plug wires there are dates typed on those also (need to pull back outer rubber shield)if they are original.My numbers are close to yours. From what others on here have stated is that Honda went with 7 digits on the VIN# in 65' sometime.I just tore down aCA72(250 Dream) and the title said 65' but the wiring harness said 63' and the plug wires said 65'.Plus a bike may have sat in a dealer for a year or more and then titled for the year it was sold.I know a retired gentleman who bought one new in 64' and still has it and it has 6 digits on VIN#.Hope that helps.Others on here like loudmouse know more than me.You out there mouse?

joeweir1
honda305.com Member
Posts: 761
Joined: Wed Mar 08, 2006 9:35 am
Location: middletown,pa

Post by joeweir1 » Fri May 05, 2006 4:26 pm

p.s.-Eng and Frame numbers on these bikes do not match and probably you have original engine in bike.

olbikenut
honda305.com Member
Posts: 2
Joined: Sat May 13, 2006 2:16 pm
Location: North Texas

Post by olbikenut » Sat May 13, 2006 2:33 pm

Curt,

Check out Bill Silvers piece on the VJMC site. Read it several times and you will see what you need to date your bike I too would lean towards a late 65 or early 66.
old bikes like old men have to be pushstarted

curtf
honda305.com Member
Posts: 7
Joined: Sat Apr 15, 2006 4:45 pm

Post by curtf » Tue May 16, 2006 12:32 pm

Thanks guys. This is turning into quite the project. Every time I make progress in one area, another issue pops up. Don’t get me wrong, this will be a fun challenge for a while. Lots of opportunity to get my hands dirty.

Curt

amish_greaser
honda305.com Member
Posts: 5
Joined: Sun Jul 09, 2006 1:52 pm

Post by amish_greaser » Sun Jul 09, 2006 2:09 pm

I was just recently given a dream and the engine has a ca77e-1032965 on it..so I assume this is a 65 my question is is it a late or early year model and I need a battery cover and I was told that a late 65 can use a 66 battery cover . Is this true. I'm a newb to these great little bikes so I would appreciate any response


thanks Steve

joeweir1
honda305.com Member
Posts: 761
Joined: Wed Mar 08, 2006 9:35 am
Location: middletown,pa

Post by joeweir1 » Sun Jul 09, 2006 2:31 pm

Yes, if you have the smaller battery box which was changed in 65' from a wide battery at some point the 66' and later are the same.

Post Reply

Return to “Honda Dream - CA72 | CA77 | CA78”