Releases: pinokiocomputer/pinokio
2.1.17
1. Editor mode
- Accessible under the "Files" tab
- Edit and save files
- Run scripts and see them execute on the side terminal
- Correctly save files under the
/api
folder instead of/_api
The editor mode was broken for a while but all fixed with this version
2. ENVIRONMENT Bug Fix
ENVIRONMENT files were incorrectly being generated when inheriting from the system ENVIRONMENT.
2.1.14
1. Much quicker loading when downloading an app
Previously when trying to download an app, there was a slight freeze of the UI before the download page is loaded. This was because it was checking whether the core modules have been already installed or not every time the download page loaded. This is unnecessary and just making the UX bad, so now it instead checks the core modules at launch, and the download page will load instantly.
BEFORE
AFTER
2. PINOKIO_SHARE_LOCAL_PORT
The Local Network Sharing feature is great but by default the local share proxy servers are started at random ports. Sometimes you may want to fix these ports instead of dynamically generated.
Now you can do this by setting the PINOKIO_SHARE_LOCAL_PORT
environment variable inside each app's "Configure" page.
Or can set it through the "Share" page:
3. Delete apps from home
Now you can delete apps from Pinokio home with just a click of a button.
4. Blue Screen
Previously when something went wrong on Pinokio it would just freeze with a blank white screen, with no way of understanding what's gone wrong. Now when something goes wrong, Pinokio will displays a "blue screen", displaying the error messages.
5. ENVIRONMENT Inheritance
Now when you set a custom environment variable in the ~/pinokio/ENVIRONMENT
file, whenever a new app is installed, the generated ENVIRONMENT
file will inherit from the custom attributes in ~/pinokio/ENVIRONMENT
.
For example, if you set PINOKIO_SHARE_CLOUDFLARE
to true
globally through ~/pinokio/ENVIRONMENT
, every app folder will automatically inherit this value true
(by default it's false
)
6. Various Bug Fixes
Some people experienced a blank white screen when upgrading to the last version. Have fixed a couple of issues which probably has fixed this.
7. Port 80 or 42000
Prior to Pinokio 2.0, the default port used by Pinokio has been 42000. With 2.0 this has changed to port 80 (in order to make the URL shorter when using Pinokio in zero-click launch mode inside regular browsers).
However, some people run web servers on their machine (which use port 80), and this caused problems for these users. So with this release, Pinokio tries to use port 80 but if it's already occupied, it uses port 42000.
This should get rid of all the issues related to the port (This was another reason some people were experiencing the "blank white screen" crash)
2.0.4
update
2.0.1
Pinokio 2
Highlights:
- Autonomous Scripts
- Zero click launch
- Customizable apps
- Pinokio Public Node
- One click stop
- Gradio file system
- Disposable apps
- More Efficient Disk Space Usage
- Bug fix
- Community Features
Autonomous Scripts
With 2.0, Pinokio Scripts can automatically start WITHOUT the user having to click through menu items. This removes a lot of friction in user experience, as well as enabling a lot of interesting use cases optimized for AI. What does this mean?
- Instead of having to click the menu buttons, you can program scripts so that simply opening an app will run the relevant script.
- For example, if an app is downloaded but hasn't been installed, run the install script.
- Or, if the app is already installed, automatically launch the app by running the start script.
- This behavior can be defined in the
pinokio.js
file by setting thedefault: true
for whichever menu item needs to be selected at any given time. Any menu item that's set asdefault: true
will be automatically selected, and when a script is selected it runs.- Because the
menu
function gets refreshed every time a script finishes a step, this means it is possible to check for certain condition and start a script when relevant. - For example, check if an app install folder already exists, and if it exists, run the start script to launch the app. But if the app folder does not exist, run the install script instead.
- Because the
Example:
module.exports = {
"version": "2.0",
"title": "Autostart",
"menu": async (kernel, info) => {
let installed = info.exists("app/env")
if (installed) {
// already installed, automatically run "start.json"
return [{
default: true,
text: "start",
href: "start.json",
}, {
text: "install",
href: "install.json"
}]
} else {
// not installed. run "install.json"
return [{
text: "start",
href: "start.json",
}, {
default: true,
text: "install",
href: "install.json"
}]
}
}]
}
Zero Click Launch
1 Click Launchers aren't cool. You know what's cool? 0 Click launchers.
Before 2.0
Previously, using apps in Pinokio meant:
- Open Pinokio
- Find the app you want to use
- Click the app to visit the app page
- Click the "start" button to start the app
- After the app starts, click "web UI" to open the web app
See, this is not really a "1 click" experience, is it?
After 2.0, with Zero Click Launch
You can now use Pinokio apps with the following step:
- Start typing a pinokio app name in your web browser address bar.
- It will autocomplete the URL (assuming you've visited it before)
- Just open the web page, and you're good to go.
No clicks, not even a need to open the Pinokio app. You can basically use the local Pinokio apps just like visiting online websites.
Here's how it works:
- Instant Access: You should be able to open any app INSTANTLY simply by typing its name in a browser address bar.
- Simply start typing the app's name in any browser address bar, and it will autocomplete (if you have visited the app before).
- Instant Launch: You shouldn't have to manually "launch" an app first just to use the app. Think about regular online websites, you simply visit a URL and the website is there. This should be the standard. No need to explicitly launch an app just to use.
- When an app is not already running, it will automatically launch when you visit it, and then present you the UI. All automatically. No clicks needed.
- If the app is already running, then it's instant access. It's almost like using a regular website.
1. Launch and Run
For example, here's what happens if you visit a Pinokio app that is NOT running yet:
Since the app is not running,
- it first launches the app
- and then automatically redirects to the Web UI.
There was NO clicks involved. The redirects were automatic.
2. Instant Run
And what if the app is ALREADY running? Then it works no different from visiting a regular online website. Here's an example where I start typing "stable diffusion web ui", and the browser autocompletes the URL and I visit the page, and it sends me directly the web app.
Customizable apps
Pinokio is a tool for the tinkerers and hobbyists. It should make it dead simple for people to customize WITHOUT having to touch the code.
However this has not been easy. Until now, Pinokio didn't provide an easy way for end users to tinker with custom settings. For example if you want to change where files are stored, you had to edit the pinokio script code.
Pinokio 2.0 introduces ENVIRONMENT variables. Scripts can make use of environment variables instead of having to hardcode everything. Each app can have a custom environment variable file.
1. Template
You can define environment variables by simply updating a file named ENVIRONMENT
(which is automatically created when you first install any script). Here's an example ENVIRONMENT
file:
CHECKPOINT_PATH=./models/llama3.gguf
Pinokio scripts may use the variable simply by accessing the env
variable:
{
"run": [{
"method": "shell.run",
"params": {
"message": "./llama-server -m {{env.CHECKPOINT_PATH}}",
"path": "llamacpp"
}
}]
}
2. Sandboxed Environment Variables
Normally, setting environment variables require people to change it globally. This is not flexible since every app may have different requirements and you probably want a custom environment for each app.
Thanks to Pinokio's isolated architecture, every value set in each app's ENVIRONMENT
file is constrained only to the app.
3. Friendly Interface
The built-in editor lets you tweak environment variables without touching the files directly. You can access the ENVIRONMENT
editor interface inside the Configure
tab in every app.
4. Custom Installer
Every app has a custom install page where the user can tweak the default settings BEFORE installing anything, such as changing the file folders, share settings, etc.
Pinokio Public Node
Now you can open up local Pinokio apps to the public internet.
1. Turn your local computer into a public web service
Anyone with a browser can connect to your local machine and run the apps you publish as public, powered by Cloudflare tunnel.
- Run an AI inference service from your local computer, which anyone can access.
- Keep your pinokio running at home and connect to it from outside using any device (such as phones)
2. Add authentication
Often you will want to only expose your public node to a select group of people. To achieve this, you can add authentication, which will require any user trying to connect to enter a correct passcode.
Turning on authentication is as easy as setting a "passcode" from the share settings page.
When you add authentication, you will be able to monitor all the incoming connections, from their IP to the device & browser information as well as which passcode is being used to make the connection.
Instantly Stop Scripts
When running things locally, stopping an app is as important as starting one, because most personal computers have limited resources and you can't be running all apps at once, and have to optimize your resources.
Before: Stopping an app wasn't easy. You had to visit the app page, open the app terminal, and click stop once the terminal loaded. Too many clicks.
After: you can stop any app with one click, either from home, or from the tabs.
Gradio File System
- Application File System: all files uploaded through gradio are now stored under the app folder (inside a folder named 'cache') instead of getting stored in an unknown location. Now you can view and manage all your files generated from gradio apps.
- Customizable: You can also switch the mode so all the gradio related files across multiple apps are stored deduplicated in one location, by setting the GRADIO_TEMP_DIR environment variable.
- Cross-app file sharing: Gradio has a security policy that blocks apps from serving files that are outside of each app's folder. For example, all the image files generated by automatic1111 stable diffusion web ui cannot be served by another app (for example a 3rd party app that serves the image files). This is for security reasons. With Pinokio, since everything happens inside pinokio anyway, Pinokio can expand this policy a bit and allow any app within the Pinokio operating system to be shared with any other app.
Disposable Apps
- Disposable Mode Install: Previously, if you install an app that uses torch hub files or any file from huggingface (for example through diffusers, transformers, etc.), all these files were stored in a single central location in order to save disk space. While this is ideal in many cases, a lot of times you just want to try an app and when you're done, just delete it, and want all the associated files to be deleted together. This was not possible before, but with 2.0, this is the default option when installing apps. Now every app install is self-contained by default, so when you delete the app folder, all the huge files associated with it will be gone with the app.
- Disk Space Save Mode Install: By default, all apps install in a disposable mode. But you can even customize this behavior and let Pinokio store these files globally in a deduplicated manner. This will be useful when you try out an app and decide to keep it. If you think you may want to keep using the app, you may want to reinstal...
2.0.2
Pinokio 2
UPDATE: just made a minor update to fix a minor bug (local sharing for pinokio itself was broken. local sharing for each individual app installed through pinokio works fine). Install 2.0.3 instead if you're seeing this https://github.com/pinokiocomputer/pinokio/releases/tag/2.0.3
Highlights:
- Autonomous Scripts
- Zero Click Launch
- Customizable Apps
- Pinokio Public Node
- One Click Stop
- Gradio file system
- Disposable apps
- More Efficient Disk Space Usage
- Bug fix
- Install Screen
- Community Features
1. Autonomous Scripts
With 2.0, Pinokio Scripts can automatically start WITHOUT the user having to click through menu items. This removes a lot of friction in user experience, as well as enabling a lot of interesting use cases optimized for AI. What does this mean?
Let's take a look at a quick example. You click exactly once at the beginning when you install, and Pinokio automatically runs install script, and then start script, all without the user having to touch anything:
IMPORTANT
To take advantage of this new feature, in addition to updating to Pinokio 2, you MUST update each individual script, since these scripts have been updated to add the autostart features.
Now when you install something on Pinokio, you simply need to click Install and forget about it. And when you come back, you'll find that the app has been not only installed but already running, automatically.
- Instead of having to click the menu buttons, you can program scripts so that simply opening an app will run the relevant script.
- For example, if an app is downloaded but hasn't been installed, run the install script.
- Or, if the app is already installed, automatically launch the app by running the start script.
- This behavior can be defined in the
pinokio.js
file by setting thedefault: true
for whichever menu item needs to be selected at any given time. Any menu item that's set asdefault: true
will be automatically selected, and when a script is selected it runs.- Because the
menu
function gets refreshed every time a script finishes a step, this means it is possible to check for certain condition and start a script when relevant. - For example, check if an app install folder already exists, and if it exists, run the start script to launch the app. But if the app folder does not exist, run the install script instead.
- Because the
Example:
module.exports = {
"version": "2.0",
"title": "Autostart",
"menu": async (kernel, info) => {
let installed = info.exists("app/env")
if (installed) {
// already installed, automatically run "start.json"
return [{
default: true,
text: "start",
href: "start.json",
}, {
text: "install",
href: "install.json"
}]
} else {
// not installed. run "install.json"
return [{
text: "start",
href: "start.json",
}, {
default: true,
text: "install",
href: "install.json"
}]
}
}]
}
2. Zero Click Launch
1 Click Launchers aren't cool. You know what's cool? 0 Click launchers.
You don't even need to open Pinokio. You can open pinokio and its apps directly from a new web browser tab (In this example I'm opening Pinokio from my mac safari browser):
Before 2.0
Previously, using apps in Pinokio meant:
- Open Pinokio
- Find the app you want to use
- Click the app to visit the app page
- Click the "start" button to start the app
- After the app starts, click "web UI" to open the web app
See, this is not really a "1 click" experience, is it?
After 2.0, with Zero Click Launch
You can now use Pinokio apps with the following steps:
- Start typing a pinokio app name in your web browser address bar.
- It will autocomplete the URL (assuming you've visited it before)
- Just open the web page, and you're good to go.
No clicks, not even a need to open the Pinokio app (to clarify, Pinokio itself should be running in the background, you just don't need to switch to Pinokio app itself like before, and instead just open apps directly from any web browser like Safari, Chrome, Firefox, Edge, etc.).
Basically, local apps work just like visiting online websites.
Here's how it works:
- Instant Access: You should be able to open any app INSTANTLY simply by typing its name in a browser address bar.
- Simply start typing the app's name in any browser address bar, and it will autocomplete (if you have visited the app before).
- Instant Launch: You shouldn't have to manually "launch" an app first just to use the app. Think about regular online websites, you simply visit a URL and the website is there. This should be the standard. No need to explicitly launch an app just to use.
- When an app is not already running, it will automatically launch when you visit it, and then present you the UI. All automatically. No clicks needed.
- If the app is already running, then it's instant access. It's almost like using a regular website.
1. Launch and Run
For example, here's what happens if you visit a Pinokio app that is NOT running yet:
Notice how I start typing "Stable..." and it autocompletes "Stable Audio" since I have visited that URL before in the browser. Just select that URL just like you do with any online website, and it opens up Pinokio's Stable Audio app.
In this case, Stable Audio is not running when I entered the URL, so:
- it first launches the app
- and then automatically redirects to the Web UI.
There was NO clicks involved. The redirects were automatic.
2. Instant Run
And what if the app is ALREADY running? Then it works no different from visiting a regular online website. Here's an example where I start typing "stable diffusion web ui", and the browser autocompletes the URL and I visit the page, and it sends me directly the web app.
3. Customizable Apps
Pinokio is a tool for the tinkerers and hobbyists. It should make it dead simple for people to customize WITHOUT having to touch the code.
However this has not been easy. Until now, Pinokio didn't provide an easy way for end users to tinker with custom settings. For example if you want to change where files are stored, you had to edit the pinokio script code.
Pinokio 2.0 introduces ENVIRONMENT variables. Scripts can make use of environment variables instead of having to hardcode everything. Each app can have a custom environment variable file.
1. Template
You can define environment variables by simply updating a file named ENVIRONMENT
(which is automatically created when you first install any script). Here's an example ENVIRONMENT
file:
CHECKPOINT_PATH=./models/llama3.gguf
Pinokio scripts may use the variable simply by accessing the env
variable:
{
"run": [{
"method": "shell.run",
"params": {
"message": "./llama-server -m {{env.CHECKPOINT_PATH}}",
"path": "llamacpp"
}
}]
}
2. User Friendly Interface
The built-in editor lets you tweak environment variables without touching the files directly. You can access the ENVIRONMENT
editor interface inside the Configure
tab in every app.
3. Sandboxed Environment Variables
Normally, setting environment variables require people to change it globally. This is not flexible since every app may have different requirements and you probably want a custom environment for each app.
Thanks to Pinokio's isolated architecture, every value set in each app's ENVIRONMENT
file is constrained only to the app.
4. Pinokio Public Node
Now you can open up local Pinokio apps to the public internet.
1. Turn your local computer into a public web service
Anyone with a browser can connect to your local machine and run the apps you publish as public, powered by Cloudflare tunnel.
- Run an AI inference service from your local computer, which anyone can access.
- Keep your pinokio running at home and connect to it from outside using any device (such as phones)
2. Add authentication
Often you will want to only expose your public node to a select group of people. To achieve this, you can add authentication, which will require any user trying to connect to enter a correct passcode.
Turning on authentication is as easy as setting a "passcode" from the share settings page, like this:
Then whenever someone visits the Cloudflare website, they will need to authenticate with a passcode, like this:
When you add authentication, you will be able to monitor all the incoming connections, from their IP to the device & browser information as well as which passcode is being used to make the connection:
Instantly Stop Scripts
When running things locally, stopping an app is as important as starting one, because most personal computers have limited resources and you can't be running all apps at once, and have to optimiz...
1.3.4
1.3.4: Bug Fix Update
- Remove constant logging: a recent release added a feature that keeps the most up-to-date system info to be fed into API calls. But this was not optimal because it kept refreshing the machine every few seconds even when nothing is running. Removed this and instead queries the system info only right before making an RPC call, which has the same effect but no need to keep querying.
- Registry fix: Some people experienced issues with recent releases where Pinokio kept saying the "registry" module is not installed. This was because of some terminal parsing issue, and has been fixed.
- Proxy port: Do NOT use the default 8000 to create proxies. Instead, the proxy ports start from
42420
. When aproxy.start
API call is made, Pinokio scans open ports starting from 42420 and starts a proxy using the first discovered port.
1.3.0
Pinokio 1.3.0 : Neuron
Pinokio script is now a full fledged AI scripting language. With this release, you can script ANYTHING AI related: installing, running, orchestrating, etc.
Also, the scripts can interact with other scripts in a distributed manner, while saving disk space and memory.
- Modules
- Distributed URI
- Conditional Execution
- Jump
- Programmable Conda + Venv
- Gradio Script
Also in v1.3.0,
- Windows Canary Support: removed the windows canary restriction (previously windows canary had some bugs that made it impossible to run pinokio, but it has been fixed, so update to the latest canary version of windows, and update pinokio to this version, and it should work now)
- Robust Linux CUDA Support: supported with the new programmable conda + venv script
- Minimal mode: minimize/maximize the terminal to hide/show the sidebar
- Various Bug fixes
1. Modules
With the new "script" API, scripts can call other scripts, process its return values, and even access local memory:
- download another script on the fly
- start/stop other scripts
- call and respond to other scripts
all programmatically.
2. Distributed URI
Any script can call any other script modules through the distributed git URI scheme, fully making use of:
- published git uri
- commit hash
- git branch
- file path
Simply specifying a git URI will automatically download and execute the script.
3. Conditional Execution
Every step in a Pinokio run script is a JSON RPC call, complete with "method" and "params". But often you want to run a step ONLY IF certain conditions are met (ex: run commands for certain OS/GPU/Arch).
The "when" attribute lets you achieve this now.
4. Jump
Officially introducing "jump" API, and an "id" attribute for each RPC call, which lets you jump to any index or an id within the run script. Even supports passing parameters when jumping.
5. Programmable Conda/Venv API
With just one line in the JSON script, you can:
- create a conda/venv if it doesn't exist
- activate a conda/venv environment
Can handle pretty much every scenario for installing & running AI apps in isolated environments, saving storage.
6. Gradio Script
Every gradio app has a built-in API and a JS/Python API client that can interact with it.
Pinokio script has introduced a new "gradio.predict" API that lets you make requests to ANY gradio app, using a JSON based script.
Great for building agents & workflows.
1.2.73
update version
1.2.72
update version
1.2.71
update version