Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gregbrimble/cf-workers-typescript-template
A template Cloudflare Workers Typescript Server & Client
https://github.com/gregbrimble/cf-workers-typescript-template
Last synced: 4 months ago
JSON representation
A template Cloudflare Workers Typescript Server & Client
- Host: GitHub
- URL: https://github.com/gregbrimble/cf-workers-typescript-template
- Owner: GregBrimble
- License: mit
- Created: 2020-04-18T08:48:59.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-30T00:36:19.000Z (10 months ago)
- Last Synced: 2024-10-25T22:54:12.070Z (4 months ago)
- Language: TypeScript
- Size: 3.83 MB
- Stars: 32
- Watchers: 5
- Forks: 75
- Open Issues: 71
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Cloudflare Workers Typescript Server & Client Template
[data:image/s3,"s3://crabby-images/d2557/d2557f72295334214ab3624f187b3dfc3575c067" alt="GitHub Actions Test"](https://github.com/GregBrimble/cf-workers-typescript-template/actions?query=workflow%3ATest)
[data:image/s3,"s3://crabby-images/e5556/e55564ec14fc58230df30e6c2191cdef8698b21b" alt="GitHub Actions Deploy"](https://github.com/GregBrimble/cf-workers-typescript-template/actions?query=workflow%3ADeploy)
[data:image/s3,"s3://crabby-images/d4ca9/d4ca98a5a605593307c08db0e3b6401fe0b23113" alt="LGTM Alerts"](https://lgtm.com/projects/g/GregBrimble/cf-workers-typescript-template/alerts/)
[data:image/s3,"s3://crabby-images/2ef69/2ef6971072a1a55be9b67ad8dd4f3cb594e97299" alt="LGTM Code Quality"](https://lgtm.com/projects/g/GregBrimble/cf-workers-typescript-template/context:javascript)
[data:image/s3,"s3://crabby-images/b3e47/b3e47fd0ad41ee53ebb2135c2cdef9a183fe7ebe" alt="Code Climate Maintainability"](https://codeclimate.com/github/GregBrimble/cf-workers-typescript-template/maintainability)
[data:image/s3,"s3://crabby-images/26fd2/26fd22f43f68692e2e37c60a2402cbbabf44e74b" alt="Codecov"](https://codecov.io/gh/GregBrimble/cf-workers-typescript-template)
[data:image/s3,"s3://crabby-images/6f17e/6f17e96bfd8920210cb46bfeec94064f3fde2bc2" alt="License"](https://github.com/GregBrimble/cf-workers-typescript-template/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/1b4d5/1b4d50aea1abf7288143e883782ff63355327ac6" alt="GitHub Last Commit"](https://github.com/GregBrimble/cf-workers-typescript-template)
[data:image/s3,"s3://crabby-images/3499d/3499dc3db9d365e8863a56aee2b7d714443ccf40" alt="Lerna"](https://lerna.js.org/)A perfect\* template for a [Cloudflare Workers](https://workers.cloudflare.com/) project, using [Workers Sites](https://workers.cloudflare.com/sites) ([React](https://reactjs.org/) although can be easily swapped for [Gatsby](https://www.gatsbyjs.org/) or another static builder), [TypeScript](https://www.typescriptlang.org/), [Jest](https://jestjs.io/) and [Prettier](https://prettier.io/).
**And now, with end-to-end tests thanks to the new [`wrangler dev`](https://github.com/cloudflare/wrangler#-dev) command and [Playwright](https://playwright.dev/)! ✨**
## Prerequisites
- [Node.js](https://nodejs.org/en/)
- [`cloudflared`](https://developers.cloudflare.com/argo-tunnel/downloads/)
(On MacOS with Homebrew: `brew install cloudflare/cloudflare/cloudflared`)
## Getting Started
### Automatic
Click [the button below](<(https://deploy.workers.cloudflare.com/?url=https://github.com/GregBrimble/cf-workers-typescript-template&paid=true)>) and follow the setup instructions.
[data:image/s3,"s3://crabby-images/3f9d8/3f9d876f7209c7a0cc03ad9cd773d1ef10fc920e" alt="Deploy to Cloudflare Workers"](https://deploy.workers.cloudflare.com/?url=https://github.com/GregBrimble/cf-workers-typescript-template&paid=true)
### Manual
1. Fork repository:
1. Click the [`Use this template`](https://github.com/GregBrimble/cf-workers-typescript-template/generate) button.
1. Add GitHub Actions secret for [`CF_ACCOUNT_ID`](https://dash.cloudflare.com/?to=/:account/workers) and [`CF_API_TOKEN`](https://dash.cloudflare.com/profile/api-tokens) using `Edit Cloudflare Workers` template permissions.
1. Enable the [CodeClimate](https://github.com/settings/installations/205740), [Codecov](https://github.com/settings/installations/655980), [LGTM](https://github.com/settings/installations/2030503), and [Synk](https://snyk.io/) apps.
1. (Optionally) Update `.nvmrc`:
- Find available versions with `nvm ls-remote`
- Use the current Node.js version with `node -v > .nvmrc`1. Update `wrangler.toml`:
1. Replace `script-name` and `script-name-dev` with `new-script-name` and `new-script-name-dev` respectively.
1. Add KV Namespaces. For example:
```toml
kv-namespaces = [
{ binding = "NAMESPACENAME", id = "86bbce2f10524d33a5f26517e8dee123" }
]
```- Find existing namespaces with `wrangler kv:namespace list`
- Create a new namespace with `wrangler kv:namespace create NAMESPACENAME`1. Update `account_id`.
1. Update `package.json`:
1. Replace `script-name` with `new-script-name`.
1. Replace `repositoryname` with `newrepositoryname`.
1. Update GitHub account name in the following locations:
1. `repository.url`
1. `bugs.url`
1. `homepage`
1. Update `homepage` and `author`.
1. `npm i`
1. (Optionally) Update npm packages: `npm run updatePackages`
1. Update `README.md`, (don't forget the badges!).
1. Follow additional instructions in `/packages/*/README.md`
## Scripts
These should all be self-explanatory:
- `npm run lint`
- `npm run lint:fix`
- `npm run test`
- `npm run test:client`
- `npm run test:server`
- `npm run test:e2e`- `npm run deploy`
To start a local version:
1. In one terminal window, run `npm run start:client`.
1. In another, run `npm run start` and navigate to [http://localhost:8787](http://localhost:8787).
## About
- `/packages/client` is simply a CRA created with `npx create-react-app . --template typescript --use-npm`.
- `/packages/server` an function which intercepts a request to the client. If it returns a 404, the request is passed through to the client.
- `/packages/worker` attempts to fetch from the server first, falling back on the client.
- `/packages/e2e` runs end-to-end tests on the full-stack Worker.
---
\* May not be perfect