Proxy Google Docs List (2027)

dotenv.config(); // loads .env (optional)

const app = express(); const PORT = process.env.PORT || 3000;

# 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" , ... ]

res.json( count: docs.length, docs ); catch (err) console.error("❌ Error while listing Docs:", err); res.status(500).json( error: "Failed to fetch Google Docs list", details: err.message ); );

// ------- OAuth2 (interactive) ------- const oauthCreds = JSON.parse(await readFile(oauthPath, "utf8")); const client_id, client_secret, redirect_uris = oauthCreds.installed

const __filename = fileURLToPath(import.meta.url); const __dirname = path.dirname(__filename);

// Query only Google Docs (mimeType = application/vnd.google-apps.document) const response = await drive.files.list( q: "mimeType='application/vnd.google-apps.document' and trashed = false", fields: "files(id, name, createdTime, modifiedTime, owners/displayName)", pageSize: 1000 // adjust as needed (max 1000 per request) );

// ────────────────────────────────────────────────────────────── // 1️⃣ Helper: create an authenticated Google API client // ────────────────────────────────────────────────────────────── async function getAuthClient() path.join(__dirname, "oauth-client.json");