aboutsummaryrefslogtreecommitdiff
path: root/server/index.js
blob: 9c69297235a6e399ff04155c713afaf9ace0acc2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
import * as Sentry from "@sentry/cloudflare";

const configuration = {
  redirects: [
    // socials
    { from: "/github", to: "https://github.com/zuedev" },
    { from: "/gitlab", to: "https://gitlab.com/zuedev" },
    { from: "/discord", to: "https://discord.gg/N34EeYtFCs" },
    { from: "/gumroad", to: "https://zuedev.gumroad.com/" },
    { from: "/linkedin", to: "https://linkedin.com/in/zuedev" },
    { from: "/steam", to: "https://steamcommunity.com/id/zuedev" },

    // bank direct pay
    { from: "/monzo", to: "https://monzo.me/alexanderpooley5" },

    // aws
    { from: "/aws", to: "https://zuedev.awsapps.com/start" },

    // stripe links
    { from: "/stripe", to: "/stripe/billing" },
    {
      from: "/stripe/billing",
      to: "https://billing.stripe.com/p/login/6oE8Ag4EK2N82OI000",
    },
    {
      from: "/donate",
      to: "/stripe/donate",
    },
    {
      from: "/stripe/donate",
      to: "https://donate.stripe.com/8x2aEW6esd4lfAc75g97G05",
    },
    {
      from: "/pay",
      to: "/stripe/pay",
    },
    {
      from: "/stripe/pay",
      to: "https://buy.stripe.com/5kQ00i1Yc9S99bOahs97G06",
    },
    {
      from: "/stripe/book",
      to: "https://book.stripe.com/cNi14mfP21lD1Jm61c97G07",
    },

    // cv/resume links
    {
      from: "/cv",
      to: "https://drive.google.com/file/d/1S49c4nQEpY5IeQNkTcLlnabz664RlnAj/view?usp=sharing",
    },
    {
      from: "/cv.pdf",
      to: "https://drive.google.com/file/d/1S49c4nQEpY5IeQNkTcLlnabz664RlnAj/view?usp=sharing",
    },
    {
      from: "/resume.pdf",
      to: "https://drive.google.com/file/d/1S49c4nQEpY5IeQNkTcLlnabz664RlnAj/view?usp=sharing",
    },
    {
      from: "/resume",
      to: "https://drive.google.com/file/d/1S49c4nQEpY5IeQNkTcLlnabz664RlnAj/view?usp=sharing",
    },

    // terms
    { from: "/tos", to: "/terms-of-service/" },
    { from: "/terms", to: "/terms-of-service/" },

    // privacy
    { from: "/pp", to: "/privacy-policy/" },
    { from: "/privacy", to: "/privacy-policy/" },

    // help
    { from: "/support", to: "/help/" },
    { from: "/help", to: "/help/" },

    // cal
    { from: "/cal", to: "https://cal.com/zuedev" },
  ],
};

export default Sentry.withSentry(
  (env) => ({
    dsn: "https://0c0371903ecb051a9c930131bc89ccf9@o613246.ingest.us.sentry.io/4511218222235648",
    // Adds request headers and IP for users, for more info visit:
    // https://docs.sentry.io/platforms/javascript/guides/cloudflare/configuration/options/#sendDefaultPii
    sendDefaultPii: true,
  }),
  {
    /*
    Fetch event handler, this function will be called whenever a request is made to the worker.
    The function will parse the request and return a response based on the request path.

    @param {Request} request - the incoming request object
    @param {Environment} environment - the environment object
    @param {Context} context - the context object

    @returns {Response} a new Response object
  */
    async fetch(request, environment, context) {
      const { pathname } = new URL(request.url);

      if (configuration.redirects) {
        for (const redirect of configuration.redirects) {
          if (pathname === redirect.from || pathname === redirect.from + "/") {
            return Response.redirect(redirect.to, 301);
          }
        }
      }

      if (pathname.startsWith("/api")) {
        return new Response("Hello from the API!", {
          headers: { "Content-Type": "text/plain" },
        });
      }

      if (pathname.startsWith("/sentry-test-error")) {
        throw new Error("Sentry test error");
      }

      return environment.ASSETS.fetch(request);
    },

    /*
    Email event handler, this function will be called whenever an email is sent to the worker.
    The function will parse the email message and forward it to a specified email address.

    @param {Message} message - the incoming email message object
    @param {Environment} environment - the environment object
    @param {Context} context - the context object

    @returns {void}
  */
    async email(message, environment, context) {
      message.forward("alex@zue.dev");
    },

    /*
    Scheduled event handler, this function will be called whenever a scheduled event is triggered.
    The function will perform a task and return a response based on the task outcome.

    @param {Event} event - the incoming event object
    @param {Environment} environment - the environment object
    @param {Context} context - the context object

    @returns {void}
  */
    async scheduled(event, environment, context) {
      console.log("Scheduled event triggered!");
    },
  },
);