reformat with prettier with semicolons and tabs

This commit is contained in:
m5r
2021-07-31 23:57:43 +08:00
parent fc4278ca7b
commit 079241ddb0
80 changed files with 1187 additions and 1270 deletions

View File

@ -1,16 +1,16 @@
import { Queue } from "quirrel/blitz"
import twilio from "twilio"
import { Queue } from "quirrel/blitz";
import twilio from "twilio";
import db from "../../../db"
import insertCallsQueue from "./insert-calls"
import db from "../../../db";
import insertCallsQueue from "./insert-calls";
type Payload = {
customerId: string
}
customerId: string;
};
const fetchCallsQueue = Queue<Payload>("api/queue/fetch-calls", async ({ customerId }) => {
const customer = await db.customer.findFirst({ where: { id: customerId } })
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } })
const customer = await db.customer.findFirst({ where: { id: customerId } });
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } });
const [callsSent, callsReceived] = await Promise.all([
twilio(customer!.accountSid!, customer!.authToken!).calls.list({
@ -19,10 +19,10 @@ const fetchCallsQueue = Queue<Payload>("api/queue/fetch-calls", async ({ custome
twilio(customer!.accountSid!, customer!.authToken!).calls.list({
to: phoneNumber!.phoneNumber,
}),
])
]);
const calls = [...callsSent, ...callsReceived].sort(
(a, b) => a.dateCreated.getTime() - b.dateCreated.getTime()
)
);
await insertCallsQueue.enqueue(
{
@ -32,7 +32,7 @@ const fetchCallsQueue = Queue<Payload>("api/queue/fetch-calls", async ({ custome
{
id: `insert-calls-${customerId}`,
}
)
})
);
});
export default fetchCallsQueue
export default fetchCallsQueue;

View File

@ -1,16 +1,16 @@
import { Queue } from "quirrel/blitz"
import twilio from "twilio"
import { Queue } from "quirrel/blitz";
import twilio from "twilio";
import db from "../../../db"
import insertMessagesQueue from "./insert-messages"
import db from "../../../db";
import insertMessagesQueue from "./insert-messages";
type Payload = {
customerId: string
}
customerId: string;
};
const fetchMessagesQueue = Queue<Payload>("api/queue/fetch-messages", async ({ customerId }) => {
const customer = await db.customer.findFirst({ where: { id: customerId } })
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } })
const customer = await db.customer.findFirst({ where: { id: customerId } });
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } });
const [messagesSent, messagesReceived] = await Promise.all([
twilio(customer!.accountSid!, customer!.authToken!).messages.list({
@ -19,10 +19,10 @@ const fetchMessagesQueue = Queue<Payload>("api/queue/fetch-messages", async ({ c
twilio(customer!.accountSid!, customer!.authToken!).messages.list({
to: phoneNumber!.phoneNumber,
}),
])
]);
const messages = [...messagesSent, ...messagesReceived].sort(
(a, b) => a.dateSent.getTime() - b.dateSent.getTime()
)
);
await insertMessagesQueue.enqueue(
{
@ -32,7 +32,7 @@ const fetchMessagesQueue = Queue<Payload>("api/queue/fetch-messages", async ({ c
{
id: `insert-messages-${customerId}`,
}
)
})
);
});
export default fetchMessagesQueue
export default fetchMessagesQueue;

View File

@ -1,12 +1,12 @@
import { Queue } from "quirrel/blitz"
import type { CallInstance } from "twilio/lib/rest/api/v2010/account/call"
import { Queue } from "quirrel/blitz";
import type { CallInstance } from "twilio/lib/rest/api/v2010/account/call";
import db, { Direction, CallStatus } from "../../../db"
import db, { Direction, CallStatus } from "../../../db";
type Payload = {
customerId: string
calls: CallInstance[]
}
customerId: string;
calls: CallInstance[];
};
const insertCallsQueue = Queue<Payload>("api/queue/insert-calls", async ({ calls, customerId }) => {
const phoneCalls = calls
@ -20,40 +20,40 @@ const insertCallsQueue = Queue<Payload>("api/queue/insert-calls", async ({ calls
duration: call.duration,
createdAt: new Date(call.dateCreated),
}))
.sort((a, b) => a.createdAt.getTime() - b.createdAt.getTime())
.sort((a, b) => a.createdAt.getTime() - b.createdAt.getTime());
await db.phoneCall.createMany({ data: phoneCalls })
})
await db.phoneCall.createMany({ data: phoneCalls });
});
export default insertCallsQueue
export default insertCallsQueue;
function translateDirection(direction: CallInstance["direction"]): Direction {
switch (direction) {
case "inbound":
return Direction.Inbound
return Direction.Inbound;
case "outbound":
default:
return Direction.Outbound
return Direction.Outbound;
}
}
function translateStatus(status: CallInstance["status"]): CallStatus {
switch (status) {
case "busy":
return CallStatus.Busy
return CallStatus.Busy;
case "canceled":
return CallStatus.Canceled
return CallStatus.Canceled;
case "completed":
return CallStatus.Completed
return CallStatus.Completed;
case "failed":
return CallStatus.Failed
return CallStatus.Failed;
case "in-progress":
return CallStatus.InProgress
return CallStatus.InProgress;
case "no-answer":
return CallStatus.NoAnswer
return CallStatus.NoAnswer;
case "queued":
return CallStatus.Queued
return CallStatus.Queued;
case "ringing":
return CallStatus.Ringing
return CallStatus.Ringing;
}
}

View File

@ -1,19 +1,19 @@
import { Queue } from "quirrel/blitz"
import type { MessageInstance } from "twilio/lib/rest/api/v2010/account/message"
import { Queue } from "quirrel/blitz";
import type { MessageInstance } from "twilio/lib/rest/api/v2010/account/message";
import db, { MessageStatus, Direction, Message } from "../../../db"
import { encrypt } from "../../../db/_encryption"
import db, { MessageStatus, Direction, Message } from "../../../db";
import { encrypt } from "../../../db/_encryption";
type Payload = {
customerId: string
messages: MessageInstance[]
}
customerId: string;
messages: MessageInstance[];
};
const insertMessagesQueue = Queue<Payload>(
"api/queue/insert-messages",
async ({ messages, customerId }) => {
const customer = await db.customer.findFirst({ where: { id: customerId } })
const encryptionKey = customer!.encryptionKey
const customer = await db.customer.findFirst({ where: { id: customerId } });
const encryptionKey = customer!.encryptionKey;
const sms = messages
.map<Omit<Message, "id">>((message) => ({
@ -26,53 +26,53 @@ const insertMessagesQueue = Queue<Payload>(
twilioSid: message.sid,
sentAt: new Date(message.dateSent),
}))
.sort((a, b) => a.sentAt.getTime() - b.sentAt.getTime())
.sort((a, b) => a.sentAt.getTime() - b.sentAt.getTime());
await db.message.createMany({ data: sms })
await db.message.createMany({ data: sms });
}
)
);
export default insertMessagesQueue
export default insertMessagesQueue;
function translateDirection(direction: MessageInstance["direction"]): Direction {
switch (direction) {
case "inbound":
return Direction.Inbound
return Direction.Inbound;
case "outbound-api":
case "outbound-call":
case "outbound-reply":
default:
return Direction.Outbound
return Direction.Outbound;
}
}
function translateStatus(status: MessageInstance["status"]): MessageStatus {
switch (status) {
case "accepted":
return MessageStatus.Accepted
return MessageStatus.Accepted;
case "canceled":
return MessageStatus.Canceled
return MessageStatus.Canceled;
case "delivered":
return MessageStatus.Delivered
return MessageStatus.Delivered;
case "failed":
return MessageStatus.Failed
return MessageStatus.Failed;
case "partially_delivered":
return MessageStatus.PartiallyDelivered
return MessageStatus.PartiallyDelivered;
case "queued":
return MessageStatus.Queued
return MessageStatus.Queued;
case "read":
return MessageStatus.Read
return MessageStatus.Read;
case "received":
return MessageStatus.Received
return MessageStatus.Received;
case "receiving":
return MessageStatus.Receiving
return MessageStatus.Receiving;
case "scheduled":
return MessageStatus.Scheduled
return MessageStatus.Scheduled;
case "sending":
return MessageStatus.Sending
return MessageStatus.Sending;
case "sent":
return MessageStatus.Sent
return MessageStatus.Sent;
case "undelivered":
return MessageStatus.Undelivered
return MessageStatus.Undelivered;
}
}

View File

@ -1,34 +1,34 @@
import { Queue } from "quirrel/blitz"
import twilio from "twilio"
import { Queue } from "quirrel/blitz";
import twilio from "twilio";
import db from "../../../db"
import db from "../../../db";
type Payload = {
id: string
customerId: string
to: string
content: string
}
id: string;
customerId: string;
to: string;
content: string;
};
const sendMessageQueue = Queue<Payload>(
"api/queue/send-message",
async ({ id, customerId, to, content }) => {
const customer = await db.customer.findFirst({ where: { id: customerId } })
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } })
const customer = await db.customer.findFirst({ where: { id: customerId } });
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } });
const message = await twilio(customer!.accountSid!, customer!.authToken!).messages.create({
body: content,
to,
from: phoneNumber!.phoneNumber,
})
});
await db.message.update({
where: { id },
data: { twilioSid: message.sid },
})
});
},
{
retry: ["1min"],
}
)
);
export default sendMessageQueue
export default sendMessageQueue;

View File

@ -1,16 +1,16 @@
import { Queue } from "quirrel/blitz"
import twilio from "twilio"
import { Queue } from "quirrel/blitz";
import twilio from "twilio";
import db from "../../../db"
import db from "../../../db";
type Payload = {
customerId: string
}
customerId: string;
};
const setTwilioWebhooks = Queue<Payload>(
"api/queue/set-twilio-webhooks",
async ({ customerId }) => {
const customer = await db.customer.findFirst({ where: { id: customerId } })
const customer = await db.customer.findFirst({ where: { id: customerId } });
const twimlApp = customer!.twimlAppSid
? await twilio(customer!.accountSid!, customer!.authToken!)
.applications.get(customer!.twimlAppSid)
@ -21,9 +21,9 @@ const setTwilioWebhooks = Queue<Payload>(
smsMethod: "POST",
voiceUrl: "https://phone.mokhtar.dev/api/webhook/incoming-call",
voiceMethod: "POST",
})
const twimlAppSid = twimlApp.sid
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } })
});
const twimlAppSid = twimlApp.sid;
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId } });
await Promise.all([
db.customer.update({
@ -36,8 +36,8 @@ const setTwilioWebhooks = Queue<Payload>(
smsApplicationSid: twimlAppSid,
voiceApplicationSid: twimlAppSid,
}),
])
]);
}
)
);
export default setTwilioWebhooks
export default setTwilioWebhooks;