Skip to main content

A packager for Tasmota Berry Application (TAPP) apps

Project description

tappack: Tasmota Application Packager

This tool aims to simplify packaging Tasmota Berry code as a TAPP file, including basic dependency resolution. It can be run locally, but is primarily intended for use during a release workflow, e.g. GitHub Actions.

What Does It Do?

It performs the following:

  • Reads your project manifest file (see below), with a list of dependency URLs (other .tapp files).
  • Downloads each, extracts and merges them, in a subfolder, it into your own code.
  • Auto-generates an autoexec.be for your library that sets up all the relevant dependency paths.
  • Packages the whole structure into a .tapp file ready for deployment.

Manifest File

Your project needs to contain a tappack manifest file, manifest.yaml, with at least fields name and dependencies. The latter is a mapping of module names to URLs of corresponding .tapp file. For example:

name: my_library
dependencies:
  my_tools: https://example.com/my_tools.tapp

You can also specify when a dependency should be read from a local path (which will be recursed automatically) as follows:

name: my_library
dependencies:
  my_dependency:
    .type: LocalPath
    path: /usr/src/my_dependency

You can also specify GitHub Release assets:

name: my_library
dependencies:
  tools:
    .type: GitHubReleaseAsset
    org: fmtr
    version: v0.0.9 # Omit this field for the latest version.
    repo: tools.be
    filename: tools.tapp

Release channels are also supported. So pulling from a URL during normal packaging, but from a local path during a development build (i.e. with parameter --channel-id development), is done like this:

name: my_library
dependencies:
  tools:
    .type: URL
    url: https://github.com/fmtr/tools/releases/download/v0.0.1/tools.tapp
    .channels:
      development:
        .type: LocalPath
        path: /fm/tools.be/module

Example Usage

$ tappack --help
Usage: tappack [OPTIONS]

Options:
  --module-path DIRECTORY  Path to your module, containing any Berry files,
                           manifests, assets, etc. Example:
                           /usr/src/my_berry_project  [required]
  --output FILE            Path to write the output .tapp package. Example:
                           ~/my_project.tapp
  --channel-id TEXT        Identifier for the release channel. Only relevant
                           if your manifests contain release channel
                           information. Example: development
  --help                   Show this message and exit.
$tappack --module-path /usr/src/my_berry_project --tapp-path ~/my_project.tapp

Installing

$pip install tappack

No autoexec.be

Your module should not contain an autoexec.be, as tappack will generate one. If you need to run any code in the autoexec context, then ensure your module implements an autoexec method, which will be called once it is imported. For example:

var mod = module("my_module")

def autoexec()

    # Do autoexec stuff here.

end

mod.autoexec=autoexec
return mod

Running as a Server

tappack can also be run as a development server. This aims to simplify Tasmota Berry script development by doing two things:

  • Starts a web app that automatically packages your project(s), and serves them as a .tapp files.
  • Opens a tunnel to the web app, letting you deploy your Tasmota Application to any device with an internet connection.

How to Install

pip install tappack[server]

Example Usage

To serve a project:

$tappack-server --project /usr/src/my_project

You can serve as many projects as you like, for example:

$tappack-server --project /usr/src/project_a --project /usr/src/project_b ...

If you want to give a project a name other than its directory name, you can prefix its path with :, e.g.

$tappack-server --project project_c:/usr/src/project_c/berry_files ...

This will serve the contents of berry_files as a TAPP file called project_c.tapp.

Sample Output

Waiting for tunnel to initialise...
 * Serving Flask app 'TappServer'
 * Debug mode: off
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
 * Running on http://127.0.0.1:80
Press CTRL+C to quit
Serving project "project_a": `tasmota.urlfetch("http://c141-x-y-z-w.ngrok.io/project_a.tapp")`
Serving project "project_b": `tasmota.urlfetch("http://c141-x-y-z-w.ngrok.io/project_b.tapp")`

:warning: Security Warning

Running tappack-server involves opening up your project files to the public internet, using a development server. Proceed with caution.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tappack-0.3.2.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

tappack-0.3.2-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file tappack-0.3.2.tar.gz.

File metadata

  • Download URL: tappack-0.3.2.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.12

File hashes

Hashes for tappack-0.3.2.tar.gz
Algorithm Hash digest
SHA256 0ca5ecb7d7b6709dead8550fcc3943bae8c342e2a8853974e36826437fd3df67
MD5 3133abbc86e1039135adaa5268fb607f
BLAKE2b-256 e67f7290014b1b6aa8b67b08e1895feb9b44a702029dd5a979752753a90f295c

See more details on using hashes here.

File details

Details for the file tappack-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: tappack-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.12

File hashes

Hashes for tappack-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ff6e1462f4d9c8e1e0c33b73408153c921c98f21189d07b62a9e9d4023a17cd4
MD5 befd3b0e7eb5f9afcc4922db2b76cf74
BLAKE2b-256 ed3fe95393f38a8ba0420f2ab3f58057e9ae12db98003a450e317d91f3d9678c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page