Skip to main content

SciTeX App SDK — write-once interface for local + cloud apps

Project description

SciTeX App (scitex-app)

SciTeX

Write-once interface for local + cloud SciTeX apps

PyPI version Documentation Tests License: AGPL-3.0

Full Documentation · pip install scitex-app


Problem

SciTeX apps (like FigRecipe, Writer, Stats) need to work in three environments: standalone local (pip install), cloud (scitex.ai), and self-hosted. Today, each environment requires different file I/O code — pathlib locally, HTTP REST calls on cloud. This means maintaining two codebases or tightly coupling apps to one deployment mode.

Solution

SciTeX App provides a unified file storage SDK with a single FilesBackend protocol. Apps call get_files() and get back a backend that works identically regardless of environment. Write your app once — it runs everywhere.

Environment Backend How it works
Local FileSystemBackend pathlib-based, zero dependencies
Cloud CloudFilesBackend HTTP REST via SCITEX_API_TOKEN (injected at runtime)
Custom register_backend() S3, GCS, or any storage you need

Table 1. Three deployment modes. The SDK auto-detects cloud when SCITEX_API_TOKEN is set; otherwise defaults to local filesystem.

Seven Operations

Every backend implements the same 7-method protocol:

Method Description
read(path) Read file content (text or binary)
write(path, content) Write content, creating parent dirs
list(directory) List files with optional extension filter
exists(path) Check if a file exists
delete(path) Delete a file
rename(old, new) Rename/move a file
copy(src, dest) Copy a file

Table 2. The FilesBackend protocol. Uses typing.Protocol for structural subtyping — backends just implement the methods, no inheritance required.

Installation

Requires Python >= 3.10. Zero dependencies — pure stdlib.

pip install scitex-app

SciTeX users: pip install scitex already includes App SDK. Access via scitex.app.

Quickstart

from scitex_app.sdk import get_files

# Local filesystem (default)
files = get_files("./my_project")
content = files.read("config/settings.yaml")
files.write("output/result.csv", csv_text)

# List files with filter
yaml_files = files.list("config", extensions=[".yaml"])

# Cloud mode (auto-detected via SCITEX_API_TOKEN)
import os
os.environ["SCITEX_API_TOKEN"] = "your-token"
cloud_files = get_files()  # routes through cloud REST API

Three Interfaces

Python API
from scitex_app.sdk import get_files, register_backend, FilesBackend

files = get_files("./project")        # auto-detect backend
files.read("data.csv")                # read file
files.write("out.txt", "hello")       # write file
files.list(extensions=[".yaml"])       # list with filter
files.exists("config.yaml")           # check existence
files.delete("temp.txt")              # delete file
files.rename("old.txt", "new.txt")    # rename/move
files.copy("src.txt", "dst.txt")      # copy file

Full API reference

CLI Commands
scitex-app --help-recursive              # Show all commands
scitex-app read <path>                   # Read a file
scitex-app write <path> "content"        # Write to a file
scitex-app list [directory]              # List files
scitex-app exists <path>                 # Check existence
scitex-app delete <path>                 # Delete a file
scitex-app rename <old> <new>            # Rename/move a file
scitex-app copy <src> <dest>             # Copy a file
scitex-app list-python-apis              # List Python API tree
scitex-app mcp list-tools                # List MCP tools

All file commands support --json output. Destructive commands support --dry-run.

Full CLI reference

MCP Server — for AI Agents

AI agents can read, write, and manage files through the unified SDK.

Tool Description
app_read_file Read a file through the SDK backend
app_write_file Write content to a file
app_list_files List files in a directory
app_file_exists Check if a file exists
app_delete_file Delete a file
app_copy_file Copy a file
app_rename_file Rename/move a file

Table 3. Seven MCP tools mirroring the FilesBackend protocol. All tools accept JSON parameters and return JSON results.

scitex-app mcp start

Full MCP specification

App Development CLI

Create, validate, and publish SciTeX apps — no platform installation required.

# Scaffold a new app
scitex-app app init . --name my_cool_app

# Validate before submission
scitex-app app validate .

# Dev-install on your SciTeX Cloud server
scitex-app app dev-install . --server http://127.0.0.1:8000

# Submit for public review
scitex-app app submit .

Also available via the main CLI: scitex app init, scitex app validate, etc.

Role in SciTeX Ecosystem

scitex-app is the complete toolkit for app developers — runtime SDK + development CLI. It provides backend-agnostic interfaces that let apps work locally, on the cloud, or self-hosted without code changes.

scitex (orchestrator, core compute, CLI, MCP)
  |-- scitex-app (this package) -- app SDK + development CLI
  |     |-- appmaker            -- scaffold, validate, publish
  |     |-- ScitexAppConfig     -- Django base class for app integration
  |     |-- AppValidator        -- security/privilege checking
  |     |-- FilesBackend        -- unified file I/O protocol
  |     |-- paths               -- project path resolution
  |     +-- chat                -- AI backend interface
  |-- scitex-ui                 -- React/TS component library
  +-- figrecipe                 -- reference app (figures)

What this package owns:

  • App scaffolding, validation, and submission (scitex-app app init/validate/submit)
  • Dev-install workflow (scitex-app app dev-install)
  • FilesBackend protocol and implementations (filesystem, cloud, custom)
  • ScitexAppConfig Django base class (from scitex_app._django import ScitexAppConfig)
  • AppValidator for security and privilege checking
  • Path resolution utilities for project/workspace discovery

What this package does NOT own:

Part of SciTeX

App SDK is part of SciTeX. When used inside the SciTeX framework, the SDK is available via scitex.app:

import scitex

# Access files through the unified SDK
files = scitex.app.get_files("./project")
content = files.read("recipes/scatter.yaml")
files.write("output/figure.png", png_bytes)

Apps built with scitex-app work in all three modes:

  • Standalone: pip install figrecipe runs locally with filesystem backend
  • Cloud: Deploy to scitex.ai — cloud backend injected automatically
  • Self-hosted: Run your own instance with custom backends

The SciTeX system follows the Four Freedoms for Research below, inspired by the Free Software Definition:

Four Freedoms for Research

  1. The freedom to run your research anywhere — your machine, your terms.
  2. The freedom to study how every step works — from raw data to final manuscript.
  3. The freedom to redistribute your workflows, not just your papers.
  4. The freedom to modify any module and share improvements with the community.

AGPL-3.0 — because we believe research infrastructure deserves the same freedoms as the software it runs on.


SciTeX

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

scitex_app-0.2.4.tar.gz (105.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scitex_app-0.2.4-py3-none-any.whl (108.0 kB view details)

Uploaded Python 3

File details

Details for the file scitex_app-0.2.4.tar.gz.

File metadata

  • Download URL: scitex_app-0.2.4.tar.gz
  • Upload date:
  • Size: 105.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scitex_app-0.2.4.tar.gz
Algorithm Hash digest
SHA256 2574cd7390e91786b8ce07e3ffdec37cf3f153ef6c17b47fbb4a512c3413c93d
MD5 7177f60605c9b31b6007bdf6f6698d14
BLAKE2b-256 780d501689a728adaffe208b268fb35102801a72caacc96a2d17467aa0b1b6e9

See more details on using hashes here.

Provenance

The following attestation bundles were made for scitex_app-0.2.4.tar.gz:

Publisher: publish-pypi.yml on ywatanabe1989/scitex-app

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file scitex_app-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: scitex_app-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 108.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scitex_app-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 669e7be506504b4279e1f3a132ae0cbcd419c913b0f46567d9f7ce50f13451b1
MD5 1ba02ffee5c933b90e14958679018ebe
BLAKE2b-256 5c525fe6b1a149bb300df4504b1d2b344f2d85eccf25c2f12a4dcf9d498c5c4c

See more details on using hashes here.

Provenance

The following attestation bundles were made for scitex_app-0.2.4-py3-none-any.whl:

Publisher: publish-pypi.yml on ywatanabe1989/scitex-app

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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