
* Crypto events (#1390) * update schemas, functions & ui to allow creating and updating events with a smart contract property * remove adding sc address in the dialog that first pops-up when creating a new event, since its an advanced option * add sc to booking ui * some more ts && error handling * fetch erc20s and nfts list in event-type page * some cleanup within time limit * ts fix 1 * more ts fixes * added web3 section to integrations * added web3 wrapper, needs connection to user_settings db * extract to api * Update eventType.ts * Update components/CryptoSection.tsx Change comment from // to /** as @zomars suggested Co-authored-by: Omar López <zomars@me.com> * convert axios to fetch, change scAddress to smartContractAddress, load bloxy from next_public_env * Fix branch conflict * add enable/disable btn web3 * fixed away user causing duplicate entries * Remove web3 validation * renamed web3 button in integrations * remove unused variable * Add metadata column * added loader and showToast to the web3 btn * fix: remove smartContractAddress from info sended * send to user events when the contract is missing * use window.web3 instead of web3 * use NEXT_PUBLIC_WEB3_AUTH_MSG * remove web3 auth from .env * wip * wip * Add metamask not installed msg and success redirect * add redirect when verified * styled web3 button and added i18n to web3 * fixed redirect after verification * wip * wip * moved crypto section to ee Co-authored-by: Yuval Drori <53199044+yuvd@users.noreply.github.com> Co-authored-by: Peer Richelsen <peeroke@richelsen.net> Co-authored-by: Yuval Drori <yuvald29@protonmail.com> Co-authored-by: Omar López <zomars@me.com> Co-authored-by: Edward Fernandez <edward.fernandez@rappi.com> Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com> Co-authored-by: Peer Richelsen <peeroke@gmail.com>
135 lines
3.8 KiB
TypeScript
135 lines
3.8 KiB
TypeScript
import { Prisma } from "@prisma/client";
|
|
import _ from "lodash";
|
|
|
|
/**
|
|
* We can't use aliases in playwright tests (yet)
|
|
* https://github.com/microsoft/playwright/issues/7121
|
|
*/
|
|
import { validJson } from "../../lib/jsonUtils";
|
|
|
|
const credentialData = Prisma.validator<Prisma.CredentialArgs>()({
|
|
select: { id: true, type: true },
|
|
});
|
|
|
|
type CredentialData = Prisma.CredentialGetPayload<typeof credentialData>;
|
|
|
|
export type Integration = {
|
|
installed: boolean;
|
|
type:
|
|
| "google_calendar"
|
|
| "office365_calendar"
|
|
| "zoom_video"
|
|
| "daily_video"
|
|
| "caldav_calendar"
|
|
| "apple_calendar"
|
|
| "stripe_payment"
|
|
| "metamask_web3";
|
|
title: string;
|
|
imageSrc: string;
|
|
description: string;
|
|
variant: "calendar" | "conferencing" | "payment" | "web3";
|
|
};
|
|
|
|
export const ALL_INTEGRATIONS = [
|
|
{
|
|
installed: !!(process.env.GOOGLE_API_CREDENTIALS && validJson(process.env.GOOGLE_API_CREDENTIALS)),
|
|
type: "google_calendar",
|
|
title: "Google Calendar",
|
|
imageSrc: "integrations/google-calendar.svg",
|
|
description: "For personal and business calendars",
|
|
variant: "calendar",
|
|
},
|
|
{
|
|
installed: !!(process.env.MS_GRAPH_CLIENT_ID && process.env.MS_GRAPH_CLIENT_SECRET),
|
|
type: "office365_calendar",
|
|
title: "Office 365 / Outlook.com Calendar",
|
|
imageSrc: "integrations/outlook.svg",
|
|
description: "For personal and business calendars",
|
|
variant: "calendar",
|
|
},
|
|
{
|
|
installed: !!(process.env.ZOOM_CLIENT_ID && process.env.ZOOM_CLIENT_SECRET),
|
|
type: "zoom_video",
|
|
title: "Zoom",
|
|
imageSrc: "integrations/zoom.svg",
|
|
description: "Video Conferencing",
|
|
variant: "conferencing",
|
|
},
|
|
{
|
|
installed: !!process.env.DAILY_API_KEY,
|
|
type: "daily_video",
|
|
title: "Daily.co Video",
|
|
imageSrc: "integrations/daily.svg",
|
|
description: "Video Conferencing",
|
|
variant: "conferencing",
|
|
},
|
|
{
|
|
installed: true,
|
|
type: "caldav_calendar",
|
|
title: "CalDav Server",
|
|
imageSrc: "integrations/caldav.svg",
|
|
description: "For personal and business calendars",
|
|
variant: "calendar",
|
|
},
|
|
{
|
|
installed: true,
|
|
type: "apple_calendar",
|
|
title: "Apple Calendar",
|
|
imageSrc: "integrations/apple-calendar.svg",
|
|
description: "For personal and business calendars",
|
|
variant: "calendar",
|
|
},
|
|
{
|
|
installed: !!(
|
|
process.env.STRIPE_CLIENT_ID &&
|
|
process.env.NEXT_PUBLIC_STRIPE_PUBLIC_KEY &&
|
|
process.env.STRIPE_PRIVATE_KEY
|
|
),
|
|
type: "stripe_payment",
|
|
title: "Stripe",
|
|
imageSrc: "integrations/stripe.svg",
|
|
description: "Collect payments",
|
|
variant: "payment",
|
|
},
|
|
{
|
|
installed: true,
|
|
type: "metamask_web3",
|
|
title: "Metamask",
|
|
imageSrc: "integrations/apple-calendar.svg",
|
|
description: "For personal and business calendars",
|
|
variant: "web3",
|
|
},
|
|
] as Integration[];
|
|
|
|
function getIntegrations(userCredentials: CredentialData[]) {
|
|
const integrations = ALL_INTEGRATIONS.map((integration) => {
|
|
const credentials = userCredentials
|
|
.filter((credential) => credential.type === integration.type)
|
|
.map((credential) => _.pick(credential, ["id", "type"])); // ensure we don't leak `key` to frontend
|
|
|
|
const credential: typeof credentials[number] | null = credentials[0] || null;
|
|
return {
|
|
...integration,
|
|
/**
|
|
* @deprecated use `credentials`
|
|
*/
|
|
credential,
|
|
credentials,
|
|
};
|
|
});
|
|
|
|
return integrations;
|
|
}
|
|
|
|
export type IntegrationMeta = ReturnType<typeof getIntegrations>;
|
|
|
|
export function hasIntegration(integrations: IntegrationMeta, type: string): boolean {
|
|
return !!integrations.find(
|
|
(i) => i.type === type && !!i.installed && (type === "daily_video" || i.credentials.length > 0)
|
|
);
|
|
}
|
|
export function hasIntegrationInstalled(type: Integration["type"]): boolean {
|
|
return ALL_INTEGRATIONS.some((i) => i.type === type && !!i.installed);
|
|
}
|
|
|
|
export default getIntegrations;
|