Skip to content

Instantly share code, notes, and snippets.

View gtrabanco's full-sized avatar
:octocat:

Gabriel Trabanco gtrabanco

:octocat:
  • Spain
View GitHub Profile
@gtrabanco
gtrabanco / setup-unifi-route-vpn-client.ts
Created February 15, 2025 12:47
This setup all ipv4 cidr of cloudflare as a route through vpn warp client that was previously setup
import IPCIDR from 'ip-cidr';
const endpoint = 'https://unifi'; // url
const apiKey = ''; // secret, create it in your unifi admin user
const description = 'Cloudflare'; // Route name
const wgClientName = 'Cloudflare Warp Client';
const wireguardInterfaceAddress = '172.16.0.2/32';
const wireguardInterfacePrivateKey = ''; // Secret provided by wgcf, see: https://www.tiernanotoole.ie/2024/12/12/how-to-use-cloudflare-warp-with-a-udm-pro.html
const wireguardPeerPublicKey = 'bmXOC+F1FxEMF9dyiK2H5/1SUtzH0JuVo51h2wPfgyo=';
@gtrabanco
gtrabanco / Promise-allSettled-example.js
Created October 3, 2024 22:15
How Promise.allSettled works
class CustomError extends Error {
constructor(public data: any) {
super(JSON.stringify(data));
}
}
Promise.allSettled([
Promise.resolve(33),
new Promise((resolve) => setTimeout(() => resolve(66), 0)),
99,
@gtrabanco
gtrabanco / what-forces-layout.md
Created August 9, 2024 21:53 — forked from paulirish/what-forces-layout.md
What forces layout/reflow. The comprehensive list.

What forces layout / reflow

All of the below properties or methods, when requested/called in JavaScript, will trigger the browser to synchronously calculate the style and layout*. This is also called reflow or layout thrashing, and is common performance bottleneck.

Generally, all APIs that synchronously provide layout metrics will trigger forced reflow / layout. Read on for additional cases and details.

Element APIs

Getting box metrics
  • elem.offsetLeft, elem.offsetTop, elem.offsetWidth, elem.offsetHeight, elem.offsetParent
@gtrabanco
gtrabanco / import-default-function-or-function-as-edge-function.ts
Created May 28, 2024 17:21
Import function to send as string with post method
import { existsSync } from 'node:fs';
export async function importDefaultFunctionOrFunctionAsEdgeFunction(filePathOrFn: string | Function) {
let fnString = filePathOrFn;
if (typeof filePathOrFn === "string" && existsSync(filePathOrFn)) {
const { default: fn } = await import(filePathOrFn);
fnString = fn.toString();
}
FROM oven/bun:1-debian
ENV DBUS_SESSION_BUS_ADDRESS autolaunch:
# Install latest chrome dev package and fonts to support major charsets (Chinese, Japanese, Arabic, Hebrew, Thai and a few others)
# Note: this installs the necessary libs to make the bundled version of Chrome that Puppeteer
# installs, work.
RUN apt update -y
RUN apt install -y wget gnupg
RUN apt install -y \
@gtrabanco
gtrabanco / git-public-keys.sh
Last active April 19, 2024 16:11
Shell script to use my github ssh keys to access my server and updates automatically daily =)
#!/usr/bin/env bash
# GIT_USERNAME=""
GIT_PUBLIC_KEYS_AUTHORIZED_KEYS_FILE="${GIT_PUBLIC_KEYS_AUTHORIZED_KEYS_FILE:-${HOME}/.ssh/authorized_keys}"
GIT_PUBLIC_KEYS_START="## Start of git public keys"
GIT_PUBLIC_KEYS_STOP="## End of git public keys"
tmp_file=$(mktemp)
clean() {
rm -f "$tmp_file" "${GIT_PUBLIC_KEYS_AUTHORIZED_KEYS_FILE}.gitkeys"
@gtrabanco
gtrabanco / debian-based-server-initial.sh
Last active July 26, 2025 06:29
Initial setup for ubuntu/debian server
#!/usr/bin/env bash
if ! command -p sudo -n -v > /dev/null 2>&1; then
echo "Execute this script as admin by using sudo writing:"
echo " sudo !!"
echo
fi
# Update
apt update -y
@gtrabanco
gtrabanco / tua.yaml
Last active April 21, 2024 20:59
Rest sensor for Oviedo local Buses
# You need to change last param of the resource url for your stop number
# You need to change "A" for whatever your line it is
# You can view all default params information stop here:
#. https://www.tua.es/es/lineas-y-horarios/paradas/uria-centro-1218.html?idLinea=6#paradasIda
# homeassistant:
# packages:
# rest: !include tua.yaml
input_text:
@gtrabanco
gtrabanco / object-group-by.js
Last active September 17, 2025 19:07
Object.groupBy polyfill
const hasGroup = typeof Object.groupBy === typeof undefined || typeof Array.groupToMap === typeof undefined || typeof Array.group === typeof undefined;
if (!hasGroup) {
const groupBy = (arr, callback) => {
return arr.reduce((acc = {}, ...args) => {
const key = callback(...args);
acc[key] ??= []
acc[key].push(args[0]);
return acc;
}, {});
};
@gtrabanco
gtrabanco / style.css
Created August 31, 2023 13:25
Dark mode en 3 líneas
/* Source: https://twitter.com/midudev/status/1652957687015940097 */
background-color: Canvas;
color: CanvasText;
color-scheme: light dark;