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
#!/usr/bin/env bash | |
export PATH="$HOME/bin:$PATH" | |
iface="$(route get 1.1.1.1 2>/dev/null | grep interface | perl -ple 's/\s*interface:\s*//')" | |
if [ $? != 0 ]; then | |
iface="n/a" | |
fi | |
case "$iface" in |
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
import { encode } from "html-entities" | |
import { getReasonPhrase, StatusCodes } from "http-status-codes" | |
import stringify from "json-stringify-safe" | |
import { NextApiResponse } from "next" | |
// Semantic sugar for returning various status codes, optionally with messages. | |
export const statusHelper = (res: NextApiResponse) => ({ | |
codes: StatusCodes, | |
status(code: number, message?: string): void { | |
const phrase = getReasonPhrase(code) |
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
import React, { | |
createContext, | |
ReactNode, | |
useCallback, | |
useContext, | |
useRef, | |
useState, | |
} from "react" | |
import { | |
Button, |
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
const fetch = require('./fetch') | |
const RED = '#cd3131' | |
const YELLOW = '#e5e512' | |
const GREEN = '#05bc79' | |
const BLUE = '#2472c8' | |
exports.handler = async function(event, context) { | |
// Debugging | |
// console.log('event', JSON.stringify(event, null, 2)) |
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
# ------------------------------ | |
# * Dependencies | |
FROM node:16.13.0-alpine3.14 AS deps | |
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed. | |
RUN apk add --no-cache libc6-compat | |
WORKDIR /app | |
COPY package.json yarn.lock ./ | |
RUN yarn install --frozen-lockfile |
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
/* | |
* Usage: | |
* const { alert, confirm, prompt } = useModals() | |
* alert("Hey!") // awaitable too | |
* if (await confirm("Are you sure?")) ... | |
* const result = await prompt("Enter a URL", "http://") | |
*/ | |
import React, { | |
createContext, |
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
const { graphql } = require("@octokit/graphql") | |
const REPO_OWNER = "x" | |
const REPO_NAME = "y" | |
const PROJECT_NUMBER = 2 | |
const COLUMN_TO_SORT = /To Do/ | |
const api = graphql.defaults({ | |
headers: { | |
authorization: `token ${process.env.GITHUB_TOKEN}`, |
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
import { FirehoseClient, PutRecordCommand } from "@aws-sdk/client-firehose" | |
const streamName = process.env.AWS_FIREHOSE_LOG_EVENT_STREAM | |
const client = new FirehoseClient({}) | |
export const logEvent = (type: string, data: Object) => { | |
try { | |
const record = Buffer.from( | |
JSON.stringify({ |
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
import getConfig from "next/config" | |
// Add publicRuntimeConfig: { oneSignalAppId: ... } to next.config.js | |
const { publicRuntimeConfig } = getConfig() | |
export const useOneSignal = (externalUserId?: string): void => { | |
// react-onsignal tries to use a global `document` variable, so we can only | |
// use it in the client side. Luckily this method doesn't trigger any "wrong | |
// number of hooks" errors either. | |
if (!process.browser) return |
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
/* | |
Want to know when ECS events happen in Slack? Try this. | |
(1) Create a new Slack app with an incoming webhook, save the webhook URL | |
(2) Create an SNS topic called something like ECSEvents | |
(3) Create a CloudWatch Rule that publishes all ECS events to the topic | |
(4) Create a Node.js Lambda that is triggered by the SNS topic | |
(5) Add a WEBHOOK_URL environment variable to the Lambda with the webhook URL | |
(6) Paste this code into index.js | |
(7) Paste the contents of https://unpkg.com/node-fetch/lib/index.js into fetch.js | |
(8) Deploy and enjoy |