Behöver ert företag hjälp med att implementera AI? Kontakta oss och få prisoffert här →
AI Skolan
januari 22, 2026

Google Drive + Supabase: alltid aktuella AI-svar

Rickard Andersson Partner, Nodenordic.se

Din AI-assistent hade rätt i går. I dag har den självsäkert fel, eftersom någon uppdaterade ett dokument i Google Drive och din vektordatabas aldrig hann ikapp. Den luckan skapar “inaktuella svar”, och den är brutal att upptäcka förrän en kund eller kollega påpekar det.

Marketing ops-team märker det när budskapsdokument ändras mitt i en kampanj. Byråägare stöter på det med levande SOP:ar och kundplaybooks. Till och med en upptagen grundare ser det när interna dokument redigeras varje vecka. Den här Drive Supabase-synken gör dokumentändringar till AI-svar som alltid är uppdaterade.

Det här arbetsflödet bevakar filuppdateringar, tar bort föråldrade vektorer, ökar versionsnumret och läser sedan in det senaste innehållet i Supabase igen. Du ser exakt vad det gör, varför det spelar roll och hur du får igång det utan att överarbeta det.

Så fungerar den här automationen

Hela n8n-arbetsflödet, från trigger till slutresultat:

n8n Workflow Template: Google Drive + Supabase: alltid aktuella AI-svar

Problemet: dina AI-svar glider ur datum

RAG-system ser bara “smarta” ut när den underliggande kunskapen är aktuell. Men Google Drive är en levande plats: folk rättar pristexter, ändrar onboardingsteg, byter ut PDF:er och döper om filer. Om dina embeddings i Supabase inte uppdateras efter redigeringar kommer din AI att citera gamla stycken, referera till borttagna policys eller svara med en halvt uppdaterad blandning av båda. Då slösar du tid på att validera svar, jaga “rätt” dokumentversion och indexera om manuellt. Ärligt talat är det den värsta typen av operativ skuld, eftersom den gömmer sig tills det verkligen gäller.

Friktionen byggs på. Här är var det faller isär i verkligheten.

  • Du slutar med att läsa in hela mappar på nytt manuellt bara för att fixa en uppdaterad fil.
  • Gamla vektor-chunks fortsätter vara sökbara, så AI:n kan “hämta” innehåll du raderade för flera dagar sedan.
  • Team tappar förtroendet snabbt, vilket gör att AI-assistenten slutar användas.
  • Utan versions-taggar kan du inte se om ett svar kom från v1 eller den senaste revisionen.

Lösningen: ta bort inaktuella vektorer och läs sedan in det uppdaterade dokumentet igen

Det här n8n-arbetsflödet körs i samma ögonblick som en fil uppdateras i din bevakade Google Drive-mapp (arbetsflödet kallar den “DOCUMENTS”). Först bekräftar det att händelsen är en riktig redigering, inte en stökig “uppdatering” som orsakas av en uppladdnings-/konverteringsprocess. Sedan hittar det varje befintlig vektor-chunk kopplad till filens ID i Supabase och raderar de raderna, så att inaktuellt innehåll inte längre kan hämtas. Efter den rensningen hämtar det den tidigare versionsetiketten från den raderade metadatan och använder ett OpenAI-steg för att öka den (v1 blir v2, och så vidare). Till sist bearbetar arbetsflödet den uppdaterade filen på nytt baserat på filtyp, extraherar text, chunkar den, skapar embeddings, lägger till ny metadata (inklusive den nya versionen) och upsertar allt tillbaka till din Supabase-vektorstore.

Arbetsflödet startar med en Google Drive-trigger för “file updated”. Det tar bort tidigare Supabase-rader för den filen, beräknar nästa versions-tagg och skickar sedan filen genom rätt extraheringsväg (PDF, Google Doc-konvertering, kalkylarksparsning, ren text). Supabase får då endast de aktuella chunkarna, korrekt versionshanterade, redo för hämtning.

Vad du får: automation vs. resultat

Exempel: så här ser det ut

Säg att ditt team uppdaterar cirka 10 dokument i veckan i Google Drive (prisblad, onboardingsteg, ett par SOP:ar). Manuellt betyder en “uppdatering” oftast att exportera filen, ladda upp eller bearbeta den igen, radera gamla poster och köra embeddings på nytt, vilket lätt kan ta cirka 15 minuter per dokument. Det är ungefär 2,5 timmar i veckan. Med det här arbetsflödet lägger du kanske 2 minuter på att bekräfta mappen och inloggningsuppgifterna, och varje redigering synkas automatiskt i bakgrunden. Tidskostnaden blir “nästan ingenting”, och svaren ligger i linje med vad som faktiskt står i dokumenten.

Det här behöver du

  • n8n-instans (prova n8n Cloud gratis)
  • Självhosting-alternativ om du föredrar det (Hostinger fungerar bra)
  • Google Drive för att övervaka mappen “DOCUMENTS”.
  • Supabase för att lagra vektorer i en documents-tabell.
  • OpenAI API-nyckel (hämta den från OpenAI API-dashboarden).

Kunskapsnivå: Medel. Du kopplar konton, väljer en mapp och verifierar Supabase-tabell/rättigheter.

Vill du inte sätta upp detta själv? Prata med en automationsexpert (gratis 15-minuters konsultation).

Så fungerar det

En filuppdatering i Google Drive triggar körningen. Arbetsflödet lyssnar efter “File Updated”-händelser i samma mapp som din ingest-pipeline använder, så att allt förblir konsekvent.

Brus filtreras bort tidigt. En “If”-kontroll förhindrar dubbla körningar som kan uppstå när ett annat arbetsflöde laddar upp ett Word-dokument och Google sedan konverterar det till ett Google-dokument (den konverteringen kan se ut som en uppdatering).

Gamla Supabase-vektorer tas bort, sedan höjs versionen. Arbetsflödet raderar alla chunks för matchande file_id i Supabase documents-tabellen, hämtar den gamla versions-taggen och använder sedan ett OpenAI-steg för att öka den så att du kan spåra vilket innehåll som är aktuellt.

Den uppdaterade filen läses in igen baserat på typ. En Switch skickar PDF:er till PDF-tolkning, kalkylark till kalkylarksextraktion och dokumentformat genom konvertering vid behov. Texten chunkas, får embeddings, berikas med metadata och upsertas sedan tillbaka till Supabase-vektorstoren.

Du kan enkelt ändra vilken mapp som övervakas för att täcka flera kunskapsbaser, eller justera chunk-storlek för att passa din sök-/hämtstil. Se hela implementationsguiden nedan för anpassningsalternativ.

Steg-för-steg-guide för implementation

Steg 1: Konfigurera Drive Update Trigger

Starta arbetsflödet genom att bevaka en specifik Google Drive-mapp efter uppdaterade filer så att nya eller redigerade dokument går in i pipelinen.

  1. Lägg till och konfigurera Drive Update Trigger.
  2. Ställ in EventfileUpdated.
  3. Ställ in Trigger OnspecificFolder och välj er mapp i Folder To Watch (t.ex. DOCUMENTS).
  4. Inloggningsuppgifter krävs: Anslut era googleDriveOAuth2Api-inloggningsuppgifter.

Tips: Behåll polling-intervallet på Every Minute under testning för att snabbt kunna validera uppdateringar.

Steg 2: Koppla Google Drive och Supabase-rensning

Fånga identifierare, validera filtyp/ålder och ta bort tidigare dokumentvektorer för en ren ominläsning.

  1. I Assign File Identifiers ställer ni in file_id till {{ $('Drive Update Trigger').item.json.id }} och file_type till {{ $('Drive Update Trigger').item.json.mimeType }}.
  2. I Conditional File Check skapar ni två villkor: mimeType equals application/vnd.google-apps.document och createdTime age {{ ((Date.now() - Date.parse($('Drive Update Trigger').item.json.createdTime)) / 1000) }} är mindre än 60.
  3. Konfigurera Remove Previous Doc Rows med Table ID documents, Operation delete och Filter String =metadata->>file_id=like.*{{ $('Assign File Identifiers').item.json.file_id }}*.
  4. Inloggningsuppgifter krävs: Anslut era supabaseApi-inloggningsuppgifter i Remove Previous Doc Rows.
  5. I Cap Items lämnar ni standardinställningarna för att begränsa batchstorleken nedströms före versionshantering.

⚠️ Vanlig fallgrop: Om filtersträngen i Remove Previous Doc Rows är felstavad kommer gamla vektorer att ligga kvar och orsaka dubbletter.

Steg 3: Sätt upp versionshantering och batchning

Skapa en versionsökning med OpenAI och förbered items för routning och hämtning. Batch Iterator skickar utdata till både Route by File Type och Retrieve Drive File parallellt.

  1. Konfigurera Increment Version Tag med Model gpt-4o-mini och aktivera JSON Output.
  2. Ställ in användarmeddelandets innehåll till incoming version number: {{ $json.metadata.version }} så att modellen ökar versionen.
  3. Inloggningsuppgifter krävs: Anslut era openAiApi-inloggningsuppgifter i Increment Version Tag.
  4. I Batch Iterator lämnar ni standardinställningarna så att items delas upp för både routning och filnedladdning.

Steg 4: Routa efter filtyp och hantera konverteringar

Routa dokument baserat på MIME-typ, tolka filer och konvertera format som inte stöds till Google Docs vid behov.

  1. I Route by File Type säkerställer ni att reglerna matchar MIME-typer som application/pdf, application/vnd.google-apps.document samt Excel-/Word-format.
  2. Konfigurera Retrieve Drive File med Operation download och aktivera Google-filkonvertering till text/plain.
  3. Inloggningsuppgifter krävs: Anslut era googleDriveOAuth2Api-inloggningsuppgifter i Retrieve Drive File.
  4. Ställ in Convert to Doc Format till POST https://www.googleapis.com/drive/v3/files/{{ $('Assign File Identifiers').item.json.file_id }}/copy med body-parametrarna name {{ $('Assign File Identifiers').item.json.name }} och mimeType application/vnd.google-apps.document.
  5. Inloggningsuppgifter krävs: Anslut era googleDriveOAuth2Api-inloggningsuppgifter i Convert to Doc Format och Remove Source File.

Tips: Om konvertering används tar Remove Source File bort originalfilen för att förhindra dubbel bearbetning.

Steg 5: Extrahera, kombinera och förbered dokumentmetadata

Extrahera innehåll från PDF:er, text och kalkylark, och berika sedan med metadata före embedding.

  1. Konfigurera extraktionsnoder: Parse PDF Content med Operation pdf, Read Text Content med Operation text och Read Spreadsheet Data med Operation xlsx.
  2. Använd Combine Items (aggreggera all item-data) och Concatenate Fields för att slå ihop fältet data.
  3. Ställ in Segment Text Chunks till Chunk Size 2000 och Chunk Overlap 200.
  4. I Load Document Metadata ställer ni in jsonData till {{ $json.data || $json.text || $json.concatenated_data }} och inkluderar metadatafält som file_id, version, creator och file_extension från trigger-data.

Steg 6: Bygg embeddings och upsert till Supabase

Skapa embeddings och infoga vektorposter i Supabase för retrieval-augmented generation.

  1. Konfigurera OpenAI Embedding Builder och koppla den till Upsert Vector Records som källa för AI-embeddings.
  2. Inloggningsuppgifter krävs: Anslut era openAiApi-inloggningsuppgifter i OpenAI Embedding Builder.
  3. Ställ in Upsert Vector Records till Mode insert och Table Name documents med Query Name match_documents.
  4. Inloggningsuppgifter krävs: Anslut era supabaseApi-inloggningsuppgifter i Upsert Vector Records.

Steg 7: Testa och aktivera ert arbetsflöde

Validera flödet från början till slut innan ni aktiverar körningar i produktion.

  1. Kör arbetsflödet manuellt genom att uppdatera en fil i den bevakade mappen och köra Drive Update Trigger via Test Workflow.
  2. Bekräfta att Remove Previous Doc Rows tar bort äldre vektorer och att Upsert Vector Records infogar nya rader i documents.
  3. Verifiera att Increment Version Tag returnerar en JSON-payload med det nya fältet version.
  4. När allt fungerar klickar ni på Activate för att aktivera automatisk bearbetning.
🔒

Lås upp fullständig steg-för-steg-guide

Få den kompletta implementeringsguiden + nedladdningsbar mall

Vanliga fallgropar

  • Google Drive-inloggningar kan löpa ut eller tappa åtkomst till en delad enhet. Om något skapar fel, kontrollera först behörigheterna för det anslutna kontot och n8n:s Google Drive-inloggning.
  • Om du använder Wait-noder eller extern rendering varierar bearbetningstiderna. Öka väntetiden om nedströms noder fallerar på tomma svar.
  • Supabase row-level security kan blockera raderingar och upserts i documents-tabellen. Om du ser “success” i n8n men inget ändras, granska dina Supabase-policys och vilken API-nyckelroll som används.

Vanliga frågor

Hur lång tid tar det att sätta upp den här Drive Supabase-synk-automationen?

Cirka 30–60 minuter om din Supabase-tabell är redo.

Behöver jag kodkunskaper för att automatisera Drive Supabase-synk?

Nej. Du kopplar mestadels konton och klistrar in några ID:n, som Drive-mappen och Supabase-projektets detaljer.

Är n8n gratis att använda för det här Drive Supabase-synk-arbetsflödet?

Ja. n8n har ett gratis självhostat alternativ och en gratis provperiod på n8n Cloud. Cloud-planer börjar på 20 USD/månad för högre volymer. Du behöver också räkna med kostnader för OpenAI API (ofta några dollar i månaden för små team, mer om du skapar embeddings på nytt för stora filer ofta).

Var kan jag hosta n8n för att köra den här Drive Supabase-synk-automationen?

Två alternativ: n8n Cloud (hanterat, enklast att komma igång) eller självhosting på en VPS. För självhosting är Hostinger VPS prisvärd och klarar n8n bra. Självhosting ger dig obegränsade körningar men kräver grundläggande serveradministration.

Kan jag anpassa det här Drive Supabase-synk-arbetsflödet för flera mappar?

Ja, men du behöver göra det med eftertanke. Du kan duplicera Google Drive Trigger och peka varje trigger mot en annan mapp, och sedan återanvända samma logik för radera-och-lägg-in-igen. Vanliga anpassningar är att ändra Switch-routningen för fler MIME-typer, justera textens chunk-storlek i text splittern och skriva in mappnamnet i metadata så att du kan filtrera hämtning senare.

Varför misslyckas min Google Drive-anslutning i det här arbetsflödet?

Oftast är det ett behörighetsproblem på den övervakade mappen, särskilt med delade enheter. Återanslut Google Drive-inloggningen i n8n och bekräfta sedan att kontot faktiskt kan komma åt mappen “DOCUMENTS” och läsa uppdaterade filer. Om arbetsflödet misslyckas direkt efter konvertering, kontrollera även logiken som förhindrar dubbla körningar, eftersom konverteringshändelser kan se ut som redigeringar.

Hur många dokument klarar den här Drive Supabase-synk-automationen?

Många, eftersom den bara bearbetar ändrade filer på nytt.

Är den här Drive Supabase-synk-automationen bättre än att använda Zapier eller Make?

För det här användningsfallet är n8n oftast bättre. Du behöver ett riktigt mönster för radera-och-lägg-in-igen, routning per filtyp, chunking, embeddings och en upsert till en vektorstore, vilket är krångligt (och dyrt) att skruva ihop i Zapier eller Make. n8n ger dig också självhosting, så frekventa dokumentuppdateringar inte blir en per-task-faktura du ångrar senare. Om du bara synkar grundläggande metadatafält mellan verktyg kan Zapier vara snabbare att sätta upp. Men för att hålla RAG-svar korrekta är det här typen av arbetsflöde där n8n:s flexibilitet faktiskt spelar roll. Om du vill ha en second opinion, prata med en automationsexpert.

Dina dokument kommer fortsätta att ändras. Det är normalt. Det här arbetsflödet ser till att dina AI-svar ändras tillsammans med dem, utan att du behöver vakta en vektordatabas varje vecka.

Kontakta oss

Hör av dig, så diskuterar vi hur just din verksamhet kan dra nytta av alla fantastiska möjligheter som AI skapar.

×

Använd mall

Få direkt tillgång till denna n8n-arbetsflödes JSON-fil

Få prisoffert redan idag!
Få prisoffert redan idag!

Berätta vad ni behöver hjälp med så hör vi av oss inom en arbetsdag!

Få prisoffert redan idag!
Få prisoffert redan idag!

Berätta vad ni behöver hjälp med så hör vi av oss inom en arbetsdag!

Launch login modal Launch register modal