webinstall / webi-roadmap Goto Github PK
View Code? Open in Web Editor NEWA space where we can ideate without cluttering the main repo with stale issues
License: Mozilla Public License 2.0
A space where we can ideate without cluttering the main repo with stale issues
License: Mozilla Public License 2.0
rnd
This is two parts:
rnd
that spits out a random string (for passwords, tokens, etc)Currently I have some aliases for creating random strings:
webi aliasman
aliasman alias rnd='xxd -l24 -ps /dev/urandom | xxd -r -ps | base64 | tr -d = | tr + - | tr / _'
aliasman alias xrnd='xxd -l24 -ps /dev/urandom'
It would be trivial to create a cross-platform Go program that spits out a random string.
rnd
2> (196-bit, base64)
> Zys_yZqEySPS5il0l1Vew_y46fQwAqvL
rnd --hex --bits 128
2> (128-bit, hexidecimal)
> 506cc039ef529b631d3d6a6baff6717e
Honestly, I'd prefer it in Rust, but I have yet to see a simple solution for cross compiling to multiple platforms from a Linux host (yes, Windows too, no the user to separately install the visual studio runtime distribution is not acceptable).
Getting this on webi would as simple as copying _example
, updating the github releases
info, and doing a find and replace on a few file system path names.
There are several Go programs on here which are released with goreleaser
which could serve as examples.
mkdir
, mv
, ls
, tar
, unzip
, variables)git clone [email protected]:webinstall/packages.git
pushd packages/
npm install
rsync -av _example/ CHANGE-ME/
CHANGE-ME/release.js
to use the official repoCHANGE-ME
unpacks (i.e. as a single file? as a .tar.gz? asCHANGE-ME/install.sh
(see bat
and jq
as examples)CHANGE-ME/install.ps1
(see bat
and jq
as examples)CHANGE-ME/README.md
It's also okay to have multiple people work on part of this (i.e. the Cheat
Sheet can be done independently from the install.sh
)
We need machine-friendly ways of editing certain aspects of the config - which will likely require splitting it out into more files and whatnot.
See webinstall/webi-installers#641 (comment).
For example:
vimtool get ale.fixers
vimtool add ale.fixers.markdown prettier
I hesitate to say "we should just do it as JSON and generate the config each time" because that's well outside the convention (whereas having a few extra files is odd, but not crazy), but... ๐คทโโ๏ธ
winget
is a built-in tool available on Windows 10 and 11.
See https://docs.microsoft.com/en-us/windows/package-manager/package/repository.
The updated webi install command could be:
winget webi && webi node
Webi has become far too complex.
I wanted something with near-0 magic - which is why I opted for shell scripts.
But as I've added one case, and then another, and then another (and pivoted from the helper script to the webi
command), it's bloated way too far.
There is a lot of necessary complexity, but there's also a lot of leftovers from the learning process.
My thoughts on fixing that:
webi
needs to be its own command, not embedded in the bootstrap --whatever
too)webi
should be offline-first webi_download
should be templated based on curl
and wget
webi_extract
should be templated based on tar
, xz
, git
etcwebi
commandbootstrap.sh
to curl-pipe-bootstrap.sh
for claritytemplate.sh
to install.tpl.sh
for clarityThis shouldn't really be Webi v2.0.0 - because it should be a smooth refactor with additional API on the server-side, not breaking changes, nor a from-scratch rewrite, nor a philosophical shift from the original goal.
Thoughts
Deserves an overview video, for sure.
https://webinstall.dev/vim-essential/
https://webi.ms/@dude/my-vpses
(or https://dude.webi.ms/my-vpses
?)pathman
Ok. This really isn't a super amazing feature request, but I was just polishing up my readme for a bit and went down a rabbit hole. I decided to add some of those neat little "badges" or shields and dug into how to use the shields.io api. And then I got the bright idea to create a Webi badge using:
https://img.shields.io/static/v1?label=webi&message=gprox&color=6c71c4&labelColor=fdf6e3&logoWidth=10&logo=data:image/svg+xml;base64,PHN2ZyBhcmlhLWhpZGRlbj0idHJ1ZSIgZGF0YS1wcmVmaXg9ImZhcyIgZGF0YS1pY29uPSJib2x0IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzMjAgNTEyIiB3aWR0aD0iMzQiIGhlaWdodD0iNTYiPjxwYXRoIGZpbGw9IiM2YzcxYzQiIGQ9Ik0yOTYgMTYwSDE4MC42bDQyLjYtMTI5LjhDMjI3LjIgMTUgMjE1LjcgMCAyMDAgMEg1NkM0NCAwIDMzLjggOC45IDMyLjIgMjAuOGwtMzIgMjQwQy0xLjcgMjc1LjIgOS41IDI4OCAyNCAyODhoMTE4LjdMOTYuNiA0ODIuNWMtMy42IDE1LjIgOCAyOS41IDIzLjMgMjkuNSA4LjQgMCAxNi40LTQuNCAyMC44LTEybDE3Ni0zMDRjOS4zLTE1LjktMi4yLTM2LTIwLjctMzZ6Ii8+PC9zdmc+Cg==
Which pretty much just follows the pattern:
https://img.shields.io/static/v1
query params:
label: webi
message: gprox
color: 6c71c4
labelColor: fdf6e3
logoWidth: 10
logo: data:image/svg+xml;base64,<BASE_64 OF THE WEBI BOLT SVG>
It'd be kind of cool if someone wanted to just add a badge on their repo to direct people to a recognizable link to the web installer website. Not sure if you can package the badge-url into the api somehow and let people put that on their website/github or something.
But also, I dont feel super strong about this, haha. Just thought it was kind of fun to have.
Not sure what I was looking at before, but the difference between these two looks right:
note: also useful: https://github.blog/2020-12-21-get-up-to-speed-with-partial-clone-and-shallow-clone/
git ls-remote --tags https://github.com/jshint/jshint
-c 'versionsort.suffix=-'
means that 1.0.0-rc4 sorts before 1.0.0--sort=version:refname
is numeric sort order (1.2.0 is before 1.10.0)--sort=-version:refname
changes the sort order to number version, descending^{}
is in the output, it's the true commit (i.e. the tag is dereferenced from the commit)Before:
--sort=version:refname
git -c 'versionsort.suffix=-' \
ls-remote --tags --sort='version:refname' \
https://github.com/jshint/jshint
After:
--sort=-version:refname
git -c 'versionsort.suffix=-' \
ls-remote --tags --sort='-version:refname' \
https://github.com/jshint/jshint
After:
{
"name": "sclient_1.5.0_darwin_amd64v2.tar.xz",
"version": "1.5.0",
"lts": false,
"channel": "stable",
"date": "2023-10-28",
"os": "macos",
"arch": "amd64",
"ext": "tar.xz",
"download": "https://github.com/therootcompany/sclient/releases/download/v1.5.0/sclient_1.5.0_darwin_amd64v2.tar.xz"
}
{
"name": "BeyondCodeBootcamp-aliasman-v1.1.2-0-g0e5e1c1.tar.gz",
"version": "1.1.2",
"lts": false,
"channel": "stable",
"date": "2023-02-23",
"os": "linux",
"arch": "amd64",
"ext": "tar.gz",
"download": "https://codeload.github.com/BeyondCodeBootcamp/aliasman/legacy.tar.gz/refs/tags/v1.1.2"
}
{
"name": "aliasman",
"version": "1.1.2",
"lts": false,
"channel": "stable",
"date": "2023-02-23",
"os": "linux",
"arch": "amd64",
"ext": "git",
"download": "https://github.com/BeyondCodeBootcamp/aliasman.git"
}
Most (all?) of the vim plugins are direct via Git (not GitHub, just git
).
For anything that has a tagged git source we could switch to showing versions using git ls-remote
:
git -c 'versionsort.suffix=-' \
ls-remote --tags --sort='version:refname' \
https://github.com/BeyondCodeBootcamp/aliasman
6a0ee1723b2106e117fc0f3862ca340eab8c26c5 refs/tags/v1.0.0
4171e2fe58122c61a100941c05ef963d80b413f4 refs/tags/v1.0.1
(doesn't seem sorted by version at all...)
This may include replacing the newly-added GitHub Source adapter, in most cases.
This would be helpful for automated checks to determine which packages have changed which OSes, Arches, etc they support.
It would also be useful for checking which packages are similar in terms of being msvc or musl or xz, etc.
When I first wrote this I was aware that Windows had symlinks, but that they required administrator privileges.
However, Windows also has "junctions" which, for all intents and purposes, appear to be symlinks... but technically are not... somehow. Anyway, they do NOT require admin privs.
It would speed up Windows installs significantly to use junctions.
Example:
Instead of
Copy-Item -Path "$pkg_src" -Destination "$pkg_dst" -Recurse
we could do a junction (if it's a directory and not just a file).
This may mean that we'd want to install all packages into
.local/opt/<package-name>-<version>/bin/<bin-name>
so that we could junction to
.local/opt/<package-name>/bin/<bin-name>
GitHub Actions would be very useful to test if an installer has broken due to some code change or a new package release. A daily runner would be able to find these issues before our users do.
Something like:
Short, 5 minute.
Not so long as https://www.youtube.com/watch?v=hj814rdTDm0&list=PLxki0D-ilnqbXhctTFCDGH3fSN7l7ATkL
We need a Tips 'n' Tricks blog
We want to update the husky pre-commit file fmt
(i.e. prettier
, shfmt
) and lint
(i.e. jshint
, shellcheck
) so that:
prettier
and shellcheck
where possibleHere's an example that can be used to "autofix" with prettier (and there's a link to a similar script for shellcheck - both may need tweaking):
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
# from https://prettier.io/docs/en/precommit.html#option-6-shell-script
# Should be functionally equivalent to `npm run fmt`
# We're not using basetag
#npx basetag rebase
FILES=$(
git diff --cached --name-only --diff-filter=ACMR | sed 's| |\\ |g'
)
if [ -z "$FILES" ]; then
exit 0
fi
echo "$FILES" | xargs npx prettier@2 --ignore-unknown --write
echo "$FILES" | xargs git add
# Should be functionally equivalent to `npm run lint`
JS_FILES=$(
echo "$FILES" | grep '\.js$' || true
)
if [ -z "$JS_FILES" ]; then
exit 0
fi
echo "$JS_FILES" | xargs npx jshint@2 -c .jshintrc.lax
See also:
The pyenv installer needs to test for the existence of zsh and fish and then update the appropriate config files.
Fish does NOT have a config directory or file by default. Here are some places to check to see if fish is installed.
~/.local/share/fish/fish_history
~/.config/fish
${WEBI_OPT_PATH}/fish
"$(command -v fish)"
A very high percentage of developer tools that provide packaged releases (~99%) can be categorized into a finite set of formats that can be installed with a finite set of rules - probably around 6 for unpacking, and 6 for type of contents.
We should be able to create almost all (80%+) installers from a set of rules.
Typically we're dealing with one of these package styles:
# bare (like ollama)
thing-1.0-linux
# bare, compressed
unxz thing-1.0-linux.xz
# compressed container
tar xvf thing-1.0-linux.tar.xz
unzip thing-1.0-linux.zip
diskutil ... thing-1.0-arm.dmg
Once unpacked, the directory structure almost always falls into one of these hierarchies:
./thing
./bin/thing
./thing-1.0/thing
./thing-1.0/bin/thing
# macOS apps (iTerm2, Brave)
Thing.app/
# macOS faux apps (fish, cmake)
Thing.app/Contents/thing
Thing.app/Contents/bin/thing
# Windows files have .exe
thing.exe
We should always know the exact name of the command that will be installed.
We should be able to determine if there are other files or just the one.
We should be able to tell if the manpage
file exists or not.
If we detect extra loose files outside the opt directory structure, we can "best guess it" flag it for manual review.
bin
dirs)bin
on Windows)we probably shouldn't attempt this in shell, but...
# count how deep "thing" is once unpacked
echo "thing/bin/thing" | tr -dc '/' | wc -c
Currently webi
is only updated when a curl https://webinstall.dev/xxxx
is run. It should definitely update when webi webi
is run, and perhaps any time webi xxxx
is run.
- cat << EOF > ...
+ cat <<'EOF' > ...
./webi/webi.sh
serveInstaller
and servePackage
/serveScript
to string-replace ./webi/webi.sh
webi info <installer>
should show (and possibly open) the URL with the cheat sheet.webi versions <installer>
should show the relevant https://webinstall.dev/api/releases/<installer>.tab
?os=macos&arch=aarch64&pretty=true
webi discord-invite
to join the discordwebi twitter-follow
to follow on twitterI don't quite understand the purpose of yet another alternative when we already have tools like Scoop, Winget, and Choco. Don't these tools already cover all use cases?
To me this seems to be almost exactly the same as Scoop.
Can someone explain diffs to me?
Hi, I'm presently developing something which as a high degree of overlap with webi.
http://github.com/elasticdotventures/_b00t_
It's definitely not same-same -- I'm planning to add webi in places where you have web installers. If webi can run bash then webi could use b00t installers, sort of incestuous.
My primary focus is menus around tool path selection and deployment (basically templated menus and interface libraries), a lot of devops/gitops type behaviors.
I like how you've configured everything to install in .local quite a bit. Anyway mostly wanted to say hi and cool project. Initiate a conversation about how we might work collaborate. Cheers!
Obviously it's a dumb idea to embed a script in a heredoc of another script.
We need a different solution for _webi/bootstrap.sh
, and it may require a shudder build step... ๐ฌ
How about we just make the webi
command its own command and installer, just like ssh-adduser
?
Or maybe even host it on GitHub releases so it gets its own version?
Maybe just check if the downloaded version is more than 5 minutes old? (bad idea)
Run if WEBI_INSTALL=true
is not set. ๐
webi webi
and webi update
should manually update webi, regardless of version.
if command -v curl > /dev/null 2> /dev/null; then
if ! curl -fsSL "$my_installer_url" -H "User-Agent: curl $WEBI_UA" \
-o "$WEBI_BOOT/$my_package-bootstrap.sh"; then
echo >&2 "error fetching '$my_installer_url'"
exit 1
fi
else
if ! wget -q "$my_installer_url" --user-agent="wget $WEBI_UA" \
-O "$WEBI_BOOT/$my_package-bootstrap.sh"; then
echo >&2 "error fetching '$my_installer_url'"
exit 1
fi
fi
webi_download \
"$WEBI_HOST/packages/${my_cmd}/${my_cmd}.sh" \
"$HOME/.local/bin/${my_cmd}"
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.