Proxy Google Docs List Today
const docs = response.data.files.map((f) => ( id: f.id, name: f.name, createdTime: f.createdTime, modifiedTime: f.modifiedTime, owner: f.owners?.[0]?.displayName ?? "unknown" ));
fetch('http://localhost:3000/list-docs') .then(r => r.json()) .then(data => console.log(`You have $data.count docs`); data.docs.forEach(doc => console.log(`$doc.name (ID: $doc.id)`)); ) .catch(console.error); Because the proxy already handled authentication, no Google credentials ever touch the browser – a big win for security. 8️⃣ Security & Production Tips | Concern | Recommendation | |---------|----------------| | Secret storage | Never commit service-account.json , oauth-client.json , or oauth-token.json to Git. Use environment variables ( GOOGLE_APPLICATION_CREDENTIALS ) or a secret‑manager (AWS Secrets Manager, GCP Secret Manager). | | Rate limiting | Add a simple IP‑based limiter ( express-rate-limit ) to protect the endpoint from abuse. | | CORS | If you plan to call the proxy from another domain, enable CORS only for allowed origins ( app.use(cors(origin: 'https://my-app.example.com')) ). | | HTTPS | In production, terminate TLS at your load balancer or reverse proxy (NGINX, Cloudflare). Never expose the proxy over plain HTTP on the public internet. | | Scopes | Grant the least privileged scope ( drive.readonly ). If you need edit capabilities later, expand scopes deliberately. | | Pagination | The example uses pageSize: 1000 . For very large accounts, implement nextPageToken handling to stream results. | | Logging | Strip any personally‑identifiable information before writing logs to external services. | | Monitoring | Hook the /healthz endpoint into your monitoring stack (Prometheus, Datadog, etc.). | 9️⃣ Alternate implementations (quick cheats) | Language | Minimal snippet (only the list request) | |----------|------------------------------------------| | Python (Flask) | Show code```python\nfrom flask import Flask, jsonify\nfrom google.oauth2 import service_account\nfrom googleapiclient.discovery import build\n\napp = Flask( name )\n Proxy Google Docs List
const __filename = fileURLToPath(import.meta.url); const __dirname = path.dirname(__filename); const docs = response
# 3️⃣ Start npm start First run (OAuth path only) You’ll see a URL printed to the console. Open it, grant the permissions, copy the parameter, paste it back into the terminal, and the token will be saved for subsequent runs. Example response "count": 3, "docs": [ "id": "1A2b3C4d5E6F7g8H9iJ0kLmNoP", "name": "Project Plan", "createdTime": "2024-08-12T14:32:11Z", "modifiedTime": "2024-11-04T09:21:57Z", "owner": "alice@example.com" , "id": "2B3c4D5e6F7g8H9iJ0kLmNoP1Q", "name": "Marketing Brief", "createdTime": "2024-09-01T10:05:03Z", "modifiedTime": "2024-10-30T16:40:12Z", "owner": "bob@example.com" , ... ] | | HTTPS | In production, terminate TLS
const app = express(); const PORT = process.env.PORT || 3000;
// ────────────────────────────────────────────────────────────── // 2️⃣ Route: GET /list-docs // Returns a compact JSON array of Google Docs files. // ────────────────────────────────────────────────────────────── app.get("/list-docs", async (req, res) => try const auth = await getAuthClient(); const drive = google.drive( version: "v3", auth );