stevensDemohandleUSPSEmail.ts5 matches
85console.log(e.text);
8687// Get Anthropic API key from environment
88const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
89if (!apiKey) {
90console.error("Anthropic API key is not configured for this val.");
91return;
92}
9394// Initialize Anthropic client
95const anthropic = new Anthropic({ apiKey });
9697// Process each image attachment serially
stevensDemohandleTelegramMessage.ts7 matches
9293/**
94* Format chat history for Anthropic API
95*/
96function formatChatHistoryForAI(history) {
321bot.on("message", async (ctx) => {
322try {
323// Get Anthropic API key from environment
324const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
325if (!apiKey) {
326console.error("Anthropic API key is not configured.");
327ctx.reply(
328"I apologize, but I'm not properly configured at the moment. Please inform the household administrator."
332333// Initialize Anthropic client
334const anthropic = new Anthropic({ apiKey });
335336// Get message text and user info
502// Set webhook if it is not set yet
503if (!isEndpointSet) {
504await bot.api.setWebhook(req.url, {
505secret_token: SECRET_TOKEN,
506});
stevensDemogetWeather.ts5 matches
27async function generateConciseWeatherSummary(weatherDay) {
28try {
29// Get API key from environment
30const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
31if (!apiKey) {
32console.error("Anthropic API key is not configured.");
33return null;
34}
3536// Initialize Anthropic client
37const anthropic = new Anthropic({ apiKey });
3839const response = await anthropic.messages.create({
stevensDemogenerateFunFacts.ts5 matches
77async function generateFunFacts(previousFacts) {
78try {
79// Get API key from environment
80const apiKey = Deno.env.get("ANTHROPIC_API_KEY");
81if (!apiKey) {
82console.error("Anthropic API key is not configured.");
83return null;
84}
8586// Initialize Anthropic client
87const anthropic = new Anthropic({ apiKey });
8889// Format previous facts for the prompt
stevensDemo.cursorrules10 matches
20### 2. HTTP Vals
2122- Create web APIs and endpoints
23- Handle HTTP requests and responses
24- Example structure:
66- Generate code in TypeScript
67- Add appropriate TypeScript types and interfaces for all data structures
68- Prefer official SDKs or libraries than writing API calls directly
69- Ask the user to supply API or library documentation if you are at all unsure about it
70- **Never bake in secrets into the code** - always use environment variables
71- Include comments explaining complex logic (avoid commenting obvious operations)
190- For AI-generated images, use: `https://maxm-imggenurl.web.val.run/the-description-of-your-image`
191- **Storage:** DO NOT use the Deno KV module for storage
192- **Browser APIs:** DO NOT use the `alert()`, `prompt()`, or `confirm()` methods
193- **Weather Data:** Use open-meteo for weather data (doesn't require API keys) unless otherwise specified
194- **View Source:** Add a view source link with `import.meta.url.replace("esm.town", "val.town")` and include `target="_top"` attribute
195- **Error Debugging:** Add `<script src="https://esm.town/v/std/catch"></script>` to HTML to capture client-side errors
196- **Error Handling:** Only use try...catch when there's a clear local resolution; avoid catches that merely log or return 500s - let errors bubble up with full context
197- **Environment Variables:** Use `Deno.env.get('keyname')` and minimize their use - prefer APIs without keys
198- **Imports:** Use `https://esm.sh` for npm and Deno dependencies to ensure compatibility on server and browser
199- **Storage Strategy:** Only use backend storage if explicitly required; prefer simple static client-side sites
230231### Backend (Hono) Best Practices
232- Hono is the recommended API framework (similar to Express, Flask, or Sinatra)
233- Main entry point should be `backend/index.ts`
234- **Static asset serving:** Use the utility functions to read and serve project files:
251});
252```
253- Create RESTful API routes for CRUD operations
254- Be careful with error handling as Hono tends to swallow errors
255- Always include this snippet at the top-level Hono app to re-throwing errors to see full stack traces:
268- Use React 18.2.0 consistently in all imports and the `@jsxImportSource` pragma
269- Follow the React component pattern from the example project
270- Handle API calls properly with proper error catching
271272### Database Patterns
299- For files in the project, use `readFile` helpers
3003015. **API Design:**
302- `fetch` handler is the entry point for HTTP vals
303- Run the Hono app with `export default app.fetch // This is the entry point for HTTP vals`
stevensDemoApp.tsx8 matches
10import { NotebookView } from "./NotebookView.tsx";
1112const API_BASE = "/api/memories";
13const MEMORIES_PER_PAGE = 20; // Increased from 7 to 20 memories per page
149091// Fetch avatar image
92fetch("/api/images/stevens.jpg")
93.then((response) => {
94if (response.ok) return response.blob();
104105// Fetch wood background
106fetch("/api/images/wood.jpg")
107.then((response) => {
108if (response.ok) return response.blob();
133setError(null);
134try {
135const response = await fetch(API_BASE);
136if (!response.ok) {
137throw new Error(`HTTP error! status: ${response.status}`);
176177try {
178const response = await fetch(API_BASE, {
179method: "POST",
180headers: { "Content-Type": "application/json" },
199200try {
201const response = await fetch(`${API_BASE}/${id}`, {
202method: "DELETE",
203});
231232try {
233const response = await fetch(`${API_BASE}/${editingMemory.id}`, {
234method: "PUT",
235headers: { "Content-Type": "application/json" },
606<div className="font-pixel text-[#f8f1e0]">
607<style jsx>{`
608@import url("https://fonts.googleapis.com/css2?family=Pixelify+Sans&display=swap");
609610@tailwind base;
5const responses = await Promise.all(
6tailscaleNodeIds.map(async (tailscaleNodeId) => {
7const response = await fetch(`https://api.tailscale.com/api/v2/device/${tailscaleNodeId}`, {
8headers: {
9"Authorization": `Bearer ${Deno.env.get("tailscaleApiKey")}`,
10},
11});
telegramBotStarterindex.ts1 match
30// This is a no-op if nothing's changed
31if (!isEndpointSet) {
32await bot.api.setWebhook(req.url, {
33secret_token: SECRET_TOKEN,
34});
survivor-planindex.ts28 matches
27getQuickGuidance,
28buildDailyProgressText
29} from "./api/ai-assistant.ts";
30import { sendDailyEmail, sendWeeklyEmail } from "./api/email.ts";
3132// Create the Hono app
60});
6162// Migration API endpoint
63app.post("/api/migrate", async c => {
64const body = await c.req.json();
65const { version } = body;
86});
8788// API Routes
89// Get all tracks
90app.get("/api/tracks", async c => {
91try {
92const tracks = await queries.getTracks();
99100// Update track status
101app.put("/api/tracks/:id", async c => {
102const trackId = parseInt(c.req.param("id"));
103const body = await c.req.json();
118119// Get all tasks
120app.get("/api/tasks", async c => {
121try {
122const tasks = await queries.getTasks();
129130// Get tasks by track
131app.get("/api/tracks/:id/tasks", async c => {
132const trackId = parseInt(c.req.param("id"));
133
142143// Update task status
144app.put("/api/tasks/:id/status", async c => {
145const taskId = parseInt(c.req.param("id"));
146const body = await c.req.json();
161162// Update task notes
163app.put("/api/tasks/:id/notes", async c => {
164const taskId = parseInt(c.req.param("id"));
165const body = await c.req.json();
176177// Get daily log
178app.get("/api/daily-logs/:date", async c => {
179const date = c.req.param("date");
180
194195// Create/update daily log
196app.post("/api/daily-logs", async c => {
197const body = await c.req.json();
198const { date, notes, wins, challenges, tracksProgress } = body;
255256// Get weekly review
257app.get("/api/weekly-reviews/:weekNumber", async c => {
258const weekNumber = parseInt(c.req.param("weekNumber"));
259
273274// Create weekly review
275app.post("/api/weekly-reviews", async c => {
276const body = await c.req.json();
277const { weekNumber, metricsData, gapsIdentified, adjustedTargets, recalibratedPriorities } = body;
337338// Get user status
339app.get("/api/user-status", async c => {
340try {
341const userStatus = await queries.getUserStatus();
353354// Create/update user status
355app.post("/api/user-status", async c => {
356const body = await c.req.json();
357const { timeAvailability, financialNeeds, mentalState, obstacles } = body;
374375// Get track prompts
376app.get("/api/track-prompts", async c => {
377try {
378const trackPrompts = await queries.getTrackPrompts();
385386// Get track prompt by track ID
387app.get("/api/tracks/:id/prompt", async c => {
388const trackId = parseInt(c.req.param("id"));
389
403404// Update track prompt
405app.put("/api/tracks/:id/prompt", async c => {
406const trackId = parseInt(c.req.param("id"));
407const body = await c.req.json();
425426// Get AI guidance for a track
427app.post("/api/tracks/:id/guidance", async c => {
428const trackId = parseInt(c.req.param("id"));
429
446447// Get daily standup feedback
448app.post("/api/daily-standup", async c => {
449try {
450// Get user status
483484// Get weekly review feedback
485app.post("/api/weekly-review-feedback", async c => {
486const body = await c.req.json();
487const { weekNumber } = body;
551552// Get quick guidance
553app.post("/api/quick-guidance", async c => {
554const body = await c.req.json();
555const { specificQuestion, relevantContext, immediateCircumstances } = body as GuidanceRequest;
575576// Get recent AI responses
577app.get("/api/ai-responses", async c => {
578try {
579const responses = await queries.getRecentAIResponses();
586587// Trigger daily email
588app.post("/api/send-daily-email", async c => {
589try {
590const success = await sendDailyEmail();
602603// Trigger weekly email
604app.post("/api/send-weekly-email", async c => {
605try {
606const success = await sendWeeklyEmail();
618619// Get basic info
620app.get("/api/info", c => {
621const currentDay = getCurrentDay();
622const currentWeek = getCurrentWeek();
blob_adminmain.tsx6 matches
1516// Public route without authentication
17app.get("/api/public/:id", async (c) => {
18const key = `__public/${c.req.param("id")}`;
19const { blob } = await import("https://esm.town/v/std/blob");
133};
134135app.get("/api/blobs", checkAuth, async (c) => {
136const prefix = c.req.query("prefix") || "";
137const limit = parseInt(c.req.query("limit") || "20", 10);
142});
143144app.get("/api/blob", checkAuth, async (c) => {
145const key = c.req.query("key");
146if (!key) return c.text("Missing key parameter", 400);
150});
151152app.put("/api/blob", checkAuth, async (c) => {
153const key = c.req.query("key");
154if (!key) return c.text("Missing key parameter", 400);
159});
160161app.delete("/api/blob", checkAuth, async (c) => {
162const key = c.req.query("key");
163if (!key) return c.text("Missing key parameter", 400);
167});
168169app.post("/api/blob", checkAuth, async (c) => {
170const { file, key } = await c.req.parseBody();
171if (!file || !key) return c.text("Missing file or key", 400);