-
Notifications
You must be signed in to change notification settings - Fork 117
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
157 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,157 @@ | ||
import sgMail from "@sendgrid/mail"; | ||
|
||
import { front_sequelize } from "@app/lib/databases"; | ||
|
||
const { SENDGRID_API_KEY = "", LIVE = false } = process.env; | ||
sgMail.setApiKey(SENDGRID_API_KEY); | ||
|
||
export const sendAPIUserEmail = async ({ | ||
user_email, | ||
}: { | ||
user_email: string; | ||
}) => { | ||
const msg = { | ||
to: user_email, | ||
from: "[email protected]", | ||
subject: "[Dust] Product Update 1", | ||
html: `<p>Hi!</p> | ||
<p style="max-width: 500px;"> | ||
Dust makes work work better. | ||
</p> | ||
<p style="max-width: 500px;"> | ||
The past month has been packed with powerful new features and upgrades. | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>⛵️ Mistral Large Now Available</b><br/> | ||
• You can now access the powerful Mistral Large model via the new @mistral-large global assistant.<br/> | ||
• Mistral Large, is the latest and most advanced language model from Mistral and delivers top-tier reasoning capacities.<br/> | ||
🔗 <a href="https://mistral.ai/news/mistral-large/">https://mistral.ai/news/mistral-large/</a> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>🧠 New Cutting-Edge Models from Anthropic</b><br/> | ||
• Claude 3 Opus is now powering the @claude-3 global assistant, delivering a major performance boost over Claude 2.1.<br/> | ||
• Opus is Anthropic most intelligent model, with best-in-market performance. It can navigate open-ended prompts and sight-unseen scenarios.<br/> | ||
• All custom assistants using Claude 2.1 have been automatically upgraded to Claude 3 Opus.<br/> | ||
🔗 <a href="https://www.anthropic.com/news/claude-3-family">https://www.anthropic.com/news/claude-3-family</a> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>📊 Introducing Table Queries</b><br/> | ||
• Connect Notion databases, Google Sheets, and CSV files to Dust for powerful data analysis.<br/> | ||
• Ask questions like "Show me top customers by revenue" and get back instant charts and insights.<br/> | ||
• Enables everyone to make data-informed decisions without needing SQL or analytics expertise.<br/> | ||
• Tables in Dust are automatically kept in sync with their source Google Sheets and Notion databases.<br/> | ||
🔗 <a href="https://blog.dust.tt/dusts-for-quantitative-analysis-with-llms/">https://blog.dust.tt/dusts-for-quantitative-analysis-with-llms/</a> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>📘 Confluence Connection</b><br/> | ||
• Connect your Confluence instance to Dust to sync global spaces and pages.<br/> | ||
• Simply add Confluence as a data source and let your assistants tap into that collective wisdom.<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>💬 Intercom Connection</b><br/> | ||
• Connect Intercom to sync Help Center articles and customer conversations to Dust.<br/> | ||
• Choose which Teams to sync conversations from and control access to customer data.<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>🔒 Okta Single Sign-On</b><br/> | ||
• Enterprise customers can ask to enable Okta SSO for an even more seamless and secure authentication experience. Simplify user management by leveraging your existing Okta setup.<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>🤖 Summon Assistants in Slack</b><br/> | ||
• Interact with any Dust assistant right from Slack using the @dust ~assistantname or @dust +assistantname syntax. Bring the power of Dust to the tools you use every day.<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>📘 Quick Start Guide</b><br/> | ||
• We've added a handy walkthrough on first login to explain Dust fundamentals and help new users get oriented. Be sure to check it out!<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
<b>➕ And more...</b><br/> | ||
• Refreshed assistant details page and builder UX.<br/> | ||
• Experimental instruction suggestions and website crawling settings.<br/> | ||
• New blog posts: <a href="https://blog.dust.tt/pennylane-dust-customer-support-journey/">How Eléonore improved the efficiency of Pennylane’s Care team thanks to Dust</a> and <a href="https://blog.dust.tt/why-dust/">Why Dust</a>.<br/> | ||
</p> | ||
<p style="max-width: 500px; padding-top: 20px;"> | ||
Happy building, | ||
</p> | ||
<p> | ||
The Dust Team | ||
</p> | ||
`, | ||
}; | ||
|
||
await sgMail.send(msg); | ||
|
||
console.log("EMAIL SENT", user_email); | ||
}; | ||
|
||
async function main() { | ||
// const [rows] = await front_sequelize.query( | ||
// `select max(ws.name) ws_name, max(ws."sId") ws_sid, u.name user_name, u.email user_email, u.id user_id | ||
// from | ||
// agent_generation_configurations agc | ||
// inner join agent_configurations ac on ac."generationConfigurationId" = agc.id | ||
// inner join workspaces ws on ws.id = ac."workspaceId" | ||
// inner join memberships m on m."workspaceId" = ws.id | ||
// inner join users u on m."userId" = u.id | ||
// where | ||
// agc."modelId" ilike 'gpt-3%' or agc."modelId" ilike 'claude-instant%' | ||
// and ws.plan not ilike '%"largeModels":true%' | ||
// and m.role = 'admin' | ||
// group by u.id | ||
// ` | ||
// ); | ||
|
||
// console.log({ count: rows.length }); | ||
|
||
// console.log("USING SENDGRID API KEY", SENDGRID_API_KEY); | ||
|
||
// // split rows in chunks of 16 | ||
// const chunks = []; | ||
// let chunk = []; | ||
// for (let i = 0; i < rows.length; i++) { | ||
// chunk.push(rows[i]); | ||
// if (chunk.length === 16) { | ||
// chunks.push(chunk); | ||
// chunk = []; | ||
// } | ||
// } | ||
// if (chunk.length > 0) { | ||
// chunks.push(chunk); | ||
// } | ||
|
||
const chunks: { user_email: string }[][] = [ | ||
[{ user_email: "[email protected]" }], | ||
]; | ||
|
||
for (let i = 0; i < chunks.length; i++) { | ||
const chunk = chunks[i] as { user_email: string }[]; | ||
console.log("SENDING CHUNK", i, chunk.length); | ||
await Promise.all( | ||
chunk.map((row) => { | ||
console.log("PREPARING EMAIL", row.user_email); | ||
if (LIVE && LIVE === "true") { | ||
return sendAPIUserEmail(row); | ||
} else { | ||
return Promise.resolve(); | ||
} | ||
}) | ||
); | ||
} | ||
|
||
process.exit(0); | ||
} | ||
|
||
void main().then(() => { | ||
console.log("DONE"); | ||
process.exit(0); | ||
}); |