Skip to main content

Module for generating Baseline packages for deployment

Project description

Baseline Builder

Python-based tooling for generating Baseline packages, for streamlining package building of multiple clients. Designed for easier CI/CD integration with Python 3.


Features implemented:

  • Resolves local files such as scripts, packages and images to Baseline packaging
    • Scans in same directory as invocation script
  • Calculates MD5 for scripts and packages
  • Determines Team ID for local packages
  • Easy imports for chaining into larger CI/CD workflows
  • Validates existing packages

Logic

Baseline Builder works by taking configuration files for Baseline, and generating a package for deployment. If scripts, packages or images are declared in the file, Baseline Builder will attempt to resolve them and embed inside the package.

  • See Baseline's documentation on how to configure: Baseline Wiki
  • If an mobileconfig is provided as input, a resolved version will be written next to the package.
    • As the mobileconfig method is meant to be used, no BaselineConfig.plist is embedded in the package.

Example configuration can be found in the Samples directory. Below is pulled from RIPEDA Engineering configuration:

<key>Packages</key>
<array>
  <dict>
    <key>DisplayName</key>
    <string>Printer</string>
    <key>PackagePath</key>
    <string>Assets/Packages/Printer.pkg</string>
    <key>Icon</key>
    <string>Assets/Icons/Printer.png</string>
  </dict>
</array>

The project will attempt to resolve the PackagePath and Icon keys through scanning the local directory:

Baseline Builder Directory:
- client.plist
- Assets:
  - Packages:
    - Printer.pkg
  - Icons:
    - Printer.png

Installation

pip3 install baseline-builder

Usage

Building

import baseline

baseline_obj = baseline.BaselineBuilder(
                    configuration_file="ripeda.plist",
                    identifier="com.ripeda.baseline.engineering",
                    version="1.0.0",
                    output="RIPEDA Baseline.pkg"
                )

baseline_obj.build()

print("Package built successfully")

After a build is complete, optional .validate_pkg() can be invoked to decompress and validate the package contents automatically.

Validating existing packages via command line

For quick validation of existing packages, the -v/--validate flag can be used to decompress and validate the package contents automatically. If the package lacks a BaselineConfig.plist, a mobileconfig can be provided to validate against.

# Validate package with mobileconfig
python3 baseline.py --validate "RIPEDA.pkg" ripeda.mobileconfig

# Validate package without config (embedded in pkg)
python3 baseline.py --validate "RIPEDA.pkg"
# Example Output
$ python3 baseline.py --validate RIPEDA.pkg

Performing post-build validation...
Validating configuration file...
    Validating Icon: Zoom.icns...
    Validating Installomator label: zoom...
    Validating Icon: Chrome.icns...
    Validating Installomator label: googlechromepkg...
    Validating PackagePath: Printer.pkg...
    Calculating MD5 for: Printer.pkg...
    Determining Team ID for: Printer.pkg...
    Validating Icon: Scripts-Printer.png...
    Validating ScriptPath: universal_remove_stock_apps.sh...
    Calculating MD5 for: universal_remove_stock_apps.sh...
    Validating Icon: Scripts-Stock-Apps.png...
    Validating ScriptPath: universal_dock.sh...
    Calculating MD5 for: universal_dock.sh...
    Validating Icon: Scripts-Dock.png...
Configuration file is valid.
Post-build validation complete.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

baseline_builder-1.5.0-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file baseline_builder-1.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for baseline_builder-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6f4dc04814693d28cec7f6c3f2a7011da69e8cf3865fe0de9bd71002536c0f89
MD5 9f43b1094fa506b39a59f1bafa68f686
BLAKE2b-256 83194fe014fe64f75761d4b375ecee29ed677e372e2e28b74d5ca3bc16ff0fc7

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