Applications can be shared with peers by seeding them to the network from an efficient local data structure (a hypercore). We call the mirroring of a local file system into the Pear platform Application Storage "staging". Seeding is sharing an app from a machine over the Distributed Hash Table (DHT) (via hyperswarm) so that other peers can replicate, consume and reseed the application.
{% embed url="https://www.youtube.com/watch?v=BEadqmp7lA0" %} Build with Pear - Episode 02: Sharing Pear Applications {% embeded %}
This guide can either follow on from, Making a Pear Desktop Application, Making a Pear Terminal Application, or get setup quickly with the following:
mkdir staging-example
cd staging-example
pear init -y
If starting from Making a Pear Desktop Application or Making a Pear Terminal Application ensure that the command-line current working directory is set to the project folder of the application.
To view the help for the pear stage
command run pear help stage
.
The command signature for pear stage
is pear stage <channel|key> [dir]
.
Before a project is staged for the first time there is no key. The application name and channel
name are involved in generating the application key, which is later used to run the application from the DHT.
By convention, for internal use we use the channel name dev
:
pear stage dev
No need to specify dir
, the command-line current working directory is already set to the project folder.
The channel name can be any valid name. Using dev
for local development checks and internal collaboration, using pear stage production
for production and pear stage <custom-channel-name>
for any customizations/specializations of the application is a reasonable convention.
Stage will output a diff of changes - the first time will all be additions of course - and then it will output the application key.
If the application is a desktop application there will also be a warmup step where the application is opened in the background and analyzed for initialization-to-loaded critical-path. This metadata is stored along with the application into an application-dedicated hypercore inside Pear. This helps the desktop application load faster. All state is local and by default only the original machine that stages an application can write to this application-dedicated hypercore.
Some frontend frameworks will load different assets based on whether the
NODE_ENV
environment variable is set toproduction
. If the application has this need, useNODE_ENV=production pear stage dev
in order to stage the production library code so that when Stage Warmup occurs the captured critical-path consists of production assets.
To view the help for the pear run
command run pear help run
.
The command signature for pear run
is pear run <key>
.
Copy the application key that was output when the application was staged in the prior step and pass it to pear run
. For example, if the application key was pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
the command to run would be:
pear run pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
pear run
opens the application from Pear's application storage. So far the application has remained local, in order to share it with other peers it must be seeded.
The application can be shared with other peers by announcing the application to the DHT and then supplying the application key to other peers.
To view the help for the pear seed
command run pear help seed
.
The command signature for pear seed
is pear seed <channel|key> [dir]
.
The staged application can be seeded with:
pear seed dev
The application name and channel
name are involved in generating the application key so pear seed
uses the project folder to determine the application name from the package.json
(pear.name
or else name
field). There is no need to specify dir
here as the command-line current working directory is already set to the project folder.
This will output something similar to the following
🍐 Seeding: chat [ dev ]
ctrl^c to stop & exit
-o-:-
pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
...
^_^ announced
As long as the process is running the application is being seeded. If other peers reseed the application the original process could be closed. Be sure to keep the terminal open while this process is running.
It's important that the application seeding process from the former step is up and running otherwise peers will not be able to reach connect and replicate state.
With another machine or friend that has pear
installed execute the pear run <key>
command to load the application directly peer-to-peer. So with the same example application key it would be:
pear run pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
When pear run
is executed on the peer machine there will be a security prompt to add the key to a list of trusted applications by typing 'TRUST'.
When running a terminal application using an untrusted key for the first time the prompt would be:
pear run pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
✖ Key pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o is not known
Be sure that software is trusted before running it
Type "TRUST" to allow execution or anything else to exit
Trust application?
The trust dialog is a security mechanism in Pear that appears when the user tries to run an application from an unknown or untrusted key for the first time. In case that the app is run in detached mode, for example, when clicking on a pear link in the browser, the trust dialog is a GUI (Graphical User Interface).
During development with
pear run --dev
, applications are automatically trusted, as they are assumed to be safe for testing purposes. Trust dialog can be suppressed using the--no-ask-trust
flag withpear run
in which case the application will automatically decline unknown keys.
The application has no state when it's opened for the first time, so the application may show a loader until it's ready to reveal.
The application staging machine that is running the seeding process should show output similar to:
🍐 Seeding: chat [ dev ]
ctrl^c to stop & exit
-o-:-
pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
...
^_^ announced
•-• peer join 8054f613d911b990834a0234507447c8ca88f4e778594c0e4fc480a314dc6d62
The peer join
line displays the remote public key, in hex, of the peer that executed pear run
with the application key.
Once the application is closed on the peer machine the seeding output on the original machine will be similar to:
🍐 Seeding: staging-example [ dev ]
ctrl^c to stop & exit
-o-:-
pear//:nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
...
^_^ announced
•-• peer join 8054f613d911b990834a0234507447c8ca88f4e778594c0e4fc480a314dc6d62
-_- peer drop 8054f613d911b990834a0234507447c8ca88f4e778594c0e4fc480a314dc6d62
When Pear loads an application from a peer the staged files are sparsely replicated. Assets not in the critical loading path are only downloaded from peers on-demand. If the application doesn't request an asset or module during a user-session on a given machine it does not get replicated to that machine. Pear's Application Storage can contain very large files (terabytes) that can be accessed by peers on demand. It also makes sense to structure applications so that very large files are not in the critical loading path. So that means strategies such as lazy loading large payloads, avoiding autoplaying large media files and deferring non-essential scripts and styles is as effective with Pear (if not moreso) than with Internet Browsers.
The command signature for pear seed
is pear seed <channel|key> [dir]
.
If the application was staged on the machine, it will seed the appliction from the machine.
Otherwise, passing an application key to pear seed
will reseed the application from that key.
For example, given the key pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
, executing pear seed pear://nykmkrpwgadcd8m9x5khhh43j9izj123eguzqg3ygta7yn1s379o
on a peer that didn't originally stage that particular application will result in that process syncing up-to-date data from peers and providing it to peers who need it.
Once an application is being reseeded, the original seeding process can be closed on the staging machine. However any newly staged changes have to be seeded from that machine for reseeders to pick them up. Which means pear seed
can be used "deploy" to reseeders by starting after staging, leaving it running until reseeders have synced and then stopping the process again.