/io

this is the beginning of the end

Primary LanguageJavaScriptGNU General Public License v2.0GPL-2.0

Please note: This app is being developed. It is riddled with bugs, and everything is subject to change.

Status: [BUG SALAD]

koad:io

tldr: An organizational tool for your mind's eye.

koad-io is a powerful command-line interface and toolset designed to help users easily manage and interact with a wide variety of data and resources. It provides a modular and extensible framework that can be easily customized to suit a wide range of needs, from simple scripting tasks to complex distributed systems.

Indeed, koad:io aims to provide a comprehensive command and control framework that allows you to manage various aspects of your projects and environments using well-defined commands. This approach can greatly simplify complex tasks and make it more efficient to manage different processes and configurations. The modularity and flexibility koad:io brings into your setup allow for easy extension and customization, making it a powerful tool for managing your meta-digital workflow.


warning: I am an amateur > all of this might be shit, it's too early to tell.

Matrix

reason

Your systems need to be faster than you (can) think.

by saving a task as a command, and saving the environment variables used as an entity,

  • I can remember how I did a thing.
  • I can replay the thing I did.
  • I can go back and see if I was right.
  • I can keep my things together as simple files and folders.
  • I can keep my projects/data organized into categories (an entity folder for each area of focus).
  • I can pass-on project files/folders onto someone else, as is.
  • I can visualize the structure of all my data.
  • I can internalize the content of all my data.

koad:io at a glance

koad:io starts with a handful of wrapper commands. Using these commands and a basic directory structure, koad:io makes it easy to remember where you leave your digital thoughts/things.

commands

many people don't like to use the command prompt but we know that it is where all the magic is.

for those who use-and-know bash, koad:io will be easy to understand and those who don't know bash will always be waiting for someone to develop a UI they can install.

example potential koad:io commands

start the software that is a website called book.koad.sh.

alice start site book.koad.sh

Open the matrix/element web application and be logged in as Alice

alice open element

SSH into a server called toronto and passwordlessly be logged in as Alice

alice ssh toronto

koad:io doesnt come with commands, they are meant to be added each by you, the creator of this space.

the documentation is shit right now, a collection of barf; but you can see if it helps you to understand where we are going here. book.koad.sh

chain reactions

when calling a koad:io command, there is a chain-reaction of environment and command files that get evaluated; this is where you can create and customize each command to run specific to the entity and/or the current working directory.

  • you call an entity wrapper, ie: alice start
  • if you didn't specify any arguments (ie: alice), stop here and pass the call to the executed-without-arguments.sh hook.
  • alice loads some general environment details
    • ENTITY=alice
    • CWD=$PWD (the directory in which the command is issued)
  • then calls the koad:io cli wrapper
    • ~/.koad-io/bin/koad-io $@
  • koad:io cli wrapper loads entity specific environment details
    • ~/.koad-io/.env (if exists)
    • ~/.$ENTITY/.env (if exists)
    • ~/.$ENTITY/.credentials (if exists)
  • then, finds the most relevant regular command by searching in the following locations
    • uses the results from the last location a command is found in.
      • the deepest directory that contains either a command.sh file or a $COMMAND_NAME.sh file.
    • ~/.koad-io/commands/
    • ~/.$ENTITY/commands/
    • checks the current working directory (CWD)
      • $CWD/commands/
    • if a command of the same name is in the current directory
      • use it instead: ./$COMMAND_NAME.sh
      • load more environment vars
        • $CWD/.env (if exists)
        • $CWD/.credentials (if exists)
  • finally, call the chosen command with
    • environment details from the chain reaction
    • the remaining arguments passed into the entity cli wrapper

examples explained

no1

alice probe domain koad.sh

is similar to / wraps to

set -a 
source ~/.koad-io/.env
source ~/.alice/.env
~/.koad-io/commands/probe/domain/command.sh koad.sh

no2

alice archive video https://www.youtube.com/watch?v=dQw4w9WgXcQ

is similar to / wraps to

set -a 
source ~/.koad-io/.env
source ~/.alice/.env
~/.koad-io/commands/archive/video.sh https://www.youtube.com/watch?v=dQw4w9WgXcQ

saves the results in the ~/.alice/archive/inbound folder by default or will take a specified folder within ~/.alice/.env/ as KOAD_IO_ARCHIVE_FOLDER

KOAD_IO_ARCHIVE_FOLDER=$HOME/.alice/archive/inbound

you can see that using this very general structure, you can create very specific outcomes.


install koad:io

install these first

create the ~/.koad-io folder with a clone of this repo

git clone https://github.com/koad/io.git ~/.koad-io

add the ~/.koad-io/bin folder to your path (add this to the end of your ~/.bashrc file)

[ -d ~/.koad-io/bin ] && export PATH=$PATH:$HOME/.koad-io/bin

all together,

git clone https://github.com/koad/io.git ~/.koad-io && echo -e "\n\n[ -d ~/.koad-io/bin ] && export PATH=$PATH:$HOME/.koad-io/bin\n" >> ~/.bashrc && export PATH=$PATH:$HOME/.koad-io/bin

create an entity

your first koad:io entity! 🤩 sooo exciting!

koad-io gestate alice

alice will be created entirely in the .alice directory in your home directory

ls -la ~/.alice

back this directory up NOW, and keep it somewhere suuuuuper safe. want to automated backups? build a raspberry pi powered concealment key-ring that also pretends to be your antique/legacy/low-tech front door bell.

Your entity's directory will be a basic bare/blank koad:io skeleton filled with directories and keys that will be handy for you if you ever decide you want your entity to exist among multiple devices/locations and interact with other-people-entities. Indeed, this project could be the start of a fully decentralized (deviceless) operating system that turns all the worlds computers into your private productivity operating system.

for now, Ignore the overwhelming possibilities and focus on populating your commands folder with whatever creative thing you desire.

create commands

bookmark koad's bash cheatsheet as it is a handy resource for creating new tasks/commands and view the ./commands/ folder where a couple of commands needed to (re)produce and initialize new and future-generation koad:io entities.

global commands

your first ever koad:io command! 😄

inside ~/.koad-io/commands/

mkdir ~/.koad-io/commands/hello
cd ~/.koad-io/commands/hello
echo '
#!/usr/bin/env bash

echo "hi there, $ENTITY here!"
echo "args: $@"
'> command.sh
chmod +x command.sh

run

inside ~/.koad-io/commands/hello using any entity

cd ~/.koad-io/commands/hello
alice command
alice command arg1 arg2 arg3 arg4

globally available using any entity

alice hello
alice hello arg1 arg2 arg3 arg4

entity specific commands

commands can be specific to the entity

create

inside ~/.alice/commands/

mkdir ~/.alice/commands/hello
cd ~/.alice/commands/hello
echo '
#!/usr/bin/env bash

echo "hi there, $ENTITY here!"
echo "args: $@"
'> command.sh
chmod +x command.sh

run

inside ~/.alice/commands/hello using any entity

cd ~/.alice/commands/hello
alice command
alice command arg1 arg2 arg3 arg4

globally available using only alice

alice hello
alice hello arg1 arg2 arg3 arg4

folder specific commands

You can use your entity's environment anywhere you want.

create

inside ~/some/random/folder/

cd ~/some/random/folder/
echo '
#!/usr/bin/env bash

echo "hi there, $ENTITY here!"
echo "args: $@"
'> hello.sh
chmod +x hello.sh

run

inside ~/some/random/folder/

cd ~/some/random/folder/
alice hello
alice hello arg1 arg2 arg3 arg4

preload

check the commands folder to see what comes preloaded, not a lot.

language specific examples

interact with the example command to see how things work

alice example

output

see how these examples work by taking a peek into the `~/.koad-io/commands/example` folder

this output is created by the file `~/.koad-io/commands/example/command.sh`

run other example commands, written to showcase various available languages

alice example bash
alice example javascript
alice example python
alice example rust
alice example go

example: Alice

Check out the example installation: Alice. Alice is a fantastic working example that demonstrates the true potential of this technology. By exploring Alice's repository, which you can find at https://github.com/koad/alice, you'll get a deeper understanding of how koad:io can enhance your productivity. Head over to Alice's repo now and be inspired by what koad:io can do. Happy exploring! 🚀

Contributing

koad-io is an open-source project, and contributions are always welcome. If you'd like to contribute to koad-io, please take a look at our contributing guidelines for more information.

🤝 Support

As mentioned above, I am an amateur;

I have been using computers for a long time, programming for a long time; but, I totally suck in a lot of ways.

I'd appreciate any feedback from any seasoned bash users out there!

Contributions, issues, and feature requests are welcome!

Give a ⭐️ if you like this project!

P.S. somebody somewhere, sometime, will create a voice controller for this,. so keep that in mind when creating commands. You have full control, imagine if you were able to teach siri over time (for yourself); it would be amazing.

/koad

License

koad-io is licensed under the GPL License.