ഫയൽ മൂല്യനിർണ്ണയത്തോടുകൂടിയ ആപ്പ് സ്ക്രിപ്റ്റിൽ ഇമെയിൽ കൈമാറൽ

Google Apps Script

ആപ്പ് സ്ക്രിപ്റ്റ് ഉപയോഗിച്ച് ഇമെയിൽ ഓട്ടോമേഷൻ

Google Apps Script-ൽ ഇമെയിൽ ഫോർവേഡിംഗ് ഓട്ടോമേറ്റ് ചെയ്യുന്നത് ആശയവിനിമയവും ഡാറ്റാ കൈമാറ്റ പ്രക്രിയകളും ഗണ്യമായി കാര്യക്ഷമമാക്കും. Gmail-ൽ നിർദ്ദിഷ്‌ട ലേബലുകളിൽ പ്രവർത്തിക്കുമ്പോൾ ഇത് പ്രത്യേകിച്ചും പ്രയോജനകരമാണ്, ഇവിടെ സ്വമേധയാലുള്ള ഇടപെടലില്ലാതെ ഇമെയിലുകൾ ബാഹ്യ അപ്ലിക്കേഷനുകളിലേക്ക് കൈമാറേണ്ടതുണ്ട്. ഈ ഫോർവേഡുകളിൽ സിഗ്‌നേച്ചറുകളും ഹെഡറുകളും പോലുള്ള അനാവശ്യ ഇൻലൈൻ ഇമേജുകൾ ഉൾപ്പെടുത്തുമ്പോൾ ഒരു പൊതു പ്രശ്നം ഉയർന്നുവരുന്നു.

ഈ പ്രശ്നം ഫോർവേഡ് ചെയ്ത സന്ദേശങ്ങളെ അലങ്കോലപ്പെടുത്തുക മാത്രമല്ല, PDF ഫയലുകൾ പോലുള്ള അറ്റാച്ച്‌മെൻ്റുകൾ മാത്രം ഫോർവേഡ് ചെയ്യേണ്ടതായിരിക്കുമ്പോൾ ഒരു വെല്ലുവിളി ഉയർത്തുകയും ചെയ്യുന്നു. അത്തരം സന്ദർഭങ്ങളിൽ, ഇമെയിൽ ത്രെഡിൻ്റെ സന്ദർഭം നിലനിർത്തിക്കൊണ്ട് അറ്റാച്ച്‌മെൻ്റുകൾ തിരഞ്ഞെടുത്ത് ഫോർവേഡ് ചെയ്യുന്നതിനായി സ്‌ക്രിപ്റ്റ് പരിഷ്‌ക്കരിക്കുന്നത് അത്യന്താപേക്ഷിതമാണ്. ഓട്ടോമേഷൻ്റെ കാര്യക്ഷമത വർധിപ്പിച്ചുകൊണ്ട് ആവശ്യമായ ഫയലുകൾ മാത്രം ഫോർവേഡ് ചെയ്യപ്പെടുന്നുവെന്ന് ഉറപ്പാക്കുന്നതിനുള്ള ഒരു പരിഹാരം അടുത്ത ലേഖനം പര്യവേക്ഷണം ചെയ്യും.

കമാൻഡ് വിവരണം
GmailApp.getUserLabelByName() നിർദ്ദിഷ്ട ലേബലുകൾക്ക് കീഴിൽ തരംതിരിച്ചിരിക്കുന്ന ഇമെയിലുകൾക്കൊപ്പം പ്രവർത്തിക്കാൻ സ്ക്രിപ്റ്റുകളെ അനുവദിക്കുന്ന, പേര് പ്രകാരം ഉപയോക്താവിൻ്റെ Gmail അക്കൗണ്ടിൽ നിന്ന് ഒരു ലേബൽ വീണ്ടെടുക്കുന്നു.
getThreads() ഒരു ലേബലിനുള്ളിലെ ത്രെഡ് ഒബ്‌ജക്റ്റുകളുടെ ഒരു നിര നൽകുന്നു, ഒരു Gmail ലേബലിന് കീഴിലുള്ള ഓരോ ഇമെയിൽ സംഭാഷണവും പ്രോസസ്സ് ചെയ്യാൻ ഉപയോഗിക്കുന്നു.
getMessages() ഒരൊറ്റ ത്രെഡിൽ അടങ്ങിയിരിക്കുന്ന എല്ലാ ഇമെയിൽ സന്ദേശങ്ങളും ലഭ്യമാക്കുന്നു, ഓരോ ഇമെയിലിൻ്റെയും ഉള്ളടക്കത്തിലേക്കും മെറ്റാഡാറ്റയിലേക്കും വിശദമായ ആക്സസ് പ്രാപ്തമാക്കുന്നു.
getAttachments() ഒരു ഇമെയിൽ സന്ദേശത്തിൽ നിന്ന് എല്ലാ അറ്റാച്ചുമെൻ്റുകളും എക്‌സ്‌ട്രാക്‌റ്റുചെയ്യുന്നു, അത് ആവശ്യമുള്ള ഫയൽ തരങ്ങൾ മാത്രം ഫോർവേഡ് ചെയ്യാൻ ഫിൽട്ടർ ചെയ്യാം.
GmailApp.sendEmail() ഉപയോക്താവിൻ്റെ Gmail അക്കൗണ്ടിൽ നിന്ന് ഒരു ഇമെയിൽ അയയ്ക്കുന്നു. അറ്റാച്ച്‌മെൻ്റുകൾ, CC, BCC, HTML ഉള്ളടക്കം എന്നിവ പോലുള്ള വിപുലമായ ഓപ്‌ഷനുകളെ ഇത് പിന്തുണയ്‌ക്കുന്നു.
filter() ഒരു അറേയിലെ ഓരോ ഘടകത്തിനും ഒരു ടെസ്റ്റ് പ്രയോഗിക്കാൻ ഉപയോഗിക്കുന്നു. ഈ സാഹചര്യത്തിൽ, PDF ഉള്ളടക്ക തരമുള്ളവ മാത്രം കണ്ടെത്തുന്നതിന് ഇത് അറ്റാച്ചുമെൻ്റുകൾ ഫിൽട്ടർ ചെയ്യുന്നു.

Google Apps സ്‌ക്രിപ്റ്റ് ഉപയോഗിച്ച് ഇമെയിൽ ഫോർവേഡിംഗ് മെച്ചപ്പെടുത്തുന്നു

നൽകിയിരിക്കുന്ന Google Apps സ്‌ക്രിപ്‌റ്റ് ഉദാഹരണങ്ങൾ, പ്രത്യേക മാനദണ്ഡങ്ങൾ പാലിക്കുന്ന ഇമെയിലുകൾ ഫിൽട്ടർ ചെയ്യുന്നതിനും കൈമാറുന്നതിനുമുള്ള പ്രത്യേക ആവശ്യകതയെ അഭിസംബോധന ചെയ്യാൻ രൂപകൽപ്പന ചെയ്‌തിരിക്കുന്നു, ഈ സാഹചര്യത്തിൽ, PDF അറ്റാച്ച്‌മെൻ്റുകൾ മാത്രം കൈമാറുകയും ഒപ്പുകളോ തലക്കെട്ടുകളോ പോലുള്ള ഇൻലൈൻ ഇമേജുകൾ ഒഴിവാക്കുകയും ചെയ്യുന്നു. ഒരു മുൻനിശ്ചയിച്ച Gmail ലേബലുമായി ബന്ധപ്പെട്ട എല്ലാ ഇമെയിൽ ത്രെഡുകളും വീണ്ടെടുക്കുന്നതിലൂടെ സ്ക്രിപ്റ്റിൻ്റെ ആദ്യ ഭാഗം ആരംഭിക്കുന്നു. 'GmailApp.getUserLabelByName()` എന്ന കമാൻഡ് ഉപയോഗിച്ചാണ് ഇത് ചെയ്യുന്നത്, ഇത് ബന്ധപ്പെട്ട എല്ലാ ഇമെയിൽ ത്രെഡുകളിലും സ്ക്രിപ്റ്റ് പ്രവർത്തിക്കാൻ അനുവദിക്കുന്ന ലേബൽ ഒബ്ജക്റ്റ് ലഭ്യമാക്കുന്നു. തുടർന്ന്, വ്യക്തിഗത സന്ദേശങ്ങൾ ആക്‌സസ് ചെയ്യുന്നതിന് ഈ ത്രെഡുകളിലൂടെ അത് ആവർത്തിക്കുന്നു.

ഓരോ സന്ദേശവും അറ്റാച്ച്‌മെൻ്റുകൾ തിരിച്ചറിയുന്നതിനും ഫിൽട്ടർ ചെയ്യുന്നതിനും `getAttachments()` രീതി ഉപയോഗിച്ച് MIME തരം പരിശോധിക്കുന്ന ഒരു ഫിൽട്ടർ ഫംഗ്‌ഷനുമായി സംയോജിപ്പിച്ച് PDF ഫയലുകൾ മാത്രമേ ഉൾപ്പെടുത്തിയിട്ടുള്ളൂവെന്ന് ഉറപ്പാക്കുന്നു. ഈ ഫിൽട്ടർ ചെയ്‌ത അറ്റാച്ച്‌മെൻ്റുകൾ കൈമാറാൻ `GmailApp.sendEmail()` ഫംഗ്‌ഷൻ ഉപയോഗിക്കുന്നു. ഫയലുകൾ അറ്റാച്ചുചെയ്യുമ്പോഴും ഇമെയിൽ ത്രെഡിൻ്റെ തുടർച്ച നിലനിർത്തുന്നതിന് എച്ച്ടിഎംഎൽ ബോഡി ഉള്ളടക്കം, ത്രെഡ് ഐഡി എന്നിവ പോലുള്ള വിപുലമായ പാരാമീറ്ററുകൾ വ്യക്തമാക്കുമ്പോഴും പ്രോഗ്രാമാറ്റിക് ആയി ഇമെയിലുകൾ അയയ്‌ക്കുന്നതിന് ഈ ഫംഗ്‌ഷൻ നിർണായകമാണ്. ഫോർവേഡ് ചെയ്‌ത ഇമെയിലുകൾ നടന്നുകൊണ്ടിരിക്കുന്ന സംഭാഷണത്തിൻ്റെ ഭാഗമായി നിലനിൽക്കുന്നുവെന്ന് ഇത് ഉറപ്പാക്കുന്നു, ഇമെയിലുകൾ ത്രെഡുചെയ്‌ത് നിലനിർത്താനും പ്രസക്തമായ അറ്റാച്ച്‌മെൻ്റുകളിൽ മാത്രം ശ്രദ്ധ കേന്ദ്രീകരിക്കാനുമുള്ള ഉപയോക്താവിൻ്റെ ആവശ്യകത നിറവേറ്റുന്നു.

ആപ്‌സ് സ്‌ക്രിപ്‌റ്റിലെ അറ്റാച്ച്‌മെൻ്റുകൾ ഫിൽട്ടർ ചെയ്യുന്നതിന് ഇമെയിൽ കൈമാറൽ പരിഷ്‌ക്കരിക്കുന്നു

Google Apps സ്‌ക്രിപ്റ്റ് നടപ്പിലാക്കൽ

function filterAndForwardEmails() {
  var label = GmailApp.getUserLabelByName("ToBeForwarded");
  var threads = label.getThreads();
  for (var i = 0; i < threads.length; i++) {
    var messages = threads[i].getMessages();
    var lastMessage = messages[messages.length - 1];
    var attachments = lastMessage.getAttachments();
    var filteredAttachments = attachments.filter(function(attachment) {
      return attachment.getContentType() === 'application/pdf';
    });
    if (filteredAttachments.length > 0) {
      forwardMessage(lastMessage, filteredAttachments);
    }
  }
}
function forwardMessage(message, attachments) {
  GmailApp.sendEmail(message.getTo(), message.getSubject(), "", {
    attachments: attachments,
    htmlBody: "<br> Message sent to external app <br>",
    inlineImages: {},
    threadId: message.getThread().getId()
  });
}

ആപ്പ് സ്ക്രിപ്റ്റ് ഉപയോഗിച്ച് ഇമെയിൽ കൈമാറൽ പ്രക്രിയയിൽ ഇൻലൈൻ ചിത്രങ്ങൾ ഒഴികെ

Google Apps സ്‌ക്രിപ്റ്റിലെ സ്‌ക്രിപ്റ്റിംഗ്

function setupEmailForwarding() {
  var targetLabel = "ExternalForward";
  var threadsToForward = GmailApp.getUserLabelByName(targetLabel).getThreads();
  threadsToForward.forEach(function(thread) {
    var message = thread.getMessages().pop(); // get the last message
    var pdfAttachments = message.getAttachments().filter(function(file) {
      return file.getContentType() === 'application/pdf';
    });
    if (pdfAttachments.length) {
      sendFilteredEmail(message, pdfAttachments);
    }
  });
}
function sendFilteredEmail(originalMessage, attachments) {
  GmailApp.sendEmail(originalMessage.getTo(), "FWD: " + originalMessage.getSubject(),
    "Forwarded message attached.", {
      attachments: attachments,
      htmlBody: originalMessage.getBody() + "<br> Forwarded with selected attachments only.<br>",
      threadId: originalMessage.getThread().getId()
  });
}

ആപ്പ് സ്ക്രിപ്റ്റിൽ ഇമെയിൽ കൈകാര്യം ചെയ്യുന്നതിനുള്ള വിപുലമായ സാങ്കേതിക വിദ്യകൾ

Google Apps സ്‌ക്രിപ്റ്റിൽ സ്വയമേവയുള്ള ഇമെയിൽ ഫോർവേഡിംഗ് കൈകാര്യം ചെയ്യുമ്പോൾ, ഇമെയിൽ മാനേജ്‌മെൻ്റിൻ്റെ വിശാലമായ സന്ദർഭം മനസ്സിലാക്കുന്നത് നിർണായകമാണ്. ഒരു പ്രധാന വശം MIME തരങ്ങൾ തമ്മിലുള്ള വ്യത്യാസമാണ്, ഇത് ഇൻലൈൻ ഇമേജുകളിൽ നിന്ന് PDF-കൾ പോലുള്ള നിർദ്ദിഷ്ട ഫയൽ തരങ്ങൾ ഫിൽട്ടർ ചെയ്യാൻ സഹായിക്കുന്നു. അനിവാര്യമല്ലാത്ത അറ്റാച്ച്‌മെൻ്റുകൾ ഒഴിവാക്കുന്ന ഫലപ്രദമായ ഫിൽട്ടറുകൾ സ്‌ക്രിപ്‌റ്റുചെയ്യുന്നതിന് ഈ വ്യത്യാസം പ്രധാനമാണ്. ബിസിനസ്സ് പരിതസ്ഥിതികളിൽ സംഘടിത ഇമെയിൽ ട്രയലുകൾ നിലനിർത്തുന്നതിൽ അത്യന്താപേക്ഷിതമായ ആശയവിനിമയങ്ങൾ യോജിപ്പുള്ളതും ലിങ്കുചെയ്തതുമായി നിലനിർത്തുന്നതിന് ഇമെയിൽ ത്രെഡുകൾ കൈകാര്യം ചെയ്യുന്നത് മറ്റൊരു വിപുലമായ സാങ്കേതികതയിൽ ഉൾപ്പെടുന്നു.

കൂടാതെ, ഇമെയിൽ ഓട്ടോമേഷനായി ഗൂഗിൾ ആപ്പ് സ്‌ക്രിപ്റ്റ് പ്രയോജനപ്പെടുത്തുന്നത് ലളിതമായ ഫോർവേഡിംഗിന് അതീതമായ ഇഷ്‌ടാനുസൃത പെരുമാറ്റങ്ങളെ അനുവദിക്കുന്നു. ഉദാഹരണത്തിന്, ഇമെയിലുകളോട് സ്വയമേവ പ്രതികരിക്കുന്നതിനോ അറ്റാച്ച്‌മെൻ്റുകളുടെ സംഗ്രഹ റിപ്പോർട്ടുകൾ സൃഷ്ടിക്കുന്നതിനോ ഇമെയിലുകൾ അവയുടെ ഉള്ളടക്കമോ അറ്റാച്ച്‌മെൻ്റ് തരമോ അടിസ്ഥാനമാക്കി വ്യത്യസ്ത ലേബലുകളായി ക്രമീകരിക്കുന്നതിനോ സ്‌ക്രിപ്റ്റുകൾ രൂപകൽപ്പന ചെയ്യാൻ കഴിയും. അത്തരം കഴിവുകൾ Google Apps Script-നെ ഇമെയിലുകൾ കൈകാര്യം ചെയ്യുന്നതിൽ ഉൽപ്പാദനക്ഷമതയും വർക്ക്ഫ്ലോ കാര്യക്ഷമതയും വർദ്ധിപ്പിക്കുന്നതിനുള്ള ശക്തമായ ഉപകരണമാക്കി മാറ്റുന്നു.

  1. ഇമെയിൽ ഓട്ടോമേഷനായി ഞാൻ എങ്ങനെ Google Apps സ്‌ക്രിപ്റ്റ് ഉപയോഗിക്കാൻ തുടങ്ങും?
  2. Google ഡ്രൈവ് വഴി ആപ്പ് സ്‌ക്രിപ്റ്റ് എൻവയോൺമെൻ്റ് ആക്‌സസ് ചെയ്‌ത്, ഒരു പുതിയ സ്‌ക്രിപ്റ്റ് സൃഷ്‌ടിച്ച്, ഇമെയിൽ ഇടപെടലുകൾ പ്രോഗ്രാം ചെയ്യുന്നതിന് GmailApp സേവനം ഉപയോഗിച്ച് നിങ്ങൾക്ക് ആരംഭിക്കാം.
  3. എന്താണ് MIME തരം, എന്തുകൊണ്ട് ഇത് പ്രധാനമാണ്?
  4. MIME തരം, അല്ലെങ്കിൽ മീഡിയ തരം, ഒരു പ്രമാണം, ഫയൽ അല്ലെങ്കിൽ ബൈറ്റുകളുടെ ശേഖരണത്തിൻ്റെ സ്വഭാവവും ഫോർമാറ്റും സൂചിപ്പിക്കുന്ന ഒരു മാനദണ്ഡമാണ്. വ്യത്യസ്ത ഫയൽ തരങ്ങളുടെ ശരിയായ കൈകാര്യം ചെയ്യൽ ഉറപ്പാക്കാൻ ഇമെയിൽ പ്രോസസ്സിംഗിന് ഇത് നിർണായകമാണ്.
  5. ആപ്പ് സ്‌ക്രിപ്റ്റിലെ അറ്റാച്ച്‌മെൻ്റ് തരം അനുസരിച്ച് എനിക്ക് ഇമെയിലുകൾ ഫിൽട്ടർ ചെയ്യാൻ കഴിയുമോ?
  6. അതെ, ഓരോ അറ്റാച്ച്‌മെൻ്റിൻ്റെയും MIME തരം പരിശോധിച്ച് അവ പ്രോസസ്സ് ചെയ്യുന്നതിന് ഫിൽട്ടറുകൾക്കൊപ്പം നിങ്ങൾക്ക് getAttachments() രീതി ഉപയോഗിക്കാം.
  7. ഫോർവേഡ് ചെയ്ത ഇമെയിലുകൾ ഒരേ ത്രെഡിൽ എങ്ങനെ സൂക്ഷിക്കാം?
  8. യഥാർത്ഥ ഇമെയിൽ ത്രെഡ് വ്യക്തമാക്കാൻ GmailApp.sendEmail() എന്നതിലെ ത്രെഡ് ഐഡി ഓപ്ഷൻ ഉപയോഗിക്കുക, ഫോർവേഡ് ചെയ്ത സന്ദേശം അതേ സംഭാഷണത്തിൽ തന്നെ നിലനിർത്തുക.
  9. ആപ്പ് സ്‌ക്രിപ്റ്റിന് തരത്തെ അടിസ്ഥാനമാക്കി ഒന്നിലധികം അറ്റാച്ച്‌മെൻ്റുകൾ വ്യത്യസ്തമായി കൈകാര്യം ചെയ്യാൻ കഴിയുമോ?
  10. അതെ, അറ്റാച്ച്‌മെൻ്റുകളെ അവയുടെ MIME തരങ്ങൾ ഉപയോഗിച്ച് വേർതിരിക്കുന്നതിനും PDF-കൾ മാത്രം ഫോർവേഡ് ചെയ്യുന്നതിനും മറ്റുള്ളവ അവഗണിക്കുന്നതിനും പോലെ ഓരോ തരവും വ്യത്യസ്തമായി കൈകാര്യം ചെയ്യുന്നതിനും നിങ്ങൾക്ക് സ്‌ക്രിപ്റ്റ് രൂപകൽപ്പന ചെയ്യാം.

ഗൂഗിൾ ആപ്പ്സ് സ്‌ക്രിപ്‌റ്റിൻ്റെ ഉപയോഗത്തിലൂടെ, ഉപയോക്താക്കൾക്ക് സങ്കീർണ്ണമായ ഇമെയിൽ ഹാൻഡ്‌ലിംഗ് ടാസ്‌ക്കുകൾ ഓട്ടോമേറ്റ് ചെയ്യാൻ കഴിയും, പ്രത്യേകിച്ചും പിഡിഎഫ് ഫയലുകൾ പോലുള്ള അവശ്യ അറ്റാച്ച്‌മെൻ്റുകൾ മാത്രം ഉൾപ്പെടുത്തുന്നതിന് ഫോർവേഡിംഗ് പ്രക്രിയ ക്രമീകരിക്കുന്നു. ഈ ടാർഗെറ്റുചെയ്‌ത സമീപനം ഓർഗനൈസേഷനുകൾക്കകത്തും പുറത്തുമുള്ള ആശയവിനിമയം കാര്യക്ഷമമാക്കുക മാത്രമല്ല, ഇമെയിൽ മാനേജുമെൻ്റിൽ ഉൾപ്പെട്ടിരിക്കുന്ന സ്വമേധയാലുള്ള പരിശ്രമം ഗണ്യമായി കുറയ്ക്കുകയും ചെയ്യുന്നു. മാത്രമല്ല, സംഭാഷണ ത്രെഡുകൾ കേടുകൂടാതെ നിലനിർത്താനുള്ള കഴിവ് ഫോർവേഡ് ചെയ്ത സന്ദേശങ്ങളെക്കുറിച്ചുള്ള സന്ദർഭോചിതമായ ധാരണ വർദ്ധിപ്പിക്കുന്നു, ഇത് പ്രൊഫഷണൽ ആശയവിനിമയങ്ങളിൽ തുടർച്ച നിലനിർത്തുന്നതിന് നിർണായകമാണ്.