diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..628b48d3 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,129 @@ +# Dependencies +node_modules +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# Build outputs +dist +build +.next +.nuxt + +# Development files +.env.local +.env.development.local +.env.test.local +.env.production.local + +# IDE and editor files +.vscode +.idea +*.swp +*.swo +*~ + +# OS generated files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Git +.git +.gitignore + +# Documentation +README.md +README-CN.md +CONTRIBUTING.md +LICENSE + +# Docker files (avoid copying docker files into docker) +# docker/ - commented out to allow entrypoint.sh to be copied + +# Repository images +repo-images/ + +# Uploads directory +uploads/ + +# Electron files (not needed for Docker) +electron/ +electron-builder.json + +# Development and build artifacts +*.log +*.tmp +*.temp + +# Font files (we'll optimize these in Dockerfile) +# public/fonts/*.ttf + +# Logs +logs +*.log + +# Runtime data +pids +*.pid +*.seed +*.pid.lock + +# Coverage directory used by tools like istanbul +coverage + +# nyc test coverage +.nyc_output + +# Dependency directories +jspm_packages/ + +# Optional npm cache directory +.npm + +# Optional eslint cache +.eslintcache + +# Microbundle cache +.rpt2_cache/ +.rts2_cache_cjs/ +.rts2_cache_es/ +.rts2_cache_umd/ + +# Optional REPL history +.node_repl_history + +# Output of 'npm pack' +*.tgz + +# Yarn Integrity file +.yarn-integrity + +# parcel-bundler cache (https://parceljs.org/) +.cache +.parcel-cache + +# next.js build output +.next + +# nuxt.js build output +.nuxt + +# vuepress build output +.vuepress/dist + +# Serverless directories +.serverless + +# FuseBox cache +.fusebox/ + +# DynamoDB Local files +.dynamodb/ + +# TernJS port file +.tern-port \ No newline at end of file diff --git a/.env b/.env deleted file mode 100644 index 6f985423..00000000 --- a/.env +++ /dev/null @@ -1,2 +0,0 @@ -VERSION=1.6.0 -VITE_API_HOST=localhost \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml index 5878ded2..39b68b66 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -18,15 +18,14 @@ body: label: Platform description: How are you using Termix? options: - - Firefox - - Safari - - Chrome - - Other Browser - - Windows - - Linux - - iOS - - Android - - Other + - Website - Firefox + - Website - Safari + - Website - Chrome + - Website - Other Browser + - App - Windows + - App - Linux + - App - iOS + - App - Android validations: required: true - type: dropdown @@ -44,7 +43,7 @@ body: attributes: label: Version description: Find your version in the User Profile tab - placeholder: "e.g., 1.6.0" + placeholder: "e.g., 1.7.0" validations: required: true - type: checkboxes @@ -72,7 +71,7 @@ body: placeholder: | 1. 2. - 3. + 3. validations: required: true - type: textarea diff --git a/.github/workflows/docker-image.yml b/.github/workflows/docker-image.yml index 69c6169f..0dc20d05 100644 --- a/.github/workflows/docker-image.yml +++ b/.github/workflows/docker-image.yml @@ -77,7 +77,7 @@ jobs: run: | REPO_OWNER=$(echo ${{ github.repository_owner }} | tr '[:upper:]' '[:lower:]') echo "REPO_OWNER=$REPO_OWNER" >> $GITHUB_ENV - + if [ "${{ github.event.inputs.tag_name }}" != "" ]; then IMAGE_TAG="${{ github.event.inputs.tag_name }}" elif [ "${{ github.ref }}" == "refs/heads/main" ]; then @@ -88,7 +88,7 @@ jobs: IMAGE_TAG="${{ github.ref_name }}" fi echo "IMAGE_TAG=$IMAGE_TAG" >> $GITHUB_ENV - + # Determine registry and image name if [ "${{ github.event.inputs.registry }}" == "dockerhub" ]; then echo "REGISTRY=docker.io" >> $GITHUB_ENV diff --git a/.github/workflows/electron-build.yml b/.github/workflows/electron-build.yml index 6f1bbbff..a9f5aa83 100644 --- a/.github/workflows/electron-build.yml +++ b/.github/workflows/electron-build.yml @@ -1,13 +1,6 @@ name: Build Electron App on: - push: - branches: - - development - paths-ignore: - - '**.md' - - '.gitignore' - - 'docker/**' workflow_dispatch: inputs: build_type: @@ -34,8 +27,8 @@ jobs: - name: Setup Node.js uses: actions/setup-node@v4 with: - node-version: '20' - cache: 'npm' + node-version: "20" + cache: "npm" - name: Install dependencies run: npm ci @@ -77,8 +70,8 @@ jobs: - name: Setup Node.js uses: actions/setup-node@v4 with: - node-version: '20' - cache: 'npm' + node-version: "20" + cache: "npm" - name: Install dependencies run: npm ci diff --git a/.gitignore b/.gitignore index 9066858c..a3188d42 100644 --- a/.gitignore +++ b/.gitignore @@ -25,3 +25,5 @@ dist-ssr /db/ /release/ /.claude/ +/ssl/ +.env diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index f80b65b2..eb97b305 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -9,13 +9,13 @@ ## Installation 1. Clone the repository: - ```sh - git clone https://github.com/LukeGus/Termix - ``` + ```sh + git clone https://github.com/LukeGus/Termix + ``` 2. Install the dependencies: - ```sh - npm install - ``` + ```sh + npm install + ``` ## Running the development server @@ -33,18 +33,18 @@ This will start the backend and the frontend Vite server. You can access Termix 1. **Fork the repository**: Click the "Fork" button at the top right of the [repository page](https://github.com/LukeGus/Termix). 2. **Create a new branch**: - ```sh - git checkout -b feature/my-new-feature - ``` + ```sh + git checkout -b feature/my-new-feature + ``` 3. **Make your changes**: Implement your feature, fix, or improvement. 4. **Commit your changes**: - ```sh - git commit -m "Feature request my new feature" - ``` + ```sh + git commit -m "Feature request my new feature" + ``` 5. **Push to your fork**: - ```sh - git push origin feature/my-feature-request - ``` + ```sh + git push origin feature/my-feature-request + ``` 6. **Open a pull request**: Go to the original repository and create a PR with a clear description. ## Guidelines @@ -61,7 +61,7 @@ This will start the backend and the frontend Vite server. You can access Termix ### Background Colors | CSS Variable | Color Value | Usage | Description | -|-------------------------------|-------------|-----------------------------|------------------------------------------| +| ----------------------------- | ----------- | --------------------------- | ---------------------------------------- | | `--color-dark-bg` | `#18181b` | Main dark background | Primary dark background color | | `--color-dark-bg-darker` | `#0e0e10` | Darker backgrounds | Darker variant for panels and containers | | `--color-dark-bg-darkest` | `#09090b` | Darkest backgrounds | Darkest background (terminal) | @@ -73,7 +73,7 @@ This will start the backend and the frontend Vite server. You can access Termix ### Element-Specific Backgrounds | CSS Variable | Color Value | Usage | Description | -|--------------------------|-------------|--------------------|-----------------------------------------------| +| ------------------------ | ----------- | ------------------ | --------------------------------------------- | | `--color-dark-bg-input` | `#222225` | Input fields | Background for input fields and form elements | | `--color-dark-bg-button` | `#23232a` | Button backgrounds | Background for buttons and clickable elements | | `--color-dark-bg-active` | `#1d1d1f` | Active states | Background for active/selected elements | @@ -82,7 +82,7 @@ This will start the backend and the frontend Vite server. You can access Termix ### Border Colors | CSS Variable | Color Value | Usage | Description | -|------------------------------|-------------|-----------------|------------------------------------------| +| ---------------------------- | ----------- | --------------- | ---------------------------------------- | | `--color-dark-border` | `#303032` | Default borders | Standard border color | | `--color-dark-border-active` | `#2d2d30` | Active borders | Border color for active elements | | `--color-dark-border-hover` | `#434345` | Hover borders | Border color on hover states | @@ -93,7 +93,7 @@ This will start the backend and the frontend Vite server. You can access Termix ### Interactive States | CSS Variable | Color Value | Usage | Description | -|--------------------------|-------------|-------------------|-----------------------------------------------| +| ------------------------ | ----------- | ----------------- | --------------------------------------------- | | `--color-dark-hover` | `#2d2d30` | Hover states | Background color for hover effects | | `--color-dark-active` | `#2a2a2c` | Active states | Background color for active elements | | `--color-dark-pressed` | `#1a1a1c` | Pressed states | Background color for pressed/clicked elements | diff --git a/README.md b/README.md index df9d1675..2bb87065 100644 --- a/README.md +++ b/README.md @@ -45,30 +45,39 @@ If you would like, you can support the project here!\ Termix is an open-source, forever-free, self-hosted all-in-one server management platform. It provides a web-based solution for managing your servers and infrastructure through a single, intuitive interface. Termix offers SSH terminal -access, SSH tunneling capabilities, and remote file editing, with many more tools to come. +access, SSH tunneling capabilities, remote file management, with many more tools to come. # Features - **SSH Terminal Access** - Full-featured terminal with split-screen support (up to 4 panels) and tab system - **SSH Tunnel Management** - Create and manage SSH tunnels with automatic reconnection and health monitoring -- **Remote File Editor** - Edit files directly on remote servers with syntax highlighting, file management features ( - uploading, removing, renaming, deleting files) -- **SSH Host Manager** - Save, organize, and manage your SSH connections with tags and folders +- **Remote File Manager** - Manage files directly on remote servers with support for viewing and editing code, images, audio, and video. Upload, download, rename, delete, and move files seamlessly. +- **SSH Host Manager** - Save, organize, and manage your SSH connections with tags and folders and easily save reusable login info while being able to automate the deploying of SSH keys - **Server Stats** - View CPU, memory, and HDD usage on any SSH server - **User Authentication** - Secure user management with admin controls and OIDC and 2FA (TOTP) support -- **Modern UI** - Clean desktop/mobile friendly (in progress) interface built with React, Tailwind CSS, and Shadcn +- **Database Encryption** - SQLite database files encrypted at rest with automatic encryption/decryption +- **Data Export/Import** - Export and import SSH hosts, credentials, and file manager data with incremental sync +- **Automatic SSL Setup** - Built-in SSL certificate generation and management with HTTPS redirects +- **Modern UI** - Clean desktop/mobile friendly interface built with React, Tailwind CSS, and Shadcn - **Languages** - Built-in support for English and Chinese -- **Improved Platform Support** - Now includes an installable Electron app (in progress) for desktop, with a dedicated - mobile app also planned. +- **Platform Support** - Available as a web app, desktop application (Windows & Linux), and dedicated mobile app for iOS and Android (coming in a few days) # Planned Features -See [Projects](https://github.com/users/LukeGus/projects/3). If you are looking to contribute, -see [Contributing](https://github.com/LukeGus/Termix/blob/main/CONTRIBUTING.md), +See [Projects](https://github.com/users/LukeGus/projects/3) for all planned features. If you are looking to contribute, see [Contributing](https://github.com/LukeGus/Termix/blob/main/CONTRIBUTING.md). # Installation -Visit the Termix [Docs](https://docs.termix.site/install) for more information on how to install Termix. Otherwise, view +Supported Devices: + +- Website (any modern browser like Google, Safari, and Firefox) +- Windows (app) +- Linux (app) +- iOS (coming in a few days) +- Android (coming in a few days) +- iPadOS and macOS are in progress + +Visit the Termix [Docs](https://docs.termix.site/install) for more information on how to install Termix on all platforms. Otherwise, view a sample docker-compose file here: ```yaml @@ -89,10 +98,6 @@ volumes: driver: local ``` -Pre-built binaries are now available for download, including a Windows installer/portable app and a Linux portable app ( -built with Electron). See [Docs](https://docs.termix.site/install#pre-built-binaries) for details. A native iOS/Android app -is planned. - # Support If you need help with Termix, you can join the [Discord](https://discord.gg/jVQGdvHDrf) server and visit the support @@ -107,13 +112,17 @@ repo.

- Termix Demo 3 - Termix Demo 4 - Termix Demo 5 + Termix Demo 3 + Termix Demo 4

-

+ +

+

diff --git a/docker/Dockerfile b/docker/Dockerfile index 92d774a6..8bf66283 100644 --- a/docker/Dockerfile +++ b/docker/Dockerfile @@ -1,8 +1,8 @@ -# Stage 1: Install dependencies and build frontend -FROM node:24-alpine AS deps +# Stage 1: Install dependencies +FROM node:22-slim AS deps WORKDIR /app -RUN apk add --no-cache python3 make g++ +RUN apt-get update && apt-get install -y python3 make g++ && rm -rf /var/lib/apt/lists/* COPY package*.json ./ @@ -10,7 +10,8 @@ ENV npm_config_target_platform=linux ENV npm_config_target_arch=x64 ENV npm_config_target_libc=glibc -RUN npm ci --force --ignore-scripts && \ +RUN rm -rf node_modules package-lock.json && \ + npm install --force && \ npm cache clean --force # Stage 2: Build frontend @@ -19,9 +20,12 @@ WORKDIR /app COPY . . -RUN npm run build +RUN find public/fonts -name "*.ttf" ! -name "*Regular.ttf" ! -name "*Bold.ttf" ! -name "*Italic.ttf" -delete -# Stage 3: Build backend TypeScript +RUN npm cache clean --force && \ + npm run build + +# Stage 3: Build backend FROM deps AS backend-builder WORKDIR /app @@ -35,10 +39,12 @@ RUN npm rebuild better-sqlite3 --force RUN npm run build:backend -# Stage 4: Production dependencies -FROM node:24-alpine AS production-deps +# Stage 4: Production dependencies only +FROM node:22-slim AS production-deps WORKDIR /app +RUN apt-get update && apt-get install -y python3 make g++ && rm -rf /var/lib/apt/lists/* + COPY package*.json ./ ENV npm_config_target_platform=linux @@ -46,53 +52,38 @@ ENV npm_config_target_arch=x64 ENV npm_config_target_libc=glibc RUN npm ci --only=production --ignore-scripts --force && \ - npm cache clean --force - -# Stage 5: Build native modules -FROM node:24-alpine AS native-builder -WORKDIR /app - -RUN apk add --no-cache python3 make g++ - -COPY package*.json ./ - -ENV npm_config_target_platform=linux -ENV npm_config_target_arch=x64 -ENV npm_config_target_libc=glibc - -# Install native modules and compile them properly -RUN npm ci --only=production --force && \ npm rebuild better-sqlite3 bcryptjs --force && \ npm cache clean --force -# Stage 6: Final image -FROM node:24-alpine +# Stage 5: Final optimized image +FROM node:22-slim +WORKDIR /app + ENV DATA_DIR=/app/data \ PORT=8080 \ NODE_ENV=production -RUN apk add --no-cache nginx gettext su-exec && \ - mkdir -p /app/data && \ - chown -R node:node /app/data +RUN apt-get update && apt-get install -y nginx gettext-base openssl && \ + rm -rf /var/lib/apt/lists/* && \ + mkdir -p /app/data /app/uploads && \ + chown -R node:node /app/data /app/uploads && \ + useradd -r -s /bin/false nginx COPY docker/nginx.conf /etc/nginx/nginx.conf -COPY --from=frontend-builder /app/dist /usr/share/nginx/html -COPY --from=frontend-builder /app/src/locales /usr/share/nginx/html/locales -RUN chown -R nginx:nginx /usr/share/nginx/html +COPY docker/nginx-https.conf /etc/nginx/nginx-https.conf -WORKDIR /app +COPY --chown=nginx:nginx --from=frontend-builder /app/dist /usr/share/nginx/html +COPY --chown=nginx:nginx --from=frontend-builder /app/src/locales /usr/share/nginx/html/locales +COPY --chown=nginx:nginx --from=frontend-builder /app/public/fonts /usr/share/nginx/html/fonts -COPY --from=native-builder /app/node_modules /app/node_modules -COPY --from=backend-builder /app/dist/backend ./dist/backend - -COPY package.json ./ -COPY .env ./.env -RUN chown -R node:node /app +COPY --chown=node:node --from=production-deps /app/node_modules /app/node_modules +COPY --chown=node:node --from=backend-builder /app/dist/backend ./dist/backend +COPY --chown=node:node package.json ./ VOLUME ["/app/data"] -EXPOSE ${PORT} 8081 8082 8083 8084 8085 +EXPOSE ${PORT} 30001 30002 30003 30004 30005 COPY docker/entrypoint.sh /entrypoint.sh RUN chmod +x /entrypoint.sh -CMD ["/entrypoint.sh"] +CMD ["/entrypoint.sh"] \ No newline at end of file diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml deleted file mode 100644 index 5e7ec7e9..00000000 --- a/docker/docker-compose.yml +++ /dev/null @@ -1,15 +0,0 @@ -services: - termix: - image: ghcr.io/lukegus/termix:latest - container_name: termix - restart: unless-stopped - ports: - - "8080:8080" - volumes: - - termix-data:/app/data - environment: - PORT: "8080" - -volumes: - termix-data: - driver: local diff --git a/docker/entrypoint.sh b/docker/entrypoint.sh index a45affd0..67d389c2 100644 --- a/docker/entrypoint.sh +++ b/docker/entrypoint.sh @@ -2,14 +2,95 @@ set -e export PORT=${PORT:-8080} +export ENABLE_SSL=${ENABLE_SSL:-false} +export SSL_PORT=${SSL_PORT:-8443} +export SSL_CERT_PATH=${SSL_CERT_PATH:-/app/data/ssl/termix.crt} +export SSL_KEY_PATH=${SSL_KEY_PATH:-/app/data/ssl/termix.key} + echo "Configuring web UI to run on port: $PORT" -envsubst '${PORT}' < /etc/nginx/nginx.conf > /etc/nginx/nginx.conf.tmp +if [ "$ENABLE_SSL" = "true" ]; then + echo "SSL enabled - using HTTPS configuration with redirect" + NGINX_CONF_SOURCE="/etc/nginx/nginx-https.conf" +else + echo "SSL disabled - using HTTP-only configuration (default)" + NGINX_CONF_SOURCE="/etc/nginx/nginx.conf" +fi + +envsubst '${PORT} ${SSL_PORT} ${SSL_CERT_PATH} ${SSL_KEY_PATH}' < $NGINX_CONF_SOURCE > /etc/nginx/nginx.conf.tmp mv /etc/nginx/nginx.conf.tmp /etc/nginx/nginx.conf -mkdir -p /app/data -chown -R node:node /app/data -chmod 755 /app/data +mkdir -p /app/data /app/uploads +chown -R node:node /app/data /app/uploads +chmod 755 /app/data /app/uploads + +if [ "$ENABLE_SSL" = "true" ]; then + echo "Checking SSL certificate configuration..." + mkdir -p /app/data/ssl + chown -R node:node /app/data/ssl + chmod 755 /app/data/ssl + + DOMAIN=${SSL_DOMAIN:-localhost} + + if [ -f "/app/data/ssl/termix.crt" ] && [ -f "/app/data/ssl/termix.key" ]; then + echo "SSL certificates found, checking validity..." + + if openssl x509 -in /app/data/ssl/termix.crt -checkend 2592000 -noout >/dev/null 2>&1; then + echo "SSL certificates are valid and will be reused for domain: $DOMAIN" + else + echo "SSL certificate is expired or expiring soon, regenerating..." + rm -f /app/data/ssl/termix.crt /app/data/ssl/termix.key + fi + else + echo "SSL certificates not found, will generate new ones..." + fi + + if [ ! -f "/app/data/ssl/termix.crt" ] || [ ! -f "/app/data/ssl/termix.key" ]; then + echo "Generating SSL certificates for domain: $DOMAIN" + + cat > /app/data/ssl/openssl.conf << EOF +[req] +default_bits = 2048 +prompt = no +default_md = sha256 +distinguished_name = dn +req_extensions = v3_req + +[dn] +C=US +ST=State +L=City +O=Termix +OU=IT Department +CN=$DOMAIN + +[v3_req] +basicConstraints = CA:FALSE +keyUsage = nonRepudiation, digitalSignature, keyEncipherment +subjectAltName = @alt_names + +[alt_names] +DNS.1 = $DOMAIN +DNS.2 = localhost +DNS.3 = 127.0.0.1 +IP.1 = 127.0.0.1 +IP.2 = ::1 +IP.3 = 0.0.0.0 +EOF + + openssl genrsa -out /app/data/ssl/termix.key 2048 + + openssl req -new -x509 -key /app/data/ssl/termix.key -out /app/data/ssl/termix.crt -days 365 -config /app/data/ssl/openssl.conf -extensions v3_req + + chmod 600 /app/data/ssl/termix.key + chmod 644 /app/data/ssl/termix.crt + chown node:node /app/data/ssl/termix.key /app/data/ssl/termix.crt + + rm -f /app/data/ssl/openssl.conf + + echo "SSL certificates generated successfully for domain: $DOMAIN" + fi +fi echo "Starting nginx..." nginx @@ -18,6 +99,17 @@ echo "Starting backend services..." cd /app export NODE_ENV=production +if [ -f "package.json" ]; then + VERSION=$(grep '"version"' package.json | sed 's/.*"version": *"\([^"]*\)".*/\1/') + if [ -n "$VERSION" ]; then + export VERSION + else + echo "Warning: Could not extract version from package.json" + fi +else + echo "Warning: package.json not found" +fi + if command -v su-exec > /dev/null 2>&1; then su-exec node node dist/backend/backend/starter.js else diff --git a/docker/nginx-https.conf b/docker/nginx-https.conf new file mode 100644 index 00000000..c2f90f35 --- /dev/null +++ b/docker/nginx-https.conf @@ -0,0 +1,266 @@ +events { + worker_connections 1024; +} + +http { + include mime.types; + default_type application/octet-stream; + + sendfile on; + keepalive_timeout 65; + client_header_timeout 300s; + + ssl_protocols TLSv1.2 TLSv1.3; + ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384; + ssl_prefer_server_ciphers off; + ssl_session_cache shared:SSL:10m; + ssl_session_timeout 10m; + + server { + listen ${PORT}; + server_name _; + + return 301 https://$host:${SSL_PORT}$request_uri; + } + + # HTTPS Server + server { + listen ${SSL_PORT} ssl; + server_name _; + + ssl_certificate ${SSL_CERT_PATH}; + ssl_certificate_key ${SSL_KEY_PATH}; + + add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always; + add_header X-Frame-Options DENY always; + add_header X-Content-Type-Options nosniff always; + add_header X-XSS-Protection "1; mode=block" always; + + location / { + root /usr/share/nginx/html; + index index.html index.htm; + } + + # Handle missing source map files gracefully + location ~* \.map$ { + return 404; + access_log off; + log_not_found off; + } + + location ~ ^/users(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/version(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/releases(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/alerts(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/credentials(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + } + + location ~ ^/database(/.*)?$ { + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; + } + + location ~ ^/db(/.*)?$ { + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; + } + + location ~ ^/encryption(/.*)?$ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/ { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/websocket/ { + proxy_pass http://127.0.0.1:30002/; + proxy_http_version 1.1; + + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "upgrade"; + proxy_set_header Host $host; + proxy_cache_bypass $http_upgrade; + + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_read_timeout 86400s; + proxy_send_timeout 86400s; + proxy_connect_timeout 10s; + + proxy_buffering off; + proxy_request_buffering off; + + proxy_next_upstream error timeout invalid_header http_500 http_502 http_503; + } + + location /ssh/tunnel/ { + proxy_pass http://127.0.0.1:30003; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/file_manager/recent { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/file_manager/pinned { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/file_manager/shortcuts { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /ssh/file_manager/ssh/ { + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30004; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; + } + + location /health { + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/status(/.*)?$ { + proxy_pass http://127.0.0.1:30005; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location ~ ^/metrics(/.*)?$ { + proxy_pass http://127.0.0.1:30005; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + error_page 500 502 503 504 /50x.html; + location = /50x.html { + root /usr/share/nginx/html; + } + } +} \ No newline at end of file diff --git a/docker/nginx.conf b/docker/nginx.conf index 2a943a46..b78418b7 100644 --- a/docker/nginx.conf +++ b/docker/nginx.conf @@ -8,18 +8,36 @@ http { sendfile on; keepalive_timeout 65; + client_header_timeout 300s; + + ssl_protocols TLSv1.2 TLSv1.3; + ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384; + ssl_prefer_server_ciphers off; + ssl_session_cache shared:SSL:10m; + ssl_session_timeout 10m; server { listen ${PORT}; server_name localhost; + add_header X-Frame-Options DENY always; + add_header X-Content-Type-Options nosniff always; + add_header X-XSS-Protection "1; mode=block" always; + location / { root /usr/share/nginx/html; index index.html index.htm; } + # Handle missing source map files gracefully + location ~* \.map$ { + return 404; + access_log off; + log_not_found off; + } + location ~ ^/users(/.*)?$ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -28,7 +46,7 @@ http { } location ~ ^/version(/.*)?$ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -37,7 +55,7 @@ http { } location ~ ^/releases(/.*)?$ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -46,7 +64,7 @@ http { } location ~ ^/alerts(/.*)?$ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -55,7 +73,58 @@ http { } location ~ ^/credentials(/.*)?$ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + } + + location ~ ^/database(/.*)?$ { + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; + } + + location ~ ^/db(/.*)?$ { + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30001; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; + } + + location ~ ^/encryption(/.*)?$ { + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -64,7 +133,7 @@ http { } location /ssh/ { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -73,28 +142,30 @@ http { } location /ssh/websocket/ { - proxy_pass http://127.0.0.1:8082/; + proxy_pass http://127.0.0.1:30002/; proxy_http_version 1.1; + proxy_set_header Upgrade $http_upgrade; - proxy_set_header Connection "Upgrade"; + proxy_set_header Connection "upgrade"; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade; - proxy_read_timeout 300s; - proxy_send_timeout 300s; - proxy_connect_timeout 75s; - proxy_set_header Connection ""; - - proxy_buffering off; - proxy_request_buffering off; - proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; + + proxy_read_timeout 86400s; + proxy_send_timeout 86400s; + proxy_connect_timeout 10s; + + proxy_buffering off; + proxy_request_buffering off; + + proxy_next_upstream error timeout invalid_header http_500 http_502 http_503; } location /ssh/tunnel/ { - proxy_pass http://127.0.0.1:8083; + proxy_pass http://127.0.0.1:30003; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -103,7 +174,7 @@ http { } location /ssh/file_manager/recent { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -112,7 +183,7 @@ http { } location /ssh/file_manager/pinned { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -121,7 +192,7 @@ http { } location /ssh/file_manager/shortcuts { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -130,16 +201,26 @@ http { } location /ssh/file_manager/ssh/ { - proxy_pass http://127.0.0.1:8084; + client_max_body_size 5G; + client_body_timeout 300s; + + proxy_pass http://127.0.0.1:30004; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; + + proxy_connect_timeout 60s; + proxy_send_timeout 300s; + proxy_read_timeout 300s; + + proxy_request_buffering off; + proxy_buffering off; } location /health { - proxy_pass http://127.0.0.1:8081; + proxy_pass http://127.0.0.1:30001; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -148,7 +229,7 @@ http { } location ~ ^/status(/.*)?$ { - proxy_pass http://127.0.0.1:8085; + proxy_pass http://127.0.0.1:30005; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; @@ -157,7 +238,7 @@ http { } location ~ ^/metrics(/.*)?$ { - proxy_pass http://127.0.0.1:8085; + proxy_pass http://127.0.0.1:30005; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; diff --git a/electron/main.cjs b/electron/main.cjs index 7c42cdf5..7a7ba5bc 100644 --- a/electron/main.cjs +++ b/electron/main.cjs @@ -1,6 +1,12 @@ -const { app, BrowserWindow, shell, ipcMain } = require("electron"); +const { app, BrowserWindow, shell, ipcMain, dialog } = require("electron"); const path = require("path"); const fs = require("fs"); +const os = require("os"); + +app.commandLine.appendSwitch("--ignore-certificate-errors"); +app.commandLine.appendSwitch("--ignore-ssl-errors"); +app.commandLine.appendSwitch("--ignore-certificate-errors-spki-list"); +app.commandLine.appendSwitch("--enable-features=NetworkService"); let mainWindow = null; @@ -13,7 +19,6 @@ if (!gotTheLock) { process.exit(0); } else { app.on("second-instance", (event, commandLine, workingDirectory) => { - console.log("Second instance detected, focusing existing window..."); if (mainWindow) { if (mainWindow.isMinimized()) mainWindow.restore(); mainWindow.focus(); @@ -35,7 +40,7 @@ function createWindow() { webPreferences: { nodeIntegration: false, contextIsolation: true, - webSecurity: !isDev, + webSecurity: true, preload: path.join(__dirname, "preload.js"), }, show: false, @@ -50,12 +55,10 @@ function createWindow() { mainWindow.webContents.openDevTools(); } else { const indexPath = path.join(__dirname, "..", "dist", "index.html"); - console.log("Loading frontend from:", indexPath); mainWindow.loadFile(indexPath); } mainWindow.once("ready-to-show", () => { - console.log("Window ready to show"); mainWindow.show(); }); @@ -96,6 +99,163 @@ ipcMain.handle("get-app-version", () => { return app.getVersion(); }); +const GITHUB_API_BASE = "https://api.github.com"; +const REPO_OWNER = "LukeGus"; +const REPO_NAME = "Termix"; + +const githubCache = new Map(); +const CACHE_DURATION = 30 * 60 * 1000; // 30 minutes + +async function fetchGitHubAPI(endpoint, cacheKey) { + const cached = githubCache.get(cacheKey); + if (cached && Date.now() - cached.timestamp < CACHE_DURATION) { + return { + data: cached.data, + cached: true, + cache_age: Date.now() - cached.timestamp, + }; + } + + try { + let fetch; + try { + fetch = globalThis.fetch || require("node-fetch"); + } catch (e) { + const https = require("https"); + const http = require("http"); + const { URL } = require("url"); + + fetch = (url, options = {}) => { + return new Promise((resolve, reject) => { + const urlObj = new URL(url); + const isHttps = urlObj.protocol === "https:"; + const client = isHttps ? https : http; + + const requestOptions = { + method: options.method || "GET", + headers: options.headers || {}, + timeout: options.timeout || 10000, + }; + + if (isHttps) { + requestOptions.rejectUnauthorized = false; + requestOptions.agent = new https.Agent({ + rejectUnauthorized: false, + secureProtocol: "TLSv1_2_method", + checkServerIdentity: () => undefined, + ciphers: "ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH", + honorCipherOrder: true, + }); + } + + const req = client.request(url, requestOptions, (res) => { + let data = ""; + res.on("data", (chunk) => (data += chunk)); + res.on("end", () => { + resolve({ + ok: res.statusCode >= 200 && res.statusCode < 300, + status: res.statusCode, + text: () => Promise.resolve(data), + json: () => Promise.resolve(JSON.parse(data)), + }); + }); + }); + + req.on("error", reject); + req.on("timeout", () => { + req.destroy(); + reject(new Error("Request timeout")); + }); + + if (options.body) { + req.write(options.body); + } + req.end(); + }); + }; + } + + const response = await fetch(`${GITHUB_API_BASE}${endpoint}`, { + headers: { + Accept: "application/vnd.github+json", + "User-Agent": "TermixElectronUpdateChecker/1.0", + "X-GitHub-Api-Version": "2022-11-28", + }, + timeout: 10000, + }); + + if (!response.ok) { + throw new Error( + `GitHub API error: ${response.status} ${response.statusText}`, + ); + } + + const data = await response.json(); + + githubCache.set(cacheKey, { + data, + timestamp: Date.now(), + }); + + return { + data: data, + cached: false, + }; + } catch (error) { + console.error("Failed to fetch from GitHub API:", error); + throw error; + } +} + +ipcMain.handle("check-electron-update", async () => { + try { + const localVersion = app.getVersion(); + + const releaseData = await fetchGitHubAPI( + `/repos/${REPO_OWNER}/${REPO_NAME}/releases/latest`, + "latest_release_electron", + ); + + const rawTag = releaseData.data.tag_name || releaseData.data.name || ""; + const remoteVersionMatch = rawTag.match(/(\d+\.\d+(\.\d+)?)/); + const remoteVersion = remoteVersionMatch ? remoteVersionMatch[1] : null; + + if (!remoteVersion) { + return { + success: false, + error: "Remote version not found", + localVersion, + }; + } + + const isUpToDate = localVersion === remoteVersion; + + const result = { + success: true, + status: isUpToDate ? "up_to_date" : "requires_update", + localVersion: localVersion, + remoteVersion: remoteVersion, + latest_release: { + tag_name: releaseData.data.tag_name, + name: releaseData.data.name, + published_at: releaseData.data.published_at, + html_url: releaseData.data.html_url, + body: releaseData.data.body, + }, + cached: releaseData.cached, + cache_age: releaseData.cache_age, + }; + + return result; + } catch (error) { + return { + success: false, + error: error.message, + localVersion: app.getVersion(), + }; + } +}); + ipcMain.handle("get-platform", () => { return process.platform; }); @@ -135,54 +295,58 @@ ipcMain.handle("save-server-config", (event, config) => { ipcMain.handle("test-server-connection", async (event, serverUrl) => { try { - let fetch; - try { - fetch = globalThis.fetch || require("node:fetch"); - } catch (e) { - const https = require("https"); - const http = require("http"); - const { URL } = require("url"); + const https = require("https"); + const http = require("http"); + const { URL } = require("url"); - fetch = (url, options = {}) => { - return new Promise((resolve, reject) => { - const urlObj = new URL(url); - const isHttps = urlObj.protocol === "https:"; - const client = isHttps ? https : http; + const fetch = (url, options = {}) => { + return new Promise((resolve, reject) => { + const urlObj = new URL(url); + const isHttps = urlObj.protocol === "https:"; + const client = isHttps ? https : http; - const req = client.request( - url, - { - method: options.method || "GET", - headers: options.headers || {}, - timeout: options.timeout || 5000, - }, - (res) => { - let data = ""; - res.on("data", (chunk) => (data += chunk)); - res.on("end", () => { - resolve({ - ok: res.statusCode >= 200 && res.statusCode < 300, - status: res.statusCode, - text: () => Promise.resolve(data), - json: () => Promise.resolve(JSON.parse(data)), - }); - }); - }, - ); + const requestOptions = { + method: options.method || "GET", + headers: options.headers || {}, + timeout: options.timeout || 10000, + }; - req.on("error", reject); - req.on("timeout", () => { - req.destroy(); - reject(new Error("Request timeout")); + if (isHttps) { + requestOptions.rejectUnauthorized = false; + requestOptions.agent = new https.Agent({ + rejectUnauthorized: false, + secureProtocol: "TLSv1_2_method", + checkServerIdentity: () => undefined, + ciphers: "ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH", + honorCipherOrder: true, }); + } - if (options.body) { - req.write(options.body); - } - req.end(); + const req = client.request(url, requestOptions, (res) => { + let data = ""; + res.on("data", (chunk) => (data += chunk)); + res.on("end", () => { + resolve({ + ok: res.statusCode >= 200 && res.statusCode < 300, + status: res.statusCode, + text: () => Promise.resolve(data), + json: () => Promise.resolve(JSON.parse(data)), + }); + }); }); - }; - } + + req.on("error", reject); + req.on("timeout", () => { + req.destroy(); + reject(new Error("Request timeout")); + }); + + if (options.body) { + req.write(options.body); + } + req.end(); + }); + }; const normalizedServerUrl = serverUrl.replace(/\/$/, ""); @@ -191,7 +355,7 @@ ipcMain.handle("test-server-connection", async (event, serverUrl) => { try { const response = await fetch(healthUrl, { method: "GET", - timeout: 5000, + timeout: 10000, }); if (response.ok) { @@ -203,9 +367,6 @@ ipcMain.handle("test-server-connection", async (event, serverUrl) => { data.includes("") || data.includes("") ) { - console.log( - "Health endpoint returned HTML instead of JSON - not a Termix server", - ); return { success: false, error: @@ -240,7 +401,7 @@ ipcMain.handle("test-server-connection", async (event, serverUrl) => { const versionUrl = `${normalizedServerUrl}/version`; const response = await fetch(versionUrl, { method: "GET", - timeout: 5000, + timeout: 10000, }); if (response.ok) { @@ -252,9 +413,6 @@ ipcMain.handle("test-server-connection", async (event, serverUrl) => { data.includes("") || data.includes("") ) { - console.log( - "Version endpoint returned HTML instead of JSON - not a Termix server", - ); return { success: false, error: @@ -300,7 +458,6 @@ ipcMain.handle("test-server-connection", async (event, serverUrl) => { app.whenReady().then(() => { createWindow(); - console.log("Termix started successfully"); }); app.on("window-all-closed", () => { @@ -317,10 +474,6 @@ app.on("activate", () => { } }); -app.on("before-quit", () => { - console.log("App is quitting..."); -}); - app.on("will-quit", () => { console.log("App will quit..."); }); diff --git a/electron/preload.js b/electron/preload.js index e1e436d8..0fbd3dc4 100644 --- a/electron/preload.js +++ b/electron/preload.js @@ -3,6 +3,7 @@ const { contextBridge, ipcRenderer } = require("electron"); contextBridge.exposeInMainWorld("electronAPI", { getAppVersion: () => ipcRenderer.invoke("get-app-version"), getPlatform: () => ipcRenderer.invoke("get-platform"), + checkElectronUpdate: () => ipcRenderer.invoke("check-electron-update"), getServerConfig: () => ipcRenderer.invoke("get-server-config"), saveServerConfig: (config) => @@ -25,5 +26,3 @@ contextBridge.exposeInMainWorld("electronAPI", { }); window.IS_ELECTRON = true; - -console.log("electronAPI exposed to window"); diff --git a/package-lock.json b/package-lock.json index d34f84e5..b7de7ca7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,18 +1,22 @@ { "name": "termix", - "version": "1.6.0", + "version": "1.7.0", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "termix", - "version": "1.6.0", + "version": "1.7.0", "dependencies": { + "@codemirror/autocomplete": "^6.18.7", + "@codemirror/commands": "^6.3.3", + "@codemirror/search": "^6.5.11", + "@codemirror/theme-one-dark": "^6.1.2", + "@codemirror/view": "^6.23.1", "@hookform/resolvers": "^5.1.1", + "@monaco-editor/react": "^4.7.0", "@radix-ui/react-accordion": "^1.2.11", - "@radix-ui/react-avatar": "^1.1.10", "@radix-ui/react-checkbox": "^1.3.2", - "@radix-ui/react-collapsible": "^1.1.11", "@radix-ui/react-dialog": "^1.1.15", "@radix-ui/react-dropdown-menu": "^2.1.15", "@radix-ui/react-label": "^2.1.7", @@ -21,30 +25,28 @@ "@radix-ui/react-scroll-area": "^1.2.9", "@radix-ui/react-select": "^2.2.5", "@radix-ui/react-separator": "^1.1.7", - "@radix-ui/react-slider": "^1.3.5", "@radix-ui/react-slot": "^1.2.3", "@radix-ui/react-switch": "^1.2.5", "@radix-ui/react-tabs": "^1.1.12", "@radix-ui/react-tooltip": "^1.2.8", "@tailwindcss/vite": "^4.1.11", "@types/bcryptjs": "^2.4.6", + "@types/cookie-parser": "^1.4.9", + "@types/jszip": "^3.4.0", "@types/multer": "^2.0.0", "@types/qrcode": "^1.5.5", "@types/speakeasy": "^2.0.10", - "@uiw/codemirror-extensions-hyper-link": "^4.24.1", "@uiw/codemirror-extensions-langs": "^4.24.1", - "@uiw/codemirror-themes": "^4.24.1", "@uiw/react-codemirror": "^4.24.1", - "@xterm/addon-attach": "^0.11.0", "@xterm/addon-clipboard": "^0.1.0", "@xterm/addon-fit": "^0.10.0", - "@xterm/addon-search": "^0.15.0", "@xterm/addon-unicode11": "^0.8.0", "@xterm/addon-web-links": "^0.11.0", "@xterm/xterm": "^5.5.0", "axios": "^1.10.0", "bcryptjs": "^3.0.2", "better-sqlite3": "^12.2.0", + "body-parser": "^1.20.2", "chalk": "^4.1.2", "class-variance-authority": "^0.7.1", "clsx": "^2.1.1", @@ -55,9 +57,9 @@ "express": "^5.1.0", "i18next": "^25.4.2", "i18next-browser-languagedetector": "^8.2.0", - "i18next-http-backend": "^3.0.2", "jose": "^5.2.3", "jsonwebtoken": "^9.0.2", + "jszip": "^3.10.1", "lucide-react": "^0.525.0", "multer": "^2.0.2", "nanoid": "^5.1.5", @@ -66,17 +68,24 @@ "qrcode": "^1.5.4", "react": "^19.1.0", "react-dom": "^19.1.0", + "react-h5-audio-player": "^3.10.1", "react-hook-form": "^7.60.0", "react-i18next": "^15.7.3", + "react-icons": "^5.5.0", + "react-markdown": "^10.1.0", + "react-pdf": "^10.1.0", + "react-photo-view": "^1.2.7", + "react-player": "^3.3.3", "react-resizable-panels": "^3.0.3", "react-simple-keyboard": "^3.8.120", + "react-syntax-highlighter": "^15.6.6", "react-xtermjs": "^1.0.10", + "remark-gfm": "^4.0.1", "sonner": "^2.0.7", "speakeasy": "^2.0.0", "ssh2": "^1.16.0", "tailwind-merge": "^3.3.1", - "tailwindcss": "^4.1.11", - "validator": "^13.15.15", + "wait-on": "^9.0.1", "ws": "^8.18.3", "zod": "^4.0.5" }, @@ -92,23 +101,17 @@ "@types/ssh2": "^1.15.5", "@types/ws": "^8.18.1", "@vitejs/plugin-react-swc": "^3.10.2", - "autoprefixer": "^10.4.21", "concurrently": "^9.2.1", "electron": "^38.0.0", "electron-builder": "^26.0.12", - "electron-icon-builder": "^2.0.1", - "electron-packager": "^17.1.2", "eslint": "^9.34.0", "eslint-plugin-react-hooks": "^5.2.0", "eslint-plugin-react-refresh": "^0.4.20", "globals": "^16.3.0", "prettier": "3.6.2", - "ts-node": "^10.9.2", - "tw-animate-css": "^1.3.5", "typescript": "~5.9.2", "typescript-eslint": "^8.40.0", - "vite": "^7.1.5", - "wait-on": "^8.0.4" + "vite": "^7.1.5" } }, "node_modules/@babel/runtime": { @@ -121,10 +124,11 @@ } }, "node_modules/@codemirror/autocomplete": { - "version": "6.18.7", - "resolved": "https://registry.npmjs.org/@codemirror/autocomplete/-/autocomplete-6.18.7.tgz", - "integrity": "sha512-8EzdeIoWPJDsMBwz3zdzwXnUpCzMiCyz5/A3FIPpriaclFCGDkAzK13sMcnsu5rowqiyeQN2Vs2TsOcoDPZirQ==", + "version": "6.19.0", + "resolved": "https://registry.npmjs.org/@codemirror/autocomplete/-/autocomplete-6.19.0.tgz", + "integrity": "sha512-61Hfv3cF07XvUxNeC3E7jhG8XNi1Yom1G0lRC936oLnlF+jrbrv8rc/J98XlYzcsAoTVupfsf5fLej1aI8kyIg==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/language": "^6.0.0", "@codemirror/state": "^6.0.0", @@ -173,6 +177,7 @@ "resolved": "https://registry.npmjs.org/@codemirror/lang-css/-/lang-css-6.3.1.tgz", "integrity": "sha512-kr5fwBGiGtmz6l0LSJIbno9QrifNMUusivHbnA1H6Dmqy4HZFte3UAICix1VuKo0lMPKQr2rqB+0BkKi/S3Ejg==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/autocomplete": "^6.0.0", "@codemirror/language": "^6.0.0", @@ -195,10 +200,11 @@ } }, "node_modules/@codemirror/lang-html": { - "version": "6.4.9", - "resolved": "https://registry.npmjs.org/@codemirror/lang-html/-/lang-html-6.4.9.tgz", - "integrity": "sha512-aQv37pIMSlueybId/2PVSP6NPnmurFDVmZwzc7jszd2KAF8qd4VBbvNYPXWQq90WIARjsdVkPbw29pszmHws3Q==", + "version": "6.4.10", + "resolved": "https://registry.npmjs.org/@codemirror/lang-html/-/lang-html-6.4.10.tgz", + "integrity": "sha512-h/SceTVsN5r+WE+TVP2g3KDvNoSzbSrtZXCKo4vkKdbfT5t4otuVgngGdFukOO/rwRD2++pCxoh6xD4TEVMkQA==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/autocomplete": "^6.0.0", "@codemirror/lang-css": "^6.0.0", @@ -226,6 +232,7 @@ "resolved": "https://registry.npmjs.org/@codemirror/lang-javascript/-/lang-javascript-6.2.4.tgz", "integrity": "sha512-0WVmhp1QOqZ4Rt6GlVGwKJN3KW7Xh4H2q8ZZNGZaP6lRdxXJzmjm4FqvmOojVj6khWJHIb9sp7U/72W7xQgqAA==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/autocomplete": "^6.0.0", "@codemirror/language": "^6.6.0", @@ -340,9 +347,9 @@ } }, "node_modules/@codemirror/lang-sql": { - "version": "6.9.1", - "resolved": "https://registry.npmjs.org/@codemirror/lang-sql/-/lang-sql-6.9.1.tgz", - "integrity": "sha512-ecSk3gm/mlINcURMcvkCZmXgdzPSq8r/yfCtTB4vgqGGIbBC2IJIAy7GqYTy5pgBEooTVmHP2GZK6Z7h63CDGg==", + "version": "6.10.0", + "resolved": "https://registry.npmjs.org/@codemirror/lang-sql/-/lang-sql-6.10.0.tgz", + "integrity": "sha512-6ayPkEd/yRw0XKBx5uAiToSgGECo/GY2NoJIHXIIQh1EVwLuKoU8BP/qK0qH5NLXAbtJRLuT73hx7P9X34iO4w==", "license": "MIT", "dependencies": { "@codemirror/autocomplete": "^6.0.0", @@ -413,6 +420,7 @@ "resolved": "https://registry.npmjs.org/@codemirror/language/-/language-6.11.3.tgz", "integrity": "sha512-9HBM2XnwDj7fnu0551HkGdrUrrqmYq/WC5iv6nbY2WdicXdGbhR/gfbZOH73Aqj4351alY1+aoG9rCNfiwS1RA==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/state": "^6.0.0", "@codemirror/view": "^6.23.0", @@ -453,9 +461,9 @@ } }, "node_modules/@codemirror/legacy-modes": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@codemirror/legacy-modes/-/legacy-modes-6.5.1.tgz", - "integrity": "sha512-DJYQQ00N1/KdESpZV7jg9hafof/iBNp9h7TYo1SLMk86TWl9uDsVdho2dzd81K+v4retmK6mdC7WpuOQDytQqw==", + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/@codemirror/legacy-modes/-/legacy-modes-6.5.2.tgz", + "integrity": "sha512-/jJbwSTazlQEDOQw2FJ8LEEKVS72pU0lx6oM54kGpL8t/NJ2Jda3CZ4pcltiKTdqYSRk3ug1B3pil1gsjA6+8Q==", "license": "MIT", "dependencies": { "@codemirror/language": "^6.0.0" @@ -488,6 +496,7 @@ "resolved": "https://registry.npmjs.org/@codemirror/state/-/state-6.5.2.tgz", "integrity": "sha512-FVqsPqtPWKVVL3dPSxy8wEF/ymIEuVzF1PK3VbUgrxXpJUSHQWWZz4JMToquRxnkw+36LTamCZG2iua2Ptq0fA==", "license": "MIT", + "peer": true, "dependencies": { "@marijn/find-cluster-break": "^1.0.0" } @@ -505,10 +514,11 @@ } }, "node_modules/@codemirror/view": { - "version": "6.38.2", - "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.38.2.tgz", - "integrity": "sha512-bTWAJxL6EOFLPzTx+O5P5xAO3gTqpatQ2b/ARQ8itfU/v2LlpS3pH2fkL0A3E/Fx8Y2St2KES7ZEV0sHTsSW/A==", + "version": "6.38.4", + "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.38.4.tgz", + "integrity": "sha512-hduz0suCcUSC/kM8Fq3A9iLwInJDl8fD1xLpTIk+5xkNm8z/FT7UsIa9sOXrkpChh+XXc18RzswE8QqELsVl+g==", "license": "MIT", + "peer": true, "dependencies": { "@codemirror/state": "^6.5.0", "crelt": "^1.0.6", @@ -516,30 +526,6 @@ "w3c-keyname": "^2.2.4" } }, - "node_modules/@cspotcode/source-map-support": { - "version": "0.8.1", - "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", - "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@jridgewell/trace-mapping": "0.3.9" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@cspotcode/source-map-support/node_modules/@jridgewell/trace-mapping": { - "version": "0.3.9", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", - "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@jridgewell/resolve-uri": "^3.0.3", - "@jridgewell/sourcemap-codec": "^1.4.10" - } - }, "node_modules/@develar/schema-utils": { "version": "2.6.5", "resolved": "https://registry.npmjs.org/@develar/schema-utils/-/schema-utils-2.6.5.tgz", @@ -576,6 +562,19 @@ "node": ">=10.12.0" } }, + "node_modules/@electron/asar/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/@electron/fuses": { "version": "1.8.0", "resolved": "https://registry.npmjs.org/@electron/fuses/-/fuses-1.8.0.tgz", @@ -652,16 +651,31 @@ "global-agent": "^3.0.0" } }, - "node_modules/@electron/get/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "node_modules/@electron/get/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } } }, + "node_modules/@electron/get/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@electron/node-gyp": { "version": "10.2.0-electron.1", "resolved": "git+ssh://git@github.com/electron/node-gyp.git#06b29aafb7708acef8b3669835c8a7857ebc92d2", @@ -697,16 +711,6 @@ "balanced-match": "^1.0.0" } }, - "node_modules/@electron/node-gyp/node_modules/chownr": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", - "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, "node_modules/@electron/node-gyp/node_modules/glob": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", @@ -751,41 +755,14 @@ "node": ">=8" } }, - "node_modules/@electron/node-gyp/node_modules/minizlib": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", - "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", - "dev": true, - "license": "MIT", - "dependencies": { - "minipass": "^3.0.0", - "yallist": "^4.0.0" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@electron/node-gyp/node_modules/minizlib/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "node_modules/@electron/node-gyp/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", "dev": true, "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@electron/node-gyp/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", "bin": { - "mkdirp": "bin/cmd.js" + "semver": "bin/semver.js" }, "engines": { "node": ">=10" @@ -809,13 +786,6 @@ "node": ">=10" } }, - "node_modules/@electron/node-gyp/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/@electron/notarize": { "version": "2.5.0", "resolved": "https://registry.npmjs.org/@electron/notarize/-/notarize-2.5.0.tgz", @@ -831,6 +801,24 @@ "node": ">= 10.0.0" } }, + "node_modules/@electron/notarize/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@electron/notarize/node_modules/fs-extra": { "version": "9.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", @@ -860,6 +848,13 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/@electron/notarize/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@electron/notarize/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -892,6 +887,24 @@ "node": ">=12.0.0" } }, + "node_modules/@electron/osx-sign/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@electron/osx-sign/node_modules/fs-extra": { "version": "10.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", @@ -933,6 +946,13 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/@electron/osx-sign/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@electron/osx-sign/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -972,29 +992,22 @@ "node": ">=12.13.0" } }, - "node_modules/@electron/rebuild/node_modules/chownr": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", - "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", + "node_modules/@electron/rebuild/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, - "node_modules/@electron/rebuild/node_modules/cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "license": "ISC", + "license": "MIT", "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" + "ms": "^2.1.3" }, "engines": { - "node": ">=12" + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } } }, "node_modules/@electron/rebuild/node_modules/fs-extra": { @@ -1035,41 +1048,21 @@ "node": ">=8" } }, - "node_modules/@electron/rebuild/node_modules/minizlib": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", - "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", + "node_modules/@electron/rebuild/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true, - "license": "MIT", - "dependencies": { - "minipass": "^3.0.0", - "yallist": "^4.0.0" - }, - "engines": { - "node": ">= 8" - } + "license": "MIT" }, - "node_modules/@electron/rebuild/node_modules/minizlib/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "node_modules/@electron/rebuild/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", "dev": true, "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@electron/rebuild/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", "bin": { - "mkdirp": "bin/cmd.js" + "semver": "bin/semver.js" }, "engines": { "node": ">=10" @@ -1103,70 +1096,6 @@ "node": ">= 10.0.0" } }, - "node_modules/@electron/rebuild/node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/@electron/rebuild/node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, - "node_modules/@electron/rebuild/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, - "node_modules/@electron/rebuild/node_modules/yargs": { - "version": "17.7.2", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", - "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", - "dev": true, - "license": "MIT", - "dependencies": { - "cliui": "^8.0.1", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.3", - "y18n": "^5.0.5", - "yargs-parser": "^21.1.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@electron/rebuild/node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=12" - } - }, "node_modules/@electron/universal": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/@electron/universal/-/universal-2.0.1.tgz", @@ -1196,10 +1125,28 @@ "balanced-match": "^1.0.0" } }, + "node_modules/@electron/universal/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@electron/universal/node_modules/fs-extra": { - "version": "11.3.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.1.tgz", - "integrity": "sha512-eXvGGwZ5CL17ZSwHWd3bbgk7UUpF6IFHtP57NYYakPvHOs8GDgDe5KJI36jIJzDkJ6eJjuzRA8eBQb6SkKue0g==", + "version": "11.3.2", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.2.tgz", + "integrity": "sha512-Xr9F6z6up6Ws+NjzMCZc6WXg2YFRlrLP9NQDO3VQrWrfiojdhS56TzueT88ze0uBdCTwEIhQ3ptnmKeWGFAe0A==", "dev": true, "license": "MIT", "dependencies": { @@ -1240,6 +1187,13 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/@electron/universal/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@electron/universal/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -1257,7 +1211,6 @@ "dev": true, "license": "BSD-2-Clause", "optional": true, - "peer": true, "dependencies": { "cross-dirname": "^0.1.0", "debug": "^4.3.4", @@ -1272,14 +1225,32 @@ "node": ">=14.14" } }, - "node_modules/@electron/windows-sign/node_modules/fs-extra": { - "version": "11.3.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.1.tgz", - "integrity": "sha512-eXvGGwZ5CL17ZSwHWd3bbgk7UUpF6IFHtP57NYYakPvHOs8GDgDe5KJI36jIJzDkJ6eJjuzRA8eBQb6SkKue0g==", + "node_modules/@electron/windows-sign/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "optional": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@electron/windows-sign/node_modules/fs-extra": { + "version": "11.3.2", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.2.tgz", + "integrity": "sha512-Xr9F6z6up6Ws+NjzMCZc6WXg2YFRlrLP9NQDO3VQrWrfiojdhS56TzueT88ze0uBdCTwEIhQ3ptnmKeWGFAe0A==", "dev": true, "license": "MIT", "optional": true, - "peer": true, "dependencies": { "graceful-fs": "^4.2.0", "jsonfile": "^6.0.1", @@ -1296,7 +1267,6 @@ "dev": true, "license": "MIT", "optional": true, - "peer": true, "dependencies": { "universalify": "^2.0.0" }, @@ -1304,6 +1274,14 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/@electron/windows-sign/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT", + "optional": true + }, "node_modules/@electron/windows-sign/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -1311,15 +1289,14 @@ "dev": true, "license": "MIT", "optional": true, - "peer": true, "engines": { "node": ">= 10.0.0" } }, "node_modules/@esbuild/aix-ppc64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.9.tgz", - "integrity": "sha512-OaGtL73Jck6pBKjNIe24BnFE6agGl+6KxDtTfHhy1HmhthfKouEcOhqpSL64K4/0WCtbKFLOdzD/44cJ4k9opA==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.10.tgz", + "integrity": "sha512-0NFWnA+7l41irNuaSVlLfgNT12caWJVLzp5eAVhZ0z1qpxbockccEt3s+149rE64VUI3Ml2zt8Nv5JVc4QXTsw==", "cpu": [ "ppc64" ], @@ -1333,9 +1310,9 @@ } }, "node_modules/@esbuild/android-arm": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.9.tgz", - "integrity": "sha512-5WNI1DaMtxQ7t7B6xa572XMXpHAaI/9Hnhk8lcxF4zVN4xstUgTlvuGDorBguKEnZO70qwEcLpfifMLoxiPqHQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.10.tgz", + "integrity": "sha512-dQAxF1dW1C3zpeCDc5KqIYuZ1tgAdRXNoZP7vkBIRtKZPYe2xVr/d3SkirklCHudW1B45tGiUlz2pUWDfbDD4w==", "cpu": [ "arm" ], @@ -1349,9 +1326,9 @@ } }, "node_modules/@esbuild/android-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.9.tgz", - "integrity": "sha512-IDrddSmpSv51ftWslJMvl3Q2ZT98fUSL2/rlUXuVqRXHCs5EUF1/f+jbjF5+NG9UffUDMCiTyh8iec7u8RlTLg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.10.tgz", + "integrity": "sha512-LSQa7eDahypv/VO6WKohZGPSJDq5OVOo3UoFR1E4t4Gj1W7zEQMUhI+lo81H+DtB+kP+tDgBp+M4oNCwp6kffg==", "cpu": [ "arm64" ], @@ -1365,9 +1342,9 @@ } }, "node_modules/@esbuild/android-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.9.tgz", - "integrity": "sha512-I853iMZ1hWZdNllhVZKm34f4wErd4lMyeV7BLzEExGEIZYsOzqDWDf+y082izYUE8gtJnYHdeDpN/6tUdwvfiw==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.10.tgz", + "integrity": "sha512-MiC9CWdPrfhibcXwr39p9ha1x0lZJ9KaVfvzA0Wxwz9ETX4v5CHfF09bx935nHlhi+MxhA63dKRRQLiVgSUtEg==", "cpu": [ "x64" ], @@ -1381,9 +1358,9 @@ } }, "node_modules/@esbuild/darwin-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.9.tgz", - "integrity": "sha512-XIpIDMAjOELi/9PB30vEbVMs3GV1v2zkkPnuyRRURbhqjyzIINwj+nbQATh4H9GxUgH1kFsEyQMxwiLFKUS6Rg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.10.tgz", + "integrity": "sha512-JC74bdXcQEpW9KkV326WpZZjLguSZ3DfS8wrrvPMHgQOIEIG/sPXEN/V8IssoJhbefLRcRqw6RQH2NnpdprtMA==", "cpu": [ "arm64" ], @@ -1397,9 +1374,9 @@ } }, "node_modules/@esbuild/darwin-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.9.tgz", - "integrity": "sha512-jhHfBzjYTA1IQu8VyrjCX4ApJDnH+ez+IYVEoJHeqJm9VhG9Dh2BYaJritkYK3vMaXrf7Ogr/0MQ8/MeIefsPQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.10.tgz", + "integrity": "sha512-tguWg1olF6DGqzws97pKZ8G2L7Ig1vjDmGTwcTuYHbuU6TTjJe5FXbgs5C1BBzHbJ2bo1m3WkQDbWO2PvamRcg==", "cpu": [ "x64" ], @@ -1413,9 +1390,9 @@ } }, "node_modules/@esbuild/freebsd-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.9.tgz", - "integrity": "sha512-z93DmbnY6fX9+KdD4Ue/H6sYs+bhFQJNCPZsi4XWJoYblUqT06MQUdBCpcSfuiN72AbqeBFu5LVQTjfXDE2A6Q==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.10.tgz", + "integrity": "sha512-3ZioSQSg1HT2N05YxeJWYR+Libe3bREVSdWhEEgExWaDtyFbbXWb49QgPvFH8u03vUPX10JhJPcz7s9t9+boWg==", "cpu": [ "arm64" ], @@ -1429,9 +1406,9 @@ } }, "node_modules/@esbuild/freebsd-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.9.tgz", - "integrity": "sha512-mrKX6H/vOyo5v71YfXWJxLVxgy1kyt1MQaD8wZJgJfG4gq4DpQGpgTB74e5yBeQdyMTbgxp0YtNj7NuHN0PoZg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.10.tgz", + "integrity": "sha512-LLgJfHJk014Aa4anGDbh8bmI5Lk+QidDmGzuC2D+vP7mv/GeSN+H39zOf7pN5N8p059FcOfs2bVlrRr4SK9WxA==", "cpu": [ "x64" ], @@ -1445,9 +1422,9 @@ } }, "node_modules/@esbuild/linux-arm": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.9.tgz", - "integrity": "sha512-HBU2Xv78SMgaydBmdor38lg8YDnFKSARg1Q6AT0/y2ezUAKiZvc211RDFHlEZRFNRVhcMamiToo7bDx3VEOYQw==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.10.tgz", + "integrity": "sha512-oR31GtBTFYCqEBALI9r6WxoU/ZofZl962pouZRTEYECvNF/dtXKku8YXcJkhgK/beU+zedXfIzHijSRapJY3vg==", "cpu": [ "arm" ], @@ -1461,9 +1438,9 @@ } }, "node_modules/@esbuild/linux-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.9.tgz", - "integrity": "sha512-BlB7bIcLT3G26urh5Dmse7fiLmLXnRlopw4s8DalgZ8ef79Jj4aUcYbk90g8iCa2467HX8SAIidbL7gsqXHdRw==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.10.tgz", + "integrity": "sha512-5luJWN6YKBsawd5f9i4+c+geYiVEw20FVW5x0v1kEMWNq8UctFjDiMATBxLvmmHA4bf7F6hTRaJgtghFr9iziQ==", "cpu": [ "arm64" ], @@ -1477,9 +1454,9 @@ } }, "node_modules/@esbuild/linux-ia32": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.9.tgz", - "integrity": "sha512-e7S3MOJPZGp2QW6AK6+Ly81rC7oOSerQ+P8L0ta4FhVi+/j/v2yZzx5CqqDaWjtPFfYz21Vi1S0auHrap3Ma3A==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.10.tgz", + "integrity": "sha512-NrSCx2Kim3EnnWgS4Txn0QGt0Xipoumb6z6sUtl5bOEZIVKhzfyp/Lyw4C1DIYvzeW/5mWYPBFJU3a/8Yr75DQ==", "cpu": [ "ia32" ], @@ -1493,9 +1470,9 @@ } }, "node_modules/@esbuild/linux-loong64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.9.tgz", - "integrity": "sha512-Sbe10Bnn0oUAB2AalYztvGcK+o6YFFA/9829PhOCUS9vkJElXGdphz0A3DbMdP8gmKkqPmPcMJmJOrI3VYB1JQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.10.tgz", + "integrity": "sha512-xoSphrd4AZda8+rUDDfD9J6FUMjrkTz8itpTITM4/xgerAZZcFW7Dv+sun7333IfKxGG8gAq+3NbfEMJfiY+Eg==", "cpu": [ "loong64" ], @@ -1509,9 +1486,9 @@ } }, "node_modules/@esbuild/linux-mips64el": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.9.tgz", - "integrity": "sha512-YcM5br0mVyZw2jcQeLIkhWtKPeVfAerES5PvOzaDxVtIyZ2NUBZKNLjC5z3/fUlDgT6w89VsxP2qzNipOaaDyA==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.10.tgz", + "integrity": "sha512-ab6eiuCwoMmYDyTnyptoKkVS3k8fy/1Uvq7Dj5czXI6DF2GqD2ToInBI0SHOp5/X1BdZ26RKc5+qjQNGRBelRA==", "cpu": [ "mips64el" ], @@ -1525,9 +1502,9 @@ } }, "node_modules/@esbuild/linux-ppc64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.9.tgz", - "integrity": "sha512-++0HQvasdo20JytyDpFvQtNrEsAgNG2CY1CLMwGXfFTKGBGQT3bOeLSYE2l1fYdvML5KUuwn9Z8L1EWe2tzs1w==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.10.tgz", + "integrity": "sha512-NLinzzOgZQsGpsTkEbdJTCanwA5/wozN9dSgEl12haXJBzMTpssebuXR42bthOF3z7zXFWH1AmvWunUCkBE4EA==", "cpu": [ "ppc64" ], @@ -1541,9 +1518,9 @@ } }, "node_modules/@esbuild/linux-riscv64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.9.tgz", - "integrity": "sha512-uNIBa279Y3fkjV+2cUjx36xkx7eSjb8IvnL01eXUKXez/CBHNRw5ekCGMPM0BcmqBxBcdgUWuUXmVWwm4CH9kg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.10.tgz", + "integrity": "sha512-FE557XdZDrtX8NMIeA8LBJX3dC2M8VGXwfrQWU7LB5SLOajfJIxmSdyL/gU1m64Zs9CBKvm4UAuBp5aJ8OgnrA==", "cpu": [ "riscv64" ], @@ -1557,9 +1534,9 @@ } }, "node_modules/@esbuild/linux-s390x": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.9.tgz", - "integrity": "sha512-Mfiphvp3MjC/lctb+7D287Xw1DGzqJPb/J2aHHcHxflUo+8tmN/6d4k6I2yFR7BVo5/g7x2Monq4+Yew0EHRIA==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.10.tgz", + "integrity": "sha512-3BBSbgzuB9ajLoVZk0mGu+EHlBwkusRmeNYdqmznmMc9zGASFjSsxgkNsqmXugpPk00gJ0JNKh/97nxmjctdew==", "cpu": [ "s390x" ], @@ -1573,9 +1550,9 @@ } }, "node_modules/@esbuild/linux-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.9.tgz", - "integrity": "sha512-iSwByxzRe48YVkmpbgoxVzn76BXjlYFXC7NvLYq+b+kDjyyk30J0JY47DIn8z1MO3K0oSl9fZoRmZPQI4Hklzg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.10.tgz", + "integrity": "sha512-QSX81KhFoZGwenVyPoberggdW1nrQZSvfVDAIUXr3WqLRZGZqWk/P4T8p2SP+de2Sr5HPcvjhcJzEiulKgnxtA==", "cpu": [ "x64" ], @@ -1589,9 +1566,9 @@ } }, "node_modules/@esbuild/netbsd-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.9.tgz", - "integrity": "sha512-9jNJl6FqaUG+COdQMjSCGW4QiMHH88xWbvZ+kRVblZsWrkXlABuGdFJ1E9L7HK+T0Yqd4akKNa/lO0+jDxQD4Q==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.10.tgz", + "integrity": "sha512-AKQM3gfYfSW8XRk8DdMCzaLUFB15dTrZfnX8WXQoOUpUBQ+NaAFCP1kPS/ykbbGYz7rxn0WS48/81l9hFl3u4A==", "cpu": [ "arm64" ], @@ -1605,9 +1582,9 @@ } }, "node_modules/@esbuild/netbsd-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.9.tgz", - "integrity": "sha512-RLLdkflmqRG8KanPGOU7Rpg829ZHu8nFy5Pqdi9U01VYtG9Y0zOG6Vr2z4/S+/3zIyOxiK6cCeYNWOFR9QP87g==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.10.tgz", + "integrity": "sha512-7RTytDPGU6fek/hWuN9qQpeGPBZFfB4zZgcz2VK2Z5VpdUxEI8JKYsg3JfO0n/Z1E/6l05n0unDCNc4HnhQGig==", "cpu": [ "x64" ], @@ -1621,9 +1598,9 @@ } }, "node_modules/@esbuild/openbsd-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.9.tgz", - "integrity": "sha512-YaFBlPGeDasft5IIM+CQAhJAqS3St3nJzDEgsgFixcfZeyGPCd6eJBWzke5piZuZ7CtL656eOSYKk4Ls2C0FRQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.10.tgz", + "integrity": "sha512-5Se0VM9Wtq797YFn+dLimf2Zx6McttsH2olUBsDml+lm0GOCRVebRWUvDtkY4BWYv/3NgzS8b/UM3jQNh5hYyw==", "cpu": [ "arm64" ], @@ -1637,9 +1614,9 @@ } }, "node_modules/@esbuild/openbsd-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.9.tgz", - "integrity": "sha512-1MkgTCuvMGWuqVtAvkpkXFmtL8XhWy+j4jaSO2wxfJtilVCi0ZE37b8uOdMItIHz4I6z1bWWtEX4CJwcKYLcuA==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.10.tgz", + "integrity": "sha512-XkA4frq1TLj4bEMB+2HnI0+4RnjbuGZfet2gs/LNs5Hc7D89ZQBHQ0gL2ND6Lzu1+QVkjp3x1gIcPKzRNP8bXw==", "cpu": [ "x64" ], @@ -1653,9 +1630,9 @@ } }, "node_modules/@esbuild/openharmony-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/openharmony-arm64/-/openharmony-arm64-0.25.9.tgz", - "integrity": "sha512-4Xd0xNiMVXKh6Fa7HEJQbrpP3m3DDn43jKxMjxLLRjWnRsfxjORYJlXPO4JNcXtOyfajXorRKY9NkOpTHptErg==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/openharmony-arm64/-/openharmony-arm64-0.25.10.tgz", + "integrity": "sha512-AVTSBhTX8Y/Fz6OmIVBip9tJzZEUcY8WLh7I59+upa5/GPhh2/aM6bvOMQySspnCCHvFi79kMtdJS1w0DXAeag==", "cpu": [ "arm64" ], @@ -1669,9 +1646,9 @@ } }, "node_modules/@esbuild/sunos-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.9.tgz", - "integrity": "sha512-WjH4s6hzo00nNezhp3wFIAfmGZ8U7KtrJNlFMRKxiI9mxEK1scOMAaa9i4crUtu+tBr+0IN6JCuAcSBJZfnphw==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.10.tgz", + "integrity": "sha512-fswk3XT0Uf2pGJmOpDB7yknqhVkJQkAQOcW/ccVOtfx05LkbWOaRAtn5SaqXypeKQra1QaEa841PgrSL9ubSPQ==", "cpu": [ "x64" ], @@ -1685,9 +1662,9 @@ } }, "node_modules/@esbuild/win32-arm64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.9.tgz", - "integrity": "sha512-mGFrVJHmZiRqmP8xFOc6b84/7xa5y5YvR1x8djzXpJBSv/UsNK6aqec+6JDjConTgvvQefdGhFDAs2DLAds6gQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.10.tgz", + "integrity": "sha512-ah+9b59KDTSfpaCg6VdJoOQvKjI33nTaQr4UluQwW7aEwZQsbMCfTmfEO4VyewOxx4RaDT/xCy9ra2GPWmO7Kw==", "cpu": [ "arm64" ], @@ -1701,9 +1678,9 @@ } }, "node_modules/@esbuild/win32-ia32": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.9.tgz", - "integrity": "sha512-b33gLVU2k11nVx1OhX3C8QQP6UHQK4ZtN56oFWvVXvz2VkDoe6fbG8TOgHFxEvqeqohmRnIHe5A1+HADk4OQww==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.10.tgz", + "integrity": "sha512-QHPDbKkrGO8/cz9LKVnJU22HOi4pxZnZhhA2HYHez5Pz4JeffhDjf85E57Oyco163GnzNCVkZK0b/n4Y0UHcSw==", "cpu": [ "ia32" ], @@ -1717,9 +1694,9 @@ } }, "node_modules/@esbuild/win32-x64": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.9.tgz", - "integrity": "sha512-PPOl1mi6lpLNQxnGoyAfschAodRFYXJ+9fs6WHXz7CSWKbOqiMZsubC+BQsVKuul+3vKLuwTHsS2c2y9EoKwxQ==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.10.tgz", + "integrity": "sha512-9KpxSVFCu0iK1owoez6aC/s/EdUQLDN3adTxGCqxMVhrPDj6bt5dbrHDXUuq+Bs2vATFBBrQS5vdQ/Ed2P+nbw==", "cpu": [ "x64" ], @@ -1789,6 +1766,44 @@ "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, + "node_modules/@eslint/config-array/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@eslint/config-array/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/@eslint/config-array/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@eslint/config-helpers": { "version": "0.3.1", "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.3.1.tgz", @@ -1836,6 +1851,24 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/@eslint/eslintrc/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@eslint/eslintrc/node_modules/globals": { "version": "14.0.0", "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", @@ -1849,10 +1882,30 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/@eslint/eslintrc/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/@eslint/eslintrc/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@eslint/js": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", - "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", + "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", "dev": true, "license": "MIT", "engines": { @@ -1931,27 +1984,58 @@ "dev": true, "license": "MIT" }, - "node_modules/@hapi/hoek": { - "version": "9.3.0", - "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", - "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==", - "dev": true, - "license": "BSD-3-Clause" - }, - "node_modules/@hapi/topo": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", - "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", - "dev": true, + "node_modules/@hapi/address": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/@hapi/address/-/address-5.1.1.tgz", + "integrity": "sha512-A+po2d/dVoY7cYajycYI43ZbYMXukuopIsqCjh5QzsBCipDtdofHntljDlpccMjIfTy6UOkg+5KPriwYch2bXA==", "license": "BSD-3-Clause", "dependencies": { - "@hapi/hoek": "^9.0.0" + "@hapi/hoek": "^11.0.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@hapi/formula": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@hapi/formula/-/formula-3.0.2.tgz", + "integrity": "sha512-hY5YPNXzw1He7s0iqkRQi+uMGh383CGdyyIGYtB+W5N3KHPXoqychklvHhKCC9M3Xtv0OCs/IHw+r4dcHtBYWw==", + "license": "BSD-3-Clause" + }, + "node_modules/@hapi/hoek": { + "version": "11.0.7", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-11.0.7.tgz", + "integrity": "sha512-HV5undWkKzcB4RZUusqOpcgxOaq6VOAH7zhhIr2g3G8NF/MlFO75SjOr2NfuSx0Mh40+1FqCkagKLJRykUWoFQ==", + "license": "BSD-3-Clause" + }, + "node_modules/@hapi/pinpoint": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@hapi/pinpoint/-/pinpoint-2.0.1.tgz", + "integrity": "sha512-EKQmr16tM8s16vTT3cA5L0kZZcTMU5DUOZTuvpnY738m+jyP3JIUj+Mm1xc1rsLkGBQ/gVnfKYPwOmPg1tUR4Q==", + "license": "BSD-3-Clause" + }, + "node_modules/@hapi/tlds": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@hapi/tlds/-/tlds-1.1.3.tgz", + "integrity": "sha512-QIvUMB5VZ8HMLZF9A2oWr3AFM430QC8oGd0L35y2jHpuW6bIIca6x/xL7zUf4J7L9WJ3qjz+iJII8ncaeMbpSg==", + "license": "BSD-3-Clause", + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@hapi/topo": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-6.0.2.tgz", + "integrity": "sha512-KR3rD5inZbGMrHmgPxsJ9dbi6zEK+C3ZwUwTa+eMwWLz7oijWUTWD2pMSNNYJAU6Qq+65NkxXjqHr/7LM2Xkqg==", + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^11.0.2" } }, "node_modules/@hookform/resolvers": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/@hookform/resolvers/-/resolvers-5.2.1.tgz", - "integrity": "sha512-u0+6X58gkjMcxur1wRWokA7XsiiBJ6aK17aPZxhkoYiK5J+HcTx0Vhu9ovXe6H+dVpO6cjrn2FkJTryXEMlryQ==", + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/@hookform/resolvers/-/resolvers-5.2.2.tgz", + "integrity": "sha512-A/IxlMLShx3KjV/HeTcTfaMxdwy690+L/ZADoeaTltLx+CVuzkeVIPuybK3jrRfw7YZnmdKsVVHAlEPIAEUNlA==", "license": "MIT", "dependencies": { "@standard-schema/utils": "^0.3.0" @@ -2012,6 +2096,27 @@ "url": "https://github.com/sponsors/nzakas" } }, + "node_modules/@iconify/react": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/@iconify/react/-/react-5.2.1.tgz", + "integrity": "sha512-37GDR3fYDZmnmUn9RagyaX+zca24jfVOMY8E1IXTqJuE8pxNtN51KWPQe3VODOWvuUurq7q9uUu3CFrpqj5Iqg==", + "license": "MIT", + "dependencies": { + "@iconify/types": "^2.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/cyberalien" + }, + "peerDependencies": { + "react": ">=16" + } + }, + "node_modules/@iconify/types": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@iconify/types/-/types-2.0.0.tgz", + "integrity": "sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==", + "license": "MIT" + }, "node_modules/@isaacs/balanced-match": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/@isaacs/balanced-match/-/balanced-match-4.0.1.tgz", @@ -2150,497 +2255,13 @@ "node": ">=18.0.0" } }, - "node_modules/@jimp/bmp": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/bmp/-/bmp-0.16.13.tgz", - "integrity": "sha512-9edAxu7N2FX7vzkdl5Jo1BbACfycUtBQX+XBMcHA2bk62P8R0otgkHg798frgAk/WxQIzwxqOH6wMiCwrlAzdQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "bmp-js": "^0.1.0" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/core": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/core/-/core-0.16.13.tgz", - "integrity": "sha512-qXpA1tzTnlkTku9yqtuRtS/wVntvE6f3m3GNxdTdtmc+O+Wcg9Xo2ABPMh7Nc0AHbMKzwvwgB2JnjZmlmJEObg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "any-base": "^1.1.0", - "buffer": "^5.2.0", - "exif-parser": "^0.1.12", - "file-type": "^16.5.4", - "load-bmfont": "^1.3.1", - "mkdirp": "^0.5.1", - "phin": "^2.9.1", - "pixelmatch": "^4.0.2", - "tinycolor2": "^1.4.1" - } - }, - "node_modules/@jimp/custom": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/custom/-/custom-0.16.13.tgz", - "integrity": "sha512-LTATglVUPGkPf15zX1wTMlZ0+AU7cGEGF6ekVF1crA8eHUWsGjrYTB+Ht4E3HTrCok8weQG+K01rJndCp/l4XA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/core": "^0.16.13" - } - }, - "node_modules/@jimp/gif": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/gif/-/gif-0.16.13.tgz", - "integrity": "sha512-yFAMZGv3o+YcjXilMWWwS/bv1iSqykFahFMSO169uVMtfQVfa90kt4/kDwrXNR6Q9i6VHpFiGZMlF2UnHClBvg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "gifwrap": "^0.9.2", - "omggif": "^1.0.9" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/jpeg": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/jpeg/-/jpeg-0.16.13.tgz", - "integrity": "sha512-BJHlDxzTlCqP2ThqP8J0eDrbBfod7npWCbJAcfkKqdQuFk0zBPaZ6KKaQKyKxmWJ87Z6ohANZoMKEbtvrwz1AA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "jpeg-js": "^0.4.2" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-blit": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-blit/-/plugin-blit-0.16.13.tgz", - "integrity": "sha512-8Z1k96ZFxlhK2bgrY1JNWNwvaBeI/bciLM0yDOni2+aZwfIIiC7Y6PeWHTAvjHNjphz+XCt01WQmOYWCn0ML6g==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-blur": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-blur/-/plugin-blur-0.16.13.tgz", - "integrity": "sha512-PvLrfa8vkej3qinlebyhLpksJgCF5aiysDMSVhOZqwH5nQLLtDE9WYbnsofGw4r0VVpyw3H/ANCIzYTyCtP9Cg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-circle": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-circle/-/plugin-circle-0.16.13.tgz", - "integrity": "sha512-RNave7EFgZrb5V5EpdvJGAEHMnDAJuwv05hKscNfIYxf0kR3KhViBTDy+MoTnMlIvaKFULfwIgaZWzyhuINMzA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-color": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-color/-/plugin-color-0.16.13.tgz", - "integrity": "sha512-xW+9BtEvoIkkH/Wde9ql4nAFbYLkVINhpgAE7VcBUsuuB34WUbcBl/taOuUYQrPEFQJ4jfXiAJZ2H/rvKjCVnQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "tinycolor2": "^1.4.1" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-contain": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-contain/-/plugin-contain-0.16.13.tgz", - "integrity": "sha512-QayTXw4tXMwU6q6acNTQrTTFTXpNRBe+MgTGMDU0lk+23PjlFCO/9sacflelG8lsp7vNHhAxFeHptDMAksEYzg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-blit": ">=0.3.5", - "@jimp/plugin-resize": ">=0.3.5", - "@jimp/plugin-scale": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-cover": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-cover/-/plugin-cover-0.16.13.tgz", - "integrity": "sha512-BSsP71GTNaqWRcvkbWuIVH+zK7b3TSNebbhDkFK0fVaUTzHuKMS/mgY4hDZIEVt7Rf5FjadAYtsujHN9w0iSYA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-crop": ">=0.3.5", - "@jimp/plugin-resize": ">=0.3.5", - "@jimp/plugin-scale": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-crop": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-crop/-/plugin-crop-0.16.13.tgz", - "integrity": "sha512-WEl2tPVYwzYL8OKme6Go2xqiWgKsgxlMwyHabdAU4tXaRwOCnOI7v4021gCcBb9zn/oWwguHuKHmK30Fw2Z/PA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-displace": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-displace/-/plugin-displace-0.16.13.tgz", - "integrity": "sha512-qt9WKq8vWrcjySa9DyQ0x/RBMHQeiVjdVSY1SJsMjssPUf0pS74qorcuAkGi89biN3YoGUgPkpqECnAWnYwgGA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-dither": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-dither/-/plugin-dither-0.16.13.tgz", - "integrity": "sha512-5/N3yJggbWQTlGZHQYJPmQXEwR52qaXjEzkp1yRBbtdaekXE3BG/suo0fqeoV/csf8ooI78sJzYmIrxNoWVtgQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-fisheye": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-fisheye/-/plugin-fisheye-0.16.13.tgz", - "integrity": "sha512-2rZmTdFbT/cF9lEZIkXCYO0TsT114Q27AX5IAo0Sju6jVQbvIk1dFUTnwLDadTo8wkJlFzGqMQ24Cs8cHWOliA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-flip": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-flip/-/plugin-flip-0.16.13.tgz", - "integrity": "sha512-EmcgAA74FTc5u7Z+hUO/sRjWwfPPLuOQP5O64x5g4j0T12Bd29IgsYZxoutZo/rb3579+JNa/3wsSEmyVv1EpA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-rotate": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-gaussian": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-gaussian/-/plugin-gaussian-0.16.13.tgz", - "integrity": "sha512-A1XKfGQD0iDdIiKqFYi8nZMv4dDVYdxbrmgR7y/CzUHhSYdcmoljLIIsZZM3Iks/Wa353W3vtvkWLuDbQbch1w==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-invert": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-invert/-/plugin-invert-0.16.13.tgz", - "integrity": "sha512-xFMrIn7czEZbdbMzZWuaZFnlLGJDVJ82y5vlsKsXRTG2kcxRsMPXvZRWHV57nSs1YFsNqXSbrC8B98n0E32njQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-mask": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-mask/-/plugin-mask-0.16.13.tgz", - "integrity": "sha512-wLRYKVBXql2GAYgt6FkTnCfE+q5NomM7Dlh0oIPGAoMBWDyTx0eYutRK6PlUrRK2yMHuroAJCglICTbxqGzowQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-normalize": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-normalize/-/plugin-normalize-0.16.13.tgz", - "integrity": "sha512-3tfad0n9soRna4IfW9NzQdQ2Z3ijkmo21DREHbE6CGcMIxOSvfRdSvf1qQPApxjTSo8LTU4MCi/fidx/NZ0GqQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-print": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-print/-/plugin-print-0.16.13.tgz", - "integrity": "sha512-0m6i3p01PGRkGAK9r53hDYrkyMq+tlhLOIbsSTmZyh6HLshUKlTB7eXskF5OpVd5ZUHoltlNc6R+ggvKIzxRFw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "load-bmfont": "^1.4.0" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-blit": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-resize": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-resize/-/plugin-resize-0.16.13.tgz", - "integrity": "sha512-qoqtN8LDknm3fJm9nuPygJv30O3vGhSBD2TxrsCnhtOsxKAqVPJtFVdGd/qVuZ8nqQANQmTlfqTiK9mVWQ7MiQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-rotate": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-rotate/-/plugin-rotate-0.16.13.tgz", - "integrity": "sha512-Ev+Jjmj1nHYw897z9C3R9dYsPv7S2/nxdgfFb/h8hOwK0Ovd1k/+yYS46A0uj/JCKK0pQk8wOslYBkPwdnLorw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-blit": ">=0.3.5", - "@jimp/plugin-crop": ">=0.3.5", - "@jimp/plugin-resize": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-scale": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-scale/-/plugin-scale-0.16.13.tgz", - "integrity": "sha512-05POQaEJVucjTiSGMoH68ZiELc7QqpIpuQlZ2JBbhCV+WCbPFUBcGSmE7w4Jd0E2GvCho/NoMODLwgcVGQA97A==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-resize": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-shadow": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-shadow/-/plugin-shadow-0.16.13.tgz", - "integrity": "sha512-nmu5VSZ9hsB1JchTKhnnCY+paRBnwzSyK5fhkhtQHHoFD5ArBQ/5wU8y6tCr7k/GQhhGq1OrixsECeMjPoc8Zw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-blur": ">=0.3.5", - "@jimp/plugin-resize": ">=0.3.5" - } - }, - "node_modules/@jimp/plugin-threshold": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugin-threshold/-/plugin-threshold-0.16.13.tgz", - "integrity": "sha512-+3zArBH0OE3Rhjm4HyAokMsZlIq5gpQec33CncyoSwxtRBM2WAhUVmCUKuBo+Lr/2/4ISoY4BWpHKhMLDix6cA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5", - "@jimp/plugin-color": ">=0.8.0", - "@jimp/plugin-resize": ">=0.8.0" - } - }, - "node_modules/@jimp/plugins": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/plugins/-/plugins-0.16.13.tgz", - "integrity": "sha512-CJLdqODEhEVs4MgWCxpWL5l95sCBlkuSLz65cxEm56X5akIsn4LOlwnKoSEZioYcZUBvHhCheH67AyPTudfnQQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/plugin-blit": "^0.16.13", - "@jimp/plugin-blur": "^0.16.13", - "@jimp/plugin-circle": "^0.16.13", - "@jimp/plugin-color": "^0.16.13", - "@jimp/plugin-contain": "^0.16.13", - "@jimp/plugin-cover": "^0.16.13", - "@jimp/plugin-crop": "^0.16.13", - "@jimp/plugin-displace": "^0.16.13", - "@jimp/plugin-dither": "^0.16.13", - "@jimp/plugin-fisheye": "^0.16.13", - "@jimp/plugin-flip": "^0.16.13", - "@jimp/plugin-gaussian": "^0.16.13", - "@jimp/plugin-invert": "^0.16.13", - "@jimp/plugin-mask": "^0.16.13", - "@jimp/plugin-normalize": "^0.16.13", - "@jimp/plugin-print": "^0.16.13", - "@jimp/plugin-resize": "^0.16.13", - "@jimp/plugin-rotate": "^0.16.13", - "@jimp/plugin-scale": "^0.16.13", - "@jimp/plugin-shadow": "^0.16.13", - "@jimp/plugin-threshold": "^0.16.13", - "timm": "^1.6.1" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/png": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/png/-/png-0.16.13.tgz", - "integrity": "sha512-8cGqINvbWJf1G0Her9zbq9I80roEX0A+U45xFby3tDWfzn+Zz8XKDF1Nv9VUwVx0N3zpcG1RPs9hfheG4Cq2kg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/utils": "^0.16.13", - "pngjs": "^3.3.3" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/png/node_modules/pngjs": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-3.4.0.tgz", - "integrity": "sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==", - "dev": true, - "license": "MIT", + "node_modules/@isaacs/fs-minipass/node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "license": "ISC", "engines": { - "node": ">=4.0.0" - } - }, - "node_modules/@jimp/tiff": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/tiff/-/tiff-0.16.13.tgz", - "integrity": "sha512-oJY8d9u95SwW00VPHuCNxPap6Q1+E/xM5QThb9Hu+P6EGuu6lIeLaNBMmFZyblwFbwrH+WBOZlvIzDhi4Dm/6Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "utif": "^2.0.1" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/types": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/types/-/types-0.16.13.tgz", - "integrity": "sha512-mC0yVNUobFDjoYLg4hoUwzMKgNlxynzwt3cDXzumGvRJ7Kb8qQGOWJQjQFo5OxmGExqzPphkirdbBF88RVLBCg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/bmp": "^0.16.13", - "@jimp/gif": "^0.16.13", - "@jimp/jpeg": "^0.16.13", - "@jimp/png": "^0.16.13", - "@jimp/tiff": "^0.16.13", - "timm": "^1.6.1" - }, - "peerDependencies": { - "@jimp/custom": ">=0.3.5" - } - }, - "node_modules/@jimp/utils": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/@jimp/utils/-/utils-0.16.13.tgz", - "integrity": "sha512-VyCpkZzFTHXtKgVO35iKN0sYR10psGpV6SkcSeV4oF7eSYlR8Bl6aQLCzVeFjvESF7mxTmIiI3/XrMobVrtxDA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "regenerator-runtime": "^0.13.3" + "node": ">=16 || 14 >=14.17" } }, "node_modules/@jridgewell/gen-mapping": { @@ -2679,9 +2300,9 @@ "license": "MIT" }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.30", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.30.tgz", - "integrity": "sha512-GQ7Nw5G2lTu/BtHTKfXhKHok2WGetd4XYcVKGx00SjAk8GMwgJM3zr6zORiPGuOE+/vkc90KtTosSSvaCjKb2Q==", + "version": "0.3.31", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz", + "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==", "license": "MIT", "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", @@ -2692,7 +2313,8 @@ "version": "1.2.3", "resolved": "https://registry.npmjs.org/@lezer/common/-/common-1.2.3.tgz", "integrity": "sha512-w7ojc8ejBqr2REPsWxJjrMFsA/ysDCFICn8zEOR9mrqzOu2amhITYuLD8ag6XZf0CFXDrhKqw7+tW8cX66NaDA==", - "license": "MIT" + "license": "MIT", + "peer": true }, "node_modules/@lezer/cpp": { "version": "1.1.3", @@ -2732,14 +2354,15 @@ "resolved": "https://registry.npmjs.org/@lezer/highlight/-/highlight-1.2.1.tgz", "integrity": "sha512-Z5duk4RN/3zuVO7Jq0pGLJ3qynpxUVsh7IbUbGj88+uV2ApSAn6kWg2au3iJb+0Zi7kKtqffIESgNcRXWZWmSA==", "license": "MIT", + "peer": true, "dependencies": { "@lezer/common": "^1.0.0" } }, "node_modules/@lezer/html": { - "version": "1.3.10", - "resolved": "https://registry.npmjs.org/@lezer/html/-/html-1.3.10.tgz", - "integrity": "sha512-dqpT8nISx/p9Do3AchvYGV3qYc4/rKr3IBZxlHmpIKam56P47RSHkSF5f13Vu9hebS1jM0HmtJIwLbWz1VIY6w==", + "version": "1.3.12", + "resolved": "https://registry.npmjs.org/@lezer/html/-/html-1.3.12.tgz", + "integrity": "sha512-RJ7eRWdaJe3bsiiLLHjCFT1JMk8m1YP9kaUbvu2rMLEoOnke9mcTVDyfOslsln0LtujdWespjJ39w6zo+RsQYw==", "license": "MIT", "dependencies": { "@lezer/common": "^1.2.0", @@ -2759,10 +2382,11 @@ } }, "node_modules/@lezer/javascript": { - "version": "1.5.3", - "resolved": "https://registry.npmjs.org/@lezer/javascript/-/javascript-1.5.3.tgz", - "integrity": "sha512-jexmlKq5NpGiB7t+0QkyhSXRgaiab5YisHIQW9C7EcU19KSUsDguZe9WY+rmRDg34nXoNH2LQ4SxpC+aJUchSQ==", + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@lezer/javascript/-/javascript-1.5.4.tgz", + "integrity": "sha512-vvYx3MhWqeZtGPwDStM2dwgljd5smolYD2lR2UyFcHfxbBQebqx8yjmFmxtJ/E6nN6u1D9srOiVWm3Rb4tmcUA==", "license": "MIT", + "peer": true, "dependencies": { "@lezer/common": "^1.2.0", "@lezer/highlight": "^1.1.3", @@ -2785,6 +2409,7 @@ "resolved": "https://registry.npmjs.org/@lezer/lr/-/lr-1.4.2.tgz", "integrity": "sha512-pu0K1jCIdnQ12aWNaAVU5bzi7Bd1w54J3ECgANPmYLtQKP0HBj2cE/5coBD66MT10xbtIuUr7tg0Shbsvk0mDA==", "license": "MIT", + "peer": true, "dependencies": { "@lezer/common": "^1.0.0" } @@ -2800,9 +2425,9 @@ } }, "node_modules/@lezer/php": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/@lezer/php/-/php-1.0.4.tgz", - "integrity": "sha512-D2dJ0t8Z28/G1guztRczMFvPDUqzeMLSQbdWQmaiHV7urc8NlEOnjYk9UrZ531OcLiRxD4Ihcbv7AsDpNKDRaQ==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@lezer/php/-/php-1.0.5.tgz", + "integrity": "sha512-W7asp9DhM6q0W6DYNwIkLSKOvxlXRrif+UXBMxzsJUuqmhE7oVU+gS3THO4S/Puh7Xzgm858UNaFi6dxTP8dJA==", "license": "MIT", "dependencies": { "@lezer/common": "^1.2.0", @@ -2904,6 +2529,24 @@ "node": ">= 10.0.0" } }, + "node_modules/@malept/flatpak-bundler/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@malept/flatpak-bundler/node_modules/fs-extra": { "version": "9.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", @@ -2933,6 +2576,13 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/@malept/flatpak-bundler/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@malept/flatpak-bundler/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -2949,6 +2599,282 @@ "integrity": "sha512-l0h88YhZFyKdXIFNfSWpyjStDjGHwZ/U7iobcK1cQQD8sejsONdQtTVU+1wVN1PBw40PiiHB1vA5S7VTfQiP9g==", "license": "MIT" }, + "node_modules/@monaco-editor/loader": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@monaco-editor/loader/-/loader-1.5.0.tgz", + "integrity": "sha512-hKoGSM+7aAc7eRTRjpqAZucPmoNOC4UUbknb/VNoTkEIkCPhqV8LfbsgM1webRM7S/z21eHEx9Fkwx8Z/C/+Xw==", + "license": "MIT", + "dependencies": { + "state-local": "^1.0.6" + } + }, + "node_modules/@monaco-editor/react": { + "version": "4.7.0", + "resolved": "https://registry.npmjs.org/@monaco-editor/react/-/react-4.7.0.tgz", + "integrity": "sha512-cyzXQCtO47ydzxpQtCGSQGOC8Gk3ZUeBXFAxD+CWXYFo5OqZyZUonFl0DwUlTyAfRHntBfw2p3w4s9R6oe1eCA==", + "license": "MIT", + "dependencies": { + "@monaco-editor/loader": "^1.5.0" + }, + "peerDependencies": { + "monaco-editor": ">= 0.25.0 < 1", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + } + }, + "node_modules/@mux/mux-data-google-ima": { + "version": "0.2.8", + "resolved": "https://registry.npmjs.org/@mux/mux-data-google-ima/-/mux-data-google-ima-0.2.8.tgz", + "integrity": "sha512-0ZEkHdcZ6bS8QtcjFcoJeZxJTpX7qRIledf4q1trMWPznugvtajCjCM2kieK/pzkZj1JM6liDRFs1PJSfVUs2A==", + "license": "MIT", + "dependencies": { + "mux-embed": "5.9.0" + } + }, + "node_modules/@mux/mux-player": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/@mux/mux-player/-/mux-player-3.6.1.tgz", + "integrity": "sha512-QidL9CSkRBwa49ItphuDXWtarAiskP8AG/+vj5u0LsCa+VqObQxPfxE9t5S9YO/SDYHXqDMviMpmSzotSROGUQ==", + "license": "MIT", + "dependencies": { + "@mux/mux-video": "0.27.0", + "@mux/playback-core": "0.31.0", + "media-chrome": "~4.14.0", + "player.style": "^0.2.0" + } + }, + "node_modules/@mux/mux-player-react": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/@mux/mux-player-react/-/mux-player-react-3.6.1.tgz", + "integrity": "sha512-YKIieu9GmFI73+1EcAvd63ftZ0Z9ilGbWo2dGXqQeyCEcagIN0oEcXWUPuIuxhvYB0XXsxB8RBAD8SigHkCYAQ==", + "license": "MIT", + "dependencies": { + "@mux/mux-player": "3.6.1", + "@mux/playback-core": "0.31.0", + "prop-types": "^15.8.1" + }, + "peerDependencies": { + "@types/react": "^17.0.0 || ^17.0.0-0 || ^18 || ^18.0.0-0 || ^19 || ^19.0.0-0", + "react": "^17.0.2 || ^17.0.0-0 || ^18 || ^18.0.0-0 || ^19 || ^19.0.0-0", + "react-dom": "^17.0.2 || ^17.0.2-0 || ^18 || ^18.0.0-0 || ^19 || ^19.0.0-0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@mux/mux-video": { + "version": "0.27.0", + "resolved": "https://registry.npmjs.org/@mux/mux-video/-/mux-video-0.27.0.tgz", + "integrity": "sha512-Oi142YAcPKrmHTG+eaWHWaE7ucMHeJwx1FXABbLM2hMGj9MQ7kYjsD5J3meFlvuyz5UeVDsPLHeUJgeBXUZovg==", + "license": "MIT", + "dependencies": { + "@mux/mux-data-google-ima": "0.2.8", + "@mux/playback-core": "0.31.0", + "castable-video": "~1.1.10", + "custom-media-element": "~1.4.5", + "media-tracks": "~0.3.3" + } + }, + "node_modules/@mux/playback-core": { + "version": "0.31.0", + "resolved": "https://registry.npmjs.org/@mux/playback-core/-/playback-core-0.31.0.tgz", + "integrity": "sha512-VADcrtS4O6fQBH8qmgavS6h7v7amzy2oCguu1NnLaVZ3Z8WccNXcF0s7jPRoRDyXWGShgtVhypW2uXjLpkPxyw==", + "license": "MIT", + "dependencies": { + "hls.js": "~1.6.6", + "mux-embed": "^5.8.3" + } + }, + "node_modules/@napi-rs/canvas": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas/-/canvas-0.1.80.tgz", + "integrity": "sha512-DxuT1ClnIPts1kQx8FBmkk4BQDTfI5kIzywAaMjQSXfNnra5UFU9PwurXrl+Je3bJ6BGsp/zmshVVFbCmyI+ww==", + "license": "MIT", + "optional": true, + "workspaces": [ + "e2e/*" + ], + "engines": { + "node": ">= 10" + }, + "optionalDependencies": { + "@napi-rs/canvas-android-arm64": "0.1.80", + "@napi-rs/canvas-darwin-arm64": "0.1.80", + "@napi-rs/canvas-darwin-x64": "0.1.80", + "@napi-rs/canvas-linux-arm-gnueabihf": "0.1.80", + "@napi-rs/canvas-linux-arm64-gnu": "0.1.80", + "@napi-rs/canvas-linux-arm64-musl": "0.1.80", + "@napi-rs/canvas-linux-riscv64-gnu": "0.1.80", + "@napi-rs/canvas-linux-x64-gnu": "0.1.80", + "@napi-rs/canvas-linux-x64-musl": "0.1.80", + "@napi-rs/canvas-win32-x64-msvc": "0.1.80" + } + }, + "node_modules/@napi-rs/canvas-android-arm64": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-android-arm64/-/canvas-android-arm64-0.1.80.tgz", + "integrity": "sha512-sk7xhN/MoXeuExlggf91pNziBxLPVUqF2CAVnB57KLG/pz7+U5TKG8eXdc3pm0d7Od0WreB6ZKLj37sX9muGOQ==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-darwin-arm64": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-darwin-arm64/-/canvas-darwin-arm64-0.1.80.tgz", + "integrity": "sha512-O64APRTXRUiAz0P8gErkfEr3lipLJgM6pjATwavZ22ebhjYl/SUbpgM0xcWPQBNMP1n29afAC/Us5PX1vg+JNQ==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-darwin-x64": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-darwin-x64/-/canvas-darwin-x64-0.1.80.tgz", + "integrity": "sha512-FqqSU7qFce0Cp3pwnTjVkKjjOtxMqRe6lmINxpIZYaZNnVI0H5FtsaraZJ36SiTHNjZlUB69/HhxNDT1Aaa9vA==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-arm-gnueabihf": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-arm-gnueabihf/-/canvas-linux-arm-gnueabihf-0.1.80.tgz", + "integrity": "sha512-eyWz0ddBDQc7/JbAtY4OtZ5SpK8tR4JsCYEZjCE3dI8pqoWUC8oMwYSBGCYfsx2w47cQgQCgMVRVTFiiO38hHQ==", + "cpu": [ + "arm" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-arm64-gnu": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-arm64-gnu/-/canvas-linux-arm64-gnu-0.1.80.tgz", + "integrity": "sha512-qwA63t8A86bnxhuA/GwOkK3jvb+XTQaTiVML0vAWoHyoZYTjNs7BzoOONDgTnNtr8/yHrq64XXzUoLqDzU+Uuw==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-arm64-musl": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-arm64-musl/-/canvas-linux-arm64-musl-0.1.80.tgz", + "integrity": "sha512-1XbCOz/ymhj24lFaIXtWnwv/6eFHXDrjP0jYkc6iHQ9q8oXKzUX1Lc6bu+wuGiLhGh2GS/2JlfORC5ZcXimRcg==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-riscv64-gnu": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-riscv64-gnu/-/canvas-linux-riscv64-gnu-0.1.80.tgz", + "integrity": "sha512-XTzR125w5ZMs0lJcxRlS1K3P5RaZ9RmUsPtd1uGt+EfDyYMu4c6SEROYsxyatbbu/2+lPe7MPHOO/0a0x7L/gw==", + "cpu": [ + "riscv64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-x64-gnu": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-x64-gnu/-/canvas-linux-x64-gnu-0.1.80.tgz", + "integrity": "sha512-BeXAmhKg1kX3UCrJsYbdQd3hIMDH/K6HnP/pG2LuITaXhXBiNdh//TVVVVCBbJzVQaV5gK/4ZOCMrQW9mvuTqA==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-linux-x64-musl": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-linux-x64-musl/-/canvas-linux-x64-musl-0.1.80.tgz", + "integrity": "sha512-x0XvZWdHbkgdgucJsRxprX/4o4sEed7qo9rCQA9ugiS9qE2QvP0RIiEugtZhfLH3cyI+jIRFJHV4Fuz+1BHHMg==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@napi-rs/canvas-win32-x64-msvc": { + "version": "0.1.80", + "resolved": "https://registry.npmjs.org/@napi-rs/canvas-win32-x64-msvc/-/canvas-win32-x64-msvc-0.1.80.tgz", + "integrity": "sha512-Z8jPsM6df5V8B1HrCHB05+bDiCxjE9QA//3YrkKIdVDEwn5RKaqOxCJDRJkl48cJbylcrJbW4HxZbTte8juuPg==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, "node_modules/@nodelib/fs.scandir": { "version": "2.1.5", "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", @@ -3001,6 +2927,19 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, + "node_modules/@npmcli/fs/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/@npmcli/move-file": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/@npmcli/move-file/-/move-file-2.0.1.tgz", @@ -3016,19 +2955,6 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, - "node_modules/@npmcli/move-file/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", - "bin": { - "mkdirp": "bin/cmd.js" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/@pkgjs/parseargs": { "version": "0.11.0", "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", @@ -3106,33 +3032,6 @@ } } }, - "node_modules/@radix-ui/react-avatar": { - "version": "1.1.10", - "resolved": "https://registry.npmjs.org/@radix-ui/react-avatar/-/react-avatar-1.1.10.tgz", - "integrity": "sha512-V8piFfWapM5OmNCXTzVQY+E1rDa53zY+MQ4Y7356v4fFz6vqCyUtIz2rUD44ZEdwg78/jKmMJHj07+C/Z/rcog==", - "license": "MIT", - "dependencies": { - "@radix-ui/react-context": "1.1.2", - "@radix-ui/react-primitive": "2.1.3", - "@radix-ui/react-use-callback-ref": "1.1.1", - "@radix-ui/react-use-is-hydrated": "0.1.0", - "@radix-ui/react-use-layout-effect": "1.1.1" - }, - "peerDependencies": { - "@types/react": "*", - "@types/react-dom": "*", - "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", - "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" - }, - "peerDependenciesMeta": { - "@types/react": { - "optional": true - }, - "@types/react-dom": { - "optional": true - } - } - }, "node_modules/@radix-ui/react-checkbox": { "version": "1.3.3", "resolved": "https://registry.npmjs.org/@radix-ui/react-checkbox/-/react-checkbox-1.3.3.tgz", @@ -3769,39 +3668,6 @@ } } }, - "node_modules/@radix-ui/react-slider": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/@radix-ui/react-slider/-/react-slider-1.3.6.tgz", - "integrity": "sha512-JPYb1GuM1bxfjMRlNLE+BcmBC8onfCi60Blk7OBqi2MLTFdS+8401U4uFjnwkOr49BLmXxLC6JHkvAsx5OJvHw==", - "license": "MIT", - "dependencies": { - "@radix-ui/number": "1.1.1", - "@radix-ui/primitive": "1.1.3", - "@radix-ui/react-collection": "1.1.7", - "@radix-ui/react-compose-refs": "1.1.2", - "@radix-ui/react-context": "1.1.2", - "@radix-ui/react-direction": "1.1.1", - "@radix-ui/react-primitive": "2.1.3", - "@radix-ui/react-use-controllable-state": "1.2.2", - "@radix-ui/react-use-layout-effect": "1.1.1", - "@radix-ui/react-use-previous": "1.1.1", - "@radix-ui/react-use-size": "1.1.1" - }, - "peerDependencies": { - "@types/react": "*", - "@types/react-dom": "*", - "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", - "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" - }, - "peerDependenciesMeta": { - "@types/react": { - "optional": true - }, - "@types/react-dom": { - "optional": true - } - } - }, "node_modules/@radix-ui/react-slot": { "version": "1.2.3", "resolved": "https://registry.npmjs.org/@radix-ui/react-slot/-/react-slot-1.2.3.tgz", @@ -3983,24 +3849,6 @@ } } }, - "node_modules/@radix-ui/react-use-is-hydrated": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/@radix-ui/react-use-is-hydrated/-/react-use-is-hydrated-0.1.0.tgz", - "integrity": "sha512-U+UORVEq+cTnRIaostJv9AGdV3G6Y+zbVd+12e18jQ5A3c0xL03IhnHuiU4UV69wolOQp5GfR58NW/EgdQhwOA==", - "license": "MIT", - "dependencies": { - "use-sync-external-store": "^1.5.0" - }, - "peerDependencies": { - "@types/react": "*", - "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" - }, - "peerDependenciesMeta": { - "@types/react": { - "optional": true - } - } - }, "node_modules/@radix-ui/react-use-layout-effect": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@radix-ui/react-use-layout-effect/-/react-use-layout-effect-1.1.1.tgz", @@ -4150,9 +3998,9 @@ "license": "MIT" }, "node_modules/@rollup/rollup-android-arm-eabi": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.50.1.tgz", - "integrity": "sha512-HJXwzoZN4eYTdD8bVV22DN8gsPCAj3V20NHKOs8ezfXanGpmVPR7kalUHd+Y31IJp9stdB87VKPFbsGY3H/2ag==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.52.3.tgz", + "integrity": "sha512-h6cqHGZ6VdnwliFG1NXvMPTy/9PS3h8oLh7ImwR+kl+oYnQizgjxsONmmPSb2C66RksfkfIxEVtDSEcJiO0tqw==", "cpu": [ "arm" ], @@ -4163,9 +4011,9 @@ ] }, "node_modules/@rollup/rollup-android-arm64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.50.1.tgz", - "integrity": "sha512-PZlsJVcjHfcH53mOImyt3bc97Ep3FJDXRpk9sMdGX0qgLmY0EIWxCag6EigerGhLVuL8lDVYNnSo8qnTElO4xw==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.52.3.tgz", + "integrity": "sha512-wd+u7SLT/u6knklV/ifG7gr5Qy4GUbH2hMWcDauPFJzmCZUAJ8L2bTkVXC2niOIxp8lk3iH/QX8kSrUxVZrOVw==", "cpu": [ "arm64" ], @@ -4176,9 +4024,9 @@ ] }, "node_modules/@rollup/rollup-darwin-arm64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.50.1.tgz", - "integrity": "sha512-xc6i2AuWh++oGi4ylOFPmzJOEeAa2lJeGUGb4MudOtgfyyjr4UPNK+eEWTPLvmPJIY/pgw6ssFIox23SyrkkJw==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.52.3.tgz", + "integrity": "sha512-lj9ViATR1SsqycwFkJCtYfQTheBdvlWJqzqxwc9f2qrcVrQaF/gCuBRTiTolkRWS6KvNxSk4KHZWG7tDktLgjg==", "cpu": [ "arm64" ], @@ -4189,9 +4037,9 @@ ] }, "node_modules/@rollup/rollup-darwin-x64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.50.1.tgz", - "integrity": "sha512-2ofU89lEpDYhdLAbRdeyz/kX3Y2lpYc6ShRnDjY35bZhd2ipuDMDi6ZTQ9NIag94K28nFMofdnKeHR7BT0CATw==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.52.3.tgz", + "integrity": "sha512-+Dyo7O1KUmIsbzx1l+4V4tvEVnVQqMOIYtrxK7ncLSknl1xnMHLgn7gddJVrYPNZfEB8CIi3hK8gq8bDhb3h5A==", "cpu": [ "x64" ], @@ -4202,9 +4050,9 @@ ] }, "node_modules/@rollup/rollup-freebsd-arm64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.50.1.tgz", - "integrity": "sha512-wOsE6H2u6PxsHY/BeFHA4VGQN3KUJFZp7QJBmDYI983fgxq5Th8FDkVuERb2l9vDMs1D5XhOrhBrnqcEY6l8ZA==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.52.3.tgz", + "integrity": "sha512-u9Xg2FavYbD30g3DSfNhxgNrxhi6xVG4Y6i9Ur1C7xUuGDW3banRbXj+qgnIrwRN4KeJ396jchwy9bCIzbyBEQ==", "cpu": [ "arm64" ], @@ -4215,9 +4063,9 @@ ] }, "node_modules/@rollup/rollup-freebsd-x64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.50.1.tgz", - "integrity": "sha512-A/xeqaHTlKbQggxCqispFAcNjycpUEHP52mwMQZUNqDUJFFYtPHCXS1VAG29uMlDzIVr+i00tSFWFLivMcoIBQ==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.52.3.tgz", + "integrity": "sha512-5M8kyi/OX96wtD5qJR89a/3x5x8x5inXBZO04JWhkQb2JWavOWfjgkdvUqibGJeNNaz1/Z1PPza5/tAPXICI6A==", "cpu": [ "x64" ], @@ -4228,9 +4076,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm-gnueabihf": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.50.1.tgz", - "integrity": "sha512-54v4okehwl5TaSIkpp97rAHGp7t3ghinRd/vyC1iXqXMfjYUTm7TfYmCzXDoHUPTTf36L8pr0E7YsD3CfB3ZDg==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.52.3.tgz", + "integrity": "sha512-IoerZJ4l1wRMopEHRKOO16e04iXRDyZFZnNZKrWeNquh5d6bucjezgd+OxG03mOMTnS1x7hilzb3uURPkJ0OfA==", "cpu": [ "arm" ], @@ -4241,9 +4089,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm-musleabihf": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.50.1.tgz", - "integrity": "sha512-p/LaFyajPN/0PUHjv8TNyxLiA7RwmDoVY3flXHPSzqrGcIp/c2FjwPPP5++u87DGHtw+5kSH5bCJz0mvXngYxw==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.52.3.tgz", + "integrity": "sha512-ZYdtqgHTDfvrJHSh3W22TvjWxwOgc3ThK/XjgcNGP2DIwFIPeAPNsQxrJO5XqleSlgDux2VAoWQ5iJrtaC1TbA==", "cpu": [ "arm" ], @@ -4254,9 +4102,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.50.1.tgz", - "integrity": "sha512-2AbMhFFkTo6Ptna1zO7kAXXDLi7H9fGTbVaIq2AAYO7yzcAsuTNWPHhb2aTA6GPiP+JXh85Y8CiS54iZoj4opw==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.52.3.tgz", + "integrity": "sha512-NcViG7A0YtuFDA6xWSgmFb6iPFzHlf5vcqb2p0lGEbT+gjrEEz8nC/EeDHvx6mnGXnGCC1SeVV+8u+smj0CeGQ==", "cpu": [ "arm64" ], @@ -4267,9 +4115,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-musl": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.50.1.tgz", - "integrity": "sha512-Cgef+5aZwuvesQNw9eX7g19FfKX5/pQRIyhoXLCiBOrWopjo7ycfB292TX9MDcDijiuIJlx1IzJz3IoCPfqs9w==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.52.3.tgz", + "integrity": "sha512-d3pY7LWno6SYNXRm6Ebsq0DJGoiLXTb83AIPCXl9fmtIQs/rXoS8SJxxUNtFbJ5MiOvs+7y34np77+9l4nfFMw==", "cpu": [ "arm64" ], @@ -4279,10 +4127,10 @@ "linux" ] }, - "node_modules/@rollup/rollup-linux-loongarch64-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.50.1.tgz", - "integrity": "sha512-RPhTwWMzpYYrHrJAS7CmpdtHNKtt2Ueo+BlLBjfZEhYBhK00OsEqM08/7f+eohiF6poe0YRDDd8nAvwtE/Y62Q==", + "node_modules/@rollup/rollup-linux-loong64-gnu": { + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.52.3.tgz", + "integrity": "sha512-3y5GA0JkBuirLqmjwAKwB0keDlI6JfGYduMlJD/Rl7fvb4Ni8iKdQs1eiunMZJhwDWdCvrcqXRY++VEBbvk6Eg==", "cpu": [ "loong64" ], @@ -4293,9 +4141,9 @@ ] }, "node_modules/@rollup/rollup-linux-ppc64-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.50.1.tgz", - "integrity": "sha512-eSGMVQw9iekut62O7eBdbiccRguuDgiPMsw++BVUg+1K7WjZXHOg/YOT9SWMzPZA+w98G+Fa1VqJgHZOHHnY0Q==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.52.3.tgz", + "integrity": "sha512-AUUH65a0p3Q0Yfm5oD2KVgzTKgwPyp9DSXc3UA7DtxhEb/WSPfbG4wqXeSN62OG5gSo18em4xv6dbfcUGXcagw==", "cpu": [ "ppc64" ], @@ -4306,9 +4154,9 @@ ] }, "node_modules/@rollup/rollup-linux-riscv64-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.50.1.tgz", - "integrity": "sha512-S208ojx8a4ciIPrLgazF6AgdcNJzQE4+S9rsmOmDJkusvctii+ZvEuIC4v/xFqzbuP8yDjn73oBlNDgF6YGSXQ==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.52.3.tgz", + "integrity": "sha512-1makPhFFVBqZE+XFg3Dkq+IkQ7JvmUrwwqaYBL2CE+ZpxPaqkGaiWFEWVGyvTwZace6WLJHwjVh/+CXbKDGPmg==", "cpu": [ "riscv64" ], @@ -4319,9 +4167,9 @@ ] }, "node_modules/@rollup/rollup-linux-riscv64-musl": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.50.1.tgz", - "integrity": "sha512-3Ag8Ls1ggqkGUvSZWYcdgFwriy2lWo+0QlYgEFra/5JGtAd6C5Hw59oojx1DeqcA2Wds2ayRgvJ4qxVTzCHgzg==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.52.3.tgz", + "integrity": "sha512-OOFJa28dxfl8kLOPMUOQBCO6z3X2SAfzIE276fwT52uXDWUS178KWq0pL7d6p1kz7pkzA0yQwtqL0dEPoVcRWg==", "cpu": [ "riscv64" ], @@ -4332,9 +4180,9 @@ ] }, "node_modules/@rollup/rollup-linux-s390x-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.50.1.tgz", - "integrity": "sha512-t9YrKfaxCYe7l7ldFERE1BRg/4TATxIg+YieHQ966jwvo7ddHJxPj9cNFWLAzhkVsbBvNA4qTbPVNsZKBO4NSg==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.52.3.tgz", + "integrity": "sha512-jMdsML2VI5l+V7cKfZx3ak+SLlJ8fKvLJ0Eoa4b9/vCUrzXKgoKxvHqvJ/mkWhFiyp88nCkM5S2v6nIwRtPcgg==", "cpu": [ "s390x" ], @@ -4345,9 +4193,9 @@ ] }, "node_modules/@rollup/rollup-linux-x64-gnu": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.50.1.tgz", - "integrity": "sha512-MCgtFB2+SVNuQmmjHf+wfI4CMxy3Tk8XjA5Z//A0AKD7QXUYFMQcns91K6dEHBvZPCnhJSyDWLApk40Iq/H3tA==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.52.3.tgz", + "integrity": "sha512-tPgGd6bY2M2LJTA1uGq8fkSPK8ZLYjDjY+ZLK9WHncCnfIz29LIXIqUgzCR0hIefzy6Hpbe8Th5WOSwTM8E7LA==", "cpu": [ "x64" ], @@ -4358,9 +4206,9 @@ ] }, "node_modules/@rollup/rollup-linux-x64-musl": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.50.1.tgz", - "integrity": "sha512-nEvqG+0jeRmqaUMuwzlfMKwcIVffy/9KGbAGyoa26iu6eSngAYQ512bMXuqqPrlTyfqdlB9FVINs93j534UJrg==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.52.3.tgz", + "integrity": "sha512-BCFkJjgk+WFzP+tcSMXq77ymAPIxsX9lFJWs+2JzuZTLtksJ2o5hvgTdIcZ5+oKzUDMwI0PfWzRBYAydAHF2Mw==", "cpu": [ "x64" ], @@ -4371,9 +4219,9 @@ ] }, "node_modules/@rollup/rollup-openharmony-arm64": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.50.1.tgz", - "integrity": "sha512-RDsLm+phmT3MJd9SNxA9MNuEAO/J2fhW8GXk62G/B4G7sLVumNFbRwDL6v5NrESb48k+QMqdGbHgEtfU0LCpbA==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.52.3.tgz", + "integrity": "sha512-KTD/EqjZF3yvRaWUJdD1cW+IQBk4fbQaHYJUmP8N4XoKFZilVL8cobFSTDnjTtxWJQ3JYaMgF4nObY/+nYkumA==", "cpu": [ "arm64" ], @@ -4384,9 +4232,9 @@ ] }, "node_modules/@rollup/rollup-win32-arm64-msvc": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.50.1.tgz", - "integrity": "sha512-hpZB/TImk2FlAFAIsoElM3tLzq57uxnGYwplg6WDyAxbYczSi8O2eQ+H2Lx74504rwKtZ3N2g4bCUkiamzS6TQ==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.52.3.tgz", + "integrity": "sha512-+zteHZdoUYLkyYKObGHieibUFLbttX2r+58l27XZauq0tcWYYuKUwY2wjeCN9oK1Um2YgH2ibd6cnX/wFD7DuA==", "cpu": [ "arm64" ], @@ -4397,9 +4245,9 @@ ] }, "node_modules/@rollup/rollup-win32-ia32-msvc": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.50.1.tgz", - "integrity": "sha512-SXjv8JlbzKM0fTJidX4eVsH+Wmnp0/WcD8gJxIZyR6Gay5Qcsmdbi9zVtnbkGPG8v2vMR1AD06lGWy5FLMcG7A==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.52.3.tgz", + "integrity": "sha512-of1iHkTQSo3kr6dTIRX6t81uj/c/b15HXVsPcEElN5sS859qHrOepM5p9G41Hah+CTqSh2r8Bm56dL2z9UQQ7g==", "cpu": [ "ia32" ], @@ -4409,10 +4257,10 @@ "win32" ] }, - "node_modules/@rollup/rollup-win32-x64-msvc": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.50.1.tgz", - "integrity": "sha512-StxAO/8ts62KZVRAm4JZYq9+NqNsV7RvimNK+YM7ry//zebEH6meuugqW/P5OFUCjyQgui+9fUxT6d5NShvMvA==", + "node_modules/@rollup/rollup-win32-x64-gnu": { + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.52.3.tgz", + "integrity": "sha512-s0hybmlHb56mWVZQj8ra9048/WZTPLILKxcvcq+8awSZmyiSUZjjem1AhU3Tf4ZKpYhK4mg36HtHDOe8QJS5PQ==", "cpu": [ "x64" ], @@ -4422,29 +4270,18 @@ "win32" ] }, - "node_modules/@sideway/address": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.5.tgz", - "integrity": "sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==", - "dev": true, - "license": "BSD-3-Clause", - "dependencies": { - "@hapi/hoek": "^9.0.0" - } - }, - "node_modules/@sideway/formula": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", - "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==", - "dev": true, - "license": "BSD-3-Clause" - }, - "node_modules/@sideway/pinpoint": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", - "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==", - "dev": true, - "license": "BSD-3-Clause" + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.52.3.tgz", + "integrity": "sha512-zGIbEVVXVtauFgl3MRwGWEN36P5ZGenHRMgNw88X5wEhEBpq0XrMEZwOn07+ICrwM17XO5xfMZqh0OldCH5VTA==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] }, "node_modules/@sindresorhus/is": { "version": "4.6.0", @@ -4459,12 +4296,24 @@ "url": "https://github.com/sindresorhus/is?sponsor=1" } }, + "node_modules/@standard-schema/spec": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@standard-schema/spec/-/spec-1.0.0.tgz", + "integrity": "sha512-m2bOd0f2RT9k8QJx1JN85cZYyH1RqFBdlwtkSlf4tBDYLCiiZnv1fIIwacK6cqwXavOydf0NPToMQgpKq+dVlA==", + "license": "MIT" + }, "node_modules/@standard-schema/utils": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/@standard-schema/utils/-/utils-0.3.0.tgz", "integrity": "sha512-e7Mew686owMaPJVNNLs55PUvgz371nKgwsc4vxE49zsODpJEnxgxRo2y/OKrqueavXgZNMDVj3DdHFlaSAeU8g==", "license": "MIT" }, + "node_modules/@svta/common-media-library": { + "version": "0.12.4", + "resolved": "https://registry.npmjs.org/@svta/common-media-library/-/common-media-library-0.12.4.tgz", + "integrity": "sha512-9EuOoaNmz7JrfGwjsrD9SxF9otU5TNMnbLu1yU4BeLK0W5cDxVXXR58Z89q9u2AnHjIctscjMTYdlqQ1gojTuw==", + "license": "Apache-2.0" + }, "node_modules/@swc/core": { "version": "1.13.5", "resolved": "https://registry.npmjs.org/@swc/core/-/core-1.13.5.tgz", @@ -4705,52 +4554,52 @@ } }, "node_modules/@tailwindcss/node": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/node/-/node-4.1.13.tgz", - "integrity": "sha512-eq3ouolC1oEFOAvOMOBAmfCIqZBJuvWvvYWh5h5iOYfe1HFC6+GZ6EIL0JdM3/niGRJmnrOc+8gl9/HGUaaptw==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/node/-/node-4.1.14.tgz", + "integrity": "sha512-hpz+8vFk3Ic2xssIA3e01R6jkmsAhvkQdXlEbRTk6S10xDAtiQiM3FyvZVGsucefq764euO/b8WUW9ysLdThHw==", "license": "MIT", "dependencies": { "@jridgewell/remapping": "^2.3.4", "enhanced-resolve": "^5.18.3", - "jiti": "^2.5.1", + "jiti": "^2.6.0", "lightningcss": "1.30.1", - "magic-string": "^0.30.18", + "magic-string": "^0.30.19", "source-map-js": "^1.2.1", - "tailwindcss": "4.1.13" + "tailwindcss": "4.1.14" } }, "node_modules/@tailwindcss/oxide": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide/-/oxide-4.1.13.tgz", - "integrity": "sha512-CPgsM1IpGRa880sMbYmG1s4xhAy3xEt1QULgTJGQmZUeNgXFR7s1YxYygmJyBGtou4SyEosGAGEeYqY7R53bIA==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide/-/oxide-4.1.14.tgz", + "integrity": "sha512-23yx+VUbBwCg2x5XWdB8+1lkPajzLmALEfMb51zZUBYaYVPDQvBSD/WYDqiVyBIo2BZFa3yw1Rpy3G2Jp+K0dw==", "hasInstallScript": true, "license": "MIT", "dependencies": { "detect-libc": "^2.0.4", - "tar": "^7.4.3" + "tar": "^7.5.1" }, "engines": { "node": ">= 10" }, "optionalDependencies": { - "@tailwindcss/oxide-android-arm64": "4.1.13", - "@tailwindcss/oxide-darwin-arm64": "4.1.13", - "@tailwindcss/oxide-darwin-x64": "4.1.13", - "@tailwindcss/oxide-freebsd-x64": "4.1.13", - "@tailwindcss/oxide-linux-arm-gnueabihf": "4.1.13", - "@tailwindcss/oxide-linux-arm64-gnu": "4.1.13", - "@tailwindcss/oxide-linux-arm64-musl": "4.1.13", - "@tailwindcss/oxide-linux-x64-gnu": "4.1.13", - "@tailwindcss/oxide-linux-x64-musl": "4.1.13", - "@tailwindcss/oxide-wasm32-wasi": "4.1.13", - "@tailwindcss/oxide-win32-arm64-msvc": "4.1.13", - "@tailwindcss/oxide-win32-x64-msvc": "4.1.13" + "@tailwindcss/oxide-android-arm64": "4.1.14", + "@tailwindcss/oxide-darwin-arm64": "4.1.14", + "@tailwindcss/oxide-darwin-x64": "4.1.14", + "@tailwindcss/oxide-freebsd-x64": "4.1.14", + "@tailwindcss/oxide-linux-arm-gnueabihf": "4.1.14", + "@tailwindcss/oxide-linux-arm64-gnu": "4.1.14", + "@tailwindcss/oxide-linux-arm64-musl": "4.1.14", + "@tailwindcss/oxide-linux-x64-gnu": "4.1.14", + "@tailwindcss/oxide-linux-x64-musl": "4.1.14", + "@tailwindcss/oxide-wasm32-wasi": "4.1.14", + "@tailwindcss/oxide-win32-arm64-msvc": "4.1.14", + "@tailwindcss/oxide-win32-x64-msvc": "4.1.14" } }, "node_modules/@tailwindcss/oxide-android-arm64": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-android-arm64/-/oxide-android-arm64-4.1.13.tgz", - "integrity": "sha512-BrpTrVYyejbgGo57yc8ieE+D6VT9GOgnNdmh5Sac6+t0m+v+sKQevpFVpwX3pBrM2qKrQwJ0c5eDbtjouY/+ew==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-android-arm64/-/oxide-android-arm64-4.1.14.tgz", + "integrity": "sha512-a94ifZrGwMvbdeAxWoSuGcIl6/DOP5cdxagid7xJv6bwFp3oebp7y2ImYsnZBMTwjn5Ev5xESvS3FFYUGgPODQ==", "cpu": [ "arm64" ], @@ -4764,9 +4613,9 @@ } }, "node_modules/@tailwindcss/oxide-darwin-arm64": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-arm64/-/oxide-darwin-arm64-4.1.13.tgz", - "integrity": "sha512-YP+Jksc4U0KHcu76UhRDHq9bx4qtBftp9ShK/7UGfq0wpaP96YVnnjFnj3ZFrUAjc5iECzODl/Ts0AN7ZPOANQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-arm64/-/oxide-darwin-arm64-4.1.14.tgz", + "integrity": "sha512-HkFP/CqfSh09xCnrPJA7jud7hij5ahKyWomrC3oiO2U9i0UjP17o9pJbxUN0IJ471GTQQmzwhp0DEcpbp4MZTA==", "cpu": [ "arm64" ], @@ -4780,9 +4629,9 @@ } }, "node_modules/@tailwindcss/oxide-darwin-x64": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-x64/-/oxide-darwin-x64-4.1.13.tgz", - "integrity": "sha512-aAJ3bbwrn/PQHDxCto9sxwQfT30PzyYJFG0u/BWZGeVXi5Hx6uuUOQEI2Fa43qvmUjTRQNZnGqe9t0Zntexeuw==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-x64/-/oxide-darwin-x64-4.1.14.tgz", + "integrity": "sha512-eVNaWmCgdLf5iv6Qd3s7JI5SEFBFRtfm6W0mphJYXgvnDEAZ5sZzqmI06bK6xo0IErDHdTA5/t7d4eTfWbWOFw==", "cpu": [ "x64" ], @@ -4796,9 +4645,9 @@ } }, "node_modules/@tailwindcss/oxide-freebsd-x64": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-freebsd-x64/-/oxide-freebsd-x64-4.1.13.tgz", - "integrity": "sha512-Wt8KvASHwSXhKE/dJLCCWcTSVmBj3xhVhp/aF3RpAhGeZ3sVo7+NTfgiN8Vey/Fi8prRClDs6/f0KXPDTZE6nQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-freebsd-x64/-/oxide-freebsd-x64-4.1.14.tgz", + "integrity": "sha512-QWLoRXNikEuqtNb0dhQN6wsSVVjX6dmUFzuuiL09ZeXju25dsei2uIPl71y2Ic6QbNBsB4scwBoFnlBfabHkEw==", "cpu": [ "x64" ], @@ -4812,9 +4661,9 @@ } }, "node_modules/@tailwindcss/oxide-linux-arm-gnueabihf": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm-gnueabihf/-/oxide-linux-arm-gnueabihf-4.1.13.tgz", - "integrity": "sha512-mbVbcAsW3Gkm2MGwA93eLtWrwajz91aXZCNSkGTx/R5eb6KpKD5q8Ueckkh9YNboU8RH7jiv+ol/I7ZyQ9H7Bw==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm-gnueabihf/-/oxide-linux-arm-gnueabihf-4.1.14.tgz", + "integrity": "sha512-VB4gjQni9+F0VCASU+L8zSIyjrLLsy03sjcR3bM0V2g4SNamo0FakZFKyUQ96ZVwGK4CaJsc9zd/obQy74o0Fw==", "cpu": [ "arm" ], @@ -4828,9 +4677,9 @@ } }, "node_modules/@tailwindcss/oxide-linux-arm64-gnu": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-gnu/-/oxide-linux-arm64-gnu-4.1.13.tgz", - "integrity": "sha512-wdtfkmpXiwej/yoAkrCP2DNzRXCALq9NVLgLELgLim1QpSfhQM5+ZxQQF8fkOiEpuNoKLp4nKZ6RC4kmeFH0HQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-gnu/-/oxide-linux-arm64-gnu-4.1.14.tgz", + "integrity": "sha512-qaEy0dIZ6d9vyLnmeg24yzA8XuEAD9WjpM5nIM1sUgQ/Zv7cVkharPDQcmm/t/TvXoKo/0knI3me3AGfdx6w1w==", "cpu": [ "arm64" ], @@ -4844,9 +4693,9 @@ } }, "node_modules/@tailwindcss/oxide-linux-arm64-musl": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-musl/-/oxide-linux-arm64-musl-4.1.13.tgz", - "integrity": "sha512-hZQrmtLdhyqzXHB7mkXfq0IYbxegaqTmfa1p9MBj72WPoDD3oNOh1Lnxf6xZLY9C3OV6qiCYkO1i/LrzEdW2mg==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-musl/-/oxide-linux-arm64-musl-4.1.14.tgz", + "integrity": "sha512-ISZjT44s59O8xKsPEIesiIydMG/sCXoMBCqsphDm/WcbnuWLxxb+GcvSIIA5NjUw6F8Tex7s5/LM2yDy8RqYBQ==", "cpu": [ "arm64" ], @@ -4860,9 +4709,9 @@ } }, "node_modules/@tailwindcss/oxide-linux-x64-gnu": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-gnu/-/oxide-linux-x64-gnu-4.1.13.tgz", - "integrity": "sha512-uaZTYWxSXyMWDJZNY1Ul7XkJTCBRFZ5Fo6wtjrgBKzZLoJNrG+WderJwAjPzuNZOnmdrVg260DKwXCFtJ/hWRQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-gnu/-/oxide-linux-x64-gnu-4.1.14.tgz", + "integrity": "sha512-02c6JhLPJj10L2caH4U0zF8Hji4dOeahmuMl23stk0MU1wfd1OraE7rOloidSF8W5JTHkFdVo/O7uRUJJnUAJg==", "cpu": [ "x64" ], @@ -4876,9 +4725,9 @@ } }, "node_modules/@tailwindcss/oxide-linux-x64-musl": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-musl/-/oxide-linux-x64-musl-4.1.13.tgz", - "integrity": "sha512-oXiPj5mi4Hdn50v5RdnuuIms0PVPI/EG4fxAfFiIKQh5TgQgX7oSuDWntHW7WNIi/yVLAiS+CRGW4RkoGSSgVQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-musl/-/oxide-linux-x64-musl-4.1.14.tgz", + "integrity": "sha512-TNGeLiN1XS66kQhxHG/7wMeQDOoL0S33x9BgmydbrWAb9Qw0KYdd8o1ifx4HOGDWhVmJ+Ul+JQ7lyknQFilO3Q==", "cpu": [ "x64" ], @@ -4892,9 +4741,9 @@ } }, "node_modules/@tailwindcss/oxide-wasm32-wasi": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-wasm32-wasi/-/oxide-wasm32-wasi-4.1.13.tgz", - "integrity": "sha512-+LC2nNtPovtrDwBc/nqnIKYh/W2+R69FA0hgoeOn64BdCX522u19ryLh3Vf3F8W49XBcMIxSe665kwy21FkhvA==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-wasm32-wasi/-/oxide-wasm32-wasi-4.1.14.tgz", + "integrity": "sha512-uZYAsaW/jS/IYkd6EWPJKW/NlPNSkWkBlaeVBi/WsFQNP05/bzkebUL8FH1pdsqx4f2fH/bWFcUABOM9nfiJkQ==", "bundleDependencies": [ "@napi-rs/wasm-runtime", "@emnapi/core", @@ -4909,21 +4758,21 @@ "license": "MIT", "optional": true, "dependencies": { - "@emnapi/core": "^1.4.5", - "@emnapi/runtime": "^1.4.5", - "@emnapi/wasi-threads": "^1.0.4", - "@napi-rs/wasm-runtime": "^0.2.12", - "@tybys/wasm-util": "^0.10.0", - "tslib": "^2.8.0" + "@emnapi/core": "^1.5.0", + "@emnapi/runtime": "^1.5.0", + "@emnapi/wasi-threads": "^1.1.0", + "@napi-rs/wasm-runtime": "^1.0.5", + "@tybys/wasm-util": "^0.10.1", + "tslib": "^2.4.0" }, "engines": { "node": ">=14.0.0" } }, "node_modules/@tailwindcss/oxide-win32-arm64-msvc": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-arm64-msvc/-/oxide-win32-arm64-msvc-4.1.13.tgz", - "integrity": "sha512-dziTNeQXtoQ2KBXmrjCxsuPk3F3CQ/yb7ZNZNA+UkNTeiTGgfeh+gH5Pi7mRncVgcPD2xgHvkFCh/MhZWSgyQg==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-arm64-msvc/-/oxide-win32-arm64-msvc-4.1.14.tgz", + "integrity": "sha512-Az0RnnkcvRqsuoLH2Z4n3JfAef0wElgzHD5Aky/e+0tBUxUhIeIqFBTMNQvmMRSP15fWwmvjBxZ3Q8RhsDnxAA==", "cpu": [ "arm64" ], @@ -4937,9 +4786,9 @@ } }, "node_modules/@tailwindcss/oxide-win32-x64-msvc": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-x64-msvc/-/oxide-win32-x64-msvc-4.1.13.tgz", - "integrity": "sha512-3+LKesjXydTkHk5zXX01b5KMzLV1xl2mcktBJkje7rhFUpUlYJy7IMOLqjIRQncLTa1WZZiFY/foAeB5nmaiTw==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-x64-msvc/-/oxide-win32-x64-msvc-4.1.14.tgz", + "integrity": "sha512-ttblVGHgf68kEE4om1n/n44I0yGPkCPbLsqzjvybhpwa6mKKtgFfAzy6btc3HRmuW7nHe0OOrSeNP9sQmmH9XA==", "cpu": [ "x64" ], @@ -4953,26 +4802,19 @@ } }, "node_modules/@tailwindcss/vite": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/@tailwindcss/vite/-/vite-4.1.13.tgz", - "integrity": "sha512-0PmqLQ010N58SbMTJ7BVJ4I2xopiQn/5i6nlb4JmxzQf8zcS5+m2Cv6tqh+sfDwtIdjoEnOvwsGQ1hkUi8QEHQ==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/@tailwindcss/vite/-/vite-4.1.14.tgz", + "integrity": "sha512-BoFUoU0XqgCUS1UXWhmDJroKKhNXeDzD7/XwabjkDIAbMnc4ULn5e2FuEuBbhZ6ENZoSYzKlzvZ44Yr6EUDUSA==", "license": "MIT", "dependencies": { - "@tailwindcss/node": "4.1.13", - "@tailwindcss/oxide": "4.1.13", - "tailwindcss": "4.1.13" + "@tailwindcss/node": "4.1.14", + "@tailwindcss/oxide": "4.1.14", + "tailwindcss": "4.1.14" }, "peerDependencies": { "vite": "^5.2.0 || ^6 || ^7" } }, - "node_modules/@tokenizer/token": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz", - "integrity": "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==", - "dev": true, - "license": "MIT" - }, "node_modules/@tootallnate/once": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz", @@ -4983,34 +4825,6 @@ "node": ">= 10" } }, - "node_modules/@tsconfig/node10": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", - "integrity": "sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==", - "dev": true, - "license": "MIT" - }, - "node_modules/@tsconfig/node12": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", - "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", - "dev": true, - "license": "MIT" - }, - "node_modules/@tsconfig/node14": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", - "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", - "dev": true, - "license": "MIT" - }, - "node_modules/@tsconfig/node16": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", - "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", - "dev": true, - "license": "MIT" - }, "node_modules/@types/bcryptjs": { "version": "2.4.6", "resolved": "https://registry.npmjs.org/@types/bcryptjs/-/bcryptjs-2.4.6.tgz", @@ -5023,6 +4837,7 @@ "integrity": "sha512-NMv9ASNARoKksWtsq/SHakpYAYnhBrQgGD8zkLYk/jaK8jUGn08CfEdTRgYhMypUQAfzSP8W6gNLe0q19/t4VA==", "devOptional": true, "license": "MIT", + "peer": true, "dependencies": { "@types/node": "*" } @@ -5059,6 +4874,15 @@ "@types/node": "*" } }, + "node_modules/@types/cookie-parser": { + "version": "1.4.9", + "resolved": "https://registry.npmjs.org/@types/cookie-parser/-/cookie-parser-1.4.9.tgz", + "integrity": "sha512-tGZiZ2Gtc4m3wIdLkZ8mkj1T6CEHb35+VApbL2T14Dew8HA7c+04dmKqsKRNC+8RJPm16JEK0tFSwdZqubfc4g==", + "license": "MIT", + "peerDependencies": { + "@types/express": "*" + } + }, "node_modules/@types/cors": { "version": "2.8.19", "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.19.tgz", @@ -5073,7 +4897,6 @@ "version": "4.1.12", "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.12.tgz", "integrity": "sha512-vIChWdVG3LG1SMxEvI/AK+FWJthlrqlTu7fbrlywTkkaONwk/UAGaULXRlf8vkzFBLVm0zkMdCquhL5aOjhXPQ==", - "dev": true, "license": "MIT", "dependencies": { "@types/ms": "*" @@ -5085,11 +4908,21 @@ "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", "license": "MIT" }, + "node_modules/@types/estree-jsx": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree-jsx/-/estree-jsx-1.0.5.tgz", + "integrity": "sha512-52CcUVNFyfb1A2ALocQw/Dd1BQFNmSdkuC3BkZ6iqhdMfQz7JWOFRuJFloOzjk+6WijU56m9oKXFAXc7o3Towg==", + "license": "MIT", + "dependencies": { + "@types/estree": "*" + } + }, "node_modules/@types/express": { "version": "5.0.3", "resolved": "https://registry.npmjs.org/@types/express/-/express-5.0.3.tgz", "integrity": "sha512-wGA0NX93b19/dZC1J18tKWVIYWyyF2ZjT9vin/NRu0qzzvfVzWjs04iq2rQ3H65vCTQYlRqs3YHfY7zjdV+9Kw==", "license": "MIT", + "peer": true, "dependencies": { "@types/body-parser": "*", "@types/express-serve-static-core": "^5.0.0", @@ -5118,6 +4951,15 @@ "@types/node": "*" } }, + "node_modules/@types/hast": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/hast/-/hast-3.0.4.tgz", + "integrity": "sha512-WPs+bbQw5aCj+x6laNGWLH3wviHtoCv/P3+otBhbOhJgG8qtpdAMlTCxLtsTWA7LH1Oh/bFCHsBn0TPS5m30EQ==", + "license": "MIT", + "dependencies": { + "@types/unist": "*" + } + }, "node_modules/@types/http-cache-semantics": { "version": "4.0.4", "resolved": "https://registry.npmjs.org/@types/http-cache-semantics/-/http-cache-semantics-4.0.4.tgz", @@ -5149,6 +4991,15 @@ "@types/node": "*" } }, + "node_modules/@types/jszip": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@types/jszip/-/jszip-3.4.0.tgz", + "integrity": "sha512-GFHqtQQP3R4NNuvZH3hNCYD0NbyBZ42bkN7kO3NDrU/SnvIZWMS8Bp38XCsRKBT5BXvgm0y1zqpZWp/ZkRzBzg==", + "license": "MIT", + "dependencies": { + "jszip": "*" + } + }, "node_modules/@types/keyv": { "version": "3.1.4", "resolved": "https://registry.npmjs.org/@types/keyv/-/keyv-3.1.4.tgz", @@ -5159,6 +5010,15 @@ "@types/node": "*" } }, + "node_modules/@types/mdast": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-4.0.4.tgz", + "integrity": "sha512-kGaNbPh1k7AFzgpud/gMdvIm5xuECykRR+JnWKQno9TAXVa6WIVCGTPvYGekIDL4uwCZQSYbUxNBSb1aUo79oA==", + "license": "MIT", + "dependencies": { + "@types/unist": "*" + } + }, "node_modules/@types/mime": { "version": "1.3.5", "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.5.tgz", @@ -5169,7 +5029,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/@types/ms/-/ms-2.1.0.tgz", "integrity": "sha512-GsCCIZDE/p3i96vtEqx+7dBUGXrc7zeSK3wwPHIaRThS+9OhWIXRqzs4d6k1SVU8g91DrNRWxWUGhp5KXQb2VA==", - "dev": true, "license": "MIT" }, "node_modules/@types/multer": { @@ -5182,12 +5041,12 @@ } }, "node_modules/@types/node": { - "version": "24.3.1", - "resolved": "https://registry.npmjs.org/@types/node/-/node-24.3.1.tgz", - "integrity": "sha512-3vXmQDXy+woz+gnrTvuvNrPzekOi+Ds0ReMxw0LzBiK3a+1k0kQn9f2NWk+lgD4rJehFUmYy2gMhJ2ZI+7YP9g==", + "version": "24.6.1", + "resolved": "https://registry.npmjs.org/@types/node/-/node-24.6.1.tgz", + "integrity": "sha512-ljvjjs3DNXummeIaooB4cLBKg2U6SPI6Hjra/9rRIy7CpM0HpLtG9HptkMKAb4HYWy5S7HUvJEuWgr/y0U8SHw==", "license": "MIT", "dependencies": { - "undici-types": "~7.10.0" + "undici-types": "~7.13.0" } }, "node_modules/@types/plist": { @@ -5224,21 +5083,22 @@ "license": "MIT" }, "node_modules/@types/react": { - "version": "19.1.12", - "resolved": "https://registry.npmjs.org/@types/react/-/react-19.1.12.tgz", - "integrity": "sha512-cMoR+FoAf/Jyq6+Df2/Z41jISvGZZ2eTlnsaJRptmZ76Caldwy1odD4xTr/gNV9VLj0AWgg/nmkevIyUfIIq5w==", - "devOptional": true, + "version": "19.1.17", + "resolved": "https://registry.npmjs.org/@types/react/-/react-19.1.17.tgz", + "integrity": "sha512-Qec1E3mhALmaspIrhWt9jkQMNdw6bReVu64mjvhbhq2NFPftLPVr+l1SZgmw/66WwBNpDh7ao5AT6gF5v41PFA==", "license": "MIT", + "peer": true, "dependencies": { "csstype": "^3.0.2" } }, "node_modules/@types/react-dom": { - "version": "19.1.9", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.1.9.tgz", - "integrity": "sha512-qXRuZaOsAdXKFyOhRBg6Lqqc0yay13vN7KrIg4L7N4aaHN68ma9OK3NE1BoDFgFOTfM7zg+3/8+2n8rLUH3OKQ==", + "version": "19.1.11", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.1.11.tgz", + "integrity": "sha512-3BKc/yGdNTYQVVw4idqHtSOcFsgGuBbMveKCOgF8wQ5QtrYOc3jDIlzg3jef04zcXFIHLelyGlj0T+BJ8+KN+w==", "devOptional": true, "license": "MIT", + "peer": true, "peerDependencies": { "@types/react": "^19.0.0" } @@ -5294,9 +5154,9 @@ } }, "node_modules/@types/ssh2/node_modules/@types/node": { - "version": "18.19.124", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.19.124.tgz", - "integrity": "sha512-hY4YWZFLs3ku6D2Gqo3RchTd9VRCcrjqp/I0mmohYeUVA5Y8eCXKJEasHxLAJVZRJuQogfd1GiJ9lgogBgKeuQ==", + "version": "18.19.129", + "resolved": "https://registry.npmjs.org/@types/node/-/node-18.19.129.tgz", + "integrity": "sha512-hrmi5jWt2w60ayox3iIXwpMEnfUvOLJCRtrOPbHtH15nTjvO7uhnelvrdAs0dO0/zl5DZ3ZbahiaXEVb54ca/A==", "dev": true, "license": "MIT", "dependencies": { @@ -5310,6 +5170,18 @@ "dev": true, "license": "MIT" }, + "node_modules/@types/trusted-types": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/trusted-types/-/trusted-types-1.0.6.tgz", + "integrity": "sha512-230RC8sFeHoT6sSUlRO6a8cAnclO06eeiq1QDfiv2FGCLWFvvERWgwIQD4FWqD9A69BN7Lzee4OXwoMVnnsWDw==", + "license": "MIT" + }, + "node_modules/@types/unist": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-3.0.3.tgz", + "integrity": "sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==", + "license": "MIT" + }, "node_modules/@types/verror": { "version": "1.10.11", "resolved": "https://registry.npmjs.org/@types/verror/-/verror-1.10.11.tgz", @@ -5340,17 +5212,17 @@ } }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.43.0.tgz", - "integrity": "sha512-8tg+gt7ENL7KewsKMKDHXR1vm8tt9eMxjJBYINf6swonlWgkYn5NwyIgXpbbDxTNU5DgpDFfj95prcTq2clIQQ==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.45.0.tgz", + "integrity": "sha512-HC3y9CVuevvWCl/oyZuI47dOeDF9ztdMEfMH8/DW/Mhwa9cCLnK1oD7JoTVGW/u7kFzNZUKUoyJEqkaJh5y3Wg==", "dev": true, "license": "MIT", "dependencies": { "@eslint-community/regexpp": "^4.10.0", - "@typescript-eslint/scope-manager": "8.43.0", - "@typescript-eslint/type-utils": "8.43.0", - "@typescript-eslint/utils": "8.43.0", - "@typescript-eslint/visitor-keys": "8.43.0", + "@typescript-eslint/scope-manager": "8.45.0", + "@typescript-eslint/type-utils": "8.45.0", + "@typescript-eslint/utils": "8.45.0", + "@typescript-eslint/visitor-keys": "8.45.0", "graphemer": "^1.4.0", "ignore": "^7.0.0", "natural-compare": "^1.4.0", @@ -5364,7 +5236,7 @@ "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "@typescript-eslint/parser": "^8.43.0", + "@typescript-eslint/parser": "^8.45.0", "eslint": "^8.57.0 || ^9.0.0", "typescript": ">=4.8.4 <6.0.0" } @@ -5380,16 +5252,16 @@ } }, "node_modules/@typescript-eslint/parser": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.43.0.tgz", - "integrity": "sha512-B7RIQiTsCBBmY+yW4+ILd6mF5h1FUwJsVvpqkrgpszYifetQ2Ke+Z4u6aZh0CblkUGIdR59iYVyXqqZGkZ3aBw==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.45.0.tgz", + "integrity": "sha512-TGf22kon8KW+DeKaUmOibKWktRY8b2NSAZNdtWh798COm1NWx8+xJ6iFBtk3IvLdv6+LGLJLRlyhrhEDZWargQ==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/scope-manager": "8.43.0", - "@typescript-eslint/types": "8.43.0", - "@typescript-eslint/typescript-estree": "8.43.0", - "@typescript-eslint/visitor-keys": "8.43.0", + "@typescript-eslint/scope-manager": "8.45.0", + "@typescript-eslint/types": "8.45.0", + "@typescript-eslint/typescript-estree": "8.45.0", + "@typescript-eslint/visitor-keys": "8.45.0", "debug": "^4.3.4" }, "engines": { @@ -5404,15 +5276,40 @@ "typescript": ">=4.8.4 <6.0.0" } }, - "node_modules/@typescript-eslint/project-service": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/project-service/-/project-service-8.43.0.tgz", - "integrity": "sha512-htB/+D/BIGoNTQYffZw4uM4NzzuolCoaA/BusuSIcC8YjmBYQioew5VUZAYdAETPjeed0hqCaW7EHg+Robq8uw==", + "node_modules/@typescript-eslint/parser/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/tsconfig-utils": "^8.43.0", - "@typescript-eslint/types": "^8.43.0", + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/parser/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@typescript-eslint/project-service": { + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/project-service/-/project-service-8.45.0.tgz", + "integrity": "sha512-3pcVHwMG/iA8afdGLMuTibGR7pDsn9RjDev6CCB+naRsSYs2pns5QbinF4Xqw6YC/Sj3lMrm/Im0eMfaa61WUg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/tsconfig-utils": "^8.45.0", + "@typescript-eslint/types": "^8.45.0", "debug": "^4.3.4" }, "engines": { @@ -5426,15 +5323,40 @@ "typescript": ">=4.8.4 <6.0.0" } }, - "node_modules/@typescript-eslint/scope-manager": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.43.0.tgz", - "integrity": "sha512-daSWlQ87ZhsjrbMLvpuuMAt3y4ba57AuvadcR7f3nl8eS3BjRc8L9VLxFLk92RL5xdXOg6IQ+qKjjqNEimGuAg==", + "node_modules/@typescript-eslint/project-service/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/types": "8.43.0", - "@typescript-eslint/visitor-keys": "8.43.0" + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/project-service/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@typescript-eslint/scope-manager": { + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.45.0.tgz", + "integrity": "sha512-clmm8XSNj/1dGvJeO6VGH7EUSeA0FMs+5au/u3lrA3KfG8iJ4u8ym9/j2tTEoacAffdW1TVUzXO30W1JTJS7dA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/types": "8.45.0", + "@typescript-eslint/visitor-keys": "8.45.0" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -5445,9 +5367,9 @@ } }, "node_modules/@typescript-eslint/tsconfig-utils": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/tsconfig-utils/-/tsconfig-utils-8.43.0.tgz", - "integrity": "sha512-ALC2prjZcj2YqqL5X/bwWQmHA2em6/94GcbB/KKu5SX3EBDOsqztmmX1kMkvAJHzxk7TazKzJfFiEIagNV3qEA==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/tsconfig-utils/-/tsconfig-utils-8.45.0.tgz", + "integrity": "sha512-aFdr+c37sc+jqNMGhH+ajxPXwjv9UtFZk79k8pLoJ6p4y0snmYpPA52GuWHgt2ZF4gRRW6odsEj41uZLojDt5w==", "dev": true, "license": "MIT", "engines": { @@ -5462,15 +5384,15 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.43.0.tgz", - "integrity": "sha512-qaH1uLBpBuBBuRf8c1mLJ6swOfzCXryhKND04Igr4pckzSEW9JX5Aw9AgW00kwfjWJF0kk0ps9ExKTfvXfw4Qg==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.45.0.tgz", + "integrity": "sha512-bpjepLlHceKgyMEPglAeULX1vixJDgaKocp0RVJ5u4wLJIMNuKtUXIczpJCPcn2waII0yuvks/5m5/h3ZQKs0A==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/types": "8.43.0", - "@typescript-eslint/typescript-estree": "8.43.0", - "@typescript-eslint/utils": "8.43.0", + "@typescript-eslint/types": "8.45.0", + "@typescript-eslint/typescript-estree": "8.45.0", + "@typescript-eslint/utils": "8.45.0", "debug": "^4.3.4", "ts-api-utils": "^2.1.0" }, @@ -5486,10 +5408,35 @@ "typescript": ">=4.8.4 <6.0.0" } }, + "node_modules/@typescript-eslint/type-utils/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/type-utils/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@typescript-eslint/types": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.43.0.tgz", - "integrity": "sha512-vQ2FZaxJpydjSZJKiSW/LJsabFFvV7KgLC5DiLhkBcykhQj8iK9BOaDmQt74nnKdLvceM5xmhaTF+pLekrxEkw==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.45.0.tgz", + "integrity": "sha512-WugXLuOIq67BMgQInIxxnsSyRLFxdkJEJu8r4ngLR56q/4Q5LrbfkFRH27vMTjxEK8Pyz7QfzuZe/G15qQnVRA==", "dev": true, "license": "MIT", "engines": { @@ -5501,16 +5448,16 @@ } }, "node_modules/@typescript-eslint/typescript-estree": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.43.0.tgz", - "integrity": "sha512-7Vv6zlAhPb+cvEpP06WXXy/ZByph9iL6BQRBDj4kmBsW98AqEeQHlj/13X+sZOrKSo9/rNKH4Ul4f6EICREFdw==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.45.0.tgz", + "integrity": "sha512-GfE1NfVbLam6XQ0LcERKwdTTPlLvHvXXhOeUGC1OXi4eQBoyy1iVsW+uzJ/J9jtCz6/7GCQ9MtrQ0fml/jWCnA==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/project-service": "8.43.0", - "@typescript-eslint/tsconfig-utils": "8.43.0", - "@typescript-eslint/types": "8.43.0", - "@typescript-eslint/visitor-keys": "8.43.0", + "@typescript-eslint/project-service": "8.45.0", + "@typescript-eslint/tsconfig-utils": "8.45.0", + "@typescript-eslint/types": "8.45.0", + "@typescript-eslint/visitor-keys": "8.45.0", "debug": "^4.3.4", "fast-glob": "^3.3.2", "is-glob": "^4.0.3", @@ -5539,6 +5486,24 @@ "balanced-match": "^1.0.0" } }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": { "version": "9.0.5", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", @@ -5555,17 +5520,37 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/@typescript-eslint/utils": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.43.0.tgz", - "integrity": "sha512-S1/tEmkUeeswxd0GGcnwuVQPFWo8NzZTOMxCvw8BX7OMxnNae+i8Tm7REQen/SwUIPoPqfKn7EaZ+YLpiB3k9g==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.45.0.tgz", + "integrity": "sha512-bxi1ht+tLYg4+XV2knz/F7RVhU0k6VrSMc9sb8DQ6fyCTrGQLHfo7lDtN0QJjZjKkLA2ThrKuCdHEvLReqtIGg==", "dev": true, "license": "MIT", "dependencies": { "@eslint-community/eslint-utils": "^4.7.0", - "@typescript-eslint/scope-manager": "8.43.0", - "@typescript-eslint/types": "8.43.0", - "@typescript-eslint/typescript-estree": "8.43.0" + "@typescript-eslint/scope-manager": "8.45.0", + "@typescript-eslint/types": "8.45.0", + "@typescript-eslint/typescript-estree": "8.45.0" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -5580,13 +5565,13 @@ } }, "node_modules/@typescript-eslint/visitor-keys": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.43.0.tgz", - "integrity": "sha512-T+S1KqRD4sg/bHfLwrpF/K3gQLBM1n7Rp7OjjikjTEssI2YJzQpi5WXoynOaQ93ERIuq3O8RBTOUYDKszUCEHw==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.45.0.tgz", + "integrity": "sha512-qsaFBA3e09MIDAGFUrTk+dzqtfv1XPVz8t8d1f0ybTzrCY7BKiMC5cjrl1O/P7UmHsNyW90EYSkU/ZWpmXelag==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/types": "8.43.0", + "@typescript-eslint/types": "8.45.0", "eslint-visitor-keys": "^4.2.1" }, "engines": { @@ -5598,9 +5583,9 @@ } }, "node_modules/@uiw/codemirror-extensions-basic-setup": { - "version": "4.25.1", - "resolved": "https://registry.npmjs.org/@uiw/codemirror-extensions-basic-setup/-/codemirror-extensions-basic-setup-4.25.1.tgz", - "integrity": "sha512-zxgA2QkvP3ZDKxTBc9UltNFTrSeFezGXcZtZj6qcsBxiMzowoEMP5mVwXcKjpzldpZVRuY+JCC+RsekEgid4vg==", + "version": "4.25.2", + "resolved": "https://registry.npmjs.org/@uiw/codemirror-extensions-basic-setup/-/codemirror-extensions-basic-setup-4.25.2.tgz", + "integrity": "sha512-s2fbpdXrSMWEc86moll/d007ZFhu6jzwNu5cWv/2o7egymvLeZO52LWkewgbr+BUCGWGPsoJVWeaejbsb/hLcw==", "license": "MIT", "dependencies": { "@codemirror/autocomplete": "^6.0.0", @@ -5624,23 +5609,10 @@ "@codemirror/view": ">=6.0.0" } }, - "node_modules/@uiw/codemirror-extensions-hyper-link": { - "version": "4.25.1", - "resolved": "https://registry.npmjs.org/@uiw/codemirror-extensions-hyper-link/-/codemirror-extensions-hyper-link-4.25.1.tgz", - "integrity": "sha512-BVp+bnPI0LtqYXAPFWBqpLLLICoD8QsTAC/KQVRf7l+MO8FXCP0F/4WoM724eU4/2bcLefBkK1gBgCB1+Ug1CQ==", - "license": "MIT", - "funding": { - "url": "https://jaywcjlove.github.io/#/sponsor" - }, - "peerDependencies": { - "@codemirror/state": ">=6.0.0", - "@codemirror/view": ">=6.0.0" - } - }, "node_modules/@uiw/codemirror-extensions-langs": { - "version": "4.25.1", - "resolved": "https://registry.npmjs.org/@uiw/codemirror-extensions-langs/-/codemirror-extensions-langs-4.25.1.tgz", - "integrity": "sha512-P9Sxk0w8WgxxoOK4hC2yNV2f3shE0CH8gmk8lG5rDrAYYyuUrTsTmJANXh30TuQWCPCkEXwXZZVy+dbTYAgvMQ==", + "version": "4.25.2", + "resolved": "https://registry.npmjs.org/@uiw/codemirror-extensions-langs/-/codemirror-extensions-langs-4.25.2.tgz", + "integrity": "sha512-fWS9fP52QJAFgXbsUl6vKMBqQ2PIT8z5TvX8BKBqPz/I+ayh6Fk+HzoeUtslUGPTu+UTPgB5m0qt3rTIDXWvng==", "license": "MIT", "dependencies": { "@codemirror/language": "^6.0.0", @@ -5658,36 +5630,17 @@ "@codemirror/language-data": ">=6.0.0" } }, - "node_modules/@uiw/codemirror-themes": { - "version": "4.25.1", - "resolved": "https://registry.npmjs.org/@uiw/codemirror-themes/-/codemirror-themes-4.25.1.tgz", - "integrity": "sha512-6o8tQ8bdq14RuVFpZ7l9u8KnuPq824uG3U1VV933Uhv8mfaxaoaOQSjv6T2bQUPhjH6ZlEu5+tAMkOfIL21eIQ==", - "license": "MIT", - "dependencies": { - "@codemirror/language": "^6.0.0", - "@codemirror/state": "^6.0.0", - "@codemirror/view": "^6.0.0" - }, - "funding": { - "url": "https://jaywcjlove.github.io/#/sponsor" - }, - "peerDependencies": { - "@codemirror/language": ">=6.0.0", - "@codemirror/state": ">=6.0.0", - "@codemirror/view": ">=6.0.0" - } - }, "node_modules/@uiw/react-codemirror": { - "version": "4.25.1", - "resolved": "https://registry.npmjs.org/@uiw/react-codemirror/-/react-codemirror-4.25.1.tgz", - "integrity": "sha512-eESBKHndoYkaEGlKCwRO4KrnTw1HkWBxVpEeqntoWTpoFEUYxdLWUYmkPBVk4/u8YzVy9g91nFfIRpqe5LjApg==", + "version": "4.25.2", + "resolved": "https://registry.npmjs.org/@uiw/react-codemirror/-/react-codemirror-4.25.2.tgz", + "integrity": "sha512-XP3R1xyE0CP6Q0iR0xf3ed+cJzJnfmbLelgJR6osVVtMStGGZP3pGQjjwDRYptmjGHfEELUyyBLdY25h0BQg7w==", "license": "MIT", "dependencies": { "@babel/runtime": "^7.18.6", "@codemirror/commands": "^6.1.0", "@codemirror/state": "^6.1.1", "@codemirror/theme-one-dark": "^6.0.0", - "@uiw/codemirror-extensions-basic-setup": "4.25.1", + "@uiw/codemirror-extensions-basic-setup": "4.25.2", "codemirror": "^6.0.0" }, "funding": { @@ -5703,6 +5656,22 @@ "react-dom": ">=17.0.0" } }, + "node_modules/@ungap/structured-clone": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", + "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", + "license": "ISC" + }, + "node_modules/@vimeo/player": { + "version": "2.29.0", + "resolved": "https://registry.npmjs.org/@vimeo/player/-/player-2.29.0.tgz", + "integrity": "sha512-9JjvjeqUndb9otCCFd0/+2ESsLk7VkDE6sxOBy9iy2ukezuQbplVRi+g9g59yAurKofbmTi/KcKxBGO/22zWRw==", + "license": "MIT", + "dependencies": { + "native-promise-only": "0.8.1", + "weakmap-polyfill": "2.0.4" + } + }, "node_modules/@vitejs/plugin-react-swc": { "version": "3.11.0", "resolved": "https://registry.npmjs.org/@vitejs/plugin-react-swc/-/plugin-react-swc-3.11.0.tgz", @@ -5727,15 +5696,6 @@ "node": ">=10.0.0" } }, - "node_modules/@xterm/addon-attach": { - "version": "0.11.0", - "resolved": "https://registry.npmjs.org/@xterm/addon-attach/-/addon-attach-0.11.0.tgz", - "integrity": "sha512-JboCN0QAY6ZLY/SSB/Zl2cQ5zW1Eh4X3fH7BnuR1NB7xGRhzbqU2Npmpiw/3zFlxDaU88vtKzok44JKi2L2V2Q==", - "license": "MIT", - "peerDependencies": { - "@xterm/xterm": "^5.0.0" - } - }, "node_modules/@xterm/addon-clipboard": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/@xterm/addon-clipboard/-/addon-clipboard-0.1.0.tgz", @@ -5757,15 +5717,6 @@ "@xterm/xterm": "^5.0.0" } }, - "node_modules/@xterm/addon-search": { - "version": "0.15.0", - "resolved": "https://registry.npmjs.org/@xterm/addon-search/-/addon-search-0.15.0.tgz", - "integrity": "sha512-ZBZKLQ+EuKE83CqCmSSz5y1tx+aNOCUaA7dm6emgOX+8J9H1FWXZyrKfzjwzV+V14TV3xToz1goIeRhXBS5qjg==", - "license": "MIT", - "peerDependencies": { - "@xterm/xterm": "^5.0.0" - } - }, "node_modules/@xterm/addon-unicode11": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/@xterm/addon-unicode11/-/addon-unicode11-0.8.0.tgz", @@ -5788,7 +5739,8 @@ "version": "5.5.0", "resolved": "https://registry.npmjs.org/@xterm/xterm/-/xterm-5.5.0.tgz", "integrity": "sha512-hqJHYaQb5OptNunnyAnkHyM8aCjZ1MEIDTQu1iIbbTD/xops91NB5yq1ZK/dC2JDbVWtF23zUtl9JE2NqwT87A==", - "license": "MIT" + "license": "MIT", + "peer": true }, "node_modules/7zip-bin": { "version": "5.2.0", @@ -5804,19 +5756,6 @@ "dev": true, "license": "ISC" }, - "node_modules/abort-controller": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", - "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", - "dev": true, - "license": "MIT", - "dependencies": { - "event-target-shim": "^5.0.0" - }, - "engines": { - "node": ">=6.5" - } - }, "node_modules/accepts": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", @@ -5836,6 +5775,7 @@ "integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==", "dev": true, "license": "MIT", + "peer": true, "bin": { "acorn": "bin/acorn" }, @@ -5853,19 +5793,6 @@ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" } }, - "node_modules/acorn-walk": { - "version": "8.3.4", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.4.tgz", - "integrity": "sha512-ueEepnujpqee2o5aIYnvHU6C0A42MNdsIDeqy5BydrkuC5R1ZuUFnm27EeFJGoEHJQgn3uleRvmTXaJgfXbt4g==", - "dev": true, - "license": "MIT", - "dependencies": { - "acorn": "^8.11.0" - }, - "engines": { - "node": ">=0.4.0" - } - }, "node_modules/agent-base": { "version": "7.1.4", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.4.tgz", @@ -5909,6 +5836,7 @@ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", "dev": true, "license": "MIT", + "peer": true, "dependencies": { "fast-deep-equal": "^3.1.1", "fast-json-stable-stringify": "^2.0.0", @@ -5954,13 +5882,6 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, - "node_modules/any-base": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/any-base/-/any-base-1.1.0.tgz", - "integrity": "sha512-uMgjozySS8adZZYePpaWs8cxB9/kdzmpX6SgJZ+wbz1K5eYk5QMYDVJaZKhxyIHUdnnJkfR7SVgStgH7LkGUyg==", - "dev": true, - "license": "MIT" - }, "node_modules/app-builder-bin": { "version": "5.0.0-alpha.12", "resolved": "https://registry.npmjs.org/app-builder-bin/-/app-builder-bin-5.0.0-alpha.12.tgz", @@ -6017,14 +5938,22 @@ "electron-builder-squirrel-windows": "26.0.12" } }, - "node_modules/app-builder-lib/node_modules/chownr": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", - "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", + "node_modules/app-builder-lib/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, - "license": "ISC", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, "engines": { - "node": ">=10" + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } } }, "node_modules/app-builder-lib/node_modules/dotenv": { @@ -6068,22 +5997,6 @@ "graceful-fs": "^4.1.6" } }, - "node_modules/app-builder-lib/node_modules/minimatch": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.3.tgz", - "integrity": "sha512-IPZ167aShDZZUMdRk66cyQAW3qr0WzbHkPdMYa8bzZhlHhO3jALbKdxcaak7W9FfT2rZNpQuUu4Od7ILEpXSaw==", - "dev": true, - "license": "ISC", - "dependencies": { - "@isaacs/brace-expansion": "^5.0.0" - }, - "engines": { - "node": "20 || >=22" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/app-builder-lib/node_modules/minipass": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", @@ -6094,41 +6007,21 @@ "node": ">=8" } }, - "node_modules/app-builder-lib/node_modules/minizlib": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", - "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", + "node_modules/app-builder-lib/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true, - "license": "MIT", - "dependencies": { - "minipass": "^3.0.0", - "yallist": "^4.0.0" - }, - "engines": { - "node": ">= 8" - } + "license": "MIT" }, - "node_modules/app-builder-lib/node_modules/minizlib/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "node_modules/app-builder-lib/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", "dev": true, "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/app-builder-lib/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", "bin": { - "mkdirp": "bin/cmd.js" + "semver": "bin/semver.js" }, "engines": { "node": ">=10" @@ -6162,26 +6055,12 @@ "node": ">= 10.0.0" } }, - "node_modules/app-builder-lib/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/append-field": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", "integrity": "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==", "license": "MIT" }, - "node_modules/arg": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", - "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", - "dev": true, - "license": "MIT" - }, "node_modules/argparse": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", @@ -6189,110 +6068,6 @@ "dev": true, "license": "Python-2.0" }, - "node_modules/args": { - "version": "5.0.3", - "resolved": "https://registry.npmjs.org/args/-/args-5.0.3.tgz", - "integrity": "sha512-h6k/zfFgusnv3i5TU08KQkVKuCPBtL/PWQbWkHUxvJrZ2nAyeaUupneemcrgn1xmqxPQsPIzwkUhOpoqPDRZuA==", - "dev": true, - "license": "MIT", - "dependencies": { - "camelcase": "5.0.0", - "chalk": "2.4.2", - "leven": "2.1.0", - "mri": "1.1.4" - }, - "engines": { - "node": ">= 6.0.0" - } - }, - "node_modules/args/node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "license": "MIT", - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/args/node_modules/camelcase": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.0.0.tgz", - "integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/args/node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/args/node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "license": "MIT", - "dependencies": { - "color-name": "1.1.3" - } - }, - "node_modules/args/node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true, - "license": "MIT" - }, - "node_modules/args/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/args/node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/args/node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "license": "MIT", - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, "node_modules/aria-hidden": { "version": "1.2.6", "resolved": "https://registry.npmjs.org/aria-hidden/-/aria-hidden-1.2.6.tgz", @@ -6305,16 +6080,6 @@ "node": ">=10" } }, - "node_modules/array-union": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", - "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, "node_modules/asn1": { "version": "0.2.6", "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.6.tgz", @@ -6330,6 +6095,7 @@ "integrity": "sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw==", "dev": true, "license": "MIT", + "optional": true, "engines": { "node": ">=0.8" } @@ -6378,75 +6144,10 @@ "node": ">= 4.0.0" } }, - "node_modules/author-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/author-regex/-/author-regex-1.0.0.tgz", - "integrity": "sha512-KbWgR8wOYRAPekEmMXrYYdc7BRyhn2Ftk7KWfMUnQ43hFdojWEFRxhhRUm3/OFEdPa1r0KAvTTg9YQK57xTe0g==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8" - } - }, - "node_modules/autoprefixer": { - "version": "10.4.21", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.21.tgz", - "integrity": "sha512-O+A6LWV5LDHSJD3LjHYoNi4VLsj/Whi7k6zG12xTYaU4cQ8oxQGckXNX8cRHK5yOZ/ppVHe0ZBXGzSV9jXdVbQ==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/autoprefixer" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "MIT", - "dependencies": { - "browserslist": "^4.24.4", - "caniuse-lite": "^1.0.30001702", - "fraction.js": "^4.3.7", - "normalize-range": "^0.1.2", - "picocolors": "^1.1.1", - "postcss-value-parser": "^4.2.0" - }, - "bin": { - "autoprefixer": "bin/autoprefixer" - }, - "engines": { - "node": "^10 || ^12 || >=14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/aws-sign2": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", - "integrity": "sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==", - "dev": true, - "license": "Apache-2.0", - "engines": { - "node": "*" - } - }, - "node_modules/aws4": { - "version": "1.13.2", - "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.13.2.tgz", - "integrity": "sha512-lHe62zvbTB5eEABUVi/AwVh0ZKY9rMMDhmm+eeyuuUQbQ3+J+fONVQOZyj+DdrvD4BY33uYniyRJ4UJIaSKAfw==", - "dev": true, - "license": "MIT" - }, "node_modules/axios": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.11.0.tgz", - "integrity": "sha512-1Lx3WLFQWm3ooKDYZD1eXmoGO9fxYQjrycfHFC8P0sCfQVXyROp0p9PFWBehewBOdCwHc+f/b8I0fMto5eSfwA==", + "version": "1.12.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.2.tgz", + "integrity": "sha512-vMJzPewAlRyOgxV2dU0Cuz2O8zzzx9VYtbJOaBgXFeLc4IV/Eg50n4LowmehOOR61S8ZMpc2K5Sa7g6A4jfkUw==", "license": "MIT", "dependencies": { "follow-redirects": "^1.15.6", @@ -6454,6 +6155,16 @@ "proxy-from-env": "^1.1.0" } }, + "node_modules/bail": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/bail/-/bail-2.0.2.tgz", + "integrity": "sha512-0xO6mYd7JB2YesxDKplafRpsiOzPt9V02ddPCLbY1xYGPOX24NTyN50qnUxgCPcSoYMhKpAuBTjQoRZCAkUDRw==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -6487,6 +6198,45 @@ ], "license": "MIT" }, + "node_modules/bcp-47": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/bcp-47/-/bcp-47-2.1.0.tgz", + "integrity": "sha512-9IIS3UPrvIa1Ej+lVDdDwO7zLehjqsaByECw0bu2RRGP73jALm6FYbzI5gWbgHLvNdkvfXB5YrSbocZdOS0c0w==", + "license": "MIT", + "dependencies": { + "is-alphabetical": "^2.0.0", + "is-alphanumerical": "^2.0.0", + "is-decimal": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/bcp-47-match": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/bcp-47-match/-/bcp-47-match-2.0.3.tgz", + "integrity": "sha512-JtTezzbAibu8G0R9op9zb3vcWZd9JF6M0xOYGPn0fNCd7wOpRB1mU2mH9T8gaBGbAAyIIVgB2G7xG0GP98zMAQ==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/bcp-47-normalize": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/bcp-47-normalize/-/bcp-47-normalize-2.3.0.tgz", + "integrity": "sha512-8I/wfzqQvttUFz7HVJgIZ7+dj3vUaIyIxYXaTRP1YWoSDfzt6TUmxaKZeuXR62qBmYr+nvuWINFRl6pZ5DlN4Q==", + "license": "MIT", + "dependencies": { + "bcp-47": "^2.0.0", + "bcp-47-match": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/bcrypt-pbkdf": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", @@ -6506,11 +6256,12 @@ } }, "node_modules/better-sqlite3": { - "version": "12.2.0", - "resolved": "https://registry.npmjs.org/better-sqlite3/-/better-sqlite3-12.2.0.tgz", - "integrity": "sha512-eGbYq2CT+tos1fBwLQ/tkBt9J5M3JEHjku4hbvQUePCckkvVf14xWj+1m7dGoK81M/fOjFT7yM9UMeKT/+vFLQ==", + "version": "12.4.1", + "resolved": "https://registry.npmjs.org/better-sqlite3/-/better-sqlite3-12.4.1.tgz", + "integrity": "sha512-3yVdyZhklTiNrtg+4WqHpJpFDd+WHTg2oM7UcR80GqL05AOV0xEJzc6qNvFYoEtE+hRp1n9MpN6/+4yhlGkDXQ==", "hasInstallScript": true, "license": "MIT", + "peer": true, "dependencies": { "bindings": "^1.5.0", "prebuild-install": "^7.1.1" @@ -6539,38 +6290,42 @@ "readable-stream": "^3.4.0" } }, - "node_modules/bluebird": { - "version": "3.7.2", - "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", - "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", - "dev": true, - "license": "MIT" - }, - "node_modules/bmp-js": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/bmp-js/-/bmp-js-0.1.0.tgz", - "integrity": "sha512-vHdS19CnY3hwiNdkaqk93DvjVLfbEcI8mys4UjuWrlX1haDmroo8o4xCzh4wD6DGV6HxRCyauwhHRqMTfERtjw==", - "dev": true, - "license": "MIT" - }, - "node_modules/body-parser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", - "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "node_modules/bl/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", "license": "MIT", "dependencies": { - "bytes": "^3.1.2", - "content-type": "^1.0.5", - "debug": "^4.4.0", - "http-errors": "^2.0.0", - "iconv-lite": "^0.6.3", - "on-finished": "^2.4.1", - "qs": "^6.14.0", - "raw-body": "^3.0.0", - "type-is": "^2.0.0" + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" }, "engines": { - "node": ">=18" + "node": ">= 6" + } + }, + "node_modules/body-parser": { + "version": "1.20.3", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", + "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", + "license": "MIT", + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.5", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.13.0", + "raw-body": "2.5.2", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" } }, "node_modules/boolean": { @@ -6606,39 +6361,6 @@ "node": ">=8" } }, - "node_modules/browserslist": { - "version": "4.25.4", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.25.4.tgz", - "integrity": "sha512-4jYpcjabC606xJ3kw2QwGEZKX0Aw7sgQdZCvIK9dhVSPh76BKo+C+btT1RRofH7B+8iNpEbgGNVWiLki5q93yg==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "MIT", - "dependencies": { - "caniuse-lite": "^1.0.30001737", - "electron-to-chromium": "^1.5.211", - "node-releases": "^2.0.19", - "update-browserslist-db": "^1.1.3" - }, - "bin": { - "browserslist": "cli.js" - }, - "engines": { - "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" - } - }, "node_modules/buffer": { "version": "5.7.1", "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", @@ -6673,19 +6395,6 @@ "node": "*" } }, - "node_modules/buffer-equal": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-1.0.1.tgz", - "integrity": "sha512-QoV3ptgEaQpvVwbXdSO39iqPQTCxSF7A5U99AxbHYqUdCizL/lH2Z0A2y6nbZucxMEOtNyZfG2s6gsVugGpKkg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/buffer-equal-constant-time": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", @@ -6747,6 +6456,49 @@ "node": ">=12.0.0" } }, + "node_modules/builder-util-runtime/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/builder-util-runtime/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/builder-util/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/builder-util/node_modules/fs-extra": { "version": "10.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", @@ -6775,6 +6527,13 @@ "graceful-fs": "^4.1.6" } }, + "node_modules/builder-util/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/builder-util/node_modules/universalify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", @@ -6845,16 +6604,6 @@ "balanced-match": "^1.0.0" } }, - "node_modules/cacache/node_modules/chownr": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", - "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, "node_modules/cacache/node_modules/glob": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", @@ -6899,46 +6648,6 @@ "node": ">=10" } }, - "node_modules/cacache/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/cacache/node_modules/minizlib": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", - "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", - "dev": true, - "license": "MIT", - "dependencies": { - "minipass": "^3.0.0", - "yallist": "^4.0.0" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/cacache/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", - "bin": { - "mkdirp": "bin/cmd.js" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/cacache/node_modules/tar": { "version": "6.2.1", "resolved": "https://registry.npmjs.org/tar/-/tar-6.2.1.tgz", @@ -6967,13 +6676,6 @@ "node": ">=8" } }, - "node_modules/cacache/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/cacheable-lookup": { "version": "5.0.4", "resolved": "https://registry.npmjs.org/cacheable-lookup/-/cacheable-lookup-5.0.4.tgz", @@ -7051,42 +6753,32 @@ "node": ">=6" } }, - "node_modules/caniuse-lite": { - "version": "1.0.30001741", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001741.tgz", - "integrity": "sha512-QGUGitqsc8ARjLdgAfxETDhRbJ0REsP6O3I96TAth/mVjh2cYzN2u+3AzPP3aVSm2FehEItaJw1xd+IGBXWeSw==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/caniuse-lite" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "CC-BY-4.0" - }, - "node_modules/caseless": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", - "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==", - "dev": true, - "license": "Apache-2.0" - }, - "node_modules/centra": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/centra/-/centra-2.7.0.tgz", - "integrity": "sha512-PbFMgMSrmgx6uxCdm57RUos9Tc3fclMvhLSATYN39XsDV29B89zZ3KA89jmY0vwSGazyU+uerqwa6t+KaodPcg==", - "dev": true, + "node_modules/castable-video": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/castable-video/-/castable-video-1.1.11.tgz", + "integrity": "sha512-LCRTK6oe7SB1SiUQFzZCo6D6gcEzijqBTVIuj3smKpQdesXM18QTbCVqWgh9MfOeQgTx/i9ji5jGcdqNPeWg2g==", "license": "MIT", "dependencies": { - "follow-redirects": "^1.15.6" + "custom-media-element": "~1.4.5" + } + }, + "node_modules/ccount": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/ccount/-/ccount-2.0.1.tgz", + "integrity": "sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/ce-la-react": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/ce-la-react/-/ce-la-react-0.3.1.tgz", + "integrity": "sha512-g0YwpZDPIwTwFumGTzNHcgJA6VhFfFCJkSNdUdC04br2UfU+56JDrJrJva3FZ7MToB4NDHAFBiPE/PZdNl1mQA==", + "license": "BSD-3-Clause", + "peerDependencies": { + "react": ">=17.0.0" } }, "node_modules/chalk": { @@ -7105,13 +6797,54 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, - "node_modules/chownr": { + "node_modules/character-entities": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-2.0.2.tgz", + "integrity": "sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/character-entities-html4": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/character-entities-html4/-/character-entities-html4-2.1.0.tgz", + "integrity": "sha512-1v7fgQRj6hnSwFpq1Eu0ynr/CDEw0rXo2B61qXrLNdHZmPKgb7fqS1a2JwF0rISo9q77jDI8VMEHoApn8qDoZA==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/character-entities-legacy": { "version": "3.0.0", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-3.0.0.tgz", - "integrity": "sha512-+IxzY9BZOQd/XuYPRmrvEVjF/nqj5kgT4kEq7VofrDoM1MxoRjEWkrCC3EtLi59TVawxTAn+orJwFQcrqEN1+g==", - "license": "BlueOak-1.0.0", + "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-3.0.0.tgz", + "integrity": "sha512-RpPp0asT/6ufRm//AJVwpViZbGM/MkjQFxJccQRHmISF/22NBtsHqAWmL+/pmkPWoIUJdWyeVleTl1wydHATVQ==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/character-reference-invalid": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/character-reference-invalid/-/character-reference-invalid-2.0.1.tgz", + "integrity": "sha512-iBZ4F4wRbyORVsu0jPV7gXkOsGYjGHPmAyv+HiHG8gi5PtC9KI2j1+v8/tlibRvjoWX027ypmG/n0HtO5t7unw==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/chownr": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", + "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", + "dev": true, + "license": "ISC", "engines": { - "node": ">=18" + "node": ">=10" } }, "node_modules/chromium-pickle-js": { @@ -7204,14 +6937,18 @@ } }, "node_modules/cliui": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", - "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dev": true, "license": "ISC", "dependencies": { "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^6.2.0" + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, + "engines": { + "node": ">=12" } }, "node_modules/clone": { @@ -7237,15 +6974,11 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/clone-response/node_modules/mimic-response": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", - "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } + "node_modules/cloudflare-video-element": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/cloudflare-video-element/-/cloudflare-video-element-1.3.4.tgz", + "integrity": "sha512-F9g+tXzGEXI6v6L48qXxr8vnR8+L6yy7IhpJxK++lpzuVekMHTixxH7/dzLuq6OacVGziU4RB5pzZYJ7/LYtJg==", + "license": "MIT" }, "node_modules/clsx": { "version": "2.1.1", @@ -7256,15 +6989,11 @@ "node": ">=6" } }, - "node_modules/code-point-at": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", - "integrity": "sha512-RpAVKQA5T63xEj6/giIbUEtZwJ4UFIc3ZtvEkiaUERylqe8xb5IvqcgOurZLahv93CLKfxcw5YI+DZcUBRyLXA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } + "node_modules/codem-isoboxer": { + "version": "0.3.10", + "resolved": "https://registry.npmjs.org/codem-isoboxer/-/codem-isoboxer-0.3.10.tgz", + "integrity": "sha512-eNk3TRV+xQMJ1PEj0FQGY8KD4m0GPxT487XJ+Iftm7mVa9WpPFDMWqPt+46buiP5j5Wzqe5oMIhqBcAeKfygSA==", + "license": "MIT" }, "node_modules/codemirror": { "version": "6.0.2", @@ -7322,6 +7051,16 @@ "node": ">= 0.8" } }, + "node_modules/comma-separated-tokens": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-2.0.3.tgz", + "integrity": "sha512-Fu4hJdvzeylCfQPp9SGWidpzrMs7tTrlu6Vb8XGaRGck8QSNZJJp538Wrb60Lax4fPwR64ViY468OIUTbRlGZg==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/commander": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", @@ -7364,6 +7103,20 @@ "typedarray": "^0.0.6" } }, + "node_modules/concat-stream/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "license": "MIT", + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/concurrently": { "version": "9.2.1", "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-9.2.1.tgz", @@ -7389,21 +7142,6 @@ "url": "https://github.com/open-cli-tools/concurrently?sponsor=1" } }, - "node_modules/concurrently/node_modules/cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/concurrently/node_modules/supports-color": { "version": "8.1.1", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", @@ -7420,63 +7158,6 @@ "url": "https://github.com/chalk/supports-color?sponsor=1" } }, - "node_modules/concurrently/node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/concurrently/node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, - "node_modules/concurrently/node_modules/yargs": { - "version": "17.7.2", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", - "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", - "dev": true, - "license": "MIT", - "dependencies": { - "cliui": "^8.0.1", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.3", - "y18n": "^5.0.5", - "yargs-parser": "^21.1.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/concurrently/node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=12" - } - }, "node_modules/config-file-ts": { "version": "0.2.8-rc1", "resolved": "https://registry.npmjs.org/config-file-ts/-/config-file-ts-0.2.8-rc1.tgz", @@ -7535,6 +7216,16 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/config-file-ts/node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, "node_modules/content-disposition": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-1.0.0.tgz", @@ -7585,10 +7276,9 @@ "license": "MIT" }, "node_modules/core-util-is": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", - "integrity": "sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ==", - "dev": true, + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", "license": "MIT" }, "node_modules/cors": { @@ -7629,13 +7319,6 @@ "buffer": "^5.1.0" } }, - "node_modules/create-require": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", - "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", - "dev": true, - "license": "MIT" - }, "node_modules/crelt": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/crelt/-/crelt-1.0.6.tgz", @@ -7648,37 +7331,7 @@ "integrity": "sha512-+R08/oI0nl3vfPcqftZRpytksBXDzOUveBq/NBVx0sUp1axwzPQrKinNx5yd5sxPu8j1wIy8AfnVQ+5eFdha6Q==", "dev": true, "license": "MIT", - "optional": true, - "peer": true - }, - "node_modules/cross-fetch": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-4.0.0.tgz", - "integrity": "sha512-e4a5N8lVvuLgAWgnCrLr2PP0YyDOTHa9H/Rj54dirp61qXnNq46m82bRhNqIA5VccJtWBvPTFRV3TtvHUKPB1g==", - "license": "MIT", - "dependencies": { - "node-fetch": "^2.6.12" - } - }, - "node_modules/cross-fetch/node_modules/node-fetch": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", - "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", - "license": "MIT", - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - }, - "peerDependencies": { - "encoding": "^0.1.0" - }, - "peerDependenciesMeta": { - "encoding": { - "optional": true - } - } + "optional": true }, "node_modules/cross-spawn": { "version": "7.0.6", @@ -7695,72 +7348,45 @@ "node": ">= 8" } }, - "node_modules/cross-spawn-windows-exe": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/cross-spawn-windows-exe/-/cross-spawn-windows-exe-1.2.0.tgz", - "integrity": "sha512-mkLtJJcYbDCxEG7Js6eUnUNndWjyUZwJ3H7bErmmtOYU/Zb99DyUkpamuIZE0b3bhmJyZ7D90uS6f+CGxRRjOw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/malept" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/subscription/pkg/npm-cross-spawn-windows-exe?utm_medium=referral&utm_source=npm_fund" - } - ], - "license": "Apache-2.0", - "dependencies": { - "@malept/cross-spawn-promise": "^1.1.0", - "is-wsl": "^2.2.0", - "which": "^2.0.2" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/cross-spawn-windows-exe/node_modules/@malept/cross-spawn-promise": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@malept/cross-spawn-promise/-/cross-spawn-promise-1.1.1.tgz", - "integrity": "sha512-RTBGWL5FWQcg9orDOCcp4LvItNzUPcyEU9bwaeJX0rJ1IQxzucC48Y0/sQLp/g6t99IQgAlGIaesJS+gTn7tVQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/malept" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/subscription/pkg/npm-.malept-cross-spawn-promise?utm_medium=referral&utm_source=npm_fund" - } - ], - "license": "Apache-2.0", - "dependencies": { - "cross-spawn": "^7.0.1" - }, - "engines": { - "node": ">= 10" - } - }, "node_modules/csstype": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", - "devOptional": true, "license": "MIT" }, - "node_modules/dashdash": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", - "integrity": "sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g==", - "dev": true, + "node_modules/custom-media-element": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/custom-media-element/-/custom-media-element-1.4.5.tgz", + "integrity": "sha512-cjrsQufETwxjvwZbYbKBCJNvmQ2++G9AvT45zDi7NXL9k2PdVcs2h0jQz96J6G4TMKRCcEsoJ+QTgQD00Igtjw==", + "license": "MIT" + }, + "node_modules/dash-video-element": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/dash-video-element/-/dash-video-element-0.2.0.tgz", + "integrity": "sha512-dgmhBOte6JgvSvowvrh0Q/vhSrB52Q/AUl/KqminAUkPuUT3CCUNhto1X8ANigWkmNwhktFc/PCe0lF/4tBFwQ==", "license": "MIT", "dependencies": { - "assert-plus": "^1.0.0" - }, - "engines": { - "node": ">=0.10" + "custom-media-element": "^1.4.5", + "dashjs": "^5.0.3", + "media-tracks": "^0.3.3" + } + }, + "node_modules/dashjs": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/dashjs/-/dashjs-5.0.3.tgz", + "integrity": "sha512-TXndNnCUjFjF2nYBxDVba+hWRpVkadkQ8flLp7kHkem+5+wZTfRShJCnVkPUosmjS0YPE9fVNLbYPJxHBeQZvA==", + "license": "BSD-3-Clause", + "dependencies": { + "@svta/common-media-library": "^0.12.4", + "bcp-47-match": "^2.0.3", + "bcp-47-normalize": "^2.3.0", + "codem-isoboxer": "0.3.10", + "fast-deep-equal": "3.1.3", + "html-entities": "^2.5.2", + "imsc": "^1.1.5", + "localforage": "^1.10.0", + "path-browserify": "^1.0.1", + "ua-parser-js": "^1.0.37" } }, "node_modules/data-uri-to-buffer": { @@ -7773,20 +7399,12 @@ } }, "node_modules/debug": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz", - "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==", + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", "license": "MIT", "dependencies": { - "ms": "^2.1.3" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } + "ms": "2.0.0" } }, "node_modules/decamelize": { @@ -7798,6 +7416,19 @@ "node": ">=0.10.0" } }, + "node_modules/decode-named-character-reference": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decode-named-character-reference/-/decode-named-character-reference-1.2.0.tgz", + "integrity": "sha512-c6fcElNV6ShtZXmsgNgFFV5tVX2PaV4g+MOAkb8eXHvn6sryJBrZa9r0zV6+dtTyoCKxtDy5tyQ5ZwQuidtd+Q==", + "license": "MIT", + "dependencies": { + "character-entities": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/decompress-response": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz", @@ -7813,6 +7444,18 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/decompress-response/node_modules/mimic-response": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", + "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/deep-extend": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", @@ -7890,29 +7533,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/del": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/del/-/del-6.1.1.tgz", - "integrity": "sha512-ua8BhapfP0JUJKC/zV9yHHDW/rDoDxP4Zhn3AkA6/xT6gY7jYXJiaeyBZznYVujhZZET+UgcbZiQ7sN3WqcImg==", - "dev": true, - "license": "MIT", - "dependencies": { - "globby": "^11.0.1", - "graceful-fs": "^4.2.4", - "is-glob": "^4.0.1", - "is-path-cwd": "^2.2.0", - "is-path-inside": "^3.0.2", - "p-map": "^4.0.0", - "rimraf": "^3.0.2", - "slash": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", @@ -7931,10 +7551,29 @@ "node": ">= 0.8" } }, + "node_modules/dequal": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", + "integrity": "sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "license": "MIT", + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, "node_modules/detect-libc": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.4.tgz", - "integrity": "sha512-3UDv+G9CsCKO1WKMGw9fwq/SWJYbI0c5Y7LU1AXYoDdbhE2AHQ6N6Nb34sG8Fj7T5APy8qXDCKuuIHd1BR0tVA==", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.1.1.tgz", + "integrity": "sha512-ecqj/sy1jcK1uWrwpR67UhYrIFQ+5WlGxth34WquCbamhFA6hkkwiu37o6J5xCHdo1oixJRfVRw+ywV+Hq/0Aw==", "license": "Apache-2.0", "engines": { "node": ">=8" @@ -7954,14 +7593,17 @@ "integrity": "sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==", "license": "MIT" }, - "node_modules/diff": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", - "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", - "dev": true, - "license": "BSD-3-Clause", - "engines": { - "node": ">=0.3.1" + "node_modules/devlop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/devlop/-/devlop-1.1.0.tgz", + "integrity": "sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA==", + "license": "MIT", + "dependencies": { + "dequal": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, "node_modules/dijkstrajs": { @@ -7981,27 +7623,17 @@ "p-limit": "^3.1.0 " } }, - "node_modules/dir-glob": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", - "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "node_modules/dir-compare/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", "dev": true, - "license": "MIT", + "license": "ISC", "dependencies": { - "path-type": "^4.0.0" + "brace-expansion": "^1.1.7" }, "engines": { - "node": ">=8" - } - }, - "node_modules/dir-glob/node_modules/path-type": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", - "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" + "node": "*" } }, "node_modules/dmg-builder": { @@ -8037,6 +7669,19 @@ "node": ">=12" } }, + "node_modules/dmg-builder/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/dmg-builder/node_modules/jsonfile": { "version": "6.2.0", "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz", @@ -8087,16 +7732,10 @@ "node": ">=8" } }, - "node_modules/dom-walk": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/dom-walk/-/dom-walk-0.1.2.tgz", - "integrity": "sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w==", - "dev": true - }, "node_modules/dotenv": { - "version": "17.2.2", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.2.tgz", - "integrity": "sha512-Sf2LSQP+bOlhKWWyhFsn0UsfdK/kCWRv1iuA2gXAwt3dyNabr6QSj00I2V10pidqz69soatm9ZwZvpQMTIOd5Q==", + "version": "17.2.3", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.3.tgz", + "integrity": "sha512-JVUnt+DUIzu87TABbhPmNfVdBDt18BLOWjMUFJMSi/Qqg7NTYtabbvSNJGOJ7afbRuv9D/lngizHtP7QyLQ+9w==", "license": "BSD-2-Clause", "engines": { "node": ">=12" @@ -8280,17 +7919,6 @@ "dev": true, "license": "MIT" }, - "node_modules/ecc-jsbn": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", - "integrity": "sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==", - "dev": true, - "license": "MIT", - "dependencies": { - "jsbn": "~0.1.0", - "safer-buffer": "^2.1.0" - } - }, "node_modules/ecdsa-sig-formatter": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", @@ -8323,9 +7951,9 @@ } }, "node_modules/electron": { - "version": "38.0.0", - "resolved": "https://registry.npmjs.org/electron/-/electron-38.0.0.tgz", - "integrity": "sha512-egljptiPJqbL/oamFCEY+g3RNeONWTVxZSGeyLqzK8xq106JhzuxnhJZ3sxt4DzJFaofbGyGJA37Oe9d+gVzYw==", + "version": "38.2.0", + "resolved": "https://registry.npmjs.org/electron/-/electron-38.2.0.tgz", + "integrity": "sha512-Cw5Mb+N5NxsG0Hc1qr8I65Kt5APRrbgTtEEn3zTod30UNJRnAE1xbGk/1NOaDn3ODzI/MYn6BzT9T9zreP7xWA==", "dev": true, "hasInstallScript": true, "license": "MIT", @@ -8380,21 +8008,6 @@ "electron-winstaller": "5.4.0" } }, - "node_modules/electron-builder/node_modules/cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/electron-builder/node_modules/fs-extra": { "version": "10.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", @@ -8433,266 +8046,6 @@ "node": ">= 10.0.0" } }, - "node_modules/electron-builder/node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/electron-builder/node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, - "node_modules/electron-builder/node_modules/yargs": { - "version": "17.7.2", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", - "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", - "dev": true, - "license": "MIT", - "dependencies": { - "cliui": "^8.0.1", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.3", - "y18n": "^5.0.5", - "yargs-parser": "^21.1.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/electron-builder/node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=12" - } - }, - "node_modules/electron-icon-builder": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/electron-icon-builder/-/electron-icon-builder-2.0.1.tgz", - "integrity": "sha512-rg9BxW2kJi3TXsMFFNXWXrwQEd5dzXmeD+w7Pj3k3z7aYRePLxE89qU4lvL/rK1X/NTY5KDn3+Dbgm1TU2dGXQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "args": "^5.0.1", - "icon-gen": "^2.0.0", - "jimp": "^0.16.1" - }, - "bin": { - "electron-icon-builder": "index.js" - }, - "engines": { - "node": ">= 10.0.0" - } - }, - "node_modules/electron-packager": { - "version": "17.1.2", - "resolved": "https://registry.npmjs.org/electron-packager/-/electron-packager-17.1.2.tgz", - "integrity": "sha512-XofXdikjYI7MVBcnXeoOvRR+yFFFHOLs3J7PF5KYQweigtgLshcH4W660PsvHr4lYZ03JBpLyEcUB8DzHZ+BNw==", - "deprecated": "Please use @electron/packager moving forward. There is no API change, just a package name change", - "dev": true, - "license": "BSD-2-Clause", - "dependencies": { - "@electron/asar": "^3.2.1", - "@electron/get": "^2.0.0", - "@electron/notarize": "^1.2.3", - "@electron/osx-sign": "^1.0.5", - "@electron/universal": "^1.3.2", - "cross-spawn-windows-exe": "^1.2.0", - "debug": "^4.0.1", - "extract-zip": "^2.0.0", - "filenamify": "^4.1.0", - "fs-extra": "^11.1.0", - "galactus": "^1.0.0", - "get-package-info": "^1.0.0", - "junk": "^3.1.0", - "parse-author": "^2.0.0", - "plist": "^3.0.0", - "rcedit": "^3.0.1", - "resolve": "^1.1.6", - "semver": "^7.1.3", - "yargs-parser": "^21.1.1" - }, - "bin": { - "electron-packager": "bin/electron-packager.js" - }, - "engines": { - "node": ">= 14.17.5" - }, - "funding": { - "url": "https://github.com/electron/electron-packager?sponsor=1" - } - }, - "node_modules/electron-packager/node_modules/@electron/notarize": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/@electron/notarize/-/notarize-1.2.4.tgz", - "integrity": "sha512-W5GQhJEosFNafewnS28d3bpQ37/s91CDWqxVchHfmv2dQSTWpOzNlUVQwYzC1ay5bChRV/A9BTL68yj0Pa+TSg==", - "dev": true, - "license": "MIT", - "dependencies": { - "debug": "^4.1.1", - "fs-extra": "^9.0.1" - }, - "engines": { - "node": ">= 10.0.0" - } - }, - "node_modules/electron-packager/node_modules/@electron/notarize/node_modules/fs-extra": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", - "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "at-least-node": "^1.0.0", - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/electron-packager/node_modules/@electron/universal": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/@electron/universal/-/universal-1.5.1.tgz", - "integrity": "sha512-kbgXxyEauPJiQQUNG2VgUeyfQNFk6hBF11ISN2PNI6agUgPl55pv4eQmaqHzTAzchBvqZ2tQuRVaPStGf0mxGw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@electron/asar": "^3.2.1", - "@malept/cross-spawn-promise": "^1.1.0", - "debug": "^4.3.1", - "dir-compare": "^3.0.0", - "fs-extra": "^9.0.1", - "minimatch": "^3.0.4", - "plist": "^3.0.4" - }, - "engines": { - "node": ">=8.6" - } - }, - "node_modules/electron-packager/node_modules/@electron/universal/node_modules/fs-extra": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", - "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "at-least-node": "^1.0.0", - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/electron-packager/node_modules/@malept/cross-spawn-promise": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@malept/cross-spawn-promise/-/cross-spawn-promise-1.1.1.tgz", - "integrity": "sha512-RTBGWL5FWQcg9orDOCcp4LvItNzUPcyEU9bwaeJX0rJ1IQxzucC48Y0/sQLp/g6t99IQgAlGIaesJS+gTn7tVQ==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/malept" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/subscription/pkg/npm-.malept-cross-spawn-promise?utm_medium=referral&utm_source=npm_fund" - } - ], - "license": "Apache-2.0", - "dependencies": { - "cross-spawn": "^7.0.1" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/electron-packager/node_modules/dir-compare": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/dir-compare/-/dir-compare-3.3.0.tgz", - "integrity": "sha512-J7/et3WlGUCxjdnD3HAAzQ6nsnc0WL6DD7WcwJb7c39iH1+AWfg+9OqzJNaI6PkBwBvm1mhZNL9iY/nRiZXlPg==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer-equal": "^1.0.0", - "minimatch": "^3.0.4" - } - }, - "node_modules/electron-packager/node_modules/fs-extra": { - "version": "11.3.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.1.tgz", - "integrity": "sha512-eXvGGwZ5CL17ZSwHWd3bbgk7UUpF6IFHtP57NYYakPvHOs8GDgDe5KJI36jIJzDkJ6eJjuzRA8eBQb6SkKue0g==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=14.14" - } - }, - "node_modules/electron-packager/node_modules/jsonfile": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz", - "integrity": "sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==", - "dev": true, - "license": "MIT", - "dependencies": { - "universalify": "^2.0.0" - }, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/electron-packager/node_modules/universalify": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", - "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 10.0.0" - } - }, - "node_modules/electron-packager/node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=12" - } - }, "node_modules/electron-publish": { "version": "26.0.11", "resolved": "https://registry.npmjs.org/electron-publish/-/electron-publish-26.0.11.tgz", @@ -8748,13 +8101,6 @@ "node": ">= 10.0.0" } }, - "node_modules/electron-to-chromium": { - "version": "1.5.215", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.215.tgz", - "integrity": "sha512-TIvGp57UpeNetj/wV/xpFNpWGb0b/ROw372lHPx5Aafx02gjTBtWnEEcaSX3W2dLM3OSdGGyHX/cHl01JQsLaQ==", - "dev": true, - "license": "ISC" - }, "node_modules/electron-winstaller": { "version": "5.4.0", "resolved": "https://registry.npmjs.org/electron-winstaller/-/electron-winstaller-5.4.0.tgz", @@ -8762,7 +8108,6 @@ "dev": true, "hasInstallScript": true, "license": "MIT", - "peer": true, "dependencies": { "@electron/asar": "^3.2.1", "debug": "^4.1.1", @@ -8777,13 +8122,30 @@ "@electron/windows-sign": "^1.1.2" } }, + "node_modules/electron-winstaller/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/electron-winstaller/node_modules/fs-extra": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", "dev": true, "license": "MIT", - "peer": true, "dependencies": { "graceful-fs": "^4.1.2", "jsonfile": "^4.0.0", @@ -8793,10 +8155,17 @@ "node": ">=6 <7 || >=8" } }, + "node_modules/electron-winstaller/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/electron/node_modules/@types/node": { - "version": "22.18.1", - "resolved": "https://registry.npmjs.org/@types/node/-/node-22.18.1.tgz", - "integrity": "sha512-rzSDyhn4cYznVG+PCzGe1lwuMYJrcBS1fc3JqSa2PvtABwWo+dZ1ij5OVok3tqfpEBCBoaR4d7upFJk73HRJDw==", + "version": "22.18.8", + "resolved": "https://registry.npmjs.org/@types/node/-/node-22.18.8.tgz", + "integrity": "sha512-pAZSHMiagDR7cARo/cch1f3rXy0AEXwsVsVH09FcyeJVAzCnGgmYis7P3JidtTUjyadhTeSo8TgRPswstghDaw==", "dev": true, "license": "MIT", "dependencies": { @@ -8829,12 +8198,27 @@ "version": "0.1.13", "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", + "dev": true, "license": "MIT", "optional": true, "dependencies": { "iconv-lite": "^0.6.2" } }, + "node_modules/encoding/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "license": "MIT", + "optional": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/end-of-stream": { "version": "1.4.5", "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.5.tgz", @@ -8874,16 +8258,6 @@ "dev": true, "license": "MIT" }, - "node_modules/error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-arrayish": "^0.2.1" - } - }, "node_modules/es-define-property": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz", @@ -8937,17 +8311,10 @@ "license": "MIT", "optional": true }, - "node_modules/es6-promise": { - "version": "4.2.8", - "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", - "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", - "dev": true, - "license": "MIT" - }, "node_modules/esbuild": { - "version": "0.25.9", - "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.9.tgz", - "integrity": "sha512-CRbODhYyQx3qp7ZEwzxOk4JBqmD/seJrzPa/cGjY1VtIn5E09Oi9/dB4JwctnfZ8Q8iT7rioVv5k/FNT/uf54g==", + "version": "0.25.10", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.10.tgz", + "integrity": "sha512-9RiGKvCwaqxO2owP61uQ4BgNborAQskMR6QusfWzQqv7AZOg5oGehdY2pRJMTKuwxd1IDBP4rSbI5lHzU7SMsQ==", "hasInstallScript": true, "license": "MIT", "bin": { @@ -8957,32 +8324,32 @@ "node": ">=18" }, "optionalDependencies": { - "@esbuild/aix-ppc64": "0.25.9", - "@esbuild/android-arm": "0.25.9", - "@esbuild/android-arm64": "0.25.9", - "@esbuild/android-x64": "0.25.9", - "@esbuild/darwin-arm64": "0.25.9", - "@esbuild/darwin-x64": "0.25.9", - "@esbuild/freebsd-arm64": "0.25.9", - "@esbuild/freebsd-x64": "0.25.9", - "@esbuild/linux-arm": "0.25.9", - "@esbuild/linux-arm64": "0.25.9", - "@esbuild/linux-ia32": "0.25.9", - "@esbuild/linux-loong64": "0.25.9", - "@esbuild/linux-mips64el": "0.25.9", - "@esbuild/linux-ppc64": "0.25.9", - "@esbuild/linux-riscv64": "0.25.9", - "@esbuild/linux-s390x": "0.25.9", - "@esbuild/linux-x64": "0.25.9", - "@esbuild/netbsd-arm64": "0.25.9", - "@esbuild/netbsd-x64": "0.25.9", - "@esbuild/openbsd-arm64": "0.25.9", - "@esbuild/openbsd-x64": "0.25.9", - "@esbuild/openharmony-arm64": "0.25.9", - "@esbuild/sunos-x64": "0.25.9", - "@esbuild/win32-arm64": "0.25.9", - "@esbuild/win32-ia32": "0.25.9", - "@esbuild/win32-x64": "0.25.9" + "@esbuild/aix-ppc64": "0.25.10", + "@esbuild/android-arm": "0.25.10", + "@esbuild/android-arm64": "0.25.10", + "@esbuild/android-x64": "0.25.10", + "@esbuild/darwin-arm64": "0.25.10", + "@esbuild/darwin-x64": "0.25.10", + "@esbuild/freebsd-arm64": "0.25.10", + "@esbuild/freebsd-x64": "0.25.10", + "@esbuild/linux-arm": "0.25.10", + "@esbuild/linux-arm64": "0.25.10", + "@esbuild/linux-ia32": "0.25.10", + "@esbuild/linux-loong64": "0.25.10", + "@esbuild/linux-mips64el": "0.25.10", + "@esbuild/linux-ppc64": "0.25.10", + "@esbuild/linux-riscv64": "0.25.10", + "@esbuild/linux-s390x": "0.25.10", + "@esbuild/linux-x64": "0.25.10", + "@esbuild/netbsd-arm64": "0.25.10", + "@esbuild/netbsd-x64": "0.25.10", + "@esbuild/openbsd-arm64": "0.25.10", + "@esbuild/openbsd-x64": "0.25.10", + "@esbuild/openharmony-arm64": "0.25.10", + "@esbuild/sunos-x64": "0.25.10", + "@esbuild/win32-arm64": "0.25.10", + "@esbuild/win32-ia32": "0.25.10", + "@esbuild/win32-x64": "0.25.10" } }, "node_modules/escalade": { @@ -9015,11 +8382,12 @@ } }, "node_modules/eslint": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.35.0.tgz", - "integrity": "sha512-QePbBFMJFjgmlE+cXAlbHZbHpdFVS2E/6vzCy7aKlebddvl1vadiC4JFV5u/wqTkNUwEV8WrQi257jf5f06hrg==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.36.0.tgz", + "integrity": "sha512-hB4FIzXovouYzwzECDcUkJ4OcfOEkXTv2zRY6B9bkwjx/cprAq0uvm1nl7zvQ0/TsUk0zQiN4uPfJpB9m+rPMQ==", "dev": true, "license": "MIT", + "peer": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", @@ -9027,7 +8395,7 @@ "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.35.0", + "@eslint/js": "9.36.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -9089,9 +8457,9 @@ } }, "node_modules/eslint-plugin-react-refresh": { - "version": "0.4.20", - "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.20.tgz", - "integrity": "sha512-XpbHQ2q5gUF8BGOX4dHe+71qoirYMhApEPZ7sfhF/dNnOF1UXnCMGZf79SFTBO7Bz5YEIT4TMieSlJBWhP9WBA==", + "version": "0.4.22", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.22.tgz", + "integrity": "sha512-atkAG6QaJMGoTLc4MDAP+rqZcfwQuTIh2IqHWFLy2TEjxr0MOK+5BSG4RzL2564AAPpZkDRsZXAUz68kjnU6Ug==", "dev": true, "license": "MIT", "peerDependencies": { @@ -9128,6 +8496,44 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/eslint/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/eslint/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/espree": { "version": "10.4.0", "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz", @@ -9182,6 +8588,16 @@ "node": ">=4.0" } }, + "node_modules/estree-util-is-identifier-name": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/estree-util-is-identifier-name/-/estree-util-is-identifier-name-3.0.0.tgz", + "integrity": "sha512-hFtqIDZTIUZ9BXLb8y4pYGyk6+wekIivNVTcmvk8NoOh+VeRn5y6cEHzbURrWbfp1fIqdVipilzj+lfaadNZmg==", + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/esutils": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", @@ -9201,32 +8617,6 @@ "node": ">= 0.6" } }, - "node_modules/event-target-shim": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", - "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/events": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", - "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.x" - } - }, - "node_modules/exif-parser": { - "version": "0.1.12", - "resolved": "https://registry.npmjs.org/exif-parser/-/exif-parser-0.1.12.tgz", - "integrity": "sha512-c2bQfLNbMzLPmzQuOr8fy0csy84WmwnER81W88DzTp9CYNPJ6yzOj2EZAh9pywYpqHnshVLHQJ8WzldAyfY+Iw==", - "dev": true - }, "node_modules/expand-template": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/expand-template/-/expand-template-2.0.3.tgz", @@ -9285,6 +8675,26 @@ "url": "https://opencollective.com/express" } }, + "node_modules/express/node_modules/body-parser": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", + "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "license": "MIT", + "dependencies": { + "bytes": "^3.1.2", + "content-type": "^1.0.5", + "debug": "^4.4.0", + "http-errors": "^2.0.0", + "iconv-lite": "^0.6.3", + "on-finished": "^2.4.1", + "qs": "^6.14.0", + "raw-body": "^3.0.0", + "type-is": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/express/node_modules/cookie-signature": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.2.2.tgz", @@ -9294,11 +8704,114 @@ "node": ">=6.6.0" } }, + "node_modules/express/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/express/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/express/node_modules/media-typer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-1.1.0.tgz", + "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, + "node_modules/express/node_modules/qs": { + "version": "6.14.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.14.0.tgz", + "integrity": "sha512-YWWTjgABSKcvs/nWBi9PycY/JiPJqOD4JA6o9Sej2AtvSGarXxKC3OQSk4pAarbdQlKAh5D4FCQkJNkW+GAn3w==", + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.1.0" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/express/node_modules/raw-body": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", + "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "license": "MIT", + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.7.0", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/express/node_modules/raw-body/node_modules/iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/express/node_modules/type-is": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-2.0.1.tgz", + "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", + "license": "MIT", + "dependencies": { + "content-type": "^1.0.5", + "media-typer": "^1.1.0", + "mime-types": "^3.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/extend": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", - "dev": true, "license": "MIT" }, "node_modules/extract-zip": { @@ -9322,6 +8835,31 @@ "@types/yauzl": "^2.9.1" } }, + "node_modules/extract-zip/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/extract-zip/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/extsprintf": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.4.1.tgz", @@ -9337,7 +8875,6 @@ "version": "3.1.3", "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", - "dev": true, "license": "MIT" }, "node_modules/fast-glob": { @@ -9394,6 +8931,19 @@ "reusify": "^1.0.4" } }, + "node_modules/fault": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/fault/-/fault-1.0.4.tgz", + "integrity": "sha512-CJ0HCB5tL5fYTEA7ToAq5+kTwd++Borf1/bifxd9iT70QcXr4MRrO3Llf8Ifs70q+SJcGHFtnIE/Nw6giCtECA==", + "license": "MIT", + "dependencies": { + "format": "^0.2.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/fd-slicer": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", @@ -9440,40 +8990,12 @@ "node": ">=16.0.0" } }, - "node_modules/file-type": { - "version": "16.5.4", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-16.5.4.tgz", - "integrity": "sha512-/yFHK0aGjFEgDJjEKP0pWCplsPFPhwyfwevf/pVxiN0tmE4L9LmwWxWukdJSHdoCli4VgQLehjJtwQBnqmsKcw==", - "dev": true, - "license": "MIT", - "dependencies": { - "readable-web-to-node-stream": "^3.0.0", - "strtok3": "^6.2.4", - "token-types": "^4.1.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/file-type?sponsor=1" - } - }, "node_modules/file-uri-to-path": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", "license": "MIT" }, - "node_modules/file-url": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/file-url/-/file-url-2.0.2.tgz", - "integrity": "sha512-x3989K8a1jM6vulMigE8VngH7C5nci0Ks5d9kVjUXmNF28gmiZUNujk5HjwaS8dAzN2QmUfX56riJKgN00dNRw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/filelist": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", @@ -9507,34 +9029,6 @@ "node": ">=10" } }, - "node_modules/filename-reserved-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/filename-reserved-regex/-/filename-reserved-regex-2.0.0.tgz", - "integrity": "sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/filenamify": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/filenamify/-/filenamify-4.3.0.tgz", - "integrity": "sha512-hcFKyUG57yWGAzu1CMt/dPzYZuv+jAJUT85bL8mrXvNe6hWj6yEHEc4EdcgiA6Z3oi1/9wXJdZPXF2dZNgwgOg==", - "dev": true, - "license": "MIT", - "dependencies": { - "filename-reserved-regex": "^2.0.0", - "strip-outer": "^1.0.1", - "trim-repeated": "^1.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/fill-range": { "version": "7.1.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", @@ -9565,6 +9059,29 @@ "node": ">= 0.8" } }, + "node_modules/finalhandler/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/finalhandler/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, "node_modules/find-up": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", @@ -9603,58 +9120,6 @@ "dev": true, "license": "ISC" }, - "node_modules/flora-colossus": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/flora-colossus/-/flora-colossus-2.0.0.tgz", - "integrity": "sha512-dz4HxH6pOvbUzZpZ/yXhafjbR2I8cenK5xL0KtBFb7U2ADsR+OwXifnxZjij/pZWF775uSCMzWVd+jDik2H2IA==", - "dev": true, - "license": "MIT", - "dependencies": { - "debug": "^4.3.4", - "fs-extra": "^10.1.0" - }, - "engines": { - "node": ">= 12" - } - }, - "node_modules/flora-colossus/node_modules/fs-extra": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", - "integrity": "sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/flora-colossus/node_modules/jsonfile": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz", - "integrity": "sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==", - "dev": true, - "license": "MIT", - "dependencies": { - "universalify": "^2.0.0" - }, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/flora-colossus/node_modules/universalify": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", - "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 10.0.0" - } - }, "node_modules/follow-redirects": { "version": "1.15.11", "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.11.tgz", @@ -9705,16 +9170,6 @@ "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/forever-agent": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", - "integrity": "sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw==", - "dev": true, - "license": "Apache-2.0", - "engines": { - "node": "*" - } - }, "node_modules/form-data": { "version": "4.0.4", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz", @@ -9752,6 +9207,14 @@ "node": ">= 0.6" } }, + "node_modules/format": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/format/-/format-0.2.2.tgz", + "integrity": "sha512-wzsgA6WOq+09wrU1tsJ09udeR/YZRaeArL9e1wPbFg3GG2yDnC2ldKpxs4xunpFF9DgqCqOIra3bc1HWrJ37Ww==", + "engines": { + "node": ">=0.4.x" + } + }, "node_modules/formdata-polyfill": { "version": "4.0.10", "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz", @@ -9773,20 +9236,6 @@ "node": ">= 0.6" } }, - "node_modules/fraction.js": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", - "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", - "dev": true, - "license": "MIT", - "engines": { - "node": "*" - }, - "funding": { - "type": "patreon", - "url": "https://github.com/sponsors/rawify" - } - }, "node_modules/fresh": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/fresh/-/fresh-2.0.0.tgz", @@ -9830,26 +9279,6 @@ "node": ">= 8" } }, - "node_modules/fs-minipass/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/fs-minipass/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", @@ -9880,59 +9309,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/galactus": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/galactus/-/galactus-1.0.0.tgz", - "integrity": "sha512-R1fam6D4CyKQGNlvJne4dkNF+PvUUl7TAJInvTGa9fti9qAv95quQz29GXapA4d8Ec266mJJxFVh82M4GIIGDQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "debug": "^4.3.4", - "flora-colossus": "^2.0.0", - "fs-extra": "^10.1.0" - }, - "engines": { - "node": ">= 12" - } - }, - "node_modules/galactus/node_modules/fs-extra": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", - "integrity": "sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/galactus/node_modules/jsonfile": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz", - "integrity": "sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==", - "dev": true, - "license": "MIT", - "dependencies": { - "universalify": "^2.0.0" - }, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/galactus/node_modules/universalify": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", - "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 10.0.0" - } - }, "node_modules/get-caller-file": { "version": "2.0.5", "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", @@ -9975,39 +9351,6 @@ "node": ">=6" } }, - "node_modules/get-package-info": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/get-package-info/-/get-package-info-1.0.0.tgz", - "integrity": "sha512-SCbprXGAPdIhKAXiG+Mk6yeoFH61JlYunqdFQFHDtLjJlDjFf6x07dsS8acO+xWt52jpdVo49AlVDnUVK1sDNw==", - "dev": true, - "license": "MIT", - "dependencies": { - "bluebird": "^3.1.1", - "debug": "^2.2.0", - "lodash.get": "^4.0.0", - "read-pkg-up": "^2.0.0" - }, - "engines": { - "node": ">= 4.0" - } - }, - "node_modules/get-package-info/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/get-package-info/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, "node_modules/get-proto": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz", @@ -10037,27 +9380,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/getpass": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", - "integrity": "sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==", - "dev": true, - "license": "MIT", - "dependencies": { - "assert-plus": "^1.0.0" - } - }, - "node_modules/gifwrap": { - "version": "0.9.4", - "resolved": "https://registry.npmjs.org/gifwrap/-/gifwrap-0.9.4.tgz", - "integrity": "sha512-MDMwbhASQuVeD4JKd1fKgNgCRL3fGqMM4WaqpNhWO0JiMOAjbQdumbs4BbBZEy9/M00EHEjKN3HieVhCUlwjeQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "image-q": "^4.0.0", - "omggif": "^1.0.10" - } - }, "node_modules/github-from-package": { "version": "0.0.0", "resolved": "https://registry.npmjs.org/github-from-package/-/github-from-package-0.0.0.tgz", @@ -10099,15 +9421,17 @@ "node": ">=10.13.0" } }, - "node_modules/global": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/global/-/global-4.4.0.tgz", - "integrity": "sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w==", + "node_modules/glob/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", "dev": true, - "license": "MIT", + "license": "ISC", "dependencies": { - "min-document": "^2.19.0", - "process": "^0.11.10" + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" } }, "node_modules/global-agent": { @@ -10129,6 +9453,20 @@ "node": ">=10.0" } }, + "node_modules/global-agent/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "dev": true, + "license": "ISC", + "optional": true, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/globals": { "version": "16.4.0", "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", @@ -10160,27 +9498,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/globby": { - "version": "11.1.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", - "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", - "dev": true, - "license": "MIT", - "dependencies": { - "array-union": "^2.1.0", - "dir-glob": "^3.0.1", - "fast-glob": "^3.2.9", - "ignore": "^5.2.0", - "merge2": "^1.4.1", - "slash": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/gopd": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz", @@ -10232,31 +9549,6 @@ "dev": true, "license": "MIT" }, - "node_modules/har-schema": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", - "integrity": "sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=4" - } - }, - "node_modules/har-validator": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", - "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", - "deprecated": "this library is no longer supported", - "dev": true, - "license": "MIT", - "dependencies": { - "ajv": "^6.12.3", - "har-schema": "^2.0.0" - }, - "engines": { - "node": ">=6" - } - }, "node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", @@ -10307,20 +9599,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/hasha": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/hasha/-/hasha-2.2.0.tgz", - "integrity": "sha512-jZ38TU/EBiGKrmyTNNZgnvCZHNowiRI4+w/I9noMlekHTZH3KyGgvJLmhSgykeAQ9j2SYPDosM0Bg3wHfzibAQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-stream": "^1.0.1", - "pinkie-promise": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/hasown": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", @@ -10333,6 +9611,153 @@ "node": ">= 0.4" } }, + "node_modules/hast-util-parse-selector": { + "version": "2.2.5", + "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-2.2.5.tgz", + "integrity": "sha512-7j6mrk/qqkSehsM92wQjdIgWM2/BW61u/53G6xmC8i1OmEdKLHbk419QKQUjz6LglWsfqoiHmyMRkP1BGjecNQ==", + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-to-jsx-runtime": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/hast-util-to-jsx-runtime/-/hast-util-to-jsx-runtime-2.3.6.tgz", + "integrity": "sha512-zl6s8LwNyo1P9uw+XJGvZtdFF1GdAkOg8ujOw+4Pyb76874fLps4ueHXDhXWdk6YHQ6OgUtinliG7RsYvCbbBg==", + "license": "MIT", + "dependencies": { + "@types/estree": "^1.0.0", + "@types/hast": "^3.0.0", + "@types/unist": "^3.0.0", + "comma-separated-tokens": "^2.0.0", + "devlop": "^1.0.0", + "estree-util-is-identifier-name": "^3.0.0", + "hast-util-whitespace": "^3.0.0", + "mdast-util-mdx-expression": "^2.0.0", + "mdast-util-mdx-jsx": "^3.0.0", + "mdast-util-mdxjs-esm": "^2.0.0", + "property-information": "^7.0.0", + "space-separated-tokens": "^2.0.0", + "style-to-js": "^1.0.0", + "unist-util-position": "^5.0.0", + "vfile-message": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-whitespace": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-3.0.0.tgz", + "integrity": "sha512-88JUN06ipLwsnv+dVn+OIYOvAuvBMy/Qoi6O7mQHxdPXpjy+Cd6xRkWwux7DKO+4sYILtLBRIKgsdpS2gQc7qw==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hastscript": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-6.0.0.tgz", + "integrity": "sha512-nDM6bvd7lIqDUiYEiu5Sl/+6ReP0BMk/2f4U/Rooccxkj0P5nm+acM5PrGJ/t5I8qPGiqZSE6hVAwZEdZIvP4w==", + "license": "MIT", + "dependencies": { + "@types/hast": "^2.0.0", + "comma-separated-tokens": "^1.0.0", + "hast-util-parse-selector": "^2.0.0", + "property-information": "^5.0.0", + "space-separated-tokens": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hastscript/node_modules/@types/hast": { + "version": "2.3.10", + "resolved": "https://registry.npmjs.org/@types/hast/-/hast-2.3.10.tgz", + "integrity": "sha512-McWspRw8xx8J9HurkVBfYj0xKoE25tOFlHGdx4MJ5xORQrMGZNqJhVQWaIbm6Oyla5kYOXtDiopzKRJzEOkwJw==", + "license": "MIT", + "dependencies": { + "@types/unist": "^2" + } + }, + "node_modules/hastscript/node_modules/@types/unist": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.11.tgz", + "integrity": "sha512-CmBKiL6NNo/OqgmMn95Fk9Whlp2mtvIv+KNpQKN2F4SjvrEesubTRWGYSg+BnWZOnlCaSTU1sMpsBOzgbYhnsA==", + "license": "MIT" + }, + "node_modules/hastscript/node_modules/comma-separated-tokens": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-1.0.8.tgz", + "integrity": "sha512-GHuDRO12Sypu2cV70d1dkA2EUmXHgntrzbpvOB+Qy+49ypNfGgFQIC2fhhXbnyrJRynDCAARsT7Ou0M6hirpfw==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/hastscript/node_modules/property-information": { + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/property-information/-/property-information-5.6.0.tgz", + "integrity": "sha512-YUHSPk+A30YPv+0Qf8i9Mbfe/C0hdPXk1s1jPVToV8pk8BQtpw10ct89Eo7OWkutrwqvT0eicAxlOg3dOAu8JA==", + "license": "MIT", + "dependencies": { + "xtend": "^4.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/hastscript/node_modules/space-separated-tokens": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-1.1.5.tgz", + "integrity": "sha512-q/JSVd1Lptzhf5bkYm4ob4iWPjx0KiRe3sRFBNrVqbJkFaBm5vbbowy1mymoPNLRa52+oadOhJ+K49wsSeSjTA==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/highlight.js": { + "version": "10.7.3", + "resolved": "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz", + "integrity": "sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==", + "license": "BSD-3-Clause", + "engines": { + "node": "*" + } + }, + "node_modules/highlightjs-vue": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/highlightjs-vue/-/highlightjs-vue-1.0.0.tgz", + "integrity": "sha512-PDEfEF102G23vHmPhLyPboFCD+BkMGu+GuJe2d9/eH4FsCwvgBpnc9n0pGE+ffKdph38s6foEZiEjdgHdzp+IA==", + "license": "CC0-1.0" + }, + "node_modules/hls-video-element": { + "version": "1.5.8", + "resolved": "https://registry.npmjs.org/hls-video-element/-/hls-video-element-1.5.8.tgz", + "integrity": "sha512-DdeX5NzhM2Bj+ls5aaRrzSSnriK+r6lCrDa0YyfviNO4zb10JyAnJHZM214lXBWQghCm+fKmlWW1qpzdNoSAvQ==", + "license": "MIT", + "dependencies": { + "custom-media-element": "^1.4.5", + "hls.js": "^1.6.5", + "media-tracks": "^0.3.3" + } + }, + "node_modules/hls.js": { + "version": "1.6.13", + "resolved": "https://registry.npmjs.org/hls.js/-/hls.js-1.6.13.tgz", + "integrity": "sha512-hNEzjZNHf5bFrUNvdS4/1RjIanuJ6szpWNfTaX5I6WfGynWXGT7K/YQLYtemSvFExzeMdgdE4SsyVLJbd5PcZA==", + "license": "Apache-2.0" + }, "node_modules/hosted-git-info": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", @@ -10346,6 +9771,22 @@ "node": ">=10" } }, + "node_modules/html-entities": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.6.0.tgz", + "integrity": "sha512-kig+rMn/QOVRvr7c86gQ8lWXq+Hkv6CbAH1hLu+RG338StTpE8Z0b44SDVaqVu7HGKf27frdmUYEs9hTUX/cLQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/mdevils" + }, + { + "type": "patreon", + "url": "https://patreon.com/mdevils" + } + ], + "license": "MIT" + }, "node_modules/html-parse-stringify": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/html-parse-stringify/-/html-parse-stringify-3.0.1.tgz", @@ -10355,6 +9796,16 @@ "void-elements": "3.1.0" } }, + "node_modules/html-url-attributes": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/html-url-attributes/-/html-url-attributes-3.0.1.tgz", + "integrity": "sha512-ol6UPyBWqsrO6EJySPz2O7ZSr856WDrEzM5zMqp+FJJLGMW35cLYmmZnl0vztAZxRUoNZJFTCohfjuIJ8I4QBQ==", + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/http-cache-semantics": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.2.0.tgz", @@ -10401,22 +9852,31 @@ "node": ">= 14" } }, - "node_modules/http-signature": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", - "integrity": "sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ==", + "node_modules/http-proxy-agent/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "license": "MIT", "dependencies": { - "assert-plus": "^1.0.0", - "jsprim": "^1.2.2", - "sshpk": "^1.7.0" + "ms": "^2.1.3" }, "engines": { - "node": ">=0.8", - "npm": ">=1.3.7" + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } } }, + "node_modules/http-proxy-agent/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/http2-wrapper": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/http2-wrapper/-/http2-wrapper-1.0.3.tgz", @@ -10445,6 +9905,31 @@ "node": ">= 14" } }, + "node_modules/https-proxy-agent/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/https-proxy-agent/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/humanize-ms": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz", @@ -10456,9 +9941,9 @@ } }, "node_modules/i18next": { - "version": "25.5.2", - "resolved": "https://registry.npmjs.org/i18next/-/i18next-25.5.2.tgz", - "integrity": "sha512-lW8Zeh37i/o0zVr+NoCHfNnfvVw+M6FQbRp36ZZ/NyHDJ3NJVpp2HhAUyU9WafL5AssymNoOjMRB48mmx2P6Hw==", + "version": "25.5.3", + "resolved": "https://registry.npmjs.org/i18next/-/i18next-25.5.3.tgz", + "integrity": "sha512-joFqorDeQ6YpIXni944upwnuHBf5IoPMuqAchGVeQLdWC2JOjxgM9V8UGLhNIIH/Q8QleRxIi0BSRQehSrDLcg==", "funding": [ { "type": "individual", @@ -10474,6 +9959,7 @@ } ], "license": "MIT", + "peer": true, "dependencies": { "@babel/runtime": "^7.27.6" }, @@ -10495,69 +9981,6 @@ "@babel/runtime": "^7.23.2" } }, - "node_modules/i18next-http-backend": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/i18next-http-backend/-/i18next-http-backend-3.0.2.tgz", - "integrity": "sha512-PdlvPnvIp4E1sYi46Ik4tBYh/v/NbYfFFgTjkwFl0is8A18s7/bx9aXqsrOax9WUbeNS6mD2oix7Z0yGGf6m5g==", - "license": "MIT", - "dependencies": { - "cross-fetch": "4.0.0" - } - }, - "node_modules/icon-gen": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/icon-gen/-/icon-gen-2.1.0.tgz", - "integrity": "sha512-rqIVvq9MJ8X7wnJW0NO8Eau/+5RWV7AH6L5vEt/U5Ajv5WefdDNDxGwJhGokyHuyBWeX7JqRMQ03tG0gAco4Eg==", - "dev": true, - "license": "MIT", - "dependencies": { - "commander": "^6.2.0", - "del": "^6.0.0", - "mkdirp": "^1.0.4", - "pngjs": "^6.0.0", - "svg2png": "4.1.1", - "uuid": "^8.3.1" - }, - "bin": { - "icon-gen": "dist/bin/index.js" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/icon-gen/node_modules/commander": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz", - "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 6" - } - }, - "node_modules/icon-gen/node_modules/mkdirp": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", - "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", - "dev": true, - "license": "MIT", - "bin": { - "mkdirp": "bin/cmd.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/icon-gen/node_modules/pngjs": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-6.0.0.tgz", - "integrity": "sha512-TRzzuFRRmEoSW/p1KVAmiOgPco2Irlah+bGFCeNfJXxxYGwSw7YwAOAcd7X28K/m5bjBWKsC29KyoMfHbypayg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=12.13.0" - } - }, "node_modules/iconv-corefoundation": { "version": "1.1.7", "resolved": "https://registry.npmjs.org/iconv-corefoundation/-/iconv-corefoundation-1.1.7.tgz", @@ -10577,12 +10000,12 @@ } }, "node_modules/iconv-lite": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", - "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", "license": "MIT", "dependencies": { - "safer-buffer": ">= 2.1.2 < 3.0.0" + "safer-buffer": ">= 2.1.2 < 3" }, "engines": { "node": ">=0.10.0" @@ -10618,21 +10041,10 @@ "node": ">= 4" } }, - "node_modules/image-q": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/image-q/-/image-q-4.0.0.tgz", - "integrity": "sha512-PfJGVgIfKQJuq3s0tTDOKtztksibuUEbJQIYT3by6wctQo+Rdlh7ef4evJ5NCdxY4CfMbvFkocEwbl4BF8RlJw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/node": "16.9.1" - } - }, - "node_modules/image-q/node_modules/@types/node": { - "version": "16.9.1", - "resolved": "https://registry.npmjs.org/@types/node/-/node-16.9.1.tgz", - "integrity": "sha512-QpLcX9ZSsq3YYUUnD3nFDY8H7wctAhQj/TFKL8Ya8v5fMm3CFXxo8zStsLAl780ltoYoo1WvKUVGBQK+1ifr7g==", - "dev": true, + "node_modules/immediate": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", + "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", "license": "MIT" }, "node_modules/import-fresh": { @@ -10652,6 +10064,21 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/imsc": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/imsc/-/imsc-1.1.5.tgz", + "integrity": "sha512-V8je+CGkcvGhgl2C1GlhqFFiUOIEdwXbXLiu1Fcubvvbo+g9inauqT3l0pNYXGoLPBj3jxtZz9t+wCopMkwadQ==", + "license": "BSD-2-Clause", + "dependencies": { + "sax": "1.2.1" + } + }, + "node_modules/imsc/node_modules/sax": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", + "integrity": "sha512-8I2a3LovHTOpm7NV5yOyO8IHqgVsfK4+UuySrXU8YXkSRX7k6hCV9b3HrkKCr3nMpgj+0bmocaJJWpvp1oc7ZA==", + "license": "ISC" + }, "node_modules/imurmurhash": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", @@ -10703,15 +10130,11 @@ "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", "license": "ISC" }, - "node_modules/invert-kv": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", - "integrity": "sha512-xgs2NH9AE66ucSq4cNG1nhSFghr5l6tdL15Pk+jl46bmmBapgoaY/AacXyaDznAqmGL99TiLSQgO/XazFSKYeQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } + "node_modules/inline-style-parser": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.2.4.tgz", + "integrity": "sha512-0aO8FkhNZlj/ZIbNi7Lxxr12obT7cL1moPfE4tg1LkX7LlLfC6DeX4l2ZEud1ukP9jNQyNnfzQVqwbwmAATY4Q==", + "license": "MIT" }, "node_modules/ip-address": { "version": "10.0.1", @@ -10732,12 +10155,29 @@ "node": ">= 0.10" } }, - "node_modules/is-arrayish": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", - "dev": true, - "license": "MIT" + "node_modules/is-alphabetical": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-alphabetical/-/is-alphabetical-2.0.1.tgz", + "integrity": "sha512-FWyyY60MeTNyeSRpkM2Iry0G9hpr7/9kD40mD/cGQEuilcZYS4okz8SN2Q6rLCJ8gbCt6fN+rC+6tMGS99LaxQ==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/is-alphanumerical": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-alphanumerical/-/is-alphanumerical-2.0.1.tgz", + "integrity": "sha512-hmbYhX/9MUMF5uh7tOXyK/n0ZvWpad5caBA17GsC6vyuCqaWliRG5K1qS9inmUhEMaOBIW7/whAnSwveW/LtZw==", + "license": "MIT", + "dependencies": { + "is-alphabetical": "^2.0.0", + "is-decimal": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } }, "node_modules/is-ci": { "version": "3.0.1", @@ -10752,36 +10192,14 @@ "is-ci": "bin.js" } }, - "node_modules/is-core-module": { - "version": "2.16.1", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.16.1.tgz", - "integrity": "sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==", - "dev": true, + "node_modules/is-decimal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-decimal/-/is-decimal-2.0.1.tgz", + "integrity": "sha512-AAB9hiomQs5DXWcRB1rqsxGUstbRroFOPPVAomNk/3XHR5JyEZChOyTWe2oayKnsSsr/kcGqF+z6yuH6HHpN0A==", "license": "MIT", - "dependencies": { - "hasown": "^2.0.2" - }, - "engines": { - "node": ">= 0.4" - }, "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-docker": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", - "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", - "dev": true, - "license": "MIT", - "bin": { - "is-docker": "cli.js" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, "node_modules/is-extglob": { @@ -10803,13 +10221,6 @@ "node": ">=8" } }, - "node_modules/is-function": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-function/-/is-function-1.0.2.tgz", - "integrity": "sha512-lw7DUp0aWXYg+CBCN+JKkcE0Q2RayZnSvnZBlwgxHBQhqt5pZNVy4Ri7H9GmmXkdu7LUthszM+Tor1u/2iBcpQ==", - "dev": true, - "license": "MIT" - }, "node_modules/is-glob": { "version": "4.0.3", "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", @@ -10823,6 +10234,16 @@ "node": ">=0.10.0" } }, + "node_modules/is-hexadecimal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-hexadecimal/-/is-hexadecimal-2.0.1.tgz", + "integrity": "sha512-DgZQp241c8oO6cA1SbTEWiXeoxV42vlcJxgH+B3hi1AiqqKruZR3ZGF8In3fj4+/y/7rHvlOZLZtgJ/4ttYGZg==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/is-interactive": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz", @@ -10850,24 +10271,16 @@ "node": ">=0.12.0" } }, - "node_modules/is-path-cwd": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", - "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==", - "dev": true, + "node_modules/is-plain-obj": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-4.1.0.tgz", + "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==", "license": "MIT", "engines": { - "node": ">=6" - } - }, - "node_modules/is-path-inside": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", - "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/is-promise": { @@ -10876,23 +10289,6 @@ "integrity": "sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==", "license": "MIT" }, - "node_modules/is-stream": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", - "integrity": "sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-typedarray": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", - "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", - "dev": true, - "license": "MIT" - }, "node_modules/is-unicode-supported": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", @@ -10906,31 +10302,10 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/is-utf8": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", - "integrity": "sha512-rMYPYvCzsXywIsldgLaSoPlw5PfoB/ssr7hY4pLfcodrA5M/eArza1a9VmTiNIBNMjOGr1Ow9mTyU2o69U6U9Q==", - "dev": true, - "license": "MIT" - }, - "node_modules/is-wsl": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", - "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-docker": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, "node_modules/isarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", - "dev": true, "license": "MIT" }, "node_modules/isbinaryfile": { @@ -10953,13 +10328,6 @@ "dev": true, "license": "ISC" }, - "node_modules/isstream": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", - "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==", - "dev": true, - "license": "MIT" - }, "node_modules/jackspeak": { "version": "3.4.3", "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", @@ -10994,41 +10362,31 @@ "node": ">=10" } }, - "node_modules/jimp": { - "version": "0.16.13", - "resolved": "https://registry.npmjs.org/jimp/-/jimp-0.16.13.tgz", - "integrity": "sha512-Bxz8q7V4rnCky9A0ktTNGA9SkNFVWRHodddI/DaAWZJzF7sVUlFYKQ60y9JGqrKpi48ECA/TnfMzzc5C70VByA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/runtime": "^7.7.2", - "@jimp/custom": "^0.16.13", - "@jimp/plugins": "^0.16.13", - "@jimp/types": "^0.16.13", - "regenerator-runtime": "^0.13.3" - } - }, "node_modules/jiti": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/jiti/-/jiti-2.5.1.tgz", - "integrity": "sha512-twQoecYPiVA5K/h6SxtORw/Bs3ar+mLUtoPSc7iMXzQzK8d7eJ/R09wmTwAjiamETn1cXYPGfNnu7DMoHgu12w==", + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-2.6.1.tgz", + "integrity": "sha512-ekilCSN1jwRvIbgeg/57YFh8qQDNbwDb9xT/qu2DAHbFFZUicIl4ygVaAvzveMhMVr3LnpSKTNnwt8PoOfmKhQ==", "license": "MIT", "bin": { "jiti": "lib/jiti-cli.mjs" } }, "node_modules/joi": { - "version": "17.13.3", - "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.3.tgz", - "integrity": "sha512-otDA4ldcIx+ZXsKHWmp0YizCweVRZG96J10b0FevjfuncLO1oX59THoAmHkNubYJ+9gWsYsp5k8v4ib6oDv1fA==", - "dev": true, + "version": "18.0.1", + "resolved": "https://registry.npmjs.org/joi/-/joi-18.0.1.tgz", + "integrity": "sha512-IiQpRyypSnLisQf3PwuN2eIHAsAIGZIrLZkd4zdvIar2bDyhM91ubRjy8a3eYablXsh9BeI/c7dmPYHca5qtoA==", "license": "BSD-3-Clause", "dependencies": { - "@hapi/hoek": "^9.3.0", - "@hapi/topo": "^5.1.0", - "@sideway/address": "^4.1.5", - "@sideway/formula": "^3.0.1", - "@sideway/pinpoint": "^2.0.0" + "@hapi/address": "^5.1.1", + "@hapi/formula": "^3.0.2", + "@hapi/hoek": "^11.0.7", + "@hapi/pinpoint": "^2.0.1", + "@hapi/tlds": "^1.1.1", + "@hapi/topo": "^6.0.2", + "@standard-schema/spec": "^1.0.0" + }, + "engines": { + "node": ">= 20" } }, "node_modules/jose": { @@ -11040,19 +10398,18 @@ "url": "https://github.com/sponsors/panva" } }, - "node_modules/jpeg-js": { - "version": "0.4.4", - "resolved": "https://registry.npmjs.org/jpeg-js/-/jpeg-js-0.4.4.tgz", - "integrity": "sha512-WZzeDOEtTOBK4Mdsar0IqEU5sMr3vSV2RqkAIzUEV2BHnUfKGyswWFPFwK5EeDo93K3FohSHbLAjj0s1Wzd+dg==", - "dev": true, - "license": "BSD-3-Clause" - }, "node_modules/js-base64": { "version": "3.7.8", "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-3.7.8.tgz", "integrity": "sha512-hNngCeKxIUQiEUN3GPJOkz4wF/YvdUdbNL9hsBcMQTkKzboD7T/q3OYOuuPZLUE6dBxSGpwhk5mwuDud7JVAow==", "license": "BSD-3-Clause" }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "license": "MIT" + }, "node_modules/js-yaml": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", @@ -11066,13 +10423,6 @@ "js-yaml": "bin/js-yaml.js" } }, - "node_modules/jsbn": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", - "integrity": "sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg==", - "dev": true, - "license": "MIT" - }, "node_modules/json-buffer": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", @@ -11080,13 +10430,6 @@ "dev": true, "license": "MIT" }, - "node_modules/json-schema": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.4.0.tgz", - "integrity": "sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==", - "dev": true, - "license": "(AFL-2.1 OR BSD-3-Clause)" - }, "node_modules/json-schema-traverse": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", @@ -11106,7 +10449,8 @@ "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", "dev": true, - "license": "ISC" + "license": "ISC", + "optional": true }, "node_modules/json5": { "version": "2.2.3", @@ -11153,55 +10497,34 @@ "npm": ">=6" } }, - "node_modules/jsprim": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", - "integrity": "sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw==", - "dev": true, - "license": "MIT", - "dependencies": { - "assert-plus": "1.0.0", - "extsprintf": "1.3.0", - "json-schema": "0.4.0", - "verror": "1.10.0" - }, - "engines": { - "node": ">=0.6.0" - } - }, - "node_modules/jsprim/node_modules/extsprintf": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", - "integrity": "sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==", - "dev": true, - "engines": [ - "node >=0.6.0" - ], + "node_modules/jsonwebtoken/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "license": "MIT" }, - "node_modules/jsprim/node_modules/verror": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", - "integrity": "sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw==", - "dev": true, - "engines": [ - "node >=0.6.0" - ], - "license": "MIT", - "dependencies": { - "assert-plus": "^1.0.0", - "core-util-is": "1.0.2", - "extsprintf": "^1.2.0" + "node_modules/jsonwebtoken/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" } }, - "node_modules/junk": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/junk/-/junk-3.1.0.tgz", - "integrity": "sha512-pBxcB3LFc8QVgdggvZWyeys+hnrNWg4OcZIU/1X59k5jQdLBlCsYGRQaz234SqoRLTCgMH00fY0xRJH+F9METQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" + "node_modules/jszip": { + "version": "3.10.1", + "resolved": "https://registry.npmjs.org/jszip/-/jszip-3.10.1.tgz", + "integrity": "sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g==", + "license": "(MIT OR GPL-3.0-or-later)", + "dependencies": { + "lie": "~3.3.0", + "pako": "~1.0.2", + "readable-stream": "~2.3.6", + "setimmediate": "^1.0.5" } }, "node_modules/jwa": { @@ -11225,13 +10548,6 @@ "safe-buffer": "^5.0.1" } }, - "node_modules/kew": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/kew/-/kew-0.7.0.tgz", - "integrity": "sha512-IG6nm0+QtAMdXt9KvbgbGdvY50RSrw+U4sGZg+KlrSKPJEwVE5JVoI3d7RWfSMdBQneRheeAOj3lIjX5VL/9RQ==", - "dev": true, - "license": "Apache-2.0" - }, "node_modules/keyv": { "version": "4.5.4", "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", @@ -11242,16 +10558,6 @@ "json-buffer": "3.0.1" } }, - "node_modules/klaw": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", - "integrity": "sha512-TED5xi9gGQjGpNnvRWknrwAB1eL5GciPfVFOt3Vk1OJCVDQbzuSfrF3hkUQKlsgKrG1F+0t5W0m+Fje1jIt8rw==", - "dev": true, - "license": "MIT", - "optionalDependencies": { - "graceful-fs": "^4.1.9" - } - }, "node_modules/lazy-val": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/lazy-val/-/lazy-val-1.0.5.tgz", @@ -11259,29 +10565,6 @@ "dev": true, "license": "MIT" }, - "node_modules/lcid": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", - "integrity": "sha512-YiGkH6EnGrDGqLMITnGjXtGmNtjoXw9SVUzcaos8RBi7Ps0VBylkq+vOcY9QE5poLasPCR849ucFUkl0UzUyOw==", - "dev": true, - "license": "MIT", - "dependencies": { - "invert-kv": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/leven": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/leven/-/leven-2.1.0.tgz", - "integrity": "sha512-nvVPLpIHUxCUoRLrFqTgSxXJ614d8AgQoWl7zPe/2VadE8+1dpU3LBhowRuBAcuwruWtOdD8oYC9jDNJjXDPyA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/levn": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", @@ -11296,6 +10579,15 @@ "node": ">= 0.8.0" } }, + "node_modules/lie": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/lie/-/lie-3.3.0.tgz", + "integrity": "sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ==", + "license": "MIT", + "dependencies": { + "immediate": "~3.0.5" + } + }, "node_modules/lightningcss": { "version": "1.30.1", "resolved": "https://registry.npmjs.org/lightningcss/-/lightningcss-1.30.1.tgz", @@ -11524,73 +10816,22 @@ "url": "https://opencollective.com/parcel" } }, - "node_modules/load-bmfont": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/load-bmfont/-/load-bmfont-1.4.2.tgz", - "integrity": "sha512-qElWkmjW9Oq1F9EI5Gt7aD9zcdHb9spJCW1L/dmPf7KzCCEJxq8nhHz5eCgI9aMf7vrG/wyaCqdsI+Iy9ZTlog==", - "dev": true, + "node_modules/localforage": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/localforage/-/localforage-1.10.0.tgz", + "integrity": "sha512-14/H1aX7hzBBmmh7sGPd+AOMkkIrHM3Z1PAyGgZigA1H1p5O5ANnMyWzvpAETtG68/dC4pC0ncy3+PPGzXZHPg==", + "license": "Apache-2.0", + "dependencies": { + "lie": "3.1.1" + } + }, + "node_modules/localforage/node_modules/lie": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/lie/-/lie-3.1.1.tgz", + "integrity": "sha512-RiNhHysUjhrDQntfYSfY4MU24coXXdEOgw9WGcKHNeEwffDYbF//u87M1EWaMGzuFoSbqW0C9C6lEEhDOAswfw==", "license": "MIT", "dependencies": { - "buffer-equal": "0.0.1", - "mime": "^1.3.4", - "parse-bmfont-ascii": "^1.0.3", - "parse-bmfont-binary": "^1.0.5", - "parse-bmfont-xml": "^1.1.4", - "phin": "^3.7.1", - "xhr": "^2.0.1", - "xtend": "^4.0.0" - } - }, - "node_modules/load-bmfont/node_modules/buffer-equal": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-0.0.1.tgz", - "integrity": "sha512-RgSV6InVQ9ODPdLWJ5UAqBqJBOg370Nz6ZQtRzpt6nUjc8v0St97uJ4PYC6NztqIScrAXafKM3mZPMygSe1ggA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/load-bmfont/node_modules/mime": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", - "dev": true, - "license": "MIT", - "bin": { - "mime": "cli.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/load-bmfont/node_modules/phin": { - "version": "3.7.1", - "resolved": "https://registry.npmjs.org/phin/-/phin-3.7.1.tgz", - "integrity": "sha512-GEazpTWwTZaEQ9RhL7Nyz0WwqilbqgLahDM3D0hxWwmVDI52nXEybHqiN6/elwpkJBhcuj+WbBu+QfT0uhPGfQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "centra": "^2.7.0" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/load-json-file": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", - "integrity": "sha512-3p6ZOGNbiX4CdvEd1VcE6yi78UrGNpjHO33noGwHCnT/o2fyllJDepsm8+mFFv/DvtwFHht5HIHSyOy5a+ChVQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.1.2", - "parse-json": "^2.2.0", - "pify": "^2.0.0", - "strip-bom": "^3.0.0" - }, - "engines": { - "node": ">=4" + "immediate": "~3.0.5" } }, "node_modules/locate-path": { @@ -11613,15 +10854,6 @@ "version": "4.17.21", "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.get": { - "version": "4.4.2", - "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", - "integrity": "sha512-z+Uw/vLuy6gQe8cfaFWD7p0wVv8fJl3mbzXh33RS+0oW2wvUqiRXiQ69gLWSLpgB5/6sU+r6BlQR0MBILadqTQ==", - "deprecated": "This package is deprecated. Use the optional chaining (?.) operator instead.", - "dev": true, "license": "MIT" }, "node_modules/lodash.includes": { @@ -11690,6 +10922,28 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/longest-streak": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/longest-streak/-/longest-streak-3.1.0.tgz", + "integrity": "sha512-9Ri+o0JYgehTaVBBDoMqIl8GXtbWg711O3srftcHhZ0dqnETqLaoIK0x17fUw9rFSlK/0NlsKe0Ahhyl5pXE2g==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "license": "MIT", + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, "node_modules/lowercase-keys": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", @@ -11700,6 +10954,20 @@ "node": ">=8" } }, + "node_modules/lowlight": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/lowlight/-/lowlight-1.20.0.tgz", + "integrity": "sha512-8Ktj+prEb1RoCPkEOrPMYUN/nCggB7qAWe3a7OpMjWQkh3l2RD5wKRQ+o8Q8YuI9RG/xs95waaI/E6ym/7NsTw==", + "license": "MIT", + "dependencies": { + "fault": "^1.0.0", + "highlight.js": "~10.7.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/lru-cache": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", @@ -11713,13 +10981,6 @@ "node": ">=10" } }, - "node_modules/lru-cache/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/lucide-react": { "version": "0.525.0", "resolved": "https://registry.npmjs.org/lucide-react/-/lucide-react-0.525.0.tgz", @@ -11738,12 +10999,23 @@ "@jridgewell/sourcemap-codec": "^1.5.5" } }, - "node_modules/make-error": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", - "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", - "dev": true, - "license": "ISC" + "node_modules/make-cancellable-promise": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/make-cancellable-promise/-/make-cancellable-promise-2.0.0.tgz", + "integrity": "sha512-3SEQqTpV9oqVsIWqAcmDuaNeo7yBO3tqPtqGRcKkEo0lrzD3wqbKG9mkxO65KoOgXqj+zH2phJ2LiAsdzlogSw==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/make-cancellable-promise?sponsor=1" + } + }, + "node_modules/make-event-props": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/make-event-props/-/make-event-props-2.0.0.tgz", + "integrity": "sha512-G/hncXrl4Qt7mauJEXSg3AcdYzmpkIITTNl5I+rH9sog5Yw0kK6vseJjCaPfOXqOqQuPUP89Rkhfz5kPS8ijtw==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/make-event-props?sponsor=1" + } }, "node_modules/make-fetch-happen": { "version": "10.2.1", @@ -11786,6 +11058,24 @@ "node": ">= 6.0.0" } }, + "node_modules/make-fetch-happen/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/make-fetch-happen/node_modules/http-proxy-agent": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz", @@ -11825,18 +11115,12 @@ "node": ">=12" } }, - "node_modules/make-fetch-happen/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "node_modules/make-fetch-happen/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } + "license": "MIT" }, "node_modules/make-fetch-happen/node_modules/negotiator": { "version": "0.6.4", @@ -11848,12 +11132,15 @@ "node": ">= 0.6" } }, - "node_modules/make-fetch-happen/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" + "node_modules/markdown-table": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-3.0.4.tgz", + "integrity": "sha512-wiYz4+JrLyb/DqW2hkFJxP7Vd7JuTDm77fvbM8VfEQdmSMqcImWeeRbHwZjBjIFki/VaMK2BhFi7oUUZeM5bqw==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } }, "node_modules/matcher": { "version": "3.0.0", @@ -11878,13 +11165,310 @@ "node": ">= 0.4" } }, - "node_modules/media-typer": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-1.1.0.tgz", - "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", + "node_modules/mdast-util-find-and-replace": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/mdast-util-find-and-replace/-/mdast-util-find-and-replace-3.0.2.tgz", + "integrity": "sha512-Tmd1Vg/m3Xz43afeNxDIhWRtFZgM2VLyaf4vSTYwudTyeuTneoL3qtWMA5jeLyz/O1vDJmmV4QuScFCA2tBPwg==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "escape-string-regexp": "^5.0.0", + "unist-util-is": "^6.0.0", + "unist-util-visit-parents": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", + "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==", "license": "MIT", "engines": { - "node": ">= 0.8" + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/mdast-util-from-markdown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.2.tgz", + "integrity": "sha512-uZhTV/8NBuw0WHkPTrCqDOl0zVe1BIng5ZtHoDk49ME1qqcjYmmLmOf0gELgcRMxN4w2iuIeVso5/6QymSrgmA==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", + "decode-named-character-reference": "^1.0.0", + "devlop": "^1.0.0", + "mdast-util-to-string": "^4.0.0", + "micromark": "^4.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-decode-string": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0", + "unist-util-stringify-position": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm/-/mdast-util-gfm-3.1.0.tgz", + "integrity": "sha512-0ulfdQOM3ysHhCJ1p06l0b0VKlhU0wuQs3thxZQagjcjPrlFRqY215uZGHHJan9GEAXd9MbfPjFJz+qMkVR6zQ==", + "license": "MIT", + "dependencies": { + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-gfm-autolink-literal": "^2.0.0", + "mdast-util-gfm-footnote": "^2.0.0", + "mdast-util-gfm-strikethrough": "^2.0.0", + "mdast-util-gfm-table": "^2.0.0", + "mdast-util-gfm-task-list-item": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-autolink-literal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-2.0.1.tgz", + "integrity": "sha512-5HVP2MKaP6L+G6YaxPNjuL0BPrq9orG3TsrZ9YXbA3vDw/ACI4MEsnoDpn6ZNm7GnZgtAcONJyPhOP8tNJQavQ==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "ccount": "^2.0.0", + "devlop": "^1.0.0", + "mdast-util-find-and-replace": "^3.0.0", + "micromark-util-character": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-footnote": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-2.1.0.tgz", + "integrity": "sha512-sqpDWlsHn7Ac9GNZQMeUzPQSMzR6Wv0WKRNvQRg0KqHh02fpTz69Qc1QSseNX29bhz1ROIyNyxExfawVKTm1GQ==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "devlop": "^1.1.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-strikethrough": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-2.0.0.tgz", + "integrity": "sha512-mKKb915TF+OC5ptj5bJ7WFRPdYtuHv0yTRxK2tJvi+BDqbkiG7h7u/9SI89nRAYcmap2xHQL9D+QG/6wSrTtXg==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-table": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-table/-/mdast-util-gfm-table-2.0.0.tgz", + "integrity": "sha512-78UEvebzz/rJIxLvE7ZtDd/vIQ0RHv+3Mh5DR96p7cS7HsBhYIICDBCu8csTNWNO6tBWfqXPWekRuj2FNOGOZg==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "markdown-table": "^3.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-task-list-item": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-2.0.0.tgz", + "integrity": "sha512-IrtvNvjxC1o06taBAVJznEnkiHxLFTzgonUdy8hzFVeDun0uTjxxrRGVaNFqkU1wJR3RBPEfsxmU6jDWPofrTQ==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-mdx-expression": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-mdx-expression/-/mdast-util-mdx-expression-2.0.1.tgz", + "integrity": "sha512-J6f+9hUp+ldTZqKRSg7Vw5V6MqjATc+3E4gf3CFNcuZNWD8XdyI6zQ8GqH7f8169MM6P7hMBRDVGnn7oHB9kXQ==", + "license": "MIT", + "dependencies": { + "@types/estree-jsx": "^1.0.0", + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-mdx-jsx": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/mdast-util-mdx-jsx/-/mdast-util-mdx-jsx-3.2.0.tgz", + "integrity": "sha512-lj/z8v0r6ZtsN/cGNNtemmmfoLAFZnjMbNyLzBafjzikOM+glrjNHPlf6lQDOTccj9n5b0PPihEBbhneMyGs1Q==", + "license": "MIT", + "dependencies": { + "@types/estree-jsx": "^1.0.0", + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", + "ccount": "^2.0.0", + "devlop": "^1.1.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0", + "parse-entities": "^4.0.0", + "stringify-entities": "^4.0.0", + "unist-util-stringify-position": "^4.0.0", + "vfile-message": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-mdxjs-esm": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-mdxjs-esm/-/mdast-util-mdxjs-esm-2.0.1.tgz", + "integrity": "sha512-EcmOpxsZ96CvlP03NghtH1EsLtr0n9Tm4lPUJUBccV9RwUOneqSycg19n5HGzCf+10LozMRSObtVr3ee1WoHtg==", + "license": "MIT", + "dependencies": { + "@types/estree-jsx": "^1.0.0", + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-phrasing": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-phrasing/-/mdast-util-phrasing-4.1.0.tgz", + "integrity": "sha512-TqICwyvJJpBwvGAMZjj4J2n0X8QWp21b9l0o7eXyVJ25YNWYbJDVIyD1bZXE6WtV6RmKJVYmQAKWa0zWOABz2w==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "unist-util-is": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-hast": { + "version": "13.2.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-13.2.0.tgz", + "integrity": "sha512-QGYKEuUsYT9ykKBCMOEDLsU5JRObWQusAolFMeko/tYPufNkRffBAQjIE+99jbA87xv6FgmjLtwjh9wBWajwAA==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "@ungap/structured-clone": "^1.0.0", + "devlop": "^1.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "trim-lines": "^3.0.0", + "unist-util-position": "^5.0.0", + "unist-util-visit": "^5.0.0", + "vfile": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-markdown": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/mdast-util-to-markdown/-/mdast-util-to-markdown-2.1.2.tgz", + "integrity": "sha512-xj68wMTvGXVOKonmog6LwyJKrYXZPvlwabaryTjLh9LuvovB/KAH+kvi8Gjj+7rJjsFi23nkUxRQv1KqSroMqA==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", + "longest-streak": "^3.0.0", + "mdast-util-phrasing": "^4.0.0", + "mdast-util-to-string": "^4.0.0", + "micromark-util-classify-character": "^2.0.0", + "micromark-util-decode-string": "^2.0.0", + "unist-util-visit": "^5.0.0", + "zwitch": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-string": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-4.0.0.tgz", + "integrity": "sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/media-chrome": { + "version": "4.14.0", + "resolved": "https://registry.npmjs.org/media-chrome/-/media-chrome-4.14.0.tgz", + "integrity": "sha512-IEdFb4blyF15vLvQzLIn6USJBv7Kf2ne+TfLQKBYI5Z0f9VEBVZz5MKy4Uhi0iA9lStl2S9ENIujJRuJIa5OiA==", + "license": "MIT", + "dependencies": { + "ce-la-react": "^0.3.0" + } + }, + "node_modules/media-tracks": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/media-tracks/-/media-tracks-0.3.3.tgz", + "integrity": "sha512-9P2FuUHnZZ3iji+2RQk7Zkh5AmZTnOG5fODACnjhCVveX1McY3jmCRHofIEI+yTBqplz7LXy48c7fQ3Uigp88w==", + "license": "MIT" + }, + "node_modules/media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", + "license": "MIT", + "engines": { + "node": ">= 0.6" } }, "node_modules/merge-descriptors": { @@ -11899,6 +11483,23 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/merge-refs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-refs/-/merge-refs-2.0.0.tgz", + "integrity": "sha512-3+B21mYK2IqUWnd2EivABLT7ueDhb0b8/dGK8LoFQPrU61YITeCMn14F7y7qZafWNZhUEKb24cJdiT5Wxs3prg==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/merge-refs?sponsor=1" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, "node_modules/merge2": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", @@ -11909,6 +11510,592 @@ "node": ">= 8" } }, + "node_modules/micromark": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/micromark/-/micromark-4.0.2.tgz", + "integrity": "sha512-zpe98Q6kvavpCr1NPVSCMebCKfD7CA2NqZ+rykeNhONIJBpc1tFKt9hucLGwha3jNTNI8lHpctWJWoimVF4PfA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "@types/debug": "^4.0.0", + "debug": "^4.0.0", + "decode-named-character-reference": "^1.0.0", + "devlop": "^1.0.0", + "micromark-core-commonmark": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-combine-extensions": "^2.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-encode": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-subtokenize": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-core-commonmark": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-2.0.3.tgz", + "integrity": "sha512-RDBrHEMSxVFLg6xvnXmb1Ayr2WzLAWjeSATAoxwKYJV94TeNavgoIdA0a9ytzDSVzBy2YKFK+emCPOEibLeCrg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "decode-named-character-reference": "^1.0.0", + "devlop": "^1.0.0", + "micromark-factory-destination": "^2.0.0", + "micromark-factory-label": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-factory-title": "^2.0.0", + "micromark-factory-whitespace": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-classify-character": "^2.0.0", + "micromark-util-html-tag-name": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-subtokenize": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-extension-gfm": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm/-/micromark-extension-gfm-3.0.0.tgz", + "integrity": "sha512-vsKArQsicm7t0z2GugkCKtZehqUm31oeGBV/KVSorWSy8ZlNAv7ytjFhvaryUiCUJYqs+NoE6AFhpQvBTM6Q4w==", + "license": "MIT", + "dependencies": { + "micromark-extension-gfm-autolink-literal": "^2.0.0", + "micromark-extension-gfm-footnote": "^2.0.0", + "micromark-extension-gfm-strikethrough": "^2.0.0", + "micromark-extension-gfm-table": "^2.0.0", + "micromark-extension-gfm-tagfilter": "^2.0.0", + "micromark-extension-gfm-task-list-item": "^2.0.0", + "micromark-util-combine-extensions": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-autolink-literal": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-2.1.0.tgz", + "integrity": "sha512-oOg7knzhicgQ3t4QCjCWgTmfNhvQbDDnJeVu9v81r7NltNCVmhPy1fJRX27pISafdjL+SVc4d3l48Gb6pbRypw==", + "license": "MIT", + "dependencies": { + "micromark-util-character": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-footnote": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-2.1.0.tgz", + "integrity": "sha512-/yPhxI1ntnDNsiHtzLKYnE3vf9JZ6cAisqVDauhp4CEHxlb4uoOTxOCJ+9s51bIB8U1N1FJ1RXOKTIlD5B/gqw==", + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-core-commonmark": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-strikethrough": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-2.1.0.tgz", + "integrity": "sha512-ADVjpOOkjz1hhkZLlBiYA9cR2Anf8F4HqZUO6e5eDcPQd0Txw5fxLzzxnEkSkfnD0wziSGiv7sYhk/ktvbf1uw==", + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-classify-character": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-table": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.1.1.tgz", + "integrity": "sha512-t2OU/dXXioARrC6yWfJ4hqB7rct14e8f7m0cbI5hUmDyyIlwv5vEtooptH8INkbLzOatzKuVbQmAYcbWoyz6Dg==", + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-tagfilter": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-2.0.0.tgz", + "integrity": "sha512-xHlTOmuCSotIA8TW1mDIM6X2O1SiX5P9IuDtqGonFhEK0qgRI4yeC6vMxEV2dgyr2TiD+2PQ10o+cOhdVAcwfg==", + "license": "MIT", + "dependencies": { + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-task-list-item": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-2.1.0.tgz", + "integrity": "sha512-qIBZhqxqI6fjLDYFTBIa4eivDMnP+OZqsNwmQ3xNLE4Cxwc+zfQEfbs6tzAo2Hjq+bh6q5F+Z8/cksrLFYWQQw==", + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-factory-destination": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-factory-destination/-/micromark-factory-destination-2.0.1.tgz", + "integrity": "sha512-Xe6rDdJlkmbFRExpTOmRj9N3MaWmbAgdpSrBQvCFqhezUn4AHqJHbaEnfbVYYiexVSs//tqOdY/DxhjdCiJnIA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-factory-label": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-factory-label/-/micromark-factory-label-2.0.1.tgz", + "integrity": "sha512-VFMekyQExqIW7xIChcXn4ok29YE3rnuyveW3wZQWWqF4Nv9Wk5rgJ99KzPvHjkmPXF93FXIbBp6YdW3t71/7Vg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-factory-space": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-factory-space/-/micromark-factory-space-2.0.1.tgz", + "integrity": "sha512-zRkxjtBxxLd2Sc0d+fbnEunsTj46SWXgXciZmHq0kDYGnck/ZSGj9/wULTV95uoeYiK5hRXP2mJ98Uo4cq/LQg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-character": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-factory-title": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-factory-title/-/micromark-factory-title-2.0.1.tgz", + "integrity": "sha512-5bZ+3CjhAd9eChYTHsjy6TGxpOFSKgKKJPJxr293jTbfry2KDoWkhBb6TcPVB4NmzaPhMs1Frm9AZH7OD4Cjzw==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-factory-whitespace": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-factory-whitespace/-/micromark-factory-whitespace-2.0.1.tgz", + "integrity": "sha512-Ob0nuZ3PKt/n0hORHyvoD9uZhr+Za8sFoP+OnMcnWK5lngSzALgQYKMr9RJVOWLqQYuyn6ulqGWSXdwf6F80lQ==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-character": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-2.1.1.tgz", + "integrity": "sha512-wv8tdUTJ3thSFFFJKtpYKOYiGP2+v96Hvk4Tu8KpCAsTMs6yi+nVmGh1syvSCsaxz45J6Jbw+9DD6g97+NV67Q==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-chunked": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-chunked/-/micromark-util-chunked-2.0.1.tgz", + "integrity": "sha512-QUNFEOPELfmvv+4xiNg2sRYeS/P84pTW0TCgP5zc9FpXetHY0ab7SxKyAQCNCc1eK0459uoLI1y5oO5Vc1dbhA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-symbol": "^2.0.0" + } + }, + "node_modules/micromark-util-classify-character": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-classify-character/-/micromark-util-classify-character-2.0.1.tgz", + "integrity": "sha512-K0kHzM6afW/MbeWYWLjoHQv1sgg2Q9EccHEDzSkxiP/EaagNzCm7T/WMKZ3rjMbvIpvBiZgwR3dKMygtA4mG1Q==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-combine-extensions": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-combine-extensions/-/micromark-util-combine-extensions-2.0.1.tgz", + "integrity": "sha512-OnAnH8Ujmy59JcyZw8JSbK9cGpdVY44NKgSM7E9Eh7DiLS2E9RNQf0dONaGDzEG9yjEl5hcqeIsj4hfRkLH/Bg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-chunked": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-decode-numeric-character-reference": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-2.0.2.tgz", + "integrity": "sha512-ccUbYk6CwVdkmCQMyr64dXz42EfHGkPQlBj5p7YVGzq8I7CtjXZJrubAYezf7Rp+bjPseiROqe7G6foFd+lEuw==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-symbol": "^2.0.0" + } + }, + "node_modules/micromark-util-decode-string": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-decode-string/-/micromark-util-decode-string-2.0.1.tgz", + "integrity": "sha512-nDV/77Fj6eH1ynwscYTOsbK7rR//Uj0bZXBwJZRfaLEJ1iGBR6kIfNmlNqaqJf649EP0F3NWNdeJi03elllNUQ==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "decode-named-character-reference": "^1.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-symbol": "^2.0.0" + } + }, + "node_modules/micromark-util-encode": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-2.0.1.tgz", + "integrity": "sha512-c3cVx2y4KqUnwopcO9b/SCdo2O67LwJJ/UyqGfbigahfegL9myoEFoDYZgkT7f36T0bLrM9hZTAaAyH+PCAXjw==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT" + }, + "node_modules/micromark-util-html-tag-name": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-html-tag-name/-/micromark-util-html-tag-name-2.0.1.tgz", + "integrity": "sha512-2cNEiYDhCWKI+Gs9T0Tiysk136SnR13hhO8yW6BGNyhOC4qYFnwF1nKfD3HFAIXA5c45RrIG1ub11GiXeYd1xA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT" + }, + "node_modules/micromark-util-normalize-identifier": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-2.0.1.tgz", + "integrity": "sha512-sxPqmo70LyARJs0w2UclACPUUEqltCkJ6PhKdMIDuJ3gSf/Q+/GIe3WKl0Ijb/GyH9lOpUkRAO2wp0GVkLvS9Q==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-symbol": "^2.0.0" + } + }, + "node_modules/micromark-util-resolve-all": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-resolve-all/-/micromark-util-resolve-all-2.0.1.tgz", + "integrity": "sha512-VdQyxFWFT2/FGJgwQnJYbe1jjQoNTS4RjglmSjTUlpUMa95Htx9NHeYW4rGDJzbjvCsl9eLjMQwGeElsqmzcHg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-sanitize-uri": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-2.0.1.tgz", + "integrity": "sha512-9N9IomZ/YuGGZZmQec1MbgxtlgougxTodVwDzzEouPKo3qFWvymFHWcnDi2vzV1ff6kas9ucW+o3yzJK9YB1AQ==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "micromark-util-character": "^2.0.0", + "micromark-util-encode": "^2.0.0", + "micromark-util-symbol": "^2.0.0" + } + }, + "node_modules/micromark-util-subtokenize": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-2.1.0.tgz", + "integrity": "sha512-XQLu552iSctvnEcgXw6+Sx75GflAPNED1qx7eBJ+wydBb2KCbRZe+NwvIEEMM83uml1+2WSXpBAcp9IUCgCYWA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT", + "dependencies": { + "devlop": "^1.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" + } + }, + "node_modules/micromark-util-symbol": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-2.0.1.tgz", + "integrity": "sha512-vs5t8Apaud9N28kgCrRUdEed4UJ+wWNvicHLPxCa9ENlYuAY31M0ETy5y1vA33YoNPDFTghEbnh6efaE8h4x0Q==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT" + }, + "node_modules/micromark-util-types": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-2.0.2.tgz", + "integrity": "sha512-Yw0ECSpJoViF1qTU4DC6NwtC4aWGt1EkzaQB8KPPyCRR8z9TWeV0HbEFGTO+ZY1wB22zmxnJqhPyTpOVCpeHTA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "license": "MIT" + }, + "node_modules/micromark/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/micromark/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, "node_modules/micromatch": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", @@ -11968,37 +12155,29 @@ } }, "node_modules/mimic-response": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", - "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", + "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", + "dev": true, "license": "MIT", "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/min-document": { - "version": "2.19.0", - "resolved": "https://registry.npmjs.org/min-document/-/min-document-2.19.0.tgz", - "integrity": "sha512-9Wy1B3m3f66bPPmU5hdA4DR4PB2OfDU/+GS3yAB7IQozE3tqXaVv2zOjgla7MEGSRv95+ILmOuvhLkOK6wJtCQ==", - "dev": true, - "dependencies": { - "dom-walk": "^0.1.0" + "node": ">=4" } }, "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.3.tgz", + "integrity": "sha512-IPZ167aShDZZUMdRk66cyQAW3qr0WzbHkPdMYa8bzZhlHhO3jALbKdxcaak7W9FfT2rZNpQuUu4Od7ILEpXSaw==", "dev": true, "license": "ISC", "dependencies": { - "brace-expansion": "^1.1.7" + "@isaacs/brace-expansion": "^5.0.0" }, "engines": { - "node": "*" + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" } }, "node_modules/minimist": { @@ -12011,12 +12190,16 @@ } }, "node_modules/minipass": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", - "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, "license": "ISC", + "dependencies": { + "yallist": "^4.0.0" + }, "engines": { - "node": ">=16 || 14 >=14.17" + "node": ">=8" } }, "node_modules/minipass-collect": { @@ -12032,26 +12215,6 @@ "node": ">= 8" } }, - "node_modules/minipass-collect/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/minipass-collect/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/minipass-fetch": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-2.1.2.tgz", @@ -12070,40 +12233,6 @@ "encoding": "^0.1.13" } }, - "node_modules/minipass-fetch/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/minipass-fetch/node_modules/minizlib": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", - "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", - "dev": true, - "license": "MIT", - "dependencies": { - "minipass": "^3.0.0", - "yallist": "^4.0.0" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/minipass-fetch/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/minipass-flush": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", @@ -12117,26 +12246,6 @@ "node": ">= 8" } }, - "node_modules/minipass-flush/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/minipass-flush/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/minipass-pipeline": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz", @@ -12150,26 +12259,6 @@ "node": ">=8" } }, - "node_modules/minipass-pipeline/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/minipass-pipeline/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/minipass-sized": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz", @@ -12183,48 +12272,31 @@ "node": ">=8" } }, - "node_modules/minipass-sized/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "node_modules/minizlib": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", + "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", "dev": true, - "license": "ISC", + "license": "MIT", "dependencies": { + "minipass": "^3.0.0", "yallist": "^4.0.0" }, "engines": { - "node": ">=8" - } - }, - "node_modules/minipass-sized/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, - "node_modules/minizlib": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-3.0.2.tgz", - "integrity": "sha512-oG62iEk+CYt5Xj2YqI5Xi9xWUeZhDI8jjQmC5oThVH5JGCTgIjr7ciJDzC7MBzYd//WvR1OTmP5Q38Q8ShQtVA==", - "license": "MIT", - "dependencies": { - "minipass": "^7.1.2" - }, - "engines": { - "node": ">= 18" + "node": ">= 8" } }, "node_modules/mkdirp": { - "version": "0.5.6", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", - "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", + "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", + "dev": true, "license": "MIT", - "dependencies": { - "minimist": "^1.2.6" - }, "bin": { "mkdirp": "bin/cmd.js" + }, + "engines": { + "node": ">=10" } }, "node_modules/mkdirp-classic": { @@ -12233,20 +12305,20 @@ "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", "license": "MIT" }, - "node_modules/mri": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/mri/-/mri-1.1.4.tgz", - "integrity": "sha512-6y7IjGPm8AzlvoUrwAaw1tLnUBudaS3752vcd8JtrpGGQn+rXIe63LFVHm/YMwtqAuh+LJPCFdlLYPWM1nYn6w==", - "dev": true, + "node_modules/monaco-editor": { + "version": "0.53.0", + "resolved": "https://registry.npmjs.org/monaco-editor/-/monaco-editor-0.53.0.tgz", + "integrity": "sha512-0WNThgC6CMWNXXBxTbaYYcunj08iB5rnx4/G56UOPeL9UVIUGGHA1GR0EWIh9Ebabj7NpCRawQ5b0hfN1jQmYQ==", "license": "MIT", - "engines": { - "node": ">=4" + "peer": true, + "dependencies": { + "@types/trusted-types": "^1.0.6" } }, "node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", "license": "MIT" }, "node_modules/multer": { @@ -12267,48 +12339,23 @@ "node": ">= 10.16.0" } }, - "node_modules/multer/node_modules/media-typer": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", - "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", - "license": "MIT", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/multer/node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "license": "MIT", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/multer/node_modules/mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "node_modules/multer/node_modules/mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", "license": "MIT", "dependencies": { - "mime-db": "1.52.0" + "minimist": "^1.2.6" }, - "engines": { - "node": ">= 0.6" + "bin": { + "mkdirp": "bin/cmd.js" } }, - "node_modules/multer/node_modules/type-is": { - "version": "1.6.18", - "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", - "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", - "license": "MIT", - "dependencies": { - "media-typer": "0.3.0", - "mime-types": "~2.1.24" - }, - "engines": { - "node": ">= 0.6" - } + "node_modules/mux-embed": { + "version": "5.9.0", + "resolved": "https://registry.npmjs.org/mux-embed/-/mux-embed-5.9.0.tgz", + "integrity": "sha512-wmunL3uoPhma/tWy8PrDPZkvJpXvSFBwbD3KkC4PG8Ztjfb1X3hRJwGUAQyRz7z99b/ovLm2UTTitrkvStjH4w==", + "license": "MIT" }, "node_modules/nan": { "version": "2.23.0", @@ -12318,9 +12365,9 @@ "optional": true }, "node_modules/nanoid": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-5.1.5.tgz", - "integrity": "sha512-Ir/+ZpE9fDsNH0hQ3C68uyThDXzYcim2EqcZ8zn8Chtt1iylPT9xXJB0kPCnqzgcEGikO9RxSrh63MsmVCU7Fw==", + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-5.1.6.tgz", + "integrity": "sha512-c7+7RQ+dMB5dPwwCp4ee1/iV/q2P6aK1mTZcfr1BTuVlyW9hJYiMPybJCcnBlQtuSmTIWNeazm/zqNoZSSElBg==", "funding": [ { "type": "github", @@ -12341,6 +12388,12 @@ "integrity": "sha512-GEbrYkbfF7MoNaoh2iGG84Mnf/WZfB0GdGEsM8wz7Expx/LlWf5U8t9nvJKXSp3qr5IsEbK04cBGhol/KwOsWA==", "license": "MIT" }, + "node_modules/native-promise-only": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/native-promise-only/-/native-promise-only-0.8.1.tgz", + "integrity": "sha512-zkVhZUA3y8mbz652WrL5x0fB0ehrBkulWT3TomAQ9iDtyXZvzKeEA6GPxAItBYeNYl5yngKRX612qHOhvMkDeg==", + "license": "MIT" + }, "node_modules/natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -12379,6 +12432,18 @@ "node": ">=10" } }, + "node_modules/node-abi/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/node-addon-api": { "version": "1.7.2", "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-1.7.2.tgz", @@ -12397,6 +12462,19 @@ "semver": "^7.3.5" } }, + "node_modules/node-api-version/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/node-domexception": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz", @@ -12435,13 +12513,6 @@ "url": "https://opencollective.com/node-fetch" } }, - "node_modules/node-releases": { - "version": "2.0.20", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.20.tgz", - "integrity": "sha512-7gK6zSXEH6neM212JgfYFXe+GmZQM+fia5SsusuBIUgnPheLFBmIPhtFoAQRj8/7wASYQnbDlHPVwY0BefoFgA==", - "dev": true, - "license": "MIT" - }, "node_modules/nopt": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz", @@ -12458,46 +12529,6 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, - "node_modules/normalize-package-data": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", - "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", - "dev": true, - "license": "BSD-2-Clause", - "dependencies": { - "hosted-git-info": "^2.1.4", - "resolve": "^1.10.0", - "semver": "2 || 3 || 4 || 5", - "validate-npm-package-license": "^3.0.1" - } - }, - "node_modules/normalize-package-data/node_modules/hosted-git-info": { - "version": "2.8.9", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", - "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", - "dev": true, - "license": "ISC" - }, - "node_modules/normalize-package-data/node_modules/semver": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", - "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/normalize-range": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", - "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/normalize-url": { "version": "6.1.0", "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-6.1.0.tgz", @@ -12511,26 +12542,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/number-is-nan": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", - "integrity": "sha512-4jbtZXNAsfZbAHiiqjLPBiCl16dES1zI4Hpzzxw61Tk+loF+sBDBKx1ICKKKwIqQ7M0mFn1TmkN7euSncWgHiQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/oauth-sign": { - "version": "0.9.0", - "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", - "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", - "dev": true, - "license": "Apache-2.0", - "engines": { - "node": "*" - } - }, "node_modules/object-assign": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", @@ -12563,13 +12574,6 @@ "node": ">= 0.4" } }, - "node_modules/omggif": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/omggif/-/omggif-1.0.10.tgz", - "integrity": "sha512-LMJTtvgc/nugXj0Vcrrs68Mn2D1r0zf630VNtqtpI1FEO7e+O9FP4gqs9AcnBaSEeoHIPm28u6qgPR0oyEpGSw==", - "dev": true, - "license": "MIT" - }, "node_modules/on-finished": { "version": "2.4.1", "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", @@ -12649,19 +12653,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/os-locale": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", - "integrity": "sha512-PRT7ZORmwu2MEFt4/fv3Q+mEfN4zetKxufQrkShY2oGvUms9r8otu5HfdyIFHkYXjO7laNsoVGmM2MANfuTA8g==", - "dev": true, - "license": "MIT", - "dependencies": { - "lcid": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/p-cancelable": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-2.1.1.tgz", @@ -12740,7 +12731,6 @@ "version": "1.0.11", "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", - "dev": true, "license": "(MIT AND Zlib)" }, "node_modules/parent-module": { @@ -12756,64 +12746,31 @@ "node": ">=6" } }, - "node_modules/parse-author": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/parse-author/-/parse-author-2.0.0.tgz", - "integrity": "sha512-yx5DfvkN8JsHL2xk2Os9oTia467qnvRgey4ahSm2X8epehBLx/gWLcy5KI+Y36ful5DzGbCS6RazqZGgy1gHNw==", - "dev": true, + "node_modules/parse-entities": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/parse-entities/-/parse-entities-4.0.2.tgz", + "integrity": "sha512-GG2AQYWoLgL877gQIKeRPGO1xF9+eG1ujIb5soS5gPvLQ1y2o8FL90w2QWNdf9I361Mpp7726c+lj3U0qK1uGw==", "license": "MIT", "dependencies": { - "author-regex": "^1.0.0" + "@types/unist": "^2.0.0", + "character-entities-legacy": "^3.0.0", + "character-reference-invalid": "^2.0.0", + "decode-named-character-reference": "^1.0.0", + "is-alphanumerical": "^2.0.0", + "is-decimal": "^2.0.0", + "is-hexadecimal": "^2.0.0" }, - "engines": { - "node": ">=0.10.0" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/parse-bmfont-ascii": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/parse-bmfont-ascii/-/parse-bmfont-ascii-1.0.6.tgz", - "integrity": "sha512-U4RrVsUFCleIOBsIGYOMKjn9PavsGOXxbvYGtMOEfnId0SVNsgehXh1DxUdVPLoxd5mvcEtvmKs2Mmf0Mpa1ZA==", - "dev": true, + "node_modules/parse-entities/node_modules/@types/unist": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.11.tgz", + "integrity": "sha512-CmBKiL6NNo/OqgmMn95Fk9Whlp2mtvIv+KNpQKN2F4SjvrEesubTRWGYSg+BnWZOnlCaSTU1sMpsBOzgbYhnsA==", "license": "MIT" }, - "node_modules/parse-bmfont-binary": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/parse-bmfont-binary/-/parse-bmfont-binary-1.0.6.tgz", - "integrity": "sha512-GxmsRea0wdGdYthjuUeWTMWPqm2+FAd4GI8vCvhgJsFnoGhTrLhXDDupwTo7rXVAgaLIGoVHDZS9p/5XbSqeWA==", - "dev": true, - "license": "MIT" - }, - "node_modules/parse-bmfont-xml": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/parse-bmfont-xml/-/parse-bmfont-xml-1.1.6.tgz", - "integrity": "sha512-0cEliVMZEhrFDwMh4SxIyVJpqYoOWDJ9P895tFuS+XuNzI5UBmBk5U5O4KuJdTnZpSBI4LFA2+ZiJaiwfSwlMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "xml-parse-from-string": "^1.0.0", - "xml2js": "^0.5.0" - } - }, - "node_modules/parse-headers": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/parse-headers/-/parse-headers-2.0.6.tgz", - "integrity": "sha512-Tz11t3uKztEW5FEVZnj1ox8GKblWn+PvHY9TmJV5Mll2uHEwRdR/5Li1OlXoECjLYkApdhWy44ocONwXLiKO5A==", - "dev": true, - "license": "MIT" - }, - "node_modules/parse-json": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", - "integrity": "sha512-QR/GGaKCkhwk1ePQNYDRKYZ3mwU9ypsKhB0XyFnLQdomyEqk3e8wpW3V5Jp88zbxK4n5ST1nqo+g9juTpownhQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "error-ex": "^1.2.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/parseurl": { "version": "1.3.3", "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", @@ -12823,6 +12780,12 @@ "node": ">= 0.8" } }, + "node_modules/path-browserify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-1.0.1.tgz", + "integrity": "sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==", + "license": "MIT" + }, "node_modules/path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -12852,13 +12815,6 @@ "node": ">=8" } }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true, - "license": "MIT" - }, "node_modules/path-scurry": { "version": "1.11.1", "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", @@ -12883,6 +12839,16 @@ "dev": true, "license": "ISC" }, + "node_modules/path-scurry/node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, "node_modules/path-to-regexp": { "version": "8.3.0", "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-8.3.0.tgz", @@ -12893,17 +12859,16 @@ "url": "https://opencollective.com/express" } }, - "node_modules/path-type": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", - "integrity": "sha512-dUnb5dXUf+kzhC/W/F4e5/SkluXIFf5VUHolW1Eg1irn1hGWjPGdsRcvYJ1nD6lhk8Ir7VM0bHJKsYTx8Jx9OQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "pify": "^2.0.0" - }, + "node_modules/pdfjs-dist": { + "version": "5.3.93", + "resolved": "https://registry.npmjs.org/pdfjs-dist/-/pdfjs-dist-5.3.93.tgz", + "integrity": "sha512-w3fQKVL1oGn8FRyx5JUG5tnbblggDqyx2XzA5brsJ5hSuS+I0NdnJANhmeWKLjotdbPQucLBug5t0MeWr0AAdg==", + "license": "Apache-2.0", "engines": { - "node": ">=4" + "node": ">=20.16.0 || >=22.3.0" + }, + "optionalDependencies": { + "@napi-rs/canvas": "^0.1.71" } }, "node_modules/pe-library": { @@ -12921,20 +12886,6 @@ "url": "https://github.com/sponsors/jet2jet" } }, - "node_modules/peek-readable": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/peek-readable/-/peek-readable-4.1.0.tgz", - "integrity": "sha512-ZI3LnwUv5nOGbQzD9c2iDG6toheuXSZP5esSHBjopsXH4dg19soufvpUGA3uohi5anFtGb2lhAVdHzH6R/Evvg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/Borewit" - } - }, "node_modules/pend": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", @@ -12942,170 +12893,6 @@ "dev": true, "license": "MIT" }, - "node_modules/performance-now": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", - "integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==", - "dev": true, - "license": "MIT" - }, - "node_modules/phantomjs-prebuilt": { - "version": "2.1.16", - "resolved": "https://registry.npmjs.org/phantomjs-prebuilt/-/phantomjs-prebuilt-2.1.16.tgz", - "integrity": "sha512-PIiRzBhW85xco2fuj41FmsyuYHKjKuXWmhjy3A/Y+CMpN/63TV+s9uzfVhsUwFe0G77xWtHBG8xmXf5BqEUEuQ==", - "deprecated": "this package is now deprecated", - "dev": true, - "hasInstallScript": true, - "license": "Apache-2.0", - "dependencies": { - "es6-promise": "^4.0.3", - "extract-zip": "^1.6.5", - "fs-extra": "^1.0.0", - "hasha": "^2.2.0", - "kew": "^0.7.0", - "progress": "^1.1.8", - "request": "^2.81.0", - "request-progress": "^2.0.1", - "which": "^1.2.10" - }, - "bin": { - "phantomjs": "bin/phantomjs" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/concat-stream": { - "version": "1.6.2", - "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", - "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", - "dev": true, - "engines": [ - "node >= 0.8" - ], - "license": "MIT", - "dependencies": { - "buffer-from": "^1.0.0", - "inherits": "^2.0.3", - "readable-stream": "^2.2.2", - "typedarray": "^0.0.6" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/extract-zip": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-1.7.0.tgz", - "integrity": "sha512-xoh5G1W/PB0/27lXgMQyIhP5DSY/LhoCsOyZgb+6iMmRtCwVBo55uKaMoEYrDCKQhWvqEip5ZPKAc6eFNyf/MA==", - "dev": true, - "license": "BSD-2-Clause", - "dependencies": { - "concat-stream": "^1.6.2", - "debug": "^2.6.9", - "mkdirp": "^0.5.4", - "yauzl": "^2.10.0" - }, - "bin": { - "extract-zip": "cli.js" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/fs-extra": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-1.0.0.tgz", - "integrity": "sha512-VerQV6vEKuhDWD2HGOybV6v5I73syoc/cXAbKlgTC7M/oFVEtklWlp9QH2Ijw3IaWDOQcMkldSPa7zXy79Z/UQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.1.2", - "jsonfile": "^2.1.0", - "klaw": "^1.0.0" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/jsonfile": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", - "integrity": "sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw==", - "dev": true, - "license": "MIT", - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, - "node_modules/phantomjs-prebuilt/node_modules/progress": { - "version": "1.1.8", - "resolved": "https://registry.npmjs.org/progress/-/progress-1.1.8.tgz", - "integrity": "sha512-UdA8mJ4weIkUBO224tIarHzuHs4HuYiJvsuGT7j/SPQiUJVjYvNDBIPa0hAorduOfjGohB/qHWRa/lrrWX/mXw==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/readable-stream": { - "version": "2.3.8", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", - "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", - "dev": true, - "license": "MIT", - "dependencies": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.3", - "isarray": "~1.0.0", - "process-nextick-args": "~2.0.0", - "safe-buffer": "~5.1.1", - "string_decoder": "~1.1.1", - "util-deprecate": "~1.0.1" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true, - "license": "MIT" - }, - "node_modules/phantomjs-prebuilt/node_modules/string_decoder": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", - "dev": true, - "license": "MIT", - "dependencies": { - "safe-buffer": "~5.1.0" - } - }, - "node_modules/phantomjs-prebuilt/node_modules/which": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", - "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "which": "bin/which" - } - }, - "node_modules/phin": { - "version": "2.9.3", - "resolved": "https://registry.npmjs.org/phin/-/phin-2.9.3.tgz", - "integrity": "sha512-CzFr90qM24ju5f88quFC/6qohjC144rehe5n6DH900lgXmUe86+xCKc10ev56gRKC4/BkHUoG4uSiQgBiIXwDA==", - "deprecated": "Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.", - "dev": true, - "license": "MIT" - }, "node_modules/picocolors": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", @@ -13125,60 +12912,29 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, - "node_modules/pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", - "dev": true, + "node_modules/player.style": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/player.style/-/player.style-0.2.0.tgz", + "integrity": "sha512-Ngoaz49TClptMr8HDA2IFmjT3Iq6R27QEUH/C+On33L59RSF3dCLefBYB1Au2RDZQJ6oVFpc1sXaPVpp7fEzzA==", "license": "MIT", - "engines": { - "node": ">=0.10.0" + "workspaces": [ + ".", + "site", + "examples/*", + "scripts/*", + "themes/*" + ], + "dependencies": { + "media-chrome": "~4.13.0" } }, - "node_modules/pinkie": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/pinkie-promise": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw==", - "dev": true, + "node_modules/player.style/node_modules/media-chrome": { + "version": "4.13.1", + "resolved": "https://registry.npmjs.org/media-chrome/-/media-chrome-4.13.1.tgz", + "integrity": "sha512-jPPwYrFkM4ky27/xNYEeyRPOBC7qvru4Oydy7vQHMHplXLQJmjtcauhlLPvG0O5kkYFEaOBXv5zGYes/UxOoVw==", "license": "MIT", "dependencies": { - "pinkie": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/pixelmatch": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/pixelmatch/-/pixelmatch-4.0.2.tgz", - "integrity": "sha512-J8B6xqiO37sU/gkcMglv6h5Jbd9xNER7aHzpfRdNmV4IbQBzBpe4l9XmbG+xPF/znacgu2jfEw+wHffaq/YkXA==", - "dev": true, - "license": "ISC", - "dependencies": { - "pngjs": "^3.0.0" - }, - "bin": { - "pixelmatch": "bin/pixelmatch" - } - }, - "node_modules/pixelmatch/node_modules/pngjs": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-3.4.0.tgz", - "integrity": "sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4.0.0" + "ce-la-react": "^0.3.0" } }, "node_modules/plist": { @@ -13196,13 +12952,6 @@ "node": ">=10.4.0" } }, - "node_modules/pn": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/pn/-/pn-1.1.0.tgz", - "integrity": "sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==", - "dev": true, - "license": "MIT" - }, "node_modules/pngjs": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-5.0.0.tgz", @@ -13240,13 +12989,6 @@ "node": "^10 || ^12 || >=14" } }, - "node_modules/postcss-value-parser": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", - "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", - "dev": true, - "license": "MIT" - }, "node_modules/postcss/node_modules/nanoid": { "version": "3.3.11", "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.11.tgz", @@ -13272,7 +13014,6 @@ "dev": true, "license": "MIT", "optional": true, - "peer": true, "dependencies": { "commander": "^9.4.0" }, @@ -13290,7 +13031,6 @@ "dev": true, "license": "MIT", "optional": true, - "peer": true, "engines": { "node": "^12.20.0 || >=14" } @@ -13347,6 +13087,15 @@ "url": "https://github.com/prettier/prettier?sponsor=1" } }, + "node_modules/prismjs": { + "version": "1.30.0", + "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.30.0.tgz", + "integrity": "sha512-DEvV2ZF2r2/63V+tK8hQvrR2ZGn10srHbXviTlcv7Kpzw8jWiNTqbVgjO3IY8RxrrOUF8VPMQQFysYYYv0YZxw==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, "node_modules/proc-log": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-2.0.1.tgz", @@ -13357,21 +13106,10 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, - "node_modules/process": { - "version": "0.11.10", - "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", - "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.6.0" - } - }, "node_modules/process-nextick-args": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", - "dev": true, "license": "MIT" }, "node_modules/progress": { @@ -13405,6 +13143,27 @@ "node": ">=10" } }, + "node_modules/prop-types": { + "version": "15.8.1", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", + "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/property-information": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/property-information/-/property-information-7.1.0.tgz", + "integrity": "sha512-TwEZ+X+yCJmYfL7TPUOcvBZ4QfoT5YenQiJuX//0th53DE6w0xxLEtfK3iyryQFddXuvkIk51EEgrJQ0WJkOmQ==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/proxy-addr": { "version": "2.0.7", "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", @@ -13424,19 +13183,6 @@ "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", "license": "MIT" }, - "node_modules/psl": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/psl/-/psl-1.15.0.tgz", - "integrity": "sha512-JZd3gMVBAVQkSs6HdNZo9Sdo0LNcQeMNP3CozBJb3JYC/QUYZTnKxP+f8oWRX4rHP5EurWxqAHTSwUCjlNKa1w==", - "dev": true, - "license": "MIT", - "dependencies": { - "punycode": "^2.3.1" - }, - "funding": { - "url": "https://github.com/sponsors/lupomontero" - } - }, "node_modules/pump": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.3.tgz", @@ -13474,13 +13220,131 @@ "node": ">=10.13.0" } }, + "node_modules/qrcode/node_modules/cliui": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", + "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", + "license": "ISC", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + } + }, + "node_modules/qrcode/node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "license": "MIT", + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/qrcode/node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "license": "MIT", + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/qrcode/node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "license": "MIT", + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/qrcode/node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "license": "MIT", + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/qrcode/node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/qrcode/node_modules/y18n": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", + "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", + "license": "ISC" + }, + "node_modules/qrcode/node_modules/yargs": { + "version": "15.4.1", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", + "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", + "license": "MIT", + "dependencies": { + "cliui": "^6.0.0", + "decamelize": "^1.2.0", + "find-up": "^4.1.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^4.2.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^18.1.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/qrcode/node_modules/yargs-parser": { + "version": "18.1.3", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", + "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", + "license": "ISC", + "dependencies": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + }, + "engines": { + "node": ">=6" + } + }, "node_modules/qs": { - "version": "6.14.0", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.14.0.tgz", - "integrity": "sha512-YWWTjgABSKcvs/nWBi9PycY/JiPJqOD4JA6o9Sej2AtvSGarXxKC3OQSk4pAarbdQlKAh5D4FCQkJNkW+GAn3w==", + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", + "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", "license": "BSD-3-Clause", "dependencies": { - "side-channel": "^1.1.0" + "side-channel": "^1.0.6" }, "engines": { "node": ">=0.6" @@ -13533,34 +13397,18 @@ } }, "node_modules/raw-body": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", - "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", + "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", "license": "MIT", "dependencies": { "bytes": "3.1.2", "http-errors": "2.0.0", - "iconv-lite": "0.7.0", + "iconv-lite": "0.4.24", "unpipe": "1.0.0" }, "engines": { - "node": ">= 0.10" - } - }, - "node_modules/raw-body/node_modules/iconv-lite": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", - "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", - "license": "MIT", - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3.0.0" - }, - "engines": { - "node": ">=0.10.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/express" + "node": ">= 0.8" } }, "node_modules/rc": { @@ -13587,24 +13435,12 @@ "node": ">=0.10.0" } }, - "node_modules/rcedit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/rcedit/-/rcedit-3.1.0.tgz", - "integrity": "sha512-WRlRdY1qZbu1L11DklT07KuHfRk42l0NFFJdaExELEu4fEQ982bP5Z6OWGPj/wLLIuKRQDCxZJGAwoFsxhZhNA==", - "dev": true, - "license": "MIT", - "dependencies": { - "cross-spawn-windows-exe": "^1.1.0" - }, - "engines": { - "node": ">= 10.0.0" - } - }, "node_modules/react": { "version": "19.1.1", "resolved": "https://registry.npmjs.org/react/-/react-19.1.1.tgz", "integrity": "sha512-w8nqGImo45dmMIfljjMwOGtbmC/mk4CMYhWIicdSflH91J9TyCyczcPFXJzrZ/ZXcgGRFeP6BU0BEJTw6tZdfQ==", "license": "MIT", + "peer": true, "engines": { "node": ">=0.10.0" } @@ -13614,6 +13450,7 @@ "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.1.1.tgz", "integrity": "sha512-Dlq/5LAZgF0Gaz6yiqZCf6VCcZs1ghAJyrsu84Q/GT0gV+mCxbfmKNoGRKBYMJ8IEdGPqu49YWXD02GCknEDkw==", "license": "MIT", + "peer": true, "dependencies": { "scheduler": "^0.26.0" }, @@ -13621,11 +13458,26 @@ "react": "^19.1.1" } }, - "node_modules/react-hook-form": { - "version": "7.62.0", - "resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.62.0.tgz", - "integrity": "sha512-7KWFejc98xqG/F4bAxpL41NB3o1nnvQO1RWZT3TqRZYL8RryQETGfEdVnJN2fy1crCiBLLjkRBVK05j24FxJGA==", + "node_modules/react-h5-audio-player": { + "version": "3.10.1", + "resolved": "https://registry.npmjs.org/react-h5-audio-player/-/react-h5-audio-player-3.10.1.tgz", + "integrity": "sha512-r6fSj9WXR6af1kxH5qQ/tawwDK4KrMfayiVCUettLYGX/KZ3BH8OGuaZP4O5KD0AxwsKAXtBv4kVQCWFzaIrUA==", "license": "MIT", + "dependencies": { + "@babel/runtime": "^7.10.2", + "@iconify/react": "^5" + }, + "peerDependencies": { + "react": "^16.3.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.3.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + } + }, + "node_modules/react-hook-form": { + "version": "7.63.0", + "resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.63.0.tgz", + "integrity": "sha512-ZwueDMvUeucovM2VjkCf7zIHcs1aAlDimZu2Hvel5C5907gUzMpm4xCrQXtRzCvsBqFjonB4m3x4LzCFI1ZKWA==", + "license": "MIT", + "peer": true, "engines": { "node": ">=18.0.0" }, @@ -13638,16 +13490,16 @@ } }, "node_modules/react-i18next": { - "version": "15.7.3", - "resolved": "https://registry.npmjs.org/react-i18next/-/react-i18next-15.7.3.tgz", - "integrity": "sha512-AANws4tOE+QSq/IeMF/ncoHlMNZaVLxpa5uUGW1wjike68elVYr0018L9xYoqBr1OFO7G7boDPrbn0HpMCJxTw==", + "version": "15.7.4", + "resolved": "https://registry.npmjs.org/react-i18next/-/react-i18next-15.7.4.tgz", + "integrity": "sha512-nyU8iKNrI5uDJch0z9+Y5XEr34b0wkyYj3Rp+tfbahxtlswxSCjcUL9H0nqXo9IR3/t5Y5PKIA3fx3MfUyR9Xw==", "license": "MIT", "dependencies": { "@babel/runtime": "^7.27.6", "html-parse-stringify": "^3.0.1" }, "peerDependencies": { - "i18next": ">= 25.4.1", + "i18next": ">= 23.4.0", "react": ">= 16.8.0", "typescript": "^5" }, @@ -13663,6 +13515,110 @@ } } }, + "node_modules/react-icons": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/react-icons/-/react-icons-5.5.0.tgz", + "integrity": "sha512-MEFcXdkP3dLo8uumGI5xN3lDFNsRtrjbOEKDLD7yv76v4wpnEq2Lt2qeHaQOr34I/wPN3s3+N08WkQ+CW37Xiw==", + "license": "MIT", + "peerDependencies": { + "react": "*" + } + }, + "node_modules/react-is": { + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", + "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", + "license": "MIT" + }, + "node_modules/react-markdown": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/react-markdown/-/react-markdown-10.1.0.tgz", + "integrity": "sha512-qKxVopLT/TyA6BX3Ue5NwabOsAzm0Q7kAPwq6L+wWDwisYs7R8vZ0nRXqq6rkueboxpkjvLGU9fWifiX/ZZFxQ==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "hast-util-to-jsx-runtime": "^2.0.0", + "html-url-attributes": "^3.0.0", + "mdast-util-to-hast": "^13.0.0", + "remark-parse": "^11.0.0", + "remark-rehype": "^11.0.0", + "unified": "^11.0.0", + "unist-util-visit": "^5.0.0", + "vfile": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + }, + "peerDependencies": { + "@types/react": ">=18", + "react": ">=18" + } + }, + "node_modules/react-pdf": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/react-pdf/-/react-pdf-10.1.0.tgz", + "integrity": "sha512-iUI1YqWgwwZcsXjrehTp3Yi8nT/bvTaWULaRMMyJWvoqqSlopk4LQQ9GDqUnDtX3gzT2glrqrLbjIPl56a+Q3w==", + "license": "MIT", + "dependencies": { + "clsx": "^2.0.0", + "dequal": "^2.0.3", + "make-cancellable-promise": "^2.0.0", + "make-event-props": "^2.0.0", + "merge-refs": "^2.0.0", + "pdfjs-dist": "5.3.93", + "tiny-invariant": "^1.0.0", + "warning": "^4.0.0" + }, + "funding": { + "url": "https://github.com/wojtekmaj/react-pdf?sponsor=1" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/react-photo-view": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/react-photo-view/-/react-photo-view-1.2.7.tgz", + "integrity": "sha512-MfOWVPxuibncRLaycZUNxqYU8D9IA+rbGDDaq6GM8RIoGJal592hEJoRAyRSI7ZxyyJNJTLMUWWL3UIXHJJOpw==", + "license": "Apache-2.0", + "peerDependencies": { + "react": ">=16.8.0", + "react-dom": ">=16.8.0" + } + }, + "node_modules/react-player": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/react-player/-/react-player-3.3.3.tgz", + "integrity": "sha512-6U2ziVohA3WLdKI/WEQ7v27CIive0TCNIro55lJZka06fjB2kC4lJqBrvddG0yBvTDcn1owiUf2hRNaIzHAjIg==", + "license": "MIT", + "dependencies": { + "@mux/mux-player-react": "^3.6.0", + "cloudflare-video-element": "^1.3.4", + "dash-video-element": "^0.2.0", + "hls-video-element": "^1.5.8", + "spotify-audio-element": "^1.0.3", + "tiktok-video-element": "^0.1.1", + "twitch-video-element": "^0.1.4", + "vimeo-video-element": "^1.5.5", + "wistia-video-element": "^1.3.4", + "youtube-video-element": "^1.6.2" + }, + "peerDependencies": { + "@types/react": "^17.0.0 || ^18 || ^19", + "react": "^17.0.2 || ^18 || ^19", + "react-dom": "^17.0.2 || ^18 || ^19" + } + }, "node_modules/react-remove-scroll": { "version": "2.7.1", "resolved": "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.7.1.tgz", @@ -13711,9 +13667,9 @@ } }, "node_modules/react-resizable-panels": { - "version": "3.0.5", - "resolved": "https://registry.npmjs.org/react-resizable-panels/-/react-resizable-panels-3.0.5.tgz", - "integrity": "sha512-3z1yN25DMTXLg2wfyFrW32r5k4WEcUa3F7cJ2EgtNK07lnOs4mpM8yWLGunCpkhcQRwJX4fqoLcIh/pHPxzlmQ==", + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/react-resizable-panels/-/react-resizable-panels-3.0.6.tgz", + "integrity": "sha512-b3qKHQ3MLqOgSS+FRYKapNkJZf5EQzuf6+RLiq1/IlTHw99YrZ2NJZLk4hQIzTnnIkRg2LUqyVinu6YWWpUYew==", "license": "MIT", "peerDependencies": { "react": "^16.14.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc", @@ -13721,9 +13677,9 @@ } }, "node_modules/react-simple-keyboard": { - "version": "3.8.122", - "resolved": "https://registry.npmjs.org/react-simple-keyboard/-/react-simple-keyboard-3.8.122.tgz", - "integrity": "sha512-9u8Boglwtoa/SpZO3UyyEhs17z3vYTRFWS93Ihc6E8JFcCpa5kzt11IwWo5qa9KZqutqWuD5ara1mf5+WJYVGQ==", + "version": "3.8.125", + "resolved": "https://registry.npmjs.org/react-simple-keyboard/-/react-simple-keyboard-3.8.125.tgz", + "integrity": "sha512-8+PbmGA2auM7V57hapHsKV7IJcJVl0QNNW09RJQ7xCiohHuZNKvqrxGvisxhhr7X8C8TKulxbqdxjZbFelwO7w==", "license": "MIT", "peerDependencies": { "react": "^16.0.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", @@ -13752,6 +13708,23 @@ } } }, + "node_modules/react-syntax-highlighter": { + "version": "15.6.6", + "resolved": "https://registry.npmjs.org/react-syntax-highlighter/-/react-syntax-highlighter-15.6.6.tgz", + "integrity": "sha512-DgXrc+AZF47+HvAPEmn7Ua/1p10jNoVZVI/LoPiYdtY+OM+/nG5yefLHKJwdKqY1adMuHFbeyBaG9j64ML7vTw==", + "license": "MIT", + "dependencies": { + "@babel/runtime": "^7.3.1", + "highlight.js": "^10.4.1", + "highlightjs-vue": "^1.0.0", + "lowlight": "^1.17.0", + "prismjs": "^1.30.0", + "refractor": "^3.6.0" + }, + "peerDependencies": { + "react": ">= 0.14.0" + } + }, "node_modules/react-xtermjs": { "version": "1.0.10", "resolved": "https://registry.npmjs.org/react-xtermjs/-/react-xtermjs-1.0.10.tgz", @@ -13774,288 +13747,232 @@ "read-binary-file-arch": "cli.js" } }, - "node_modules/read-pkg": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", - "integrity": "sha512-eFIBOPW7FGjzBuk3hdXEuNSiTZS/xEMlH49HxMyzb0hyPfu4EhVjT2DH32K1hSSmVq4sebAWnZuuY5auISUTGA==", + "node_modules/read-binary-file-arch/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "license": "MIT", "dependencies": { - "load-json-file": "^2.0.0", - "normalize-package-data": "^2.3.2", - "path-type": "^2.0.0" + "ms": "^2.1.3" }, "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", - "integrity": "sha512-1orxQfbWGUiTn9XsPlChs6rLie/AV9jwZTGmu2NZw/CUDJQchXJFYE0Fq5j7+n558T1JhDWLdhyd1Zj+wLY//w==", - "dev": true, - "license": "MIT", - "dependencies": { - "find-up": "^2.0.0", - "read-pkg": "^2.0.0" + "node": ">=6.0" }, - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/find-up": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", - "integrity": "sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "locate-path": "^2.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/locate-path": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", - "integrity": "sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA==", - "dev": true, - "license": "MIT", - "dependencies": { - "p-locate": "^2.0.0", - "path-exists": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/p-limit": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", - "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "p-try": "^1.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/p-locate": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", - "integrity": "sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg==", - "dev": true, - "license": "MIT", - "dependencies": { - "p-limit": "^1.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/p-try": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", - "integrity": "sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/read-pkg-up/node_modules/path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/readable-web-to-node-stream": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.4.tgz", - "integrity": "sha512-9nX56alTf5bwXQ3ZDipHJhusu9NTQJ/CVPtb/XHAJCXihZeitfJvIRS4GqQ/mfIoOE3IelHMrpayVrosdHBuLw==", - "dev": true, - "license": "MIT", - "dependencies": { - "readable-stream": "^4.7.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/Borewit" - } - }, - "node_modules/readable-web-to-node-stream/node_modules/buffer": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", - "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" + "peerDependenciesMeta": { + "supports-color": { + "optional": true } - ], - "license": "MIT", - "dependencies": { - "base64-js": "^1.3.1", - "ieee754": "^1.2.1" } }, - "node_modules/readable-web-to-node-stream/node_modules/readable-stream": { - "version": "4.7.0", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-4.7.0.tgz", - "integrity": "sha512-oIGGmcpTLwPga8Bn6/Z75SVaH1z5dUut2ibSyAMVhmUggWpmDn2dapB0n7f8nwaSiRtepAsfJyfXIO5DCVAODg==", - "dev": true, - "license": "MIT", - "dependencies": { - "abort-controller": "^3.0.0", - "buffer": "^6.0.3", - "events": "^3.3.0", - "process": "^0.11.10", - "string_decoder": "^1.3.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - } - }, - "node_modules/regenerator-runtime": { - "version": "0.13.11", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", - "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==", + "node_modules/read-binary-file-arch/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true, "license": "MIT" }, - "node_modules/request": { - "version": "2.88.2", - "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", - "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", - "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", - "dev": true, - "license": "Apache-2.0", + "node_modules/readable-stream": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", + "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", + "license": "MIT", "dependencies": { - "aws-sign2": "~0.7.0", - "aws4": "^1.8.0", - "caseless": "~0.12.0", - "combined-stream": "~1.0.6", - "extend": "~3.0.2", - "forever-agent": "~0.6.1", - "form-data": "~2.3.2", - "har-validator": "~5.1.3", - "http-signature": "~1.2.0", - "is-typedarray": "~1.0.0", - "isstream": "~0.1.2", - "json-stringify-safe": "~5.0.1", - "mime-types": "~2.1.19", - "oauth-sign": "~0.9.0", - "performance-now": "^2.1.0", - "qs": "~6.5.2", - "safe-buffer": "^5.1.2", - "tough-cookie": "~2.5.0", - "tunnel-agent": "^0.6.0", - "uuid": "^3.3.2" + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/readable-stream/node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "license": "MIT" + }, + "node_modules/refractor": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/refractor/-/refractor-3.6.0.tgz", + "integrity": "sha512-MY9W41IOWxxk31o+YvFCNyNzdkc9M20NoZK5vq6jkv4I/uh2zkWcfudj0Q1fovjUQJrNewS9NMzeTtqPf+n5EA==", + "license": "MIT", + "dependencies": { + "hastscript": "^6.0.0", + "parse-entities": "^2.0.0", + "prismjs": "~1.27.0" }, - "engines": { - "node": ">= 6" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/request-progress": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/request-progress/-/request-progress-2.0.1.tgz", - "integrity": "sha512-dxdraeZVUNEn9AvLrxkgB2k6buTlym71dJk1fk4v8j3Ou3RKNm07BcgbHdj2lLgYGfqX71F+awb1MR+tWPFJzA==", - "dev": true, + "node_modules/refractor/node_modules/character-entities": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-1.2.4.tgz", + "integrity": "sha512-iBMyeEHxfVnIakwOuDXpVkc54HijNgCyQB2w0VfGQThle6NXn50zU6V/u+LDhxHcDUPojn6Kpga3PTAD8W1bQw==", "license": "MIT", - "dependencies": { - "throttleit": "^1.0.0" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/request/node_modules/form-data": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", - "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", - "dev": true, + "node_modules/refractor/node_modules/character-entities-legacy": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-1.1.4.tgz", + "integrity": "sha512-3Xnr+7ZFS1uxeiUDvV02wQ+QDbc55o97tIV5zHScSPJpcLm/r0DFPcoY3tYRp+VZukxuMeKgXYmsXQHO05zQeA==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/refractor/node_modules/character-reference-invalid": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/character-reference-invalid/-/character-reference-invalid-1.1.4.tgz", + "integrity": "sha512-mKKUkUbhPpQlCOfIuZkvSEgktjPFIsZKRRbC6KWVEMvlzblj3i3asQv5ODsrwt0N3pHAEvjP8KTQPHkp0+6jOg==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/refractor/node_modules/is-alphabetical": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-alphabetical/-/is-alphabetical-1.0.4.tgz", + "integrity": "sha512-DwzsA04LQ10FHTZuL0/grVDk4rFoVH1pjAToYwBrHSxcrBIGQuXrQMtD5U1b0U2XVgKZCTLLP8u2Qxqhy3l2Vg==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/refractor/node_modules/is-alphanumerical": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-alphanumerical/-/is-alphanumerical-1.0.4.tgz", + "integrity": "sha512-UzoZUr+XfVz3t3v4KyGEniVL9BDRoQtY7tOyrRybkVNjDFWyo1yhXNGrrBTQxp3ib9BLAWs7k2YKBQsFRkZG9A==", "license": "MIT", "dependencies": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.6", - "mime-types": "^2.1.12" + "is-alphabetical": "^1.0.0", + "is-decimal": "^1.0.0" }, - "engines": { - "node": ">= 0.12" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/request/node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "dev": true, + "node_modules/refractor/node_modules/is-decimal": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-decimal/-/is-decimal-1.0.4.tgz", + "integrity": "sha512-RGdriMmQQvZ2aqaQq3awNA6dCGtKpiDFcOzrTWrDAT2MiWrKQVPmxLGHl7Y2nNu6led0kEyoX0enY0qXYsv9zw==", "license": "MIT", - "engines": { - "node": ">= 0.6" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/request/node_modules/mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "dev": true, + "node_modules/refractor/node_modules/is-hexadecimal": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-hexadecimal/-/is-hexadecimal-1.0.4.tgz", + "integrity": "sha512-gyPJuv83bHMpocVYoqof5VDiZveEoGoFL8m3BXNb2VW8Xs+rz9kqO8LOQ5DH6EsuvilT1ApazU0pyl+ytbPtlw==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/refractor/node_modules/parse-entities": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/parse-entities/-/parse-entities-2.0.0.tgz", + "integrity": "sha512-kkywGpCcRYhqQIchaWqZ875wzpS/bMKhz5HnN3p7wveJTkTtyAB/AlnS0f8DFSqYW1T82t6yEAkEcB+A1I3MbQ==", "license": "MIT", "dependencies": { - "mime-db": "1.52.0" + "character-entities": "^1.0.0", + "character-entities-legacy": "^1.0.0", + "character-reference-invalid": "^1.0.0", + "is-alphanumerical": "^1.0.0", + "is-decimal": "^1.0.0", + "is-hexadecimal": "^1.0.0" }, - "engines": { - "node": ">= 0.6" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/request/node_modules/qs": { - "version": "6.5.3", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.3.tgz", - "integrity": "sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA==", - "dev": true, - "license": "BSD-3-Clause", - "engines": { - "node": ">=0.6" - } - }, - "node_modules/request/node_modules/uuid": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", - "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", - "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", - "dev": true, + "node_modules/refractor/node_modules/prismjs": { + "version": "1.27.0", + "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.27.0.tgz", + "integrity": "sha512-t13BGPUlFDR7wRB5kQDG4jjl7XeuH6jbJGt11JHPL96qwsEHNX2+68tFXqc1/k+/jALsbSWJKUOT/hcYAZ5LkA==", "license": "MIT", - "bin": { - "uuid": "bin/uuid" + "engines": { + "node": ">=6" + } + }, + "node_modules/remark-gfm": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/remark-gfm/-/remark-gfm-4.0.1.tgz", + "integrity": "sha512-1quofZ2RQ9EWdeN34S79+KExV1764+wCUGop5CPL1WGdD0ocPpu91lzPGbwWMECpEpd42kJGQwzRfyov9j4yNg==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "mdast-util-gfm": "^3.0.0", + "micromark-extension-gfm": "^3.0.0", + "remark-parse": "^11.0.0", + "remark-stringify": "^11.0.0", + "unified": "^11.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/remark-parse": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-11.0.0.tgz", + "integrity": "sha512-FCxlKLNGknS5ba/1lmpYijMUzX2esxW5xQqjWxw2eHFfS2MSdaHVINFmhjo+qN1WhZhNimq0dZATN9pH0IDrpA==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "mdast-util-from-markdown": "^2.0.0", + "micromark-util-types": "^2.0.0", + "unified": "^11.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/remark-rehype": { + "version": "11.1.2", + "resolved": "https://registry.npmjs.org/remark-rehype/-/remark-rehype-11.1.2.tgz", + "integrity": "sha512-Dh7l57ianaEoIpzbp0PC9UKAdCSVklD8E5Rpw7ETfbTl3FqcOOgq5q2LVDhgGCkaBv7p24JXikPdvhhmHvKMsw==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "mdast-util-to-hast": "^13.0.0", + "unified": "^11.0.0", + "vfile": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/remark-stringify": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/remark-stringify/-/remark-stringify-11.0.0.tgz", + "integrity": "sha512-1OSmLd3awB/t8qdoEOMazZkNsfVTeY4fTsgzcQFdXNq8ToTN4ZGwrMnlda4K6smTFKD+GRV6O48i6Z4iKgPPpw==", + "license": "MIT", + "dependencies": { + "@types/mdast": "^4.0.0", + "mdast-util-to-markdown": "^2.0.0", + "unified": "^11.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" } }, "node_modules/require-directory": { @@ -14091,27 +14008,6 @@ "url": "https://github.com/sponsors/jet2jet" } }, - "node_modules/resolve": { - "version": "1.22.10", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.10.tgz", - "integrity": "sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-core-module": "^2.16.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/resolve-alpn": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/resolve-alpn/-/resolve-alpn-1.2.1.tgz", @@ -14214,9 +14110,9 @@ } }, "node_modules/rollup": { - "version": "4.50.1", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.50.1.tgz", - "integrity": "sha512-78E9voJHwnXQMiQdiqswVLZwJIzdBKJ1GdI5Zx6XwoFKUIk09/sSrr+05QFzvYb8q6Y9pPV45zzDuYa3907TZA==", + "version": "4.52.3", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.52.3.tgz", + "integrity": "sha512-RIDh866U8agLgiIcdpB+COKnlCreHJLfIhWC3LVflku5YHfpnsIKigRZeFfMfCc4dVcqNVfQQ5gO/afOck064A==", "license": "MIT", "dependencies": { "@types/estree": "1.0.8" @@ -14229,27 +14125,28 @@ "npm": ">=8.0.0" }, "optionalDependencies": { - "@rollup/rollup-android-arm-eabi": "4.50.1", - "@rollup/rollup-android-arm64": "4.50.1", - "@rollup/rollup-darwin-arm64": "4.50.1", - "@rollup/rollup-darwin-x64": "4.50.1", - "@rollup/rollup-freebsd-arm64": "4.50.1", - "@rollup/rollup-freebsd-x64": "4.50.1", - "@rollup/rollup-linux-arm-gnueabihf": "4.50.1", - "@rollup/rollup-linux-arm-musleabihf": "4.50.1", - "@rollup/rollup-linux-arm64-gnu": "4.50.1", - "@rollup/rollup-linux-arm64-musl": "4.50.1", - "@rollup/rollup-linux-loongarch64-gnu": "4.50.1", - "@rollup/rollup-linux-ppc64-gnu": "4.50.1", - "@rollup/rollup-linux-riscv64-gnu": "4.50.1", - "@rollup/rollup-linux-riscv64-musl": "4.50.1", - "@rollup/rollup-linux-s390x-gnu": "4.50.1", - "@rollup/rollup-linux-x64-gnu": "4.50.1", - "@rollup/rollup-linux-x64-musl": "4.50.1", - "@rollup/rollup-openharmony-arm64": "4.50.1", - "@rollup/rollup-win32-arm64-msvc": "4.50.1", - "@rollup/rollup-win32-ia32-msvc": "4.50.1", - "@rollup/rollup-win32-x64-msvc": "4.50.1", + "@rollup/rollup-android-arm-eabi": "4.52.3", + "@rollup/rollup-android-arm64": "4.52.3", + "@rollup/rollup-darwin-arm64": "4.52.3", + "@rollup/rollup-darwin-x64": "4.52.3", + "@rollup/rollup-freebsd-arm64": "4.52.3", + "@rollup/rollup-freebsd-x64": "4.52.3", + "@rollup/rollup-linux-arm-gnueabihf": "4.52.3", + "@rollup/rollup-linux-arm-musleabihf": "4.52.3", + "@rollup/rollup-linux-arm64-gnu": "4.52.3", + "@rollup/rollup-linux-arm64-musl": "4.52.3", + "@rollup/rollup-linux-loong64-gnu": "4.52.3", + "@rollup/rollup-linux-ppc64-gnu": "4.52.3", + "@rollup/rollup-linux-riscv64-gnu": "4.52.3", + "@rollup/rollup-linux-riscv64-musl": "4.52.3", + "@rollup/rollup-linux-s390x-gnu": "4.52.3", + "@rollup/rollup-linux-x64-gnu": "4.52.3", + "@rollup/rollup-linux-x64-musl": "4.52.3", + "@rollup/rollup-openharmony-arm64": "4.52.3", + "@rollup/rollup-win32-arm64-msvc": "4.52.3", + "@rollup/rollup-win32-ia32-msvc": "4.52.3", + "@rollup/rollup-win32-x64-gnu": "4.52.3", + "@rollup/rollup-win32-x64-msvc": "4.52.3", "fsevents": "~2.3.2" } }, @@ -14269,6 +14166,29 @@ "node": ">= 18" } }, + "node_modules/router/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/router/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, "node_modules/run-parallel": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", @@ -14297,7 +14217,6 @@ "version": "7.8.2", "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.2.tgz", "integrity": "sha512-dhKf903U/PQZY6boNNtAGdWbG85WAbjT/1xYoZIC7FAY0yWapOBQVsVrDl58W86//e1VpMNBtRV4MaXfdMySFA==", - "dev": true, "license": "Apache-2.0", "dependencies": { "tslib": "^2.1.0" @@ -14353,15 +14272,13 @@ "license": "MIT" }, "node_modules/semver": { - "version": "7.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", - "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, "license": "ISC", "bin": { "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" } }, "node_modules/semver-compare": { @@ -14394,6 +14311,29 @@ "node": ">= 18" } }, + "node_modules/send/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/send/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, "node_modules/serialize-error": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/serialize-error/-/serialize-error-7.0.1.tgz", @@ -14432,6 +14372,12 @@ "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==", "license": "ISC" }, + "node_modules/setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", + "license": "MIT" + }, "node_modules/setprototypeof": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", @@ -14611,14 +14557,17 @@ "node": ">=10" } }, - "node_modules/slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "node_modules/simple-update-notifier/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", "dev": true, - "license": "MIT", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, "engines": { - "node": ">=8" + "node": ">=10" } }, "node_modules/slice-ansi": { @@ -14691,6 +14640,31 @@ "node": ">= 6.0.0" } }, + "node_modules/socks-proxy-agent/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/socks-proxy-agent/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, "node_modules/sonner": { "version": "2.0.7", "resolved": "https://registry.npmjs.org/sonner/-/sonner-2.0.7.tgz", @@ -14731,42 +14705,16 @@ "source-map": "^0.6.0" } }, - "node_modules/spdx-correct": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", - "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "spdx-expression-parse": "^3.0.0", - "spdx-license-ids": "^3.0.0" - } - }, - "node_modules/spdx-exceptions": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", - "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", - "dev": true, - "license": "CC-BY-3.0" - }, - "node_modules/spdx-expression-parse": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", - "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", - "dev": true, + "node_modules/space-separated-tokens": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-2.0.2.tgz", + "integrity": "sha512-PEGlAwrG8yXGXRjW32fGbg66JAlOAwbObuqVoJpv/mRgoWDQfgH1wDPvtzWyUSNAXBGSk8h755YDbbcEy3SH2Q==", "license": "MIT", - "dependencies": { - "spdx-exceptions": "^2.1.0", - "spdx-license-ids": "^3.0.0" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/spdx-license-ids": { - "version": "3.0.22", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.22.tgz", - "integrity": "sha512-4PRT4nh1EImPbt2jASOKHX7PB7I+e4IWNLvkKFDxNhJlfjbYlleYQh285Z/3mPTHSAK/AvdMmw5BNNuYH8ShgQ==", - "dev": true, - "license": "CC0-1.0" - }, "node_modules/speakeasy": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/speakeasy/-/speakeasy-2.0.0.tgz", @@ -14779,6 +14727,12 @@ "node": ">= 0.10.0" } }, + "node_modules/spotify-audio-element": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/spotify-audio-element/-/spotify-audio-element-1.0.3.tgz", + "integrity": "sha512-I1/qD8cg/UnTlCIMiKSdZUJTyYfYhaqFK7LIVElc48eOqUUbVCaw1bqL8I6mJzdMJTh3eoNyF/ewvB7NoS/g9A==", + "license": "MIT" + }, "node_modules/sprintf-js": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", @@ -14787,14 +14741,6 @@ "license": "BSD-3-Clause", "optional": true }, - "node_modules/sql.js": { - "version": "1.13.0", - "resolved": "https://registry.npmjs.org/sql.js/-/sql.js-1.13.0.tgz", - "integrity": "sha512-RJbVP1HRDlUUXahJ7VMTcu9Rm1Nzw+EBpoPr94vnbD4LwR715F3CcxE2G2k45PewcaZ57pjetYa+LoSJLAASgA==", - "license": "MIT", - "optional": true, - "peer": true - }, "node_modules/ssh2": { "version": "1.17.0", "resolved": "https://registry.npmjs.org/ssh2/-/ssh2-1.17.0.tgz", @@ -14812,32 +14758,6 @@ "nan": "^2.23.0" } }, - "node_modules/sshpk": { - "version": "1.18.0", - "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.18.0.tgz", - "integrity": "sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "asn1": "~0.2.3", - "assert-plus": "^1.0.0", - "bcrypt-pbkdf": "^1.0.0", - "dashdash": "^1.12.0", - "ecc-jsbn": "~0.1.1", - "getpass": "^0.1.1", - "jsbn": "~0.1.0", - "safer-buffer": "^2.0.2", - "tweetnacl": "~0.14.0" - }, - "bin": { - "sshpk-conv": "bin/sshpk-conv", - "sshpk-sign": "bin/sshpk-sign", - "sshpk-verify": "bin/sshpk-verify" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/ssri": { "version": "9.0.1", "resolved": "https://registry.npmjs.org/ssri/-/ssri-9.0.1.tgz", @@ -14851,26 +14771,6 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, - "node_modules/ssri/node_modules/minipass": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", - "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", - "dev": true, - "license": "ISC", - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/ssri/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true, - "license": "ISC" - }, "node_modules/stat-mode": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/stat-mode/-/stat-mode-1.0.0.tgz", @@ -14881,6 +14781,12 @@ "node": ">= 6" } }, + "node_modules/state-local": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/state-local/-/state-local-1.0.7.tgz", + "integrity": "sha512-HTEHMNieakEnoe33shBYcZ7NX83ACUjCu8c40iOGEZsngj9zRnkqS9j1pqQPXwobB0ZcVTk27REb7COQ0UR59w==", + "license": "MIT" + }, "node_modules/statuses": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.2.tgz", @@ -14899,14 +14805,20 @@ } }, "node_modules/string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", "license": "MIT", "dependencies": { - "safe-buffer": "~5.2.0" + "safe-buffer": "~5.1.0" } }, + "node_modules/string_decoder/node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "license": "MIT" + }, "node_modules/string-width": { "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", @@ -14937,6 +14849,20 @@ "node": ">=8" } }, + "node_modules/stringify-entities": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/stringify-entities/-/stringify-entities-4.0.4.tgz", + "integrity": "sha512-IwfBptatlO+QCJUo19AqvrPNqlVMpW9YEL2LIVY+Rpv2qsjCGxaDLNRgeGsQWJhfItebuJhsGSLjaBbNSQ+ieg==", + "license": "MIT", + "dependencies": { + "character-entities-html4": "^2.0.0", + "character-entities-legacy": "^3.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/strip-ansi": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", @@ -14963,16 +14889,6 @@ "node": ">=8" } }, - "node_modules/strip-bom": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", - "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/strip-json-comments": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", @@ -14986,53 +14902,30 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/strip-outer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/strip-outer/-/strip-outer-1.0.1.tgz", - "integrity": "sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==", - "dev": true, - "license": "MIT", - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/strip-outer/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/strtok3": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz", - "integrity": "sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@tokenizer/token": "^0.3.0", - "peek-readable": "^4.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/Borewit" - } - }, "node_modules/style-mod": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/style-mod/-/style-mod-4.1.2.tgz", "integrity": "sha512-wnD1HyVqpJUI2+eKZ+eo1UwghftP6yuFheBqqe+bWCotBjC2K1YnteJILRMs3SM4V/0dLEW1SC27MWP5y+mwmw==", "license": "MIT" }, + "node_modules/style-to-js": { + "version": "1.1.17", + "resolved": "https://registry.npmjs.org/style-to-js/-/style-to-js-1.1.17.tgz", + "integrity": "sha512-xQcBGDxJb6jjFCTzvQtfiPn6YvvP2O8U1MDIPNfJQlWMYfktPy+iGsHE7cssjs7y84d9fQaK4UF3RIJaAHSoYA==", + "license": "MIT", + "dependencies": { + "style-to-object": "1.0.9" + } + }, + "node_modules/style-to-object": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/style-to-object/-/style-to-object-1.0.9.tgz", + "integrity": "sha512-G4qppLgKu/k6FwRpHiGiKPaPTFcG3g4wNVX/Qsfu+RqQM30E7Tyu/TEgxcL9PNLF5pdRLwQdE3YKKf+KF2Dzlw==", + "license": "MIT", + "dependencies": { + "inline-style-parser": "0.2.4" + } + }, "node_modules/sumchecker": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/sumchecker/-/sumchecker-3.0.1.tgz", @@ -15046,6 +14939,37 @@ "node": ">= 8.0" } }, + "node_modules/sumchecker/node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/sumchecker/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/super-media-element": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/super-media-element/-/super-media-element-1.4.2.tgz", + "integrity": "sha512-9pP/CVNp4NF2MNlRzLwQkjiTgKKe9WYXrLh9+8QokWmMxz+zt2mf1utkWLco26IuA3AfVcTb//qtlTIjY3VHxA==", + "license": "MIT" + }, "node_modules/supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -15058,283 +14982,6 @@ "node": ">=8" } }, - "node_modules/supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/svg2png": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/svg2png/-/svg2png-4.1.1.tgz", - "integrity": "sha512-9tOp9Ugjlunuf1ugqkhiYboTmTaTI7p48dz5ZjNA5NQJ5xS1NLTZZ1tF8vkJOIBb/ZwxGJsKZvRWqVpo4q9z9Q==", - "dev": true, - "license": "WTFPL", - "dependencies": { - "file-url": "^2.0.0", - "phantomjs-prebuilt": "^2.1.14", - "pn": "^1.0.0", - "yargs": "^6.5.0" - }, - "bin": { - "svg2png": "bin/svg2png-cli.js" - } - }, - "node_modules/svg2png/node_modules/ansi-regex": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/camelcase": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", - "integrity": "sha512-4nhGqUkc4BqbBBB4Q6zLuD7lzzrHYrjKGeYaEji/3tFR5VdJu9v+LilhGIVe8wxEJPPOeWo7eg8dwY13TZ1BNg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/cliui": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", - "integrity": "sha512-0yayqDxWQbqk3ojkYqUKqaAQ6AfNKeKWRNA8kR0WXzAsdHpP4BIaOmMAG87JGuO6qcobyW4GjxHd9PmhEd+T9w==", - "dev": true, - "license": "ISC", - "dependencies": { - "string-width": "^1.0.1", - "strip-ansi": "^3.0.1", - "wrap-ansi": "^2.0.0" - } - }, - "node_modules/svg2png/node_modules/find-up": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha512-jvElSjyuo4EMQGoTwo1uJU5pQMwTW5lS1x05zzfJuTIyLR3zwO27LYrxNg+dlvKpGOuGy/MzBdXh80g0ve5+HA==", - "dev": true, - "license": "MIT", - "dependencies": { - "path-exists": "^2.0.0", - "pinkie-promise": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/get-caller-file": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", - "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", - "dev": true, - "license": "ISC" - }, - "node_modules/svg2png/node_modules/is-fullwidth-code-point": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", - "integrity": "sha512-1pqUqRjkhPJ9miNq9SwMfdvi6lBJcd6eFxvfaivQhaH3SgisfiuudvFntdKOmxuee/77l+FPjKrQjWvmPjWrRw==", - "dev": true, - "license": "MIT", - "dependencies": { - "number-is-nan": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/load-json-file": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", - "integrity": "sha512-cy7ZdNRXdablkXYNI049pthVeXFurRyb9+hA/dZzerZ0pGTx42z+y+ssxBaVV2l70t1muq5IdKhn4UtcoGUY9A==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.1.2", - "parse-json": "^2.2.0", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0", - "strip-bom": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/path-exists": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", - "integrity": "sha512-yTltuKuhtNeFJKa1PiRzfLAU5182q1y4Eb4XCJ3PBqyzEDkAZRzBrKKBct682ls9reBVHf9udYLN5Nd+K1B9BQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "pinkie-promise": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/path-type": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", - "integrity": "sha512-S4eENJz1pkiQn9Znv33Q+deTOKmbl+jj1Fl+qiP/vYezj+S8x+J3Uo0ISrx/QoEvIlOaDWJhPaRd1flJ9HXZqg==", - "dev": true, - "license": "MIT", - "dependencies": { - "graceful-fs": "^4.1.2", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/read-pkg": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", - "integrity": "sha512-7BGwRHqt4s/uVbuyoeejRn4YmFnYZiFl4AuaeXHlgZf3sONF0SOGlxs2Pw8g6hCKupo08RafIO5YXFNOKTfwsQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "load-json-file": "^1.0.0", - "normalize-package-data": "^2.3.2", - "path-type": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/read-pkg-up": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", - "integrity": "sha512-WD9MTlNtI55IwYUS27iHh9tK3YoIVhxis8yKhLpTqWtml739uXc9NWTpxoHkfZf3+DkCCsXox94/VWZniuZm6A==", - "dev": true, - "license": "MIT", - "dependencies": { - "find-up": "^1.0.0", - "read-pkg": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/require-main-filename": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", - "integrity": "sha512-IqSUtOVP4ksd1C/ej5zeEh/BIP2ajqpn8c5x+q99gvcIG/Qf0cud5raVnE/Dwd0ua9TXYDoDc0RE5hBSdz22Ug==", - "dev": true, - "license": "ISC" - }, - "node_modules/svg2png/node_modules/string-width": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", - "integrity": "sha512-0XsVpQLnVCXHJfyEs8tC0zpTVIr5PKKsQtkT29IwupnPTjtPmQ3xT/4yCREF9hYkV/3M3kzcUTSAZT6a6h81tw==", - "dev": true, - "license": "MIT", - "dependencies": { - "code-point-at": "^1.0.0", - "is-fullwidth-code-point": "^1.0.0", - "strip-ansi": "^3.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/strip-ansi": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-regex": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/strip-bom": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", - "integrity": "sha512-kwrX1y7czp1E69n2ajbG65mIo9dqvJ+8aBQXOGVxqwvNbsXdFM6Lq37dLAY3mknUwru8CfcCbfOLL/gMo+fi3g==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-utf8": "^0.2.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/which-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", - "integrity": "sha512-F6+WgncZi/mJDrammbTuHe1q0R5hOXv/mBaiNA2TCNT/LTHusX0V+CJnj9XT8ki5ln2UZyyddDgHfCzyrOH7MQ==", - "dev": true, - "license": "ISC" - }, - "node_modules/svg2png/node_modules/wrap-ansi": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", - "integrity": "sha512-vAaEaDM946gbNpH5pLVNR+vX2ht6n0Bt3GXwVB1AuAqZosOvHNF3P7wDnh8KLkSqgUh0uh77le7Owgoz+Z9XBw==", - "dev": true, - "license": "MIT", - "dependencies": { - "string-width": "^1.0.1", - "strip-ansi": "^3.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/svg2png/node_modules/y18n": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.2.tgz", - "integrity": "sha512-uGZHXkHnhF0XeeAPgnKfPv1bgKAYyVvmNL1xlKsPYZPaIHxGti2hHqvOCQv71XMsLxu1QjergkqogUnms5D3YQ==", - "dev": true, - "license": "ISC" - }, - "node_modules/svg2png/node_modules/yargs": { - "version": "6.6.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-6.6.0.tgz", - "integrity": "sha512-6/QWTdisjnu5UHUzQGst+UOEuEVwIzFVGBjq3jMTFNs5WJQsH/X6nMURSaScIdF5txylr1Ao9bvbWiKi2yXbwA==", - "dev": true, - "license": "MIT", - "dependencies": { - "camelcase": "^3.0.0", - "cliui": "^3.2.0", - "decamelize": "^1.1.1", - "get-caller-file": "^1.0.1", - "os-locale": "^1.4.0", - "read-pkg-up": "^1.0.1", - "require-directory": "^2.1.1", - "require-main-filename": "^1.0.1", - "set-blocking": "^2.0.0", - "string-width": "^1.0.2", - "which-module": "^1.0.0", - "y18n": "^3.2.1", - "yargs-parser": "^4.2.0" - } - }, - "node_modules/svg2png/node_modules/yargs-parser": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-4.2.1.tgz", - "integrity": "sha512-+QQWqC2xeL0N5/TE+TY6OGEqyNRM+g2/r712PDNYgiCdXYCApXf1vzfmDSLBxfGRwV+moTq/V8FnMI24JCm2Yg==", - "dev": true, - "license": "ISC", - "dependencies": { - "camelcase": "^3.0.0" - } - }, "node_modules/tailwind-merge": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/tailwind-merge/-/tailwind-merge-3.3.1.tgz", @@ -15346,9 +14993,9 @@ } }, "node_modules/tailwindcss": { - "version": "4.1.13", - "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.1.13.tgz", - "integrity": "sha512-i+zidfmTqtwquj4hMEwdjshYYgMbOrPzb9a0M3ZgNa0JMoZeFC6bxZvO8yr8ozS6ix2SDz0+mvryPeBs2TFE+w==", + "version": "4.1.14", + "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.1.14.tgz", + "integrity": "sha512-b7pCxjGO98LnxVkKjaZSDeNuljC4ueKUddjENJOADtubtdo8llTaJy7HwBMeLNSSo2N5QIAgklslK1+Ir8r6CA==", "license": "MIT" }, "node_modules/tapable": { @@ -15365,16 +15012,15 @@ } }, "node_modules/tar": { - "version": "7.4.3", - "resolved": "https://registry.npmjs.org/tar/-/tar-7.4.3.tgz", - "integrity": "sha512-5S7Va8hKfV7W5U6g3aYxXmlPoZVAwUMy9AOKyF2fVuZa2UD3qZjg578OrLRt8PcNN1PleVaL/5/yYATNL0ICUw==", + "version": "7.5.1", + "resolved": "https://registry.npmjs.org/tar/-/tar-7.5.1.tgz", + "integrity": "sha512-nlGpxf+hv0v7GkWBK2V9spgactGOp0qvfWRxUMjqHyzrt3SgwE48DIv/FhqPHJYLHpgW1opq3nERbz5Anq7n1g==", "license": "ISC", "dependencies": { "@isaacs/fs-minipass": "^4.0.0", "chownr": "^3.0.0", "minipass": "^7.1.2", - "minizlib": "^3.0.1", - "mkdirp": "^3.0.1", + "minizlib": "^3.1.0", "yallist": "^5.0.0" }, "engines": { @@ -15382,9 +15028,9 @@ } }, "node_modules/tar-fs": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.3.tgz", - "integrity": "sha512-090nwYJDmlhwFwEW3QQl+vaNnxsO2yVsd45eTKRBzSzu+hlb1w2K9inVq5b0ngXuLVqQ4ApvsUHHnu/zQNkWAg==", + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.4.tgz", + "integrity": "sha512-mDAjwmZdh7LTT6pNleZ05Yt65HC3E+NiQzl672vQG38jIrehtJk/J3mNwIg+vShQPcLF/LV7CMnDW6vjj6sfYQ==", "license": "MIT", "dependencies": { "chownr": "^1.1.1", @@ -15415,19 +15061,57 @@ "node": ">=6" } }, - "node_modules/tar/node_modules/mkdirp": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-3.0.1.tgz", - "integrity": "sha512-+NsyUUAZDmo6YVHzL/stxSu3t9YS1iljliy3BSDrXJ/dkn1KYdmtZODGGjLcc9XLgVVpH4KshHB8XmZgMhaBXg==", + "node_modules/tar-stream/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", "license": "MIT", - "bin": { - "mkdirp": "dist/cjs/src/bin.js" + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" }, "engines": { - "node": ">=10" + "node": ">= 6" + } + }, + "node_modules/tar/node_modules/chownr": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-3.0.0.tgz", + "integrity": "sha512-+IxzY9BZOQd/XuYPRmrvEVjF/nqj5kgT4kEq7VofrDoM1MxoRjEWkrCC3EtLi59TVawxTAn+orJwFQcrqEN1+g==", + "license": "BlueOak-1.0.0", + "engines": { + "node": ">=18" + } + }, + "node_modules/tar/node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "license": "ISC", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/tar/node_modules/minizlib": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-3.1.0.tgz", + "integrity": "sha512-KZxYo1BUkWD2TVFLr0MQoM8vUUigWD3LlD83a/75BqC+4qE0Hb1Vo5v1FgcfaNXvfXzr+5EhQ6ing/CaBijTlw==", + "license": "MIT", + "dependencies": { + "minipass": "^7.1.2" }, - "funding": { - "url": "https://github.com/sponsors/isaacs" + "engines": { + "node": ">= 18" + } + }, + "node_modules/tar/node_modules/yallist": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-5.0.0.tgz", + "integrity": "sha512-YgvUTfwqyc7UXVMrB+SImsVYSmTS8X/tSrtdNZMImM+n7+QTriRXyXim0mBrTXNeqzVF0KWGgHPeiyViFFrNDw==", + "license": "BlueOak-1.0.0", + "engines": { + "node": ">=18" } }, "node_modules/temp": { @@ -15436,7 +15120,6 @@ "integrity": "sha512-yYrrsWnrXMcdsnu/7YMYAofM1ktpL5By7vZhf15CrXijWWrEYZks5AXBudalfSWJLlnen/QUJUB5aoB0kqZUGA==", "dev": true, "license": "MIT", - "peer": true, "dependencies": { "mkdirp": "^0.5.1", "rimraf": "~2.6.2" @@ -15494,6 +15177,19 @@ "node": ">= 10.0.0" } }, + "node_modules/temp/node_modules/mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "dev": true, + "license": "MIT", + "dependencies": { + "minimist": "^1.2.6" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, "node_modules/temp/node_modules/rimraf": { "version": "2.6.3", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", @@ -15501,7 +15197,6 @@ "deprecated": "Rimraf versions prior to v4 are no longer supported", "dev": true, "license": "ISC", - "peer": true, "dependencies": { "glob": "^7.1.3" }, @@ -15509,21 +15204,10 @@ "rimraf": "bin.js" } }, - "node_modules/throttleit": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/throttleit/-/throttleit-1.0.1.tgz", - "integrity": "sha512-vDZpf9Chs9mAdfY046mcPt8fg5QSZr37hEH4TXYBnDF+izxgrbRGUAAaBvIk/fJm9aOFCGFd1EsNg5AZCbnQCQ==", - "dev": true, - "license": "MIT", - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/timm": { - "version": "1.7.1", - "resolved": "https://registry.npmjs.org/timm/-/timm-1.7.1.tgz", - "integrity": "sha512-IjZc9KIotudix8bMaBW6QvMuq64BrJWFs1+4V0lXwWGQZwH+LnX87doAYhem4caOEusRP9/g6jVDQmZ8XOk1nw==", - "dev": true, + "node_modules/tiktok-video-element": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/tiktok-video-element/-/tiktok-video-element-0.1.1.tgz", + "integrity": "sha512-BaiVzvNz2UXDKTdSrXzrNf4q6Ecc+/utYUh7zdEu2jzYcJVDoqYbVfUl0bCfMoOeeAqg28vD/yN63Y3E9jOrlA==", "license": "MIT" }, "node_modules/tiny-async-pool": { @@ -15546,11 +15230,10 @@ "semver": "bin/semver" } }, - "node_modules/tinycolor2": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.6.0.tgz", - "integrity": "sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw==", - "dev": true, + "node_modules/tiny-invariant": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/tiny-invariant/-/tiny-invariant-1.3.3.tgz", + "integrity": "sha512-+FbBPE1o9QAYvviau/qC5SE3caw21q3xkvWKBtja5vgqOWIHHJ3ioaq1VPfn/Szqctz2bU/oYeKd9/z5BL+PVg==", "license": "MIT" }, "node_modules/tinyglobby": { @@ -15591,6 +15274,7 @@ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", "license": "MIT", + "peer": true, "engines": { "node": ">=12" }, @@ -15640,44 +15324,6 @@ "node": ">=0.6" } }, - "node_modules/token-types": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/token-types/-/token-types-4.2.1.tgz", - "integrity": "sha512-6udB24Q737UD/SDsKAHI9FCRP7Bqc9D/MQUV02ORQg5iskjtLJlZJNdN4kKtcdtwCeWIwIHDGaUsTsCCAa8sFQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@tokenizer/token": "^0.3.0", - "ieee754": "^1.2.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/Borewit" - } - }, - "node_modules/tough-cookie": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", - "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", - "dev": true, - "license": "BSD-3-Clause", - "dependencies": { - "psl": "^1.1.28", - "punycode": "^2.1.1" - }, - "engines": { - "node": ">=0.8" - } - }, - "node_modules/tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", - "license": "MIT" - }, "node_modules/tree-kill": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", @@ -15688,27 +15334,24 @@ "tree-kill": "cli.js" } }, - "node_modules/trim-repeated": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz", - "integrity": "sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==", - "dev": true, + "node_modules/trim-lines": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/trim-lines/-/trim-lines-3.0.1.tgz", + "integrity": "sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg==", "license": "MIT", - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/trim-repeated/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, + "node_modules/trough": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/trough/-/trough-2.2.0.tgz", + "integrity": "sha512-tmMpK00BjZiUyVyvrBK7knerNgmgvcV/KLVyuma/SC+TQN167GrMRciANTz09+k3zW8L8t60jWO1GpfkZdjTaw==", "license": "MIT", - "engines": { - "node": ">=0.8.0" + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" } }, "node_modules/truncate-utf8-bytes": { @@ -15734,50 +15377,6 @@ "typescript": ">=4.8.4" } }, - "node_modules/ts-node": { - "version": "10.9.2", - "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", - "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@cspotcode/source-map-support": "^0.8.0", - "@tsconfig/node10": "^1.0.7", - "@tsconfig/node12": "^1.0.7", - "@tsconfig/node14": "^1.0.0", - "@tsconfig/node16": "^1.0.2", - "acorn": "^8.4.1", - "acorn-walk": "^8.1.1", - "arg": "^4.1.0", - "create-require": "^1.1.0", - "diff": "^4.0.1", - "make-error": "^1.1.1", - "v8-compile-cache-lib": "^3.0.1", - "yn": "3.1.1" - }, - "bin": { - "ts-node": "dist/bin.js", - "ts-node-cwd": "dist/bin-cwd.js", - "ts-node-esm": "dist/bin-esm.js", - "ts-node-script": "dist/bin-script.js", - "ts-node-transpile-only": "dist/bin-transpile.js", - "ts-script": "dist/bin-script-deprecated.js" - }, - "peerDependencies": { - "@swc/core": ">=1.2.50", - "@swc/wasm": ">=1.2.50", - "@types/node": "*", - "typescript": ">=2.7" - }, - "peerDependenciesMeta": { - "@swc/core": { - "optional": true - }, - "@swc/wasm": { - "optional": true - } - } - }, "node_modules/tslib": { "version": "2.8.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", @@ -15796,22 +15395,18 @@ "node": "*" } }, - "node_modules/tw-animate-css": { - "version": "1.3.8", - "resolved": "https://registry.npmjs.org/tw-animate-css/-/tw-animate-css-1.3.8.tgz", - "integrity": "sha512-Qrk3PZ7l7wUcGYhwZloqfkWCmaXZAoqjkdbIDvzfGshwGtexa/DAs9koXxIkrpEasyevandomzCBAV1Yyop5rw==", - "dev": true, - "license": "MIT", - "funding": { - "url": "https://github.com/sponsors/Wombosvideo" - } - }, "node_modules/tweetnacl": { "version": "0.14.5", "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", "integrity": "sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA==", "license": "Unlicense" }, + "node_modules/twitch-video-element": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/twitch-video-element/-/twitch-video-element-0.1.4.tgz", + "integrity": "sha512-SDpZ4f7sZmwHF6XG5PF0KWuP18pH/kNG04MhTcpqJby7Lk/D3TS/lCYd+RSg0rIAAVi1LDgSIo1yJs9kmHlhgw==", + "license": "MIT" + }, "node_modules/type-check": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", @@ -15840,14 +15435,34 @@ } }, "node_modules/type-is": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/type-is/-/type-is-2.0.1.tgz", - "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", "license": "MIT", "dependencies": { - "content-type": "^1.0.5", - "media-typer": "^1.1.0", - "mime-types": "^3.0.0" + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/type-is/node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/type-is/node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" }, "engines": { "node": ">= 0.6" @@ -15860,11 +15475,12 @@ "license": "MIT" }, "node_modules/typescript": { - "version": "5.9.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.9.2.tgz", - "integrity": "sha512-CWBzXQrc/qOkhidw1OzBTQuYRbfyxDXJMVJ1XNwUHGROVmuaeiEm3OslpZ1RV96d7SKKjZKrSJu3+t/xlw3R9A==", + "version": "5.9.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.9.3.tgz", + "integrity": "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw==", "devOptional": true, "license": "Apache-2.0", + "peer": true, "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" @@ -15874,16 +15490,16 @@ } }, "node_modules/typescript-eslint": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.43.0.tgz", - "integrity": "sha512-FyRGJKUGvcFekRRcBKFBlAhnp4Ng8rhe8tuvvkR9OiU0gfd4vyvTRQHEckO6VDlH57jbeUQem2IpqPq9kLJH+w==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.45.0.tgz", + "integrity": "sha512-qzDmZw/Z5beNLUrXfd0HIW6MzIaAV5WNDxmMs9/3ojGOpYavofgNAAD/nC6tGV2PczIi0iw8vot2eAe/sBn7zg==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/eslint-plugin": "8.43.0", - "@typescript-eslint/parser": "8.43.0", - "@typescript-eslint/typescript-estree": "8.43.0", - "@typescript-eslint/utils": "8.43.0" + "@typescript-eslint/eslint-plugin": "8.45.0", + "@typescript-eslint/parser": "8.45.0", + "@typescript-eslint/typescript-estree": "8.45.0", + "@typescript-eslint/utils": "8.45.0" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -15897,12 +15513,57 @@ "typescript": ">=4.8.4 <6.0.0" } }, + "node_modules/ua-parser-js": { + "version": "1.0.41", + "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-1.0.41.tgz", + "integrity": "sha512-LbBDqdIC5s8iROCUjMbW1f5dJQTEFB1+KO9ogbvlb3nm9n4YHa5p4KTvFPWvh2Hs8gZMBuiB1/8+pdfe/tDPug==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/ua-parser-js" + }, + { + "type": "paypal", + "url": "https://paypal.me/faisalman" + }, + { + "type": "github", + "url": "https://github.com/sponsors/faisalman" + } + ], + "license": "MIT", + "bin": { + "ua-parser-js": "script/cli.js" + }, + "engines": { + "node": "*" + } + }, "node_modules/undici-types": { - "version": "7.10.0", - "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.10.0.tgz", - "integrity": "sha512-t5Fy/nfn+14LuOc2KNYg75vZqClpAiqscVvMygNnlsHBFpSXdJaYtXMcdNLpl/Qvc3P2cB3s6lOV51nqsFq4ag==", + "version": "7.13.0", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.13.0.tgz", + "integrity": "sha512-Ov2Rr9Sx+fRgagJ5AX0qvItZG/JKKoBRAVITs1zk7IqZGTJUwgUr7qoYBpWwakpWilTZFM98rG/AFRocu10iIQ==", "license": "MIT" }, + "node_modules/unified": { + "version": "11.0.5", + "resolved": "https://registry.npmjs.org/unified/-/unified-11.0.5.tgz", + "integrity": "sha512-xKvGhPWw3k84Qjh8bI3ZeJjqnyadK+GEFtazSfZv/rKeTkTjOJho6mFqh2SM96iIcZokxiOpg78GazTSg8+KHA==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0", + "bail": "^2.0.0", + "devlop": "^1.0.0", + "extend": "^3.0.0", + "is-plain-obj": "^4.0.0", + "trough": "^2.0.0", + "vfile": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/unique-filename": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-2.0.1.tgz", @@ -15929,6 +15590,74 @@ "node": "^12.13.0 || ^14.15.0 || >=16.0.0" } }, + "node_modules/unist-util-is": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-6.0.0.tgz", + "integrity": "sha512-2qCTHimwdxLfz+YzdGfkqNlH0tLi9xjTnHddPmJwtIG9MGsdbutfTc4P+haPD7l7Cjxf/WZj+we5qfVPvvxfYw==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-position": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-5.0.0.tgz", + "integrity": "sha512-fucsC7HjXvkB5R3kTCO7kUjRdrS0BJt3M/FPxmHMBOm8JQi2BsHAHFsy27E0EolP8rp0NzXsJ+jNPyDWvOJZPA==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-stringify-position": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-4.0.0.tgz", + "integrity": "sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-visit": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-5.0.0.tgz", + "integrity": "sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0", + "unist-util-is": "^6.0.0", + "unist-util-visit-parents": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-visit-parents": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-6.0.1.tgz", + "integrity": "sha512-L/PqWzfTP9lzzEa6CKs0k2nARxTdZduw3zyh8d2NVBnsyvHjSX4TWse388YrrQKbvI8w20fGjGlhgT96WwKykw==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0", + "unist-util-is": "^6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/universalify": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", @@ -15948,37 +15677,6 @@ "node": ">= 0.8" } }, - "node_modules/update-browserslist-db": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz", - "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "MIT", - "dependencies": { - "escalade": "^3.2.0", - "picocolors": "^1.1.1" - }, - "bin": { - "update-browserslist-db": "cli.js" - }, - "peerDependencies": { - "browserslist": ">= 4.21.0" - } - }, "node_modules/uri-js": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", @@ -16032,15 +15730,6 @@ } } }, - "node_modules/use-sync-external-store": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.5.0.tgz", - "integrity": "sha512-Rb46I4cGGVBmjamjphe8L/UnvJD+uPPtTkNvX5mZgqdbavhI4EbgIWJiIHXJ8bc/i9EQGPRh4DwEURJ552Do0A==", - "license": "MIT", - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" - } - }, "node_modules/utf8-byte-length": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/utf8-byte-length/-/utf8-byte-length-1.0.5.tgz", @@ -16048,59 +15737,12 @@ "dev": true, "license": "(WTFPL OR MIT)" }, - "node_modules/utif": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/utif/-/utif-2.0.1.tgz", - "integrity": "sha512-Z/S1fNKCicQTf375lIP9G8Sa1H/phcysstNrrSdZKj1f9g58J4NMgb5IgiEZN9/nLMPDwF0W7hdOe9Qq2IYoLg==", - "dev": true, - "license": "MIT", - "dependencies": { - "pako": "^1.0.5" - } - }, "node_modules/util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", "license": "MIT" }, - "node_modules/uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "dev": true, - "license": "MIT", - "bin": { - "uuid": "dist/bin/uuid" - } - }, - "node_modules/v8-compile-cache-lib": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", - "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", - "dev": true, - "license": "MIT" - }, - "node_modules/validate-npm-package-license": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", - "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "spdx-correct": "^3.0.0", - "spdx-expression-parse": "^3.0.0" - } - }, - "node_modules/validator": { - "version": "13.15.15", - "resolved": "https://registry.npmjs.org/validator/-/validator-13.15.15.tgz", - "integrity": "sha512-BgWVbCI72aIQy937xbawcs+hrVaN/CZ2UwutgaJ36hGqRrLNM+f5LUT/YPRbo8IV/ASeFzXszezV+y2+rq3l8A==", - "license": "MIT", - "engines": { - "node": ">= 0.10" - } - }, "node_modules/vary": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", @@ -16126,11 +15768,57 @@ "node": ">=0.6.0" } }, - "node_modules/vite": { - "version": "7.1.5", - "resolved": "https://registry.npmjs.org/vite/-/vite-7.1.5.tgz", - "integrity": "sha512-4cKBO9wR75r0BeIWWWId9XK9Lj6La5X846Zw9dFfzMRw38IlTk2iCcUt6hsyiDRcPidc55ZParFYDXi0nXOeLQ==", + "node_modules/verror/node_modules/core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ==", + "dev": true, "license": "MIT", + "optional": true + }, + "node_modules/vfile": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/vfile/-/vfile-6.0.3.tgz", + "integrity": "sha512-KzIbH/9tXat2u30jf+smMwFCsno4wHVdNmzFyL+T/L3UGqqk6JKfVqOFOZEpZSHADH1k40ab6NUIXZq422ov3Q==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0", + "vfile-message": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/vfile-message": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-4.0.3.tgz", + "integrity": "sha512-QTHzsGd1EhbZs4AsQ20JX1rC3cOlt/IWJruk893DfLRr57lcnOeMaWG4K0JrRta4mIJZKth2Au3mM3u03/JWKw==", + "license": "MIT", + "dependencies": { + "@types/unist": "^3.0.0", + "unist-util-stringify-position": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/vimeo-video-element": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/vimeo-video-element/-/vimeo-video-element-1.6.0.tgz", + "integrity": "sha512-Vs+WWvd6ph6FtY+DqrVO5OHUUS02An87QydUcCUtAsIiXnYhZl0yiDC0XxWiFluo+S6keG38i4xCaQfS1LgeSg==", + "license": "MIT", + "dependencies": { + "@vimeo/player": "2.29.0" + } + }, + "node_modules/vite": { + "version": "7.1.7", + "resolved": "https://registry.npmjs.org/vite/-/vite-7.1.7.tgz", + "integrity": "sha512-VbA8ScMvAISJNJVbRDTJdCwqQoAareR/wutevKanhR2/1EkoXVZVkkORaYm/tNVCjP/UDTKtcw3bAkwOUdedmA==", + "license": "MIT", + "peer": true, "dependencies": { "esbuild": "^0.25.0", "fdir": "^6.5.0", @@ -16222,6 +15910,7 @@ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", "license": "MIT", + "peer": true, "engines": { "node": ">=12" }, @@ -16245,14 +15934,13 @@ "license": "MIT" }, "node_modules/wait-on": { - "version": "8.0.4", - "resolved": "https://registry.npmjs.org/wait-on/-/wait-on-8.0.4.tgz", - "integrity": "sha512-8f9LugAGo4PSc0aLbpKVCVtzayd36sSCp4WLpVngkYq6PK87H79zt77/tlCU6eKCLqR46iFvcl0PU5f+DmtkwA==", - "dev": true, + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/wait-on/-/wait-on-9.0.1.tgz", + "integrity": "sha512-noeCAI+XbqWMXY23sKril0BSURhuLYarkVXwJv1uUWwoojZJE7pmX3vJ7kh7SZaNgPGzfsCSQIZM/AGvu0Q9pA==", "license": "MIT", "dependencies": { - "axios": "^1.11.0", - "joi": "^17.13.3", + "axios": "^1.12.2", + "joi": "^18.0.1", "lodash": "^4.17.21", "minimist": "^1.2.8", "rxjs": "^7.8.2" @@ -16261,7 +15949,16 @@ "wait-on": "bin/wait-on" }, "engines": { - "node": ">=12.0.0" + "node": ">=20.0.0" + } + }, + "node_modules/warning": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/warning/-/warning-4.0.3.tgz", + "integrity": "sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.0.0" } }, "node_modules/wcwidth": { @@ -16274,6 +15971,15 @@ "defaults": "^1.0.3" } }, + "node_modules/weakmap-polyfill": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/weakmap-polyfill/-/weakmap-polyfill-2.0.4.tgz", + "integrity": "sha512-ZzxBf288iALJseijWelmECm/1x7ZwQn3sMYIkDr2VvZp7r6SEKuT8D0O9Wiq6L9Nl5mazrOMcmiZE/2NCenaxw==", + "license": "MIT", + "engines": { + "node": ">=8.10.0" + } + }, "node_modules/web-streams-polyfill": { "version": "3.3.3", "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.3.3.tgz", @@ -16283,22 +15989,6 @@ "node": ">= 8" } }, - "node_modules/webidl-conversions": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", - "license": "BSD-2-Clause" - }, - "node_modules/whatwg-url": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", - "license": "MIT", - "dependencies": { - "tr46": "~0.0.3", - "webidl-conversions": "^3.0.0" - } - }, "node_modules/which": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", @@ -16321,6 +16011,15 @@ "integrity": "sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==", "license": "ISC" }, + "node_modules/wistia-video-element": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/wistia-video-element/-/wistia-video-element-1.3.4.tgz", + "integrity": "sha512-2l22oaQe4jUfi3yvsh2m2oCEgvbqTzaSYx6aJnZAvV5hlMUJlyZheFUnaj0JU2wGlHdVGV7xNY+5KpKu+ruLYA==", + "license": "MIT", + "dependencies": { + "super-media-element": "~1.4.2" + } + }, "node_modules/word-wrap": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", @@ -16332,9 +16031,10 @@ } }, "node_modules/wrap-ansi": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", - "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, "license": "MIT", "dependencies": { "ansi-styles": "^4.0.0", @@ -16342,7 +16042,10 @@ "strip-ansi": "^6.0.0" }, "engines": { - "node": ">=8" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" } }, "node_modules/wrap-ansi-cjs": { @@ -16391,50 +16094,6 @@ } } }, - "node_modules/xhr": { - "version": "2.6.0", - "resolved": "https://registry.npmjs.org/xhr/-/xhr-2.6.0.tgz", - "integrity": "sha512-/eCGLb5rxjx5e3mF1A7s+pLlR6CGyqWN91fv1JgER5mVWg1MZmlhBvy9kjcsOdRk8RrIujotWyJamfyrp+WIcA==", - "dev": true, - "license": "MIT", - "dependencies": { - "global": "~4.4.0", - "is-function": "^1.0.1", - "parse-headers": "^2.0.0", - "xtend": "^4.0.0" - } - }, - "node_modules/xml-parse-from-string": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/xml-parse-from-string/-/xml-parse-from-string-1.0.1.tgz", - "integrity": "sha512-ErcKwJTF54uRzzNMXq2X5sMIy88zJvfN2DmdoQvy7PAFJ+tPRU6ydWuOKNMyfmOjdyBQTFREi60s0Y0SyI0G0g==", - "dev": true, - "license": "MIT" - }, - "node_modules/xml2js": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.5.0.tgz", - "integrity": "sha512-drPFnkQJik/O+uPKpqSgr22mpuFHqKdbS835iAQrUC73L2F5WkboIRd63ai/2Yg6I1jzifPFKH2NTK+cfglkIA==", - "dev": true, - "license": "MIT", - "dependencies": { - "sax": ">=0.6.0", - "xmlbuilder": "~11.0.0" - }, - "engines": { - "node": ">=4.0.0" - } - }, - "node_modules/xml2js/node_modules/xmlbuilder": { - "version": "11.0.1", - "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", - "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4.0" - } - }, "node_modules/xmlbuilder": { "version": "15.1.1", "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-15.1.1.tgz", @@ -16455,105 +16114,49 @@ } }, "node_modules/y18n": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", - "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", - "license": "ISC" - }, - "node_modules/yallist": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-5.0.0.tgz", - "integrity": "sha512-YgvUTfwqyc7UXVMrB+SImsVYSmTS8X/tSrtdNZMImM+n7+QTriRXyXim0mBrTXNeqzVF0KWGgHPeiyViFFrNDw==", - "license": "BlueOak-1.0.0", + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "license": "ISC", "engines": { - "node": ">=18" + "node": ">=10" } }, + "node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true, + "license": "ISC" + }, "node_modules/yargs": { - "version": "15.4.1", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", - "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", + "version": "17.7.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", + "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", + "dev": true, "license": "MIT", "dependencies": { - "cliui": "^6.0.0", - "decamelize": "^1.2.0", - "find-up": "^4.1.0", - "get-caller-file": "^2.0.1", + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", "require-directory": "^2.1.1", - "require-main-filename": "^2.0.0", - "set-blocking": "^2.0.0", - "string-width": "^4.2.0", - "which-module": "^2.0.0", - "y18n": "^4.0.0", - "yargs-parser": "^18.1.2" + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" }, "engines": { - "node": ">=8" + "node": ">=12" } }, "node_modules/yargs-parser": { - "version": "18.1.3", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", - "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", + "dev": true, "license": "ISC", - "dependencies": { - "camelcase": "^5.0.0", - "decamelize": "^1.2.0" - }, "engines": { - "node": ">=6" - } - }, - "node_modules/yargs/node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "license": "MIT", - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/yargs/node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "license": "MIT", - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/yargs/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "license": "MIT", - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/yargs/node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "license": "MIT", - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" + "node": ">=12" } }, "node_modules/yauzl": { @@ -16567,16 +16170,6 @@ "fd-slicer": "~1.1.0" } }, - "node_modules/yn": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", - "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, "node_modules/yocto-queue": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", @@ -16590,14 +16183,30 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/youtube-video-element": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/youtube-video-element/-/youtube-video-element-1.6.2.tgz", + "integrity": "sha512-YHDIOAqgRpfl1Ois9HcB8UFtWOxK8KJrV5TXpImj4BKYP1rWT04f/fMM9tQ9SYZlBKukT7NR+9wcI3UpB5BMDQ==", + "license": "MIT" + }, "node_modules/zod": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/zod/-/zod-4.1.5.tgz", - "integrity": "sha512-rcUUZqlLJgBC33IT3PNMgsCq6TzLQEG/Ei/KTCU0PedSWRMAXoOUN+4t/0H+Q8bdnLPdqUYnvboJT0bn/229qg==", + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/zod/-/zod-4.1.11.tgz", + "integrity": "sha512-WPsqwxITS2tzx1bzhIKsEs19ABD5vmCVa4xBo2tq/SrV4RNZtfws1EnCWQXM6yh8bD08a1idvkB5MZSBiZsjwg==", "license": "MIT", "funding": { "url": "https://github.com/sponsors/colinhacks" } + }, + "node_modules/zwitch": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/zwitch/-/zwitch-2.0.4.tgz", + "integrity": "sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } } } } diff --git a/package.json b/package.json index 78bd621d..1b587c96 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "termix", "private": true, - "version": "1.6.0", + "version": "1.7.0", "description": "A web-based server management platform with SSH terminal, tunneling, and file editing capabilities", "author": "Karmaa", "main": "electron/main.cjs", @@ -12,20 +12,24 @@ "build": "vite build && tsc -p tsconfig.node.json", "build:backend": "tsc -p tsconfig.node.json", "dev:backend": "tsc -p tsconfig.node.json && node ./dist/backend/backend/starter.js", - "lint": "eslint .", "preview": "vite preview", - "electron": "electron .", "electron:dev": "concurrently \"npm run dev\" \"wait-on http://localhost:5173 && electron .\"", "build:win-portable": "npm run build && electron-builder --win --dir", "build:win-installer": "npm run build && electron-builder --win --publish=never", - "build:linux-portable": "npm run build && electron-builder --linux --dir" + "build:linux-portable": "npm run build && electron-builder --linux --dir", + "test:encryption": "tsc -p tsconfig.node.json && node ./dist/backend/backend/utils/encryption-test.js", + "migrate:encryption": "tsc -p tsconfig.node.json && node ./dist/backend/backend/utils/encryption-migration.js" }, "dependencies": { + "@codemirror/autocomplete": "^6.18.7", + "@codemirror/commands": "^6.3.3", + "@codemirror/search": "^6.5.11", + "@codemirror/theme-one-dark": "^6.1.2", + "@codemirror/view": "^6.23.1", "@hookform/resolvers": "^5.1.1", + "@monaco-editor/react": "^4.7.0", "@radix-ui/react-accordion": "^1.2.11", - "@radix-ui/react-avatar": "^1.1.10", "@radix-ui/react-checkbox": "^1.3.2", - "@radix-ui/react-collapsible": "^1.1.11", "@radix-ui/react-dialog": "^1.1.15", "@radix-ui/react-dropdown-menu": "^2.1.15", "@radix-ui/react-label": "^2.1.7", @@ -34,30 +38,28 @@ "@radix-ui/react-scroll-area": "^1.2.9", "@radix-ui/react-select": "^2.2.5", "@radix-ui/react-separator": "^1.1.7", - "@radix-ui/react-slider": "^1.3.5", "@radix-ui/react-slot": "^1.2.3", "@radix-ui/react-switch": "^1.2.5", "@radix-ui/react-tabs": "^1.1.12", "@radix-ui/react-tooltip": "^1.2.8", "@tailwindcss/vite": "^4.1.11", "@types/bcryptjs": "^2.4.6", + "@types/cookie-parser": "^1.4.9", + "@types/jszip": "^3.4.0", "@types/multer": "^2.0.0", "@types/qrcode": "^1.5.5", "@types/speakeasy": "^2.0.10", - "@uiw/codemirror-extensions-hyper-link": "^4.24.1", "@uiw/codemirror-extensions-langs": "^4.24.1", - "@uiw/codemirror-themes": "^4.24.1", "@uiw/react-codemirror": "^4.24.1", - "@xterm/addon-attach": "^0.11.0", "@xterm/addon-clipboard": "^0.1.0", "@xterm/addon-fit": "^0.10.0", - "@xterm/addon-search": "^0.15.0", "@xterm/addon-unicode11": "^0.8.0", "@xterm/addon-web-links": "^0.11.0", "@xterm/xterm": "^5.5.0", "axios": "^1.10.0", "bcryptjs": "^3.0.2", "better-sqlite3": "^12.2.0", + "body-parser": "^1.20.2", "chalk": "^4.1.2", "class-variance-authority": "^0.7.1", "clsx": "^2.1.1", @@ -68,9 +70,9 @@ "express": "^5.1.0", "i18next": "^25.4.2", "i18next-browser-languagedetector": "^8.2.0", - "i18next-http-backend": "^3.0.2", "jose": "^5.2.3", "jsonwebtoken": "^9.0.2", + "jszip": "^3.10.1", "lucide-react": "^0.525.0", "multer": "^2.0.2", "nanoid": "^5.1.5", @@ -79,17 +81,24 @@ "qrcode": "^1.5.4", "react": "^19.1.0", "react-dom": "^19.1.0", + "react-h5-audio-player": "^3.10.1", "react-hook-form": "^7.60.0", "react-i18next": "^15.7.3", + "react-icons": "^5.5.0", + "react-markdown": "^10.1.0", + "react-pdf": "^10.1.0", + "react-photo-view": "^1.2.7", + "react-player": "^3.3.3", "react-resizable-panels": "^3.0.3", "react-simple-keyboard": "^3.8.120", + "react-syntax-highlighter": "^15.6.6", "react-xtermjs": "^1.0.10", + "remark-gfm": "^4.0.1", "sonner": "^2.0.7", "speakeasy": "^2.0.0", "ssh2": "^1.16.0", "tailwind-merge": "^3.3.1", - "tailwindcss": "^4.1.11", - "validator": "^13.15.15", + "wait-on": "^9.0.1", "ws": "^8.18.3", "zod": "^4.0.5" }, @@ -105,22 +114,16 @@ "@types/ssh2": "^1.15.5", "@types/ws": "^8.18.1", "@vitejs/plugin-react-swc": "^3.10.2", - "autoprefixer": "^10.4.21", "concurrently": "^9.2.1", "electron": "^38.0.0", "electron-builder": "^26.0.12", - "electron-icon-builder": "^2.0.1", - "electron-packager": "^17.1.2", "eslint": "^9.34.0", "eslint-plugin-react-hooks": "^5.2.0", "eslint-plugin-react-refresh": "^0.4.20", "globals": "^16.3.0", "prettier": "3.6.2", - "ts-node": "^10.9.2", - "tw-animate-css": "^1.3.5", "typescript": "~5.9.2", "typescript-eslint": "^8.40.0", - "vite": "^7.1.5", - "wait-on": "^8.0.4" + "vite": "^7.1.5" } } diff --git a/public/pdf.worker.min.js b/public/pdf.worker.min.js new file mode 100644 index 00000000..1cc642ee --- /dev/null +++ b/public/pdf.worker.min.js @@ -0,0 +1,58128 @@ +/** + * @licstart The following is the entire license notice for the + * JavaScript code in this page + * + * Copyright 2024 Mozilla Foundation + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * @licend The above is the entire license notice for the + * JavaScript code in this page + */ +/** + * pdfjsVersion = 5.3.93 + * pdfjsBuild = cbeef3233 + */ +const e = !( + "object" != typeof process || + process + "" != "[object process]" || + process.versions.nw || + (process.versions.electron && process.type && "browser" !== process.type) + ), + t = [0.001, 0, 0, 0.001, 0, 0], + a = 1.35, + r = 0.35, + i = 0.25925925925925924, + n = 1, + s = 2, + o = 4, + c = 8, + l = 16, + h = 64, + u = 128, + d = 256, + f = "pdfjs_internal_editor_", + g = 3, + p = 9, + m = 13, + b = 15, + y = 101, + w = { + PRINT: 4, + MODIFY_CONTENTS: 8, + COPY: 16, + MODIFY_ANNOTATIONS: 32, + FILL_INTERACTIVE_FORMS: 256, + COPY_FOR_ACCESSIBILITY: 512, + ASSEMBLE: 1024, + PRINT_HIGH_QUALITY: 2048, + }, + x = 0, + S = 4, + k = 1, + C = 2, + v = 3, + F = 1, + T = 2, + O = 3, + M = 4, + D = 5, + R = 6, + N = 7, + E = 8, + L = 9, + j = 10, + _ = 11, + U = 12, + X = 13, + q = 14, + H = 15, + W = 16, + z = 17, + $ = 20, + G = "Group", + V = "R", + K = 1, + J = 2, + Y = 4, + Z = 16, + Q = 32, + ee = 128, + te = 512, + ae = 1, + re = 2, + ie = 4096, + ne = 8192, + se = 32768, + oe = 65536, + ce = 131072, + le = 1048576, + he = 2097152, + ue = 8388608, + de = 16777216, + fe = 1, + ge = 2, + pe = 3, + me = 4, + be = 5, + ye = { + E: "Mouse Enter", + X: "Mouse Exit", + D: "Mouse Down", + U: "Mouse Up", + Fo: "Focus", + Bl: "Blur", + PO: "PageOpen", + PC: "PageClose", + PV: "PageVisible", + PI: "PageInvisible", + K: "Keystroke", + F: "Format", + V: "Validate", + C: "Calculate", + }, + we = { + WC: "WillClose", + WS: "WillSave", + DS: "DidSave", + WP: "WillPrint", + DP: "DidPrint", + }, + xe = { O: "PageOpen", C: "PageClose" }, + Se = 1, + ke = 5, + Ae = 1, + Ce = 2, + ve = 3, + Fe = 4, + Ie = 5, + Te = 6, + Oe = 7, + Me = 8, + De = 9, + Be = 10, + Re = 11, + Ne = 12, + Ee = 13, + Pe = 14, + Le = 15, + je = 16, + _e = 17, + Ue = 18, + Xe = 19, + qe = 20, + He = 21, + We = 22, + ze = 23, + $e = 24, + Ge = 25, + Ve = 26, + Ke = 27, + Je = 28, + Ye = 29, + Ze = 30, + Qe = 31, + et = 32, + tt = 33, + at = 34, + rt = 35, + it = 36, + nt = 37, + st = 38, + ot = 39, + ct = 40, + lt = 41, + ht = 42, + ut = 43, + dt = 44, + ft = 45, + gt = 46, + pt = 47, + mt = 48, + bt = 49, + yt = 50, + wt = 51, + xt = 52, + St = 53, + kt = 54, + At = 55, + Ct = 56, + vt = 57, + Ft = 58, + It = 59, + Tt = 60, + Ot = 61, + Mt = 62, + Dt = 63, + Bt = 64, + Rt = 65, + Nt = 66, + Et = 67, + Pt = 68, + Lt = 69, + jt = 70, + _t = 71, + Ut = 72, + Xt = 73, + qt = 74, + Ht = 75, + Wt = 76, + zt = 77, + $t = 80, + Gt = 81, + Vt = 83, + Kt = 84, + Jt = 85, + Yt = 86, + Zt = 87, + Qt = 88, + ea = 89, + ta = 90, + aa = 91, + ra = 92, + ia = 93, + na = 94, + sa = 0, + oa = 1, + ca = 2, + la = 3, + ha = 1, + ua = 2; +let da = Se; +function getVerbosityLevel() { + return da; +} +function info(e) { + da >= ke && console.log(`Info: ${e}`); +} +function warn(e) { + da >= Se && console.log(`Warning: ${e}`); +} +function unreachable(e) { + throw new Error(e); +} +function assert(e, t) { + e || unreachable(t); +} +function createValidAbsoluteUrl(e, t = null, a = null) { + if (!e) return null; + if (a && "string" == typeof e) { + if (a.addDefaultProtocol && e.startsWith("www.")) { + const t = e.match(/\./g); + t?.length >= 2 && (e = `http://${e}`); + } + if (a.tryConvertEncoding) + try { + e = stringToUTF8String(e); + } catch {} + } + const r = t ? URL.parse(e, t) : URL.parse(e); + return (function _isValidProtocol(e) { + switch (e?.protocol) { + case "http:": + case "https:": + case "ftp:": + case "mailto:": + case "tel:": + return !0; + default: + return !1; + } + })(r) + ? r + : null; +} +function shadow(e, t, a, r = !1) { + Object.defineProperty(e, t, { + value: a, + enumerable: !r, + configurable: !0, + writable: !1, + }); + return a; +} +const fa = (function BaseExceptionClosure() { + function BaseException(e, t) { + this.message = e; + this.name = t; + } + BaseException.prototype = new Error(); + BaseException.constructor = BaseException; + return BaseException; +})(); +class PasswordException extends fa { + constructor(e, t) { + super(e, "PasswordException"); + this.code = t; + } +} +class UnknownErrorException extends fa { + constructor(e, t) { + super(e, "UnknownErrorException"); + this.details = t; + } +} +class InvalidPDFException extends fa { + constructor(e) { + super(e, "InvalidPDFException"); + } +} +class ResponseException extends fa { + constructor(e, t, a) { + super(e, "ResponseException"); + this.status = t; + this.missing = a; + } +} +class FormatError extends fa { + constructor(e) { + super(e, "FormatError"); + } +} +class AbortException extends fa { + constructor(e) { + super(e, "AbortException"); + } +} +function bytesToString(e) { + ("object" == typeof e && void 0 !== e?.length) || + unreachable("Invalid argument for bytesToString"); + const t = e.length, + a = 8192; + if (t < a) return String.fromCharCode.apply(null, e); + const r = []; + for (let i = 0; i < t; i += a) { + const n = Math.min(i + a, t), + s = e.subarray(i, n); + r.push(String.fromCharCode.apply(null, s)); + } + return r.join(""); +} +function stringToBytes(e) { + "string" != typeof e && unreachable("Invalid argument for stringToBytes"); + const t = e.length, + a = new Uint8Array(t); + for (let r = 0; r < t; ++r) a[r] = 255 & e.charCodeAt(r); + return a; +} +function string32(e) { + return String.fromCharCode( + (e >> 24) & 255, + (e >> 16) & 255, + (e >> 8) & 255, + 255 & e, + ); +} +function objectSize(e) { + return Object.keys(e).length; +} +class FeatureTest { + static get isLittleEndian() { + return shadow( + this, + "isLittleEndian", + (function isLittleEndian() { + const e = new Uint8Array(4); + e[0] = 1; + return 1 === new Uint32Array(e.buffer, 0, 1)[0]; + })(), + ); + } + static get isEvalSupported() { + return shadow( + this, + "isEvalSupported", + (function isEvalSupported() { + try { + new Function(""); + return !0; + } catch { + return !1; + } + })(), + ); + } + static get isOffscreenCanvasSupported() { + return shadow( + this, + "isOffscreenCanvasSupported", + "undefined" != typeof OffscreenCanvas, + ); + } + static get isImageDecoderSupported() { + return shadow( + this, + "isImageDecoderSupported", + "undefined" != typeof ImageDecoder, + ); + } + static get platform() { + const { platform: e, userAgent: t } = navigator; + return shadow(this, "platform", { + isAndroid: t.includes("Android"), + isLinux: e.includes("Linux"), + isMac: e.includes("Mac"), + isWindows: e.includes("Win"), + isFirefox: t.includes("Firefox"), + }); + } + static get isCSSRoundSupported() { + return shadow( + this, + "isCSSRoundSupported", + globalThis.CSS?.supports?.("width: round(1.5px, 1px)"), + ); + } +} +const ga = Array.from(Array(256).keys(), (e) => + e.toString(16).padStart(2, "0"), +); +class Util { + static makeHexColor(e, t, a) { + return `#${ga[e]}${ga[t]}${ga[a]}`; + } + static scaleMinMax(e, t) { + let a; + if (e[0]) { + if (e[0] < 0) { + a = t[0]; + t[0] = t[2]; + t[2] = a; + } + t[0] *= e[0]; + t[2] *= e[0]; + if (e[3] < 0) { + a = t[1]; + t[1] = t[3]; + t[3] = a; + } + t[1] *= e[3]; + t[3] *= e[3]; + } else { + a = t[0]; + t[0] = t[1]; + t[1] = a; + a = t[2]; + t[2] = t[3]; + t[3] = a; + if (e[1] < 0) { + a = t[1]; + t[1] = t[3]; + t[3] = a; + } + t[1] *= e[1]; + t[3] *= e[1]; + if (e[2] < 0) { + a = t[0]; + t[0] = t[2]; + t[2] = a; + } + t[0] *= e[2]; + t[2] *= e[2]; + } + t[0] += e[4]; + t[1] += e[5]; + t[2] += e[4]; + t[3] += e[5]; + } + static transform(e, t) { + return [ + e[0] * t[0] + e[2] * t[1], + e[1] * t[0] + e[3] * t[1], + e[0] * t[2] + e[2] * t[3], + e[1] * t[2] + e[3] * t[3], + e[0] * t[4] + e[2] * t[5] + e[4], + e[1] * t[4] + e[3] * t[5] + e[5], + ]; + } + static applyTransform(e, t, a = 0) { + const r = e[a], + i = e[a + 1]; + e[a] = r * t[0] + i * t[2] + t[4]; + e[a + 1] = r * t[1] + i * t[3] + t[5]; + } + static applyTransformToBezier(e, t, a = 0) { + const r = t[0], + i = t[1], + n = t[2], + s = t[3], + o = t[4], + c = t[5]; + for (let t = 0; t < 6; t += 2) { + const l = e[a + t], + h = e[a + t + 1]; + e[a + t] = l * r + h * n + o; + e[a + t + 1] = l * i + h * s + c; + } + } + static applyInverseTransform(e, t) { + const a = e[0], + r = e[1], + i = t[0] * t[3] - t[1] * t[2]; + e[0] = (a * t[3] - r * t[2] + t[2] * t[5] - t[4] * t[3]) / i; + e[1] = (-a * t[1] + r * t[0] + t[4] * t[1] - t[5] * t[0]) / i; + } + static axialAlignedBoundingBox(e, t, a) { + const r = t[0], + i = t[1], + n = t[2], + s = t[3], + o = t[4], + c = t[5], + l = e[0], + h = e[1], + u = e[2], + d = e[3]; + let f = r * l + o, + g = f, + p = r * u + o, + m = p, + b = s * h + c, + y = b, + w = s * d + c, + x = w; + if (0 !== i || 0 !== n) { + const e = i * l, + t = i * u, + a = n * h, + r = n * d; + f += a; + m += a; + p += r; + g += r; + b += e; + x += e; + w += t; + y += t; + } + a[0] = Math.min(a[0], f, p, g, m); + a[1] = Math.min(a[1], b, w, y, x); + a[2] = Math.max(a[2], f, p, g, m); + a[3] = Math.max(a[3], b, w, y, x); + } + static inverseTransform(e) { + const t = e[0] * e[3] - e[1] * e[2]; + return [ + e[3] / t, + -e[1] / t, + -e[2] / t, + e[0] / t, + (e[2] * e[5] - e[4] * e[3]) / t, + (e[4] * e[1] - e[5] * e[0]) / t, + ]; + } + static singularValueDecompose2dScale(e, t) { + const a = e[0], + r = e[1], + i = e[2], + n = e[3], + s = a ** 2 + r ** 2, + o = a * i + r * n, + c = i ** 2 + n ** 2, + l = (s + c) / 2, + h = Math.sqrt(l ** 2 - (s * c - o ** 2)); + t[0] = Math.sqrt(l + h || 1); + t[1] = Math.sqrt(l - h || 1); + } + static normalizeRect(e) { + const t = e.slice(0); + if (e[0] > e[2]) { + t[0] = e[2]; + t[2] = e[0]; + } + if (e[1] > e[3]) { + t[1] = e[3]; + t[3] = e[1]; + } + return t; + } + static intersect(e, t) { + const a = Math.max(Math.min(e[0], e[2]), Math.min(t[0], t[2])), + r = Math.min(Math.max(e[0], e[2]), Math.max(t[0], t[2])); + if (a > r) return null; + const i = Math.max(Math.min(e[1], e[3]), Math.min(t[1], t[3])), + n = Math.min(Math.max(e[1], e[3]), Math.max(t[1], t[3])); + return i > n ? null : [a, i, r, n]; + } + static pointBoundingBox(e, t, a) { + a[0] = Math.min(a[0], e); + a[1] = Math.min(a[1], t); + a[2] = Math.max(a[2], e); + a[3] = Math.max(a[3], t); + } + static rectBoundingBox(e, t, a, r, i) { + i[0] = Math.min(i[0], e, a); + i[1] = Math.min(i[1], t, r); + i[2] = Math.max(i[2], e, a); + i[3] = Math.max(i[3], t, r); + } + static #e(e, t, a, r, i, n, s, o, c, l) { + if (c <= 0 || c >= 1) return; + const h = 1 - c, + u = c * c, + d = u * c, + f = h * (h * (h * e + 3 * c * t) + 3 * u * a) + d * r, + g = h * (h * (h * i + 3 * c * n) + 3 * u * s) + d * o; + l[0] = Math.min(l[0], f); + l[1] = Math.min(l[1], g); + l[2] = Math.max(l[2], f); + l[3] = Math.max(l[3], g); + } + static #t(e, t, a, r, i, n, s, o, c, l, h, u) { + if (Math.abs(c) < 1e-12) { + Math.abs(l) >= 1e-12 && this.#e(e, t, a, r, i, n, s, o, -h / l, u); + return; + } + const d = l ** 2 - 4 * h * c; + if (d < 0) return; + const f = Math.sqrt(d), + g = 2 * c; + this.#e(e, t, a, r, i, n, s, o, (-l + f) / g, u); + this.#e(e, t, a, r, i, n, s, o, (-l - f) / g, u); + } + static bezierBoundingBox(e, t, a, r, i, n, s, o, c) { + c[0] = Math.min(c[0], e, s); + c[1] = Math.min(c[1], t, o); + c[2] = Math.max(c[2], e, s); + c[3] = Math.max(c[3], t, o); + this.#t( + e, + a, + i, + s, + t, + r, + n, + o, + 3 * (3 * (a - i) - e + s), + 6 * (e - 2 * a + i), + 3 * (a - e), + c, + ); + this.#t( + e, + a, + i, + s, + t, + r, + n, + o, + 3 * (3 * (r - n) - t + o), + 6 * (t - 2 * r + n), + 3 * (r - t), + c, + ); + } +} +const pa = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 728, + 711, 710, 729, 733, 731, 730, 732, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 8226, 8224, 8225, 8230, 8212, 8211, 402, 8260, 8249, 8250, 8722, + 8240, 8222, 8220, 8221, 8216, 8217, 8218, 8482, 64257, 64258, 321, 338, 352, + 376, 381, 305, 322, 339, 353, 382, 0, 8364, +]; +function stringToPDFString(e, t = !1) { + if (e[0] >= "ï") { + let a; + if ("þ" === e[0] && "ÿ" === e[1]) { + a = "utf-16be"; + e.length % 2 == 1 && (e = e.slice(0, -1)); + } else if ("ÿ" === e[0] && "þ" === e[1]) { + a = "utf-16le"; + e.length % 2 == 1 && (e = e.slice(0, -1)); + } else "ï" === e[0] && "»" === e[1] && "¿" === e[2] && (a = "utf-8"); + if (a) + try { + const r = new TextDecoder(a, { fatal: !0 }), + i = stringToBytes(e), + n = r.decode(i); + return t || !n.includes("") + ? n + : n.replaceAll(/\x1b[^\x1b]*(?:\x1b|$)/g, ""); + } catch (e) { + warn(`stringToPDFString: "${e}".`); + } + } + const a = []; + for (let r = 0, i = e.length; r < i; r++) { + const n = e.charCodeAt(r); + if (!t && 27 === n) { + for (; ++r < i && 27 !== e.charCodeAt(r); ); + continue; + } + const s = pa[n]; + a.push(s ? String.fromCharCode(s) : e.charAt(r)); + } + return a.join(""); +} +function stringToUTF8String(e) { + return decodeURIComponent(escape(e)); +} +function utf8StringToString(e) { + return unescape(encodeURIComponent(e)); +} +function isArrayEqual(e, t) { + if (e.length !== t.length) return !1; + for (let a = 0, r = e.length; a < r; a++) if (e[a] !== t[a]) return !1; + return !0; +} +function getModificationDate(e = new Date()) { + return [ + e.getUTCFullYear().toString(), + (e.getUTCMonth() + 1).toString().padStart(2, "0"), + e.getUTCDate().toString().padStart(2, "0"), + e.getUTCHours().toString().padStart(2, "0"), + e.getUTCMinutes().toString().padStart(2, "0"), + e.getUTCSeconds().toString().padStart(2, "0"), + ].join(""); +} +let ma = null, + ba = null; +function MathClamp(e, t, a) { + return Math.min(Math.max(e, t), a); +} +function toHexUtil(e) { + return Uint8Array.prototype.toHex + ? e.toHex() + : Array.from(e, (e) => ga[e]).join(""); +} +"function" != typeof Promise.try && + (Promise.try = function (e, ...t) { + return new Promise((a) => { + a(e(...t)); + }); + }); +"function" != typeof Math.sumPrecise && + (Math.sumPrecise = function (e) { + return e.reduce((e, t) => e + t, 0); + }); +const ya = Symbol("CIRCULAR_REF"), + wa = Symbol("EOF"); +let xa = Object.create(null), + Sa = Object.create(null), + ka = Object.create(null); +class Name { + constructor(e) { + this.name = e; + } + static get(e) { + return (Sa[e] ||= new Name(e)); + } +} +class Cmd { + constructor(e) { + this.cmd = e; + } + static get(e) { + return (xa[e] ||= new Cmd(e)); + } +} +const Aa = function nonSerializableClosure() { + return Aa; +}; +class Dict { + constructor(e = null) { + this._map = new Map(); + this.xref = e; + this.objId = null; + this.suppressEncryption = !1; + this.__nonSerializable__ = Aa; + } + assignXref(e) { + this.xref = e; + } + get size() { + return this._map.size; + } + get(e, t, a) { + let r = this._map.get(e); + if (void 0 === r && void 0 !== t) { + r = this._map.get(t); + void 0 === r && void 0 !== a && (r = this._map.get(a)); + } + return r instanceof Ref && this.xref + ? this.xref.fetch(r, this.suppressEncryption) + : r; + } + async getAsync(e, t, a) { + let r = this._map.get(e); + if (void 0 === r && void 0 !== t) { + r = this._map.get(t); + void 0 === r && void 0 !== a && (r = this._map.get(a)); + } + return r instanceof Ref && this.xref + ? this.xref.fetchAsync(r, this.suppressEncryption) + : r; + } + getArray(e, t, a) { + let r = this._map.get(e); + if (void 0 === r && void 0 !== t) { + r = this._map.get(t); + void 0 === r && void 0 !== a && (r = this._map.get(a)); + } + r instanceof Ref && + this.xref && + (r = this.xref.fetch(r, this.suppressEncryption)); + if (Array.isArray(r)) { + r = r.slice(); + for (let e = 0, t = r.length; e < t; e++) + r[e] instanceof Ref && + this.xref && + (r[e] = this.xref.fetch(r[e], this.suppressEncryption)); + } + return r; + } + getRaw(e) { + return this._map.get(e); + } + getKeys() { + return [...this._map.keys()]; + } + getRawValues() { + return [...this._map.values()]; + } + set(e, t) { + this._map.set(e, t); + } + has(e) { + return this._map.has(e); + } + *[Symbol.iterator]() { + for (const [e, t] of this._map) + yield [ + e, + t instanceof Ref && this.xref + ? this.xref.fetch(t, this.suppressEncryption) + : t, + ]; + } + static get empty() { + const e = new Dict(null); + e.set = (e, t) => { + unreachable("Should not call `set` on the empty dictionary."); + }; + return shadow(this, "empty", e); + } + static merge({ xref: e, dictArray: t, mergeSubDicts: a = !1 }) { + const r = new Dict(e), + i = new Map(); + for (const e of t) + if (e instanceof Dict) + for (const [t, r] of e._map) { + let e = i.get(t); + if (void 0 === e) { + e = []; + i.set(t, e); + } else if (!(a && r instanceof Dict)) continue; + e.push(r); + } + for (const [t, a] of i) { + if (1 === a.length || !(a[0] instanceof Dict)) { + r._map.set(t, a[0]); + continue; + } + const i = new Dict(e); + for (const e of a) + for (const [t, a] of e._map) i._map.has(t) || i._map.set(t, a); + i.size > 0 && r._map.set(t, i); + } + i.clear(); + return r.size > 0 ? r : Dict.empty; + } + clone() { + const e = new Dict(this.xref); + for (const t of this.getKeys()) e.set(t, this.getRaw(t)); + return e; + } + delete(e) { + delete this._map[e]; + } +} +class Ref { + constructor(e, t) { + this.num = e; + this.gen = t; + } + toString() { + return 0 === this.gen ? `${this.num}R` : `${this.num}R${this.gen}`; + } + static fromString(e) { + const t = ka[e]; + if (t) return t; + const a = /^(\d+)R(\d*)$/.exec(e); + return a && "0" !== a[1] + ? (ka[e] = new Ref(parseInt(a[1]), a[2] ? parseInt(a[2]) : 0)) + : null; + } + static get(e, t) { + const a = 0 === t ? `${e}R` : `${e}R${t}`; + return (ka[a] ||= new Ref(e, t)); + } +} +class RefSet { + constructor(e = null) { + this._set = new Set(e?._set); + } + has(e) { + return this._set.has(e.toString()); + } + put(e) { + this._set.add(e.toString()); + } + remove(e) { + this._set.delete(e.toString()); + } + [Symbol.iterator]() { + return this._set.values(); + } + clear() { + this._set.clear(); + } +} +class RefSetCache { + constructor() { + this._map = new Map(); + } + get size() { + return this._map.size; + } + get(e) { + return this._map.get(e.toString()); + } + has(e) { + return this._map.has(e.toString()); + } + put(e, t) { + this._map.set(e.toString(), t); + } + putAlias(e, t) { + this._map.set(e.toString(), this.get(t)); + } + [Symbol.iterator]() { + return this._map.values(); + } + clear() { + this._map.clear(); + } + *values() { + yield* this._map.values(); + } + *items() { + for (const [e, t] of this._map) yield [Ref.fromString(e), t]; + } +} +function isName(e, t) { + return e instanceof Name && (void 0 === t || e.name === t); +} +function isCmd(e, t) { + return e instanceof Cmd && (void 0 === t || e.cmd === t); +} +function isDict(e, t) { + return e instanceof Dict && (void 0 === t || isName(e.get("Type"), t)); +} +function isRefsEqual(e, t) { + return e.num === t.num && e.gen === t.gen; +} +class BaseStream { + get length() { + unreachable("Abstract getter `length` accessed"); + } + get isEmpty() { + unreachable("Abstract getter `isEmpty` accessed"); + } + get isDataLoaded() { + return shadow(this, "isDataLoaded", !0); + } + getByte() { + unreachable("Abstract method `getByte` called"); + } + getBytes(e) { + unreachable("Abstract method `getBytes` called"); + } + async getImageData(e, t) { + return this.getBytes(e, t); + } + async asyncGetBytes() { + unreachable("Abstract method `asyncGetBytes` called"); + } + get isAsync() { + return !1; + } + get isAsyncDecoder() { + return !1; + } + get canAsyncDecodeImageFromBuffer() { + return !1; + } + async getTransferableImage() { + return null; + } + peekByte() { + const e = this.getByte(); + -1 !== e && this.pos--; + return e; + } + peekBytes(e) { + const t = this.getBytes(e); + this.pos -= t.length; + return t; + } + getUint16() { + const e = this.getByte(), + t = this.getByte(); + return -1 === e || -1 === t ? -1 : (e << 8) + t; + } + getInt32() { + return ( + (this.getByte() << 24) + + (this.getByte() << 16) + + (this.getByte() << 8) + + this.getByte() + ); + } + getByteRange(e, t) { + unreachable("Abstract method `getByteRange` called"); + } + getString(e) { + return bytesToString(this.getBytes(e)); + } + skip(e) { + this.pos += e || 1; + } + reset() { + unreachable("Abstract method `reset` called"); + } + moveStart() { + unreachable("Abstract method `moveStart` called"); + } + makeSubStream(e, t, a = null) { + unreachable("Abstract method `makeSubStream` called"); + } + getBaseStreams() { + return null; + } +} +const Ca = /^[1-9]\.\d$/, + va = 2 ** 31 - 1, + Fa = [1, 0, 0, 1, 0, 0], + Ia = [ + "ColorSpace", + "ExtGState", + "Font", + "Pattern", + "Properties", + "Shading", + "XObject", + ], + Ta = ["ExtGState", "Font", "Properties", "XObject"]; +function getLookupTableFactory(e) { + let t; + return function () { + if (e) { + t = Object.create(null); + e(t); + e = null; + } + return t; + }; +} +class MissingDataException extends fa { + constructor(e, t) { + super(`Missing data [${e}, ${t})`, "MissingDataException"); + this.begin = e; + this.end = t; + } +} +class ParserEOFException extends fa { + constructor(e) { + super(e, "ParserEOFException"); + } +} +class XRefEntryException extends fa { + constructor(e) { + super(e, "XRefEntryException"); + } +} +class XRefParseException extends fa { + constructor(e) { + super(e, "XRefParseException"); + } +} +function arrayBuffersToBytes(e) { + const t = e.length; + if (0 === t) return new Uint8Array(0); + if (1 === t) return new Uint8Array(e[0]); + let a = 0; + for (let r = 0; r < t; r++) a += e[r].byteLength; + const r = new Uint8Array(a); + let i = 0; + for (let a = 0; a < t; a++) { + const t = new Uint8Array(e[a]); + r.set(t, i); + i += t.byteLength; + } + return r; +} +async function fetchBinaryData(e) { + const t = await fetch(e); + if (!t.ok) + throw new Error(`Failed to fetch file "${e}" with "${t.statusText}".`); + return new Uint8Array(await t.arrayBuffer()); +} +function getInheritableProperty({ + dict: e, + key: t, + getArray: a = !1, + stopWhenFound: r = !0, +}) { + let i; + const n = new RefSet(); + for (; e instanceof Dict && (!e.objId || !n.has(e.objId)); ) { + e.objId && n.put(e.objId); + const s = a ? e.getArray(t) : e.get(t); + if (void 0 !== s) { + if (r) return s; + (i ||= []).push(s); + } + e = e.get("Parent"); + } + return i; +} +const Oa = [ + "", + "C", + "CC", + "CCC", + "CD", + "D", + "DC", + "DCC", + "DCCC", + "CM", + "", + "X", + "XX", + "XXX", + "XL", + "L", + "LX", + "LXX", + "LXXX", + "XC", + "", + "I", + "II", + "III", + "IV", + "V", + "VI", + "VII", + "VIII", + "IX", +]; +function toRomanNumerals(e, t = !1) { + assert( + Number.isInteger(e) && e > 0, + "The number should be a positive integer.", + ); + const a = + "M".repeat((e / 1e3) | 0) + + Oa[((e % 1e3) / 100) | 0] + + Oa[10 + (((e % 100) / 10) | 0)] + + Oa[20 + (e % 10)]; + return t ? a.toLowerCase() : a; +} +function log2(e) { + return e > 0 ? Math.ceil(Math.log2(e)) : 0; +} +function readInt8(e, t) { + return (e[t] << 24) >> 24; +} +function readInt16(e, t) { + return ((e[t] << 24) | (e[t + 1] << 16)) >> 16; +} +function readUint16(e, t) { + return (e[t] << 8) | e[t + 1]; +} +function readUint32(e, t) { + return ((e[t] << 24) | (e[t + 1] << 16) | (e[t + 2] << 8) | e[t + 3]) >>> 0; +} +function isWhiteSpace(e) { + return 32 === e || 9 === e || 13 === e || 10 === e; +} +function isNumberArray(e, t) { + return Array.isArray(e) + ? (null === t || e.length === t) && e.every((e) => "number" == typeof e) + : ArrayBuffer.isView(e) && + !(e instanceof BigInt64Array || e instanceof BigUint64Array) && + (null === t || e.length === t); +} +function lookupMatrix(e, t) { + return isNumberArray(e, 6) ? e : t; +} +function lookupRect(e, t) { + return isNumberArray(e, 4) ? e : t; +} +function lookupNormalRect(e, t) { + return isNumberArray(e, 4) ? Util.normalizeRect(e) : t; +} +function parseXFAPath(e) { + const t = /(.+)\[(\d+)\]$/; + return e.split(".").map((e) => { + const a = e.match(t); + return a ? { name: a[1], pos: parseInt(a[2], 10) } : { name: e, pos: 0 }; + }); +} +function escapePDFName(e) { + const t = []; + let a = 0; + for (let r = 0, i = e.length; r < i; r++) { + const i = e.charCodeAt(r); + if ( + i < 33 || + i > 126 || + 35 === i || + 40 === i || + 41 === i || + 60 === i || + 62 === i || + 91 === i || + 93 === i || + 123 === i || + 125 === i || + 47 === i || + 37 === i + ) { + a < r && t.push(e.substring(a, r)); + t.push(`#${i.toString(16)}`); + a = r + 1; + } + } + if (0 === t.length) return e; + a < e.length && t.push(e.substring(a, e.length)); + return t.join(""); +} +function escapeString(e) { + return e.replaceAll(/([()\\\n\r])/g, (e) => + "\n" === e ? "\\n" : "\r" === e ? "\\r" : `\\${e}`, + ); +} +function _collectJS(e, t, a, r) { + if (!e) return; + let i = null; + if (e instanceof Ref) { + if (r.has(e)) return; + i = e; + r.put(i); + e = t.fetch(e); + } + if (Array.isArray(e)) for (const i of e) _collectJS(i, t, a, r); + else if (e instanceof Dict) { + if (isName(e.get("S"), "JavaScript")) { + const t = e.get("JS"); + let r; + t instanceof BaseStream + ? (r = t.getString()) + : "string" == typeof t && (r = t); + r &&= stringToPDFString(r, !0).replaceAll("\0", ""); + r && a.push(r); + } + _collectJS(e.getRaw("Next"), t, a, r); + } + i && r.remove(i); +} +function collectActions(e, t, a) { + const r = Object.create(null), + i = getInheritableProperty({ dict: t, key: "AA", stopWhenFound: !1 }); + if (i) + for (let t = i.length - 1; t >= 0; t--) { + const n = i[t]; + if (n instanceof Dict) + for (const t of n.getKeys()) { + const i = a[t]; + if (!i) continue; + const s = []; + _collectJS(n.getRaw(t), e, s, new RefSet()); + s.length > 0 && (r[i] = s); + } + } + if (t.has("A")) { + const a = []; + _collectJS(t.get("A"), e, a, new RefSet()); + a.length > 0 && (r.Action = a); + } + return objectSize(r) > 0 ? r : null; +} +const Ma = { 60: "<", 62: ">", 38: "&", 34: """, 39: "'" }; +function* codePointIter(e) { + for (let t = 0, a = e.length; t < a; t++) { + const a = e.codePointAt(t); + a > 55295 && (a < 57344 || a > 65533) && t++; + yield a; + } +} +function encodeToXmlString(e) { + const t = []; + let a = 0; + for (let r = 0, i = e.length; r < i; r++) { + const i = e.codePointAt(r); + if (32 <= i && i <= 126) { + const n = Ma[i]; + if (n) { + a < r && t.push(e.substring(a, r)); + t.push(n); + a = r + 1; + } + } else { + a < r && t.push(e.substring(a, r)); + t.push(`&#x${i.toString(16).toUpperCase()};`); + i > 55295 && (i < 57344 || i > 65533) && r++; + a = r + 1; + } + } + if (0 === t.length) return e; + a < e.length && t.push(e.substring(a, e.length)); + return t.join(""); +} +function validateFontName(e, t = !1) { + const a = /^("|').*("|')$/.exec(e); + if (a && a[1] === a[2]) { + if (new RegExp(`[^\\\\]${a[1]}`).test(e.slice(1, -1))) { + t && warn(`FontFamily contains unescaped ${a[1]}: ${e}.`); + return !1; + } + } else + for (const a of e.split(/[ \t]+/)) + if (/^(\d|(-(\d|-)))/.test(a) || !/^[\w-\\]+$/.test(a)) { + t && warn(`FontFamily contains invalid : ${e}.`); + return !1; + } + return !0; +} +function validateCSSFont(e) { + const t = new Set([ + "100", + "200", + "300", + "400", + "500", + "600", + "700", + "800", + "900", + "1000", + "normal", + "bold", + "bolder", + "lighter", + ]), + { fontFamily: a, fontWeight: r, italicAngle: i } = e; + if (!validateFontName(a, !0)) return !1; + const n = r ? r.toString() : ""; + e.fontWeight = t.has(n) ? n : "400"; + const s = parseFloat(i); + e.italicAngle = isNaN(s) || s < -90 || s > 90 ? "14" : i.toString(); + return !0; +} +function recoverJsURL(e) { + const t = new RegExp( + "^\\s*(" + + ["app.launchURL", "window.open", "xfa.host.gotoURL"] + .join("|") + .replaceAll(".", "\\.") + + ")\\((?:'|\")([^'\"]*)(?:'|\")(?:,\\s*(\\w+)\\)|\\))", + "i", + ).exec(e); + return t?.[2] + ? { url: t[2], newWindow: "app.launchURL" === t[1] && "true" === t[3] } + : null; +} +function numberToString(e) { + if (Number.isInteger(e)) return e.toString(); + const t = Math.round(100 * e); + return t % 100 == 0 + ? (t / 100).toString() + : t % 10 == 0 + ? e.toFixed(1) + : e.toFixed(2); +} +function getNewAnnotationsMap(e) { + if (!e) return null; + const t = new Map(); + for (const [a, r] of e) { + if (!a.startsWith(f)) continue; + let e = t.get(r.pageIndex); + if (!e) { + e = []; + t.set(r.pageIndex, e); + } + e.push(r); + } + return t.size > 0 ? t : null; +} +function stringToAsciiOrUTF16BE(e) { + return (function isAscii(e) { + return /^[\x00-\x7F]*$/.test(e); + })(e) + ? e + : stringToUTF16String(e, !0); +} +function stringToUTF16HexString(e) { + const t = []; + for (let a = 0, r = e.length; a < r; a++) { + const r = e.charCodeAt(a); + t.push(ga[(r >> 8) & 255], ga[255 & r]); + } + return t.join(""); +} +function stringToUTF16String(e, t = !1) { + const a = []; + t && a.push("þÿ"); + for (let t = 0, r = e.length; t < r; t++) { + const r = e.charCodeAt(t); + a.push(String.fromCharCode((r >> 8) & 255), String.fromCharCode(255 & r)); + } + return a.join(""); +} +function getRotationMatrix(e, t, a) { + switch (e) { + case 90: + return [0, 1, -1, 0, t, 0]; + case 180: + return [-1, 0, 0, -1, t, a]; + case 270: + return [0, -1, 1, 0, 0, a]; + default: + throw new Error("Invalid rotation"); + } +} +function getSizeInBytes(e) { + return Math.ceil(Math.ceil(Math.log2(1 + e)) / 8); +} +class QCMS { + static #a = null; + static _memory = null; + static _mustAddAlpha = !1; + static _destBuffer = null; + static _destOffset = 0; + static _destLength = 0; + static _cssColor = ""; + static _makeHexColor = null; + static get _memoryArray() { + const e = this.#a; + return e?.byteLength ? e : (this.#a = new Uint8Array(this._memory.buffer)); + } +} +let Da; +const Ba = + "undefined" != typeof TextDecoder + ? new TextDecoder("utf-8", { ignoreBOM: !0, fatal: !0 }) + : { + decode: () => { + throw Error("TextDecoder not available"); + }, + }; +"undefined" != typeof TextDecoder && Ba.decode(); +let Ra = null; +function getUint8ArrayMemory0() { + (null !== Ra && 0 !== Ra.byteLength) || + (Ra = new Uint8Array(Da.memory.buffer)); + return Ra; +} +let Na = 0; +function passArray8ToWasm0(e, t) { + const a = t(1 * e.length, 1) >>> 0; + getUint8ArrayMemory0().set(e, a / 1); + Na = e.length; + return a; +} +const Ea = Object.freeze({ + RGB8: 0, + 0: "RGB8", + RGBA8: 1, + 1: "RGBA8", + BGRA8: 2, + 2: "BGRA8", + Gray8: 3, + 3: "Gray8", + GrayA8: 4, + 4: "GrayA8", + CMYK: 5, + 5: "CMYK", + }), + Pa = Object.freeze({ + Perceptual: 0, + 0: "Perceptual", + RelativeColorimetric: 1, + 1: "RelativeColorimetric", + Saturation: 2, + 2: "Saturation", + AbsoluteColorimetric: 3, + 3: "AbsoluteColorimetric", + }); +function __wbg_get_imports() { + const e = { wbg: {} }; + e.wbg.__wbg_copyresult_b08ee7d273f295dd = function (e, t) { + !(function copy_result(e, t) { + const { + _mustAddAlpha: a, + _destBuffer: r, + _destOffset: i, + _destLength: n, + _memoryArray: s, + } = QCMS; + if (t !== n) + if (a) + for (let a = e, n = e + t, o = i; a < n; a += 3, o += 4) { + r[o] = s[a]; + r[o + 1] = s[a + 1]; + r[o + 2] = s[a + 2]; + r[o + 3] = 255; + } + else + for (let a = e, n = e + t, o = i; a < n; a += 3, o += 4) { + r[o] = s[a]; + r[o + 1] = s[a + 1]; + r[o + 2] = s[a + 2]; + } + else r.set(s.subarray(e, e + t), i); + })(e >>> 0, t >>> 0); + }; + e.wbg.__wbg_copyrgb_d60ce17bb05d9b67 = function (e) { + !(function copy_rgb(e) { + const { _destBuffer: t, _destOffset: a, _memoryArray: r } = QCMS; + t[a] = r[e]; + t[a + 1] = r[e + 1]; + t[a + 2] = r[e + 2]; + })(e >>> 0); + }; + e.wbg.__wbg_makecssRGB_893bf0cd9fdb302d = function (e) { + !(function make_cssRGB(e) { + const { _memoryArray: t } = QCMS; + QCMS._cssColor = QCMS._makeHexColor(t[e], t[e + 1], t[e + 2]); + })(e >>> 0); + }; + e.wbg.__wbindgen_init_externref_table = function () { + const e = Da.__wbindgen_export_0, + t = e.grow(4); + e.set(0, void 0); + e.set(t + 0, void 0); + e.set(t + 1, null); + e.set(t + 2, !0); + e.set(t + 3, !1); + }; + e.wbg.__wbindgen_throw = function (e, t) { + throw new Error( + (function getStringFromWasm0(e, t) { + e >>>= 0; + return Ba.decode(getUint8ArrayMemory0().subarray(e, e + t)); + })(e, t), + ); + }; + return e; +} +function __wbg_finalize_init(e, t) { + Da = e.exports; + __wbg_init.__wbindgen_wasm_module = t; + Ra = null; + Da.__wbindgen_start(); + return Da; +} +async function __wbg_init(e) { + if (void 0 !== Da) return Da; + void 0 !== e && + (Object.getPrototypeOf(e) === Object.prototype + ? ({ module_or_path: e } = e) + : console.warn( + "using deprecated parameters for the initialization function; pass a single object instead", + )); + const t = __wbg_get_imports(); + ("string" == typeof e || + ("function" == typeof Request && e instanceof Request) || + ("function" == typeof URL && e instanceof URL)) && + (e = fetch(e)); + const { instance: a, module: r } = await (async function __wbg_load(e, t) { + if ("function" == typeof Response && e instanceof Response) { + if ("function" == typeof WebAssembly.instantiateStreaming) + try { + return await WebAssembly.instantiateStreaming(e, t); + } catch (t) { + if ("application/wasm" == e.headers.get("Content-Type")) throw t; + console.warn( + "`WebAssembly.instantiateStreaming` failed because your server does not serve Wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\n", + t, + ); + } + const a = await e.arrayBuffer(); + return await WebAssembly.instantiate(a, t); + } + { + const a = await WebAssembly.instantiate(e, t); + return a instanceof WebAssembly.Instance ? { instance: a, module: e } : a; + } + })(await e, t); + return __wbg_finalize_init(a, r); +} +class ColorSpace { + static #r = new Uint8ClampedArray(3); + constructor(e, t) { + this.name = e; + this.numComps = t; + } + getRgb(e, t, a = new Uint8ClampedArray(3)) { + this.getRgbItem(e, t, a, 0); + return a; + } + getRgbHex(e, t) { + const a = this.getRgb(e, t, ColorSpace.#r); + return Util.makeHexColor(a[0], a[1], a[2]); + } + getRgbItem(e, t, a, r) { + unreachable("Should not call ColorSpace.getRgbItem"); + } + getRgbBuffer(e, t, a, r, i, n, s) { + unreachable("Should not call ColorSpace.getRgbBuffer"); + } + getOutputLength(e, t) { + unreachable("Should not call ColorSpace.getOutputLength"); + } + isPassthrough(e) { + return !1; + } + isDefaultDecode(e, t) { + return ColorSpace.isDefaultDecode(e, this.numComps); + } + fillRgb(e, t, a, r, i, n, s, o, c) { + const l = t * a; + let h = null; + const u = 1 << s, + d = a !== i || t !== r; + if (this.isPassthrough(s)) h = o; + else if ( + 1 === this.numComps && + l > u && + "DeviceGray" !== this.name && + "DeviceRGB" !== this.name + ) { + const t = s <= 8 ? new Uint8Array(u) : new Uint16Array(u); + for (let e = 0; e < u; e++) t[e] = e; + const a = new Uint8ClampedArray(3 * u); + this.getRgbBuffer(t, 0, u, a, 0, s, 0); + if (d) { + h = new Uint8Array(3 * l); + let e = 0; + for (let t = 0; t < l; ++t) { + const r = 3 * o[t]; + h[e++] = a[r]; + h[e++] = a[r + 1]; + h[e++] = a[r + 2]; + } + } else { + let t = 0; + for (let r = 0; r < l; ++r) { + const i = 3 * o[r]; + e[t++] = a[i]; + e[t++] = a[i + 1]; + e[t++] = a[i + 2]; + t += c; + } + } + } else if (d) { + h = new Uint8ClampedArray(3 * l); + this.getRgbBuffer(o, 0, l, h, 0, s, 0); + } else this.getRgbBuffer(o, 0, r * n, e, 0, s, c); + if (h) + if (d) + !(function resizeRgbImage(e, t, a, r, i, n, s) { + s = 1 !== s ? 0 : s; + const o = a / i, + c = r / n; + let l, + h = 0; + const u = new Uint16Array(i), + d = 3 * a; + for (let e = 0; e < i; e++) u[e] = 3 * Math.floor(e * o); + for (let a = 0; a < n; a++) { + const r = Math.floor(a * c) * d; + for (let a = 0; a < i; a++) { + l = r + u[a]; + t[h++] = e[l++]; + t[h++] = e[l++]; + t[h++] = e[l++]; + h += s; + } + } + })(h, e, t, a, r, i, c); + else { + let t = 0, + a = 0; + for (let i = 0, s = r * n; i < s; i++) { + e[t++] = h[a++]; + e[t++] = h[a++]; + e[t++] = h[a++]; + t += c; + } + } + } + get usesZeroToOneRange() { + return shadow(this, "usesZeroToOneRange", !0); + } + static isDefaultDecode(e, t) { + if (!Array.isArray(e)) return !0; + if (2 * t !== e.length) { + warn("The decode map is not the correct length"); + return !0; + } + for (let t = 0, a = e.length; t < a; t += 2) + if (0 !== e[t] || 1 !== e[t + 1]) return !1; + return !0; + } +} +class AlternateCS extends ColorSpace { + constructor(e, t, a) { + super("Alternate", e); + this.base = t; + this.tintFn = a; + this.tmpBuf = new Float32Array(t.numComps); + } + getRgbItem(e, t, a, r) { + const i = this.tmpBuf; + this.tintFn(e, t, i, 0); + this.base.getRgbItem(i, 0, a, r); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = this.tintFn, + c = this.base, + l = 1 / ((1 << n) - 1), + h = c.numComps, + u = c.usesZeroToOneRange, + d = (c.isPassthrough(8) || !u) && 0 === s; + let f = d ? i : 0; + const g = d ? r : new Uint8ClampedArray(h * a), + p = this.numComps, + m = new Float32Array(p), + b = new Float32Array(h); + let y, w; + for (y = 0; y < a; y++) { + for (w = 0; w < p; w++) m[w] = e[t++] * l; + o(m, 0, b, 0); + if (u) for (w = 0; w < h; w++) g[f++] = 255 * b[w]; + else { + c.getRgbItem(b, 0, g, f); + f += h; + } + } + d || c.getRgbBuffer(g, 0, a, r, i, 8, s); + } + getOutputLength(e, t) { + return this.base.getOutputLength( + (e * this.base.numComps) / this.numComps, + t, + ); + } +} +class PatternCS extends ColorSpace { + constructor(e) { + super("Pattern", null); + this.base = e; + } + isDefaultDecode(e, t) { + unreachable("Should not call PatternCS.isDefaultDecode"); + } +} +class IndexedCS extends ColorSpace { + constructor(e, t, a) { + super("Indexed", 1); + this.base = e; + this.highVal = t; + const r = e.numComps * (t + 1); + this.lookup = new Uint8Array(r); + if (a instanceof BaseStream) { + const e = a.getBytes(r); + this.lookup.set(e); + } else { + if ("string" != typeof a) + throw new FormatError(`IndexedCS - unrecognized lookup table: ${a}`); + for (let e = 0; e < r; ++e) this.lookup[e] = 255 & a.charCodeAt(e); + } + } + getRgbItem(e, t, a, r) { + const { base: i, highVal: n, lookup: s } = this, + o = MathClamp(Math.round(e[t]), 0, n) * i.numComps; + i.getRgbBuffer(s, o, 1, a, r, 8, 0); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const { base: o, highVal: c, lookup: l } = this, + { numComps: h } = o, + u = o.getOutputLength(h, s); + for (let n = 0; n < a; ++n) { + const a = MathClamp(Math.round(e[t++]), 0, c) * h; + o.getRgbBuffer(l, a, 1, r, i, 8, s); + i += u; + } + } + getOutputLength(e, t) { + return this.base.getOutputLength(e * this.base.numComps, t); + } + isDefaultDecode(e, t) { + if (!Array.isArray(e)) return !0; + if (2 !== e.length) { + warn("Decode map length is not correct"); + return !0; + } + if (!Number.isInteger(t) || t < 1) { + warn("Bits per component is not correct"); + return !0; + } + return 0 === e[0] && e[1] === (1 << t) - 1; + } +} +class DeviceGrayCS extends ColorSpace { + constructor() { + super("DeviceGray", 1); + } + getRgbItem(e, t, a, r) { + const i = 255 * e[t]; + a[r] = a[r + 1] = a[r + 2] = i; + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = 255 / ((1 << n) - 1); + let c = t, + l = i; + for (let t = 0; t < a; ++t) { + const t = o * e[c++]; + r[l++] = t; + r[l++] = t; + r[l++] = t; + l += s; + } + } + getOutputLength(e, t) { + return e * (3 + t); + } +} +class DeviceRgbCS extends ColorSpace { + constructor() { + super("DeviceRGB", 3); + } + getRgbItem(e, t, a, r) { + a[r] = 255 * e[t]; + a[r + 1] = 255 * e[t + 1]; + a[r + 2] = 255 * e[t + 2]; + } + getRgbBuffer(e, t, a, r, i, n, s) { + if (8 === n && 0 === s) { + r.set(e.subarray(t, t + 3 * a), i); + return; + } + const o = 255 / ((1 << n) - 1); + let c = t, + l = i; + for (let t = 0; t < a; ++t) { + r[l++] = o * e[c++]; + r[l++] = o * e[c++]; + r[l++] = o * e[c++]; + l += s; + } + } + getOutputLength(e, t) { + return ((e * (3 + t)) / 3) | 0; + } + isPassthrough(e) { + return 8 === e; + } +} +class DeviceRgbaCS extends ColorSpace { + constructor() { + super("DeviceRGBA", 4); + } + getOutputLength(e, t) { + return 4 * e; + } + isPassthrough(e) { + return 8 === e; + } + fillRgb(e, t, a, r, i, n, s, o, c) { + a !== i || t !== r + ? (function resizeRgbaImage(e, t, a, r, i, n, s) { + const o = a / i, + c = r / n; + let l = 0; + const h = new Uint16Array(i); + if (1 === s) { + for (let e = 0; e < i; e++) h[e] = Math.floor(e * o); + const r = new Uint32Array(e.buffer), + s = new Uint32Array(t.buffer), + u = FeatureTest.isLittleEndian ? 16777215 : 4294967040; + for (let e = 0; e < n; e++) { + const t = r.subarray(Math.floor(e * c) * a); + for (let e = 0; e < i; e++) s[l++] |= t[h[e]] & u; + } + } else { + const r = 4, + s = a * r; + for (let e = 0; e < i; e++) h[e] = Math.floor(e * o) * r; + for (let a = 0; a < n; a++) { + const r = e.subarray(Math.floor(a * c) * s); + for (let e = 0; e < i; e++) { + const a = h[e]; + t[l++] = r[a]; + t[l++] = r[a + 1]; + t[l++] = r[a + 2]; + } + } + } + })(o, e, t, a, r, i, c) + : (function copyRgbaImage(e, t, a) { + if (1 === a) { + const a = new Uint32Array(e.buffer), + r = new Uint32Array(t.buffer), + i = FeatureTest.isLittleEndian ? 16777215 : 4294967040; + for (let e = 0, t = a.length; e < t; e++) r[e] |= a[e] & i; + } else { + let a = 0; + for (let r = 0, i = e.length; r < i; r += 4) { + t[a++] = e[r]; + t[a++] = e[r + 1]; + t[a++] = e[r + 2]; + } + } + })(o, e, c); + } +} +class DeviceCmykCS extends ColorSpace { + constructor() { + super("DeviceCMYK", 4); + } + #i(e, t, a, r, i) { + const n = e[t] * a, + s = e[t + 1] * a, + o = e[t + 2] * a, + c = e[t + 3] * a; + r[i] = + 255 + + n * + (-4.387332384609988 * n + + 54.48615194189176 * s + + 18.82290502165302 * o + + 212.25662451639585 * c - + 285.2331026137004) + + s * + (1.7149763477362134 * s - + 5.6096736904047315 * o + + -17.873870861415444 * c - + 5.497006427196366) + + o * + (-2.5217340131683033 * o - 21.248923337353073 * c + 17.5119270841813) + + c * (-21.86122147463605 * c - 189.48180835922747); + r[i + 1] = + 255 + + n * + (8.841041422036149 * n + + 60.118027045597366 * s + + 6.871425592049007 * o + + 31.159100130055922 * c - + 79.2970844816548) + + s * + (-15.310361306967817 * s + + 17.575251261109482 * o + + 131.35250912493976 * c - + 190.9453302588951) + + o * (4.444339102852739 * o + 9.8632861493405 * c - 24.86741582555878) + + c * (-20.737325471181034 * c - 187.80453709719578); + r[i + 2] = + 255 + + n * + (0.8842522430003296 * n + + 8.078677503112928 * s + + 30.89978309703729 * o - + 0.23883238689178934 * c - + 14.183576799673286) + + s * + (10.49593273432072 * s + + 63.02378494754052 * o + + 50.606957656360734 * c - + 112.23884253719248) + + o * + (0.03296041114873217 * o + + 115.60384449646641 * c - + 193.58209356861505) + + c * (-22.33816807309886 * c - 180.12613974708367); + } + getRgbItem(e, t, a, r) { + this.#i(e, t, 1, a, r); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = 1 / ((1 << n) - 1); + for (let n = 0; n < a; n++) { + this.#i(e, t, o, r, i); + t += 4; + i += 3 + s; + } + } + getOutputLength(e, t) { + return ((e / 4) * (3 + t)) | 0; + } +} +class CalGrayCS extends ColorSpace { + constructor(e, t, a) { + super("CalGray", 1); + if (!e) + throw new FormatError( + "WhitePoint missing - required for color space CalGray", + ); + [this.XW, this.YW, this.ZW] = e; + [this.XB, this.YB, this.ZB] = t || [0, 0, 0]; + this.G = a || 1; + if (this.XW < 0 || this.ZW < 0 || 1 !== this.YW) + throw new FormatError( + `Invalid WhitePoint components for ${this.name}, no fallback available`, + ); + if (this.XB < 0 || this.YB < 0 || this.ZB < 0) { + info(`Invalid BlackPoint for ${this.name}, falling back to default.`); + this.XB = this.YB = this.ZB = 0; + } + (0 === this.XB && 0 === this.YB && 0 === this.ZB) || + warn( + `${this.name}, BlackPoint: XB: ${this.XB}, YB: ${this.YB}, ZB: ${this.ZB}, only default values are supported.`, + ); + if (this.G < 1) { + info( + `Invalid Gamma: ${this.G} for ${this.name}, falling back to default.`, + ); + this.G = 1; + } + } + #i(e, t, a, r, i) { + const n = (e[t] * i) ** this.G, + s = this.YW * n, + o = Math.max(295.8 * s ** 0.3333333333333333 - 40.8, 0); + a[r] = o; + a[r + 1] = o; + a[r + 2] = o; + } + getRgbItem(e, t, a, r) { + this.#i(e, t, a, r, 1); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = 1 / ((1 << n) - 1); + for (let n = 0; n < a; ++n) { + this.#i(e, t, r, i, o); + t += 1; + i += 3 + s; + } + } + getOutputLength(e, t) { + return e * (3 + t); + } +} +class CalRGBCS extends ColorSpace { + static #n = new Float32Array([ + 0.8951, 0.2664, -0.1614, -0.7502, 1.7135, 0.0367, 0.0389, -0.0685, 1.0296, + ]); + static #s = new Float32Array([ + 0.9869929, -0.1470543, 0.1599627, 0.4323053, 0.5183603, 0.0492912, + -0.0085287, 0.0400428, 0.9684867, + ]); + static #o = new Float32Array([ + 3.2404542, -1.5371385, -0.4985314, -0.969266, 1.8760108, 0.041556, + 0.0556434, -0.2040259, 1.0572252, + ]); + static #c = new Float32Array([1, 1, 1]); + static #l = new Float32Array(3); + static #h = new Float32Array(3); + static #u = new Float32Array(3); + static #d = (24 / 116) ** 3 / 8; + constructor(e, t, a, r) { + super("CalRGB", 3); + if (!e) + throw new FormatError( + "WhitePoint missing - required for color space CalRGB", + ); + const [i, n, s] = (this.whitePoint = e), + [o, c, l] = (this.blackPoint = t || new Float32Array(3)); + [this.GR, this.GG, this.GB] = a || new Float32Array([1, 1, 1]); + [ + this.MXA, + this.MYA, + this.MZA, + this.MXB, + this.MYB, + this.MZB, + this.MXC, + this.MYC, + this.MZC, + ] = r || new Float32Array([1, 0, 0, 0, 1, 0, 0, 0, 1]); + if (i < 0 || s < 0 || 1 !== n) + throw new FormatError( + `Invalid WhitePoint components for ${this.name}, no fallback available`, + ); + if (o < 0 || c < 0 || l < 0) { + info( + `Invalid BlackPoint for ${this.name} [${o}, ${c}, ${l}], falling back to default.`, + ); + this.blackPoint = new Float32Array(3); + } + if (this.GR < 0 || this.GG < 0 || this.GB < 0) { + info( + `Invalid Gamma [${this.GR}, ${this.GG}, ${this.GB}] for ${this.name}, falling back to default.`, + ); + this.GR = this.GG = this.GB = 1; + } + } + #f(e, t, a) { + a[0] = e[0] * t[0] + e[1] * t[1] + e[2] * t[2]; + a[1] = e[3] * t[0] + e[4] * t[1] + e[5] * t[2]; + a[2] = e[6] * t[0] + e[7] * t[1] + e[8] * t[2]; + } + #g(e, t, a) { + a[0] = (1 * t[0]) / e[0]; + a[1] = (1 * t[1]) / e[1]; + a[2] = (1 * t[2]) / e[2]; + } + #p(e, t, a) { + a[0] = (0.95047 * t[0]) / e[0]; + a[1] = (1 * t[1]) / e[1]; + a[2] = (1.08883 * t[2]) / e[2]; + } + #m(e) { + return e <= 0.0031308 + ? MathClamp(12.92 * e, 0, 1) + : e >= 0.99554525 + ? 1 + : MathClamp(1.055 * e ** (1 / 2.4) - 0.055, 0, 1); + } + #b(e) { + return e < 0 + ? -this.#b(-e) + : e > 8 + ? ((e + 16) / 116) ** 3 + : e * CalRGBCS.#d; + } + #y(e, t, a) { + if (0 === e[0] && 0 === e[1] && 0 === e[2]) { + a[0] = t[0]; + a[1] = t[1]; + a[2] = t[2]; + return; + } + const r = this.#b(0), + i = (1 - r) / (1 - this.#b(e[0])), + n = 1 - i, + s = (1 - r) / (1 - this.#b(e[1])), + o = 1 - s, + c = (1 - r) / (1 - this.#b(e[2])), + l = 1 - c; + a[0] = t[0] * i + n; + a[1] = t[1] * s + o; + a[2] = t[2] * c + l; + } + #w(e, t, a) { + if (1 === e[0] && 1 === e[2]) { + a[0] = t[0]; + a[1] = t[1]; + a[2] = t[2]; + return; + } + const r = a; + this.#f(CalRGBCS.#n, t, r); + const i = CalRGBCS.#l; + this.#g(e, r, i); + this.#f(CalRGBCS.#s, i, a); + } + #x(e, t, a) { + const r = a; + this.#f(CalRGBCS.#n, t, r); + const i = CalRGBCS.#l; + this.#p(e, r, i); + this.#f(CalRGBCS.#s, i, a); + } + #i(e, t, a, r, i) { + const n = MathClamp(e[t] * i, 0, 1), + s = MathClamp(e[t + 1] * i, 0, 1), + o = MathClamp(e[t + 2] * i, 0, 1), + c = 1 === n ? 1 : n ** this.GR, + l = 1 === s ? 1 : s ** this.GG, + h = 1 === o ? 1 : o ** this.GB, + u = this.MXA * c + this.MXB * l + this.MXC * h, + d = this.MYA * c + this.MYB * l + this.MYC * h, + f = this.MZA * c + this.MZB * l + this.MZC * h, + g = CalRGBCS.#h; + g[0] = u; + g[1] = d; + g[2] = f; + const p = CalRGBCS.#u; + this.#w(this.whitePoint, g, p); + const m = CalRGBCS.#h; + this.#y(this.blackPoint, p, m); + const b = CalRGBCS.#u; + this.#x(CalRGBCS.#c, m, b); + const y = CalRGBCS.#h; + this.#f(CalRGBCS.#o, b, y); + a[r] = 255 * this.#m(y[0]); + a[r + 1] = 255 * this.#m(y[1]); + a[r + 2] = 255 * this.#m(y[2]); + } + getRgbItem(e, t, a, r) { + this.#i(e, t, a, r, 1); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = 1 / ((1 << n) - 1); + for (let n = 0; n < a; ++n) { + this.#i(e, t, r, i, o); + t += 3; + i += 3 + s; + } + } + getOutputLength(e, t) { + return ((e * (3 + t)) / 3) | 0; + } +} +class LabCS extends ColorSpace { + constructor(e, t, a) { + super("Lab", 3); + if (!e) + throw new FormatError( + "WhitePoint missing - required for color space Lab", + ); + [this.XW, this.YW, this.ZW] = e; + [this.amin, this.amax, this.bmin, this.bmax] = a || [-100, 100, -100, 100]; + [this.XB, this.YB, this.ZB] = t || [0, 0, 0]; + if (this.XW < 0 || this.ZW < 0 || 1 !== this.YW) + throw new FormatError( + "Invalid WhitePoint components, no fallback available", + ); + if (this.XB < 0 || this.YB < 0 || this.ZB < 0) { + info("Invalid BlackPoint, falling back to default"); + this.XB = this.YB = this.ZB = 0; + } + if (this.amin > this.amax || this.bmin > this.bmax) { + info("Invalid Range, falling back to defaults"); + this.amin = -100; + this.amax = 100; + this.bmin = -100; + this.bmax = 100; + } + } + #S(e) { + return e >= 6 / 29 ? e ** 3 : (108 / 841) * (e - 4 / 29); + } + #k(e, t, a, r) { + return a + (e * (r - a)) / t; + } + #i(e, t, a, r, i) { + let n = e[t], + s = e[t + 1], + o = e[t + 2]; + if (!1 !== a) { + n = this.#k(n, a, 0, 100); + s = this.#k(s, a, this.amin, this.amax); + o = this.#k(o, a, this.bmin, this.bmax); + } + s > this.amax ? (s = this.amax) : s < this.amin && (s = this.amin); + o > this.bmax ? (o = this.bmax) : o < this.bmin && (o = this.bmin); + const c = (n + 16) / 116, + l = c + s / 500, + h = c - o / 200, + u = this.XW * this.#S(l), + d = this.YW * this.#S(c), + f = this.ZW * this.#S(h); + let g, p, m; + if (this.ZW < 1) { + g = 3.1339 * u + -1.617 * d + -0.4906 * f; + p = -0.9785 * u + 1.916 * d + 0.0333 * f; + m = 0.072 * u + -0.229 * d + 1.4057 * f; + } else { + g = 3.2406 * u + -1.5372 * d + -0.4986 * f; + p = -0.9689 * u + 1.8758 * d + 0.0415 * f; + m = 0.0557 * u + -0.204 * d + 1.057 * f; + } + r[i] = 255 * Math.sqrt(g); + r[i + 1] = 255 * Math.sqrt(p); + r[i + 2] = 255 * Math.sqrt(m); + } + getRgbItem(e, t, a, r) { + this.#i(e, t, !1, a, r); + } + getRgbBuffer(e, t, a, r, i, n, s) { + const o = (1 << n) - 1; + for (let n = 0; n < a; n++) { + this.#i(e, t, o, r, i); + t += 3; + i += 3 + s; + } + } + getOutputLength(e, t) { + return ((e * (3 + t)) / 3) | 0; + } + isDefaultDecode(e, t) { + return !0; + } + get usesZeroToOneRange() { + return shadow(this, "usesZeroToOneRange", !1); + } +} +function fetchSync(e) { + const t = new XMLHttpRequest(); + t.open("GET", e, !1); + t.responseType = "arraybuffer"; + t.send(null); + return t.response; +} +class IccColorSpace extends ColorSpace { + #A; + #C; + static #v = !0; + static #F = null; + static #I = new FinalizationRegistry((e) => { + !(function qcms_drop_transformer(e) { + Da.qcms_drop_transformer(e); + })(e); + }); + constructor(e, t, a) { + if (!IccColorSpace.isUsable) throw new Error("No ICC color space support"); + super(t, a); + let r; + switch (a) { + case 1: + r = Ea.Gray8; + this.#C = (e, t, a) => + (function qcms_convert_one(e, t, a) { + Da.qcms_convert_one(e, t, a); + })(this.#A, 255 * e[t], a); + break; + case 3: + r = Ea.RGB8; + this.#C = (e, t, a) => + (function qcms_convert_three(e, t, a, r, i) { + Da.qcms_convert_three(e, t, a, r, i); + })(this.#A, 255 * e[t], 255 * e[t + 1], 255 * e[t + 2], a); + break; + case 4: + r = Ea.CMYK; + this.#C = (e, t, a) => + (function qcms_convert_four(e, t, a, r, i, n) { + Da.qcms_convert_four(e, t, a, r, i, n); + })( + this.#A, + 255 * e[t], + 255 * e[t + 1], + 255 * e[t + 2], + 255 * e[t + 3], + a, + ); + break; + default: + throw new Error(`Unsupported number of components: ${a}`); + } + this.#A = (function qcms_transformer_from_memory(e, t, a) { + const r = passArray8ToWasm0(e, Da.__wbindgen_malloc), + i = Na; + return Da.qcms_transformer_from_memory(r, i, t, a) >>> 0; + })(e, r, Pa.Perceptual); + if (!this.#A) throw new Error("Failed to create ICC color space"); + IccColorSpace.#I.register(this, this.#A); + } + getRgbHex(e, t) { + this.#C(e, t, !0); + return QCMS._cssColor; + } + getRgbItem(e, t, a, r) { + QCMS._destBuffer = a; + QCMS._destOffset = r; + QCMS._destLength = 3; + this.#C(e, t, !1); + QCMS._destBuffer = null; + } + getRgbBuffer(e, t, a, r, i, n, s) { + e = e.subarray(t, t + a * this.numComps); + if (8 !== n) { + const t = 255 / ((1 << n) - 1); + for (let a = 0, r = e.length; a < r; a++) e[a] *= t; + } + QCMS._mustAddAlpha = s && r.buffer === e.buffer; + QCMS._destBuffer = r; + QCMS._destOffset = i; + QCMS._destLength = a * (3 + s); + !(function qcms_convert_array(e, t) { + const a = passArray8ToWasm0(t, Da.__wbindgen_malloc), + r = Na; + Da.qcms_convert_array(e, a, r); + })(this.#A, e); + QCMS._mustAddAlpha = !1; + QCMS._destBuffer = null; + } + getOutputLength(e, t) { + return ((e / this.numComps) * (3 + t)) | 0; + } + static setOptions({ useWasm: e, useWorkerFetch: t, wasmUrl: a }) { + if (t) { + this.#v = e; + this.#F = a; + } else this.#v = !1; + } + static get isUsable() { + let e = !1; + if (this.#v) + if (this.#F) + try { + this._module = (function initSync(e) { + if (void 0 !== Da) return Da; + void 0 !== e && + (Object.getPrototypeOf(e) === Object.prototype + ? ({ module: e } = e) + : console.warn( + "using deprecated parameters for `initSync()`; pass a single object instead", + )); + const t = __wbg_get_imports(); + e instanceof WebAssembly.Module || (e = new WebAssembly.Module(e)); + return __wbg_finalize_init(new WebAssembly.Instance(e, t), e); + })({ module: fetchSync(`${this.#F}qcms_bg.wasm`) }); + e = !!this._module; + QCMS._memory = this._module.memory; + QCMS._makeHexColor = Util.makeHexColor; + } catch (e) { + warn(`ICCBased color space: "${e}".`); + } + else + warn("No ICC color space support due to missing `wasmUrl` API option"); + return shadow(this, "isUsable", e); + } +} +class CmykICCBasedCS extends IccColorSpace { + static #T; + constructor() { + super( + new Uint8Array( + fetchSync(`${CmykICCBasedCS.#T}CGATS001Compat-v2-micro.icc`), + ), + "DeviceCMYK", + 4, + ); + } + static setOptions({ iccUrl: e }) { + this.#T = e; + } + static get isUsable() { + let e = !1; + IccColorSpace.isUsable && + (this.#T + ? (e = !0) + : warn( + "No CMYK ICC profile support due to missing `iccUrl` API option", + )); + return shadow(this, "isUsable", e); + } +} +class Stream extends BaseStream { + constructor(e, t, a, r) { + super(); + this.bytes = e instanceof Uint8Array ? e : new Uint8Array(e); + this.start = t || 0; + this.pos = this.start; + this.end = t + a || this.bytes.length; + this.dict = r; + } + get length() { + return this.end - this.start; + } + get isEmpty() { + return 0 === this.length; + } + getByte() { + return this.pos >= this.end ? -1 : this.bytes[this.pos++]; + } + getBytes(e) { + const t = this.bytes, + a = this.pos, + r = this.end; + if (!e) return t.subarray(a, r); + let i = a + e; + i > r && (i = r); + this.pos = i; + return t.subarray(a, i); + } + getByteRange(e, t) { + e < 0 && (e = 0); + t > this.end && (t = this.end); + return this.bytes.subarray(e, t); + } + reset() { + this.pos = this.start; + } + moveStart() { + this.start = this.pos; + } + makeSubStream(e, t, a = null) { + return new Stream(this.bytes.buffer, e, t, a); + } +} +class StringStream extends Stream { + constructor(e) { + super(stringToBytes(e)); + } +} +class NullStream extends Stream { + constructor() { + super(new Uint8Array(0)); + } +} +class ChunkedStream extends Stream { + constructor(e, t, a) { + super(new Uint8Array(e), 0, e, null); + this.chunkSize = t; + this._loadedChunks = new Set(); + this.numChunks = Math.ceil(e / t); + this.manager = a; + this.progressiveDataLength = 0; + this.lastSuccessfulEnsureByteChunk = -1; + } + getMissingChunks() { + const e = []; + for (let t = 0, a = this.numChunks; t < a; ++t) + this._loadedChunks.has(t) || e.push(t); + return e; + } + get numChunksLoaded() { + return this._loadedChunks.size; + } + get isDataLoaded() { + return this.numChunksLoaded === this.numChunks; + } + onReceiveData(e, t) { + const a = this.chunkSize; + if (e % a != 0) throw new Error(`Bad begin offset: ${e}`); + const r = e + t.byteLength; + if (r % a != 0 && r !== this.bytes.length) + throw new Error(`Bad end offset: ${r}`); + this.bytes.set(new Uint8Array(t), e); + const i = Math.floor(e / a), + n = Math.floor((r - 1) / a) + 1; + for (let e = i; e < n; ++e) this._loadedChunks.add(e); + } + onReceiveProgressiveData(e) { + let t = this.progressiveDataLength; + const a = Math.floor(t / this.chunkSize); + this.bytes.set(new Uint8Array(e), t); + t += e.byteLength; + this.progressiveDataLength = t; + const r = t >= this.end ? this.numChunks : Math.floor(t / this.chunkSize); + for (let e = a; e < r; ++e) this._loadedChunks.add(e); + } + ensureByte(e) { + if (e < this.progressiveDataLength) return; + const t = Math.floor(e / this.chunkSize); + if (!(t > this.numChunks) && t !== this.lastSuccessfulEnsureByteChunk) { + if (!this._loadedChunks.has(t)) throw new MissingDataException(e, e + 1); + this.lastSuccessfulEnsureByteChunk = t; + } + } + ensureRange(e, t) { + if (e >= t) return; + if (t <= this.progressiveDataLength) return; + const a = Math.floor(e / this.chunkSize); + if (a > this.numChunks) return; + const r = Math.min( + Math.floor((t - 1) / this.chunkSize) + 1, + this.numChunks, + ); + for (let i = a; i < r; ++i) + if (!this._loadedChunks.has(i)) throw new MissingDataException(e, t); + } + nextEmptyChunk(e) { + const t = this.numChunks; + for (let a = 0; a < t; ++a) { + const r = (e + a) % t; + if (!this._loadedChunks.has(r)) return r; + } + return null; + } + hasChunk(e) { + return this._loadedChunks.has(e); + } + getByte() { + const e = this.pos; + if (e >= this.end) return -1; + e >= this.progressiveDataLength && this.ensureByte(e); + return this.bytes[this.pos++]; + } + getBytes(e) { + const t = this.bytes, + a = this.pos, + r = this.end; + if (!e) { + r > this.progressiveDataLength && this.ensureRange(a, r); + return t.subarray(a, r); + } + let i = a + e; + i > r && (i = r); + i > this.progressiveDataLength && this.ensureRange(a, i); + this.pos = i; + return t.subarray(a, i); + } + getByteRange(e, t) { + e < 0 && (e = 0); + t > this.end && (t = this.end); + t > this.progressiveDataLength && this.ensureRange(e, t); + return this.bytes.subarray(e, t); + } + makeSubStream(e, t, a = null) { + t + ? e + t > this.progressiveDataLength && this.ensureRange(e, e + t) + : e >= this.progressiveDataLength && this.ensureByte(e); + function ChunkedStreamSubstream() {} + ChunkedStreamSubstream.prototype = Object.create(this); + ChunkedStreamSubstream.prototype.getMissingChunks = function () { + const e = this.chunkSize, + t = Math.floor(this.start / e), + a = Math.floor((this.end - 1) / e) + 1, + r = []; + for (let e = t; e < a; ++e) this._loadedChunks.has(e) || r.push(e); + return r; + }; + Object.defineProperty(ChunkedStreamSubstream.prototype, "isDataLoaded", { + get() { + return ( + this.numChunksLoaded === this.numChunks || + 0 === this.getMissingChunks().length + ); + }, + configurable: !0, + }); + const r = new ChunkedStreamSubstream(); + r.pos = r.start = e; + r.end = e + t || this.end; + r.dict = a; + return r; + } + getBaseStreams() { + return [this]; + } +} +class ChunkedStreamManager { + constructor(e, t) { + this.length = t.length; + this.chunkSize = t.rangeChunkSize; + this.stream = new ChunkedStream(this.length, this.chunkSize, this); + this.pdfNetworkStream = e; + this.disableAutoFetch = t.disableAutoFetch; + this.msgHandler = t.msgHandler; + this.currRequestId = 0; + this._chunksNeededByRequest = new Map(); + this._requestsByChunk = new Map(); + this._promisesByRequest = new Map(); + this.progressiveDataLength = 0; + this.aborted = !1; + this._loadedStreamCapability = Promise.withResolvers(); + } + sendRequest(e, t) { + const a = this.pdfNetworkStream.getRangeReader(e, t); + a.isStreamingSupported || (a.onProgress = this.onProgress.bind(this)); + let r = [], + i = 0; + return new Promise((e, t) => { + const readChunk = ({ value: n, done: s }) => { + try { + if (s) { + const t = arrayBuffersToBytes(r); + r = null; + e(t); + return; + } + i += n.byteLength; + a.isStreamingSupported && this.onProgress({ loaded: i }); + r.push(n); + a.read().then(readChunk, t); + } catch (e) { + t(e); + } + }; + a.read().then(readChunk, t); + }).then((t) => { + this.aborted || this.onReceiveData({ chunk: t, begin: e }); + }); + } + requestAllChunks(e = !1) { + if (!e) { + const e = this.stream.getMissingChunks(); + this._requestChunks(e); + } + return this._loadedStreamCapability.promise; + } + _requestChunks(e) { + const t = this.currRequestId++, + a = new Set(); + this._chunksNeededByRequest.set(t, a); + for (const t of e) this.stream.hasChunk(t) || a.add(t); + if (0 === a.size) return Promise.resolve(); + const r = Promise.withResolvers(); + this._promisesByRequest.set(t, r); + const i = []; + for (const e of a) { + let a = this._requestsByChunk.get(e); + if (!a) { + a = []; + this._requestsByChunk.set(e, a); + i.push(e); + } + a.push(t); + } + if (i.length > 0) { + const e = this.groupChunks(i); + for (const t of e) { + const e = t.beginChunk * this.chunkSize, + a = Math.min(t.endChunk * this.chunkSize, this.length); + this.sendRequest(e, a).catch(r.reject); + } + } + return r.promise.catch((e) => { + if (!this.aborted) throw e; + }); + } + getStream() { + return this.stream; + } + requestRange(e, t) { + t = Math.min(t, this.length); + const a = this.getBeginChunk(e), + r = this.getEndChunk(t), + i = []; + for (let e = a; e < r; ++e) i.push(e); + return this._requestChunks(i); + } + requestRanges(e = []) { + const t = []; + for (const a of e) { + const e = this.getBeginChunk(a.begin), + r = this.getEndChunk(a.end); + for (let a = e; a < r; ++a) t.includes(a) || t.push(a); + } + t.sort((e, t) => e - t); + return this._requestChunks(t); + } + groupChunks(e) { + const t = []; + let a = -1, + r = -1; + for (let i = 0, n = e.length; i < n; ++i) { + const n = e[i]; + a < 0 && (a = n); + if (r >= 0 && r + 1 !== n) { + t.push({ beginChunk: a, endChunk: r + 1 }); + a = n; + } + i + 1 === e.length && t.push({ beginChunk: a, endChunk: n + 1 }); + r = n; + } + return t; + } + onProgress(e) { + this.msgHandler.send("DocProgress", { + loaded: this.stream.numChunksLoaded * this.chunkSize + e.loaded, + total: this.length, + }); + } + onReceiveData(e) { + const t = e.chunk, + a = void 0 === e.begin, + r = a ? this.progressiveDataLength : e.begin, + i = r + t.byteLength, + n = Math.floor(r / this.chunkSize), + s = + i < this.length + ? Math.floor(i / this.chunkSize) + : Math.ceil(i / this.chunkSize); + if (a) { + this.stream.onReceiveProgressiveData(t); + this.progressiveDataLength = i; + } else this.stream.onReceiveData(r, t); + this.stream.isDataLoaded && + this._loadedStreamCapability.resolve(this.stream); + const o = []; + for (let e = n; e < s; ++e) { + const t = this._requestsByChunk.get(e); + if (t) { + this._requestsByChunk.delete(e); + for (const a of t) { + const t = this._chunksNeededByRequest.get(a); + t.has(e) && t.delete(e); + t.size > 0 || o.push(a); + } + } + } + if (!this.disableAutoFetch && 0 === this._requestsByChunk.size) { + let e; + if (1 === this.stream.numChunksLoaded) { + const t = this.stream.numChunks - 1; + this.stream.hasChunk(t) || (e = t); + } else e = this.stream.nextEmptyChunk(s); + Number.isInteger(e) && this._requestChunks([e]); + } + for (const e of o) { + const t = this._promisesByRequest.get(e); + this._promisesByRequest.delete(e); + t.resolve(); + } + this.msgHandler.send("DocProgress", { + loaded: this.stream.numChunksLoaded * this.chunkSize, + total: this.length, + }); + } + onError(e) { + this._loadedStreamCapability.reject(e); + } + getBeginChunk(e) { + return Math.floor(e / this.chunkSize); + } + getEndChunk(e) { + return Math.floor((e - 1) / this.chunkSize) + 1; + } + abort(e) { + this.aborted = !0; + this.pdfNetworkStream?.cancelAllRequests(e); + for (const t of this._promisesByRequest.values()) t.reject(e); + } +} +function convertToRGBA(e) { + switch (e.kind) { + case k: + return convertBlackAndWhiteToRGBA(e); + case C: + return (function convertRGBToRGBA({ + src: e, + srcPos: t = 0, + dest: a, + destPos: r = 0, + width: i, + height: n, + }) { + let s = 0; + const o = i * n * 3, + c = o >> 2, + l = new Uint32Array(e.buffer, t, c); + if (FeatureTest.isLittleEndian) { + for (; s < c - 2; s += 3, r += 4) { + const e = l[s], + t = l[s + 1], + i = l[s + 2]; + a[r] = 4278190080 | e; + a[r + 1] = (e >>> 24) | (t << 8) | 4278190080; + a[r + 2] = (t >>> 16) | (i << 16) | 4278190080; + a[r + 3] = (i >>> 8) | 4278190080; + } + for (let i = 4 * s, n = t + o; i < n; i += 3) + a[r++] = e[i] | (e[i + 1] << 8) | (e[i + 2] << 16) | 4278190080; + } else { + for (; s < c - 2; s += 3, r += 4) { + const e = l[s], + t = l[s + 1], + i = l[s + 2]; + a[r] = 255 | e; + a[r + 1] = (e << 24) | (t >>> 8) | 255; + a[r + 2] = (t << 16) | (i >>> 16) | 255; + a[r + 3] = (i << 8) | 255; + } + for (let i = 4 * s, n = t + o; i < n; i += 3) + a[r++] = (e[i] << 24) | (e[i + 1] << 16) | (e[i + 2] << 8) | 255; + } + return { srcPos: t + o, destPos: r }; + })(e); + } + return null; +} +function convertBlackAndWhiteToRGBA({ + src: e, + srcPos: t = 0, + dest: a, + width: r, + height: i, + nonBlackColor: n = 4294967295, + inverseDecode: s = !1, +}) { + const o = FeatureTest.isLittleEndian ? 4278190080 : 255, + [c, l] = s ? [n, o] : [o, n], + h = r >> 3, + u = 7 & r, + d = e.length; + a = new Uint32Array(a.buffer); + let f = 0; + for (let r = 0; r < i; r++) { + for (const r = t + h; t < r; t++) { + const r = t < d ? e[t] : 255; + a[f++] = 128 & r ? l : c; + a[f++] = 64 & r ? l : c; + a[f++] = 32 & r ? l : c; + a[f++] = 16 & r ? l : c; + a[f++] = 8 & r ? l : c; + a[f++] = 4 & r ? l : c; + a[f++] = 2 & r ? l : c; + a[f++] = 1 & r ? l : c; + } + if (0 === u) continue; + const r = t < d ? e[t++] : 255; + for (let e = 0; e < u; e++) a[f++] = r & (1 << (7 - e)) ? l : c; + } + return { srcPos: t, destPos: f }; +} +class ImageResizer { + static #O = 2048; + static #M = FeatureTest.isImageDecoderSupported; + constructor(e, t) { + this._imgData = e; + this._isMask = t; + } + static get canUseImageDecoder() { + return shadow( + this, + "canUseImageDecoder", + this.#M ? ImageDecoder.isTypeSupported("image/bmp") : Promise.resolve(!1), + ); + } + static needsToBeResized(e, t) { + if (e <= this.#O && t <= this.#O) return !1; + const { MAX_DIM: a } = this; + if (e > a || t > a) return !0; + const r = e * t; + if (this._hasMaxArea) return r > this.MAX_AREA; + if (r < this.#O ** 2) return !1; + if (this._areGoodDims(e, t)) { + this.#O = Math.max(this.#O, Math.floor(Math.sqrt(e * t))); + return !1; + } + this.#O = this._guessMax(this.#O, a, 128, 0); + return r > (this.MAX_AREA = this.#O ** 2); + } + static getReducePowerForJPX(e, t, a) { + const r = e * t, + i = 2 ** 30 / (4 * a); + if (!this.needsToBeResized(e, t)) + return r > i ? Math.ceil(Math.log2(r / i)) : 0; + const { MAX_DIM: n, MAX_AREA: s } = this, + o = Math.max(e / n, t / n, Math.sqrt(r / Math.min(i, s))); + return Math.ceil(Math.log2(o)); + } + static get MAX_DIM() { + return shadow(this, "MAX_DIM", this._guessMax(2048, 65537, 0, 1)); + } + static get MAX_AREA() { + this._hasMaxArea = !0; + return shadow( + this, + "MAX_AREA", + this._guessMax(this.#O, this.MAX_DIM, 128, 0) ** 2, + ); + } + static set MAX_AREA(e) { + if (e >= 0) { + this._hasMaxArea = !0; + shadow(this, "MAX_AREA", e); + } + } + static setOptions({ + canvasMaxAreaInBytes: e = -1, + isImageDecoderSupported: t = !1, + }) { + this._hasMaxArea || (this.MAX_AREA = e >> 2); + this.#M = t; + } + static _areGoodDims(e, t) { + try { + const a = new OffscreenCanvas(e, t), + r = a.getContext("2d"); + r.fillRect(0, 0, 1, 1); + const i = r.getImageData(0, 0, 1, 1).data[3]; + a.width = a.height = 1; + return 0 !== i; + } catch { + return !1; + } + } + static _guessMax(e, t, a, r) { + for (; e + a + 1 < t; ) { + const a = Math.floor((e + t) / 2), + i = r || a; + this._areGoodDims(a, i) ? (e = a) : (t = a); + } + return e; + } + static async createImage(e, t = !1) { + return new ImageResizer(e, t)._createImage(); + } + async _createImage() { + const { _imgData: e } = this, + { width: t, height: a } = e; + if (t * a * 4 > va) { + const e = this.#D(); + if (e) return e; + } + const r = this._encodeBMP(); + let i, n; + if (await ImageResizer.canUseImageDecoder) { + i = new ImageDecoder({ + data: r, + type: "image/bmp", + preferAnimation: !1, + transfer: [r.buffer], + }); + n = i + .decode() + .catch((e) => { + warn(`BMP image decoding failed: ${e}`); + return createImageBitmap( + new Blob([this._encodeBMP().buffer], { type: "image/bmp" }), + ); + }) + .finally(() => { + i.close(); + }); + } else n = createImageBitmap(new Blob([r.buffer], { type: "image/bmp" })); + const { MAX_AREA: s, MAX_DIM: o } = ImageResizer, + c = Math.max(t / o, a / o, Math.sqrt((t * a) / s)), + l = Math.max(c, 2), + h = Math.round(10 * (c + 1.25)) / 10 / l, + u = Math.floor(Math.log2(h)), + d = new Array(u + 2).fill(2); + d[0] = l; + d.splice(-1, 1, h / (1 << u)); + let f = t, + g = a; + const p = await n; + let m = p.image || p; + for (const e of d) { + const t = f, + a = g; + f = Math.floor(f / e) - 1; + g = Math.floor(g / e) - 1; + const r = new OffscreenCanvas(f, g); + r.getContext("2d").drawImage(m, 0, 0, t, a, 0, 0, f, g); + m.close(); + m = r.transferToImageBitmap(); + } + e.data = null; + e.bitmap = m; + e.width = f; + e.height = g; + return e; + } + #D() { + const { _imgData: e } = this, + { data: t, width: a, height: r, kind: i } = e, + n = a * r * 4, + s = Math.ceil(Math.log2(n / va)), + o = a >> s, + c = r >> s; + let l, + h = r; + try { + l = new Uint8Array(n); + } catch { + let e = Math.floor(Math.log2(n + 1)); + for (;;) + try { + l = new Uint8Array(2 ** e - 1); + break; + } catch { + e -= 1; + } + h = Math.floor((2 ** e - 1) / (4 * a)); + const t = a * h * 4; + t < l.length && (l = new Uint8Array(t)); + } + const u = new Uint32Array(l.buffer), + d = new Uint32Array(o * c); + let f = 0, + g = 0; + const p = Math.ceil(r / h), + m = r % h == 0 ? r : r % h; + for (let e = 0; e < p; e++) { + const r = e < p - 1 ? h : m; + ({ srcPos: f } = convertToRGBA({ + kind: i, + src: t, + dest: u, + width: a, + height: r, + inverseDecode: this._isMask, + srcPos: f, + })); + for (let e = 0, t = r >> s; e < t; e++) { + const t = u.subarray((e << s) * a); + for (let e = 0; e < o; e++) d[g++] = t[e << s]; + } + } + if (ImageResizer.needsToBeResized(o, c)) { + e.data = d; + e.width = o; + e.height = c; + e.kind = v; + return null; + } + const b = new OffscreenCanvas(o, c); + b.getContext("2d", { willReadFrequently: !0 }).putImageData( + new ImageData(new Uint8ClampedArray(d.buffer), o, c), + 0, + 0, + ); + e.data = null; + e.bitmap = b.transferToImageBitmap(); + e.width = o; + e.height = c; + return e; + } + _encodeBMP() { + const { width: e, height: t, kind: a } = this._imgData; + let r, + i = this._imgData.data, + n = new Uint8Array(0), + s = n, + o = 0; + switch (a) { + case k: { + r = 1; + n = new Uint8Array( + this._isMask + ? [255, 255, 255, 255, 0, 0, 0, 0] + : [0, 0, 0, 0, 255, 255, 255, 255], + ); + const a = (e + 7) >> 3, + s = (a + 3) & -4; + if (a !== s) { + const e = new Uint8Array(s * t); + let r = 0; + for (let n = 0, o = t * a; n < o; n += a, r += s) + e.set(i.subarray(n, n + a), r); + i = e; + } + break; + } + case C: + r = 24; + if (3 & e) { + const a = 3 * e, + r = (a + 3) & -4, + n = r - a, + s = new Uint8Array(r * t); + let o = 0; + for (let e = 0, r = t * a; e < r; e += a) { + const t = i.subarray(e, e + a); + for (let e = 0; e < a; e += 3) { + s[o++] = t[e + 2]; + s[o++] = t[e + 1]; + s[o++] = t[e]; + } + o += n; + } + i = s; + } else + for (let e = 0, t = i.length; e < t; e += 3) { + const t = i[e]; + i[e] = i[e + 2]; + i[e + 2] = t; + } + break; + case v: + r = 32; + o = 3; + s = new Uint8Array(68); + const a = new DataView(s.buffer); + if (FeatureTest.isLittleEndian) { + a.setUint32(0, 255, !0); + a.setUint32(4, 65280, !0); + a.setUint32(8, 16711680, !0); + a.setUint32(12, 4278190080, !0); + } else { + a.setUint32(0, 4278190080, !0); + a.setUint32(4, 16711680, !0); + a.setUint32(8, 65280, !0); + a.setUint32(12, 255, !0); + } + break; + default: + throw new Error("invalid format"); + } + let c = 0; + const l = 40 + s.length, + h = 14 + l + n.length + i.length, + u = new Uint8Array(h), + d = new DataView(u.buffer); + d.setUint16(c, 19778, !0); + c += 2; + d.setUint32(c, h, !0); + c += 4; + d.setUint32(c, 0, !0); + c += 4; + d.setUint32(c, 14 + l + n.length, !0); + c += 4; + d.setUint32(c, l, !0); + c += 4; + d.setInt32(c, e, !0); + c += 4; + d.setInt32(c, -t, !0); + c += 4; + d.setUint16(c, 1, !0); + c += 2; + d.setUint16(c, r, !0); + c += 2; + d.setUint32(c, o, !0); + c += 4; + d.setUint32(c, 0, !0); + c += 4; + d.setInt32(c, 0, !0); + c += 4; + d.setInt32(c, 0, !0); + c += 4; + d.setUint32(c, n.length / 4, !0); + c += 4; + d.setUint32(c, 0, !0); + c += 4; + u.set(s, c); + c += s.length; + u.set(n, c); + c += n.length; + u.set(i, c); + return u; + } +} +const La = new Uint8Array(0); +class DecodeStream extends BaseStream { + constructor(e) { + super(); + this._rawMinBufferLength = e || 0; + this.pos = 0; + this.bufferLength = 0; + this.eof = !1; + this.buffer = La; + this.minBufferLength = 512; + if (e) for (; this.minBufferLength < e; ) this.minBufferLength *= 2; + } + get isEmpty() { + for (; !this.eof && 0 === this.bufferLength; ) this.readBlock(); + return 0 === this.bufferLength; + } + ensureBuffer(e) { + const t = this.buffer; + if (e <= t.byteLength) return t; + let a = this.minBufferLength; + for (; a < e; ) a *= 2; + const r = new Uint8Array(a); + r.set(t); + return (this.buffer = r); + } + getByte() { + const e = this.pos; + for (; this.bufferLength <= e; ) { + if (this.eof) return -1; + this.readBlock(); + } + return this.buffer[this.pos++]; + } + getBytes(e, t = null) { + const a = this.pos; + let r; + if (e) { + this.ensureBuffer(a + e); + r = a + e; + for (; !this.eof && this.bufferLength < r; ) this.readBlock(t); + const i = this.bufferLength; + r > i && (r = i); + } else { + for (; !this.eof; ) this.readBlock(t); + r = this.bufferLength; + } + this.pos = r; + return this.buffer.subarray(a, r); + } + async getImageData(e, t) { + if (!this.canAsyncDecodeImageFromBuffer) + return this.isAsyncDecoder + ? this.decodeImage(null, t) + : this.getBytes(e, t); + const a = await this.stream.asyncGetBytes(); + return this.decodeImage(a, t); + } + reset() { + this.pos = 0; + } + makeSubStream(e, t, a = null) { + if (void 0 === t) for (; !this.eof; ) this.readBlock(); + else { + const a = e + t; + for (; this.bufferLength <= a && !this.eof; ) this.readBlock(); + } + return new Stream(this.buffer, e, t, a); + } + getBaseStreams() { + return this.str ? this.str.getBaseStreams() : null; + } +} +class StreamsSequenceStream extends DecodeStream { + constructor(e, t = null) { + e = e.filter((e) => e instanceof BaseStream); + let a = 0; + for (const t of e) + a += t instanceof DecodeStream ? t._rawMinBufferLength : t.length; + super(a); + this.streams = e; + this._onError = t; + } + readBlock() { + const e = this.streams; + if (0 === e.length) { + this.eof = !0; + return; + } + const t = e.shift(); + let a; + try { + a = t.getBytes(); + } catch (e) { + if (this._onError) { + this._onError(e, t.dict?.objId); + return; + } + throw e; + } + const r = this.bufferLength, + i = r + a.length; + this.ensureBuffer(i).set(a, r); + this.bufferLength = i; + } + getBaseStreams() { + const e = []; + for (const t of this.streams) { + const a = t.getBaseStreams(); + a && e.push(...a); + } + return e.length > 0 ? e : null; + } +} +class ColorSpaceUtils { + static parse({ + cs: e, + xref: t, + resources: a = null, + pdfFunctionFactory: r, + globalColorSpaceCache: i, + localColorSpaceCache: n, + asyncIfNotCached: s = !1, + }) { + const o = { + xref: t, + resources: a, + pdfFunctionFactory: r, + globalColorSpaceCache: i, + localColorSpaceCache: n, + }; + let c, l, h; + if (e instanceof Ref) { + l = e; + const a = i.getByRef(l) || n.getByRef(l); + if (a) return a; + e = t.fetch(e); + } + if (e instanceof Name) { + c = e.name; + const t = n.getByName(c); + if (t) return t; + } + try { + h = this.#B(e, o); + } catch (e) { + if (s && !(e instanceof MissingDataException)) return Promise.reject(e); + throw e; + } + if (c || l) { + n.set(c, l, h); + l && i.set(null, l, h); + } + return s ? Promise.resolve(h) : h; + } + static #R(e, t) { + const { globalColorSpaceCache: a } = t; + let r; + if (e instanceof Ref) { + r = e; + const t = a.getByRef(r); + if (t) return t; + } + const i = this.#B(e, t); + r && a.set(null, r, i); + return i; + } + static #B(e, t) { + const { + xref: a, + resources: r, + pdfFunctionFactory: i, + globalColorSpaceCache: n, + } = t; + if ((e = a.fetchIfRef(e)) instanceof Name) + switch (e.name) { + case "G": + case "DeviceGray": + return this.gray; + case "RGB": + case "DeviceRGB": + return this.rgb; + case "DeviceRGBA": + return this.rgba; + case "CMYK": + case "DeviceCMYK": + return this.cmyk; + case "Pattern": + return new PatternCS(null); + default: + if (r instanceof Dict) { + const a = r.get("ColorSpace"); + if (a instanceof Dict) { + const r = a.get(e.name); + if (r) { + if (r instanceof Name) return this.#B(r, t); + e = r; + break; + } + } + } + warn(`Unrecognized ColorSpace: ${e.name}`); + return this.gray; + } + if (Array.isArray(e)) { + const r = a.fetchIfRef(e[0]).name; + let s, o, c, l, h, u; + switch (r) { + case "G": + case "DeviceGray": + return this.gray; + case "RGB": + case "DeviceRGB": + return this.rgb; + case "CMYK": + case "DeviceCMYK": + return this.cmyk; + case "CalGray": + s = a.fetchIfRef(e[1]); + l = s.getArray("WhitePoint"); + h = s.getArray("BlackPoint"); + u = s.get("Gamma"); + return new CalGrayCS(l, h, u); + case "CalRGB": + s = a.fetchIfRef(e[1]); + l = s.getArray("WhitePoint"); + h = s.getArray("BlackPoint"); + u = s.getArray("Gamma"); + const d = s.getArray("Matrix"); + return new CalRGBCS(l, h, u, d); + case "ICCBased": + const f = e[1] instanceof Ref; + if (f) { + const t = n.getByRef(e[1]); + if (t) return t; + } + const g = a.fetchIfRef(e[1]), + p = g.dict; + o = p.get("N"); + if (IccColorSpace.isUsable) + try { + const t = new IccColorSpace(g.getBytes(), "ICCBased", o); + f && n.set(null, e[1], t); + return t; + } catch (t) { + if (t instanceof MissingDataException) throw t; + warn(`ICCBased color space (${e[1]}): "${t}".`); + } + const m = p.getRaw("Alternate"); + if (m) { + const e = this.#R(m, t); + if (e.numComps === o) return e; + warn("ICCBased color space: Ignoring incorrect /Alternate entry."); + } + if (1 === o) return this.gray; + if (3 === o) return this.rgb; + if (4 === o) return this.cmyk; + break; + case "Pattern": + c = e[1] || null; + c && (c = this.#R(c, t)); + return new PatternCS(c); + case "I": + case "Indexed": + c = this.#R(e[1], t); + const b = MathClamp(a.fetchIfRef(e[2]), 0, 255), + y = a.fetchIfRef(e[3]); + return new IndexedCS(c, b, y); + case "Separation": + case "DeviceN": + const w = a.fetchIfRef(e[1]); + o = Array.isArray(w) ? w.length : 1; + c = this.#R(e[2], t); + const x = i.create(e[3]); + return new AlternateCS(o, c, x); + case "Lab": + s = a.fetchIfRef(e[1]); + l = s.getArray("WhitePoint"); + h = s.getArray("BlackPoint"); + const S = s.getArray("Range"); + return new LabCS(l, h, S); + default: + warn(`Unimplemented ColorSpace object: ${r}`); + return this.gray; + } + } + warn(`Unrecognized ColorSpace object: ${e}`); + return this.gray; + } + static get gray() { + return shadow(this, "gray", new DeviceGrayCS()); + } + static get rgb() { + return shadow(this, "rgb", new DeviceRgbCS()); + } + static get rgba() { + return shadow(this, "rgba", new DeviceRgbaCS()); + } + static get cmyk() { + if (CmykICCBasedCS.isUsable) + try { + return shadow(this, "cmyk", new CmykICCBasedCS()); + } catch { + warn("CMYK fallback: DeviceCMYK"); + } + return shadow(this, "cmyk", new DeviceCmykCS()); + } +} +class JpegError extends fa { + constructor(e) { + super(e, "JpegError"); + } +} +class DNLMarkerError extends fa { + constructor(e, t) { + super(e, "DNLMarkerError"); + this.scanLines = t; + } +} +class EOIMarkerError extends fa { + constructor(e) { + super(e, "EOIMarkerError"); + } +} +const ja = new Uint8Array([ + 0, 1, 8, 16, 9, 2, 3, 10, 17, 24, 32, 25, 18, 11, 4, 5, 12, 19, 26, 33, 40, + 48, 41, 34, 27, 20, 13, 6, 7, 14, 21, 28, 35, 42, 49, 56, 57, 50, 43, 36, + 29, 22, 15, 23, 30, 37, 44, 51, 58, 59, 52, 45, 38, 31, 39, 46, 53, 60, 61, + 54, 47, 55, 62, 63, + ]), + _a = 4017, + Ua = 799, + Xa = 3406, + qa = 2276, + Ha = 1567, + Wa = 3784, + za = 5793, + $a = 2896; +function buildHuffmanTable(e, t) { + let a, + r, + i = 0, + n = 16; + for (; n > 0 && !e[n - 1]; ) n--; + const s = [{ children: [], index: 0 }]; + let o, + c = s[0]; + for (a = 0; a < n; a++) { + for (r = 0; r < e[a]; r++) { + c = s.pop(); + c.children[c.index] = t[i]; + for (; c.index > 0; ) c = s.pop(); + c.index++; + s.push(c); + for (; s.length <= a; ) { + s.push((o = { children: [], index: 0 })); + c.children[c.index] = o.children; + c = o; + } + i++; + } + if (a + 1 < n) { + s.push((o = { children: [], index: 0 })); + c.children[c.index] = o.children; + c = o; + } + } + return s[0].children; +} +function getBlockBufferOffset(e, t, a) { + return 64 * ((e.blocksPerLine + 1) * t + a); +} +function decodeScan(e, t, a, r, i, n, s, o, c, l = !1) { + const h = a.mcusPerLine, + u = a.progressive, + d = t; + let f = 0, + g = 0; + function readBit() { + if (g > 0) { + g--; + return (f >> g) & 1; + } + f = e[t++]; + if (255 === f) { + const r = e[t++]; + if (r) { + if (220 === r && l) { + const r = readUint16(e, (t += 2)); + t += 2; + if (r > 0 && r !== a.scanLines) + throw new DNLMarkerError( + "Found DNL marker (0xFFDC) while parsing scan data", + r, + ); + } else if (217 === r) { + if (l) { + const e = y * (8 === a.precision ? 8 : 0); + if (e > 0 && Math.round(a.scanLines / e) >= 5) + throw new DNLMarkerError( + "Found EOI marker (0xFFD9) while parsing scan data, possibly caused by incorrect `scanLines` parameter", + e, + ); + } + throw new EOIMarkerError( + "Found EOI marker (0xFFD9) while parsing scan data", + ); + } + throw new JpegError(`unexpected marker ${((f << 8) | r).toString(16)}`); + } + } + g = 7; + return f >>> 7; + } + function decodeHuffman(e) { + let t = e; + for (;;) { + t = t[readBit()]; + switch (typeof t) { + case "number": + return t; + case "object": + continue; + } + throw new JpegError("invalid huffman sequence"); + } + } + function receive(e) { + let t = 0; + for (; e > 0; ) { + t = (t << 1) | readBit(); + e--; + } + return t; + } + function receiveAndExtend(e) { + if (1 === e) return 1 === readBit() ? 1 : -1; + const t = receive(e); + return t >= 1 << (e - 1) ? t : t + (-1 << e) + 1; + } + let p = 0; + let m, + b = 0; + let y = 0; + function decodeMcu(e, t, a, r, i) { + const n = a % h; + y = ((a / h) | 0) * e.v + r; + const s = n * e.h + i; + t(e, getBlockBufferOffset(e, y, s)); + } + function decodeBlock(e, t, a) { + y = (a / e.blocksPerLine) | 0; + const r = a % e.blocksPerLine; + t(e, getBlockBufferOffset(e, y, r)); + } + const w = r.length; + let x, S, k, C, v, F; + F = u + ? 0 === n + ? 0 === o + ? function decodeDCFirst(e, t) { + const a = decodeHuffman(e.huffmanTableDC), + r = 0 === a ? 0 : receiveAndExtend(a) << c; + e.blockData[t] = e.pred += r; + } + : function decodeDCSuccessive(e, t) { + e.blockData[t] |= readBit() << c; + } + : 0 === o + ? function decodeACFirst(e, t) { + if (p > 0) { + p--; + return; + } + let a = n; + const r = s; + for (; a <= r; ) { + const r = decodeHuffman(e.huffmanTableAC), + i = 15 & r, + n = r >> 4; + if (0 === i) { + if (n < 15) { + p = receive(n) + (1 << n) - 1; + break; + } + a += 16; + continue; + } + a += n; + const s = ja[a]; + e.blockData[t + s] = receiveAndExtend(i) * (1 << c); + a++; + } + } + : function decodeACSuccessive(e, t) { + let a = n; + const r = s; + let i, + o, + l = 0; + for (; a <= r; ) { + const r = t + ja[a], + n = e.blockData[r] < 0 ? -1 : 1; + switch (b) { + case 0: + o = decodeHuffman(e.huffmanTableAC); + i = 15 & o; + l = o >> 4; + if (0 === i) + if (l < 15) { + p = receive(l) + (1 << l); + b = 4; + } else { + l = 16; + b = 1; + } + else { + if (1 !== i) throw new JpegError("invalid ACn encoding"); + m = receiveAndExtend(i); + b = l ? 2 : 3; + } + continue; + case 1: + case 2: + if (e.blockData[r]) e.blockData[r] += n * (readBit() << c); + else { + l--; + 0 === l && (b = 2 === b ? 3 : 0); + } + break; + case 3: + if (e.blockData[r]) e.blockData[r] += n * (readBit() << c); + else { + e.blockData[r] = m << c; + b = 0; + } + break; + case 4: + e.blockData[r] && (e.blockData[r] += n * (readBit() << c)); + } + a++; + } + if (4 === b) { + p--; + 0 === p && (b = 0); + } + } + : function decodeBaseline(e, t) { + const a = decodeHuffman(e.huffmanTableDC), + r = 0 === a ? 0 : receiveAndExtend(a); + e.blockData[t] = e.pred += r; + let i = 1; + for (; i < 64; ) { + const a = decodeHuffman(e.huffmanTableAC), + r = 15 & a, + n = a >> 4; + if (0 === r) { + if (n < 15) break; + i += 16; + continue; + } + i += n; + const s = ja[i]; + e.blockData[t + s] = receiveAndExtend(r); + i++; + } + }; + let T, + O = 0; + const M = + 1 === w ? r[0].blocksPerLine * r[0].blocksPerColumn : h * a.mcusPerColumn; + let D, R; + for (; O <= M; ) { + const a = i ? Math.min(M - O, i) : M; + if (a > 0) { + for (S = 0; S < w; S++) r[S].pred = 0; + p = 0; + if (1 === w) { + x = r[0]; + for (v = 0; v < a; v++) { + decodeBlock(x, F, O); + O++; + } + } else + for (v = 0; v < a; v++) { + for (S = 0; S < w; S++) { + x = r[S]; + D = x.h; + R = x.v; + for (k = 0; k < R; k++) + for (C = 0; C < D; C++) decodeMcu(x, F, O, k, C); + } + O++; + } + } + g = 0; + T = findNextFileMarker(e, t); + if (!T) break; + if (T.invalid) { + warn( + `decodeScan - ${a > 0 ? "unexpected" : "excessive"} MCU data, current marker is: ${T.invalid}`, + ); + t = T.offset; + } + if (!(T.marker >= 65488 && T.marker <= 65495)) break; + t += 2; + } + return t - d; +} +function quantizeAndInverse(e, t, a) { + const r = e.quantizationTable, + i = e.blockData; + let n, s, o, c, l, h, u, d, f, g, p, m, b, y, w, x, S; + if (!r) throw new JpegError("missing required Quantization Table."); + for (let e = 0; e < 64; e += 8) { + f = i[t + e]; + g = i[t + e + 1]; + p = i[t + e + 2]; + m = i[t + e + 3]; + b = i[t + e + 4]; + y = i[t + e + 5]; + w = i[t + e + 6]; + x = i[t + e + 7]; + f *= r[e]; + if (g | p | m | b | y | w | x) { + g *= r[e + 1]; + p *= r[e + 2]; + m *= r[e + 3]; + b *= r[e + 4]; + y *= r[e + 5]; + w *= r[e + 6]; + x *= r[e + 7]; + n = (za * f + 128) >> 8; + s = (za * b + 128) >> 8; + o = p; + c = w; + l = ($a * (g - x) + 128) >> 8; + d = ($a * (g + x) + 128) >> 8; + h = m << 4; + u = y << 4; + n = (n + s + 1) >> 1; + s = n - s; + S = (o * Wa + c * Ha + 128) >> 8; + o = (o * Ha - c * Wa + 128) >> 8; + c = S; + l = (l + u + 1) >> 1; + u = l - u; + d = (d + h + 1) >> 1; + h = d - h; + n = (n + c + 1) >> 1; + c = n - c; + s = (s + o + 1) >> 1; + o = s - o; + S = (l * qa + d * Xa + 2048) >> 12; + l = (l * Xa - d * qa + 2048) >> 12; + d = S; + S = (h * Ua + u * _a + 2048) >> 12; + h = (h * _a - u * Ua + 2048) >> 12; + u = S; + a[e] = n + d; + a[e + 7] = n - d; + a[e + 1] = s + u; + a[e + 6] = s - u; + a[e + 2] = o + h; + a[e + 5] = o - h; + a[e + 3] = c + l; + a[e + 4] = c - l; + } else { + S = (za * f + 512) >> 10; + a[e] = S; + a[e + 1] = S; + a[e + 2] = S; + a[e + 3] = S; + a[e + 4] = S; + a[e + 5] = S; + a[e + 6] = S; + a[e + 7] = S; + } + } + for (let e = 0; e < 8; ++e) { + f = a[e]; + g = a[e + 8]; + p = a[e + 16]; + m = a[e + 24]; + b = a[e + 32]; + y = a[e + 40]; + w = a[e + 48]; + x = a[e + 56]; + if (g | p | m | b | y | w | x) { + n = (za * f + 2048) >> 12; + s = (za * b + 2048) >> 12; + o = p; + c = w; + l = ($a * (g - x) + 2048) >> 12; + d = ($a * (g + x) + 2048) >> 12; + h = m; + u = y; + n = 4112 + ((n + s + 1) >> 1); + s = n - s; + S = (o * Wa + c * Ha + 2048) >> 12; + o = (o * Ha - c * Wa + 2048) >> 12; + c = S; + l = (l + u + 1) >> 1; + u = l - u; + d = (d + h + 1) >> 1; + h = d - h; + n = (n + c + 1) >> 1; + c = n - c; + s = (s + o + 1) >> 1; + o = s - o; + S = (l * qa + d * Xa + 2048) >> 12; + l = (l * Xa - d * qa + 2048) >> 12; + d = S; + S = (h * Ua + u * _a + 2048) >> 12; + h = (h * _a - u * Ua + 2048) >> 12; + u = S; + f = n + d; + x = n - d; + g = s + u; + w = s - u; + p = o + h; + y = o - h; + m = c + l; + b = c - l; + f < 16 ? (f = 0) : f >= 4080 ? (f = 255) : (f >>= 4); + g < 16 ? (g = 0) : g >= 4080 ? (g = 255) : (g >>= 4); + p < 16 ? (p = 0) : p >= 4080 ? (p = 255) : (p >>= 4); + m < 16 ? (m = 0) : m >= 4080 ? (m = 255) : (m >>= 4); + b < 16 ? (b = 0) : b >= 4080 ? (b = 255) : (b >>= 4); + y < 16 ? (y = 0) : y >= 4080 ? (y = 255) : (y >>= 4); + w < 16 ? (w = 0) : w >= 4080 ? (w = 255) : (w >>= 4); + x < 16 ? (x = 0) : x >= 4080 ? (x = 255) : (x >>= 4); + i[t + e] = f; + i[t + e + 8] = g; + i[t + e + 16] = p; + i[t + e + 24] = m; + i[t + e + 32] = b; + i[t + e + 40] = y; + i[t + e + 48] = w; + i[t + e + 56] = x; + } else { + S = (za * f + 8192) >> 14; + S = S < -2040 ? 0 : S >= 2024 ? 255 : (S + 2056) >> 4; + i[t + e] = S; + i[t + e + 8] = S; + i[t + e + 16] = S; + i[t + e + 24] = S; + i[t + e + 32] = S; + i[t + e + 40] = S; + i[t + e + 48] = S; + i[t + e + 56] = S; + } + } +} +function buildComponentData(e, t) { + const a = t.blocksPerLine, + r = t.blocksPerColumn, + i = new Int16Array(64); + for (let e = 0; e < r; e++) + for (let r = 0; r < a; r++) { + quantizeAndInverse(t, getBlockBufferOffset(t, e, r), i); + } + return t.blockData; +} +function findNextFileMarker(e, t, a = t) { + const r = e.length - 1; + let i = a < t ? a : t; + if (t >= r) return null; + const n = readUint16(e, t); + if (n >= 65472 && n <= 65534) return { invalid: null, marker: n, offset: t }; + let s = readUint16(e, i); + for (; !(s >= 65472 && s <= 65534); ) { + if (++i >= r) return null; + s = readUint16(e, i); + } + return { invalid: n.toString(16), marker: s, offset: i }; +} +function prepareComponents(e) { + const t = Math.ceil(e.samplesPerLine / 8 / e.maxH), + a = Math.ceil(e.scanLines / 8 / e.maxV); + for (const r of e.components) { + const i = Math.ceil((Math.ceil(e.samplesPerLine / 8) * r.h) / e.maxH), + n = Math.ceil((Math.ceil(e.scanLines / 8) * r.v) / e.maxV), + s = t * r.h, + o = 64 * (a * r.v) * (s + 1); + r.blockData = new Int16Array(o); + r.blocksPerLine = i; + r.blocksPerColumn = n; + } + e.mcusPerLine = t; + e.mcusPerColumn = a; +} +function readDataBlock(e, t) { + const a = readUint16(e, t); + let r = (t += 2) + a - 2; + const i = findNextFileMarker(e, r, t); + if (i?.invalid) { + warn("readDataBlock - incorrect length, current marker is: " + i.invalid); + r = i.offset; + } + const n = e.subarray(t, r); + return { appData: n, oldOffset: t, newOffset: t + n.length }; +} +function skipData(e, t) { + const a = readUint16(e, t), + r = (t += 2) + a - 2, + i = findNextFileMarker(e, r, t); + return i?.invalid ? i.offset : r; +} +class JpegImage { + constructor({ decodeTransform: e = null, colorTransform: t = -1 } = {}) { + this._decodeTransform = e; + this._colorTransform = t; + } + static canUseImageDecoder(e, t = -1) { + let a = null, + r = 0, + i = null, + n = readUint16(e, r); + r += 2; + if (65496 !== n) throw new JpegError("SOI not found"); + n = readUint16(e, r); + r += 2; + e: for (; 65497 !== n; ) { + switch (n) { + case 65505: + const { + appData: t, + oldOffset: s, + newOffset: o, + } = readDataBlock(e, r); + r = o; + if ( + 69 === t[0] && + 120 === t[1] && + 105 === t[2] && + 102 === t[3] && + 0 === t[4] && + 0 === t[5] + ) { + if (a) throw new JpegError("Duplicate EXIF-blocks found."); + a = { exifStart: s + 6, exifEnd: o }; + } + n = readUint16(e, r); + r += 2; + continue; + case 65472: + case 65473: + case 65474: + i = e[r + 7]; + break e; + case 65535: + 255 !== e[r] && r--; + } + r = skipData(e, r); + n = readUint16(e, r); + r += 2; + } + return 4 === i || (3 === i && 0 === t) ? null : a || {}; + } + parse(e, { dnlScanLines: t = null } = {}) { + let a, + r, + i = 0, + n = null, + s = null, + o = 0; + const c = [], + l = [], + h = []; + let u = readUint16(e, i); + i += 2; + if (65496 !== u) throw new JpegError("SOI not found"); + u = readUint16(e, i); + i += 2; + e: for (; 65497 !== u; ) { + let d, f, g; + switch (u) { + case 65504: + case 65505: + case 65506: + case 65507: + case 65508: + case 65509: + case 65510: + case 65511: + case 65512: + case 65513: + case 65514: + case 65515: + case 65516: + case 65517: + case 65518: + case 65519: + case 65534: + const { appData: p, newOffset: m } = readDataBlock(e, i); + i = m; + 65504 === u && + 74 === p[0] && + 70 === p[1] && + 73 === p[2] && + 70 === p[3] && + 0 === p[4] && + (n = { + version: { major: p[5], minor: p[6] }, + densityUnits: p[7], + xDensity: (p[8] << 8) | p[9], + yDensity: (p[10] << 8) | p[11], + thumbWidth: p[12], + thumbHeight: p[13], + thumbData: p.subarray(14, 14 + 3 * p[12] * p[13]), + }); + 65518 === u && + 65 === p[0] && + 100 === p[1] && + 111 === p[2] && + 98 === p[3] && + 101 === p[4] && + (s = { + version: (p[5] << 8) | p[6], + flags0: (p[7] << 8) | p[8], + flags1: (p[9] << 8) | p[10], + transformCode: p[11], + }); + break; + case 65499: + const b = readUint16(e, i); + i += 2; + const y = b + i - 2; + let w; + for (; i < y; ) { + const t = e[i++], + a = new Uint16Array(64); + if (t >> 4) { + if (t >> 4 != 1) throw new JpegError("DQT - invalid table spec"); + for (f = 0; f < 64; f++) { + w = ja[f]; + a[w] = readUint16(e, i); + i += 2; + } + } else + for (f = 0; f < 64; f++) { + w = ja[f]; + a[w] = e[i++]; + } + c[15 & t] = a; + } + break; + case 65472: + case 65473: + case 65474: + if (a) throw new JpegError("Only single frame JPEGs supported"); + i += 2; + a = {}; + a.extended = 65473 === u; + a.progressive = 65474 === u; + a.precision = e[i++]; + const x = readUint16(e, i); + i += 2; + a.scanLines = t || x; + a.samplesPerLine = readUint16(e, i); + i += 2; + a.components = []; + a.componentIds = {}; + const S = e[i++]; + let k = 0, + C = 0; + for (d = 0; d < S; d++) { + const t = e[i], + r = e[i + 1] >> 4, + n = 15 & e[i + 1]; + k < r && (k = r); + C < n && (C = n); + const s = e[i + 2]; + g = a.components.push({ + h: r, + v: n, + quantizationId: s, + quantizationTable: null, + }); + a.componentIds[t] = g - 1; + i += 3; + } + a.maxH = k; + a.maxV = C; + prepareComponents(a); + break; + case 65476: + const v = readUint16(e, i); + i += 2; + for (d = 2; d < v; ) { + const t = e[i++], + a = new Uint8Array(16); + let r = 0; + for (f = 0; f < 16; f++, i++) r += a[f] = e[i]; + const n = new Uint8Array(r); + for (f = 0; f < r; f++, i++) n[f] = e[i]; + d += 17 + r; + (t >> 4 ? l : h)[15 & t] = buildHuffmanTable(a, n); + } + break; + case 65501: + i += 2; + r = readUint16(e, i); + i += 2; + break; + case 65498: + const F = 1 == ++o && !t; + i += 2; + const T = e[i++], + O = []; + for (d = 0; d < T; d++) { + const t = e[i++], + r = a.componentIds[t], + n = a.components[r]; + n.index = t; + const s = e[i++]; + n.huffmanTableDC = h[s >> 4]; + n.huffmanTableAC = l[15 & s]; + O.push(n); + } + const M = e[i++], + D = e[i++], + R = e[i++]; + try { + i += decodeScan(e, i, a, O, r, M, D, R >> 4, 15 & R, F); + } catch (t) { + if (t instanceof DNLMarkerError) { + warn(`${t.message} -- attempting to re-parse the JPEG image.`); + return this.parse(e, { dnlScanLines: t.scanLines }); + } + if (t instanceof EOIMarkerError) { + warn(`${t.message} -- ignoring the rest of the image data.`); + break e; + } + throw t; + } + break; + case 65500: + i += 4; + break; + case 65535: + 255 !== e[i] && i--; + break; + default: + const N = findNextFileMarker(e, i - 2, i - 3); + if (N?.invalid) { + warn( + "JpegImage.parse - unexpected data, current marker is: " + + N.invalid, + ); + i = N.offset; + break; + } + if (!N || i >= e.length - 1) { + warn( + "JpegImage.parse - reached the end of the image data without finding an EOI marker (0xFFD9).", + ); + break e; + } + throw new JpegError( + "JpegImage.parse - unknown marker: " + u.toString(16), + ); + } + u = readUint16(e, i); + i += 2; + } + if (!a) throw new JpegError("JpegImage.parse - no frame data found."); + this.width = a.samplesPerLine; + this.height = a.scanLines; + this.jfif = n; + this.adobe = s; + this.components = []; + for (const e of a.components) { + const t = c[e.quantizationId]; + t && (e.quantizationTable = t); + this.components.push({ + index: e.index, + output: buildComponentData(0, e), + scaleX: e.h / a.maxH, + scaleY: e.v / a.maxV, + blocksPerLine: e.blocksPerLine, + blocksPerColumn: e.blocksPerColumn, + }); + } + this.numComponents = this.components.length; + } + _getLinearizedBlockData(e, t, a = !1) { + const r = this.width / e, + i = this.height / t; + let n, + s, + o, + c, + l, + h, + u, + d, + f, + g, + p, + m = 0; + const b = this.components.length, + y = e * t * b, + w = new Uint8ClampedArray(y), + x = new Uint32Array(e), + S = 4294967288; + let k; + for (u = 0; u < b; u++) { + n = this.components[u]; + s = n.scaleX * r; + o = n.scaleY * i; + m = u; + p = n.output; + c = (n.blocksPerLine + 1) << 3; + if (s !== k) { + for (l = 0; l < e; l++) { + d = 0 | (l * s); + x[l] = ((d & S) << 3) | (7 & d); + } + k = s; + } + for (h = 0; h < t; h++) { + d = 0 | (h * o); + g = (c * (d & S)) | ((7 & d) << 3); + for (l = 0; l < e; l++) { + w[m] = p[g + x[l]]; + m += b; + } + } + } + let C = this._decodeTransform; + a || + 4 !== b || + C || + (C = new Int32Array([-256, 255, -256, 255, -256, 255, -256, 255])); + if (C) + for (u = 0; u < y; ) + for (d = 0, f = 0; d < b; d++, u++, f += 2) + w[u] = ((w[u] * C[f]) >> 8) + C[f + 1]; + return w; + } + get _isColorConversionNeeded() { + return this.adobe + ? !!this.adobe.transformCode + : 3 === this.numComponents + ? 0 !== this._colorTransform && + (82 !== this.components[0].index || + 71 !== this.components[1].index || + 66 !== this.components[2].index) + : 1 === this._colorTransform; + } + _convertYccToRgb(e) { + let t, a, r; + for (let i = 0, n = e.length; i < n; i += 3) { + t = e[i]; + a = e[i + 1]; + r = e[i + 2]; + e[i] = t - 179.456 + 1.402 * r; + e[i + 1] = t + 135.459 - 0.344 * a - 0.714 * r; + e[i + 2] = t - 226.816 + 1.772 * a; + } + return e; + } + _convertYccToRgba(e, t) { + for (let a = 0, r = 0, i = e.length; a < i; a += 3, r += 4) { + const i = e[a], + n = e[a + 1], + s = e[a + 2]; + t[r] = i - 179.456 + 1.402 * s; + t[r + 1] = i + 135.459 - 0.344 * n - 0.714 * s; + t[r + 2] = i - 226.816 + 1.772 * n; + t[r + 3] = 255; + } + return t; + } + _convertYcckToRgb(e) { + this._convertYcckToCmyk(e); + return this._convertCmykToRgb(e); + } + _convertYcckToRgba(e) { + this._convertYcckToCmyk(e); + return this._convertCmykToRgba(e); + } + _convertYcckToCmyk(e) { + let t, a, r; + for (let i = 0, n = e.length; i < n; i += 4) { + t = e[i]; + a = e[i + 1]; + r = e[i + 2]; + e[i] = 434.456 - t - 1.402 * r; + e[i + 1] = 119.541 - t + 0.344 * a + 0.714 * r; + e[i + 2] = 481.816 - t - 1.772 * a; + } + return e; + } + _convertCmykToRgb(e) { + const t = e.length / 4; + ColorSpaceUtils.cmyk.getRgbBuffer(e, 0, t, e, 0, 8, 0); + return e.subarray(0, 3 * t); + } + _convertCmykToRgba(e) { + ColorSpaceUtils.cmyk.getRgbBuffer(e, 0, e.length / 4, e, 0, 8, 1); + if (ColorSpaceUtils.cmyk instanceof DeviceCmykCS) + for (let t = 3, a = e.length; t < a; t += 4) e[t] = 255; + return e; + } + getData({ + width: e, + height: t, + forceRGBA: a = !1, + forceRGB: r = !1, + isSourcePDF: i = !1, + }) { + if (this.numComponents > 4) throw new JpegError("Unsupported color mode"); + const n = this._getLinearizedBlockData(e, t, i); + if (1 === this.numComponents && (a || r)) { + const e = n.length * (a ? 4 : 3), + t = new Uint8ClampedArray(e); + let r = 0; + if (a) + !(function grayToRGBA(e, t) { + if (FeatureTest.isLittleEndian) + for (let a = 0, r = e.length; a < r; a++) + t[a] = (65793 * e[a]) | 4278190080; + else + for (let a = 0, r = e.length; a < r; a++) + t[a] = (16843008 * e[a]) | 255; + })(n, new Uint32Array(t.buffer)); + else + for (const e of n) { + t[r++] = e; + t[r++] = e; + t[r++] = e; + } + return t; + } + if (3 === this.numComponents && this._isColorConversionNeeded) { + if (a) { + const e = new Uint8ClampedArray((n.length / 3) * 4); + return this._convertYccToRgba(n, e); + } + return this._convertYccToRgb(n); + } + if (4 === this.numComponents) { + if (this._isColorConversionNeeded) + return a + ? this._convertYcckToRgba(n) + : r + ? this._convertYcckToRgb(n) + : this._convertYcckToCmyk(n); + if (a) return this._convertCmykToRgba(n); + if (r) return this._convertCmykToRgb(n); + } + return n; + } +} +class JpegStream extends DecodeStream { + static #M = FeatureTest.isImageDecoderSupported; + constructor(e, t, a) { + super(t); + this.stream = e; + this.dict = e.dict; + this.maybeLength = t; + this.params = a; + } + static get canUseImageDecoder() { + return shadow( + this, + "canUseImageDecoder", + this.#M + ? ImageDecoder.isTypeSupported("image/jpeg") + : Promise.resolve(!1), + ); + } + static setOptions({ isImageDecoderSupported: e = !1 }) { + this.#M = e; + } + get bytes() { + return shadow(this, "bytes", this.stream.getBytes(this.maybeLength)); + } + ensureBuffer(e) {} + readBlock() { + this.decodeImage(); + } + get jpegOptions() { + const e = { decodeTransform: void 0, colorTransform: void 0 }, + t = this.dict.getArray("D", "Decode"); + if ((this.forceRGBA || this.forceRGB) && Array.isArray(t)) { + const a = this.dict.get("BPC", "BitsPerComponent") || 8, + r = t.length, + i = new Int32Array(r); + let n = !1; + const s = (1 << a) - 1; + for (let e = 0; e < r; e += 2) { + i[e] = (256 * (t[e + 1] - t[e])) | 0; + i[e + 1] = (t[e] * s) | 0; + (256 === i[e] && 0 === i[e + 1]) || (n = !0); + } + n && (e.decodeTransform = i); + } + if (this.params instanceof Dict) { + const t = this.params.get("ColorTransform"); + Number.isInteger(t) && (e.colorTransform = t); + } + return shadow(this, "jpegOptions", e); + } + #N(e) { + for (let t = 0, a = e.length - 1; t < a; t++) + if (255 === e[t] && 216 === e[t + 1]) { + t > 0 && (e = e.subarray(t)); + break; + } + return e; + } + decodeImage(e) { + if (this.eof) return this.buffer; + e = this.#N(e || this.bytes); + const t = new JpegImage(this.jpegOptions); + t.parse(e); + const a = t.getData({ + width: this.drawWidth, + height: this.drawHeight, + forceRGBA: this.forceRGBA, + forceRGB: this.forceRGB, + isSourcePDF: !0, + }); + this.buffer = a; + this.bufferLength = a.length; + this.eof = !0; + return this.buffer; + } + get canAsyncDecodeImageFromBuffer() { + return this.stream.isAsync; + } + async getTransferableImage() { + if (!(await JpegStream.canUseImageDecoder)) return null; + const e = this.jpegOptions; + if (e.decodeTransform) return null; + let t; + try { + const a = + (this.canAsyncDecodeImageFromBuffer && + (await this.stream.asyncGetBytes())) || + this.bytes; + if (!a) return null; + let r = this.#N(a); + const i = JpegImage.canUseImageDecoder(r, e.colorTransform); + if (!i) return null; + if (i.exifStart) { + r = r.slice(); + r.fill(0, i.exifStart, i.exifEnd); + } + t = new ImageDecoder({ + data: r, + type: "image/jpeg", + preferAnimation: !1, + }); + return (await t.decode()).image; + } catch (e) { + warn(`getTransferableImage - failed: "${e}".`); + return null; + } finally { + t?.close(); + } + } +} +var OpenJPEG = async function (e = {}) { + var t, + a, + r = e, + i = new Promise((e, r) => { + t = e; + a = r; + }), + n = "./this.program", + quit_ = (e, t) => { + throw t; + }, + s = import.meta.url; + try { + new URL(".", s).href; + } catch {} + var o, + c, + l, + h, + u, + d, + f = console.log.bind(console), + g = console.error.bind(console), + p = !1; + function updateMemoryViews() { + var e = o.buffer; + l = new Int8Array(e); + new Int16Array(e); + h = new Uint8Array(e); + new Uint16Array(e); + u = new Int32Array(e); + d = new Uint32Array(e); + new Float32Array(e); + new Float64Array(e); + new BigInt64Array(e); + new BigUint64Array(e); + } + var m = 0, + b = null; + class ExitStatus { + name = "ExitStatus"; + constructor(e) { + this.message = `Program terminated with exit(${e})`; + this.status = e; + } + } + var callRuntimeCallbacks = (e) => { + for (; e.length > 0; ) e.shift()(r); + }, + y = [], + addOnPostRun = (e) => y.push(e), + w = [], + addOnPreRun = (e) => w.push(e), + x = !0, + S = 0, + k = {}, + handleException = (e) => { + if (e instanceof ExitStatus || "unwind" == e) return c; + quit_(0, e); + }, + keepRuntimeAlive = () => x || S > 0, + _proc_exit = (e) => { + c = e; + if (!keepRuntimeAlive()) { + r.onExit?.(e); + p = !0; + } + quit_(0, new ExitStatus(e)); + }, + _exit = (e, t) => { + c = e; + _proc_exit(e); + }, + callUserCallback = (e) => { + if (!p) + try { + e(); + (() => { + if (!keepRuntimeAlive()) + try { + _exit(c); + } catch (e) { + handleException(e); + } + })(); + } catch (e) { + handleException(e); + } + }, + growMemory = (e) => { + var t = ((e - o.buffer.byteLength + 65535) / 65536) | 0; + try { + o.grow(t); + updateMemoryViews(); + return 1; + } catch (e) {} + }, + C = {}, + getEnvStrings = () => { + if (!getEnvStrings.strings) { + var e = { + USER: "web_user", + LOGNAME: "web_user", + PATH: "/", + PWD: "/", + HOME: "/home/web_user", + LANG: + ( + ("object" == typeof navigator && + navigator.languages && + navigator.languages[0]) || + "C" + ).replace("-", "_") + ".UTF-8", + _: n || "./this.program", + }; + for (var t in C) void 0 === C[t] ? delete e[t] : (e[t] = C[t]); + var a = []; + for (var t in e) a.push(`${t}=${e[t]}`); + getEnvStrings.strings = a; + } + return getEnvStrings.strings; + }, + lengthBytesUTF8 = (e) => { + for (var t = 0, a = 0; a < e.length; ++a) { + var r = e.charCodeAt(a); + if (r <= 127) t++; + else if (r <= 2047) t += 2; + else if (r >= 55296 && r <= 57343) { + t += 4; + ++a; + } else t += 3; + } + return t; + }, + v = [null, [], []], + F = "undefined" != typeof TextDecoder ? new TextDecoder() : void 0, + UTF8ArrayToString = (e, t = 0, a = NaN) => { + for (var r = t + a, i = t; e[i] && !(i >= r); ) ++i; + if (i - t > 16 && e.buffer && F) return F.decode(e.subarray(t, i)); + for (var n = ""; t < i; ) { + var s = e[t++]; + if (128 & s) { + var o = 63 & e[t++]; + if (192 != (224 & s)) { + var c = 63 & e[t++]; + if ( + (s = + 224 == (240 & s) + ? ((15 & s) << 12) | (o << 6) | c + : ((7 & s) << 18) | (o << 12) | (c << 6) | (63 & e[t++])) < + 65536 + ) + n += String.fromCharCode(s); + else { + var l = s - 65536; + n += String.fromCharCode(55296 | (l >> 10), 56320 | (1023 & l)); + } + } else n += String.fromCharCode(((31 & s) << 6) | o); + } else n += String.fromCharCode(s); + } + return n; + }, + printChar = (e, t) => { + var a = v[e]; + if (0 === t || 10 === t) { + (1 === e ? f : g)(UTF8ArrayToString(a)); + a.length = 0; + } else a.push(t); + }, + UTF8ToString = (e, t) => (e ? UTF8ArrayToString(h, e, t) : ""); + r.noExitRuntime && (x = r.noExitRuntime); + r.print && (f = r.print); + r.printErr && (g = r.printErr); + r.wasmBinary && r.wasmBinary; + r.arguments && r.arguments; + r.thisProgram && (n = r.thisProgram); + r.writeArrayToMemory = (e, t) => { + l.set(e, t); + }; + var T = { + l: () => + (function abort(e) { + r.onAbort?.(e); + g((e = "Aborted(" + e + ")")); + p = !0; + e += ". Build with -sASSERTIONS for more info."; + var t = new WebAssembly.RuntimeError(e); + a(t); + throw t; + })(""), + k: () => { + x = !1; + S = 0; + }, + m: (e, t) => { + if (k[e]) { + clearTimeout(k[e].id); + delete k[e]; + } + if (!t) return 0; + var a = setTimeout(() => { + delete k[e]; + callUserCallback(() => M(e, performance.now())); + }, t); + k[e] = { id: a, timeout_ms: t }; + return 0; + }, + g: function _copy_pixels_1(e, t) { + e >>= 2; + const a = (r.imageData = new Uint8ClampedArray(t)), + i = u.subarray(e, e + t); + a.set(i); + }, + f: function _copy_pixels_3(e, t, a, i) { + e >>= 2; + t >>= 2; + a >>= 2; + const n = (r.imageData = new Uint8ClampedArray(3 * i)), + s = u.subarray(e, e + i), + o = u.subarray(t, t + i), + c = u.subarray(a, a + i); + for (let e = 0; e < i; e++) { + n[3 * e] = s[e]; + n[3 * e + 1] = o[e]; + n[3 * e + 2] = c[e]; + } + }, + e: function _copy_pixels_4(e, t, a, i, n) { + e >>= 2; + t >>= 2; + a >>= 2; + i >>= 2; + const s = (r.imageData = new Uint8ClampedArray(4 * n)), + o = u.subarray(e, e + n), + c = u.subarray(t, t + n), + l = u.subarray(a, a + n), + h = u.subarray(i, i + n); + for (let e = 0; e < n; e++) { + s[4 * e] = o[e]; + s[4 * e + 1] = c[e]; + s[4 * e + 2] = l[e]; + s[4 * e + 3] = h[e]; + } + }, + n: (e) => { + var t, + a, + r = h.length, + i = 2147483648; + if ((e >>>= 0) > i) return !1; + for (var n = 1; n <= 4; n *= 2) { + var s = r * (1 + 0.2 / n); + s = Math.min(s, e + 100663296); + var o = Math.min( + i, + ((t = Math.max(e, s)), (a = 65536), Math.ceil(t / a) * a), + ); + if (growMemory(o)) return !0; + } + return !1; + }, + p: (e, t) => { + var a = 0, + r = 0; + for (var i of getEnvStrings()) { + var n = t + a; + d[(e + r) >> 2] = n; + a += + ((e, t, a, r) => { + if (!(r > 0)) return 0; + for (var i = a, n = a + r - 1, s = 0; s < e.length; ++s) { + var o = e.charCodeAt(s); + o >= 55296 && + o <= 57343 && + (o = + (65536 + ((1023 & o) << 10)) | (1023 & e.charCodeAt(++s))); + if (o <= 127) { + if (a >= n) break; + t[a++] = o; + } else if (o <= 2047) { + if (a + 1 >= n) break; + t[a++] = 192 | (o >> 6); + t[a++] = 128 | (63 & o); + } else if (o <= 65535) { + if (a + 2 >= n) break; + t[a++] = 224 | (o >> 12); + t[a++] = 128 | ((o >> 6) & 63); + t[a++] = 128 | (63 & o); + } else { + if (a + 3 >= n) break; + t[a++] = 240 | (o >> 18); + t[a++] = 128 | ((o >> 12) & 63); + t[a++] = 128 | ((o >> 6) & 63); + t[a++] = 128 | (63 & o); + } + } + t[a] = 0; + return a - i; + })(i, h, n, 1 / 0) + 1; + r += 4; + } + return 0; + }, + q: (e, t) => { + var a = getEnvStrings(); + d[e >> 2] = a.length; + var r = 0; + for (var i of a) r += lengthBytesUTF8(i) + 1; + d[t >> 2] = r; + return 0; + }, + b: (e) => 52, + o: function _fd_seek(e, t, a, r) { + t = + (i = t) < -9007199254740992 || i > 9007199254740992 ? NaN : Number(i); + var i; + return 70; + }, + c: (e, t, a, r) => { + for (var i = 0, n = 0; n < a; n++) { + var s = d[t >> 2], + o = d[(t + 4) >> 2]; + t += 8; + for (var c = 0; c < o; c++) printChar(e, h[s + c]); + i += o; + } + d[r >> 2] = i; + return 0; + }, + r: function _gray_to_rgba(e, t) { + e >>= 2; + const a = (r.imageData = new Uint8ClampedArray(4 * t)), + i = u.subarray(e, e + t); + for (let e = 0; e < t; e++) { + a[4 * e] = a[4 * e + 1] = a[4 * e + 2] = i[e]; + a[4 * e + 3] = 255; + } + }, + i: function _graya_to_rgba(e, t, a) { + e >>= 2; + t >>= 2; + const i = (r.imageData = new Uint8ClampedArray(4 * a)), + n = u.subarray(e, e + a), + s = u.subarray(t, t + a); + for (let e = 0; e < a; e++) { + i[4 * e] = i[4 * e + 1] = i[4 * e + 2] = n[e]; + i[4 * e + 3] = s[e]; + } + }, + d: function _jsPrintWarning(e) { + const t = UTF8ToString(e); + (r.warn || console.warn)(`OpenJPEG: ${t}`); + }, + j: _proc_exit, + h: function _rgb_to_rgba(e, t, a, i) { + e >>= 2; + t >>= 2; + a >>= 2; + const n = (r.imageData = new Uint8ClampedArray(4 * i)), + s = u.subarray(e, e + i), + o = u.subarray(t, t + i), + c = u.subarray(a, a + i); + for (let e = 0; e < i; e++) { + n[4 * e] = s[e]; + n[4 * e + 1] = o[e]; + n[4 * e + 2] = c[e]; + n[4 * e + 3] = 255; + } + }, + a: function _storeErrorMessage(e) { + const t = UTF8ToString(e); + r.errorMessages ? (r.errorMessages += "\n" + t) : (r.errorMessages = t); + }, + }, + O = await (async function createWasm() { + function receiveInstance(e, t) { + O = e.exports; + o = O.s; + updateMemoryViews(); + !(function removeRunDependency(e) { + m--; + r.monitorRunDependencies?.(m); + if (0 == m && b) { + var t = b; + b = null; + t(); + } + })(); + return O; + } + !(function addRunDependency(e) { + m++; + r.monitorRunDependencies?.(m); + })(); + var e = (function getWasmImports() { + return { a: T }; + })(); + return new Promise((t, a) => { + r.instantiateWasm(e, (e, a) => { + t(receiveInstance(e)); + }); + }); + })(), + M = (O.t, (r._malloc = O.u), (r._free = O.v), (r._jp2_decode = O.w), O.x); + !(function preInit() { + if (r.preInit) { + "function" == typeof r.preInit && (r.preInit = [r.preInit]); + for (; r.preInit.length > 0; ) r.preInit.shift()(); + } + })(); + !(function run() { + if (m > 0) b = run; + else { + !(function preRun() { + if (r.preRun) { + "function" == typeof r.preRun && (r.preRun = [r.preRun]); + for (; r.preRun.length; ) addOnPreRun(r.preRun.shift()); + } + callRuntimeCallbacks(w); + })(); + if (m > 0) b = run; + else if (r.setStatus) { + r.setStatus("Running..."); + setTimeout(() => { + setTimeout(() => r.setStatus(""), 1); + doRun(); + }, 1); + } else doRun(); + } + function doRun() { + r.calledRun = !0; + if (!p) { + !(function initRuntime() { + O.t(); + })(); + t(r); + r.onRuntimeInitialized?.(); + !(function postRun() { + if (r.postRun) { + "function" == typeof r.postRun && (r.postRun = [r.postRun]); + for (; r.postRun.length; ) addOnPostRun(r.postRun.shift()); + } + callRuntimeCallbacks(y); + })(); + } + } + })(); + return i; +}; +const Ga = OpenJPEG; +class JpxError extends fa { + constructor(e) { + super(e, "JpxError"); + } +} +class JpxImage { + static #E = null; + static #P = null; + static #L = null; + static #v = !0; + static #j = !0; + static #F = null; + static setOptions({ handler: e, useWasm: t, useWorkerFetch: a, wasmUrl: r }) { + this.#v = t; + this.#j = a; + this.#F = r; + a || (this.#P = e); + } + static async #_(e) { + const t = `${this.#F}openjpeg_nowasm_fallback.js`; + let a = null; + try { + a = ( + await import( + /*webpackIgnore: true*/ + /*@vite-ignore*/ + t + ) + ).default(); + } catch (e) { + warn(`JpxImage#getJsModule: ${e}`); + } + e(a); + } + static async #U(e, t, a) { + const r = "openjpeg.wasm"; + try { + this.#E || + (this.#j + ? (this.#E = await fetchBinaryData(`${this.#F}${r}`)) + : (this.#E = await this.#P.sendWithPromise("FetchBinaryData", { + type: "wasmFactory", + filename: r, + }))); + return a((await WebAssembly.instantiate(this.#E, t)).instance); + } catch (t) { + warn(`JpxImage#instantiateWasm: ${t}`); + this.#_(e); + return null; + } finally { + this.#P = null; + } + } + static async decode( + e, + { + numComponents: t = 4, + isIndexedColormap: a = !1, + smaskInData: r = !1, + reducePower: i = 0, + } = {}, + ) { + if (!this.#L) { + const { promise: e, resolve: t } = Promise.withResolvers(), + a = [e]; + this.#v + ? a.push(Ga({ warn, instantiateWasm: this.#U.bind(this, t) })) + : this.#_(t); + this.#L = Promise.race(a); + } + const n = await this.#L; + if (!n) throw new JpxError("OpenJPEG failed to initialize"); + let s; + try { + const o = e.length; + s = n._malloc(o); + n.writeArrayToMemory(e, s); + if (n._jp2_decode(s, o, t > 0 ? t : 0, !!a, !!r, i)) { + const { errorMessages: e } = n; + if (e) { + delete n.errorMessages; + throw new JpxError(e); + } + throw new JpxError("Unknown error"); + } + const { imageData: c } = n; + n.imageData = null; + return c; + } finally { + s && n._free(s); + } + } + static cleanup() { + this.#L = null; + } + static parseImageProperties(e) { + let t = e.getByte(); + for (; t >= 0; ) { + const a = t; + t = e.getByte(); + if (65361 === ((a << 8) | t)) { + e.skip(4); + const t = e.getInt32() >>> 0, + a = e.getInt32() >>> 0, + r = e.getInt32() >>> 0, + i = e.getInt32() >>> 0; + e.skip(16); + return { + width: t - r, + height: a - i, + bitsPerComponent: 8, + componentsCount: e.getUint16(), + }; + } + } + throw new JpxError("No size marker found in JPX stream"); + } +} +function addState(e, t, a, r, i) { + let n = e; + for (let e = 0, a = t.length - 1; e < a; e++) { + const a = t[e]; + n = n[a] ||= []; + } + n[t.at(-1)] = { checkFn: a, iterateFn: r, processFn: i }; +} +const Va = []; +addState( + Va, + [Be, Ne, Yt, Re], + null, + function iterateInlineImageGroup(e, t) { + const a = e.fnArray, + r = (t - (e.iCurr - 3)) % 4; + switch (r) { + case 0: + return a[t] === Be; + case 1: + return a[t] === Ne; + case 2: + return a[t] === Yt; + case 3: + return a[t] === Re; + } + throw new Error(`iterateInlineImageGroup - invalid pos: ${r}`); + }, + function foundInlineImageGroup(e, t) { + const a = e.fnArray, + r = e.argsArray, + i = e.iCurr, + n = i - 3, + s = i - 2, + o = i - 1, + c = Math.min(Math.floor((t - n) / 4), 200); + if (c < 10) return t - ((t - n) % 4); + let l = 0; + const h = []; + let u = 0, + d = 1, + f = 1; + for (let e = 0; e < c; e++) { + const t = r[s + (e << 2)], + a = r[o + (e << 2)][0]; + if (d + a.width > 1e3) { + l = Math.max(l, d); + f += u + 2; + d = 0; + u = 0; + } + h.push({ transform: t, x: d, y: f, w: a.width, h: a.height }); + d += a.width + 2; + u = Math.max(u, a.height); + } + const g = Math.max(l, d) + 1, + p = f + u + 1, + m = new Uint8Array(g * p * 4), + b = g << 2; + for (let e = 0; e < c; e++) { + const t = r[o + (e << 2)][0].data, + a = h[e].w << 2; + let i = 0, + n = (h[e].x + h[e].y * g) << 2; + m.set(t.subarray(0, a), n - b); + for (let r = 0, s = h[e].h; r < s; r++) { + m.set(t.subarray(i, i + a), n); + i += a; + n += b; + } + m.set(t.subarray(i - a, i), n); + for (; n >= 0; ) { + t[n - 4] = t[n]; + t[n - 3] = t[n + 1]; + t[n - 2] = t[n + 2]; + t[n - 1] = t[n + 3]; + t[n + a] = t[n + a - 4]; + t[n + a + 1] = t[n + a - 3]; + t[n + a + 2] = t[n + a - 2]; + t[n + a + 3] = t[n + a - 1]; + n -= b; + } + } + const y = { width: g, height: p }; + if (e.isOffscreenCanvasSupported) { + const e = new OffscreenCanvas(g, p); + e.getContext("2d").putImageData( + new ImageData(new Uint8ClampedArray(m.buffer), g, p), + 0, + 0, + ); + y.bitmap = e.transferToImageBitmap(); + y.data = null; + } else { + y.kind = v; + y.data = m; + } + a.splice(n, 4 * c, Zt); + r.splice(n, 4 * c, [y, h]); + return n + 1; + }, +); +addState( + Va, + [Be, Ne, Vt, Re], + null, + function iterateImageMaskGroup(e, t) { + const a = e.fnArray, + r = (t - (e.iCurr - 3)) % 4; + switch (r) { + case 0: + return a[t] === Be; + case 1: + return a[t] === Ne; + case 2: + return a[t] === Vt; + case 3: + return a[t] === Re; + } + throw new Error(`iterateImageMaskGroup - invalid pos: ${r}`); + }, + function foundImageMaskGroup(e, t) { + const a = e.fnArray, + r = e.argsArray, + i = e.iCurr, + n = i - 3, + s = i - 2, + o = i - 1; + let c = Math.floor((t - n) / 4); + if (c < 10) return t - ((t - n) % 4); + let l, + h, + u = !1; + const d = r[o][0], + f = r[s][0], + g = r[s][1], + p = r[s][2], + m = r[s][3]; + if (g === p) { + u = !0; + l = s + 4; + let e = o + 4; + for (let t = 1; t < c; t++, l += 4, e += 4) { + h = r[l]; + if ( + r[e][0] !== d || + h[0] !== f || + h[1] !== g || + h[2] !== p || + h[3] !== m + ) { + t < 10 ? (u = !1) : (c = t); + break; + } + } + } + if (u) { + c = Math.min(c, 1e3); + const e = new Float32Array(2 * c); + l = s; + for (let t = 0; t < c; t++, l += 4) { + h = r[l]; + e[t << 1] = h[4]; + e[1 + (t << 1)] = h[5]; + } + a.splice(n, 4 * c, ea); + r.splice(n, 4 * c, [d, f, g, p, m, e]); + } else { + c = Math.min(c, 100); + const e = []; + for (let t = 0; t < c; t++) { + h = r[s + (t << 2)]; + const a = r[o + (t << 2)][0]; + e.push({ + data: a.data, + width: a.width, + height: a.height, + interpolate: a.interpolate, + count: a.count, + transform: h, + }); + } + a.splice(n, 4 * c, Kt); + r.splice(n, 4 * c, [e]); + } + return n + 1; + }, +); +addState( + Va, + [Be, Ne, Jt, Re], + function (e) { + const t = e.argsArray, + a = e.iCurr - 2; + return 0 === t[a][1] && 0 === t[a][2]; + }, + function iterateImageGroup(e, t) { + const a = e.fnArray, + r = e.argsArray, + i = (t - (e.iCurr - 3)) % 4; + switch (i) { + case 0: + return a[t] === Be; + case 1: + if (a[t] !== Ne) return !1; + const i = e.iCurr - 2, + n = r[i][0], + s = r[i][3]; + return r[t][0] === n && 0 === r[t][1] && 0 === r[t][2] && r[t][3] === s; + case 2: + if (a[t] !== Jt) return !1; + const o = r[e.iCurr - 1][0]; + return r[t][0] === o; + case 3: + return a[t] === Re; + } + throw new Error(`iterateImageGroup - invalid pos: ${i}`); + }, + function (e, t) { + const a = e.fnArray, + r = e.argsArray, + i = e.iCurr, + n = i - 3, + s = i - 2, + o = r[i - 1][0], + c = r[s][0], + l = r[s][3], + h = Math.min(Math.floor((t - n) / 4), 1e3); + if (h < 3) return t - ((t - n) % 4); + const u = new Float32Array(2 * h); + let d = s; + for (let e = 0; e < h; e++, d += 4) { + const t = r[d]; + u[e << 1] = t[4]; + u[1 + (e << 1)] = t[5]; + } + const f = [o, c, l, u]; + a.splice(n, 4 * h, Qt); + r.splice(n, 4 * h, f); + return n + 1; + }, +); +addState( + Va, + [Qe, nt, ht, dt, et], + null, + function iterateShowTextGroup(e, t) { + const a = e.fnArray, + r = e.argsArray, + i = (t - (e.iCurr - 4)) % 5; + switch (i) { + case 0: + return a[t] === Qe; + case 1: + return a[t] === nt; + case 2: + return a[t] === ht; + case 3: + if (a[t] !== dt) return !1; + const i = e.iCurr - 3, + n = r[i][0], + s = r[i][1]; + return r[t][0] === n && r[t][1] === s; + case 4: + return a[t] === et; + } + throw new Error(`iterateShowTextGroup - invalid pos: ${i}`); + }, + function (e, t) { + const a = e.fnArray, + r = e.argsArray, + i = e.iCurr, + n = i - 4, + s = i - 3, + o = i - 2, + c = i - 1, + l = i, + h = r[s][0], + u = r[s][1]; + let d = Math.min(Math.floor((t - n) / 5), 1e3); + if (d < 3) return t - ((t - n) % 5); + let f = n; + if ( + n >= 4 && + a[n - 4] === a[s] && + a[n - 3] === a[o] && + a[n - 2] === a[c] && + a[n - 1] === a[l] && + r[n - 4][0] === h && + r[n - 4][1] === u + ) { + d++; + f -= 5; + } + let g = f + 4; + for (let e = 1; e < d; e++) { + a.splice(g, 3); + r.splice(g, 3); + g += 2; + } + return g + 1; + }, +); +addState( + Va, + [Be, Ne, aa, Re], + (e) => { + const t = e.argsArray, + a = t[e.iCurr - 1][0]; + if (a !== qe && a !== He && a !== $e && a !== Ge && a !== Ve && a !== Ke) + return !0; + const r = t[e.iCurr - 2]; + return 1 === r[0] && 0 === r[1] && 0 === r[2] && 1 === r[3]; + }, + () => !1, + (e, t) => { + const { fnArray: a, argsArray: r } = e, + i = e.iCurr, + n = i - 3, + s = i - 2, + o = r[i - 1], + c = r[s], + [, [l], h] = o; + if (h) { + Util.scaleMinMax(c, h); + for (let e = 0, t = l.length; e < t; ) + switch (l[e++]) { + case sa: + case oa: + Util.applyTransform(l, c, e); + e += 2; + break; + case ca: + Util.applyTransformToBezier(l, c, e); + e += 6; + } + } + a.splice(n, 4, aa); + r.splice(n, 4, o); + return n + 1; + }, +); +class NullOptimizer { + constructor(e) { + this.queue = e; + } + _optimize() {} + push(e, t) { + this.queue.fnArray.push(e); + this.queue.argsArray.push(t); + this._optimize(); + } + flush() {} + reset() {} +} +class QueueOptimizer extends NullOptimizer { + constructor(e) { + super(e); + this.state = null; + this.context = { + iCurr: 0, + fnArray: e.fnArray, + argsArray: e.argsArray, + isOffscreenCanvasSupported: OperatorList.isOffscreenCanvasSupported, + }; + this.match = null; + this.lastProcessed = 0; + } + _optimize() { + const e = this.queue.fnArray; + let t = this.lastProcessed, + a = e.length, + r = this.state, + i = this.match; + if (!r && !i && t + 1 === a && !Va[e[t]]) { + this.lastProcessed = a; + return; + } + const n = this.context; + for (; t < a; ) { + if (i) { + if ((0, i.iterateFn)(n, t)) { + t++; + continue; + } + t = (0, i.processFn)(n, t + 1); + a = e.length; + i = null; + r = null; + if (t >= a) break; + } + r = (r || Va)[e[t]]; + if (r && !Array.isArray(r)) { + n.iCurr = t; + t++; + if (!r.checkFn || (0, r.checkFn)(n)) { + i = r; + r = null; + } else r = null; + } else t++; + } + this.state = r; + this.match = i; + this.lastProcessed = t; + } + flush() { + for (; this.match; ) { + const e = this.queue.fnArray.length; + this.lastProcessed = (0, this.match.processFn)(this.context, e); + this.match = null; + this.state = null; + this._optimize(); + } + } + reset() { + this.state = null; + this.match = null; + this.lastProcessed = 0; + } +} +class OperatorList { + static CHUNK_SIZE = 1e3; + static CHUNK_SIZE_ABOUT = this.CHUNK_SIZE - 5; + static isOffscreenCanvasSupported = !1; + constructor(e = 0, t) { + this._streamSink = t; + this.fnArray = []; + this.argsArray = []; + this.optimizer = + !t || e & d ? new NullOptimizer(this) : new QueueOptimizer(this); + this.dependencies = new Set(); + this._totalLength = 0; + this.weight = 0; + this._resolved = t ? null : Promise.resolve(); + } + static setOptions({ isOffscreenCanvasSupported: e }) { + this.isOffscreenCanvasSupported = e; + } + get length() { + return this.argsArray.length; + } + get ready() { + return this._resolved || this._streamSink.ready; + } + get totalLength() { + return this._totalLength + this.length; + } + addOp(e, t) { + this.optimizer.push(e, t); + this.weight++; + this._streamSink && + (this.weight >= OperatorList.CHUNK_SIZE || + (this.weight >= OperatorList.CHUNK_SIZE_ABOUT && + (e === Re || e === et))) && + this.flush(); + } + addImageOps(e, t, a, r = !1) { + if (r) { + this.addOp(Be); + this.addOp(De, [[["SMask", !1]]]); + } + void 0 !== a && this.addOp(jt, ["OC", a]); + this.addOp(e, t); + void 0 !== a && this.addOp(_t, []); + r && this.addOp(Re); + } + addDependency(e) { + if (!this.dependencies.has(e)) { + this.dependencies.add(e); + this.addOp(Ae, [e]); + } + } + addDependencies(e) { + for (const t of e) this.addDependency(t); + } + addOpList(e) { + if (e instanceof OperatorList) { + for (const t of e.dependencies) this.dependencies.add(t); + for (let t = 0, a = e.length; t < a; t++) + this.addOp(e.fnArray[t], e.argsArray[t]); + } else warn('addOpList - ignoring invalid "opList" parameter.'); + } + getIR() { + return { + fnArray: this.fnArray, + argsArray: this.argsArray, + length: this.length, + }; + } + get _transfers() { + const e = [], + { fnArray: t, argsArray: a, length: r } = this; + for (let i = 0; i < r; i++) + switch (t[i]) { + case Yt: + case Zt: + case Vt: { + const { bitmap: t, data: r } = a[i][0]; + (t || r?.buffer) && e.push(t || r.buffer); + break; + } + case aa: { + const [, [t], r] = a[i]; + t && e.push(t.buffer, r.buffer); + break; + } + case qt: + const [t, r] = a[i]; + t && e.push(t.buffer); + r && e.push(r.buffer); + break; + case ht: + e.push(a[i][0].buffer); + } + return e; + } + flush(e = !1, t = null) { + this.optimizer.flush(); + const a = this.length; + this._totalLength += a; + this._streamSink.enqueue( + { + fnArray: this.fnArray, + argsArray: this.argsArray, + lastChunk: e, + separateAnnots: t, + length: a, + }, + 1, + this._transfers, + ); + this.dependencies.clear(); + this.fnArray.length = 0; + this.argsArray.length = 0; + this.weight = 0; + this.optimizer.reset(); + } +} +function hexToInt(e, t) { + let a = 0; + for (let r = 0; r <= t; r++) a = (a << 8) | e[r]; + return a >>> 0; +} +function hexToStr(e, t) { + return 1 === t + ? String.fromCharCode(e[0], e[1]) + : 3 === t + ? String.fromCharCode(e[0], e[1], e[2], e[3]) + : String.fromCharCode(...e.subarray(0, t + 1)); +} +function addHex(e, t, a) { + let r = 0; + for (let i = a; i >= 0; i--) { + r += e[i] + t[i]; + e[i] = 255 & r; + r >>= 8; + } +} +function incHex(e, t) { + let a = 1; + for (let r = t; r >= 0 && a > 0; r--) { + a += e[r]; + e[r] = 255 & a; + a >>= 8; + } +} +const Ka = 16; +class BinaryCMapStream { + constructor(e) { + this.buffer = e; + this.pos = 0; + this.end = e.length; + this.tmpBuf = new Uint8Array(19); + } + readByte() { + return this.pos >= this.end ? -1 : this.buffer[this.pos++]; + } + readNumber() { + let e, + t = 0; + do { + const a = this.readByte(); + if (a < 0) throw new FormatError("unexpected EOF in bcmap"); + e = !(128 & a); + t = (t << 7) | (127 & a); + } while (!e); + return t; + } + readSigned() { + const e = this.readNumber(); + return 1 & e ? ~(e >>> 1) : e >>> 1; + } + readHex(e, t) { + e.set(this.buffer.subarray(this.pos, this.pos + t + 1)); + this.pos += t + 1; + } + readHexNumber(e, t) { + let a; + const r = this.tmpBuf; + let i = 0; + do { + const e = this.readByte(); + if (e < 0) throw new FormatError("unexpected EOF in bcmap"); + a = !(128 & e); + r[i++] = 127 & e; + } while (!a); + let n = t, + s = 0, + o = 0; + for (; n >= 0; ) { + for (; o < 8 && r.length > 0; ) { + s |= r[--i] << o; + o += 7; + } + e[n] = 255 & s; + n--; + s >>= 8; + o -= 8; + } + } + readHexSigned(e, t) { + this.readHexNumber(e, t); + const a = 1 & e[t] ? 255 : 0; + let r = 0; + for (let i = 0; i <= t; i++) { + r = ((1 & r) << 8) | e[i]; + e[i] = (r >> 1) ^ a; + } + } + readString() { + const e = this.readNumber(), + t = new Array(e); + for (let a = 0; a < e; a++) t[a] = this.readNumber(); + return String.fromCharCode(...t); + } +} +class BinaryCMapReader { + async process(e, t, a) { + const r = new BinaryCMapStream(e), + i = r.readByte(); + t.vertical = !!(1 & i); + let n = null; + const s = new Uint8Array(Ka), + o = new Uint8Array(Ka), + c = new Uint8Array(Ka), + l = new Uint8Array(Ka), + h = new Uint8Array(Ka); + let u, d; + for (; (d = r.readByte()) >= 0; ) { + const e = d >> 5; + if (7 === e) { + switch (31 & d) { + case 0: + r.readString(); + break; + case 1: + n = r.readString(); + } + continue; + } + const a = !!(16 & d), + i = 15 & d; + if (i + 1 > Ka) + throw new Error("BinaryCMapReader.process: Invalid dataSize."); + const f = 1, + g = r.readNumber(); + switch (e) { + case 0: + r.readHex(s, i); + r.readHexNumber(o, i); + addHex(o, s, i); + t.addCodespaceRange(i + 1, hexToInt(s, i), hexToInt(o, i)); + for (let e = 1; e < g; e++) { + incHex(o, i); + r.readHexNumber(s, i); + addHex(s, o, i); + r.readHexNumber(o, i); + addHex(o, s, i); + t.addCodespaceRange(i + 1, hexToInt(s, i), hexToInt(o, i)); + } + break; + case 1: + r.readHex(s, i); + r.readHexNumber(o, i); + addHex(o, s, i); + r.readNumber(); + for (let e = 1; e < g; e++) { + incHex(o, i); + r.readHexNumber(s, i); + addHex(s, o, i); + r.readHexNumber(o, i); + addHex(o, s, i); + r.readNumber(); + } + break; + case 2: + r.readHex(c, i); + u = r.readNumber(); + t.mapOne(hexToInt(c, i), u); + for (let e = 1; e < g; e++) { + incHex(c, i); + if (!a) { + r.readHexNumber(h, i); + addHex(c, h, i); + } + u = r.readSigned() + (u + 1); + t.mapOne(hexToInt(c, i), u); + } + break; + case 3: + r.readHex(s, i); + r.readHexNumber(o, i); + addHex(o, s, i); + u = r.readNumber(); + t.mapCidRange(hexToInt(s, i), hexToInt(o, i), u); + for (let e = 1; e < g; e++) { + incHex(o, i); + if (a) s.set(o); + else { + r.readHexNumber(s, i); + addHex(s, o, i); + } + r.readHexNumber(o, i); + addHex(o, s, i); + u = r.readNumber(); + t.mapCidRange(hexToInt(s, i), hexToInt(o, i), u); + } + break; + case 4: + r.readHex(c, f); + r.readHex(l, i); + t.mapOne(hexToInt(c, f), hexToStr(l, i)); + for (let e = 1; e < g; e++) { + incHex(c, f); + if (!a) { + r.readHexNumber(h, f); + addHex(c, h, f); + } + incHex(l, i); + r.readHexSigned(h, i); + addHex(l, h, i); + t.mapOne(hexToInt(c, f), hexToStr(l, i)); + } + break; + case 5: + r.readHex(s, f); + r.readHexNumber(o, f); + addHex(o, s, f); + r.readHex(l, i); + t.mapBfRange(hexToInt(s, f), hexToInt(o, f), hexToStr(l, i)); + for (let e = 1; e < g; e++) { + incHex(o, f); + if (a) s.set(o); + else { + r.readHexNumber(s, f); + addHex(s, o, f); + } + r.readHexNumber(o, f); + addHex(o, s, f); + r.readHex(l, i); + t.mapBfRange(hexToInt(s, f), hexToInt(o, f), hexToStr(l, i)); + } + break; + default: + throw new Error(`BinaryCMapReader.process - unknown type: ${e}`); + } + } + return n ? a(n) : t; + } +} +class Ascii85Stream extends DecodeStream { + constructor(e, t) { + t && (t *= 0.8); + super(t); + this.str = e; + this.dict = e.dict; + this.input = new Uint8Array(5); + } + readBlock() { + const e = this.str; + let t = e.getByte(); + for (; isWhiteSpace(t); ) t = e.getByte(); + if (-1 === t || 126 === t) { + this.eof = !0; + return; + } + const a = this.bufferLength; + let r, i; + if (122 === t) { + r = this.ensureBuffer(a + 4); + for (i = 0; i < 4; ++i) r[a + i] = 0; + this.bufferLength += 4; + } else { + const n = this.input; + n[0] = t; + for (i = 1; i < 5; ++i) { + t = e.getByte(); + for (; isWhiteSpace(t); ) t = e.getByte(); + n[i] = t; + if (-1 === t || 126 === t) break; + } + r = this.ensureBuffer(a + i - 1); + this.bufferLength += i - 1; + if (i < 5) { + for (; i < 5; ++i) n[i] = 117; + this.eof = !0; + } + let s = 0; + for (i = 0; i < 5; ++i) s = 85 * s + (n[i] - 33); + for (i = 3; i >= 0; --i) { + r[a + i] = 255 & s; + s >>= 8; + } + } + } +} +class AsciiHexStream extends DecodeStream { + constructor(e, t) { + t && (t *= 0.5); + super(t); + this.str = e; + this.dict = e.dict; + this.firstDigit = -1; + } + readBlock() { + const e = this.str.getBytes(8e3); + if (!e.length) { + this.eof = !0; + return; + } + const t = (e.length + 1) >> 1, + a = this.ensureBuffer(this.bufferLength + t); + let r = this.bufferLength, + i = this.firstDigit; + for (const t of e) { + let e; + if (t >= 48 && t <= 57) e = 15 & t; + else { + if (!((t >= 65 && t <= 70) || (t >= 97 && t <= 102))) { + if (62 === t) { + this.eof = !0; + break; + } + continue; + } + e = 9 + (15 & t); + } + if (i < 0) i = e; + else { + a[r++] = (i << 4) | e; + i = -1; + } + } + if (i >= 0 && this.eof) { + a[r++] = i << 4; + i = -1; + } + this.firstDigit = i; + this.bufferLength = r; + } +} +const Ja = -1, + Ya = [ + [-1, -1], + [-1, -1], + [7, 8], + [7, 7], + [6, 6], + [6, 6], + [6, 5], + [6, 5], + [4, 0], + [4, 0], + [4, 0], + [4, 0], + [4, 0], + [4, 0], + [4, 0], + [4, 0], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [3, 3], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + [1, 2], + ], + Za = [ + [-1, -1], + [12, -2], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [11, 1792], + [11, 1792], + [12, 1984], + [12, 2048], + [12, 2112], + [12, 2176], + [12, 2240], + [12, 2304], + [11, 1856], + [11, 1856], + [11, 1920], + [11, 1920], + [12, 2368], + [12, 2432], + [12, 2496], + [12, 2560], + ], + Qa = [ + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [8, 29], + [8, 29], + [8, 30], + [8, 30], + [8, 45], + [8, 45], + [8, 46], + [8, 46], + [7, 22], + [7, 22], + [7, 22], + [7, 22], + [7, 23], + [7, 23], + [7, 23], + [7, 23], + [8, 47], + [8, 47], + [8, 48], + [8, 48], + [6, 13], + [6, 13], + [6, 13], + [6, 13], + [6, 13], + [6, 13], + [6, 13], + [6, 13], + [7, 20], + [7, 20], + [7, 20], + [7, 20], + [8, 33], + [8, 33], + [8, 34], + [8, 34], + [8, 35], + [8, 35], + [8, 36], + [8, 36], + [8, 37], + [8, 37], + [8, 38], + [8, 38], + [7, 19], + [7, 19], + [7, 19], + [7, 19], + [8, 31], + [8, 31], + [8, 32], + [8, 32], + [6, 1], + [6, 1], + [6, 1], + [6, 1], + [6, 1], + [6, 1], + [6, 1], + [6, 1], + [6, 12], + [6, 12], + [6, 12], + [6, 12], + [6, 12], + [6, 12], + [6, 12], + [6, 12], + [8, 53], + [8, 53], + [8, 54], + [8, 54], + [7, 26], + [7, 26], + [7, 26], + [7, 26], + [8, 39], + [8, 39], + [8, 40], + [8, 40], + [8, 41], + [8, 41], + [8, 42], + [8, 42], + [8, 43], + [8, 43], + [8, 44], + [8, 44], + [7, 21], + [7, 21], + [7, 21], + [7, 21], + [7, 28], + [7, 28], + [7, 28], + [7, 28], + [8, 61], + [8, 61], + [8, 62], + [8, 62], + [8, 63], + [8, 63], + [8, 0], + [8, 0], + [8, 320], + [8, 320], + [8, 384], + [8, 384], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 10], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [5, 11], + [7, 27], + [7, 27], + [7, 27], + [7, 27], + [8, 59], + [8, 59], + [8, 60], + [8, 60], + [9, 1472], + [9, 1536], + [9, 1600], + [9, 1728], + [7, 18], + [7, 18], + [7, 18], + [7, 18], + [7, 24], + [7, 24], + [7, 24], + [7, 24], + [8, 49], + [8, 49], + [8, 50], + [8, 50], + [8, 51], + [8, 51], + [8, 52], + [8, 52], + [7, 25], + [7, 25], + [7, 25], + [7, 25], + [8, 55], + [8, 55], + [8, 56], + [8, 56], + [8, 57], + [8, 57], + [8, 58], + [8, 58], + [6, 192], + [6, 192], + [6, 192], + [6, 192], + [6, 192], + [6, 192], + [6, 192], + [6, 192], + [6, 1664], + [6, 1664], + [6, 1664], + [6, 1664], + [6, 1664], + [6, 1664], + [6, 1664], + [6, 1664], + [8, 448], + [8, 448], + [8, 512], + [8, 512], + [9, 704], + [9, 768], + [8, 640], + [8, 640], + [8, 576], + [8, 576], + [9, 832], + [9, 896], + [9, 960], + [9, 1024], + [9, 1088], + [9, 1152], + [9, 1216], + [9, 1280], + [9, 1344], + [9, 1408], + [7, 256], + [7, 256], + [7, 256], + [7, 256], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 2], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [4, 3], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 128], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 8], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [5, 9], + [6, 16], + [6, 16], + [6, 16], + [6, 16], + [6, 16], + [6, 16], + [6, 16], + [6, 16], + [6, 17], + [6, 17], + [6, 17], + [6, 17], + [6, 17], + [6, 17], + [6, 17], + [6, 17], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 4], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [6, 14], + [6, 14], + [6, 14], + [6, 14], + [6, 14], + [6, 14], + [6, 14], + [6, 14], + [6, 15], + [6, 15], + [6, 15], + [6, 15], + [6, 15], + [6, 15], + [6, 15], + [6, 15], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [5, 64], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + [4, 7], + ], + er = [ + [-1, -1], + [-1, -1], + [12, -2], + [12, -2], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [11, 1792], + [11, 1792], + [11, 1792], + [11, 1792], + [12, 1984], + [12, 1984], + [12, 2048], + [12, 2048], + [12, 2112], + [12, 2112], + [12, 2176], + [12, 2176], + [12, 2240], + [12, 2240], + [12, 2304], + [12, 2304], + [11, 1856], + [11, 1856], + [11, 1856], + [11, 1856], + [11, 1920], + [11, 1920], + [11, 1920], + [11, 1920], + [12, 2368], + [12, 2368], + [12, 2432], + [12, 2432], + [12, 2496], + [12, 2496], + [12, 2560], + [12, 2560], + [10, 18], + [10, 18], + [10, 18], + [10, 18], + [10, 18], + [10, 18], + [10, 18], + [10, 18], + [12, 52], + [12, 52], + [13, 640], + [13, 704], + [13, 768], + [13, 832], + [12, 55], + [12, 55], + [12, 56], + [12, 56], + [13, 1280], + [13, 1344], + [13, 1408], + [13, 1472], + [12, 59], + [12, 59], + [12, 60], + [12, 60], + [13, 1536], + [13, 1600], + [11, 24], + [11, 24], + [11, 24], + [11, 24], + [11, 25], + [11, 25], + [11, 25], + [11, 25], + [13, 1664], + [13, 1728], + [12, 320], + [12, 320], + [12, 384], + [12, 384], + [12, 448], + [12, 448], + [13, 512], + [13, 576], + [12, 53], + [12, 53], + [12, 54], + [12, 54], + [13, 896], + [13, 960], + [13, 1024], + [13, 1088], + [13, 1152], + [13, 1216], + [10, 64], + [10, 64], + [10, 64], + [10, 64], + [10, 64], + [10, 64], + [10, 64], + [10, 64], + ], + tr = [ + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [8, 13], + [11, 23], + [11, 23], + [12, 50], + [12, 51], + [12, 44], + [12, 45], + [12, 46], + [12, 47], + [12, 57], + [12, 58], + [12, 61], + [12, 256], + [10, 16], + [10, 16], + [10, 16], + [10, 16], + [10, 17], + [10, 17], + [10, 17], + [10, 17], + [12, 48], + [12, 49], + [12, 62], + [12, 63], + [12, 30], + [12, 31], + [12, 32], + [12, 33], + [12, 40], + [12, 41], + [11, 22], + [11, 22], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [8, 14], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 10], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [7, 11], + [9, 15], + [9, 15], + [9, 15], + [9, 15], + [9, 15], + [9, 15], + [9, 15], + [9, 15], + [12, 128], + [12, 192], + [12, 26], + [12, 27], + [12, 28], + [12, 29], + [11, 19], + [11, 19], + [11, 20], + [11, 20], + [12, 34], + [12, 35], + [12, 36], + [12, 37], + [12, 38], + [12, 39], + [11, 21], + [11, 21], + [12, 42], + [12, 43], + [10, 0], + [10, 0], + [10, 0], + [10, 0], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + [7, 12], + ], + ar = [ + [-1, -1], + [-1, -1], + [-1, -1], + [-1, -1], + [6, 9], + [6, 8], + [5, 7], + [5, 7], + [4, 6], + [4, 6], + [4, 6], + [4, 6], + [4, 5], + [4, 5], + [4, 5], + [4, 5], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 1], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [3, 4], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 3], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + [2, 2], + ]; +class CCITTFaxDecoder { + constructor(e, t = {}) { + if ("function" != typeof e?.next) + throw new Error('CCITTFaxDecoder - invalid "source" parameter.'); + this.source = e; + this.eof = !1; + this.encoding = t.K || 0; + this.eoline = t.EndOfLine || !1; + this.byteAlign = t.EncodedByteAlign || !1; + this.columns = t.Columns || 1728; + this.rows = t.Rows || 0; + this.eoblock = t.EndOfBlock ?? !0; + this.black = t.BlackIs1 || !1; + this.codingLine = new Uint32Array(this.columns + 1); + this.refLine = new Uint32Array(this.columns + 2); + this.codingLine[0] = this.columns; + this.codingPos = 0; + this.row = 0; + this.nextLine2D = this.encoding < 0; + this.inputBits = 0; + this.inputBuf = 0; + this.outputBits = 0; + this.rowsDone = !1; + let a; + for (; 0 === (a = this._lookBits(12)); ) this._eatBits(1); + 1 === a && this._eatBits(12); + if (this.encoding > 0) { + this.nextLine2D = !this._lookBits(1); + this._eatBits(1); + } + } + readNextChar() { + if (this.eof) return -1; + const e = this.refLine, + t = this.codingLine, + a = this.columns; + let r, i, n, s, o; + if (0 === this.outputBits) { + this.rowsDone && (this.eof = !0); + if (this.eof) return -1; + this.err = !1; + let n, o, c; + if (this.nextLine2D) { + for (s = 0; t[s] < a; ++s) e[s] = t[s]; + e[s++] = a; + e[s] = a; + t[0] = 0; + this.codingPos = 0; + r = 0; + i = 0; + for (; t[this.codingPos] < a; ) { + n = this._getTwoDimCode(); + switch (n) { + case 0: + this._addPixels(e[r + 1], i); + e[r + 1] < a && (r += 2); + break; + case 1: + n = o = 0; + if (i) { + do { + n += c = this._getBlackCode(); + } while (c >= 64); + do { + o += c = this._getWhiteCode(); + } while (c >= 64); + } else { + do { + n += c = this._getWhiteCode(); + } while (c >= 64); + do { + o += c = this._getBlackCode(); + } while (c >= 64); + } + this._addPixels(t[this.codingPos] + n, i); + t[this.codingPos] < a && + this._addPixels(t[this.codingPos] + o, 1 ^ i); + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + break; + case 7: + this._addPixels(e[r] + 3, i); + i ^= 1; + if (t[this.codingPos] < a) { + ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 5: + this._addPixels(e[r] + 2, i); + i ^= 1; + if (t[this.codingPos] < a) { + ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 3: + this._addPixels(e[r] + 1, i); + i ^= 1; + if (t[this.codingPos] < a) { + ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 2: + this._addPixels(e[r], i); + i ^= 1; + if (t[this.codingPos] < a) { + ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 8: + this._addPixelsNeg(e[r] - 3, i); + i ^= 1; + if (t[this.codingPos] < a) { + r > 0 ? --r : ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 6: + this._addPixelsNeg(e[r] - 2, i); + i ^= 1; + if (t[this.codingPos] < a) { + r > 0 ? --r : ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case 4: + this._addPixelsNeg(e[r] - 1, i); + i ^= 1; + if (t[this.codingPos] < a) { + r > 0 ? --r : ++r; + for (; e[r] <= t[this.codingPos] && e[r] < a; ) r += 2; + } + break; + case Ja: + this._addPixels(a, 0); + this.eof = !0; + break; + default: + info("bad 2d code"); + this._addPixels(a, 0); + this.err = !0; + } + } + } else { + t[0] = 0; + this.codingPos = 0; + i = 0; + for (; t[this.codingPos] < a; ) { + n = 0; + if (i) + do { + n += c = this._getBlackCode(); + } while (c >= 64); + else + do { + n += c = this._getWhiteCode(); + } while (c >= 64); + this._addPixels(t[this.codingPos] + n, i); + i ^= 1; + } + } + let l = !1; + this.byteAlign && (this.inputBits &= -8); + if (this.eoblock || this.row !== this.rows - 1) { + n = this._lookBits(12); + if (this.eoline) + for (; n !== Ja && 1 !== n; ) { + this._eatBits(1); + n = this._lookBits(12); + } + else + for (; 0 === n; ) { + this._eatBits(1); + n = this._lookBits(12); + } + if (1 === n) { + this._eatBits(12); + l = !0; + } else n === Ja && (this.eof = !0); + } else this.rowsDone = !0; + if (!this.eof && this.encoding > 0 && !this.rowsDone) { + this.nextLine2D = !this._lookBits(1); + this._eatBits(1); + } + if (this.eoblock && l && this.byteAlign) { + n = this._lookBits(12); + if (1 === n) { + this._eatBits(12); + if (this.encoding > 0) { + this._lookBits(1); + this._eatBits(1); + } + if (this.encoding >= 0) + for (s = 0; s < 4; ++s) { + n = this._lookBits(12); + 1 !== n && info("bad rtc code: " + n); + this._eatBits(12); + if (this.encoding > 0) { + this._lookBits(1); + this._eatBits(1); + } + } + this.eof = !0; + } + } else if (this.err && this.eoline) { + for (;;) { + n = this._lookBits(13); + if (n === Ja) { + this.eof = !0; + return -1; + } + if (n >> 1 == 1) break; + this._eatBits(1); + } + this._eatBits(12); + if (this.encoding > 0) { + this._eatBits(1); + this.nextLine2D = !(1 & n); + } + } + this.outputBits = + t[0] > 0 ? t[(this.codingPos = 0)] : t[(this.codingPos = 1)]; + this.row++; + } + if (this.outputBits >= 8) { + o = 1 & this.codingPos ? 0 : 255; + this.outputBits -= 8; + if (0 === this.outputBits && t[this.codingPos] < a) { + this.codingPos++; + this.outputBits = t[this.codingPos] - t[this.codingPos - 1]; + } + } else { + n = 8; + o = 0; + do { + if ("number" != typeof this.outputBits) + throw new FormatError( + 'Invalid /CCITTFaxDecode data, "outputBits" must be a number.', + ); + if (this.outputBits > n) { + o <<= n; + 1 & this.codingPos || (o |= 255 >> (8 - n)); + this.outputBits -= n; + n = 0; + } else { + o <<= this.outputBits; + 1 & this.codingPos || (o |= 255 >> (8 - this.outputBits)); + n -= this.outputBits; + this.outputBits = 0; + if (t[this.codingPos] < a) { + this.codingPos++; + this.outputBits = t[this.codingPos] - t[this.codingPos - 1]; + } else if (n > 0) { + o <<= n; + n = 0; + } + } + } while (n); + } + this.black && (o ^= 255); + return o; + } + _addPixels(e, t) { + const a = this.codingLine; + let r = this.codingPos; + if (e > a[r]) { + if (e > this.columns) { + info("row is wrong length"); + this.err = !0; + e = this.columns; + } + (1 & r) ^ t && ++r; + a[r] = e; + } + this.codingPos = r; + } + _addPixelsNeg(e, t) { + const a = this.codingLine; + let r = this.codingPos; + if (e > a[r]) { + if (e > this.columns) { + info("row is wrong length"); + this.err = !0; + e = this.columns; + } + (1 & r) ^ t && ++r; + a[r] = e; + } else if (e < a[r]) { + if (e < 0) { + info("invalid code"); + this.err = !0; + e = 0; + } + for (; r > 0 && e < a[r - 1]; ) --r; + a[r] = e; + } + this.codingPos = r; + } + _findTableCode(e, t, a, r) { + const i = r || 0; + for (let r = e; r <= t; ++r) { + let e = this._lookBits(r); + if (e === Ja) return [!0, 1, !1]; + r < t && (e <<= t - r); + if (!i || e >= i) { + const t = a[e - i]; + if (t[0] === r) { + this._eatBits(r); + return [!0, t[1], !0]; + } + } + } + return [!1, 0, !1]; + } + _getTwoDimCode() { + let e, + t = 0; + if (this.eoblock) { + t = this._lookBits(7); + e = Ya[t]; + if (e?.[0] > 0) { + this._eatBits(e[0]); + return e[1]; + } + } else { + const e = this._findTableCode(1, 7, Ya); + if (e[0] && e[2]) return e[1]; + } + info("Bad two dim code"); + return Ja; + } + _getWhiteCode() { + let e, + t = 0; + if (this.eoblock) { + t = this._lookBits(12); + if (t === Ja) return 1; + e = t >> 5 ? Qa[t >> 3] : Za[t]; + if (e[0] > 0) { + this._eatBits(e[0]); + return e[1]; + } + } else { + let e = this._findTableCode(1, 9, Qa); + if (e[0]) return e[1]; + e = this._findTableCode(11, 12, Za); + if (e[0]) return e[1]; + } + info("bad white code"); + this._eatBits(1); + return 1; + } + _getBlackCode() { + let e, t; + if (this.eoblock) { + e = this._lookBits(13); + if (e === Ja) return 1; + t = + e >> 7 ? (!(e >> 9) && e >> 7 ? tr[(e >> 1) - 64] : ar[e >> 7]) : er[e]; + if (t[0] > 0) { + this._eatBits(t[0]); + return t[1]; + } + } else { + let e = this._findTableCode(2, 6, ar); + if (e[0]) return e[1]; + e = this._findTableCode(7, 12, tr, 64); + if (e[0]) return e[1]; + e = this._findTableCode(10, 13, er); + if (e[0]) return e[1]; + } + info("bad black code"); + this._eatBits(1); + return 1; + } + _lookBits(e) { + let t; + for (; this.inputBits < e; ) { + if (-1 === (t = this.source.next())) + return 0 === this.inputBits + ? Ja + : (this.inputBuf << (e - this.inputBits)) & (65535 >> (16 - e)); + this.inputBuf = (this.inputBuf << 8) | t; + this.inputBits += 8; + } + return (this.inputBuf >> (this.inputBits - e)) & (65535 >> (16 - e)); + } + _eatBits(e) { + (this.inputBits -= e) < 0 && (this.inputBits = 0); + } +} +class CCITTFaxStream extends DecodeStream { + constructor(e, t, a) { + super(t); + this.str = e; + this.dict = e.dict; + a instanceof Dict || (a = Dict.empty); + const r = { next: () => e.getByte() }; + this.ccittFaxDecoder = new CCITTFaxDecoder(r, { + K: a.get("K"), + EndOfLine: a.get("EndOfLine"), + EncodedByteAlign: a.get("EncodedByteAlign"), + Columns: a.get("Columns"), + Rows: a.get("Rows"), + EndOfBlock: a.get("EndOfBlock"), + BlackIs1: a.get("BlackIs1"), + }); + } + readBlock() { + for (; !this.eof; ) { + const e = this.ccittFaxDecoder.readNextChar(); + if (-1 === e) { + this.eof = !0; + return; + } + this.ensureBuffer(this.bufferLength + 1); + this.buffer[this.bufferLength++] = e; + } + } +} +const rr = new Int32Array([ + 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15, + ]), + ir = new Int32Array([ + 3, 4, 5, 6, 7, 8, 9, 10, 65547, 65549, 65551, 65553, 131091, 131095, 131099, + 131103, 196643, 196651, 196659, 196667, 262211, 262227, 262243, 262259, + 327811, 327843, 327875, 327907, 258, 258, 258, + ]), + nr = new Int32Array([ + 1, 2, 3, 4, 65541, 65543, 131081, 131085, 196625, 196633, 262177, 262193, + 327745, 327777, 393345, 393409, 459009, 459137, 524801, 525057, 590849, + 591361, 657409, 658433, 724993, 727041, 794625, 798721, 868353, 876545, + ]), + sr = [ + new Int32Array([ + 459008, 524368, 524304, 524568, 459024, 524400, 524336, 590016, 459016, + 524384, 524320, 589984, 524288, 524416, 524352, 590048, 459012, 524376, + 524312, 589968, 459028, 524408, 524344, 590032, 459020, 524392, 524328, + 59e4, 524296, 524424, 524360, 590064, 459010, 524372, 524308, 524572, + 459026, 524404, 524340, 590024, 459018, 524388, 524324, 589992, 524292, + 524420, 524356, 590056, 459014, 524380, 524316, 589976, 459030, 524412, + 524348, 590040, 459022, 524396, 524332, 590008, 524300, 524428, 524364, + 590072, 459009, 524370, 524306, 524570, 459025, 524402, 524338, 590020, + 459017, 524386, 524322, 589988, 524290, 524418, 524354, 590052, 459013, + 524378, 524314, 589972, 459029, 524410, 524346, 590036, 459021, 524394, + 524330, 590004, 524298, 524426, 524362, 590068, 459011, 524374, 524310, + 524574, 459027, 524406, 524342, 590028, 459019, 524390, 524326, 589996, + 524294, 524422, 524358, 590060, 459015, 524382, 524318, 589980, 459031, + 524414, 524350, 590044, 459023, 524398, 524334, 590012, 524302, 524430, + 524366, 590076, 459008, 524369, 524305, 524569, 459024, 524401, 524337, + 590018, 459016, 524385, 524321, 589986, 524289, 524417, 524353, 590050, + 459012, 524377, 524313, 589970, 459028, 524409, 524345, 590034, 459020, + 524393, 524329, 590002, 524297, 524425, 524361, 590066, 459010, 524373, + 524309, 524573, 459026, 524405, 524341, 590026, 459018, 524389, 524325, + 589994, 524293, 524421, 524357, 590058, 459014, 524381, 524317, 589978, + 459030, 524413, 524349, 590042, 459022, 524397, 524333, 590010, 524301, + 524429, 524365, 590074, 459009, 524371, 524307, 524571, 459025, 524403, + 524339, 590022, 459017, 524387, 524323, 589990, 524291, 524419, 524355, + 590054, 459013, 524379, 524315, 589974, 459029, 524411, 524347, 590038, + 459021, 524395, 524331, 590006, 524299, 524427, 524363, 590070, 459011, + 524375, 524311, 524575, 459027, 524407, 524343, 590030, 459019, 524391, + 524327, 589998, 524295, 524423, 524359, 590062, 459015, 524383, 524319, + 589982, 459031, 524415, 524351, 590046, 459023, 524399, 524335, 590014, + 524303, 524431, 524367, 590078, 459008, 524368, 524304, 524568, 459024, + 524400, 524336, 590017, 459016, 524384, 524320, 589985, 524288, 524416, + 524352, 590049, 459012, 524376, 524312, 589969, 459028, 524408, 524344, + 590033, 459020, 524392, 524328, 590001, 524296, 524424, 524360, 590065, + 459010, 524372, 524308, 524572, 459026, 524404, 524340, 590025, 459018, + 524388, 524324, 589993, 524292, 524420, 524356, 590057, 459014, 524380, + 524316, 589977, 459030, 524412, 524348, 590041, 459022, 524396, 524332, + 590009, 524300, 524428, 524364, 590073, 459009, 524370, 524306, 524570, + 459025, 524402, 524338, 590021, 459017, 524386, 524322, 589989, 524290, + 524418, 524354, 590053, 459013, 524378, 524314, 589973, 459029, 524410, + 524346, 590037, 459021, 524394, 524330, 590005, 524298, 524426, 524362, + 590069, 459011, 524374, 524310, 524574, 459027, 524406, 524342, 590029, + 459019, 524390, 524326, 589997, 524294, 524422, 524358, 590061, 459015, + 524382, 524318, 589981, 459031, 524414, 524350, 590045, 459023, 524398, + 524334, 590013, 524302, 524430, 524366, 590077, 459008, 524369, 524305, + 524569, 459024, 524401, 524337, 590019, 459016, 524385, 524321, 589987, + 524289, 524417, 524353, 590051, 459012, 524377, 524313, 589971, 459028, + 524409, 524345, 590035, 459020, 524393, 524329, 590003, 524297, 524425, + 524361, 590067, 459010, 524373, 524309, 524573, 459026, 524405, 524341, + 590027, 459018, 524389, 524325, 589995, 524293, 524421, 524357, 590059, + 459014, 524381, 524317, 589979, 459030, 524413, 524349, 590043, 459022, + 524397, 524333, 590011, 524301, 524429, 524365, 590075, 459009, 524371, + 524307, 524571, 459025, 524403, 524339, 590023, 459017, 524387, 524323, + 589991, 524291, 524419, 524355, 590055, 459013, 524379, 524315, 589975, + 459029, 524411, 524347, 590039, 459021, 524395, 524331, 590007, 524299, + 524427, 524363, 590071, 459011, 524375, 524311, 524575, 459027, 524407, + 524343, 590031, 459019, 524391, 524327, 589999, 524295, 524423, 524359, + 590063, 459015, 524383, 524319, 589983, 459031, 524415, 524351, 590047, + 459023, 524399, 524335, 590015, 524303, 524431, 524367, 590079, + ]), + 9, + ], + or = [ + new Int32Array([ + 327680, 327696, 327688, 327704, 327684, 327700, 327692, 327708, 327682, + 327698, 327690, 327706, 327686, 327702, 327694, 0, 327681, 327697, 327689, + 327705, 327685, 327701, 327693, 327709, 327683, 327699, 327691, 327707, + 327687, 327703, 327695, 0, + ]), + 5, + ]; +class FlateStream extends DecodeStream { + constructor(e, t) { + super(t); + this.str = e; + this.dict = e.dict; + const a = e.getByte(), + r = e.getByte(); + if (-1 === a || -1 === r) + throw new FormatError(`Invalid header in flate stream: ${a}, ${r}`); + if (8 != (15 & a)) + throw new FormatError( + `Unknown compression method in flate stream: ${a}, ${r}`, + ); + if (((a << 8) + r) % 31 != 0) + throw new FormatError(`Bad FCHECK in flate stream: ${a}, ${r}`); + if (32 & r) + throw new FormatError(`FDICT bit set in flate stream: ${a}, ${r}`); + this.codeSize = 0; + this.codeBuf = 0; + } + async getImageData(e, t) { + const a = await this.asyncGetBytes(); + return a ? (a.length <= e ? a : a.subarray(0, e)) : this.getBytes(e); + } + async asyncGetBytes() { + this.str.reset(); + const e = this.str.getBytes(); + try { + const { readable: t, writable: a } = new DecompressionStream("deflate"), + r = a.getWriter(); + await r.ready; + r.write(e) + .then(async () => { + await r.ready; + await r.close(); + }) + .catch(() => {}); + const i = []; + let n = 0; + for await (const e of t) { + i.push(e); + n += e.byteLength; + } + const s = new Uint8Array(n); + let o = 0; + for (const e of i) { + s.set(e, o); + o += e.byteLength; + } + return s; + } catch { + this.str = new Stream(e, 2, e.length, this.str.dict); + this.reset(); + return null; + } + } + get isAsync() { + return !0; + } + getBits(e) { + const t = this.str; + let a, + r = this.codeSize, + i = this.codeBuf; + for (; r < e; ) { + if (-1 === (a = t.getByte())) + throw new FormatError("Bad encoding in flate stream"); + i |= a << r; + r += 8; + } + a = i & ((1 << e) - 1); + this.codeBuf = i >> e; + this.codeSize = r -= e; + return a; + } + getCode(e) { + const t = this.str, + a = e[0], + r = e[1]; + let i, + n = this.codeSize, + s = this.codeBuf; + for (; n < r && -1 !== (i = t.getByte()); ) { + s |= i << n; + n += 8; + } + const o = a[s & ((1 << r) - 1)], + c = o >> 16, + l = 65535 & o; + if (c < 1 || n < c) throw new FormatError("Bad encoding in flate stream"); + this.codeBuf = s >> c; + this.codeSize = n - c; + return l; + } + generateHuffmanTable(e) { + const t = e.length; + let a, + r = 0; + for (a = 0; a < t; ++a) e[a] > r && (r = e[a]); + const i = 1 << r, + n = new Int32Array(i); + for (let s = 1, o = 0, c = 2; s <= r; ++s, o <<= 1, c <<= 1) + for (let r = 0; r < t; ++r) + if (e[r] === s) { + let e = 0, + t = o; + for (a = 0; a < s; ++a) { + e = (e << 1) | (1 & t); + t >>= 1; + } + for (a = e; a < i; a += c) n[a] = (s << 16) | r; + ++o; + } + return [n, r]; + } + #X(e) { + info(e); + this.eof = !0; + } + readBlock() { + let e, t, a; + const r = this.str; + try { + t = this.getBits(3); + } catch (e) { + this.#X(e.message); + return; + } + 1 & t && (this.eof = !0); + t >>= 1; + if (0 === t) { + let t; + if (-1 === (t = r.getByte())) { + this.#X("Bad block header in flate stream"); + return; + } + let a = t; + if (-1 === (t = r.getByte())) { + this.#X("Bad block header in flate stream"); + return; + } + a |= t << 8; + if (-1 === (t = r.getByte())) { + this.#X("Bad block header in flate stream"); + return; + } + let i = t; + if (-1 === (t = r.getByte())) { + this.#X("Bad block header in flate stream"); + return; + } + i |= t << 8; + if (i !== (65535 & ~a) && (0 !== a || 0 !== i)) + throw new FormatError("Bad uncompressed block length in flate stream"); + this.codeBuf = 0; + this.codeSize = 0; + const n = this.bufferLength, + s = n + a; + e = this.ensureBuffer(s); + this.bufferLength = s; + if (0 === a) -1 === r.peekByte() && (this.eof = !0); + else { + const t = r.getBytes(a); + e.set(t, n); + t.length < a && (this.eof = !0); + } + return; + } + let i, n; + if (1 === t) { + i = sr; + n = or; + } else { + if (2 !== t) throw new FormatError("Unknown block type in flate stream"); + { + const e = this.getBits(5) + 257, + t = this.getBits(5) + 1, + r = this.getBits(4) + 4, + s = new Uint8Array(rr.length); + let o; + for (o = 0; o < r; ++o) s[rr[o]] = this.getBits(3); + const c = this.generateHuffmanTable(s); + a = 0; + o = 0; + const l = e + t, + h = new Uint8Array(l); + let u, d, f; + for (; o < l; ) { + const e = this.getCode(c); + if (16 === e) { + u = 2; + d = 3; + f = a; + } else if (17 === e) { + u = 3; + d = 3; + f = a = 0; + } else { + if (18 !== e) { + h[o++] = a = e; + continue; + } + u = 7; + d = 11; + f = a = 0; + } + let t = this.getBits(u) + d; + for (; t-- > 0; ) h[o++] = f; + } + i = this.generateHuffmanTable(h.subarray(0, e)); + n = this.generateHuffmanTable(h.subarray(e, l)); + } + } + e = this.buffer; + let s = e ? e.length : 0, + o = this.bufferLength; + for (;;) { + let t = this.getCode(i); + if (t < 256) { + if (o + 1 >= s) { + e = this.ensureBuffer(o + 1); + s = e.length; + } + e[o++] = t; + continue; + } + if (256 === t) { + this.bufferLength = o; + return; + } + t -= 257; + t = ir[t]; + let r = t >> 16; + r > 0 && (r = this.getBits(r)); + a = (65535 & t) + r; + t = this.getCode(n); + t = nr[t]; + r = t >> 16; + r > 0 && (r = this.getBits(r)); + const c = (65535 & t) + r; + if (o + a >= s) { + e = this.ensureBuffer(o + a); + s = e.length; + } + for (let t = 0; t < a; ++t, ++o) e[o] = e[o - c]; + } + } +} +const cr = [ + { qe: 22017, nmps: 1, nlps: 1, switchFlag: 1 }, + { qe: 13313, nmps: 2, nlps: 6, switchFlag: 0 }, + { qe: 6145, nmps: 3, nlps: 9, switchFlag: 0 }, + { qe: 2753, nmps: 4, nlps: 12, switchFlag: 0 }, + { qe: 1313, nmps: 5, nlps: 29, switchFlag: 0 }, + { qe: 545, nmps: 38, nlps: 33, switchFlag: 0 }, + { qe: 22017, nmps: 7, nlps: 6, switchFlag: 1 }, + { qe: 21505, nmps: 8, nlps: 14, switchFlag: 0 }, + { qe: 18433, nmps: 9, nlps: 14, switchFlag: 0 }, + { qe: 14337, nmps: 10, nlps: 14, switchFlag: 0 }, + { qe: 12289, nmps: 11, nlps: 17, switchFlag: 0 }, + { qe: 9217, nmps: 12, nlps: 18, switchFlag: 0 }, + { qe: 7169, nmps: 13, nlps: 20, switchFlag: 0 }, + { qe: 5633, nmps: 29, nlps: 21, switchFlag: 0 }, + { qe: 22017, nmps: 15, nlps: 14, switchFlag: 1 }, + { qe: 21505, nmps: 16, nlps: 14, switchFlag: 0 }, + { qe: 20737, nmps: 17, nlps: 15, switchFlag: 0 }, + { qe: 18433, nmps: 18, nlps: 16, switchFlag: 0 }, + { qe: 14337, nmps: 19, nlps: 17, switchFlag: 0 }, + { qe: 13313, nmps: 20, nlps: 18, switchFlag: 0 }, + { qe: 12289, nmps: 21, nlps: 19, switchFlag: 0 }, + { qe: 10241, nmps: 22, nlps: 19, switchFlag: 0 }, + { qe: 9217, nmps: 23, nlps: 20, switchFlag: 0 }, + { qe: 8705, nmps: 24, nlps: 21, switchFlag: 0 }, + { qe: 7169, nmps: 25, nlps: 22, switchFlag: 0 }, + { qe: 6145, nmps: 26, nlps: 23, switchFlag: 0 }, + { qe: 5633, nmps: 27, nlps: 24, switchFlag: 0 }, + { qe: 5121, nmps: 28, nlps: 25, switchFlag: 0 }, + { qe: 4609, nmps: 29, nlps: 26, switchFlag: 0 }, + { qe: 4353, nmps: 30, nlps: 27, switchFlag: 0 }, + { qe: 2753, nmps: 31, nlps: 28, switchFlag: 0 }, + { qe: 2497, nmps: 32, nlps: 29, switchFlag: 0 }, + { qe: 2209, nmps: 33, nlps: 30, switchFlag: 0 }, + { qe: 1313, nmps: 34, nlps: 31, switchFlag: 0 }, + { qe: 1089, nmps: 35, nlps: 32, switchFlag: 0 }, + { qe: 673, nmps: 36, nlps: 33, switchFlag: 0 }, + { qe: 545, nmps: 37, nlps: 34, switchFlag: 0 }, + { qe: 321, nmps: 38, nlps: 35, switchFlag: 0 }, + { qe: 273, nmps: 39, nlps: 36, switchFlag: 0 }, + { qe: 133, nmps: 40, nlps: 37, switchFlag: 0 }, + { qe: 73, nmps: 41, nlps: 38, switchFlag: 0 }, + { qe: 37, nmps: 42, nlps: 39, switchFlag: 0 }, + { qe: 21, nmps: 43, nlps: 40, switchFlag: 0 }, + { qe: 9, nmps: 44, nlps: 41, switchFlag: 0 }, + { qe: 5, nmps: 45, nlps: 42, switchFlag: 0 }, + { qe: 1, nmps: 45, nlps: 43, switchFlag: 0 }, + { qe: 22017, nmps: 46, nlps: 46, switchFlag: 0 }, +]; +class ArithmeticDecoder { + constructor(e, t, a) { + this.data = e; + this.bp = t; + this.dataEnd = a; + this.chigh = e[t]; + this.clow = 0; + this.byteIn(); + this.chigh = ((this.chigh << 7) & 65535) | ((this.clow >> 9) & 127); + this.clow = (this.clow << 7) & 65535; + this.ct -= 7; + this.a = 32768; + } + byteIn() { + const e = this.data; + let t = this.bp; + if (255 === e[t]) + if (e[t + 1] > 143) { + this.clow += 65280; + this.ct = 8; + } else { + t++; + this.clow += e[t] << 9; + this.ct = 7; + this.bp = t; + } + else { + t++; + this.clow += t < this.dataEnd ? e[t] << 8 : 65280; + this.ct = 8; + this.bp = t; + } + if (this.clow > 65535) { + this.chigh += this.clow >> 16; + this.clow &= 65535; + } + } + readBit(e, t) { + let a = e[t] >> 1, + r = 1 & e[t]; + const i = cr[a], + n = i.qe; + let s, + o = this.a - n; + if (this.chigh < n) + if (o < n) { + o = n; + s = r; + a = i.nmps; + } else { + o = n; + s = 1 ^ r; + 1 === i.switchFlag && (r = s); + a = i.nlps; + } + else { + this.chigh -= n; + if (32768 & o) { + this.a = o; + return r; + } + if (o < n) { + s = 1 ^ r; + 1 === i.switchFlag && (r = s); + a = i.nlps; + } else { + s = r; + a = i.nmps; + } + } + do { + 0 === this.ct && this.byteIn(); + o <<= 1; + this.chigh = ((this.chigh << 1) & 65535) | ((this.clow >> 15) & 1); + this.clow = (this.clow << 1) & 65535; + this.ct--; + } while (!(32768 & o)); + this.a = o; + e[t] = (a << 1) | r; + return s; + } +} +class Jbig2Error extends fa { + constructor(e) { + super(e, "Jbig2Error"); + } +} +class ContextCache { + getContexts(e) { + return e in this ? this[e] : (this[e] = new Int8Array(65536)); + } +} +class DecodingContext { + constructor(e, t, a) { + this.data = e; + this.start = t; + this.end = a; + } + get decoder() { + return shadow( + this, + "decoder", + new ArithmeticDecoder(this.data, this.start, this.end), + ); + } + get contextCache() { + return shadow(this, "contextCache", new ContextCache()); + } +} +function decodeInteger(e, t, a) { + const r = e.getContexts(t); + let i = 1; + function readBits(e) { + let t = 0; + for (let n = 0; n < e; n++) { + const e = a.readBit(r, i); + i = i < 256 ? (i << 1) | e : (511 & ((i << 1) | e)) | 256; + t = (t << 1) | e; + } + return t >>> 0; + } + const n = readBits(1), + s = readBits(1) + ? readBits(1) + ? readBits(1) + ? readBits(1) + ? readBits(1) + ? readBits(32) + 4436 + : readBits(12) + 340 + : readBits(8) + 84 + : readBits(6) + 20 + : readBits(4) + 4 + : readBits(2); + let o; + 0 === n ? (o = s) : s > 0 && (o = -s); + return o >= -2147483648 && o <= va ? o : null; +} +function decodeIAID(e, t, a) { + const r = e.getContexts("IAID"); + let i = 1; + for (let e = 0; e < a; e++) { + i = (i << 1) | t.readBit(r, i); + } + return a < 31 ? i & ((1 << a) - 1) : 2147483647 & i; +} +const lr = [ + "SymbolDictionary", + null, + null, + null, + "IntermediateTextRegion", + null, + "ImmediateTextRegion", + "ImmediateLosslessTextRegion", + null, + null, + null, + null, + null, + null, + null, + null, + "PatternDictionary", + null, + null, + null, + "IntermediateHalftoneRegion", + null, + "ImmediateHalftoneRegion", + "ImmediateLosslessHalftoneRegion", + null, + null, + null, + null, + null, + null, + null, + null, + null, + null, + null, + null, + "IntermediateGenericRegion", + null, + "ImmediateGenericRegion", + "ImmediateLosslessGenericRegion", + "IntermediateGenericRefinementRegion", + null, + "ImmediateGenericRefinementRegion", + "ImmediateLosslessGenericRefinementRegion", + null, + null, + null, + null, + "PageInformation", + "EndOfPage", + "EndOfStripe", + "EndOfFile", + "Profiles", + "Tables", + null, + null, + null, + null, + null, + null, + null, + null, + "Extension", + ], + hr = [ + [ + { x: -1, y: -2 }, + { x: 0, y: -2 }, + { x: 1, y: -2 }, + { x: -2, y: -1 }, + { x: -1, y: -1 }, + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: 2, y: -1 }, + { x: -4, y: 0 }, + { x: -3, y: 0 }, + { x: -2, y: 0 }, + { x: -1, y: 0 }, + ], + [ + { x: -1, y: -2 }, + { x: 0, y: -2 }, + { x: 1, y: -2 }, + { x: 2, y: -2 }, + { x: -2, y: -1 }, + { x: -1, y: -1 }, + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: 2, y: -1 }, + { x: -3, y: 0 }, + { x: -2, y: 0 }, + { x: -1, y: 0 }, + ], + [ + { x: -1, y: -2 }, + { x: 0, y: -2 }, + { x: 1, y: -2 }, + { x: -2, y: -1 }, + { x: -1, y: -1 }, + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: -2, y: 0 }, + { x: -1, y: 0 }, + ], + [ + { x: -3, y: -1 }, + { x: -2, y: -1 }, + { x: -1, y: -1 }, + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: -4, y: 0 }, + { x: -3, y: 0 }, + { x: -2, y: 0 }, + { x: -1, y: 0 }, + ], + ], + ur = [ + { + coding: [ + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: -1, y: 0 }, + ], + reference: [ + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: -1, y: 0 }, + { x: 0, y: 0 }, + { x: 1, y: 0 }, + { x: -1, y: 1 }, + { x: 0, y: 1 }, + { x: 1, y: 1 }, + ], + }, + { + coding: [ + { x: -1, y: -1 }, + { x: 0, y: -1 }, + { x: 1, y: -1 }, + { x: -1, y: 0 }, + ], + reference: [ + { x: 0, y: -1 }, + { x: -1, y: 0 }, + { x: 0, y: 0 }, + { x: 1, y: 0 }, + { x: 0, y: 1 }, + { x: 1, y: 1 }, + ], + }, + ], + dr = [39717, 1941, 229, 405], + fr = [32, 8]; +function decodeBitmap(e, t, a, r, i, n, s, o) { + if (e) { + return decodeMMRBitmap(new Reader(o.data, o.start, o.end), t, a, !1); + } + if ( + 0 === r && + !n && + !i && + 4 === s.length && + 3 === s[0].x && + -1 === s[0].y && + -3 === s[1].x && + -1 === s[1].y && + 2 === s[2].x && + -2 === s[2].y && + -2 === s[3].x && + -2 === s[3].y + ) + return (function decodeBitmapTemplate0(e, t, a) { + const r = a.decoder, + i = a.contextCache.getContexts("GB"), + n = []; + let s, o, c, l, h, u, d; + for (o = 0; o < t; o++) { + h = n[o] = new Uint8Array(e); + u = o < 1 ? h : n[o - 1]; + d = o < 2 ? h : n[o - 2]; + s = + (d[0] << 13) | + (d[1] << 12) | + (d[2] << 11) | + (u[0] << 7) | + (u[1] << 6) | + (u[2] << 5) | + (u[3] << 4); + for (c = 0; c < e; c++) { + h[c] = l = r.readBit(i, s); + s = + ((31735 & s) << 1) | + (c + 3 < e ? d[c + 3] << 11 : 0) | + (c + 4 < e ? u[c + 4] << 4 : 0) | + l; + } + } + return n; + })(t, a, o); + const c = !!n, + l = hr[r].concat(s); + l.sort((e, t) => e.y - t.y || e.x - t.x); + const h = l.length, + u = new Int8Array(h), + d = new Int8Array(h), + f = []; + let g, + p, + m = 0, + b = 0, + y = 0, + w = 0; + for (p = 0; p < h; p++) { + u[p] = l[p].x; + d[p] = l[p].y; + b = Math.min(b, l[p].x); + y = Math.max(y, l[p].x); + w = Math.min(w, l[p].y); + p < h - 1 && l[p].y === l[p + 1].y && l[p].x === l[p + 1].x - 1 + ? (m |= 1 << (h - 1 - p)) + : f.push(p); + } + const x = f.length, + S = new Int8Array(x), + k = new Int8Array(x), + C = new Uint16Array(x); + for (g = 0; g < x; g++) { + p = f[g]; + S[g] = l[p].x; + k[g] = l[p].y; + C[g] = 1 << (h - 1 - p); + } + const v = -b, + F = -w, + T = t - y, + O = dr[r]; + let M = new Uint8Array(t); + const D = [], + R = o.decoder, + N = o.contextCache.getContexts("GB"); + let E, + L, + j, + _, + U, + X = 0, + q = 0; + for (let e = 0; e < a; e++) { + if (i) { + X ^= R.readBit(N, O); + if (X) { + D.push(M); + continue; + } + } + M = new Uint8Array(M); + D.push(M); + for (E = 0; E < t; E++) { + if (c && n[e][E]) { + M[E] = 0; + continue; + } + if (E >= v && E < T && e >= F) { + q = (q << 1) & m; + for (p = 0; p < x; p++) { + L = e + k[p]; + j = E + S[p]; + _ = D[L][j]; + if (_) { + _ = C[p]; + q |= _; + } + } + } else { + q = 0; + U = h - 1; + for (p = 0; p < h; p++, U--) { + j = E + u[p]; + if (j >= 0 && j < t) { + L = e + d[p]; + if (L >= 0) { + _ = D[L][j]; + _ && (q |= _ << U); + } + } + } + } + const a = R.readBit(N, q); + M[E] = a; + } + } + return D; +} +function decodeRefinement(e, t, a, r, i, n, s, o, c) { + let l = ur[a].coding; + 0 === a && (l = l.concat([o[0]])); + const h = l.length, + u = new Int32Array(h), + d = new Int32Array(h); + let f; + for (f = 0; f < h; f++) { + u[f] = l[f].x; + d[f] = l[f].y; + } + let g = ur[a].reference; + 0 === a && (g = g.concat([o[1]])); + const p = g.length, + m = new Int32Array(p), + b = new Int32Array(p); + for (f = 0; f < p; f++) { + m[f] = g[f].x; + b[f] = g[f].y; + } + const y = r[0].length, + w = r.length, + x = fr[a], + S = [], + k = c.decoder, + C = c.contextCache.getContexts("GR"); + let v = 0; + for (let a = 0; a < t; a++) { + if (s) { + v ^= k.readBit(C, x); + if (v) throw new Jbig2Error("prediction is not supported"); + } + const t = new Uint8Array(e); + S.push(t); + for (let s = 0; s < e; s++) { + let o, + c, + l = 0; + for (f = 0; f < h; f++) { + o = a + d[f]; + c = s + u[f]; + o < 0 || c < 0 || c >= e ? (l <<= 1) : (l = (l << 1) | S[o][c]); + } + for (f = 0; f < p; f++) { + o = a + b[f] - n; + c = s + m[f] - i; + o < 0 || o >= w || c < 0 || c >= y + ? (l <<= 1) + : (l = (l << 1) | r[o][c]); + } + const g = k.readBit(C, l); + t[s] = g; + } + } + return S; +} +function decodeTextRegion( + e, + t, + a, + r, + i, + n, + s, + o, + c, + l, + h, + u, + d, + f, + g, + p, + m, + b, + y, +) { + if (e && t) throw new Jbig2Error("refinement with Huffman is not supported"); + const w = []; + let x, S; + for (x = 0; x < r; x++) { + S = new Uint8Array(a); + i && S.fill(i); + w.push(S); + } + const k = m.decoder, + C = m.contextCache; + let v = e ? -f.tableDeltaT.decode(y) : -decodeInteger(C, "IADT", k), + F = 0; + x = 0; + for (; x < n; ) { + v += e ? f.tableDeltaT.decode(y) : decodeInteger(C, "IADT", k); + F += e ? f.tableFirstS.decode(y) : decodeInteger(C, "IAFS", k); + let r = F; + for (;;) { + let i = 0; + s > 1 && (i = e ? y.readBits(b) : decodeInteger(C, "IAIT", k)); + const n = s * v + i, + F = e ? f.symbolIDTable.decode(y) : decodeIAID(C, k, c), + T = t && (e ? y.readBit() : decodeInteger(C, "IARI", k)); + let O = o[F], + M = O[0].length, + D = O.length; + if (T) { + const e = decodeInteger(C, "IARDW", k), + t = decodeInteger(C, "IARDH", k); + M += e; + D += t; + O = decodeRefinement( + M, + D, + g, + O, + (e >> 1) + decodeInteger(C, "IARDX", k), + (t >> 1) + decodeInteger(C, "IARDY", k), + !1, + p, + m, + ); + } + let R = 0; + l + ? 1 & u + ? (R = D - 1) + : (r += D - 1) + : u > 1 + ? (r += M - 1) + : (R = M - 1); + const N = n - (1 & u ? 0 : D - 1), + E = r - (2 & u ? M - 1 : 0); + let L, j, _; + if (l) + for (L = 0; L < D; L++) { + S = w[E + L]; + if (!S) continue; + _ = O[L]; + const e = Math.min(a - N, M); + switch (d) { + case 0: + for (j = 0; j < e; j++) S[N + j] |= _[j]; + break; + case 2: + for (j = 0; j < e; j++) S[N + j] ^= _[j]; + break; + default: + throw new Jbig2Error(`operator ${d} is not supported`); + } + } + else + for (j = 0; j < D; j++) { + S = w[N + j]; + if (S) { + _ = O[j]; + switch (d) { + case 0: + for (L = 0; L < M; L++) S[E + L] |= _[L]; + break; + case 2: + for (L = 0; L < M; L++) S[E + L] ^= _[L]; + break; + default: + throw new Jbig2Error(`operator ${d} is not supported`); + } + } + } + x++; + const U = e ? f.tableDeltaS.decode(y) : decodeInteger(C, "IADS", k); + if (null === U) break; + r += R + U + h; + } + } + return w; +} +function readSegmentHeader(e, t) { + const a = {}; + a.number = readUint32(e, t); + const r = e[t + 4], + i = 63 & r; + if (!lr[i]) throw new Jbig2Error("invalid segment type: " + i); + a.type = i; + a.typeName = lr[i]; + a.deferredNonRetain = !!(128 & r); + const n = !!(64 & r), + s = e[t + 5]; + let o = (s >> 5) & 7; + const c = [31 & s]; + let l = t + 6; + if (7 === s) { + o = 536870911 & readUint32(e, l - 1); + l += 3; + let t = (o + 7) >> 3; + c[0] = e[l++]; + for (; --t > 0; ) c.push(e[l++]); + } else if (5 === s || 6 === s) + throw new Jbig2Error("invalid referred-to flags"); + a.retainBits = c; + let h = 4; + a.number <= 256 ? (h = 1) : a.number <= 65536 && (h = 2); + const u = []; + let d, f; + for (d = 0; d < o; d++) { + let t; + t = 1 === h ? e[l] : 2 === h ? readUint16(e, l) : readUint32(e, l); + u.push(t); + l += h; + } + a.referredTo = u; + if (n) { + a.pageAssociation = readUint32(e, l); + l += 4; + } else a.pageAssociation = e[l++]; + a.length = readUint32(e, l); + l += 4; + if (4294967295 === a.length) { + if (38 !== i) throw new Jbig2Error("invalid unknown segment length"); + { + const t = readRegionSegmentInformation(e, l), + r = !!(1 & e[l + gr]), + i = 6, + n = new Uint8Array(i); + if (!r) { + n[0] = 255; + n[1] = 172; + } + n[2] = (t.height >>> 24) & 255; + n[3] = (t.height >> 16) & 255; + n[4] = (t.height >> 8) & 255; + n[5] = 255 & t.height; + for (d = l, f = e.length; d < f; d++) { + let t = 0; + for (; t < i && n[t] === e[d + t]; ) t++; + if (t === i) { + a.length = d + i; + break; + } + } + if (4294967295 === a.length) + throw new Jbig2Error("segment end was not found"); + } + } + a.headerEnd = l; + return a; +} +function readSegments(e, t, a, r) { + const i = []; + let n = a; + for (; n < r; ) { + const a = readSegmentHeader(t, n); + n = a.headerEnd; + const r = { header: a, data: t }; + if (!e.randomAccess) { + r.start = n; + n += a.length; + r.end = n; + } + i.push(r); + if (51 === a.type) break; + } + if (e.randomAccess) + for (let e = 0, t = i.length; e < t; e++) { + i[e].start = n; + n += i[e].header.length; + i[e].end = n; + } + return i; +} +function readRegionSegmentInformation(e, t) { + return { + width: readUint32(e, t), + height: readUint32(e, t + 4), + x: readUint32(e, t + 8), + y: readUint32(e, t + 12), + combinationOperator: 7 & e[t + 16], + }; +} +const gr = 17; +function processSegment(e, t) { + const a = e.header, + r = e.data, + i = e.end; + let n, + s, + o, + c, + l = e.start; + switch (a.type) { + case 0: + const e = {}, + t = readUint16(r, l); + e.huffman = !!(1 & t); + e.refinement = !!(2 & t); + e.huffmanDHSelector = (t >> 2) & 3; + e.huffmanDWSelector = (t >> 4) & 3; + e.bitmapSizeSelector = (t >> 6) & 1; + e.aggregationInstancesSelector = (t >> 7) & 1; + e.bitmapCodingContextUsed = !!(256 & t); + e.bitmapCodingContextRetained = !!(512 & t); + e.template = (t >> 10) & 3; + e.refinementTemplate = (t >> 12) & 1; + l += 2; + if (!e.huffman) { + c = 0 === e.template ? 4 : 1; + s = []; + for (o = 0; o < c; o++) { + s.push({ x: readInt8(r, l), y: readInt8(r, l + 1) }); + l += 2; + } + e.at = s; + } + if (e.refinement && !e.refinementTemplate) { + s = []; + for (o = 0; o < 2; o++) { + s.push({ x: readInt8(r, l), y: readInt8(r, l + 1) }); + l += 2; + } + e.refinementAt = s; + } + e.numberOfExportedSymbols = readUint32(r, l); + l += 4; + e.numberOfNewSymbols = readUint32(r, l); + l += 4; + n = [e, a.number, a.referredTo, r, l, i]; + break; + case 6: + case 7: + const h = {}; + h.info = readRegionSegmentInformation(r, l); + l += gr; + const u = readUint16(r, l); + l += 2; + h.huffman = !!(1 & u); + h.refinement = !!(2 & u); + h.logStripSize = (u >> 2) & 3; + h.stripSize = 1 << h.logStripSize; + h.referenceCorner = (u >> 4) & 3; + h.transposed = !!(64 & u); + h.combinationOperator = (u >> 7) & 3; + h.defaultPixelValue = (u >> 9) & 1; + h.dsOffset = (u << 17) >> 27; + h.refinementTemplate = (u >> 15) & 1; + if (h.huffman) { + const e = readUint16(r, l); + l += 2; + h.huffmanFS = 3 & e; + h.huffmanDS = (e >> 2) & 3; + h.huffmanDT = (e >> 4) & 3; + h.huffmanRefinementDW = (e >> 6) & 3; + h.huffmanRefinementDH = (e >> 8) & 3; + h.huffmanRefinementDX = (e >> 10) & 3; + h.huffmanRefinementDY = (e >> 12) & 3; + h.huffmanRefinementSizeSelector = !!(16384 & e); + } + if (h.refinement && !h.refinementTemplate) { + s = []; + for (o = 0; o < 2; o++) { + s.push({ x: readInt8(r, l), y: readInt8(r, l + 1) }); + l += 2; + } + h.refinementAt = s; + } + h.numberOfSymbolInstances = readUint32(r, l); + l += 4; + n = [h, a.referredTo, r, l, i]; + break; + case 16: + const d = {}, + f = r[l++]; + d.mmr = !!(1 & f); + d.template = (f >> 1) & 3; + d.patternWidth = r[l++]; + d.patternHeight = r[l++]; + d.maxPatternIndex = readUint32(r, l); + l += 4; + n = [d, a.number, r, l, i]; + break; + case 22: + case 23: + const g = {}; + g.info = readRegionSegmentInformation(r, l); + l += gr; + const p = r[l++]; + g.mmr = !!(1 & p); + g.template = (p >> 1) & 3; + g.enableSkip = !!(8 & p); + g.combinationOperator = (p >> 4) & 7; + g.defaultPixelValue = (p >> 7) & 1; + g.gridWidth = readUint32(r, l); + l += 4; + g.gridHeight = readUint32(r, l); + l += 4; + g.gridOffsetX = 4294967295 & readUint32(r, l); + l += 4; + g.gridOffsetY = 4294967295 & readUint32(r, l); + l += 4; + g.gridVectorX = readUint16(r, l); + l += 2; + g.gridVectorY = readUint16(r, l); + l += 2; + n = [g, a.referredTo, r, l, i]; + break; + case 38: + case 39: + const m = {}; + m.info = readRegionSegmentInformation(r, l); + l += gr; + const b = r[l++]; + m.mmr = !!(1 & b); + m.template = (b >> 1) & 3; + m.prediction = !!(8 & b); + if (!m.mmr) { + c = 0 === m.template ? 4 : 1; + s = []; + for (o = 0; o < c; o++) { + s.push({ x: readInt8(r, l), y: readInt8(r, l + 1) }); + l += 2; + } + m.at = s; + } + n = [m, r, l, i]; + break; + case 48: + const y = { + width: readUint32(r, l), + height: readUint32(r, l + 4), + resolutionX: readUint32(r, l + 8), + resolutionY: readUint32(r, l + 12), + }; + 4294967295 === y.height && delete y.height; + const w = r[l + 16]; + readUint16(r, l + 17); + y.lossless = !!(1 & w); + y.refinement = !!(2 & w); + y.defaultPixelValue = (w >> 2) & 1; + y.combinationOperator = (w >> 3) & 3; + y.requiresBuffer = !!(32 & w); + y.combinationOperatorOverride = !!(64 & w); + n = [y]; + break; + case 49: + case 50: + case 51: + case 62: + break; + case 53: + n = [a.number, r, l, i]; + break; + default: + throw new Jbig2Error( + `segment type ${a.typeName}(${a.type}) is not implemented`, + ); + } + const h = "on" + a.typeName; + h in t && t[h].apply(t, n); +} +function processSegments(e, t) { + for (let a = 0, r = e.length; a < r; a++) processSegment(e[a], t); +} +class SimpleSegmentVisitor { + onPageInformation(e) { + this.currentPageInfo = e; + const t = (e.width + 7) >> 3, + a = new Uint8ClampedArray(t * e.height); + e.defaultPixelValue && a.fill(255); + this.buffer = a; + } + drawBitmap(e, t) { + const a = this.currentPageInfo, + r = e.width, + i = e.height, + n = (a.width + 7) >> 3, + s = a.combinationOperatorOverride + ? e.combinationOperator + : a.combinationOperator, + o = this.buffer, + c = 128 >> (7 & e.x); + let l, + h, + u, + d, + f = e.y * n + (e.x >> 3); + switch (s) { + case 0: + for (l = 0; l < i; l++) { + u = c; + d = f; + for (h = 0; h < r; h++) { + t[l][h] && (o[d] |= u); + u >>= 1; + if (!u) { + u = 128; + d++; + } + } + f += n; + } + break; + case 2: + for (l = 0; l < i; l++) { + u = c; + d = f; + for (h = 0; h < r; h++) { + t[l][h] && (o[d] ^= u); + u >>= 1; + if (!u) { + u = 128; + d++; + } + } + f += n; + } + break; + default: + throw new Jbig2Error(`operator ${s} is not supported`); + } + } + onImmediateGenericRegion(e, t, a, r) { + const i = e.info, + n = new DecodingContext(t, a, r), + s = decodeBitmap( + e.mmr, + i.width, + i.height, + e.template, + e.prediction, + null, + e.at, + n, + ); + this.drawBitmap(i, s); + } + onImmediateLosslessGenericRegion() { + this.onImmediateGenericRegion(...arguments); + } + onSymbolDictionary(e, t, a, r, i, n) { + let s, o; + if (e.huffman) { + s = (function getSymbolDictionaryHuffmanTables(e, t, a) { + let r, + i, + n, + s, + o = 0; + switch (e.huffmanDHSelector) { + case 0: + case 1: + r = getStandardTable(e.huffmanDHSelector + 4); + break; + case 3: + r = getCustomHuffmanTable(o, t, a); + o++; + break; + default: + throw new Jbig2Error("invalid Huffman DH selector"); + } + switch (e.huffmanDWSelector) { + case 0: + case 1: + i = getStandardTable(e.huffmanDWSelector + 2); + break; + case 3: + i = getCustomHuffmanTable(o, t, a); + o++; + break; + default: + throw new Jbig2Error("invalid Huffman DW selector"); + } + if (e.bitmapSizeSelector) { + n = getCustomHuffmanTable(o, t, a); + o++; + } else n = getStandardTable(1); + s = e.aggregationInstancesSelector + ? getCustomHuffmanTable(o, t, a) + : getStandardTable(1); + return { + tableDeltaHeight: r, + tableDeltaWidth: i, + tableBitmapSize: n, + tableAggregateInstances: s, + }; + })(e, a, this.customTables); + o = new Reader(r, i, n); + } + let c = this.symbols; + c || (this.symbols = c = {}); + const l = []; + for (const e of a) { + const t = c[e]; + t && l.push(...t); + } + const h = new DecodingContext(r, i, n); + c[t] = (function decodeSymbolDictionary( + e, + t, + a, + r, + i, + n, + s, + o, + c, + l, + h, + u, + ) { + if (e && t) + throw new Jbig2Error("symbol refinement with Huffman is not supported"); + const d = []; + let f = 0, + g = log2(a.length + r); + const p = h.decoder, + m = h.contextCache; + let b, y; + if (e) { + b = getStandardTable(1); + y = []; + g = Math.max(g, 1); + } + for (; d.length < r; ) { + f += e ? n.tableDeltaHeight.decode(u) : decodeInteger(m, "IADH", p); + let r = 0, + i = 0; + const b = e ? y.length : 0; + for (;;) { + const b = e + ? n.tableDeltaWidth.decode(u) + : decodeInteger(m, "IADW", p); + if (null === b) break; + r += b; + i += r; + let w; + if (t) { + const i = decodeInteger(m, "IAAI", p); + if (i > 1) + w = decodeTextRegion( + e, + t, + r, + f, + 0, + i, + 1, + a.concat(d), + g, + 0, + 0, + 1, + 0, + n, + c, + l, + h, + 0, + u, + ); + else { + const e = decodeIAID(m, p, g), + t = decodeInteger(m, "IARDX", p), + i = decodeInteger(m, "IARDY", p); + w = decodeRefinement( + r, + f, + c, + e < a.length ? a[e] : d[e - a.length], + t, + i, + !1, + l, + h, + ); + } + d.push(w); + } else if (e) y.push(r); + else { + w = decodeBitmap(!1, r, f, s, !1, null, o, h); + d.push(w); + } + } + if (e && !t) { + const e = n.tableBitmapSize.decode(u); + u.byteAlign(); + let t; + if (0 === e) t = readUncompressedBitmap(u, i, f); + else { + const a = u.end, + r = u.position + e; + u.end = r; + t = decodeMMRBitmap(u, i, f, !1); + u.end = a; + u.position = r; + } + const a = y.length; + if (b === a - 1) d.push(t); + else { + let e, + r, + i, + n, + s, + o = 0; + for (e = b; e < a; e++) { + n = y[e]; + i = o + n; + s = []; + for (r = 0; r < f; r++) s.push(t[r].subarray(o, i)); + d.push(s); + o = i; + } + } + } + } + const w = [], + x = []; + let S, + k, + C = !1; + const v = a.length + r; + for (; x.length < v; ) { + let t = e ? b.decode(u) : decodeInteger(m, "IAEX", p); + for (; t--; ) x.push(C); + C = !C; + } + for (S = 0, k = a.length; S < k; S++) x[S] && w.push(a[S]); + for (let e = 0; e < r; S++, e++) x[S] && w.push(d[e]); + return w; + })( + e.huffman, + e.refinement, + l, + e.numberOfNewSymbols, + e.numberOfExportedSymbols, + s, + e.template, + e.at, + e.refinementTemplate, + e.refinementAt, + h, + o, + ); + } + onImmediateTextRegion(e, t, a, r, i) { + const n = e.info; + let s, o; + const c = this.symbols, + l = []; + for (const e of t) { + const t = c[e]; + t && l.push(...t); + } + const h = log2(l.length); + if (e.huffman) { + o = new Reader(a, r, i); + s = (function getTextRegionHuffmanTables(e, t, a, r, i) { + const n = []; + for (let e = 0; e <= 34; e++) { + const t = i.readBits(4); + n.push(new HuffmanLine([e, t, 0, 0])); + } + const s = new HuffmanTable(n, !1); + n.length = 0; + for (let e = 0; e < r; ) { + const t = s.decode(i); + if (t >= 32) { + let a, r, s; + switch (t) { + case 32: + if (0 === e) + throw new Jbig2Error("no previous value in symbol ID table"); + r = i.readBits(2) + 3; + a = n[e - 1].prefixLength; + break; + case 33: + r = i.readBits(3) + 3; + a = 0; + break; + case 34: + r = i.readBits(7) + 11; + a = 0; + break; + default: + throw new Jbig2Error("invalid code length in symbol ID table"); + } + for (s = 0; s < r; s++) { + n.push(new HuffmanLine([e, a, 0, 0])); + e++; + } + } else { + n.push(new HuffmanLine([e, t, 0, 0])); + e++; + } + } + i.byteAlign(); + const o = new HuffmanTable(n, !1); + let c, + l, + h, + u = 0; + switch (e.huffmanFS) { + case 0: + case 1: + c = getStandardTable(e.huffmanFS + 6); + break; + case 3: + c = getCustomHuffmanTable(u, t, a); + u++; + break; + default: + throw new Jbig2Error("invalid Huffman FS selector"); + } + switch (e.huffmanDS) { + case 0: + case 1: + case 2: + l = getStandardTable(e.huffmanDS + 8); + break; + case 3: + l = getCustomHuffmanTable(u, t, a); + u++; + break; + default: + throw new Jbig2Error("invalid Huffman DS selector"); + } + switch (e.huffmanDT) { + case 0: + case 1: + case 2: + h = getStandardTable(e.huffmanDT + 11); + break; + case 3: + h = getCustomHuffmanTable(u, t, a); + u++; + break; + default: + throw new Jbig2Error("invalid Huffman DT selector"); + } + if (e.refinement) + throw new Jbig2Error("refinement with Huffman is not supported"); + return { + symbolIDTable: o, + tableFirstS: c, + tableDeltaS: l, + tableDeltaT: h, + }; + })(e, t, this.customTables, l.length, o); + } + const u = new DecodingContext(a, r, i), + d = decodeTextRegion( + e.huffman, + e.refinement, + n.width, + n.height, + e.defaultPixelValue, + e.numberOfSymbolInstances, + e.stripSize, + l, + h, + e.transposed, + e.dsOffset, + e.referenceCorner, + e.combinationOperator, + s, + e.refinementTemplate, + e.refinementAt, + u, + e.logStripSize, + o, + ); + this.drawBitmap(n, d); + } + onImmediateLosslessTextRegion() { + this.onImmediateTextRegion(...arguments); + } + onPatternDictionary(e, t, a, r, i) { + let n = this.patterns; + n || (this.patterns = n = {}); + const s = new DecodingContext(a, r, i); + n[t] = (function decodePatternDictionary(e, t, a, r, i, n) { + const s = []; + if (!e) { + s.push({ x: -t, y: 0 }); + 0 === i && s.push({ x: -3, y: -1 }, { x: 2, y: -2 }, { x: -2, y: -2 }); + } + const o = decodeBitmap(e, (r + 1) * t, a, i, !1, null, s, n), + c = []; + for (let e = 0; e <= r; e++) { + const r = [], + i = t * e, + n = i + t; + for (let e = 0; e < a; e++) r.push(o[e].subarray(i, n)); + c.push(r); + } + return c; + })( + e.mmr, + e.patternWidth, + e.patternHeight, + e.maxPatternIndex, + e.template, + s, + ); + } + onImmediateHalftoneRegion(e, t, a, r, i) { + const n = this.patterns[t[0]], + s = e.info, + o = new DecodingContext(a, r, i), + c = (function decodeHalftoneRegion( + e, + t, + a, + r, + i, + n, + s, + o, + c, + l, + h, + u, + d, + f, + g, + ) { + if (s) throw new Jbig2Error("skip is not supported"); + if (0 !== o) + throw new Jbig2Error( + `operator "${o}" is not supported in halftone region`, + ); + const p = []; + let m, b, y; + for (m = 0; m < i; m++) { + y = new Uint8Array(r); + n && y.fill(n); + p.push(y); + } + const w = t.length, + x = t[0], + S = x[0].length, + k = x.length, + C = log2(w), + v = []; + if (!e) { + v.push({ x: a <= 1 ? 3 : 2, y: -1 }); + 0 === a && + v.push({ x: -3, y: -1 }, { x: 2, y: -2 }, { x: -2, y: -2 }); + } + const F = []; + let T, O, M, D, R, N, E, L, j, _, U; + e && (T = new Reader(g.data, g.start, g.end)); + for (m = C - 1; m >= 0; m--) { + O = e + ? decodeMMRBitmap(T, c, l, !0) + : decodeBitmap(!1, c, l, a, !1, null, v, g); + F[m] = O; + } + for (M = 0; M < l; M++) + for (D = 0; D < c; D++) { + R = 0; + N = 0; + for (b = C - 1; b >= 0; b--) { + R ^= F[b][M][D]; + N |= R << b; + } + E = t[N]; + L = (h + M * f + D * d) >> 8; + j = (u + M * d - D * f) >> 8; + if (L >= 0 && L + S <= r && j >= 0 && j + k <= i) + for (m = 0; m < k; m++) { + U = p[j + m]; + _ = E[m]; + for (b = 0; b < S; b++) U[L + b] |= _[b]; + } + else { + let e, t; + for (m = 0; m < k; m++) { + t = j + m; + if (!(t < 0 || t >= i)) { + U = p[t]; + _ = E[m]; + for (b = 0; b < S; b++) { + e = L + b; + e >= 0 && e < r && (U[e] |= _[b]); + } + } + } + } + } + return p; + })( + e.mmr, + n, + e.template, + s.width, + s.height, + e.defaultPixelValue, + e.enableSkip, + e.combinationOperator, + e.gridWidth, + e.gridHeight, + e.gridOffsetX, + e.gridOffsetY, + e.gridVectorX, + e.gridVectorY, + o, + ); + this.drawBitmap(s, c); + } + onImmediateLosslessHalftoneRegion() { + this.onImmediateHalftoneRegion(...arguments); + } + onTables(e, t, a, r) { + let i = this.customTables; + i || (this.customTables = i = {}); + i[e] = (function decodeTablesSegment(e, t, a) { + const r = e[t], + i = 4294967295 & readUint32(e, t + 1), + n = 4294967295 & readUint32(e, t + 5), + s = new Reader(e, t + 9, a), + o = 1 + ((r >> 1) & 7), + c = 1 + ((r >> 4) & 7), + l = []; + let h, + u, + d = i; + do { + h = s.readBits(o); + u = s.readBits(c); + l.push(new HuffmanLine([d, h, u, 0])); + d += 1 << u; + } while (d < n); + h = s.readBits(o); + l.push(new HuffmanLine([i - 1, h, 32, 0, "lower"])); + h = s.readBits(o); + l.push(new HuffmanLine([n, h, 32, 0])); + if (1 & r) { + h = s.readBits(o); + l.push(new HuffmanLine([h, 0])); + } + return new HuffmanTable(l, !1); + })(t, a, r); + } +} +class HuffmanLine { + constructor(e) { + if (2 === e.length) { + this.isOOB = !0; + this.rangeLow = 0; + this.prefixLength = e[0]; + this.rangeLength = 0; + this.prefixCode = e[1]; + this.isLowerRange = !1; + } else { + this.isOOB = !1; + this.rangeLow = e[0]; + this.prefixLength = e[1]; + this.rangeLength = e[2]; + this.prefixCode = e[3]; + this.isLowerRange = "lower" === e[4]; + } + } +} +class HuffmanTreeNode { + constructor(e) { + this.children = []; + if (e) { + this.isLeaf = !0; + this.rangeLength = e.rangeLength; + this.rangeLow = e.rangeLow; + this.isLowerRange = e.isLowerRange; + this.isOOB = e.isOOB; + } else this.isLeaf = !1; + } + buildTree(e, t) { + const a = (e.prefixCode >> t) & 1; + if (t <= 0) this.children[a] = new HuffmanTreeNode(e); + else { + let r = this.children[a]; + r || (this.children[a] = r = new HuffmanTreeNode(null)); + r.buildTree(e, t - 1); + } + } + decodeNode(e) { + if (this.isLeaf) { + if (this.isOOB) return null; + const t = e.readBits(this.rangeLength); + return this.rangeLow + (this.isLowerRange ? -t : t); + } + const t = this.children[e.readBit()]; + if (!t) throw new Jbig2Error("invalid Huffman data"); + return t.decodeNode(e); + } +} +class HuffmanTable { + constructor(e, t) { + t || this.assignPrefixCodes(e); + this.rootNode = new HuffmanTreeNode(null); + for (let t = 0, a = e.length; t < a; t++) { + const a = e[t]; + a.prefixLength > 0 && this.rootNode.buildTree(a, a.prefixLength - 1); + } + } + decode(e) { + return this.rootNode.decodeNode(e); + } + assignPrefixCodes(e) { + const t = e.length; + let a = 0; + for (let r = 0; r < t; r++) a = Math.max(a, e[r].prefixLength); + const r = new Uint32Array(a + 1); + for (let a = 0; a < t; a++) r[e[a].prefixLength]++; + let i, + n, + s, + o = 1, + c = 0; + r[0] = 0; + for (; o <= a; ) { + c = (c + r[o - 1]) << 1; + i = c; + n = 0; + for (; n < t; ) { + s = e[n]; + if (s.prefixLength === o) { + s.prefixCode = i; + i++; + } + n++; + } + o++; + } + } +} +const pr = {}; +function getStandardTable(e) { + let t, + a = pr[e]; + if (a) return a; + switch (e) { + case 1: + t = [ + [0, 1, 4, 0], + [16, 2, 8, 2], + [272, 3, 16, 6], + [65808, 3, 32, 7], + ]; + break; + case 2: + t = [ + [0, 1, 0, 0], + [1, 2, 0, 2], + [2, 3, 0, 6], + [3, 4, 3, 14], + [11, 5, 6, 30], + [75, 6, 32, 62], + [6, 63], + ]; + break; + case 3: + t = [ + [-256, 8, 8, 254], + [0, 1, 0, 0], + [1, 2, 0, 2], + [2, 3, 0, 6], + [3, 4, 3, 14], + [11, 5, 6, 30], + [-257, 8, 32, 255, "lower"], + [75, 7, 32, 126], + [6, 62], + ]; + break; + case 4: + t = [ + [1, 1, 0, 0], + [2, 2, 0, 2], + [3, 3, 0, 6], + [4, 4, 3, 14], + [12, 5, 6, 30], + [76, 5, 32, 31], + ]; + break; + case 5: + t = [ + [-255, 7, 8, 126], + [1, 1, 0, 0], + [2, 2, 0, 2], + [3, 3, 0, 6], + [4, 4, 3, 14], + [12, 5, 6, 30], + [-256, 7, 32, 127, "lower"], + [76, 6, 32, 62], + ]; + break; + case 6: + t = [ + [-2048, 5, 10, 28], + [-1024, 4, 9, 8], + [-512, 4, 8, 9], + [-256, 4, 7, 10], + [-128, 5, 6, 29], + [-64, 5, 5, 30], + [-32, 4, 5, 11], + [0, 2, 7, 0], + [128, 3, 7, 2], + [256, 3, 8, 3], + [512, 4, 9, 12], + [1024, 4, 10, 13], + [-2049, 6, 32, 62, "lower"], + [2048, 6, 32, 63], + ]; + break; + case 7: + t = [ + [-1024, 4, 9, 8], + [-512, 3, 8, 0], + [-256, 4, 7, 9], + [-128, 5, 6, 26], + [-64, 5, 5, 27], + [-32, 4, 5, 10], + [0, 4, 5, 11], + [32, 5, 5, 28], + [64, 5, 6, 29], + [128, 4, 7, 12], + [256, 3, 8, 1], + [512, 3, 9, 2], + [1024, 3, 10, 3], + [-1025, 5, 32, 30, "lower"], + [2048, 5, 32, 31], + ]; + break; + case 8: + t = [ + [-15, 8, 3, 252], + [-7, 9, 1, 508], + [-5, 8, 1, 253], + [-3, 9, 0, 509], + [-2, 7, 0, 124], + [-1, 4, 0, 10], + [0, 2, 1, 0], + [2, 5, 0, 26], + [3, 6, 0, 58], + [4, 3, 4, 4], + [20, 6, 1, 59], + [22, 4, 4, 11], + [38, 4, 5, 12], + [70, 5, 6, 27], + [134, 5, 7, 28], + [262, 6, 7, 60], + [390, 7, 8, 125], + [646, 6, 10, 61], + [-16, 9, 32, 510, "lower"], + [1670, 9, 32, 511], + [2, 1], + ]; + break; + case 9: + t = [ + [-31, 8, 4, 252], + [-15, 9, 2, 508], + [-11, 8, 2, 253], + [-7, 9, 1, 509], + [-5, 7, 1, 124], + [-3, 4, 1, 10], + [-1, 3, 1, 2], + [1, 3, 1, 3], + [3, 5, 1, 26], + [5, 6, 1, 58], + [7, 3, 5, 4], + [39, 6, 2, 59], + [43, 4, 5, 11], + [75, 4, 6, 12], + [139, 5, 7, 27], + [267, 5, 8, 28], + [523, 6, 8, 60], + [779, 7, 9, 125], + [1291, 6, 11, 61], + [-32, 9, 32, 510, "lower"], + [3339, 9, 32, 511], + [2, 0], + ]; + break; + case 10: + t = [ + [-21, 7, 4, 122], + [-5, 8, 0, 252], + [-4, 7, 0, 123], + [-3, 5, 0, 24], + [-2, 2, 2, 0], + [2, 5, 0, 25], + [3, 6, 0, 54], + [4, 7, 0, 124], + [5, 8, 0, 253], + [6, 2, 6, 1], + [70, 5, 5, 26], + [102, 6, 5, 55], + [134, 6, 6, 56], + [198, 6, 7, 57], + [326, 6, 8, 58], + [582, 6, 9, 59], + [1094, 6, 10, 60], + [2118, 7, 11, 125], + [-22, 8, 32, 254, "lower"], + [4166, 8, 32, 255], + [2, 2], + ]; + break; + case 11: + t = [ + [1, 1, 0, 0], + [2, 2, 1, 2], + [4, 4, 0, 12], + [5, 4, 1, 13], + [7, 5, 1, 28], + [9, 5, 2, 29], + [13, 6, 2, 60], + [17, 7, 2, 122], + [21, 7, 3, 123], + [29, 7, 4, 124], + [45, 7, 5, 125], + [77, 7, 6, 126], + [141, 7, 32, 127], + ]; + break; + case 12: + t = [ + [1, 1, 0, 0], + [2, 2, 0, 2], + [3, 3, 1, 6], + [5, 5, 0, 28], + [6, 5, 1, 29], + [8, 6, 1, 60], + [10, 7, 0, 122], + [11, 7, 1, 123], + [13, 7, 2, 124], + [17, 7, 3, 125], + [25, 7, 4, 126], + [41, 8, 5, 254], + [73, 8, 32, 255], + ]; + break; + case 13: + t = [ + [1, 1, 0, 0], + [2, 3, 0, 4], + [3, 4, 0, 12], + [4, 5, 0, 28], + [5, 4, 1, 13], + [7, 3, 3, 5], + [15, 6, 1, 58], + [17, 6, 2, 59], + [21, 6, 3, 60], + [29, 6, 4, 61], + [45, 6, 5, 62], + [77, 7, 6, 126], + [141, 7, 32, 127], + ]; + break; + case 14: + t = [ + [-2, 3, 0, 4], + [-1, 3, 0, 5], + [0, 1, 0, 0], + [1, 3, 0, 6], + [2, 3, 0, 7], + ]; + break; + case 15: + t = [ + [-24, 7, 4, 124], + [-8, 6, 2, 60], + [-4, 5, 1, 28], + [-2, 4, 0, 12], + [-1, 3, 0, 4], + [0, 1, 0, 0], + [1, 3, 0, 5], + [2, 4, 0, 13], + [3, 5, 1, 29], + [5, 6, 2, 61], + [9, 7, 4, 125], + [-25, 7, 32, 126, "lower"], + [25, 7, 32, 127], + ]; + break; + default: + throw new Jbig2Error(`standard table B.${e} does not exist`); + } + for (let e = 0, a = t.length; e < a; e++) t[e] = new HuffmanLine(t[e]); + a = new HuffmanTable(t, !0); + pr[e] = a; + return a; +} +class Reader { + constructor(e, t, a) { + this.data = e; + this.start = t; + this.end = a; + this.position = t; + this.shift = -1; + this.currentByte = 0; + } + readBit() { + if (this.shift < 0) { + if (this.position >= this.end) + throw new Jbig2Error("end of data while reading bit"); + this.currentByte = this.data[this.position++]; + this.shift = 7; + } + const e = (this.currentByte >> this.shift) & 1; + this.shift--; + return e; + } + readBits(e) { + let t, + a = 0; + for (t = e - 1; t >= 0; t--) a |= this.readBit() << t; + return a; + } + byteAlign() { + this.shift = -1; + } + next() { + return this.position >= this.end ? -1 : this.data[this.position++]; + } +} +function getCustomHuffmanTable(e, t, a) { + let r = 0; + for (let i = 0, n = t.length; i < n; i++) { + const n = a[t[i]]; + if (n) { + if (e === r) return n; + r++; + } + } + throw new Jbig2Error("can't find custom Huffman table"); +} +function readUncompressedBitmap(e, t, a) { + const r = []; + for (let i = 0; i < a; i++) { + const a = new Uint8Array(t); + r.push(a); + for (let r = 0; r < t; r++) a[r] = e.readBit(); + e.byteAlign(); + } + return r; +} +function decodeMMRBitmap(e, t, a, r) { + const i = new CCITTFaxDecoder(e, { + K: -1, + Columns: t, + Rows: a, + BlackIs1: !0, + EndOfBlock: r, + }), + n = []; + let s, + o = !1; + for (let e = 0; e < a; e++) { + const e = new Uint8Array(t); + n.push(e); + let a = -1; + for (let r = 0; r < t; r++) { + if (a < 0) { + s = i.readNextChar(); + if (-1 === s) { + s = 0; + o = !0; + } + a = 7; + } + e[r] = (s >> a) & 1; + a--; + } + } + if (r && !o) { + const e = 5; + for (let t = 0; t < e && -1 !== i.readNextChar(); t++); + } + return n; +} +class Jbig2Image { + parseChunks(e) { + return (function parseJbig2Chunks(e) { + const t = new SimpleSegmentVisitor(); + for (let a = 0, r = e.length; a < r; a++) { + const r = e[a]; + processSegments(readSegments({}, r.data, r.start, r.end), t); + } + return t.buffer; + })(e); + } + parse(e) { + throw new Error("Not implemented: Jbig2Image.parse"); + } +} +class Jbig2Stream extends DecodeStream { + constructor(e, t, a) { + super(t); + this.stream = e; + this.dict = e.dict; + this.maybeLength = t; + this.params = a; + } + get bytes() { + return shadow(this, "bytes", this.stream.getBytes(this.maybeLength)); + } + ensureBuffer(e) {} + readBlock() { + this.decodeImage(); + } + decodeImage(e) { + if (this.eof) return this.buffer; + e ||= this.bytes; + const t = new Jbig2Image(), + a = []; + if (this.params instanceof Dict) { + const e = this.params.get("JBIG2Globals"); + if (e instanceof BaseStream) { + const t = e.getBytes(); + a.push({ data: t, start: 0, end: t.length }); + } + } + a.push({ data: e, start: 0, end: e.length }); + const r = t.parseChunks(a), + i = r.length; + for (let e = 0; e < i; e++) r[e] ^= 255; + this.buffer = r; + this.bufferLength = i; + this.eof = !0; + return this.buffer; + } + get canAsyncDecodeImageFromBuffer() { + return this.stream.isAsync; + } +} +class JpxStream extends DecodeStream { + constructor(e, t, a) { + super(t); + this.stream = e; + this.dict = e.dict; + this.maybeLength = t; + this.params = a; + } + get bytes() { + return shadow(this, "bytes", this.stream.getBytes(this.maybeLength)); + } + ensureBuffer(e) {} + readBlock(e) { + unreachable("JpxStream.readBlock"); + } + get isAsyncDecoder() { + return !0; + } + async decodeImage(e, t) { + if (this.eof) return this.buffer; + e ||= this.bytes; + this.buffer = await JpxImage.decode(e, t); + this.bufferLength = this.buffer.length; + this.eof = !0; + return this.buffer; + } + get canAsyncDecodeImageFromBuffer() { + return this.stream.isAsync; + } +} +class LZWStream extends DecodeStream { + constructor(e, t, a) { + super(t); + this.str = e; + this.dict = e.dict; + this.cachedData = 0; + this.bitsCached = 0; + const r = 4096, + i = { + earlyChange: a, + codeLength: 9, + nextCode: 258, + dictionaryValues: new Uint8Array(r), + dictionaryLengths: new Uint16Array(r), + dictionaryPrevCodes: new Uint16Array(r), + currentSequence: new Uint8Array(r), + currentSequenceLength: 0, + }; + for (let e = 0; e < 256; ++e) { + i.dictionaryValues[e] = e; + i.dictionaryLengths[e] = 1; + } + this.lzwState = i; + } + readBits(e) { + let t = this.bitsCached, + a = this.cachedData; + for (; t < e; ) { + const e = this.str.getByte(); + if (-1 === e) { + this.eof = !0; + return null; + } + a = (a << 8) | e; + t += 8; + } + this.bitsCached = t -= e; + this.cachedData = a; + this.lastCode = null; + return (a >>> t) & ((1 << e) - 1); + } + readBlock() { + let e, + t, + a, + r = 1024; + const i = this.lzwState; + if (!i) return; + const n = i.earlyChange; + let s = i.nextCode; + const o = i.dictionaryValues, + c = i.dictionaryLengths, + l = i.dictionaryPrevCodes; + let h = i.codeLength, + u = i.prevCode; + const d = i.currentSequence; + let f = i.currentSequenceLength, + g = 0, + p = this.bufferLength, + m = this.ensureBuffer(this.bufferLength + r); + for (e = 0; e < 512; e++) { + const e = this.readBits(h), + i = f > 0; + if (e < 256) { + d[0] = e; + f = 1; + } else { + if (!(e >= 258)) { + if (256 === e) { + h = 9; + s = 258; + f = 0; + continue; + } + this.eof = !0; + delete this.lzwState; + break; + } + if (e < s) { + f = c[e]; + for (t = f - 1, a = e; t >= 0; t--) { + d[t] = o[a]; + a = l[a]; + } + } else d[f++] = d[0]; + } + if (i) { + l[s] = u; + c[s] = c[u] + 1; + o[s] = d[0]; + s++; + h = + (s + n) & (s + n - 1) + ? h + : 0 | Math.min(Math.log(s + n) / 0.6931471805599453 + 1, 12); + } + u = e; + g += f; + if (r < g) { + do { + r += 512; + } while (r < g); + m = this.ensureBuffer(this.bufferLength + r); + } + for (t = 0; t < f; t++) m[p++] = d[t]; + } + i.nextCode = s; + i.codeLength = h; + i.prevCode = u; + i.currentSequenceLength = f; + this.bufferLength = p; + } +} +class PredictorStream extends DecodeStream { + constructor(e, t, a) { + super(t); + if (!(a instanceof Dict)) return e; + const r = (this.predictor = a.get("Predictor") || 1); + if (r <= 1) return e; + if (2 !== r && (r < 10 || r > 15)) + throw new FormatError(`Unsupported predictor: ${r}`); + this.readBlock = 2 === r ? this.readBlockTiff : this.readBlockPng; + this.str = e; + this.dict = e.dict; + const i = (this.colors = a.get("Colors") || 1), + n = (this.bits = a.get("BPC", "BitsPerComponent") || 8), + s = (this.columns = a.get("Columns") || 1); + this.pixBytes = (i * n + 7) >> 3; + this.rowBytes = (s * i * n + 7) >> 3; + return this; + } + readBlockTiff() { + const e = this.rowBytes, + t = this.bufferLength, + a = this.ensureBuffer(t + e), + r = this.bits, + i = this.colors, + n = this.str.getBytes(e); + this.eof = !n.length; + if (this.eof) return; + let s, + o = 0, + c = 0, + l = 0, + h = 0, + u = t; + if (1 === r && 1 === i) + for (s = 0; s < e; ++s) { + let e = n[s] ^ o; + e ^= e >> 1; + e ^= e >> 2; + e ^= e >> 4; + o = (1 & e) << 7; + a[u++] = e; + } + else if (8 === r) { + for (s = 0; s < i; ++s) a[u++] = n[s]; + for (; s < e; ++s) { + a[u] = a[u - i] + n[s]; + u++; + } + } else if (16 === r) { + const t = 2 * i; + for (s = 0; s < t; ++s) a[u++] = n[s]; + for (; s < e; s += 2) { + const e = + ((255 & n[s]) << 8) + + (255 & n[s + 1]) + + ((255 & a[u - t]) << 8) + + (255 & a[u - t + 1]); + a[u++] = (e >> 8) & 255; + a[u++] = 255 & e; + } + } else { + const e = new Uint8Array(i + 1), + u = (1 << r) - 1; + let d = 0, + f = t; + const g = this.columns; + for (s = 0; s < g; ++s) + for (let t = 0; t < i; ++t) { + if (l < r) { + o = (o << 8) | (255 & n[d++]); + l += 8; + } + e[t] = (e[t] + (o >> (l - r))) & u; + l -= r; + c = (c << r) | e[t]; + h += r; + if (h >= 8) { + a[f++] = (c >> (h - 8)) & 255; + h -= 8; + } + } + h > 0 && (a[f++] = (c << (8 - h)) + (o & ((1 << (8 - h)) - 1))); + } + this.bufferLength += e; + } + readBlockPng() { + const e = this.rowBytes, + t = this.pixBytes, + a = this.str.getByte(), + r = this.str.getBytes(e); + this.eof = !r.length; + if (this.eof) return; + const i = this.bufferLength, + n = this.ensureBuffer(i + e); + let s = n.subarray(i - e, i); + 0 === s.length && (s = new Uint8Array(e)); + let o, + c, + l, + h = i; + switch (a) { + case 0: + for (o = 0; o < e; ++o) n[h++] = r[o]; + break; + case 1: + for (o = 0; o < t; ++o) n[h++] = r[o]; + for (; o < e; ++o) { + n[h] = (n[h - t] + r[o]) & 255; + h++; + } + break; + case 2: + for (o = 0; o < e; ++o) n[h++] = (s[o] + r[o]) & 255; + break; + case 3: + for (o = 0; o < t; ++o) n[h++] = (s[o] >> 1) + r[o]; + for (; o < e; ++o) { + n[h] = (((s[o] + n[h - t]) >> 1) + r[o]) & 255; + h++; + } + break; + case 4: + for (o = 0; o < t; ++o) { + c = s[o]; + l = r[o]; + n[h++] = c + l; + } + for (; o < e; ++o) { + c = s[o]; + const e = s[o - t], + a = n[h - t], + i = a + c - e; + let u = i - a; + u < 0 && (u = -u); + let d = i - c; + d < 0 && (d = -d); + let f = i - e; + f < 0 && (f = -f); + l = r[o]; + n[h++] = u <= d && u <= f ? a + l : d <= f ? c + l : e + l; + } + break; + default: + throw new FormatError(`Unsupported predictor: ${a}`); + } + this.bufferLength += e; + } +} +class RunLengthStream extends DecodeStream { + constructor(e, t) { + super(t); + this.str = e; + this.dict = e.dict; + } + readBlock() { + const e = this.str.getBytes(2); + if (!e || e.length < 2 || 128 === e[0]) { + this.eof = !0; + return; + } + let t, + a = this.bufferLength, + r = e[0]; + if (r < 128) { + t = this.ensureBuffer(a + r + 1); + t[a++] = e[1]; + if (r > 0) { + const e = this.str.getBytes(r); + t.set(e, a); + a += r; + } + } else { + r = 257 - r; + t = this.ensureBuffer(a + r + 1); + t.fill(e[1], a, a + r); + a += r; + } + this.bufferLength = a; + } +} +class Parser { + constructor({ + lexer: e, + xref: t, + allowStreams: a = !1, + recoveryMode: r = !1, + }) { + this.lexer = e; + this.xref = t; + this.allowStreams = a; + this.recoveryMode = r; + this.imageCache = Object.create(null); + this._imageId = 0; + this.refill(); + } + refill() { + this.buf1 = this.lexer.getObj(); + this.buf2 = this.lexer.getObj(); + } + shift() { + if (this.buf2 instanceof Cmd && "ID" === this.buf2.cmd) { + this.buf1 = this.buf2; + this.buf2 = null; + } else { + this.buf1 = this.buf2; + this.buf2 = this.lexer.getObj(); + } + } + tryShift() { + try { + this.shift(); + return !0; + } catch (e) { + if (e instanceof MissingDataException) throw e; + return !1; + } + } + getObj(e = null) { + const t = this.buf1; + this.shift(); + if (t instanceof Cmd) + switch (t.cmd) { + case "BI": + return this.makeInlineImage(e); + case "[": + const a = []; + for (; !isCmd(this.buf1, "]") && this.buf1 !== wa; ) + a.push(this.getObj(e)); + if (this.buf1 === wa) { + if (this.recoveryMode) return a; + throw new ParserEOFException("End of file inside array."); + } + this.shift(); + return a; + case "<<": + const r = new Dict(this.xref); + for (; !isCmd(this.buf1, ">>") && this.buf1 !== wa; ) { + if (!(this.buf1 instanceof Name)) { + info("Malformed dictionary: key must be a name object"); + this.shift(); + continue; + } + const t = this.buf1.name; + this.shift(); + if (this.buf1 === wa) break; + r.set(t, this.getObj(e)); + } + if (this.buf1 === wa) { + if (this.recoveryMode) return r; + throw new ParserEOFException("End of file inside dictionary."); + } + if (isCmd(this.buf2, "stream")) + return this.allowStreams ? this.makeStream(r, e) : r; + this.shift(); + return r; + default: + return t; + } + if (Number.isInteger(t)) { + if (Number.isInteger(this.buf1) && isCmd(this.buf2, "R")) { + const e = Ref.get(t, this.buf1); + this.shift(); + this.shift(); + return e; + } + return t; + } + return "string" == typeof t && e ? e.decryptString(t) : t; + } + findDefaultInlineStreamEnd(e) { + const { knownCommands: t } = this.lexer, + a = e.pos; + let r, + i, + n = 0; + for (; -1 !== (r = e.getByte()); ) + if (0 === n) n = 69 === r ? 1 : 0; + else if (1 === n) n = 73 === r ? 2 : 0; + else if (32 === r || 10 === r || 13 === r) { + i = e.pos; + const a = e.peekBytes(15), + s = a.length; + if (0 === s) break; + for (let e = 0; e < s; e++) { + r = a[e]; + if ( + (0 !== r || 0 === a[e + 1]) && + 10 !== r && + 13 !== r && + (r < 32 || r > 127) + ) { + n = 0; + break; + } + } + if (2 !== n) continue; + if (!t) { + warn( + "findDefaultInlineStreamEnd - `lexer.knownCommands` is undefined.", + ); + continue; + } + const o = new Lexer(new Stream(e.peekBytes(75)), t); + o._hexStringWarn = () => {}; + let c = 0; + for (;;) { + const e = o.getObj(); + if (e === wa) { + n = 0; + break; + } + if (e instanceof Cmd) { + const a = t[e.cmd]; + if (!a) { + n = 0; + break; + } + if (a.variableArgs ? c <= a.numArgs : c === a.numArgs) break; + c = 0; + } else c++; + } + if (2 === n) break; + } else n = 0; + if (-1 === r) { + warn( + "findDefaultInlineStreamEnd: Reached the end of the stream without finding a valid EI marker", + ); + if (i) { + warn('... trying to recover by using the last "EI" occurrence.'); + e.skip(-(e.pos - i)); + } + } + let s = 4; + e.skip(-s); + r = e.peekByte(); + e.skip(s); + isWhiteSpace(r) || s--; + return e.pos - s - a; + } + findDCTDecodeInlineStreamEnd(e) { + const t = e.pos; + let a, + r, + i = !1; + for (; -1 !== (a = e.getByte()); ) + if (255 === a) { + switch (e.getByte()) { + case 0: + break; + case 255: + e.skip(-1); + break; + case 217: + i = !0; + break; + case 192: + case 193: + case 194: + case 195: + case 197: + case 198: + case 199: + case 201: + case 202: + case 203: + case 205: + case 206: + case 207: + case 196: + case 204: + case 218: + case 219: + case 220: + case 221: + case 222: + case 223: + case 224: + case 225: + case 226: + case 227: + case 228: + case 229: + case 230: + case 231: + case 232: + case 233: + case 234: + case 235: + case 236: + case 237: + case 238: + case 239: + case 254: + r = e.getUint16(); + r > 2 ? e.skip(r - 2) : e.skip(-2); + } + if (i) break; + } + const n = e.pos - t; + if (-1 === a) { + warn( + "Inline DCTDecode image stream: EOI marker not found, searching for /EI/ instead.", + ); + e.skip(-n); + return this.findDefaultInlineStreamEnd(e); + } + this.inlineStreamSkipEI(e); + return n; + } + findASCII85DecodeInlineStreamEnd(e) { + const t = e.pos; + let a; + for (; -1 !== (a = e.getByte()); ) + if (126 === a) { + const t = e.pos; + a = e.peekByte(); + for (; isWhiteSpace(a); ) { + e.skip(); + a = e.peekByte(); + } + if (62 === a) { + e.skip(); + break; + } + if (e.pos > t) { + const t = e.peekBytes(2); + if (69 === t[0] && 73 === t[1]) break; + } + } + const r = e.pos - t; + if (-1 === a) { + warn( + "Inline ASCII85Decode image stream: EOD marker not found, searching for /EI/ instead.", + ); + e.skip(-r); + return this.findDefaultInlineStreamEnd(e); + } + this.inlineStreamSkipEI(e); + return r; + } + findASCIIHexDecodeInlineStreamEnd(e) { + const t = e.pos; + let a; + for (; -1 !== (a = e.getByte()) && 62 !== a; ); + const r = e.pos - t; + if (-1 === a) { + warn( + "Inline ASCIIHexDecode image stream: EOD marker not found, searching for /EI/ instead.", + ); + e.skip(-r); + return this.findDefaultInlineStreamEnd(e); + } + this.inlineStreamSkipEI(e); + return r; + } + inlineStreamSkipEI(e) { + let t, + a = 0; + for (; -1 !== (t = e.getByte()); ) + if (0 === a) a = 69 === t ? 1 : 0; + else if (1 === a) a = 73 === t ? 2 : 0; + else if (2 === a) break; + } + makeInlineImage(e) { + const t = this.lexer, + a = t.stream, + r = Object.create(null); + let i; + for (; !isCmd(this.buf1, "ID") && this.buf1 !== wa; ) { + if (!(this.buf1 instanceof Name)) + throw new FormatError("Dictionary key must be a name object"); + const t = this.buf1.name; + this.shift(); + if (this.buf1 === wa) break; + r[t] = this.getObj(e); + } + -1 !== t.beginInlineImagePos && (i = a.pos - t.beginInlineImagePos); + const n = this.xref.fetchIfRef(r.F || r.Filter); + let s; + if (n instanceof Name) s = n.name; + else if (Array.isArray(n)) { + const e = this.xref.fetchIfRef(n[0]); + e instanceof Name && (s = e.name); + } + const o = a.pos; + let c, l; + switch (s) { + case "DCT": + case "DCTDecode": + c = this.findDCTDecodeInlineStreamEnd(a); + break; + case "A85": + case "ASCII85Decode": + c = this.findASCII85DecodeInlineStreamEnd(a); + break; + case "AHx": + case "ASCIIHexDecode": + c = this.findASCIIHexDecodeInlineStreamEnd(a); + break; + default: + c = this.findDefaultInlineStreamEnd(a); + } + if (c < 1e3 && i > 0) { + const e = a.pos; + a.pos = t.beginInlineImagePos; + l = (function getInlineImageCacheKey(e) { + const t = [], + a = e.length; + let r = 0; + for (; r < a - 1; ) t.push((e[r++] << 8) | e[r++]); + r < a && t.push(e[r]); + return a + "_" + String.fromCharCode.apply(null, t); + })(a.getBytes(i + c)); + a.pos = e; + const r = this.imageCache[l]; + if (void 0 !== r) { + this.buf2 = Cmd.get("EI"); + this.shift(); + r.reset(); + return r; + } + } + const h = new Dict(this.xref); + for (const e in r) h.set(e, r[e]); + let u = a.makeSubStream(o, c, h); + e && (u = e.createStream(u, c)); + u = this.filter(u, h, c); + u.dict = h; + if (void 0 !== l) { + u.cacheKey = "inline_img_" + ++this._imageId; + this.imageCache[l] = u; + } + this.buf2 = Cmd.get("EI"); + this.shift(); + return u; + } + #q(e) { + const { stream: t } = this.lexer; + t.pos = e; + const a = new Uint8Array([101, 110, 100]), + r = a.length, + i = [ + new Uint8Array([115, 116, 114, 101, 97, 109]), + new Uint8Array([115, 116, 101, 97, 109]), + new Uint8Array([115, 116, 114, 101, 97]), + ], + n = 9 - r; + for (; t.pos < t.end; ) { + const s = t.peekBytes(2048), + o = s.length - 9; + if (o <= 0) break; + let c = 0; + for (; c < o; ) { + let o = 0; + for (; o < r && s[c + o] === a[o]; ) o++; + if (o >= r) { + let r = !1; + for (const e of i) { + const t = e.length; + let i = 0; + for (; i < t && s[c + o + i] === e[i]; ) i++; + if (i >= n) { + r = !0; + break; + } + if (i >= t) { + if (isWhiteSpace(s[c + o + i])) { + info( + `Found "${bytesToString([...a, ...e])}" when searching for endstream command.`, + ); + r = !0; + } + break; + } + } + if (r) { + t.pos += c; + return t.pos - e; + } + } + c++; + } + t.pos += o; + } + return -1; + } + makeStream(e, t) { + const a = this.lexer; + let r = a.stream; + a.skipToNextLine(); + const i = r.pos - 1; + let n = e.get("Length"); + if (!Number.isInteger(n)) { + info(`Bad length "${n && n.toString()}" in stream.`); + n = 0; + } + r.pos = i + n; + a.nextChar(); + if (this.tryShift() && isCmd(this.buf2, "endstream")) this.shift(); + else { + n = this.#q(i); + if (n < 0) throw new FormatError("Missing endstream command."); + a.nextChar(); + this.shift(); + this.shift(); + } + this.shift(); + r = r.makeSubStream(i, n, e); + t && (r = t.createStream(r, n)); + r = this.filter(r, e, n); + r.dict = e; + return r; + } + filter(e, t, a) { + let r = t.get("F", "Filter"), + i = t.get("DP", "DecodeParms"); + if (r instanceof Name) { + Array.isArray(i) && + warn("/DecodeParms should not be an Array, when /Filter is a Name."); + return this.makeFilter(e, r.name, a, i); + } + let n = a; + if (Array.isArray(r)) { + const t = r, + a = i; + for (let s = 0, o = t.length; s < o; ++s) { + r = this.xref.fetchIfRef(t[s]); + if (!(r instanceof Name)) + throw new FormatError(`Bad filter name "${r}"`); + i = null; + Array.isArray(a) && s in a && (i = this.xref.fetchIfRef(a[s])); + e = this.makeFilter(e, r.name, n, i); + n = null; + } + } + return e; + } + makeFilter(e, t, a, r) { + if (0 === a) { + warn(`Empty "${t}" stream.`); + return new NullStream(); + } + try { + switch (t) { + case "Fl": + case "FlateDecode": + return r + ? new PredictorStream(new FlateStream(e, a), a, r) + : new FlateStream(e, a); + case "LZW": + case "LZWDecode": + let t = 1; + if (r) { + r.has("EarlyChange") && (t = r.get("EarlyChange")); + return new PredictorStream(new LZWStream(e, a, t), a, r); + } + return new LZWStream(e, a, t); + case "DCT": + case "DCTDecode": + return new JpegStream(e, a, r); + case "JPX": + case "JPXDecode": + return new JpxStream(e, a, r); + case "A85": + case "ASCII85Decode": + return new Ascii85Stream(e, a); + case "AHx": + case "ASCIIHexDecode": + return new AsciiHexStream(e, a); + case "CCF": + case "CCITTFaxDecode": + return new CCITTFaxStream(e, a, r); + case "RL": + case "RunLengthDecode": + return new RunLengthStream(e, a); + case "JBIG2Decode": + return new Jbig2Stream(e, a, r); + } + warn(`Filter "${t}" is not supported.`); + return e; + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`Invalid stream: "${e}"`); + return new NullStream(); + } + } +} +const mr = [ + 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 2, 0, 0, 2, 2, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, +]; +function toHexDigit(e) { + return e >= 48 && e <= 57 + ? 15 & e + : (e >= 65 && e <= 70) || (e >= 97 && e <= 102) + ? 9 + (15 & e) + : -1; +} +class Lexer { + constructor(e, t = null) { + this.stream = e; + this.nextChar(); + this.strBuf = []; + this.knownCommands = t; + this._hexStringNumWarn = 0; + this.beginInlineImagePos = -1; + } + nextChar() { + return (this.currentChar = this.stream.getByte()); + } + peekChar() { + return this.stream.peekByte(); + } + getNumber() { + let e = this.currentChar, + t = !1, + a = 0, + r = 1; + if (45 === e) { + r = -1; + e = this.nextChar(); + 45 === e && (e = this.nextChar()); + } else 43 === e && (e = this.nextChar()); + if (10 === e || 13 === e) + do { + e = this.nextChar(); + } while (10 === e || 13 === e); + if (46 === e) { + a = 10; + e = this.nextChar(); + } + if (e < 48 || e > 57) { + const t = `Invalid number: ${String.fromCharCode(e)} (charCode ${e})`; + if (isWhiteSpace(e) || 40 === e || 60 === e || -1 === e) { + info(`Lexer.getNumber - "${t}".`); + return 0; + } + throw new FormatError(t); + } + let i = e - 48, + n = 0, + s = 1; + for (; (e = this.nextChar()) >= 0; ) + if (e >= 48 && e <= 57) { + const r = e - 48; + if (t) n = 10 * n + r; + else { + 0 !== a && (a *= 10); + i = 10 * i + r; + } + } else if (46 === e) { + if (0 !== a) break; + a = 1; + } else if (45 === e) + warn("Badly formatted number: minus sign in the middle"); + else { + if (69 !== e && 101 !== e) break; + e = this.peekChar(); + if (43 === e || 45 === e) { + s = 45 === e ? -1 : 1; + this.nextChar(); + } else if (e < 48 || e > 57) break; + t = !0; + } + 0 !== a && (i /= a); + t && (i *= 10 ** (s * n)); + return r * i; + } + getString() { + let e = 1, + t = !1; + const a = this.strBuf; + a.length = 0; + let r = this.nextChar(); + for (;;) { + let i = !1; + switch (0 | r) { + case -1: + warn("Unterminated string"); + t = !0; + break; + case 40: + ++e; + a.push("("); + break; + case 41: + if (0 == --e) { + this.nextChar(); + t = !0; + } else a.push(")"); + break; + case 92: + r = this.nextChar(); + switch (r) { + case -1: + warn("Unterminated string"); + t = !0; + break; + case 110: + a.push("\n"); + break; + case 114: + a.push("\r"); + break; + case 116: + a.push("\t"); + break; + case 98: + a.push("\b"); + break; + case 102: + a.push("\f"); + break; + case 92: + case 40: + case 41: + a.push(String.fromCharCode(r)); + break; + case 48: + case 49: + case 50: + case 51: + case 52: + case 53: + case 54: + case 55: + let e = 15 & r; + r = this.nextChar(); + i = !0; + if (r >= 48 && r <= 55) { + e = (e << 3) + (15 & r); + r = this.nextChar(); + if (r >= 48 && r <= 55) { + i = !1; + e = (e << 3) + (15 & r); + } + } + a.push(String.fromCharCode(e)); + break; + case 13: + 10 === this.peekChar() && this.nextChar(); + break; + case 10: + break; + default: + a.push(String.fromCharCode(r)); + } + break; + default: + a.push(String.fromCharCode(r)); + } + if (t) break; + i || (r = this.nextChar()); + } + return a.join(""); + } + getName() { + let e, t; + const a = this.strBuf; + a.length = 0; + for (; (e = this.nextChar()) >= 0 && !mr[e]; ) + if (35 === e) { + e = this.nextChar(); + if (mr[e]) { + warn( + "Lexer_getName: NUMBER SIGN (#) should be followed by a hexadecimal number.", + ); + a.push("#"); + break; + } + const r = toHexDigit(e); + if (-1 !== r) { + t = e; + e = this.nextChar(); + const i = toHexDigit(e); + if (-1 === i) { + warn( + `Lexer_getName: Illegal digit (${String.fromCharCode(e)}) in hexadecimal number.`, + ); + a.push("#", String.fromCharCode(t)); + if (mr[e]) break; + a.push(String.fromCharCode(e)); + continue; + } + a.push(String.fromCharCode((r << 4) | i)); + } else a.push("#", String.fromCharCode(e)); + } else a.push(String.fromCharCode(e)); + a.length > 127 && + warn(`Name token is longer than allowed by the spec: ${a.length}`); + return Name.get(a.join("")); + } + _hexStringWarn(e) { + 5 != this._hexStringNumWarn++ + ? this._hexStringNumWarn > 5 || + warn(`getHexString - ignoring invalid character: ${e}`) + : warn("getHexString - ignoring additional invalid characters."); + } + getHexString() { + const e = this.strBuf; + e.length = 0; + let t = this.currentChar, + a = -1, + r = -1; + this._hexStringNumWarn = 0; + for (;;) { + if (t < 0) { + warn("Unterminated hex string"); + break; + } + if (62 === t) { + this.nextChar(); + break; + } + if (1 !== mr[t]) { + r = toHexDigit(t); + if (-1 === r) this._hexStringWarn(t); + else if (-1 === a) a = r; + else { + e.push(String.fromCharCode((a << 4) | r)); + a = -1; + } + t = this.nextChar(); + } else t = this.nextChar(); + } + -1 !== a && e.push(String.fromCharCode(a << 4)); + return e.join(""); + } + getObj() { + let e = !1, + t = this.currentChar; + for (;;) { + if (t < 0) return wa; + if (e) (10 !== t && 13 !== t) || (e = !1); + else if (37 === t) e = !0; + else if (1 !== mr[t]) break; + t = this.nextChar(); + } + switch (0 | t) { + case 48: + case 49: + case 50: + case 51: + case 52: + case 53: + case 54: + case 55: + case 56: + case 57: + case 43: + case 45: + case 46: + return this.getNumber(); + case 40: + return this.getString(); + case 47: + return this.getName(); + case 91: + this.nextChar(); + return Cmd.get("["); + case 93: + this.nextChar(); + return Cmd.get("]"); + case 60: + t = this.nextChar(); + if (60 === t) { + this.nextChar(); + return Cmd.get("<<"); + } + return this.getHexString(); + case 62: + t = this.nextChar(); + if (62 === t) { + this.nextChar(); + return Cmd.get(">>"); + } + return Cmd.get(">"); + case 123: + this.nextChar(); + return Cmd.get("{"); + case 125: + this.nextChar(); + return Cmd.get("}"); + case 41: + this.nextChar(); + throw new FormatError(`Illegal character: ${t}`); + } + let a = String.fromCharCode(t); + if (t < 32 || t > 127) { + const e = this.peekChar(); + if (e >= 32 && e <= 127) { + this.nextChar(); + return Cmd.get(a); + } + } + const r = this.knownCommands; + let i = void 0 !== r?.[a]; + for (; (t = this.nextChar()) >= 0 && !mr[t]; ) { + const e = a + String.fromCharCode(t); + if (i && void 0 === r[e]) break; + if (128 === a.length) + throw new FormatError(`Command token too long: ${a.length}`); + a = e; + i = void 0 !== r?.[a]; + } + if ("true" === a) return !0; + if ("false" === a) return !1; + if ("null" === a) return null; + "BI" === a && (this.beginInlineImagePos = this.stream.pos); + return Cmd.get(a); + } + skipToNextLine() { + let e = this.currentChar; + for (; e >= 0; ) { + if (13 === e) { + e = this.nextChar(); + 10 === e && this.nextChar(); + break; + } + if (10 === e) { + this.nextChar(); + break; + } + e = this.nextChar(); + } + } +} +class Linearization { + static create(e) { + function getInt(e, t, a = !1) { + const r = e.get(t); + if (Number.isInteger(r) && (a ? r >= 0 : r > 0)) return r; + throw new Error( + `The "${t}" parameter in the linearization dictionary is invalid.`, + ); + } + const t = new Parser({ lexer: new Lexer(e), xref: null }), + a = t.getObj(), + r = t.getObj(), + i = t.getObj(), + n = t.getObj(); + let s, o; + if ( + !( + Number.isInteger(a) && + Number.isInteger(r) && + isCmd(i, "obj") && + n instanceof Dict && + "number" == typeof (s = n.get("Linearized")) && + s > 0 + ) + ) + return null; + if ((o = getInt(n, "L")) !== e.length) + throw new Error( + 'The "L" parameter in the linearization dictionary does not equal the stream length.', + ); + return { + length: o, + hints: (function getHints(e) { + const t = e.get("H"); + let a; + if (Array.isArray(t) && (2 === (a = t.length) || 4 === a)) { + for (let e = 0; e < a; e++) { + const a = t[e]; + if (!(Number.isInteger(a) && a > 0)) + throw new Error( + `Hint (${e}) in the linearization dictionary is invalid.`, + ); + } + return t; + } + throw new Error( + "Hint array in the linearization dictionary is invalid.", + ); + })(n), + objectNumberFirst: getInt(n, "O"), + endFirst: getInt(n, "E"), + numPages: getInt(n, "N"), + mainXRefEntriesOffset: getInt(n, "T"), + pageFirst: n.has("P") ? getInt(n, "P", !0) : 0, + }; + } +} +const br = [ + "Adobe-GB1-UCS2", + "Adobe-CNS1-UCS2", + "Adobe-Japan1-UCS2", + "Adobe-Korea1-UCS2", + "78-EUC-H", + "78-EUC-V", + "78-H", + "78-RKSJ-H", + "78-RKSJ-V", + "78-V", + "78ms-RKSJ-H", + "78ms-RKSJ-V", + "83pv-RKSJ-H", + "90ms-RKSJ-H", + "90ms-RKSJ-V", + "90msp-RKSJ-H", + "90msp-RKSJ-V", + "90pv-RKSJ-H", + "90pv-RKSJ-V", + "Add-H", + "Add-RKSJ-H", + "Add-RKSJ-V", + "Add-V", + "Adobe-CNS1-0", + "Adobe-CNS1-1", + "Adobe-CNS1-2", + "Adobe-CNS1-3", + "Adobe-CNS1-4", + "Adobe-CNS1-5", + "Adobe-CNS1-6", + "Adobe-GB1-0", + "Adobe-GB1-1", + "Adobe-GB1-2", + "Adobe-GB1-3", + "Adobe-GB1-4", + "Adobe-GB1-5", + "Adobe-Japan1-0", + "Adobe-Japan1-1", + "Adobe-Japan1-2", + "Adobe-Japan1-3", + "Adobe-Japan1-4", + "Adobe-Japan1-5", + "Adobe-Japan1-6", + "Adobe-Korea1-0", + "Adobe-Korea1-1", + "Adobe-Korea1-2", + "B5-H", + "B5-V", + "B5pc-H", + "B5pc-V", + "CNS-EUC-H", + "CNS-EUC-V", + "CNS1-H", + "CNS1-V", + "CNS2-H", + "CNS2-V", + "ETHK-B5-H", + "ETHK-B5-V", + "ETen-B5-H", + "ETen-B5-V", + "ETenms-B5-H", + "ETenms-B5-V", + "EUC-H", + "EUC-V", + "Ext-H", + "Ext-RKSJ-H", + "Ext-RKSJ-V", + "Ext-V", + "GB-EUC-H", + "GB-EUC-V", + "GB-H", + "GB-V", + "GBK-EUC-H", + "GBK-EUC-V", + "GBK2K-H", + "GBK2K-V", + "GBKp-EUC-H", + "GBKp-EUC-V", + "GBT-EUC-H", + "GBT-EUC-V", + "GBT-H", + "GBT-V", + "GBTpc-EUC-H", + "GBTpc-EUC-V", + "GBpc-EUC-H", + "GBpc-EUC-V", + "H", + "HKdla-B5-H", + "HKdla-B5-V", + "HKdlb-B5-H", + "HKdlb-B5-V", + "HKgccs-B5-H", + "HKgccs-B5-V", + "HKm314-B5-H", + "HKm314-B5-V", + "HKm471-B5-H", + "HKm471-B5-V", + "HKscs-B5-H", + "HKscs-B5-V", + "Hankaku", + "Hiragana", + "KSC-EUC-H", + "KSC-EUC-V", + "KSC-H", + "KSC-Johab-H", + "KSC-Johab-V", + "KSC-V", + "KSCms-UHC-H", + "KSCms-UHC-HW-H", + "KSCms-UHC-HW-V", + "KSCms-UHC-V", + "KSCpc-EUC-H", + "KSCpc-EUC-V", + "Katakana", + "NWP-H", + "NWP-V", + "RKSJ-H", + "RKSJ-V", + "Roman", + "UniCNS-UCS2-H", + "UniCNS-UCS2-V", + "UniCNS-UTF16-H", + "UniCNS-UTF16-V", + "UniCNS-UTF32-H", + "UniCNS-UTF32-V", + "UniCNS-UTF8-H", + "UniCNS-UTF8-V", + "UniGB-UCS2-H", + "UniGB-UCS2-V", + "UniGB-UTF16-H", + "UniGB-UTF16-V", + "UniGB-UTF32-H", + "UniGB-UTF32-V", + "UniGB-UTF8-H", + "UniGB-UTF8-V", + "UniJIS-UCS2-H", + "UniJIS-UCS2-HW-H", + "UniJIS-UCS2-HW-V", + "UniJIS-UCS2-V", + "UniJIS-UTF16-H", + "UniJIS-UTF16-V", + "UniJIS-UTF32-H", + "UniJIS-UTF32-V", + "UniJIS-UTF8-H", + "UniJIS-UTF8-V", + "UniJIS2004-UTF16-H", + "UniJIS2004-UTF16-V", + "UniJIS2004-UTF32-H", + "UniJIS2004-UTF32-V", + "UniJIS2004-UTF8-H", + "UniJIS2004-UTF8-V", + "UniJISPro-UCS2-HW-V", + "UniJISPro-UCS2-V", + "UniJISPro-UTF8-V", + "UniJISX0213-UTF32-H", + "UniJISX0213-UTF32-V", + "UniJISX02132004-UTF32-H", + "UniJISX02132004-UTF32-V", + "UniKS-UCS2-H", + "UniKS-UCS2-V", + "UniKS-UTF16-H", + "UniKS-UTF16-V", + "UniKS-UTF32-H", + "UniKS-UTF32-V", + "UniKS-UTF8-H", + "UniKS-UTF8-V", + "V", + "WP-Symbol", + ], + yr = 2 ** 24 - 1; +class CMap { + constructor(e = !1) { + this.codespaceRanges = [[], [], [], []]; + this.numCodespaceRanges = 0; + this._map = []; + this.name = ""; + this.vertical = !1; + this.useCMap = null; + this.builtInCMap = e; + } + addCodespaceRange(e, t, a) { + this.codespaceRanges[e - 1].push(t, a); + this.numCodespaceRanges++; + } + mapCidRange(e, t, a) { + if (t - e > yr) + throw new Error("mapCidRange - ignoring data above MAX_MAP_RANGE."); + for (; e <= t; ) this._map[e++] = a++; + } + mapBfRange(e, t, a) { + if (t - e > yr) + throw new Error("mapBfRange - ignoring data above MAX_MAP_RANGE."); + const r = a.length - 1; + for (; e <= t; ) { + this._map[e++] = a; + const t = a.charCodeAt(r) + 1; + t > 255 + ? (a = + a.substring(0, r - 1) + + String.fromCharCode(a.charCodeAt(r - 1) + 1) + + "\0") + : (a = a.substring(0, r) + String.fromCharCode(t)); + } + } + mapBfRangeToArray(e, t, a) { + if (t - e > yr) + throw new Error("mapBfRangeToArray - ignoring data above MAX_MAP_RANGE."); + const r = a.length; + let i = 0; + for (; e <= t && i < r; ) { + this._map[e] = a[i++]; + ++e; + } + } + mapOne(e, t) { + this._map[e] = t; + } + lookup(e) { + return this._map[e]; + } + contains(e) { + return void 0 !== this._map[e]; + } + forEach(e) { + const t = this._map, + a = t.length; + if (a <= 65536) for (let r = 0; r < a; r++) void 0 !== t[r] && e(r, t[r]); + else for (const a in t) e(a, t[a]); + } + charCodeOf(e) { + const t = this._map; + if (t.length <= 65536) return t.indexOf(e); + for (const a in t) if (t[a] === e) return 0 | a; + return -1; + } + getMap() { + return this._map; + } + readCharCode(e, t, a) { + let r = 0; + const i = this.codespaceRanges; + for (let n = 0, s = i.length; n < s; n++) { + r = ((r << 8) | e.charCodeAt(t + n)) >>> 0; + const s = i[n]; + for (let e = 0, t = s.length; e < t; ) { + const t = s[e++], + i = s[e++]; + if (r >= t && r <= i) { + a.charcode = r; + a.length = n + 1; + return; + } + } + } + a.charcode = 0; + a.length = 1; + } + getCharCodeLength(e) { + const t = this.codespaceRanges; + for (let a = 0, r = t.length; a < r; a++) { + const r = t[a]; + for (let t = 0, i = r.length; t < i; ) { + const i = r[t++], + n = r[t++]; + if (e >= i && e <= n) return a + 1; + } + } + return 1; + } + get length() { + return this._map.length; + } + get isIdentityCMap() { + if ("Identity-H" !== this.name && "Identity-V" !== this.name) return !1; + if (65536 !== this._map.length) return !1; + for (let e = 0; e < 65536; e++) if (this._map[e] !== e) return !1; + return !0; + } +} +class IdentityCMap extends CMap { + constructor(e, t) { + super(); + this.vertical = e; + this.addCodespaceRange(t, 0, 65535); + } + mapCidRange(e, t, a) { + unreachable("should not call mapCidRange"); + } + mapBfRange(e, t, a) { + unreachable("should not call mapBfRange"); + } + mapBfRangeToArray(e, t, a) { + unreachable("should not call mapBfRangeToArray"); + } + mapOne(e, t) { + unreachable("should not call mapCidOne"); + } + lookup(e) { + return Number.isInteger(e) && e <= 65535 ? e : void 0; + } + contains(e) { + return Number.isInteger(e) && e <= 65535; + } + forEach(e) { + for (let t = 0; t <= 65535; t++) e(t, t); + } + charCodeOf(e) { + return Number.isInteger(e) && e <= 65535 ? e : -1; + } + getMap() { + const e = new Array(65536); + for (let t = 0; t <= 65535; t++) e[t] = t; + return e; + } + get length() { + return 65536; + } + get isIdentityCMap() { + unreachable("should not access .isIdentityCMap"); + } +} +function strToInt(e) { + let t = 0; + for (let a = 0; a < e.length; a++) t = (t << 8) | e.charCodeAt(a); + return t >>> 0; +} +function expectString(e) { + if ("string" != typeof e) + throw new FormatError("Malformed CMap: expected string."); +} +function expectInt(e) { + if (!Number.isInteger(e)) + throw new FormatError("Malformed CMap: expected int."); +} +function parseBfChar(e, t) { + for (;;) { + let a = t.getObj(); + if (a === wa) break; + if (isCmd(a, "endbfchar")) return; + expectString(a); + const r = strToInt(a); + a = t.getObj(); + expectString(a); + const i = a; + e.mapOne(r, i); + } +} +function parseBfRange(e, t) { + for (;;) { + let a = t.getObj(); + if (a === wa) break; + if (isCmd(a, "endbfrange")) return; + expectString(a); + const r = strToInt(a); + a = t.getObj(); + expectString(a); + const i = strToInt(a); + a = t.getObj(); + if (Number.isInteger(a) || "string" == typeof a) { + const t = Number.isInteger(a) ? String.fromCharCode(a) : a; + e.mapBfRange(r, i, t); + } else { + if (!isCmd(a, "[")) break; + { + a = t.getObj(); + const n = []; + for (; !isCmd(a, "]") && a !== wa; ) { + n.push(a); + a = t.getObj(); + } + e.mapBfRangeToArray(r, i, n); + } + } + } + throw new FormatError("Invalid bf range."); +} +function parseCidChar(e, t) { + for (;;) { + let a = t.getObj(); + if (a === wa) break; + if (isCmd(a, "endcidchar")) return; + expectString(a); + const r = strToInt(a); + a = t.getObj(); + expectInt(a); + const i = a; + e.mapOne(r, i); + } +} +function parseCidRange(e, t) { + for (;;) { + let a = t.getObj(); + if (a === wa) break; + if (isCmd(a, "endcidrange")) return; + expectString(a); + const r = strToInt(a); + a = t.getObj(); + expectString(a); + const i = strToInt(a); + a = t.getObj(); + expectInt(a); + const n = a; + e.mapCidRange(r, i, n); + } +} +function parseCodespaceRange(e, t) { + for (;;) { + let a = t.getObj(); + if (a === wa) break; + if (isCmd(a, "endcodespacerange")) return; + if ("string" != typeof a) break; + const r = strToInt(a); + a = t.getObj(); + if ("string" != typeof a) break; + const i = strToInt(a); + e.addCodespaceRange(a.length, r, i); + } + throw new FormatError("Invalid codespace range."); +} +function parseWMode(e, t) { + const a = t.getObj(); + Number.isInteger(a) && (e.vertical = !!a); +} +function parseCMapName(e, t) { + const a = t.getObj(); + a instanceof Name && (e.name = a.name); +} +async function parseCMap(e, t, a, r) { + let i, n; + e: for (;;) + try { + const a = t.getObj(); + if (a === wa) break; + if (a instanceof Name) { + "WMode" === a.name + ? parseWMode(e, t) + : "CMapName" === a.name && parseCMapName(e, t); + i = a; + } else if (a instanceof Cmd) + switch (a.cmd) { + case "endcmap": + break e; + case "usecmap": + i instanceof Name && (n = i.name); + break; + case "begincodespacerange": + parseCodespaceRange(e, t); + break; + case "beginbfchar": + parseBfChar(e, t); + break; + case "begincidchar": + parseCidChar(e, t); + break; + case "beginbfrange": + parseBfRange(e, t); + break; + case "begincidrange": + parseCidRange(e, t); + } + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Invalid cMap data: " + e); + continue; + } + !r && n && (r = n); + return r ? extendCMap(e, a, r) : e; +} +async function extendCMap(e, t, a) { + e.useCMap = await createBuiltInCMap(a, t); + if (0 === e.numCodespaceRanges) { + const t = e.useCMap.codespaceRanges; + for (let a = 0; a < t.length; a++) e.codespaceRanges[a] = t[a].slice(); + e.numCodespaceRanges = e.useCMap.numCodespaceRanges; + } + e.useCMap.forEach(function (t, a) { + e.contains(t) || e.mapOne(t, a); + }); + return e; +} +async function createBuiltInCMap(e, t) { + if ("Identity-H" === e) return new IdentityCMap(!1, 2); + if ("Identity-V" === e) return new IdentityCMap(!0, 2); + if (!br.includes(e)) throw new Error("Unknown CMap name: " + e); + if (!t) throw new Error("Built-in CMap parameters are not provided."); + const { cMapData: a, isCompressed: r } = await t(e), + i = new CMap(!0); + if (r) + return new BinaryCMapReader().process(a, i, (e) => extendCMap(i, t, e)); + const n = new Lexer(new Stream(a)); + return parseCMap(i, n, t, null); +} +class CMapFactory { + static async create({ encoding: e, fetchBuiltInCMap: t, useCMap: a }) { + if (e instanceof Name) return createBuiltInCMap(e.name, t); + if (e instanceof BaseStream) { + const r = await parseCMap(new CMap(), new Lexer(e), t, a); + return r.isIdentityCMap ? createBuiltInCMap(r.name, t) : r; + } + throw new Error("Encoding required."); + } +} +const wr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclamsmall", + "Hungarumlautsmall", + "", + "dollaroldstyle", + "dollarsuperior", + "ampersandsmall", + "Acutesmall", + "parenleftsuperior", + "parenrightsuperior", + "twodotenleader", + "onedotenleader", + "comma", + "hyphen", + "period", + "fraction", + "zerooldstyle", + "oneoldstyle", + "twooldstyle", + "threeoldstyle", + "fouroldstyle", + "fiveoldstyle", + "sixoldstyle", + "sevenoldstyle", + "eightoldstyle", + "nineoldstyle", + "colon", + "semicolon", + "commasuperior", + "threequartersemdash", + "periodsuperior", + "questionsmall", + "", + "asuperior", + "bsuperior", + "centsuperior", + "dsuperior", + "esuperior", + "", + "", + "", + "isuperior", + "", + "", + "lsuperior", + "msuperior", + "nsuperior", + "osuperior", + "", + "", + "rsuperior", + "ssuperior", + "tsuperior", + "", + "ff", + "fi", + "fl", + "ffi", + "ffl", + "parenleftinferior", + "", + "parenrightinferior", + "Circumflexsmall", + "hyphensuperior", + "Gravesmall", + "Asmall", + "Bsmall", + "Csmall", + "Dsmall", + "Esmall", + "Fsmall", + "Gsmall", + "Hsmall", + "Ismall", + "Jsmall", + "Ksmall", + "Lsmall", + "Msmall", + "Nsmall", + "Osmall", + "Psmall", + "Qsmall", + "Rsmall", + "Ssmall", + "Tsmall", + "Usmall", + "Vsmall", + "Wsmall", + "Xsmall", + "Ysmall", + "Zsmall", + "colonmonetary", + "onefitted", + "rupiah", + "Tildesmall", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "exclamdownsmall", + "centoldstyle", + "Lslashsmall", + "", + "", + "Scaronsmall", + "Zcaronsmall", + "Dieresissmall", + "Brevesmall", + "Caronsmall", + "", + "Dotaccentsmall", + "", + "", + "Macronsmall", + "", + "", + "figuredash", + "hypheninferior", + "", + "", + "Ogoneksmall", + "Ringsmall", + "Cedillasmall", + "", + "", + "", + "onequarter", + "onehalf", + "threequarters", + "questiondownsmall", + "oneeighth", + "threeeighths", + "fiveeighths", + "seveneighths", + "onethird", + "twothirds", + "", + "", + "zerosuperior", + "onesuperior", + "twosuperior", + "threesuperior", + "foursuperior", + "fivesuperior", + "sixsuperior", + "sevensuperior", + "eightsuperior", + "ninesuperior", + "zeroinferior", + "oneinferior", + "twoinferior", + "threeinferior", + "fourinferior", + "fiveinferior", + "sixinferior", + "seveninferior", + "eightinferior", + "nineinferior", + "centinferior", + "dollarinferior", + "periodinferior", + "commainferior", + "Agravesmall", + "Aacutesmall", + "Acircumflexsmall", + "Atildesmall", + "Adieresissmall", + "Aringsmall", + "AEsmall", + "Ccedillasmall", + "Egravesmall", + "Eacutesmall", + "Ecircumflexsmall", + "Edieresissmall", + "Igravesmall", + "Iacutesmall", + "Icircumflexsmall", + "Idieresissmall", + "Ethsmall", + "Ntildesmall", + "Ogravesmall", + "Oacutesmall", + "Ocircumflexsmall", + "Otildesmall", + "Odieresissmall", + "OEsmall", + "Oslashsmall", + "Ugravesmall", + "Uacutesmall", + "Ucircumflexsmall", + "Udieresissmall", + "Yacutesmall", + "Thornsmall", + "Ydieresissmall", + ], + xr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclamsmall", + "Hungarumlautsmall", + "centoldstyle", + "dollaroldstyle", + "dollarsuperior", + "ampersandsmall", + "Acutesmall", + "parenleftsuperior", + "parenrightsuperior", + "twodotenleader", + "onedotenleader", + "comma", + "hyphen", + "period", + "fraction", + "zerooldstyle", + "oneoldstyle", + "twooldstyle", + "threeoldstyle", + "fouroldstyle", + "fiveoldstyle", + "sixoldstyle", + "sevenoldstyle", + "eightoldstyle", + "nineoldstyle", + "colon", + "semicolon", + "", + "threequartersemdash", + "", + "questionsmall", + "", + "", + "", + "", + "Ethsmall", + "", + "", + "onequarter", + "onehalf", + "threequarters", + "oneeighth", + "threeeighths", + "fiveeighths", + "seveneighths", + "onethird", + "twothirds", + "", + "", + "", + "", + "", + "", + "ff", + "fi", + "fl", + "ffi", + "ffl", + "parenleftinferior", + "", + "parenrightinferior", + "Circumflexsmall", + "hypheninferior", + "Gravesmall", + "Asmall", + "Bsmall", + "Csmall", + "Dsmall", + "Esmall", + "Fsmall", + "Gsmall", + "Hsmall", + "Ismall", + "Jsmall", + "Ksmall", + "Lsmall", + "Msmall", + "Nsmall", + "Osmall", + "Psmall", + "Qsmall", + "Rsmall", + "Ssmall", + "Tsmall", + "Usmall", + "Vsmall", + "Wsmall", + "Xsmall", + "Ysmall", + "Zsmall", + "colonmonetary", + "onefitted", + "rupiah", + "Tildesmall", + "", + "", + "asuperior", + "centsuperior", + "", + "", + "", + "", + "Aacutesmall", + "Agravesmall", + "Acircumflexsmall", + "Adieresissmall", + "Atildesmall", + "Aringsmall", + "Ccedillasmall", + "Eacutesmall", + "Egravesmall", + "Ecircumflexsmall", + "Edieresissmall", + "Iacutesmall", + "Igravesmall", + "Icircumflexsmall", + "Idieresissmall", + "Ntildesmall", + "Oacutesmall", + "Ogravesmall", + "Ocircumflexsmall", + "Odieresissmall", + "Otildesmall", + "Uacutesmall", + "Ugravesmall", + "Ucircumflexsmall", + "Udieresissmall", + "", + "eightsuperior", + "fourinferior", + "threeinferior", + "sixinferior", + "eightinferior", + "seveninferior", + "Scaronsmall", + "", + "centinferior", + "twoinferior", + "", + "Dieresissmall", + "", + "Caronsmall", + "osuperior", + "fiveinferior", + "", + "commainferior", + "periodinferior", + "Yacutesmall", + "", + "dollarinferior", + "", + "", + "Thornsmall", + "", + "nineinferior", + "zeroinferior", + "Zcaronsmall", + "AEsmall", + "Oslashsmall", + "questiondownsmall", + "oneinferior", + "Lslashsmall", + "", + "", + "", + "", + "", + "", + "Cedillasmall", + "", + "", + "", + "", + "", + "OEsmall", + "figuredash", + "hyphensuperior", + "", + "", + "", + "", + "exclamdownsmall", + "", + "Ydieresissmall", + "", + "onesuperior", + "twosuperior", + "threesuperior", + "foursuperior", + "fivesuperior", + "sixsuperior", + "sevensuperior", + "ninesuperior", + "zerosuperior", + "", + "esuperior", + "rsuperior", + "tsuperior", + "", + "", + "isuperior", + "ssuperior", + "dsuperior", + "", + "", + "", + "", + "", + "lsuperior", + "Ogoneksmall", + "Brevesmall", + "Macronsmall", + "bsuperior", + "nsuperior", + "msuperior", + "commasuperior", + "periodsuperior", + "Dotaccentsmall", + "Ringsmall", + "", + "", + "", + "", + ], + Sr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quotesingle", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "grave", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "", + "Adieresis", + "Aring", + "Ccedilla", + "Eacute", + "Ntilde", + "Odieresis", + "Udieresis", + "aacute", + "agrave", + "acircumflex", + "adieresis", + "atilde", + "aring", + "ccedilla", + "eacute", + "egrave", + "ecircumflex", + "edieresis", + "iacute", + "igrave", + "icircumflex", + "idieresis", + "ntilde", + "oacute", + "ograve", + "ocircumflex", + "odieresis", + "otilde", + "uacute", + "ugrave", + "ucircumflex", + "udieresis", + "dagger", + "degree", + "cent", + "sterling", + "section", + "bullet", + "paragraph", + "germandbls", + "registered", + "copyright", + "trademark", + "acute", + "dieresis", + "notequal", + "AE", + "Oslash", + "infinity", + "plusminus", + "lessequal", + "greaterequal", + "yen", + "mu", + "partialdiff", + "summation", + "product", + "pi", + "integral", + "ordfeminine", + "ordmasculine", + "Omega", + "ae", + "oslash", + "questiondown", + "exclamdown", + "logicalnot", + "radical", + "florin", + "approxequal", + "Delta", + "guillemotleft", + "guillemotright", + "ellipsis", + "space", + "Agrave", + "Atilde", + "Otilde", + "OE", + "oe", + "endash", + "emdash", + "quotedblleft", + "quotedblright", + "quoteleft", + "quoteright", + "divide", + "lozenge", + "ydieresis", + "Ydieresis", + "fraction", + "currency", + "guilsinglleft", + "guilsinglright", + "fi", + "fl", + "daggerdbl", + "periodcentered", + "quotesinglbase", + "quotedblbase", + "perthousand", + "Acircumflex", + "Ecircumflex", + "Aacute", + "Edieresis", + "Egrave", + "Iacute", + "Icircumflex", + "Idieresis", + "Igrave", + "Oacute", + "Ocircumflex", + "apple", + "Ograve", + "Uacute", + "Ucircumflex", + "Ugrave", + "dotlessi", + "circumflex", + "tilde", + "macron", + "breve", + "dotaccent", + "ring", + "cedilla", + "hungarumlaut", + "ogonek", + "caron", + ], + kr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quoteright", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "quoteleft", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "exclamdown", + "cent", + "sterling", + "fraction", + "yen", + "florin", + "section", + "currency", + "quotesingle", + "quotedblleft", + "guillemotleft", + "guilsinglleft", + "guilsinglright", + "fi", + "fl", + "", + "endash", + "dagger", + "daggerdbl", + "periodcentered", + "", + "paragraph", + "bullet", + "quotesinglbase", + "quotedblbase", + "quotedblright", + "guillemotright", + "ellipsis", + "perthousand", + "", + "questiondown", + "", + "grave", + "acute", + "circumflex", + "tilde", + "macron", + "breve", + "dotaccent", + "dieresis", + "", + "ring", + "cedilla", + "", + "hungarumlaut", + "ogonek", + "caron", + "emdash", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "AE", + "", + "ordfeminine", + "", + "", + "", + "", + "Lslash", + "Oslash", + "OE", + "ordmasculine", + "", + "", + "", + "", + "", + "ae", + "", + "", + "", + "dotlessi", + "", + "", + "lslash", + "oslash", + "oe", + "germandbls", + "", + "", + "", + "", + ], + Ar = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quotesingle", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "grave", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "bullet", + "Euro", + "bullet", + "quotesinglbase", + "florin", + "quotedblbase", + "ellipsis", + "dagger", + "daggerdbl", + "circumflex", + "perthousand", + "Scaron", + "guilsinglleft", + "OE", + "bullet", + "Zcaron", + "bullet", + "bullet", + "quoteleft", + "quoteright", + "quotedblleft", + "quotedblright", + "bullet", + "endash", + "emdash", + "tilde", + "trademark", + "scaron", + "guilsinglright", + "oe", + "bullet", + "zcaron", + "Ydieresis", + "space", + "exclamdown", + "cent", + "sterling", + "currency", + "yen", + "brokenbar", + "section", + "dieresis", + "copyright", + "ordfeminine", + "guillemotleft", + "logicalnot", + "hyphen", + "registered", + "macron", + "degree", + "plusminus", + "twosuperior", + "threesuperior", + "acute", + "mu", + "paragraph", + "periodcentered", + "cedilla", + "onesuperior", + "ordmasculine", + "guillemotright", + "onequarter", + "onehalf", + "threequarters", + "questiondown", + "Agrave", + "Aacute", + "Acircumflex", + "Atilde", + "Adieresis", + "Aring", + "AE", + "Ccedilla", + "Egrave", + "Eacute", + "Ecircumflex", + "Edieresis", + "Igrave", + "Iacute", + "Icircumflex", + "Idieresis", + "Eth", + "Ntilde", + "Ograve", + "Oacute", + "Ocircumflex", + "Otilde", + "Odieresis", + "multiply", + "Oslash", + "Ugrave", + "Uacute", + "Ucircumflex", + "Udieresis", + "Yacute", + "Thorn", + "germandbls", + "agrave", + "aacute", + "acircumflex", + "atilde", + "adieresis", + "aring", + "ae", + "ccedilla", + "egrave", + "eacute", + "ecircumflex", + "edieresis", + "igrave", + "iacute", + "icircumflex", + "idieresis", + "eth", + "ntilde", + "ograve", + "oacute", + "ocircumflex", + "otilde", + "odieresis", + "divide", + "oslash", + "ugrave", + "uacute", + "ucircumflex", + "udieresis", + "yacute", + "thorn", + "ydieresis", + ], + Cr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "exclam", + "universal", + "numbersign", + "existential", + "percent", + "ampersand", + "suchthat", + "parenleft", + "parenright", + "asteriskmath", + "plus", + "comma", + "minus", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "congruent", + "Alpha", + "Beta", + "Chi", + "Delta", + "Epsilon", + "Phi", + "Gamma", + "Eta", + "Iota", + "theta1", + "Kappa", + "Lambda", + "Mu", + "Nu", + "Omicron", + "Pi", + "Theta", + "Rho", + "Sigma", + "Tau", + "Upsilon", + "sigma1", + "Omega", + "Xi", + "Psi", + "Zeta", + "bracketleft", + "therefore", + "bracketright", + "perpendicular", + "underscore", + "radicalex", + "alpha", + "beta", + "chi", + "delta", + "epsilon", + "phi", + "gamma", + "eta", + "iota", + "phi1", + "kappa", + "lambda", + "mu", + "nu", + "omicron", + "pi", + "theta", + "rho", + "sigma", + "tau", + "upsilon", + "omega1", + "omega", + "xi", + "psi", + "zeta", + "braceleft", + "bar", + "braceright", + "similar", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "Euro", + "Upsilon1", + "minute", + "lessequal", + "fraction", + "infinity", + "florin", + "club", + "diamond", + "heart", + "spade", + "arrowboth", + "arrowleft", + "arrowup", + "arrowright", + "arrowdown", + "degree", + "plusminus", + "second", + "greaterequal", + "multiply", + "proportional", + "partialdiff", + "bullet", + "divide", + "notequal", + "equivalence", + "approxequal", + "ellipsis", + "arrowvertex", + "arrowhorizex", + "carriagereturn", + "aleph", + "Ifraktur", + "Rfraktur", + "weierstrass", + "circlemultiply", + "circleplus", + "emptyset", + "intersection", + "union", + "propersuperset", + "reflexsuperset", + "notsubset", + "propersubset", + "reflexsubset", + "element", + "notelement", + "angle", + "gradient", + "registerserif", + "copyrightserif", + "trademarkserif", + "product", + "radical", + "dotmath", + "logicalnot", + "logicaland", + "logicalor", + "arrowdblboth", + "arrowdblleft", + "arrowdblup", + "arrowdblright", + "arrowdbldown", + "lozenge", + "angleleft", + "registersans", + "copyrightsans", + "trademarksans", + "summation", + "parenlefttp", + "parenleftex", + "parenleftbt", + "bracketlefttp", + "bracketleftex", + "bracketleftbt", + "bracelefttp", + "braceleftmid", + "braceleftbt", + "braceex", + "", + "angleright", + "integral", + "integraltp", + "integralex", + "integralbt", + "parenrighttp", + "parenrightex", + "parenrightbt", + "bracketrighttp", + "bracketrightex", + "bracketrightbt", + "bracerighttp", + "bracerightmid", + "bracerightbt", + "", + ], + vr = [ + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "space", + "a1", + "a2", + "a202", + "a3", + "a4", + "a5", + "a119", + "a118", + "a117", + "a11", + "a12", + "a13", + "a14", + "a15", + "a16", + "a105", + "a17", + "a18", + "a19", + "a20", + "a21", + "a22", + "a23", + "a24", + "a25", + "a26", + "a27", + "a28", + "a6", + "a7", + "a8", + "a9", + "a10", + "a29", + "a30", + "a31", + "a32", + "a33", + "a34", + "a35", + "a36", + "a37", + "a38", + "a39", + "a40", + "a41", + "a42", + "a43", + "a44", + "a45", + "a46", + "a47", + "a48", + "a49", + "a50", + "a51", + "a52", + "a53", + "a54", + "a55", + "a56", + "a57", + "a58", + "a59", + "a60", + "a61", + "a62", + "a63", + "a64", + "a65", + "a66", + "a67", + "a68", + "a69", + "a70", + "a71", + "a72", + "a73", + "a74", + "a203", + "a75", + "a204", + "a76", + "a77", + "a78", + "a79", + "a81", + "a82", + "a83", + "a84", + "a97", + "a98", + "a99", + "a100", + "", + "a89", + "a90", + "a93", + "a94", + "a91", + "a92", + "a205", + "a85", + "a206", + "a86", + "a87", + "a88", + "a95", + "a96", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "", + "a101", + "a102", + "a103", + "a104", + "a106", + "a107", + "a108", + "a112", + "a111", + "a110", + "a109", + "a120", + "a121", + "a122", + "a123", + "a124", + "a125", + "a126", + "a127", + "a128", + "a129", + "a130", + "a131", + "a132", + "a133", + "a134", + "a135", + "a136", + "a137", + "a138", + "a139", + "a140", + "a141", + "a142", + "a143", + "a144", + "a145", + "a146", + "a147", + "a148", + "a149", + "a150", + "a151", + "a152", + "a153", + "a154", + "a155", + "a156", + "a157", + "a158", + "a159", + "a160", + "a161", + "a163", + "a164", + "a196", + "a165", + "a192", + "a166", + "a167", + "a168", + "a169", + "a170", + "a171", + "a172", + "a173", + "a162", + "a174", + "a175", + "a176", + "a177", + "a178", + "a179", + "a193", + "a180", + "a199", + "a181", + "a200", + "a182", + "", + "a201", + "a183", + "a184", + "a197", + "a185", + "a194", + "a198", + "a186", + "a195", + "a187", + "a188", + "a189", + "a190", + "a191", + "", + ]; +function getEncoding(e) { + switch (e) { + case "WinAnsiEncoding": + return Ar; + case "StandardEncoding": + return kr; + case "MacRomanEncoding": + return Sr; + case "SymbolSetEncoding": + return Cr; + case "ZapfDingbatsEncoding": + return vr; + case "ExpertEncoding": + return wr; + case "MacExpertEncoding": + return xr; + default: + return null; + } +} +const Fr = getLookupTableFactory(function (e) { + e.A = 65; + e.AE = 198; + e.AEacute = 508; + e.AEmacron = 482; + e.AEsmall = 63462; + e.Aacute = 193; + e.Aacutesmall = 63457; + e.Abreve = 258; + e.Abreveacute = 7854; + e.Abrevecyrillic = 1232; + e.Abrevedotbelow = 7862; + e.Abrevegrave = 7856; + e.Abrevehookabove = 7858; + e.Abrevetilde = 7860; + e.Acaron = 461; + e.Acircle = 9398; + e.Acircumflex = 194; + e.Acircumflexacute = 7844; + e.Acircumflexdotbelow = 7852; + e.Acircumflexgrave = 7846; + e.Acircumflexhookabove = 7848; + e.Acircumflexsmall = 63458; + e.Acircumflextilde = 7850; + e.Acute = 63177; + e.Acutesmall = 63412; + e.Acyrillic = 1040; + e.Adblgrave = 512; + e.Adieresis = 196; + e.Adieresiscyrillic = 1234; + e.Adieresismacron = 478; + e.Adieresissmall = 63460; + e.Adotbelow = 7840; + e.Adotmacron = 480; + e.Agrave = 192; + e.Agravesmall = 63456; + e.Ahookabove = 7842; + e.Aiecyrillic = 1236; + e.Ainvertedbreve = 514; + e.Alpha = 913; + e.Alphatonos = 902; + e.Amacron = 256; + e.Amonospace = 65313; + e.Aogonek = 260; + e.Aring = 197; + e.Aringacute = 506; + e.Aringbelow = 7680; + e.Aringsmall = 63461; + e.Asmall = 63329; + e.Atilde = 195; + e.Atildesmall = 63459; + e.Aybarmenian = 1329; + e.B = 66; + e.Bcircle = 9399; + e.Bdotaccent = 7682; + e.Bdotbelow = 7684; + e.Becyrillic = 1041; + e.Benarmenian = 1330; + e.Beta = 914; + e.Bhook = 385; + e.Blinebelow = 7686; + e.Bmonospace = 65314; + e.Brevesmall = 63220; + e.Bsmall = 63330; + e.Btopbar = 386; + e.C = 67; + e.Caarmenian = 1342; + e.Cacute = 262; + e.Caron = 63178; + e.Caronsmall = 63221; + e.Ccaron = 268; + e.Ccedilla = 199; + e.Ccedillaacute = 7688; + e.Ccedillasmall = 63463; + e.Ccircle = 9400; + e.Ccircumflex = 264; + e.Cdot = 266; + e.Cdotaccent = 266; + e.Cedillasmall = 63416; + e.Chaarmenian = 1353; + e.Cheabkhasiancyrillic = 1212; + e.Checyrillic = 1063; + e.Chedescenderabkhasiancyrillic = 1214; + e.Chedescendercyrillic = 1206; + e.Chedieresiscyrillic = 1268; + e.Cheharmenian = 1347; + e.Chekhakassiancyrillic = 1227; + e.Cheverticalstrokecyrillic = 1208; + e.Chi = 935; + e.Chook = 391; + e.Circumflexsmall = 63222; + e.Cmonospace = 65315; + e.Coarmenian = 1361; + e.Csmall = 63331; + e.D = 68; + e.DZ = 497; + e.DZcaron = 452; + e.Daarmenian = 1332; + e.Dafrican = 393; + e.Dcaron = 270; + e.Dcedilla = 7696; + e.Dcircle = 9401; + e.Dcircumflexbelow = 7698; + e.Dcroat = 272; + e.Ddotaccent = 7690; + e.Ddotbelow = 7692; + e.Decyrillic = 1044; + e.Deicoptic = 1006; + e.Delta = 8710; + e.Deltagreek = 916; + e.Dhook = 394; + e.Dieresis = 63179; + e.DieresisAcute = 63180; + e.DieresisGrave = 63181; + e.Dieresissmall = 63400; + e.Digammagreek = 988; + e.Djecyrillic = 1026; + e.Dlinebelow = 7694; + e.Dmonospace = 65316; + e.Dotaccentsmall = 63223; + e.Dslash = 272; + e.Dsmall = 63332; + e.Dtopbar = 395; + e.Dz = 498; + e.Dzcaron = 453; + e.Dzeabkhasiancyrillic = 1248; + e.Dzecyrillic = 1029; + e.Dzhecyrillic = 1039; + e.E = 69; + e.Eacute = 201; + e.Eacutesmall = 63465; + e.Ebreve = 276; + e.Ecaron = 282; + e.Ecedillabreve = 7708; + e.Echarmenian = 1333; + e.Ecircle = 9402; + e.Ecircumflex = 202; + e.Ecircumflexacute = 7870; + e.Ecircumflexbelow = 7704; + e.Ecircumflexdotbelow = 7878; + e.Ecircumflexgrave = 7872; + e.Ecircumflexhookabove = 7874; + e.Ecircumflexsmall = 63466; + e.Ecircumflextilde = 7876; + e.Ecyrillic = 1028; + e.Edblgrave = 516; + e.Edieresis = 203; + e.Edieresissmall = 63467; + e.Edot = 278; + e.Edotaccent = 278; + e.Edotbelow = 7864; + e.Efcyrillic = 1060; + e.Egrave = 200; + e.Egravesmall = 63464; + e.Eharmenian = 1335; + e.Ehookabove = 7866; + e.Eightroman = 8551; + e.Einvertedbreve = 518; + e.Eiotifiedcyrillic = 1124; + e.Elcyrillic = 1051; + e.Elevenroman = 8554; + e.Emacron = 274; + e.Emacronacute = 7702; + e.Emacrongrave = 7700; + e.Emcyrillic = 1052; + e.Emonospace = 65317; + e.Encyrillic = 1053; + e.Endescendercyrillic = 1186; + e.Eng = 330; + e.Enghecyrillic = 1188; + e.Enhookcyrillic = 1223; + e.Eogonek = 280; + e.Eopen = 400; + e.Epsilon = 917; + e.Epsilontonos = 904; + e.Ercyrillic = 1056; + e.Ereversed = 398; + e.Ereversedcyrillic = 1069; + e.Escyrillic = 1057; + e.Esdescendercyrillic = 1194; + e.Esh = 425; + e.Esmall = 63333; + e.Eta = 919; + e.Etarmenian = 1336; + e.Etatonos = 905; + e.Eth = 208; + e.Ethsmall = 63472; + e.Etilde = 7868; + e.Etildebelow = 7706; + e.Euro = 8364; + e.Ezh = 439; + e.Ezhcaron = 494; + e.Ezhreversed = 440; + e.F = 70; + e.Fcircle = 9403; + e.Fdotaccent = 7710; + e.Feharmenian = 1366; + e.Feicoptic = 996; + e.Fhook = 401; + e.Fitacyrillic = 1138; + e.Fiveroman = 8548; + e.Fmonospace = 65318; + e.Fourroman = 8547; + e.Fsmall = 63334; + e.G = 71; + e.GBsquare = 13191; + e.Gacute = 500; + e.Gamma = 915; + e.Gammaafrican = 404; + e.Gangiacoptic = 1002; + e.Gbreve = 286; + e.Gcaron = 486; + e.Gcedilla = 290; + e.Gcircle = 9404; + e.Gcircumflex = 284; + e.Gcommaaccent = 290; + e.Gdot = 288; + e.Gdotaccent = 288; + e.Gecyrillic = 1043; + e.Ghadarmenian = 1346; + e.Ghemiddlehookcyrillic = 1172; + e.Ghestrokecyrillic = 1170; + e.Gheupturncyrillic = 1168; + e.Ghook = 403; + e.Gimarmenian = 1331; + e.Gjecyrillic = 1027; + e.Gmacron = 7712; + e.Gmonospace = 65319; + e.Grave = 63182; + e.Gravesmall = 63328; + e.Gsmall = 63335; + e.Gsmallhook = 667; + e.Gstroke = 484; + e.H = 72; + e.H18533 = 9679; + e.H18543 = 9642; + e.H18551 = 9643; + e.H22073 = 9633; + e.HPsquare = 13259; + e.Haabkhasiancyrillic = 1192; + e.Hadescendercyrillic = 1202; + e.Hardsigncyrillic = 1066; + e.Hbar = 294; + e.Hbrevebelow = 7722; + e.Hcedilla = 7720; + e.Hcircle = 9405; + e.Hcircumflex = 292; + e.Hdieresis = 7718; + e.Hdotaccent = 7714; + e.Hdotbelow = 7716; + e.Hmonospace = 65320; + e.Hoarmenian = 1344; + e.Horicoptic = 1e3; + e.Hsmall = 63336; + e.Hungarumlaut = 63183; + e.Hungarumlautsmall = 63224; + e.Hzsquare = 13200; + e.I = 73; + e.IAcyrillic = 1071; + e.IJ = 306; + e.IUcyrillic = 1070; + e.Iacute = 205; + e.Iacutesmall = 63469; + e.Ibreve = 300; + e.Icaron = 463; + e.Icircle = 9406; + e.Icircumflex = 206; + e.Icircumflexsmall = 63470; + e.Icyrillic = 1030; + e.Idblgrave = 520; + e.Idieresis = 207; + e.Idieresisacute = 7726; + e.Idieresiscyrillic = 1252; + e.Idieresissmall = 63471; + e.Idot = 304; + e.Idotaccent = 304; + e.Idotbelow = 7882; + e.Iebrevecyrillic = 1238; + e.Iecyrillic = 1045; + e.Ifraktur = 8465; + e.Igrave = 204; + e.Igravesmall = 63468; + e.Ihookabove = 7880; + e.Iicyrillic = 1048; + e.Iinvertedbreve = 522; + e.Iishortcyrillic = 1049; + e.Imacron = 298; + e.Imacroncyrillic = 1250; + e.Imonospace = 65321; + e.Iniarmenian = 1339; + e.Iocyrillic = 1025; + e.Iogonek = 302; + e.Iota = 921; + e.Iotaafrican = 406; + e.Iotadieresis = 938; + e.Iotatonos = 906; + e.Ismall = 63337; + e.Istroke = 407; + e.Itilde = 296; + e.Itildebelow = 7724; + e.Izhitsacyrillic = 1140; + e.Izhitsadblgravecyrillic = 1142; + e.J = 74; + e.Jaarmenian = 1345; + e.Jcircle = 9407; + e.Jcircumflex = 308; + e.Jecyrillic = 1032; + e.Jheharmenian = 1355; + e.Jmonospace = 65322; + e.Jsmall = 63338; + e.K = 75; + e.KBsquare = 13189; + e.KKsquare = 13261; + e.Kabashkircyrillic = 1184; + e.Kacute = 7728; + e.Kacyrillic = 1050; + e.Kadescendercyrillic = 1178; + e.Kahookcyrillic = 1219; + e.Kappa = 922; + e.Kastrokecyrillic = 1182; + e.Kaverticalstrokecyrillic = 1180; + e.Kcaron = 488; + e.Kcedilla = 310; + e.Kcircle = 9408; + e.Kcommaaccent = 310; + e.Kdotbelow = 7730; + e.Keharmenian = 1364; + e.Kenarmenian = 1343; + e.Khacyrillic = 1061; + e.Kheicoptic = 998; + e.Khook = 408; + e.Kjecyrillic = 1036; + e.Klinebelow = 7732; + e.Kmonospace = 65323; + e.Koppacyrillic = 1152; + e.Koppagreek = 990; + e.Ksicyrillic = 1134; + e.Ksmall = 63339; + e.L = 76; + e.LJ = 455; + e.LL = 63167; + e.Lacute = 313; + e.Lambda = 923; + e.Lcaron = 317; + e.Lcedilla = 315; + e.Lcircle = 9409; + e.Lcircumflexbelow = 7740; + e.Lcommaaccent = 315; + e.Ldot = 319; + e.Ldotaccent = 319; + e.Ldotbelow = 7734; + e.Ldotbelowmacron = 7736; + e.Liwnarmenian = 1340; + e.Lj = 456; + e.Ljecyrillic = 1033; + e.Llinebelow = 7738; + e.Lmonospace = 65324; + e.Lslash = 321; + e.Lslashsmall = 63225; + e.Lsmall = 63340; + e.M = 77; + e.MBsquare = 13190; + e.Macron = 63184; + e.Macronsmall = 63407; + e.Macute = 7742; + e.Mcircle = 9410; + e.Mdotaccent = 7744; + e.Mdotbelow = 7746; + e.Menarmenian = 1348; + e.Mmonospace = 65325; + e.Msmall = 63341; + e.Mturned = 412; + e.Mu = 924; + e.N = 78; + e.NJ = 458; + e.Nacute = 323; + e.Ncaron = 327; + e.Ncedilla = 325; + e.Ncircle = 9411; + e.Ncircumflexbelow = 7754; + e.Ncommaaccent = 325; + e.Ndotaccent = 7748; + e.Ndotbelow = 7750; + e.Nhookleft = 413; + e.Nineroman = 8552; + e.Nj = 459; + e.Njecyrillic = 1034; + e.Nlinebelow = 7752; + e.Nmonospace = 65326; + e.Nowarmenian = 1350; + e.Nsmall = 63342; + e.Ntilde = 209; + e.Ntildesmall = 63473; + e.Nu = 925; + e.O = 79; + e.OE = 338; + e.OEsmall = 63226; + e.Oacute = 211; + e.Oacutesmall = 63475; + e.Obarredcyrillic = 1256; + e.Obarreddieresiscyrillic = 1258; + e.Obreve = 334; + e.Ocaron = 465; + e.Ocenteredtilde = 415; + e.Ocircle = 9412; + e.Ocircumflex = 212; + e.Ocircumflexacute = 7888; + e.Ocircumflexdotbelow = 7896; + e.Ocircumflexgrave = 7890; + e.Ocircumflexhookabove = 7892; + e.Ocircumflexsmall = 63476; + e.Ocircumflextilde = 7894; + e.Ocyrillic = 1054; + e.Odblacute = 336; + e.Odblgrave = 524; + e.Odieresis = 214; + e.Odieresiscyrillic = 1254; + e.Odieresissmall = 63478; + e.Odotbelow = 7884; + e.Ogoneksmall = 63227; + e.Ograve = 210; + e.Ogravesmall = 63474; + e.Oharmenian = 1365; + e.Ohm = 8486; + e.Ohookabove = 7886; + e.Ohorn = 416; + e.Ohornacute = 7898; + e.Ohorndotbelow = 7906; + e.Ohorngrave = 7900; + e.Ohornhookabove = 7902; + e.Ohorntilde = 7904; + e.Ohungarumlaut = 336; + e.Oi = 418; + e.Oinvertedbreve = 526; + e.Omacron = 332; + e.Omacronacute = 7762; + e.Omacrongrave = 7760; + e.Omega = 8486; + e.Omegacyrillic = 1120; + e.Omegagreek = 937; + e.Omegaroundcyrillic = 1146; + e.Omegatitlocyrillic = 1148; + e.Omegatonos = 911; + e.Omicron = 927; + e.Omicrontonos = 908; + e.Omonospace = 65327; + e.Oneroman = 8544; + e.Oogonek = 490; + e.Oogonekmacron = 492; + e.Oopen = 390; + e.Oslash = 216; + e.Oslashacute = 510; + e.Oslashsmall = 63480; + e.Osmall = 63343; + e.Ostrokeacute = 510; + e.Otcyrillic = 1150; + e.Otilde = 213; + e.Otildeacute = 7756; + e.Otildedieresis = 7758; + e.Otildesmall = 63477; + e.P = 80; + e.Pacute = 7764; + e.Pcircle = 9413; + e.Pdotaccent = 7766; + e.Pecyrillic = 1055; + e.Peharmenian = 1354; + e.Pemiddlehookcyrillic = 1190; + e.Phi = 934; + e.Phook = 420; + e.Pi = 928; + e.Piwrarmenian = 1363; + e.Pmonospace = 65328; + e.Psi = 936; + e.Psicyrillic = 1136; + e.Psmall = 63344; + e.Q = 81; + e.Qcircle = 9414; + e.Qmonospace = 65329; + e.Qsmall = 63345; + e.R = 82; + e.Raarmenian = 1356; + e.Racute = 340; + e.Rcaron = 344; + e.Rcedilla = 342; + e.Rcircle = 9415; + e.Rcommaaccent = 342; + e.Rdblgrave = 528; + e.Rdotaccent = 7768; + e.Rdotbelow = 7770; + e.Rdotbelowmacron = 7772; + e.Reharmenian = 1360; + e.Rfraktur = 8476; + e.Rho = 929; + e.Ringsmall = 63228; + e.Rinvertedbreve = 530; + e.Rlinebelow = 7774; + e.Rmonospace = 65330; + e.Rsmall = 63346; + e.Rsmallinverted = 641; + e.Rsmallinvertedsuperior = 694; + e.S = 83; + e.SF010000 = 9484; + e.SF020000 = 9492; + e.SF030000 = 9488; + e.SF040000 = 9496; + e.SF050000 = 9532; + e.SF060000 = 9516; + e.SF070000 = 9524; + e.SF080000 = 9500; + e.SF090000 = 9508; + e.SF100000 = 9472; + e.SF110000 = 9474; + e.SF190000 = 9569; + e.SF200000 = 9570; + e.SF210000 = 9558; + e.SF220000 = 9557; + e.SF230000 = 9571; + e.SF240000 = 9553; + e.SF250000 = 9559; + e.SF260000 = 9565; + e.SF270000 = 9564; + e.SF280000 = 9563; + e.SF360000 = 9566; + e.SF370000 = 9567; + e.SF380000 = 9562; + e.SF390000 = 9556; + e.SF400000 = 9577; + e.SF410000 = 9574; + e.SF420000 = 9568; + e.SF430000 = 9552; + e.SF440000 = 9580; + e.SF450000 = 9575; + e.SF460000 = 9576; + e.SF470000 = 9572; + e.SF480000 = 9573; + e.SF490000 = 9561; + e.SF500000 = 9560; + e.SF510000 = 9554; + e.SF520000 = 9555; + e.SF530000 = 9579; + e.SF540000 = 9578; + e.Sacute = 346; + e.Sacutedotaccent = 7780; + e.Sampigreek = 992; + e.Scaron = 352; + e.Scarondotaccent = 7782; + e.Scaronsmall = 63229; + e.Scedilla = 350; + e.Schwa = 399; + e.Schwacyrillic = 1240; + e.Schwadieresiscyrillic = 1242; + e.Scircle = 9416; + e.Scircumflex = 348; + e.Scommaaccent = 536; + e.Sdotaccent = 7776; + e.Sdotbelow = 7778; + e.Sdotbelowdotaccent = 7784; + e.Seharmenian = 1357; + e.Sevenroman = 8550; + e.Shaarmenian = 1351; + e.Shacyrillic = 1064; + e.Shchacyrillic = 1065; + e.Sheicoptic = 994; + e.Shhacyrillic = 1210; + e.Shimacoptic = 1004; + e.Sigma = 931; + e.Sixroman = 8549; + e.Smonospace = 65331; + e.Softsigncyrillic = 1068; + e.Ssmall = 63347; + e.Stigmagreek = 986; + e.T = 84; + e.Tau = 932; + e.Tbar = 358; + e.Tcaron = 356; + e.Tcedilla = 354; + e.Tcircle = 9417; + e.Tcircumflexbelow = 7792; + e.Tcommaaccent = 354; + e.Tdotaccent = 7786; + e.Tdotbelow = 7788; + e.Tecyrillic = 1058; + e.Tedescendercyrillic = 1196; + e.Tenroman = 8553; + e.Tetsecyrillic = 1204; + e.Theta = 920; + e.Thook = 428; + e.Thorn = 222; + e.Thornsmall = 63486; + e.Threeroman = 8546; + e.Tildesmall = 63230; + e.Tiwnarmenian = 1359; + e.Tlinebelow = 7790; + e.Tmonospace = 65332; + e.Toarmenian = 1337; + e.Tonefive = 444; + e.Tonesix = 388; + e.Tonetwo = 423; + e.Tretroflexhook = 430; + e.Tsecyrillic = 1062; + e.Tshecyrillic = 1035; + e.Tsmall = 63348; + e.Twelveroman = 8555; + e.Tworoman = 8545; + e.U = 85; + e.Uacute = 218; + e.Uacutesmall = 63482; + e.Ubreve = 364; + e.Ucaron = 467; + e.Ucircle = 9418; + e.Ucircumflex = 219; + e.Ucircumflexbelow = 7798; + e.Ucircumflexsmall = 63483; + e.Ucyrillic = 1059; + e.Udblacute = 368; + e.Udblgrave = 532; + e.Udieresis = 220; + e.Udieresisacute = 471; + e.Udieresisbelow = 7794; + e.Udieresiscaron = 473; + e.Udieresiscyrillic = 1264; + e.Udieresisgrave = 475; + e.Udieresismacron = 469; + e.Udieresissmall = 63484; + e.Udotbelow = 7908; + e.Ugrave = 217; + e.Ugravesmall = 63481; + e.Uhookabove = 7910; + e.Uhorn = 431; + e.Uhornacute = 7912; + e.Uhorndotbelow = 7920; + e.Uhorngrave = 7914; + e.Uhornhookabove = 7916; + e.Uhorntilde = 7918; + e.Uhungarumlaut = 368; + e.Uhungarumlautcyrillic = 1266; + e.Uinvertedbreve = 534; + e.Ukcyrillic = 1144; + e.Umacron = 362; + e.Umacroncyrillic = 1262; + e.Umacrondieresis = 7802; + e.Umonospace = 65333; + e.Uogonek = 370; + e.Upsilon = 933; + e.Upsilon1 = 978; + e.Upsilonacutehooksymbolgreek = 979; + e.Upsilonafrican = 433; + e.Upsilondieresis = 939; + e.Upsilondieresishooksymbolgreek = 980; + e.Upsilonhooksymbol = 978; + e.Upsilontonos = 910; + e.Uring = 366; + e.Ushortcyrillic = 1038; + e.Usmall = 63349; + e.Ustraightcyrillic = 1198; + e.Ustraightstrokecyrillic = 1200; + e.Utilde = 360; + e.Utildeacute = 7800; + e.Utildebelow = 7796; + e.V = 86; + e.Vcircle = 9419; + e.Vdotbelow = 7806; + e.Vecyrillic = 1042; + e.Vewarmenian = 1358; + e.Vhook = 434; + e.Vmonospace = 65334; + e.Voarmenian = 1352; + e.Vsmall = 63350; + e.Vtilde = 7804; + e.W = 87; + e.Wacute = 7810; + e.Wcircle = 9420; + e.Wcircumflex = 372; + e.Wdieresis = 7812; + e.Wdotaccent = 7814; + e.Wdotbelow = 7816; + e.Wgrave = 7808; + e.Wmonospace = 65335; + e.Wsmall = 63351; + e.X = 88; + e.Xcircle = 9421; + e.Xdieresis = 7820; + e.Xdotaccent = 7818; + e.Xeharmenian = 1341; + e.Xi = 926; + e.Xmonospace = 65336; + e.Xsmall = 63352; + e.Y = 89; + e.Yacute = 221; + e.Yacutesmall = 63485; + e.Yatcyrillic = 1122; + e.Ycircle = 9422; + e.Ycircumflex = 374; + e.Ydieresis = 376; + e.Ydieresissmall = 63487; + e.Ydotaccent = 7822; + e.Ydotbelow = 7924; + e.Yericyrillic = 1067; + e.Yerudieresiscyrillic = 1272; + e.Ygrave = 7922; + e.Yhook = 435; + e.Yhookabove = 7926; + e.Yiarmenian = 1349; + e.Yicyrillic = 1031; + e.Yiwnarmenian = 1362; + e.Ymonospace = 65337; + e.Ysmall = 63353; + e.Ytilde = 7928; + e.Yusbigcyrillic = 1130; + e.Yusbigiotifiedcyrillic = 1132; + e.Yuslittlecyrillic = 1126; + e.Yuslittleiotifiedcyrillic = 1128; + e.Z = 90; + e.Zaarmenian = 1334; + e.Zacute = 377; + e.Zcaron = 381; + e.Zcaronsmall = 63231; + e.Zcircle = 9423; + e.Zcircumflex = 7824; + e.Zdot = 379; + e.Zdotaccent = 379; + e.Zdotbelow = 7826; + e.Zecyrillic = 1047; + e.Zedescendercyrillic = 1176; + e.Zedieresiscyrillic = 1246; + e.Zeta = 918; + e.Zhearmenian = 1338; + e.Zhebrevecyrillic = 1217; + e.Zhecyrillic = 1046; + e.Zhedescendercyrillic = 1174; + e.Zhedieresiscyrillic = 1244; + e.Zlinebelow = 7828; + e.Zmonospace = 65338; + e.Zsmall = 63354; + e.Zstroke = 437; + e.a = 97; + e.aabengali = 2438; + e.aacute = 225; + e.aadeva = 2310; + e.aagujarati = 2694; + e.aagurmukhi = 2566; + e.aamatragurmukhi = 2622; + e.aarusquare = 13059; + e.aavowelsignbengali = 2494; + e.aavowelsigndeva = 2366; + e.aavowelsigngujarati = 2750; + e.abbreviationmarkarmenian = 1375; + e.abbreviationsigndeva = 2416; + e.abengali = 2437; + e.abopomofo = 12570; + e.abreve = 259; + e.abreveacute = 7855; + e.abrevecyrillic = 1233; + e.abrevedotbelow = 7863; + e.abrevegrave = 7857; + e.abrevehookabove = 7859; + e.abrevetilde = 7861; + e.acaron = 462; + e.acircle = 9424; + e.acircumflex = 226; + e.acircumflexacute = 7845; + e.acircumflexdotbelow = 7853; + e.acircumflexgrave = 7847; + e.acircumflexhookabove = 7849; + e.acircumflextilde = 7851; + e.acute = 180; + e.acutebelowcmb = 791; + e.acutecmb = 769; + e.acutecomb = 769; + e.acutedeva = 2388; + e.acutelowmod = 719; + e.acutetonecmb = 833; + e.acyrillic = 1072; + e.adblgrave = 513; + e.addakgurmukhi = 2673; + e.adeva = 2309; + e.adieresis = 228; + e.adieresiscyrillic = 1235; + e.adieresismacron = 479; + e.adotbelow = 7841; + e.adotmacron = 481; + e.ae = 230; + e.aeacute = 509; + e.aekorean = 12624; + e.aemacron = 483; + e.afii00208 = 8213; + e.afii08941 = 8356; + e.afii10017 = 1040; + e.afii10018 = 1041; + e.afii10019 = 1042; + e.afii10020 = 1043; + e.afii10021 = 1044; + e.afii10022 = 1045; + e.afii10023 = 1025; + e.afii10024 = 1046; + e.afii10025 = 1047; + e.afii10026 = 1048; + e.afii10027 = 1049; + e.afii10028 = 1050; + e.afii10029 = 1051; + e.afii10030 = 1052; + e.afii10031 = 1053; + e.afii10032 = 1054; + e.afii10033 = 1055; + e.afii10034 = 1056; + e.afii10035 = 1057; + e.afii10036 = 1058; + e.afii10037 = 1059; + e.afii10038 = 1060; + e.afii10039 = 1061; + e.afii10040 = 1062; + e.afii10041 = 1063; + e.afii10042 = 1064; + e.afii10043 = 1065; + e.afii10044 = 1066; + e.afii10045 = 1067; + e.afii10046 = 1068; + e.afii10047 = 1069; + e.afii10048 = 1070; + e.afii10049 = 1071; + e.afii10050 = 1168; + e.afii10051 = 1026; + e.afii10052 = 1027; + e.afii10053 = 1028; + e.afii10054 = 1029; + e.afii10055 = 1030; + e.afii10056 = 1031; + e.afii10057 = 1032; + e.afii10058 = 1033; + e.afii10059 = 1034; + e.afii10060 = 1035; + e.afii10061 = 1036; + e.afii10062 = 1038; + e.afii10063 = 63172; + e.afii10064 = 63173; + e.afii10065 = 1072; + e.afii10066 = 1073; + e.afii10067 = 1074; + e.afii10068 = 1075; + e.afii10069 = 1076; + e.afii10070 = 1077; + e.afii10071 = 1105; + e.afii10072 = 1078; + e.afii10073 = 1079; + e.afii10074 = 1080; + e.afii10075 = 1081; + e.afii10076 = 1082; + e.afii10077 = 1083; + e.afii10078 = 1084; + e.afii10079 = 1085; + e.afii10080 = 1086; + e.afii10081 = 1087; + e.afii10082 = 1088; + e.afii10083 = 1089; + e.afii10084 = 1090; + e.afii10085 = 1091; + e.afii10086 = 1092; + e.afii10087 = 1093; + e.afii10088 = 1094; + e.afii10089 = 1095; + e.afii10090 = 1096; + e.afii10091 = 1097; + e.afii10092 = 1098; + e.afii10093 = 1099; + e.afii10094 = 1100; + e.afii10095 = 1101; + e.afii10096 = 1102; + e.afii10097 = 1103; + e.afii10098 = 1169; + e.afii10099 = 1106; + e.afii10100 = 1107; + e.afii10101 = 1108; + e.afii10102 = 1109; + e.afii10103 = 1110; + e.afii10104 = 1111; + e.afii10105 = 1112; + e.afii10106 = 1113; + e.afii10107 = 1114; + e.afii10108 = 1115; + e.afii10109 = 1116; + e.afii10110 = 1118; + e.afii10145 = 1039; + e.afii10146 = 1122; + e.afii10147 = 1138; + e.afii10148 = 1140; + e.afii10192 = 63174; + e.afii10193 = 1119; + e.afii10194 = 1123; + e.afii10195 = 1139; + e.afii10196 = 1141; + e.afii10831 = 63175; + e.afii10832 = 63176; + e.afii10846 = 1241; + e.afii299 = 8206; + e.afii300 = 8207; + e.afii301 = 8205; + e.afii57381 = 1642; + e.afii57388 = 1548; + e.afii57392 = 1632; + e.afii57393 = 1633; + e.afii57394 = 1634; + e.afii57395 = 1635; + e.afii57396 = 1636; + e.afii57397 = 1637; + e.afii57398 = 1638; + e.afii57399 = 1639; + e.afii57400 = 1640; + e.afii57401 = 1641; + e.afii57403 = 1563; + e.afii57407 = 1567; + e.afii57409 = 1569; + e.afii57410 = 1570; + e.afii57411 = 1571; + e.afii57412 = 1572; + e.afii57413 = 1573; + e.afii57414 = 1574; + e.afii57415 = 1575; + e.afii57416 = 1576; + e.afii57417 = 1577; + e.afii57418 = 1578; + e.afii57419 = 1579; + e.afii57420 = 1580; + e.afii57421 = 1581; + e.afii57422 = 1582; + e.afii57423 = 1583; + e.afii57424 = 1584; + e.afii57425 = 1585; + e.afii57426 = 1586; + e.afii57427 = 1587; + e.afii57428 = 1588; + e.afii57429 = 1589; + e.afii57430 = 1590; + e.afii57431 = 1591; + e.afii57432 = 1592; + e.afii57433 = 1593; + e.afii57434 = 1594; + e.afii57440 = 1600; + e.afii57441 = 1601; + e.afii57442 = 1602; + e.afii57443 = 1603; + e.afii57444 = 1604; + e.afii57445 = 1605; + e.afii57446 = 1606; + e.afii57448 = 1608; + e.afii57449 = 1609; + e.afii57450 = 1610; + e.afii57451 = 1611; + e.afii57452 = 1612; + e.afii57453 = 1613; + e.afii57454 = 1614; + e.afii57455 = 1615; + e.afii57456 = 1616; + e.afii57457 = 1617; + e.afii57458 = 1618; + e.afii57470 = 1607; + e.afii57505 = 1700; + e.afii57506 = 1662; + e.afii57507 = 1670; + e.afii57508 = 1688; + e.afii57509 = 1711; + e.afii57511 = 1657; + e.afii57512 = 1672; + e.afii57513 = 1681; + e.afii57514 = 1722; + e.afii57519 = 1746; + e.afii57534 = 1749; + e.afii57636 = 8362; + e.afii57645 = 1470; + e.afii57658 = 1475; + e.afii57664 = 1488; + e.afii57665 = 1489; + e.afii57666 = 1490; + e.afii57667 = 1491; + e.afii57668 = 1492; + e.afii57669 = 1493; + e.afii57670 = 1494; + e.afii57671 = 1495; + e.afii57672 = 1496; + e.afii57673 = 1497; + e.afii57674 = 1498; + e.afii57675 = 1499; + e.afii57676 = 1500; + e.afii57677 = 1501; + e.afii57678 = 1502; + e.afii57679 = 1503; + e.afii57680 = 1504; + e.afii57681 = 1505; + e.afii57682 = 1506; + e.afii57683 = 1507; + e.afii57684 = 1508; + e.afii57685 = 1509; + e.afii57686 = 1510; + e.afii57687 = 1511; + e.afii57688 = 1512; + e.afii57689 = 1513; + e.afii57690 = 1514; + e.afii57694 = 64298; + e.afii57695 = 64299; + e.afii57700 = 64331; + e.afii57705 = 64287; + e.afii57716 = 1520; + e.afii57717 = 1521; + e.afii57718 = 1522; + e.afii57723 = 64309; + e.afii57793 = 1460; + e.afii57794 = 1461; + e.afii57795 = 1462; + e.afii57796 = 1467; + e.afii57797 = 1464; + e.afii57798 = 1463; + e.afii57799 = 1456; + e.afii57800 = 1458; + e.afii57801 = 1457; + e.afii57802 = 1459; + e.afii57803 = 1474; + e.afii57804 = 1473; + e.afii57806 = 1465; + e.afii57807 = 1468; + e.afii57839 = 1469; + e.afii57841 = 1471; + e.afii57842 = 1472; + e.afii57929 = 700; + e.afii61248 = 8453; + e.afii61289 = 8467; + e.afii61352 = 8470; + e.afii61573 = 8236; + e.afii61574 = 8237; + e.afii61575 = 8238; + e.afii61664 = 8204; + e.afii63167 = 1645; + e.afii64937 = 701; + e.agrave = 224; + e.agujarati = 2693; + e.agurmukhi = 2565; + e.ahiragana = 12354; + e.ahookabove = 7843; + e.aibengali = 2448; + e.aibopomofo = 12574; + e.aideva = 2320; + e.aiecyrillic = 1237; + e.aigujarati = 2704; + e.aigurmukhi = 2576; + e.aimatragurmukhi = 2632; + e.ainarabic = 1593; + e.ainfinalarabic = 65226; + e.aininitialarabic = 65227; + e.ainmedialarabic = 65228; + e.ainvertedbreve = 515; + e.aivowelsignbengali = 2504; + e.aivowelsigndeva = 2376; + e.aivowelsigngujarati = 2760; + e.akatakana = 12450; + e.akatakanahalfwidth = 65393; + e.akorean = 12623; + e.alef = 1488; + e.alefarabic = 1575; + e.alefdageshhebrew = 64304; + e.aleffinalarabic = 65166; + e.alefhamzaabovearabic = 1571; + e.alefhamzaabovefinalarabic = 65156; + e.alefhamzabelowarabic = 1573; + e.alefhamzabelowfinalarabic = 65160; + e.alefhebrew = 1488; + e.aleflamedhebrew = 64335; + e.alefmaddaabovearabic = 1570; + e.alefmaddaabovefinalarabic = 65154; + e.alefmaksuraarabic = 1609; + e.alefmaksurafinalarabic = 65264; + e.alefmaksurainitialarabic = 65267; + e.alefmaksuramedialarabic = 65268; + e.alefpatahhebrew = 64302; + e.alefqamatshebrew = 64303; + e.aleph = 8501; + e.allequal = 8780; + e.alpha = 945; + e.alphatonos = 940; + e.amacron = 257; + e.amonospace = 65345; + e.ampersand = 38; + e.ampersandmonospace = 65286; + e.ampersandsmall = 63270; + e.amsquare = 13250; + e.anbopomofo = 12578; + e.angbopomofo = 12580; + e.angbracketleft = 12296; + e.angbracketright = 12297; + e.angkhankhuthai = 3674; + e.angle = 8736; + e.anglebracketleft = 12296; + e.anglebracketleftvertical = 65087; + e.anglebracketright = 12297; + e.anglebracketrightvertical = 65088; + e.angleleft = 9001; + e.angleright = 9002; + e.angstrom = 8491; + e.anoteleia = 903; + e.anudattadeva = 2386; + e.anusvarabengali = 2434; + e.anusvaradeva = 2306; + e.anusvaragujarati = 2690; + e.aogonek = 261; + e.apaatosquare = 13056; + e.aparen = 9372; + e.apostrophearmenian = 1370; + e.apostrophemod = 700; + e.apple = 63743; + e.approaches = 8784; + e.approxequal = 8776; + e.approxequalorimage = 8786; + e.approximatelyequal = 8773; + e.araeaekorean = 12686; + e.araeakorean = 12685; + e.arc = 8978; + e.arighthalfring = 7834; + e.aring = 229; + e.aringacute = 507; + e.aringbelow = 7681; + e.arrowboth = 8596; + e.arrowdashdown = 8675; + e.arrowdashleft = 8672; + e.arrowdashright = 8674; + e.arrowdashup = 8673; + e.arrowdblboth = 8660; + e.arrowdbldown = 8659; + e.arrowdblleft = 8656; + e.arrowdblright = 8658; + e.arrowdblup = 8657; + e.arrowdown = 8595; + e.arrowdownleft = 8601; + e.arrowdownright = 8600; + e.arrowdownwhite = 8681; + e.arrowheaddownmod = 709; + e.arrowheadleftmod = 706; + e.arrowheadrightmod = 707; + e.arrowheadupmod = 708; + e.arrowhorizex = 63719; + e.arrowleft = 8592; + e.arrowleftdbl = 8656; + e.arrowleftdblstroke = 8653; + e.arrowleftoverright = 8646; + e.arrowleftwhite = 8678; + e.arrowright = 8594; + e.arrowrightdblstroke = 8655; + e.arrowrightheavy = 10142; + e.arrowrightoverleft = 8644; + e.arrowrightwhite = 8680; + e.arrowtableft = 8676; + e.arrowtabright = 8677; + e.arrowup = 8593; + e.arrowupdn = 8597; + e.arrowupdnbse = 8616; + e.arrowupdownbase = 8616; + e.arrowupleft = 8598; + e.arrowupleftofdown = 8645; + e.arrowupright = 8599; + e.arrowupwhite = 8679; + e.arrowvertex = 63718; + e.asciicircum = 94; + e.asciicircummonospace = 65342; + e.asciitilde = 126; + e.asciitildemonospace = 65374; + e.ascript = 593; + e.ascriptturned = 594; + e.asmallhiragana = 12353; + e.asmallkatakana = 12449; + e.asmallkatakanahalfwidth = 65383; + e.asterisk = 42; + e.asteriskaltonearabic = 1645; + e.asteriskarabic = 1645; + e.asteriskmath = 8727; + e.asteriskmonospace = 65290; + e.asterisksmall = 65121; + e.asterism = 8258; + e.asuperior = 63209; + e.asymptoticallyequal = 8771; + e.at = 64; + e.atilde = 227; + e.atmonospace = 65312; + e.atsmall = 65131; + e.aturned = 592; + e.aubengali = 2452; + e.aubopomofo = 12576; + e.audeva = 2324; + e.augujarati = 2708; + e.augurmukhi = 2580; + e.aulengthmarkbengali = 2519; + e.aumatragurmukhi = 2636; + e.auvowelsignbengali = 2508; + e.auvowelsigndeva = 2380; + e.auvowelsigngujarati = 2764; + e.avagrahadeva = 2365; + e.aybarmenian = 1377; + e.ayin = 1506; + e.ayinaltonehebrew = 64288; + e.ayinhebrew = 1506; + e.b = 98; + e.babengali = 2476; + e.backslash = 92; + e.backslashmonospace = 65340; + e.badeva = 2348; + e.bagujarati = 2732; + e.bagurmukhi = 2604; + e.bahiragana = 12400; + e.bahtthai = 3647; + e.bakatakana = 12496; + e.bar = 124; + e.barmonospace = 65372; + e.bbopomofo = 12549; + e.bcircle = 9425; + e.bdotaccent = 7683; + e.bdotbelow = 7685; + e.beamedsixteenthnotes = 9836; + e.because = 8757; + e.becyrillic = 1073; + e.beharabic = 1576; + e.behfinalarabic = 65168; + e.behinitialarabic = 65169; + e.behiragana = 12409; + e.behmedialarabic = 65170; + e.behmeeminitialarabic = 64671; + e.behmeemisolatedarabic = 64520; + e.behnoonfinalarabic = 64621; + e.bekatakana = 12505; + e.benarmenian = 1378; + e.bet = 1489; + e.beta = 946; + e.betasymbolgreek = 976; + e.betdagesh = 64305; + e.betdageshhebrew = 64305; + e.bethebrew = 1489; + e.betrafehebrew = 64332; + e.bhabengali = 2477; + e.bhadeva = 2349; + e.bhagujarati = 2733; + e.bhagurmukhi = 2605; + e.bhook = 595; + e.bihiragana = 12403; + e.bikatakana = 12499; + e.bilabialclick = 664; + e.bindigurmukhi = 2562; + e.birusquare = 13105; + e.blackcircle = 9679; + e.blackdiamond = 9670; + e.blackdownpointingtriangle = 9660; + e.blackleftpointingpointer = 9668; + e.blackleftpointingtriangle = 9664; + e.blacklenticularbracketleft = 12304; + e.blacklenticularbracketleftvertical = 65083; + e.blacklenticularbracketright = 12305; + e.blacklenticularbracketrightvertical = 65084; + e.blacklowerlefttriangle = 9699; + e.blacklowerrighttriangle = 9698; + e.blackrectangle = 9644; + e.blackrightpointingpointer = 9658; + e.blackrightpointingtriangle = 9654; + e.blacksmallsquare = 9642; + e.blacksmilingface = 9787; + e.blacksquare = 9632; + e.blackstar = 9733; + e.blackupperlefttriangle = 9700; + e.blackupperrighttriangle = 9701; + e.blackuppointingsmalltriangle = 9652; + e.blackuppointingtriangle = 9650; + e.blank = 9251; + e.blinebelow = 7687; + e.block = 9608; + e.bmonospace = 65346; + e.bobaimaithai = 3610; + e.bohiragana = 12412; + e.bokatakana = 12508; + e.bparen = 9373; + e.bqsquare = 13251; + e.braceex = 63732; + e.braceleft = 123; + e.braceleftbt = 63731; + e.braceleftmid = 63730; + e.braceleftmonospace = 65371; + e.braceleftsmall = 65115; + e.bracelefttp = 63729; + e.braceleftvertical = 65079; + e.braceright = 125; + e.bracerightbt = 63742; + e.bracerightmid = 63741; + e.bracerightmonospace = 65373; + e.bracerightsmall = 65116; + e.bracerighttp = 63740; + e.bracerightvertical = 65080; + e.bracketleft = 91; + e.bracketleftbt = 63728; + e.bracketleftex = 63727; + e.bracketleftmonospace = 65339; + e.bracketlefttp = 63726; + e.bracketright = 93; + e.bracketrightbt = 63739; + e.bracketrightex = 63738; + e.bracketrightmonospace = 65341; + e.bracketrighttp = 63737; + e.breve = 728; + e.brevebelowcmb = 814; + e.brevecmb = 774; + e.breveinvertedbelowcmb = 815; + e.breveinvertedcmb = 785; + e.breveinverteddoublecmb = 865; + e.bridgebelowcmb = 810; + e.bridgeinvertedbelowcmb = 826; + e.brokenbar = 166; + e.bstroke = 384; + e.bsuperior = 63210; + e.btopbar = 387; + e.buhiragana = 12406; + e.bukatakana = 12502; + e.bullet = 8226; + e.bulletinverse = 9688; + e.bulletoperator = 8729; + e.bullseye = 9678; + e.c = 99; + e.caarmenian = 1390; + e.cabengali = 2458; + e.cacute = 263; + e.cadeva = 2330; + e.cagujarati = 2714; + e.cagurmukhi = 2586; + e.calsquare = 13192; + e.candrabindubengali = 2433; + e.candrabinducmb = 784; + e.candrabindudeva = 2305; + e.candrabindugujarati = 2689; + e.capslock = 8682; + e.careof = 8453; + e.caron = 711; + e.caronbelowcmb = 812; + e.caroncmb = 780; + e.carriagereturn = 8629; + e.cbopomofo = 12568; + e.ccaron = 269; + e.ccedilla = 231; + e.ccedillaacute = 7689; + e.ccircle = 9426; + e.ccircumflex = 265; + e.ccurl = 597; + e.cdot = 267; + e.cdotaccent = 267; + e.cdsquare = 13253; + e.cedilla = 184; + e.cedillacmb = 807; + e.cent = 162; + e.centigrade = 8451; + e.centinferior = 63199; + e.centmonospace = 65504; + e.centoldstyle = 63394; + e.centsuperior = 63200; + e.chaarmenian = 1401; + e.chabengali = 2459; + e.chadeva = 2331; + e.chagujarati = 2715; + e.chagurmukhi = 2587; + e.chbopomofo = 12564; + e.cheabkhasiancyrillic = 1213; + e.checkmark = 10003; + e.checyrillic = 1095; + e.chedescenderabkhasiancyrillic = 1215; + e.chedescendercyrillic = 1207; + e.chedieresiscyrillic = 1269; + e.cheharmenian = 1395; + e.chekhakassiancyrillic = 1228; + e.cheverticalstrokecyrillic = 1209; + e.chi = 967; + e.chieuchacirclekorean = 12919; + e.chieuchaparenkorean = 12823; + e.chieuchcirclekorean = 12905; + e.chieuchkorean = 12618; + e.chieuchparenkorean = 12809; + e.chochangthai = 3594; + e.chochanthai = 3592; + e.chochingthai = 3593; + e.chochoethai = 3596; + e.chook = 392; + e.cieucacirclekorean = 12918; + e.cieucaparenkorean = 12822; + e.cieuccirclekorean = 12904; + e.cieuckorean = 12616; + e.cieucparenkorean = 12808; + e.cieucuparenkorean = 12828; + e.circle = 9675; + e.circlecopyrt = 169; + e.circlemultiply = 8855; + e.circleot = 8857; + e.circleplus = 8853; + e.circlepostalmark = 12342; + e.circlewithlefthalfblack = 9680; + e.circlewithrighthalfblack = 9681; + e.circumflex = 710; + e.circumflexbelowcmb = 813; + e.circumflexcmb = 770; + e.clear = 8999; + e.clickalveolar = 450; + e.clickdental = 448; + e.clicklateral = 449; + e.clickretroflex = 451; + e.club = 9827; + e.clubsuitblack = 9827; + e.clubsuitwhite = 9831; + e.cmcubedsquare = 13220; + e.cmonospace = 65347; + e.cmsquaredsquare = 13216; + e.coarmenian = 1409; + e.colon = 58; + e.colonmonetary = 8353; + e.colonmonospace = 65306; + e.colonsign = 8353; + e.colonsmall = 65109; + e.colontriangularhalfmod = 721; + e.colontriangularmod = 720; + e.comma = 44; + e.commaabovecmb = 787; + e.commaaboverightcmb = 789; + e.commaaccent = 63171; + e.commaarabic = 1548; + e.commaarmenian = 1373; + e.commainferior = 63201; + e.commamonospace = 65292; + e.commareversedabovecmb = 788; + e.commareversedmod = 701; + e.commasmall = 65104; + e.commasuperior = 63202; + e.commaturnedabovecmb = 786; + e.commaturnedmod = 699; + e.compass = 9788; + e.congruent = 8773; + e.contourintegral = 8750; + e.control = 8963; + e.controlACK = 6; + e.controlBEL = 7; + e.controlBS = 8; + e.controlCAN = 24; + e.controlCR = 13; + e.controlDC1 = 17; + e.controlDC2 = 18; + e.controlDC3 = 19; + e.controlDC4 = 20; + e.controlDEL = 127; + e.controlDLE = 16; + e.controlEM = 25; + e.controlENQ = 5; + e.controlEOT = 4; + e.controlESC = 27; + e.controlETB = 23; + e.controlETX = 3; + e.controlFF = 12; + e.controlFS = 28; + e.controlGS = 29; + e.controlHT = 9; + e.controlLF = 10; + e.controlNAK = 21; + e.controlNULL = 0; + e.controlRS = 30; + e.controlSI = 15; + e.controlSO = 14; + e.controlSOT = 2; + e.controlSTX = 1; + e.controlSUB = 26; + e.controlSYN = 22; + e.controlUS = 31; + e.controlVT = 11; + e.copyright = 169; + e.copyrightsans = 63721; + e.copyrightserif = 63193; + e.cornerbracketleft = 12300; + e.cornerbracketlefthalfwidth = 65378; + e.cornerbracketleftvertical = 65089; + e.cornerbracketright = 12301; + e.cornerbracketrighthalfwidth = 65379; + e.cornerbracketrightvertical = 65090; + e.corporationsquare = 13183; + e.cosquare = 13255; + e.coverkgsquare = 13254; + e.cparen = 9374; + e.cruzeiro = 8354; + e.cstretched = 663; + e.curlyand = 8911; + e.curlyor = 8910; + e.currency = 164; + e.cyrBreve = 63185; + e.cyrFlex = 63186; + e.cyrbreve = 63188; + e.cyrflex = 63189; + e.d = 100; + e.daarmenian = 1380; + e.dabengali = 2470; + e.dadarabic = 1590; + e.dadeva = 2342; + e.dadfinalarabic = 65214; + e.dadinitialarabic = 65215; + e.dadmedialarabic = 65216; + e.dagesh = 1468; + e.dageshhebrew = 1468; + e.dagger = 8224; + e.daggerdbl = 8225; + e.dagujarati = 2726; + e.dagurmukhi = 2598; + e.dahiragana = 12384; + e.dakatakana = 12480; + e.dalarabic = 1583; + e.dalet = 1491; + e.daletdagesh = 64307; + e.daletdageshhebrew = 64307; + e.dalethebrew = 1491; + e.dalfinalarabic = 65194; + e.dammaarabic = 1615; + e.dammalowarabic = 1615; + e.dammatanaltonearabic = 1612; + e.dammatanarabic = 1612; + e.danda = 2404; + e.dargahebrew = 1447; + e.dargalefthebrew = 1447; + e.dasiapneumatacyrilliccmb = 1157; + e.dblGrave = 63187; + e.dblanglebracketleft = 12298; + e.dblanglebracketleftvertical = 65085; + e.dblanglebracketright = 12299; + e.dblanglebracketrightvertical = 65086; + e.dblarchinvertedbelowcmb = 811; + e.dblarrowleft = 8660; + e.dblarrowright = 8658; + e.dbldanda = 2405; + e.dblgrave = 63190; + e.dblgravecmb = 783; + e.dblintegral = 8748; + e.dbllowline = 8215; + e.dbllowlinecmb = 819; + e.dbloverlinecmb = 831; + e.dblprimemod = 698; + e.dblverticalbar = 8214; + e.dblverticallineabovecmb = 782; + e.dbopomofo = 12553; + e.dbsquare = 13256; + e.dcaron = 271; + e.dcedilla = 7697; + e.dcircle = 9427; + e.dcircumflexbelow = 7699; + e.dcroat = 273; + e.ddabengali = 2465; + e.ddadeva = 2337; + e.ddagujarati = 2721; + e.ddagurmukhi = 2593; + e.ddalarabic = 1672; + e.ddalfinalarabic = 64393; + e.dddhadeva = 2396; + e.ddhabengali = 2466; + e.ddhadeva = 2338; + e.ddhagujarati = 2722; + e.ddhagurmukhi = 2594; + e.ddotaccent = 7691; + e.ddotbelow = 7693; + e.decimalseparatorarabic = 1643; + e.decimalseparatorpersian = 1643; + e.decyrillic = 1076; + e.degree = 176; + e.dehihebrew = 1453; + e.dehiragana = 12391; + e.deicoptic = 1007; + e.dekatakana = 12487; + e.deleteleft = 9003; + e.deleteright = 8998; + e.delta = 948; + e.deltaturned = 397; + e.denominatorminusonenumeratorbengali = 2552; + e.dezh = 676; + e.dhabengali = 2471; + e.dhadeva = 2343; + e.dhagujarati = 2727; + e.dhagurmukhi = 2599; + e.dhook = 599; + e.dialytikatonos = 901; + e.dialytikatonoscmb = 836; + e.diamond = 9830; + e.diamondsuitwhite = 9826; + e.dieresis = 168; + e.dieresisacute = 63191; + e.dieresisbelowcmb = 804; + e.dieresiscmb = 776; + e.dieresisgrave = 63192; + e.dieresistonos = 901; + e.dihiragana = 12386; + e.dikatakana = 12482; + e.dittomark = 12291; + e.divide = 247; + e.divides = 8739; + e.divisionslash = 8725; + e.djecyrillic = 1106; + e.dkshade = 9619; + e.dlinebelow = 7695; + e.dlsquare = 13207; + e.dmacron = 273; + e.dmonospace = 65348; + e.dnblock = 9604; + e.dochadathai = 3598; + e.dodekthai = 3604; + e.dohiragana = 12393; + e.dokatakana = 12489; + e.dollar = 36; + e.dollarinferior = 63203; + e.dollarmonospace = 65284; + e.dollaroldstyle = 63268; + e.dollarsmall = 65129; + e.dollarsuperior = 63204; + e.dong = 8363; + e.dorusquare = 13094; + e.dotaccent = 729; + e.dotaccentcmb = 775; + e.dotbelowcmb = 803; + e.dotbelowcomb = 803; + e.dotkatakana = 12539; + e.dotlessi = 305; + e.dotlessj = 63166; + e.dotlessjstrokehook = 644; + e.dotmath = 8901; + e.dottedcircle = 9676; + e.doubleyodpatah = 64287; + e.doubleyodpatahhebrew = 64287; + e.downtackbelowcmb = 798; + e.downtackmod = 725; + e.dparen = 9375; + e.dsuperior = 63211; + e.dtail = 598; + e.dtopbar = 396; + e.duhiragana = 12389; + e.dukatakana = 12485; + e.dz = 499; + e.dzaltone = 675; + e.dzcaron = 454; + e.dzcurl = 677; + e.dzeabkhasiancyrillic = 1249; + e.dzecyrillic = 1109; + e.dzhecyrillic = 1119; + e.e = 101; + e.eacute = 233; + e.earth = 9793; + e.ebengali = 2447; + e.ebopomofo = 12572; + e.ebreve = 277; + e.ecandradeva = 2317; + e.ecandragujarati = 2701; + e.ecandravowelsigndeva = 2373; + e.ecandravowelsigngujarati = 2757; + e.ecaron = 283; + e.ecedillabreve = 7709; + e.echarmenian = 1381; + e.echyiwnarmenian = 1415; + e.ecircle = 9428; + e.ecircumflex = 234; + e.ecircumflexacute = 7871; + e.ecircumflexbelow = 7705; + e.ecircumflexdotbelow = 7879; + e.ecircumflexgrave = 7873; + e.ecircumflexhookabove = 7875; + e.ecircumflextilde = 7877; + e.ecyrillic = 1108; + e.edblgrave = 517; + e.edeva = 2319; + e.edieresis = 235; + e.edot = 279; + e.edotaccent = 279; + e.edotbelow = 7865; + e.eegurmukhi = 2575; + e.eematragurmukhi = 2631; + e.efcyrillic = 1092; + e.egrave = 232; + e.egujarati = 2703; + e.eharmenian = 1383; + e.ehbopomofo = 12573; + e.ehiragana = 12360; + e.ehookabove = 7867; + e.eibopomofo = 12575; + e.eight = 56; + e.eightarabic = 1640; + e.eightbengali = 2542; + e.eightcircle = 9319; + e.eightcircleinversesansserif = 10129; + e.eightdeva = 2414; + e.eighteencircle = 9329; + e.eighteenparen = 9349; + e.eighteenperiod = 9369; + e.eightgujarati = 2798; + e.eightgurmukhi = 2670; + e.eighthackarabic = 1640; + e.eighthangzhou = 12328; + e.eighthnotebeamed = 9835; + e.eightideographicparen = 12839; + e.eightinferior = 8328; + e.eightmonospace = 65304; + e.eightoldstyle = 63288; + e.eightparen = 9339; + e.eightperiod = 9359; + e.eightpersian = 1784; + e.eightroman = 8567; + e.eightsuperior = 8312; + e.eightthai = 3672; + e.einvertedbreve = 519; + e.eiotifiedcyrillic = 1125; + e.ekatakana = 12456; + e.ekatakanahalfwidth = 65396; + e.ekonkargurmukhi = 2676; + e.ekorean = 12628; + e.elcyrillic = 1083; + e.element = 8712; + e.elevencircle = 9322; + e.elevenparen = 9342; + e.elevenperiod = 9362; + e.elevenroman = 8570; + e.ellipsis = 8230; + e.ellipsisvertical = 8942; + e.emacron = 275; + e.emacronacute = 7703; + e.emacrongrave = 7701; + e.emcyrillic = 1084; + e.emdash = 8212; + e.emdashvertical = 65073; + e.emonospace = 65349; + e.emphasismarkarmenian = 1371; + e.emptyset = 8709; + e.enbopomofo = 12579; + e.encyrillic = 1085; + e.endash = 8211; + e.endashvertical = 65074; + e.endescendercyrillic = 1187; + e.eng = 331; + e.engbopomofo = 12581; + e.enghecyrillic = 1189; + e.enhookcyrillic = 1224; + e.enspace = 8194; + e.eogonek = 281; + e.eokorean = 12627; + e.eopen = 603; + e.eopenclosed = 666; + e.eopenreversed = 604; + e.eopenreversedclosed = 606; + e.eopenreversedhook = 605; + e.eparen = 9376; + e.epsilon = 949; + e.epsilontonos = 941; + e.equal = 61; + e.equalmonospace = 65309; + e.equalsmall = 65126; + e.equalsuperior = 8316; + e.equivalence = 8801; + e.erbopomofo = 12582; + e.ercyrillic = 1088; + e.ereversed = 600; + e.ereversedcyrillic = 1101; + e.escyrillic = 1089; + e.esdescendercyrillic = 1195; + e.esh = 643; + e.eshcurl = 646; + e.eshortdeva = 2318; + e.eshortvowelsigndeva = 2374; + e.eshreversedloop = 426; + e.eshsquatreversed = 645; + e.esmallhiragana = 12359; + e.esmallkatakana = 12455; + e.esmallkatakanahalfwidth = 65386; + e.estimated = 8494; + e.esuperior = 63212; + e.eta = 951; + e.etarmenian = 1384; + e.etatonos = 942; + e.eth = 240; + e.etilde = 7869; + e.etildebelow = 7707; + e.etnahtafoukhhebrew = 1425; + e.etnahtafoukhlefthebrew = 1425; + e.etnahtahebrew = 1425; + e.etnahtalefthebrew = 1425; + e.eturned = 477; + e.eukorean = 12641; + e.euro = 8364; + e.evowelsignbengali = 2503; + e.evowelsigndeva = 2375; + e.evowelsigngujarati = 2759; + e.exclam = 33; + e.exclamarmenian = 1372; + e.exclamdbl = 8252; + e.exclamdown = 161; + e.exclamdownsmall = 63393; + e.exclammonospace = 65281; + e.exclamsmall = 63265; + e.existential = 8707; + e.ezh = 658; + e.ezhcaron = 495; + e.ezhcurl = 659; + e.ezhreversed = 441; + e.ezhtail = 442; + e.f = 102; + e.fadeva = 2398; + e.fagurmukhi = 2654; + e.fahrenheit = 8457; + e.fathaarabic = 1614; + e.fathalowarabic = 1614; + e.fathatanarabic = 1611; + e.fbopomofo = 12552; + e.fcircle = 9429; + e.fdotaccent = 7711; + e.feharabic = 1601; + e.feharmenian = 1414; + e.fehfinalarabic = 65234; + e.fehinitialarabic = 65235; + e.fehmedialarabic = 65236; + e.feicoptic = 997; + e.female = 9792; + e.ff = 64256; + e.f_f = 64256; + e.ffi = 64259; + e.f_f_i = 64259; + e.ffl = 64260; + e.f_f_l = 64260; + e.fi = 64257; + e.f_i = 64257; + e.fifteencircle = 9326; + e.fifteenparen = 9346; + e.fifteenperiod = 9366; + e.figuredash = 8210; + e.filledbox = 9632; + e.filledrect = 9644; + e.finalkaf = 1498; + e.finalkafdagesh = 64314; + e.finalkafdageshhebrew = 64314; + e.finalkafhebrew = 1498; + e.finalmem = 1501; + e.finalmemhebrew = 1501; + e.finalnun = 1503; + e.finalnunhebrew = 1503; + e.finalpe = 1507; + e.finalpehebrew = 1507; + e.finaltsadi = 1509; + e.finaltsadihebrew = 1509; + e.firsttonechinese = 713; + e.fisheye = 9673; + e.fitacyrillic = 1139; + e.five = 53; + e.fivearabic = 1637; + e.fivebengali = 2539; + e.fivecircle = 9316; + e.fivecircleinversesansserif = 10126; + e.fivedeva = 2411; + e.fiveeighths = 8541; + e.fivegujarati = 2795; + e.fivegurmukhi = 2667; + e.fivehackarabic = 1637; + e.fivehangzhou = 12325; + e.fiveideographicparen = 12836; + e.fiveinferior = 8325; + e.fivemonospace = 65301; + e.fiveoldstyle = 63285; + e.fiveparen = 9336; + e.fiveperiod = 9356; + e.fivepersian = 1781; + e.fiveroman = 8564; + e.fivesuperior = 8309; + e.fivethai = 3669; + e.fl = 64258; + e.f_l = 64258; + e.florin = 402; + e.fmonospace = 65350; + e.fmsquare = 13209; + e.fofanthai = 3615; + e.fofathai = 3613; + e.fongmanthai = 3663; + e.forall = 8704; + e.four = 52; + e.fourarabic = 1636; + e.fourbengali = 2538; + e.fourcircle = 9315; + e.fourcircleinversesansserif = 10125; + e.fourdeva = 2410; + e.fourgujarati = 2794; + e.fourgurmukhi = 2666; + e.fourhackarabic = 1636; + e.fourhangzhou = 12324; + e.fourideographicparen = 12835; + e.fourinferior = 8324; + e.fourmonospace = 65300; + e.fournumeratorbengali = 2551; + e.fouroldstyle = 63284; + e.fourparen = 9335; + e.fourperiod = 9355; + e.fourpersian = 1780; + e.fourroman = 8563; + e.foursuperior = 8308; + e.fourteencircle = 9325; + e.fourteenparen = 9345; + e.fourteenperiod = 9365; + e.fourthai = 3668; + e.fourthtonechinese = 715; + e.fparen = 9377; + e.fraction = 8260; + e.franc = 8355; + e.g = 103; + e.gabengali = 2455; + e.gacute = 501; + e.gadeva = 2327; + e.gafarabic = 1711; + e.gaffinalarabic = 64403; + e.gafinitialarabic = 64404; + e.gafmedialarabic = 64405; + e.gagujarati = 2711; + e.gagurmukhi = 2583; + e.gahiragana = 12364; + e.gakatakana = 12460; + e.gamma = 947; + e.gammalatinsmall = 611; + e.gammasuperior = 736; + e.gangiacoptic = 1003; + e.gbopomofo = 12557; + e.gbreve = 287; + e.gcaron = 487; + e.gcedilla = 291; + e.gcircle = 9430; + e.gcircumflex = 285; + e.gcommaaccent = 291; + e.gdot = 289; + e.gdotaccent = 289; + e.gecyrillic = 1075; + e.gehiragana = 12370; + e.gekatakana = 12466; + e.geometricallyequal = 8785; + e.gereshaccenthebrew = 1436; + e.gereshhebrew = 1523; + e.gereshmuqdamhebrew = 1437; + e.germandbls = 223; + e.gershayimaccenthebrew = 1438; + e.gershayimhebrew = 1524; + e.getamark = 12307; + e.ghabengali = 2456; + e.ghadarmenian = 1394; + e.ghadeva = 2328; + e.ghagujarati = 2712; + e.ghagurmukhi = 2584; + e.ghainarabic = 1594; + e.ghainfinalarabic = 65230; + e.ghaininitialarabic = 65231; + e.ghainmedialarabic = 65232; + e.ghemiddlehookcyrillic = 1173; + e.ghestrokecyrillic = 1171; + e.gheupturncyrillic = 1169; + e.ghhadeva = 2394; + e.ghhagurmukhi = 2650; + e.ghook = 608; + e.ghzsquare = 13203; + e.gihiragana = 12366; + e.gikatakana = 12462; + e.gimarmenian = 1379; + e.gimel = 1490; + e.gimeldagesh = 64306; + e.gimeldageshhebrew = 64306; + e.gimelhebrew = 1490; + e.gjecyrillic = 1107; + e.glottalinvertedstroke = 446; + e.glottalstop = 660; + e.glottalstopinverted = 662; + e.glottalstopmod = 704; + e.glottalstopreversed = 661; + e.glottalstopreversedmod = 705; + e.glottalstopreversedsuperior = 740; + e.glottalstopstroke = 673; + e.glottalstopstrokereversed = 674; + e.gmacron = 7713; + e.gmonospace = 65351; + e.gohiragana = 12372; + e.gokatakana = 12468; + e.gparen = 9378; + e.gpasquare = 13228; + e.gradient = 8711; + e.grave = 96; + e.gravebelowcmb = 790; + e.gravecmb = 768; + e.gravecomb = 768; + e.gravedeva = 2387; + e.gravelowmod = 718; + e.gravemonospace = 65344; + e.gravetonecmb = 832; + e.greater = 62; + e.greaterequal = 8805; + e.greaterequalorless = 8923; + e.greatermonospace = 65310; + e.greaterorequivalent = 8819; + e.greaterorless = 8823; + e.greateroverequal = 8807; + e.greatersmall = 65125; + e.gscript = 609; + e.gstroke = 485; + e.guhiragana = 12368; + e.guillemotleft = 171; + e.guillemotright = 187; + e.guilsinglleft = 8249; + e.guilsinglright = 8250; + e.gukatakana = 12464; + e.guramusquare = 13080; + e.gysquare = 13257; + e.h = 104; + e.haabkhasiancyrillic = 1193; + e.haaltonearabic = 1729; + e.habengali = 2489; + e.hadescendercyrillic = 1203; + e.hadeva = 2361; + e.hagujarati = 2745; + e.hagurmukhi = 2617; + e.haharabic = 1581; + e.hahfinalarabic = 65186; + e.hahinitialarabic = 65187; + e.hahiragana = 12399; + e.hahmedialarabic = 65188; + e.haitusquare = 13098; + e.hakatakana = 12495; + e.hakatakanahalfwidth = 65418; + e.halantgurmukhi = 2637; + e.hamzaarabic = 1569; + e.hamzalowarabic = 1569; + e.hangulfiller = 12644; + e.hardsigncyrillic = 1098; + e.harpoonleftbarbup = 8636; + e.harpoonrightbarbup = 8640; + e.hasquare = 13258; + e.hatafpatah = 1458; + e.hatafpatah16 = 1458; + e.hatafpatah23 = 1458; + e.hatafpatah2f = 1458; + e.hatafpatahhebrew = 1458; + e.hatafpatahnarrowhebrew = 1458; + e.hatafpatahquarterhebrew = 1458; + e.hatafpatahwidehebrew = 1458; + e.hatafqamats = 1459; + e.hatafqamats1b = 1459; + e.hatafqamats28 = 1459; + e.hatafqamats34 = 1459; + e.hatafqamatshebrew = 1459; + e.hatafqamatsnarrowhebrew = 1459; + e.hatafqamatsquarterhebrew = 1459; + e.hatafqamatswidehebrew = 1459; + e.hatafsegol = 1457; + e.hatafsegol17 = 1457; + e.hatafsegol24 = 1457; + e.hatafsegol30 = 1457; + e.hatafsegolhebrew = 1457; + e.hatafsegolnarrowhebrew = 1457; + e.hatafsegolquarterhebrew = 1457; + e.hatafsegolwidehebrew = 1457; + e.hbar = 295; + e.hbopomofo = 12559; + e.hbrevebelow = 7723; + e.hcedilla = 7721; + e.hcircle = 9431; + e.hcircumflex = 293; + e.hdieresis = 7719; + e.hdotaccent = 7715; + e.hdotbelow = 7717; + e.he = 1492; + e.heart = 9829; + e.heartsuitblack = 9829; + e.heartsuitwhite = 9825; + e.hedagesh = 64308; + e.hedageshhebrew = 64308; + e.hehaltonearabic = 1729; + e.heharabic = 1607; + e.hehebrew = 1492; + e.hehfinalaltonearabic = 64423; + e.hehfinalalttwoarabic = 65258; + e.hehfinalarabic = 65258; + e.hehhamzaabovefinalarabic = 64421; + e.hehhamzaaboveisolatedarabic = 64420; + e.hehinitialaltonearabic = 64424; + e.hehinitialarabic = 65259; + e.hehiragana = 12408; + e.hehmedialaltonearabic = 64425; + e.hehmedialarabic = 65260; + e.heiseierasquare = 13179; + e.hekatakana = 12504; + e.hekatakanahalfwidth = 65421; + e.hekutaarusquare = 13110; + e.henghook = 615; + e.herutusquare = 13113; + e.het = 1495; + e.hethebrew = 1495; + e.hhook = 614; + e.hhooksuperior = 689; + e.hieuhacirclekorean = 12923; + e.hieuhaparenkorean = 12827; + e.hieuhcirclekorean = 12909; + e.hieuhkorean = 12622; + e.hieuhparenkorean = 12813; + e.hihiragana = 12402; + e.hikatakana = 12498; + e.hikatakanahalfwidth = 65419; + e.hiriq = 1460; + e.hiriq14 = 1460; + e.hiriq21 = 1460; + e.hiriq2d = 1460; + e.hiriqhebrew = 1460; + e.hiriqnarrowhebrew = 1460; + e.hiriqquarterhebrew = 1460; + e.hiriqwidehebrew = 1460; + e.hlinebelow = 7830; + e.hmonospace = 65352; + e.hoarmenian = 1392; + e.hohipthai = 3627; + e.hohiragana = 12411; + e.hokatakana = 12507; + e.hokatakanahalfwidth = 65422; + e.holam = 1465; + e.holam19 = 1465; + e.holam26 = 1465; + e.holam32 = 1465; + e.holamhebrew = 1465; + e.holamnarrowhebrew = 1465; + e.holamquarterhebrew = 1465; + e.holamwidehebrew = 1465; + e.honokhukthai = 3630; + e.hookabovecomb = 777; + e.hookcmb = 777; + e.hookpalatalizedbelowcmb = 801; + e.hookretroflexbelowcmb = 802; + e.hoonsquare = 13122; + e.horicoptic = 1001; + e.horizontalbar = 8213; + e.horncmb = 795; + e.hotsprings = 9832; + e.house = 8962; + e.hparen = 9379; + e.hsuperior = 688; + e.hturned = 613; + e.huhiragana = 12405; + e.huiitosquare = 13107; + e.hukatakana = 12501; + e.hukatakanahalfwidth = 65420; + e.hungarumlaut = 733; + e.hungarumlautcmb = 779; + e.hv = 405; + e.hyphen = 45; + e.hypheninferior = 63205; + e.hyphenmonospace = 65293; + e.hyphensmall = 65123; + e.hyphensuperior = 63206; + e.hyphentwo = 8208; + e.i = 105; + e.iacute = 237; + e.iacyrillic = 1103; + e.ibengali = 2439; + e.ibopomofo = 12583; + e.ibreve = 301; + e.icaron = 464; + e.icircle = 9432; + e.icircumflex = 238; + e.icyrillic = 1110; + e.idblgrave = 521; + e.ideographearthcircle = 12943; + e.ideographfirecircle = 12939; + e.ideographicallianceparen = 12863; + e.ideographiccallparen = 12858; + e.ideographiccentrecircle = 12965; + e.ideographicclose = 12294; + e.ideographiccomma = 12289; + e.ideographiccommaleft = 65380; + e.ideographiccongratulationparen = 12855; + e.ideographiccorrectcircle = 12963; + e.ideographicearthparen = 12847; + e.ideographicenterpriseparen = 12861; + e.ideographicexcellentcircle = 12957; + e.ideographicfestivalparen = 12864; + e.ideographicfinancialcircle = 12950; + e.ideographicfinancialparen = 12854; + e.ideographicfireparen = 12843; + e.ideographichaveparen = 12850; + e.ideographichighcircle = 12964; + e.ideographiciterationmark = 12293; + e.ideographiclaborcircle = 12952; + e.ideographiclaborparen = 12856; + e.ideographicleftcircle = 12967; + e.ideographiclowcircle = 12966; + e.ideographicmedicinecircle = 12969; + e.ideographicmetalparen = 12846; + e.ideographicmoonparen = 12842; + e.ideographicnameparen = 12852; + e.ideographicperiod = 12290; + e.ideographicprintcircle = 12958; + e.ideographicreachparen = 12867; + e.ideographicrepresentparen = 12857; + e.ideographicresourceparen = 12862; + e.ideographicrightcircle = 12968; + e.ideographicsecretcircle = 12953; + e.ideographicselfparen = 12866; + e.ideographicsocietyparen = 12851; + e.ideographicspace = 12288; + e.ideographicspecialparen = 12853; + e.ideographicstockparen = 12849; + e.ideographicstudyparen = 12859; + e.ideographicsunparen = 12848; + e.ideographicsuperviseparen = 12860; + e.ideographicwaterparen = 12844; + e.ideographicwoodparen = 12845; + e.ideographiczero = 12295; + e.ideographmetalcircle = 12942; + e.ideographmooncircle = 12938; + e.ideographnamecircle = 12948; + e.ideographsuncircle = 12944; + e.ideographwatercircle = 12940; + e.ideographwoodcircle = 12941; + e.ideva = 2311; + e.idieresis = 239; + e.idieresisacute = 7727; + e.idieresiscyrillic = 1253; + e.idotbelow = 7883; + e.iebrevecyrillic = 1239; + e.iecyrillic = 1077; + e.ieungacirclekorean = 12917; + e.ieungaparenkorean = 12821; + e.ieungcirclekorean = 12903; + e.ieungkorean = 12615; + e.ieungparenkorean = 12807; + e.igrave = 236; + e.igujarati = 2695; + e.igurmukhi = 2567; + e.ihiragana = 12356; + e.ihookabove = 7881; + e.iibengali = 2440; + e.iicyrillic = 1080; + e.iideva = 2312; + e.iigujarati = 2696; + e.iigurmukhi = 2568; + e.iimatragurmukhi = 2624; + e.iinvertedbreve = 523; + e.iishortcyrillic = 1081; + e.iivowelsignbengali = 2496; + e.iivowelsigndeva = 2368; + e.iivowelsigngujarati = 2752; + e.ij = 307; + e.ikatakana = 12452; + e.ikatakanahalfwidth = 65394; + e.ikorean = 12643; + e.ilde = 732; + e.iluyhebrew = 1452; + e.imacron = 299; + e.imacroncyrillic = 1251; + e.imageorapproximatelyequal = 8787; + e.imatragurmukhi = 2623; + e.imonospace = 65353; + e.increment = 8710; + e.infinity = 8734; + e.iniarmenian = 1387; + e.integral = 8747; + e.integralbottom = 8993; + e.integralbt = 8993; + e.integralex = 63733; + e.integraltop = 8992; + e.integraltp = 8992; + e.intersection = 8745; + e.intisquare = 13061; + e.invbullet = 9688; + e.invcircle = 9689; + e.invsmileface = 9787; + e.iocyrillic = 1105; + e.iogonek = 303; + e.iota = 953; + e.iotadieresis = 970; + e.iotadieresistonos = 912; + e.iotalatin = 617; + e.iotatonos = 943; + e.iparen = 9380; + e.irigurmukhi = 2674; + e.ismallhiragana = 12355; + e.ismallkatakana = 12451; + e.ismallkatakanahalfwidth = 65384; + e.issharbengali = 2554; + e.istroke = 616; + e.isuperior = 63213; + e.iterationhiragana = 12445; + e.iterationkatakana = 12541; + e.itilde = 297; + e.itildebelow = 7725; + e.iubopomofo = 12585; + e.iucyrillic = 1102; + e.ivowelsignbengali = 2495; + e.ivowelsigndeva = 2367; + e.ivowelsigngujarati = 2751; + e.izhitsacyrillic = 1141; + e.izhitsadblgravecyrillic = 1143; + e.j = 106; + e.jaarmenian = 1393; + e.jabengali = 2460; + e.jadeva = 2332; + e.jagujarati = 2716; + e.jagurmukhi = 2588; + e.jbopomofo = 12560; + e.jcaron = 496; + e.jcircle = 9433; + e.jcircumflex = 309; + e.jcrossedtail = 669; + e.jdotlessstroke = 607; + e.jecyrillic = 1112; + e.jeemarabic = 1580; + e.jeemfinalarabic = 65182; + e.jeeminitialarabic = 65183; + e.jeemmedialarabic = 65184; + e.jeharabic = 1688; + e.jehfinalarabic = 64395; + e.jhabengali = 2461; + e.jhadeva = 2333; + e.jhagujarati = 2717; + e.jhagurmukhi = 2589; + e.jheharmenian = 1403; + e.jis = 12292; + e.jmonospace = 65354; + e.jparen = 9381; + e.jsuperior = 690; + e.k = 107; + e.kabashkircyrillic = 1185; + e.kabengali = 2453; + e.kacute = 7729; + e.kacyrillic = 1082; + e.kadescendercyrillic = 1179; + e.kadeva = 2325; + e.kaf = 1499; + e.kafarabic = 1603; + e.kafdagesh = 64315; + e.kafdageshhebrew = 64315; + e.kaffinalarabic = 65242; + e.kafhebrew = 1499; + e.kafinitialarabic = 65243; + e.kafmedialarabic = 65244; + e.kafrafehebrew = 64333; + e.kagujarati = 2709; + e.kagurmukhi = 2581; + e.kahiragana = 12363; + e.kahookcyrillic = 1220; + e.kakatakana = 12459; + e.kakatakanahalfwidth = 65398; + e.kappa = 954; + e.kappasymbolgreek = 1008; + e.kapyeounmieumkorean = 12657; + e.kapyeounphieuphkorean = 12676; + e.kapyeounpieupkorean = 12664; + e.kapyeounssangpieupkorean = 12665; + e.karoriisquare = 13069; + e.kashidaautoarabic = 1600; + e.kashidaautonosidebearingarabic = 1600; + e.kasmallkatakana = 12533; + e.kasquare = 13188; + e.kasraarabic = 1616; + e.kasratanarabic = 1613; + e.kastrokecyrillic = 1183; + e.katahiraprolongmarkhalfwidth = 65392; + e.kaverticalstrokecyrillic = 1181; + e.kbopomofo = 12558; + e.kcalsquare = 13193; + e.kcaron = 489; + e.kcedilla = 311; + e.kcircle = 9434; + e.kcommaaccent = 311; + e.kdotbelow = 7731; + e.keharmenian = 1412; + e.kehiragana = 12369; + e.kekatakana = 12465; + e.kekatakanahalfwidth = 65401; + e.kenarmenian = 1391; + e.kesmallkatakana = 12534; + e.kgreenlandic = 312; + e.khabengali = 2454; + e.khacyrillic = 1093; + e.khadeva = 2326; + e.khagujarati = 2710; + e.khagurmukhi = 2582; + e.khaharabic = 1582; + e.khahfinalarabic = 65190; + e.khahinitialarabic = 65191; + e.khahmedialarabic = 65192; + e.kheicoptic = 999; + e.khhadeva = 2393; + e.khhagurmukhi = 2649; + e.khieukhacirclekorean = 12920; + e.khieukhaparenkorean = 12824; + e.khieukhcirclekorean = 12906; + e.khieukhkorean = 12619; + e.khieukhparenkorean = 12810; + e.khokhaithai = 3586; + e.khokhonthai = 3589; + e.khokhuatthai = 3587; + e.khokhwaithai = 3588; + e.khomutthai = 3675; + e.khook = 409; + e.khorakhangthai = 3590; + e.khzsquare = 13201; + e.kihiragana = 12365; + e.kikatakana = 12461; + e.kikatakanahalfwidth = 65399; + e.kiroguramusquare = 13077; + e.kiromeetorusquare = 13078; + e.kirosquare = 13076; + e.kiyeokacirclekorean = 12910; + e.kiyeokaparenkorean = 12814; + e.kiyeokcirclekorean = 12896; + e.kiyeokkorean = 12593; + e.kiyeokparenkorean = 12800; + e.kiyeoksioskorean = 12595; + e.kjecyrillic = 1116; + e.klinebelow = 7733; + e.klsquare = 13208; + e.kmcubedsquare = 13222; + e.kmonospace = 65355; + e.kmsquaredsquare = 13218; + e.kohiragana = 12371; + e.kohmsquare = 13248; + e.kokaithai = 3585; + e.kokatakana = 12467; + e.kokatakanahalfwidth = 65402; + e.kooposquare = 13086; + e.koppacyrillic = 1153; + e.koreanstandardsymbol = 12927; + e.koroniscmb = 835; + e.kparen = 9382; + e.kpasquare = 13226; + e.ksicyrillic = 1135; + e.ktsquare = 13263; + e.kturned = 670; + e.kuhiragana = 12367; + e.kukatakana = 12463; + e.kukatakanahalfwidth = 65400; + e.kvsquare = 13240; + e.kwsquare = 13246; + e.l = 108; + e.labengali = 2482; + e.lacute = 314; + e.ladeva = 2354; + e.lagujarati = 2738; + e.lagurmukhi = 2610; + e.lakkhangyaothai = 3653; + e.lamaleffinalarabic = 65276; + e.lamalefhamzaabovefinalarabic = 65272; + e.lamalefhamzaaboveisolatedarabic = 65271; + e.lamalefhamzabelowfinalarabic = 65274; + e.lamalefhamzabelowisolatedarabic = 65273; + e.lamalefisolatedarabic = 65275; + e.lamalefmaddaabovefinalarabic = 65270; + e.lamalefmaddaaboveisolatedarabic = 65269; + e.lamarabic = 1604; + e.lambda = 955; + e.lambdastroke = 411; + e.lamed = 1500; + e.lameddagesh = 64316; + e.lameddageshhebrew = 64316; + e.lamedhebrew = 1500; + e.lamfinalarabic = 65246; + e.lamhahinitialarabic = 64714; + e.laminitialarabic = 65247; + e.lamjeeminitialarabic = 64713; + e.lamkhahinitialarabic = 64715; + e.lamlamhehisolatedarabic = 65010; + e.lammedialarabic = 65248; + e.lammeemhahinitialarabic = 64904; + e.lammeeminitialarabic = 64716; + e.largecircle = 9711; + e.lbar = 410; + e.lbelt = 620; + e.lbopomofo = 12556; + e.lcaron = 318; + e.lcedilla = 316; + e.lcircle = 9435; + e.lcircumflexbelow = 7741; + e.lcommaaccent = 316; + e.ldot = 320; + e.ldotaccent = 320; + e.ldotbelow = 7735; + e.ldotbelowmacron = 7737; + e.leftangleabovecmb = 794; + e.lefttackbelowcmb = 792; + e.less = 60; + e.lessequal = 8804; + e.lessequalorgreater = 8922; + e.lessmonospace = 65308; + e.lessorequivalent = 8818; + e.lessorgreater = 8822; + e.lessoverequal = 8806; + e.lesssmall = 65124; + e.lezh = 622; + e.lfblock = 9612; + e.lhookretroflex = 621; + e.lira = 8356; + e.liwnarmenian = 1388; + e.lj = 457; + e.ljecyrillic = 1113; + e.ll = 63168; + e.lladeva = 2355; + e.llagujarati = 2739; + e.llinebelow = 7739; + e.llladeva = 2356; + e.llvocalicbengali = 2529; + e.llvocalicdeva = 2401; + e.llvocalicvowelsignbengali = 2531; + e.llvocalicvowelsigndeva = 2403; + e.lmiddletilde = 619; + e.lmonospace = 65356; + e.lmsquare = 13264; + e.lochulathai = 3628; + e.logicaland = 8743; + e.logicalnot = 172; + e.logicalnotreversed = 8976; + e.logicalor = 8744; + e.lolingthai = 3621; + e.longs = 383; + e.lowlinecenterline = 65102; + e.lowlinecmb = 818; + e.lowlinedashed = 65101; + e.lozenge = 9674; + e.lparen = 9383; + e.lslash = 322; + e.lsquare = 8467; + e.lsuperior = 63214; + e.ltshade = 9617; + e.luthai = 3622; + e.lvocalicbengali = 2444; + e.lvocalicdeva = 2316; + e.lvocalicvowelsignbengali = 2530; + e.lvocalicvowelsigndeva = 2402; + e.lxsquare = 13267; + e.m = 109; + e.mabengali = 2478; + e.macron = 175; + e.macronbelowcmb = 817; + e.macroncmb = 772; + e.macronlowmod = 717; + e.macronmonospace = 65507; + e.macute = 7743; + e.madeva = 2350; + e.magujarati = 2734; + e.magurmukhi = 2606; + e.mahapakhhebrew = 1444; + e.mahapakhlefthebrew = 1444; + e.mahiragana = 12414; + e.maichattawalowleftthai = 63637; + e.maichattawalowrightthai = 63636; + e.maichattawathai = 3659; + e.maichattawaupperleftthai = 63635; + e.maieklowleftthai = 63628; + e.maieklowrightthai = 63627; + e.maiekthai = 3656; + e.maiekupperleftthai = 63626; + e.maihanakatleftthai = 63620; + e.maihanakatthai = 3633; + e.maitaikhuleftthai = 63625; + e.maitaikhuthai = 3655; + e.maitholowleftthai = 63631; + e.maitholowrightthai = 63630; + e.maithothai = 3657; + e.maithoupperleftthai = 63629; + e.maitrilowleftthai = 63634; + e.maitrilowrightthai = 63633; + e.maitrithai = 3658; + e.maitriupperleftthai = 63632; + e.maiyamokthai = 3654; + e.makatakana = 12510; + e.makatakanahalfwidth = 65423; + e.male = 9794; + e.mansyonsquare = 13127; + e.maqafhebrew = 1470; + e.mars = 9794; + e.masoracirclehebrew = 1455; + e.masquare = 13187; + e.mbopomofo = 12551; + e.mbsquare = 13268; + e.mcircle = 9436; + e.mcubedsquare = 13221; + e.mdotaccent = 7745; + e.mdotbelow = 7747; + e.meemarabic = 1605; + e.meemfinalarabic = 65250; + e.meeminitialarabic = 65251; + e.meemmedialarabic = 65252; + e.meemmeeminitialarabic = 64721; + e.meemmeemisolatedarabic = 64584; + e.meetorusquare = 13133; + e.mehiragana = 12417; + e.meizierasquare = 13182; + e.mekatakana = 12513; + e.mekatakanahalfwidth = 65426; + e.mem = 1502; + e.memdagesh = 64318; + e.memdageshhebrew = 64318; + e.memhebrew = 1502; + e.menarmenian = 1396; + e.merkhahebrew = 1445; + e.merkhakefulahebrew = 1446; + e.merkhakefulalefthebrew = 1446; + e.merkhalefthebrew = 1445; + e.mhook = 625; + e.mhzsquare = 13202; + e.middledotkatakanahalfwidth = 65381; + e.middot = 183; + e.mieumacirclekorean = 12914; + e.mieumaparenkorean = 12818; + e.mieumcirclekorean = 12900; + e.mieumkorean = 12609; + e.mieumpansioskorean = 12656; + e.mieumparenkorean = 12804; + e.mieumpieupkorean = 12654; + e.mieumsioskorean = 12655; + e.mihiragana = 12415; + e.mikatakana = 12511; + e.mikatakanahalfwidth = 65424; + e.minus = 8722; + e.minusbelowcmb = 800; + e.minuscircle = 8854; + e.minusmod = 727; + e.minusplus = 8723; + e.minute = 8242; + e.miribaarusquare = 13130; + e.mirisquare = 13129; + e.mlonglegturned = 624; + e.mlsquare = 13206; + e.mmcubedsquare = 13219; + e.mmonospace = 65357; + e.mmsquaredsquare = 13215; + e.mohiragana = 12418; + e.mohmsquare = 13249; + e.mokatakana = 12514; + e.mokatakanahalfwidth = 65427; + e.molsquare = 13270; + e.momathai = 3617; + e.moverssquare = 13223; + e.moverssquaredsquare = 13224; + e.mparen = 9384; + e.mpasquare = 13227; + e.mssquare = 13235; + e.msuperior = 63215; + e.mturned = 623; + e.mu = 181; + e.mu1 = 181; + e.muasquare = 13186; + e.muchgreater = 8811; + e.muchless = 8810; + e.mufsquare = 13196; + e.mugreek = 956; + e.mugsquare = 13197; + e.muhiragana = 12416; + e.mukatakana = 12512; + e.mukatakanahalfwidth = 65425; + e.mulsquare = 13205; + e.multiply = 215; + e.mumsquare = 13211; + e.munahhebrew = 1443; + e.munahlefthebrew = 1443; + e.musicalnote = 9834; + e.musicalnotedbl = 9835; + e.musicflatsign = 9837; + e.musicsharpsign = 9839; + e.mussquare = 13234; + e.muvsquare = 13238; + e.muwsquare = 13244; + e.mvmegasquare = 13241; + e.mvsquare = 13239; + e.mwmegasquare = 13247; + e.mwsquare = 13245; + e.n = 110; + e.nabengali = 2472; + e.nabla = 8711; + e.nacute = 324; + e.nadeva = 2344; + e.nagujarati = 2728; + e.nagurmukhi = 2600; + e.nahiragana = 12394; + e.nakatakana = 12490; + e.nakatakanahalfwidth = 65413; + e.napostrophe = 329; + e.nasquare = 13185; + e.nbopomofo = 12555; + e.nbspace = 160; + e.ncaron = 328; + e.ncedilla = 326; + e.ncircle = 9437; + e.ncircumflexbelow = 7755; + e.ncommaaccent = 326; + e.ndotaccent = 7749; + e.ndotbelow = 7751; + e.nehiragana = 12397; + e.nekatakana = 12493; + e.nekatakanahalfwidth = 65416; + e.newsheqelsign = 8362; + e.nfsquare = 13195; + e.ngabengali = 2457; + e.ngadeva = 2329; + e.ngagujarati = 2713; + e.ngagurmukhi = 2585; + e.ngonguthai = 3591; + e.nhiragana = 12435; + e.nhookleft = 626; + e.nhookretroflex = 627; + e.nieunacirclekorean = 12911; + e.nieunaparenkorean = 12815; + e.nieuncieuckorean = 12597; + e.nieuncirclekorean = 12897; + e.nieunhieuhkorean = 12598; + e.nieunkorean = 12596; + e.nieunpansioskorean = 12648; + e.nieunparenkorean = 12801; + e.nieunsioskorean = 12647; + e.nieuntikeutkorean = 12646; + e.nihiragana = 12395; + e.nikatakana = 12491; + e.nikatakanahalfwidth = 65414; + e.nikhahitleftthai = 63641; + e.nikhahitthai = 3661; + e.nine = 57; + e.ninearabic = 1641; + e.ninebengali = 2543; + e.ninecircle = 9320; + e.ninecircleinversesansserif = 10130; + e.ninedeva = 2415; + e.ninegujarati = 2799; + e.ninegurmukhi = 2671; + e.ninehackarabic = 1641; + e.ninehangzhou = 12329; + e.nineideographicparen = 12840; + e.nineinferior = 8329; + e.ninemonospace = 65305; + e.nineoldstyle = 63289; + e.nineparen = 9340; + e.nineperiod = 9360; + e.ninepersian = 1785; + e.nineroman = 8568; + e.ninesuperior = 8313; + e.nineteencircle = 9330; + e.nineteenparen = 9350; + e.nineteenperiod = 9370; + e.ninethai = 3673; + e.nj = 460; + e.njecyrillic = 1114; + e.nkatakana = 12531; + e.nkatakanahalfwidth = 65437; + e.nlegrightlong = 414; + e.nlinebelow = 7753; + e.nmonospace = 65358; + e.nmsquare = 13210; + e.nnabengali = 2467; + e.nnadeva = 2339; + e.nnagujarati = 2723; + e.nnagurmukhi = 2595; + e.nnnadeva = 2345; + e.nohiragana = 12398; + e.nokatakana = 12494; + e.nokatakanahalfwidth = 65417; + e.nonbreakingspace = 160; + e.nonenthai = 3603; + e.nonuthai = 3609; + e.noonarabic = 1606; + e.noonfinalarabic = 65254; + e.noonghunnaarabic = 1722; + e.noonghunnafinalarabic = 64415; + e.nooninitialarabic = 65255; + e.noonjeeminitialarabic = 64722; + e.noonjeemisolatedarabic = 64587; + e.noonmedialarabic = 65256; + e.noonmeeminitialarabic = 64725; + e.noonmeemisolatedarabic = 64590; + e.noonnoonfinalarabic = 64653; + e.notcontains = 8716; + e.notelement = 8713; + e.notelementof = 8713; + e.notequal = 8800; + e.notgreater = 8815; + e.notgreaternorequal = 8817; + e.notgreaternorless = 8825; + e.notidentical = 8802; + e.notless = 8814; + e.notlessnorequal = 8816; + e.notparallel = 8742; + e.notprecedes = 8832; + e.notsubset = 8836; + e.notsucceeds = 8833; + e.notsuperset = 8837; + e.nowarmenian = 1398; + e.nparen = 9385; + e.nssquare = 13233; + e.nsuperior = 8319; + e.ntilde = 241; + e.nu = 957; + e.nuhiragana = 12396; + e.nukatakana = 12492; + e.nukatakanahalfwidth = 65415; + e.nuktabengali = 2492; + e.nuktadeva = 2364; + e.nuktagujarati = 2748; + e.nuktagurmukhi = 2620; + e.numbersign = 35; + e.numbersignmonospace = 65283; + e.numbersignsmall = 65119; + e.numeralsigngreek = 884; + e.numeralsignlowergreek = 885; + e.numero = 8470; + e.nun = 1504; + e.nundagesh = 64320; + e.nundageshhebrew = 64320; + e.nunhebrew = 1504; + e.nvsquare = 13237; + e.nwsquare = 13243; + e.nyabengali = 2462; + e.nyadeva = 2334; + e.nyagujarati = 2718; + e.nyagurmukhi = 2590; + e.o = 111; + e.oacute = 243; + e.oangthai = 3629; + e.obarred = 629; + e.obarredcyrillic = 1257; + e.obarreddieresiscyrillic = 1259; + e.obengali = 2451; + e.obopomofo = 12571; + e.obreve = 335; + e.ocandradeva = 2321; + e.ocandragujarati = 2705; + e.ocandravowelsigndeva = 2377; + e.ocandravowelsigngujarati = 2761; + e.ocaron = 466; + e.ocircle = 9438; + e.ocircumflex = 244; + e.ocircumflexacute = 7889; + e.ocircumflexdotbelow = 7897; + e.ocircumflexgrave = 7891; + e.ocircumflexhookabove = 7893; + e.ocircumflextilde = 7895; + e.ocyrillic = 1086; + e.odblacute = 337; + e.odblgrave = 525; + e.odeva = 2323; + e.odieresis = 246; + e.odieresiscyrillic = 1255; + e.odotbelow = 7885; + e.oe = 339; + e.oekorean = 12634; + e.ogonek = 731; + e.ogonekcmb = 808; + e.ograve = 242; + e.ogujarati = 2707; + e.oharmenian = 1413; + e.ohiragana = 12362; + e.ohookabove = 7887; + e.ohorn = 417; + e.ohornacute = 7899; + e.ohorndotbelow = 7907; + e.ohorngrave = 7901; + e.ohornhookabove = 7903; + e.ohorntilde = 7905; + e.ohungarumlaut = 337; + e.oi = 419; + e.oinvertedbreve = 527; + e.okatakana = 12458; + e.okatakanahalfwidth = 65397; + e.okorean = 12631; + e.olehebrew = 1451; + e.omacron = 333; + e.omacronacute = 7763; + e.omacrongrave = 7761; + e.omdeva = 2384; + e.omega = 969; + e.omega1 = 982; + e.omegacyrillic = 1121; + e.omegalatinclosed = 631; + e.omegaroundcyrillic = 1147; + e.omegatitlocyrillic = 1149; + e.omegatonos = 974; + e.omgujarati = 2768; + e.omicron = 959; + e.omicrontonos = 972; + e.omonospace = 65359; + e.one = 49; + e.onearabic = 1633; + e.onebengali = 2535; + e.onecircle = 9312; + e.onecircleinversesansserif = 10122; + e.onedeva = 2407; + e.onedotenleader = 8228; + e.oneeighth = 8539; + e.onefitted = 63196; + e.onegujarati = 2791; + e.onegurmukhi = 2663; + e.onehackarabic = 1633; + e.onehalf = 189; + e.onehangzhou = 12321; + e.oneideographicparen = 12832; + e.oneinferior = 8321; + e.onemonospace = 65297; + e.onenumeratorbengali = 2548; + e.oneoldstyle = 63281; + e.oneparen = 9332; + e.oneperiod = 9352; + e.onepersian = 1777; + e.onequarter = 188; + e.oneroman = 8560; + e.onesuperior = 185; + e.onethai = 3665; + e.onethird = 8531; + e.oogonek = 491; + e.oogonekmacron = 493; + e.oogurmukhi = 2579; + e.oomatragurmukhi = 2635; + e.oopen = 596; + e.oparen = 9386; + e.openbullet = 9702; + e.option = 8997; + e.ordfeminine = 170; + e.ordmasculine = 186; + e.orthogonal = 8735; + e.oshortdeva = 2322; + e.oshortvowelsigndeva = 2378; + e.oslash = 248; + e.oslashacute = 511; + e.osmallhiragana = 12361; + e.osmallkatakana = 12457; + e.osmallkatakanahalfwidth = 65387; + e.ostrokeacute = 511; + e.osuperior = 63216; + e.otcyrillic = 1151; + e.otilde = 245; + e.otildeacute = 7757; + e.otildedieresis = 7759; + e.oubopomofo = 12577; + e.overline = 8254; + e.overlinecenterline = 65098; + e.overlinecmb = 773; + e.overlinedashed = 65097; + e.overlinedblwavy = 65100; + e.overlinewavy = 65099; + e.overscore = 175; + e.ovowelsignbengali = 2507; + e.ovowelsigndeva = 2379; + e.ovowelsigngujarati = 2763; + e.p = 112; + e.paampssquare = 13184; + e.paasentosquare = 13099; + e.pabengali = 2474; + e.pacute = 7765; + e.padeva = 2346; + e.pagedown = 8671; + e.pageup = 8670; + e.pagujarati = 2730; + e.pagurmukhi = 2602; + e.pahiragana = 12401; + e.paiyannoithai = 3631; + e.pakatakana = 12497; + e.palatalizationcyrilliccmb = 1156; + e.palochkacyrillic = 1216; + e.pansioskorean = 12671; + e.paragraph = 182; + e.parallel = 8741; + e.parenleft = 40; + e.parenleftaltonearabic = 64830; + e.parenleftbt = 63725; + e.parenleftex = 63724; + e.parenleftinferior = 8333; + e.parenleftmonospace = 65288; + e.parenleftsmall = 65113; + e.parenleftsuperior = 8317; + e.parenlefttp = 63723; + e.parenleftvertical = 65077; + e.parenright = 41; + e.parenrightaltonearabic = 64831; + e.parenrightbt = 63736; + e.parenrightex = 63735; + e.parenrightinferior = 8334; + e.parenrightmonospace = 65289; + e.parenrightsmall = 65114; + e.parenrightsuperior = 8318; + e.parenrighttp = 63734; + e.parenrightvertical = 65078; + e.partialdiff = 8706; + e.paseqhebrew = 1472; + e.pashtahebrew = 1433; + e.pasquare = 13225; + e.patah = 1463; + e.patah11 = 1463; + e.patah1d = 1463; + e.patah2a = 1463; + e.patahhebrew = 1463; + e.patahnarrowhebrew = 1463; + e.patahquarterhebrew = 1463; + e.patahwidehebrew = 1463; + e.pazerhebrew = 1441; + e.pbopomofo = 12550; + e.pcircle = 9439; + e.pdotaccent = 7767; + e.pe = 1508; + e.pecyrillic = 1087; + e.pedagesh = 64324; + e.pedageshhebrew = 64324; + e.peezisquare = 13115; + e.pefinaldageshhebrew = 64323; + e.peharabic = 1662; + e.peharmenian = 1402; + e.pehebrew = 1508; + e.pehfinalarabic = 64343; + e.pehinitialarabic = 64344; + e.pehiragana = 12410; + e.pehmedialarabic = 64345; + e.pekatakana = 12506; + e.pemiddlehookcyrillic = 1191; + e.perafehebrew = 64334; + e.percent = 37; + e.percentarabic = 1642; + e.percentmonospace = 65285; + e.percentsmall = 65130; + e.period = 46; + e.periodarmenian = 1417; + e.periodcentered = 183; + e.periodhalfwidth = 65377; + e.periodinferior = 63207; + e.periodmonospace = 65294; + e.periodsmall = 65106; + e.periodsuperior = 63208; + e.perispomenigreekcmb = 834; + e.perpendicular = 8869; + e.perthousand = 8240; + e.peseta = 8359; + e.pfsquare = 13194; + e.phabengali = 2475; + e.phadeva = 2347; + e.phagujarati = 2731; + e.phagurmukhi = 2603; + e.phi = 966; + e.phi1 = 981; + e.phieuphacirclekorean = 12922; + e.phieuphaparenkorean = 12826; + e.phieuphcirclekorean = 12908; + e.phieuphkorean = 12621; + e.phieuphparenkorean = 12812; + e.philatin = 632; + e.phinthuthai = 3642; + e.phisymbolgreek = 981; + e.phook = 421; + e.phophanthai = 3614; + e.phophungthai = 3612; + e.phosamphaothai = 3616; + e.pi = 960; + e.pieupacirclekorean = 12915; + e.pieupaparenkorean = 12819; + e.pieupcieuckorean = 12662; + e.pieupcirclekorean = 12901; + e.pieupkiyeokkorean = 12658; + e.pieupkorean = 12610; + e.pieupparenkorean = 12805; + e.pieupsioskiyeokkorean = 12660; + e.pieupsioskorean = 12612; + e.pieupsiostikeutkorean = 12661; + e.pieupthieuthkorean = 12663; + e.pieuptikeutkorean = 12659; + e.pihiragana = 12404; + e.pikatakana = 12500; + e.pisymbolgreek = 982; + e.piwrarmenian = 1411; + e.planckover2pi = 8463; + e.planckover2pi1 = 8463; + e.plus = 43; + e.plusbelowcmb = 799; + e.pluscircle = 8853; + e.plusminus = 177; + e.plusmod = 726; + e.plusmonospace = 65291; + e.plussmall = 65122; + e.plussuperior = 8314; + e.pmonospace = 65360; + e.pmsquare = 13272; + e.pohiragana = 12413; + e.pointingindexdownwhite = 9759; + e.pointingindexleftwhite = 9756; + e.pointingindexrightwhite = 9758; + e.pointingindexupwhite = 9757; + e.pokatakana = 12509; + e.poplathai = 3611; + e.postalmark = 12306; + e.postalmarkface = 12320; + e.pparen = 9387; + e.precedes = 8826; + e.prescription = 8478; + e.primemod = 697; + e.primereversed = 8245; + e.product = 8719; + e.projective = 8965; + e.prolongedkana = 12540; + e.propellor = 8984; + e.propersubset = 8834; + e.propersuperset = 8835; + e.proportion = 8759; + e.proportional = 8733; + e.psi = 968; + e.psicyrillic = 1137; + e.psilipneumatacyrilliccmb = 1158; + e.pssquare = 13232; + e.puhiragana = 12407; + e.pukatakana = 12503; + e.pvsquare = 13236; + e.pwsquare = 13242; + e.q = 113; + e.qadeva = 2392; + e.qadmahebrew = 1448; + e.qafarabic = 1602; + e.qaffinalarabic = 65238; + e.qafinitialarabic = 65239; + e.qafmedialarabic = 65240; + e.qamats = 1464; + e.qamats10 = 1464; + e.qamats1a = 1464; + e.qamats1c = 1464; + e.qamats27 = 1464; + e.qamats29 = 1464; + e.qamats33 = 1464; + e.qamatsde = 1464; + e.qamatshebrew = 1464; + e.qamatsnarrowhebrew = 1464; + e.qamatsqatanhebrew = 1464; + e.qamatsqatannarrowhebrew = 1464; + e.qamatsqatanquarterhebrew = 1464; + e.qamatsqatanwidehebrew = 1464; + e.qamatsquarterhebrew = 1464; + e.qamatswidehebrew = 1464; + e.qarneyparahebrew = 1439; + e.qbopomofo = 12561; + e.qcircle = 9440; + e.qhook = 672; + e.qmonospace = 65361; + e.qof = 1511; + e.qofdagesh = 64327; + e.qofdageshhebrew = 64327; + e.qofhebrew = 1511; + e.qparen = 9388; + e.quarternote = 9833; + e.qubuts = 1467; + e.qubuts18 = 1467; + e.qubuts25 = 1467; + e.qubuts31 = 1467; + e.qubutshebrew = 1467; + e.qubutsnarrowhebrew = 1467; + e.qubutsquarterhebrew = 1467; + e.qubutswidehebrew = 1467; + e.question = 63; + e.questionarabic = 1567; + e.questionarmenian = 1374; + e.questiondown = 191; + e.questiondownsmall = 63423; + e.questiongreek = 894; + e.questionmonospace = 65311; + e.questionsmall = 63295; + e.quotedbl = 34; + e.quotedblbase = 8222; + e.quotedblleft = 8220; + e.quotedblmonospace = 65282; + e.quotedblprime = 12318; + e.quotedblprimereversed = 12317; + e.quotedblright = 8221; + e.quoteleft = 8216; + e.quoteleftreversed = 8219; + e.quotereversed = 8219; + e.quoteright = 8217; + e.quoterightn = 329; + e.quotesinglbase = 8218; + e.quotesingle = 39; + e.quotesinglemonospace = 65287; + e.r = 114; + e.raarmenian = 1404; + e.rabengali = 2480; + e.racute = 341; + e.radeva = 2352; + e.radical = 8730; + e.radicalex = 63717; + e.radoverssquare = 13230; + e.radoverssquaredsquare = 13231; + e.radsquare = 13229; + e.rafe = 1471; + e.rafehebrew = 1471; + e.ragujarati = 2736; + e.ragurmukhi = 2608; + e.rahiragana = 12425; + e.rakatakana = 12521; + e.rakatakanahalfwidth = 65431; + e.ralowerdiagonalbengali = 2545; + e.ramiddlediagonalbengali = 2544; + e.ramshorn = 612; + e.ratio = 8758; + e.rbopomofo = 12566; + e.rcaron = 345; + e.rcedilla = 343; + e.rcircle = 9441; + e.rcommaaccent = 343; + e.rdblgrave = 529; + e.rdotaccent = 7769; + e.rdotbelow = 7771; + e.rdotbelowmacron = 7773; + e.referencemark = 8251; + e.reflexsubset = 8838; + e.reflexsuperset = 8839; + e.registered = 174; + e.registersans = 63720; + e.registerserif = 63194; + e.reharabic = 1585; + e.reharmenian = 1408; + e.rehfinalarabic = 65198; + e.rehiragana = 12428; + e.rekatakana = 12524; + e.rekatakanahalfwidth = 65434; + e.resh = 1512; + e.reshdageshhebrew = 64328; + e.reshhebrew = 1512; + e.reversedtilde = 8765; + e.reviahebrew = 1431; + e.reviamugrashhebrew = 1431; + e.revlogicalnot = 8976; + e.rfishhook = 638; + e.rfishhookreversed = 639; + e.rhabengali = 2525; + e.rhadeva = 2397; + e.rho = 961; + e.rhook = 637; + e.rhookturned = 635; + e.rhookturnedsuperior = 693; + e.rhosymbolgreek = 1009; + e.rhotichookmod = 734; + e.rieulacirclekorean = 12913; + e.rieulaparenkorean = 12817; + e.rieulcirclekorean = 12899; + e.rieulhieuhkorean = 12608; + e.rieulkiyeokkorean = 12602; + e.rieulkiyeoksioskorean = 12649; + e.rieulkorean = 12601; + e.rieulmieumkorean = 12603; + e.rieulpansioskorean = 12652; + e.rieulparenkorean = 12803; + e.rieulphieuphkorean = 12607; + e.rieulpieupkorean = 12604; + e.rieulpieupsioskorean = 12651; + e.rieulsioskorean = 12605; + e.rieulthieuthkorean = 12606; + e.rieultikeutkorean = 12650; + e.rieulyeorinhieuhkorean = 12653; + e.rightangle = 8735; + e.righttackbelowcmb = 793; + e.righttriangle = 8895; + e.rihiragana = 12426; + e.rikatakana = 12522; + e.rikatakanahalfwidth = 65432; + e.ring = 730; + e.ringbelowcmb = 805; + e.ringcmb = 778; + e.ringhalfleft = 703; + e.ringhalfleftarmenian = 1369; + e.ringhalfleftbelowcmb = 796; + e.ringhalfleftcentered = 723; + e.ringhalfright = 702; + e.ringhalfrightbelowcmb = 825; + e.ringhalfrightcentered = 722; + e.rinvertedbreve = 531; + e.rittorusquare = 13137; + e.rlinebelow = 7775; + e.rlongleg = 636; + e.rlonglegturned = 634; + e.rmonospace = 65362; + e.rohiragana = 12429; + e.rokatakana = 12525; + e.rokatakanahalfwidth = 65435; + e.roruathai = 3619; + e.rparen = 9389; + e.rrabengali = 2524; + e.rradeva = 2353; + e.rragurmukhi = 2652; + e.rreharabic = 1681; + e.rrehfinalarabic = 64397; + e.rrvocalicbengali = 2528; + e.rrvocalicdeva = 2400; + e.rrvocalicgujarati = 2784; + e.rrvocalicvowelsignbengali = 2500; + e.rrvocalicvowelsigndeva = 2372; + e.rrvocalicvowelsigngujarati = 2756; + e.rsuperior = 63217; + e.rtblock = 9616; + e.rturned = 633; + e.rturnedsuperior = 692; + e.ruhiragana = 12427; + e.rukatakana = 12523; + e.rukatakanahalfwidth = 65433; + e.rupeemarkbengali = 2546; + e.rupeesignbengali = 2547; + e.rupiah = 63197; + e.ruthai = 3620; + e.rvocalicbengali = 2443; + e.rvocalicdeva = 2315; + e.rvocalicgujarati = 2699; + e.rvocalicvowelsignbengali = 2499; + e.rvocalicvowelsigndeva = 2371; + e.rvocalicvowelsigngujarati = 2755; + e.s = 115; + e.sabengali = 2488; + e.sacute = 347; + e.sacutedotaccent = 7781; + e.sadarabic = 1589; + e.sadeva = 2360; + e.sadfinalarabic = 65210; + e.sadinitialarabic = 65211; + e.sadmedialarabic = 65212; + e.sagujarati = 2744; + e.sagurmukhi = 2616; + e.sahiragana = 12373; + e.sakatakana = 12469; + e.sakatakanahalfwidth = 65403; + e.sallallahoualayhewasallamarabic = 65018; + e.samekh = 1505; + e.samekhdagesh = 64321; + e.samekhdageshhebrew = 64321; + e.samekhhebrew = 1505; + e.saraaathai = 3634; + e.saraaethai = 3649; + e.saraaimaimalaithai = 3652; + e.saraaimaimuanthai = 3651; + e.saraamthai = 3635; + e.saraathai = 3632; + e.saraethai = 3648; + e.saraiileftthai = 63622; + e.saraiithai = 3637; + e.saraileftthai = 63621; + e.saraithai = 3636; + e.saraothai = 3650; + e.saraueeleftthai = 63624; + e.saraueethai = 3639; + e.saraueleftthai = 63623; + e.sarauethai = 3638; + e.sarauthai = 3640; + e.sarauuthai = 3641; + e.sbopomofo = 12569; + e.scaron = 353; + e.scarondotaccent = 7783; + e.scedilla = 351; + e.schwa = 601; + e.schwacyrillic = 1241; + e.schwadieresiscyrillic = 1243; + e.schwahook = 602; + e.scircle = 9442; + e.scircumflex = 349; + e.scommaaccent = 537; + e.sdotaccent = 7777; + e.sdotbelow = 7779; + e.sdotbelowdotaccent = 7785; + e.seagullbelowcmb = 828; + e.second = 8243; + e.secondtonechinese = 714; + e.section = 167; + e.seenarabic = 1587; + e.seenfinalarabic = 65202; + e.seeninitialarabic = 65203; + e.seenmedialarabic = 65204; + e.segol = 1462; + e.segol13 = 1462; + e.segol1f = 1462; + e.segol2c = 1462; + e.segolhebrew = 1462; + e.segolnarrowhebrew = 1462; + e.segolquarterhebrew = 1462; + e.segoltahebrew = 1426; + e.segolwidehebrew = 1462; + e.seharmenian = 1405; + e.sehiragana = 12379; + e.sekatakana = 12475; + e.sekatakanahalfwidth = 65406; + e.semicolon = 59; + e.semicolonarabic = 1563; + e.semicolonmonospace = 65307; + e.semicolonsmall = 65108; + e.semivoicedmarkkana = 12444; + e.semivoicedmarkkanahalfwidth = 65439; + e.sentisquare = 13090; + e.sentosquare = 13091; + e.seven = 55; + e.sevenarabic = 1639; + e.sevenbengali = 2541; + e.sevencircle = 9318; + e.sevencircleinversesansserif = 10128; + e.sevendeva = 2413; + e.seveneighths = 8542; + e.sevengujarati = 2797; + e.sevengurmukhi = 2669; + e.sevenhackarabic = 1639; + e.sevenhangzhou = 12327; + e.sevenideographicparen = 12838; + e.seveninferior = 8327; + e.sevenmonospace = 65303; + e.sevenoldstyle = 63287; + e.sevenparen = 9338; + e.sevenperiod = 9358; + e.sevenpersian = 1783; + e.sevenroman = 8566; + e.sevensuperior = 8311; + e.seventeencircle = 9328; + e.seventeenparen = 9348; + e.seventeenperiod = 9368; + e.seventhai = 3671; + e.sfthyphen = 173; + e.shaarmenian = 1399; + e.shabengali = 2486; + e.shacyrillic = 1096; + e.shaddaarabic = 1617; + e.shaddadammaarabic = 64609; + e.shaddadammatanarabic = 64606; + e.shaddafathaarabic = 64608; + e.shaddakasraarabic = 64610; + e.shaddakasratanarabic = 64607; + e.shade = 9618; + e.shadedark = 9619; + e.shadelight = 9617; + e.shademedium = 9618; + e.shadeva = 2358; + e.shagujarati = 2742; + e.shagurmukhi = 2614; + e.shalshelethebrew = 1427; + e.shbopomofo = 12565; + e.shchacyrillic = 1097; + e.sheenarabic = 1588; + e.sheenfinalarabic = 65206; + e.sheeninitialarabic = 65207; + e.sheenmedialarabic = 65208; + e.sheicoptic = 995; + e.sheqel = 8362; + e.sheqelhebrew = 8362; + e.sheva = 1456; + e.sheva115 = 1456; + e.sheva15 = 1456; + e.sheva22 = 1456; + e.sheva2e = 1456; + e.shevahebrew = 1456; + e.shevanarrowhebrew = 1456; + e.shevaquarterhebrew = 1456; + e.shevawidehebrew = 1456; + e.shhacyrillic = 1211; + e.shimacoptic = 1005; + e.shin = 1513; + e.shindagesh = 64329; + e.shindageshhebrew = 64329; + e.shindageshshindot = 64300; + e.shindageshshindothebrew = 64300; + e.shindageshsindot = 64301; + e.shindageshsindothebrew = 64301; + e.shindothebrew = 1473; + e.shinhebrew = 1513; + e.shinshindot = 64298; + e.shinshindothebrew = 64298; + e.shinsindot = 64299; + e.shinsindothebrew = 64299; + e.shook = 642; + e.sigma = 963; + e.sigma1 = 962; + e.sigmafinal = 962; + e.sigmalunatesymbolgreek = 1010; + e.sihiragana = 12375; + e.sikatakana = 12471; + e.sikatakanahalfwidth = 65404; + e.siluqhebrew = 1469; + e.siluqlefthebrew = 1469; + e.similar = 8764; + e.sindothebrew = 1474; + e.siosacirclekorean = 12916; + e.siosaparenkorean = 12820; + e.sioscieuckorean = 12670; + e.sioscirclekorean = 12902; + e.sioskiyeokkorean = 12666; + e.sioskorean = 12613; + e.siosnieunkorean = 12667; + e.siosparenkorean = 12806; + e.siospieupkorean = 12669; + e.siostikeutkorean = 12668; + e.six = 54; + e.sixarabic = 1638; + e.sixbengali = 2540; + e.sixcircle = 9317; + e.sixcircleinversesansserif = 10127; + e.sixdeva = 2412; + e.sixgujarati = 2796; + e.sixgurmukhi = 2668; + e.sixhackarabic = 1638; + e.sixhangzhou = 12326; + e.sixideographicparen = 12837; + e.sixinferior = 8326; + e.sixmonospace = 65302; + e.sixoldstyle = 63286; + e.sixparen = 9337; + e.sixperiod = 9357; + e.sixpersian = 1782; + e.sixroman = 8565; + e.sixsuperior = 8310; + e.sixteencircle = 9327; + e.sixteencurrencydenominatorbengali = 2553; + e.sixteenparen = 9347; + e.sixteenperiod = 9367; + e.sixthai = 3670; + e.slash = 47; + e.slashmonospace = 65295; + e.slong = 383; + e.slongdotaccent = 7835; + e.smileface = 9786; + e.smonospace = 65363; + e.sofpasuqhebrew = 1475; + e.softhyphen = 173; + e.softsigncyrillic = 1100; + e.sohiragana = 12381; + e.sokatakana = 12477; + e.sokatakanahalfwidth = 65407; + e.soliduslongoverlaycmb = 824; + e.solidusshortoverlaycmb = 823; + e.sorusithai = 3625; + e.sosalathai = 3624; + e.sosothai = 3595; + e.sosuathai = 3626; + e.space = 32; + e.spacehackarabic = 32; + e.spade = 9824; + e.spadesuitblack = 9824; + e.spadesuitwhite = 9828; + e.sparen = 9390; + e.squarebelowcmb = 827; + e.squarecc = 13252; + e.squarecm = 13213; + e.squarediagonalcrosshatchfill = 9641; + e.squarehorizontalfill = 9636; + e.squarekg = 13199; + e.squarekm = 13214; + e.squarekmcapital = 13262; + e.squareln = 13265; + e.squarelog = 13266; + e.squaremg = 13198; + e.squaremil = 13269; + e.squaremm = 13212; + e.squaremsquared = 13217; + e.squareorthogonalcrosshatchfill = 9638; + e.squareupperlefttolowerrightfill = 9639; + e.squareupperrighttolowerleftfill = 9640; + e.squareverticalfill = 9637; + e.squarewhitewithsmallblack = 9635; + e.srsquare = 13275; + e.ssabengali = 2487; + e.ssadeva = 2359; + e.ssagujarati = 2743; + e.ssangcieuckorean = 12617; + e.ssanghieuhkorean = 12677; + e.ssangieungkorean = 12672; + e.ssangkiyeokkorean = 12594; + e.ssangnieunkorean = 12645; + e.ssangpieupkorean = 12611; + e.ssangsioskorean = 12614; + e.ssangtikeutkorean = 12600; + e.ssuperior = 63218; + e.sterling = 163; + e.sterlingmonospace = 65505; + e.strokelongoverlaycmb = 822; + e.strokeshortoverlaycmb = 821; + e.subset = 8834; + e.subsetnotequal = 8842; + e.subsetorequal = 8838; + e.succeeds = 8827; + e.suchthat = 8715; + e.suhiragana = 12377; + e.sukatakana = 12473; + e.sukatakanahalfwidth = 65405; + e.sukunarabic = 1618; + e.summation = 8721; + e.sun = 9788; + e.superset = 8835; + e.supersetnotequal = 8843; + e.supersetorequal = 8839; + e.svsquare = 13276; + e.syouwaerasquare = 13180; + e.t = 116; + e.tabengali = 2468; + e.tackdown = 8868; + e.tackleft = 8867; + e.tadeva = 2340; + e.tagujarati = 2724; + e.tagurmukhi = 2596; + e.taharabic = 1591; + e.tahfinalarabic = 65218; + e.tahinitialarabic = 65219; + e.tahiragana = 12383; + e.tahmedialarabic = 65220; + e.taisyouerasquare = 13181; + e.takatakana = 12479; + e.takatakanahalfwidth = 65408; + e.tatweelarabic = 1600; + e.tau = 964; + e.tav = 1514; + e.tavdages = 64330; + e.tavdagesh = 64330; + e.tavdageshhebrew = 64330; + e.tavhebrew = 1514; + e.tbar = 359; + e.tbopomofo = 12554; + e.tcaron = 357; + e.tccurl = 680; + e.tcedilla = 355; + e.tcheharabic = 1670; + e.tchehfinalarabic = 64379; + e.tchehinitialarabic = 64380; + e.tchehmedialarabic = 64381; + e.tcircle = 9443; + e.tcircumflexbelow = 7793; + e.tcommaaccent = 355; + e.tdieresis = 7831; + e.tdotaccent = 7787; + e.tdotbelow = 7789; + e.tecyrillic = 1090; + e.tedescendercyrillic = 1197; + e.teharabic = 1578; + e.tehfinalarabic = 65174; + e.tehhahinitialarabic = 64674; + e.tehhahisolatedarabic = 64524; + e.tehinitialarabic = 65175; + e.tehiragana = 12390; + e.tehjeeminitialarabic = 64673; + e.tehjeemisolatedarabic = 64523; + e.tehmarbutaarabic = 1577; + e.tehmarbutafinalarabic = 65172; + e.tehmedialarabic = 65176; + e.tehmeeminitialarabic = 64676; + e.tehmeemisolatedarabic = 64526; + e.tehnoonfinalarabic = 64627; + e.tekatakana = 12486; + e.tekatakanahalfwidth = 65411; + e.telephone = 8481; + e.telephoneblack = 9742; + e.telishagedolahebrew = 1440; + e.telishaqetanahebrew = 1449; + e.tencircle = 9321; + e.tenideographicparen = 12841; + e.tenparen = 9341; + e.tenperiod = 9361; + e.tenroman = 8569; + e.tesh = 679; + e.tet = 1496; + e.tetdagesh = 64312; + e.tetdageshhebrew = 64312; + e.tethebrew = 1496; + e.tetsecyrillic = 1205; + e.tevirhebrew = 1435; + e.tevirlefthebrew = 1435; + e.thabengali = 2469; + e.thadeva = 2341; + e.thagujarati = 2725; + e.thagurmukhi = 2597; + e.thalarabic = 1584; + e.thalfinalarabic = 65196; + e.thanthakhatlowleftthai = 63640; + e.thanthakhatlowrightthai = 63639; + e.thanthakhatthai = 3660; + e.thanthakhatupperleftthai = 63638; + e.theharabic = 1579; + e.thehfinalarabic = 65178; + e.thehinitialarabic = 65179; + e.thehmedialarabic = 65180; + e.thereexists = 8707; + e.therefore = 8756; + e.theta = 952; + e.theta1 = 977; + e.thetasymbolgreek = 977; + e.thieuthacirclekorean = 12921; + e.thieuthaparenkorean = 12825; + e.thieuthcirclekorean = 12907; + e.thieuthkorean = 12620; + e.thieuthparenkorean = 12811; + e.thirteencircle = 9324; + e.thirteenparen = 9344; + e.thirteenperiod = 9364; + e.thonangmonthothai = 3601; + e.thook = 429; + e.thophuthaothai = 3602; + e.thorn = 254; + e.thothahanthai = 3607; + e.thothanthai = 3600; + e.thothongthai = 3608; + e.thothungthai = 3606; + e.thousandcyrillic = 1154; + e.thousandsseparatorarabic = 1644; + e.thousandsseparatorpersian = 1644; + e.three = 51; + e.threearabic = 1635; + e.threebengali = 2537; + e.threecircle = 9314; + e.threecircleinversesansserif = 10124; + e.threedeva = 2409; + e.threeeighths = 8540; + e.threegujarati = 2793; + e.threegurmukhi = 2665; + e.threehackarabic = 1635; + e.threehangzhou = 12323; + e.threeideographicparen = 12834; + e.threeinferior = 8323; + e.threemonospace = 65299; + e.threenumeratorbengali = 2550; + e.threeoldstyle = 63283; + e.threeparen = 9334; + e.threeperiod = 9354; + e.threepersian = 1779; + e.threequarters = 190; + e.threequartersemdash = 63198; + e.threeroman = 8562; + e.threesuperior = 179; + e.threethai = 3667; + e.thzsquare = 13204; + e.tihiragana = 12385; + e.tikatakana = 12481; + e.tikatakanahalfwidth = 65409; + e.tikeutacirclekorean = 12912; + e.tikeutaparenkorean = 12816; + e.tikeutcirclekorean = 12898; + e.tikeutkorean = 12599; + e.tikeutparenkorean = 12802; + e.tilde = 732; + e.tildebelowcmb = 816; + e.tildecmb = 771; + e.tildecomb = 771; + e.tildedoublecmb = 864; + e.tildeoperator = 8764; + e.tildeoverlaycmb = 820; + e.tildeverticalcmb = 830; + e.timescircle = 8855; + e.tipehahebrew = 1430; + e.tipehalefthebrew = 1430; + e.tippigurmukhi = 2672; + e.titlocyrilliccmb = 1155; + e.tiwnarmenian = 1407; + e.tlinebelow = 7791; + e.tmonospace = 65364; + e.toarmenian = 1385; + e.tohiragana = 12392; + e.tokatakana = 12488; + e.tokatakanahalfwidth = 65412; + e.tonebarextrahighmod = 741; + e.tonebarextralowmod = 745; + e.tonebarhighmod = 742; + e.tonebarlowmod = 744; + e.tonebarmidmod = 743; + e.tonefive = 445; + e.tonesix = 389; + e.tonetwo = 424; + e.tonos = 900; + e.tonsquare = 13095; + e.topatakthai = 3599; + e.tortoiseshellbracketleft = 12308; + e.tortoiseshellbracketleftsmall = 65117; + e.tortoiseshellbracketleftvertical = 65081; + e.tortoiseshellbracketright = 12309; + e.tortoiseshellbracketrightsmall = 65118; + e.tortoiseshellbracketrightvertical = 65082; + e.totaothai = 3605; + e.tpalatalhook = 427; + e.tparen = 9391; + e.trademark = 8482; + e.trademarksans = 63722; + e.trademarkserif = 63195; + e.tretroflexhook = 648; + e.triagdn = 9660; + e.triaglf = 9668; + e.triagrt = 9658; + e.triagup = 9650; + e.ts = 678; + e.tsadi = 1510; + e.tsadidagesh = 64326; + e.tsadidageshhebrew = 64326; + e.tsadihebrew = 1510; + e.tsecyrillic = 1094; + e.tsere = 1461; + e.tsere12 = 1461; + e.tsere1e = 1461; + e.tsere2b = 1461; + e.tserehebrew = 1461; + e.tserenarrowhebrew = 1461; + e.tserequarterhebrew = 1461; + e.tserewidehebrew = 1461; + e.tshecyrillic = 1115; + e.tsuperior = 63219; + e.ttabengali = 2463; + e.ttadeva = 2335; + e.ttagujarati = 2719; + e.ttagurmukhi = 2591; + e.tteharabic = 1657; + e.ttehfinalarabic = 64359; + e.ttehinitialarabic = 64360; + e.ttehmedialarabic = 64361; + e.tthabengali = 2464; + e.tthadeva = 2336; + e.tthagujarati = 2720; + e.tthagurmukhi = 2592; + e.tturned = 647; + e.tuhiragana = 12388; + e.tukatakana = 12484; + e.tukatakanahalfwidth = 65410; + e.tusmallhiragana = 12387; + e.tusmallkatakana = 12483; + e.tusmallkatakanahalfwidth = 65391; + e.twelvecircle = 9323; + e.twelveparen = 9343; + e.twelveperiod = 9363; + e.twelveroman = 8571; + e.twentycircle = 9331; + e.twentyhangzhou = 21316; + e.twentyparen = 9351; + e.twentyperiod = 9371; + e.two = 50; + e.twoarabic = 1634; + e.twobengali = 2536; + e.twocircle = 9313; + e.twocircleinversesansserif = 10123; + e.twodeva = 2408; + e.twodotenleader = 8229; + e.twodotleader = 8229; + e.twodotleadervertical = 65072; + e.twogujarati = 2792; + e.twogurmukhi = 2664; + e.twohackarabic = 1634; + e.twohangzhou = 12322; + e.twoideographicparen = 12833; + e.twoinferior = 8322; + e.twomonospace = 65298; + e.twonumeratorbengali = 2549; + e.twooldstyle = 63282; + e.twoparen = 9333; + e.twoperiod = 9353; + e.twopersian = 1778; + e.tworoman = 8561; + e.twostroke = 443; + e.twosuperior = 178; + e.twothai = 3666; + e.twothirds = 8532; + e.u = 117; + e.uacute = 250; + e.ubar = 649; + e.ubengali = 2441; + e.ubopomofo = 12584; + e.ubreve = 365; + e.ucaron = 468; + e.ucircle = 9444; + e.ucircumflex = 251; + e.ucircumflexbelow = 7799; + e.ucyrillic = 1091; + e.udattadeva = 2385; + e.udblacute = 369; + e.udblgrave = 533; + e.udeva = 2313; + e.udieresis = 252; + e.udieresisacute = 472; + e.udieresisbelow = 7795; + e.udieresiscaron = 474; + e.udieresiscyrillic = 1265; + e.udieresisgrave = 476; + e.udieresismacron = 470; + e.udotbelow = 7909; + e.ugrave = 249; + e.ugujarati = 2697; + e.ugurmukhi = 2569; + e.uhiragana = 12358; + e.uhookabove = 7911; + e.uhorn = 432; + e.uhornacute = 7913; + e.uhorndotbelow = 7921; + e.uhorngrave = 7915; + e.uhornhookabove = 7917; + e.uhorntilde = 7919; + e.uhungarumlaut = 369; + e.uhungarumlautcyrillic = 1267; + e.uinvertedbreve = 535; + e.ukatakana = 12454; + e.ukatakanahalfwidth = 65395; + e.ukcyrillic = 1145; + e.ukorean = 12636; + e.umacron = 363; + e.umacroncyrillic = 1263; + e.umacrondieresis = 7803; + e.umatragurmukhi = 2625; + e.umonospace = 65365; + e.underscore = 95; + e.underscoredbl = 8215; + e.underscoremonospace = 65343; + e.underscorevertical = 65075; + e.underscorewavy = 65103; + e.union = 8746; + e.universal = 8704; + e.uogonek = 371; + e.uparen = 9392; + e.upblock = 9600; + e.upperdothebrew = 1476; + e.upsilon = 965; + e.upsilondieresis = 971; + e.upsilondieresistonos = 944; + e.upsilonlatin = 650; + e.upsilontonos = 973; + e.uptackbelowcmb = 797; + e.uptackmod = 724; + e.uragurmukhi = 2675; + e.uring = 367; + e.ushortcyrillic = 1118; + e.usmallhiragana = 12357; + e.usmallkatakana = 12453; + e.usmallkatakanahalfwidth = 65385; + e.ustraightcyrillic = 1199; + e.ustraightstrokecyrillic = 1201; + e.utilde = 361; + e.utildeacute = 7801; + e.utildebelow = 7797; + e.uubengali = 2442; + e.uudeva = 2314; + e.uugujarati = 2698; + e.uugurmukhi = 2570; + e.uumatragurmukhi = 2626; + e.uuvowelsignbengali = 2498; + e.uuvowelsigndeva = 2370; + e.uuvowelsigngujarati = 2754; + e.uvowelsignbengali = 2497; + e.uvowelsigndeva = 2369; + e.uvowelsigngujarati = 2753; + e.v = 118; + e.vadeva = 2357; + e.vagujarati = 2741; + e.vagurmukhi = 2613; + e.vakatakana = 12535; + e.vav = 1493; + e.vavdagesh = 64309; + e.vavdagesh65 = 64309; + e.vavdageshhebrew = 64309; + e.vavhebrew = 1493; + e.vavholam = 64331; + e.vavholamhebrew = 64331; + e.vavvavhebrew = 1520; + e.vavyodhebrew = 1521; + e.vcircle = 9445; + e.vdotbelow = 7807; + e.vecyrillic = 1074; + e.veharabic = 1700; + e.vehfinalarabic = 64363; + e.vehinitialarabic = 64364; + e.vehmedialarabic = 64365; + e.vekatakana = 12537; + e.venus = 9792; + e.verticalbar = 124; + e.verticallineabovecmb = 781; + e.verticallinebelowcmb = 809; + e.verticallinelowmod = 716; + e.verticallinemod = 712; + e.vewarmenian = 1406; + e.vhook = 651; + e.vikatakana = 12536; + e.viramabengali = 2509; + e.viramadeva = 2381; + e.viramagujarati = 2765; + e.visargabengali = 2435; + e.visargadeva = 2307; + e.visargagujarati = 2691; + e.vmonospace = 65366; + e.voarmenian = 1400; + e.voicediterationhiragana = 12446; + e.voicediterationkatakana = 12542; + e.voicedmarkkana = 12443; + e.voicedmarkkanahalfwidth = 65438; + e.vokatakana = 12538; + e.vparen = 9393; + e.vtilde = 7805; + e.vturned = 652; + e.vuhiragana = 12436; + e.vukatakana = 12532; + e.w = 119; + e.wacute = 7811; + e.waekorean = 12633; + e.wahiragana = 12431; + e.wakatakana = 12527; + e.wakatakanahalfwidth = 65436; + e.wakorean = 12632; + e.wasmallhiragana = 12430; + e.wasmallkatakana = 12526; + e.wattosquare = 13143; + e.wavedash = 12316; + e.wavyunderscorevertical = 65076; + e.wawarabic = 1608; + e.wawfinalarabic = 65262; + e.wawhamzaabovearabic = 1572; + e.wawhamzaabovefinalarabic = 65158; + e.wbsquare = 13277; + e.wcircle = 9446; + e.wcircumflex = 373; + e.wdieresis = 7813; + e.wdotaccent = 7815; + e.wdotbelow = 7817; + e.wehiragana = 12433; + e.weierstrass = 8472; + e.wekatakana = 12529; + e.wekorean = 12638; + e.weokorean = 12637; + e.wgrave = 7809; + e.whitebullet = 9702; + e.whitecircle = 9675; + e.whitecircleinverse = 9689; + e.whitecornerbracketleft = 12302; + e.whitecornerbracketleftvertical = 65091; + e.whitecornerbracketright = 12303; + e.whitecornerbracketrightvertical = 65092; + e.whitediamond = 9671; + e.whitediamondcontainingblacksmalldiamond = 9672; + e.whitedownpointingsmalltriangle = 9663; + e.whitedownpointingtriangle = 9661; + e.whiteleftpointingsmalltriangle = 9667; + e.whiteleftpointingtriangle = 9665; + e.whitelenticularbracketleft = 12310; + e.whitelenticularbracketright = 12311; + e.whiterightpointingsmalltriangle = 9657; + e.whiterightpointingtriangle = 9655; + e.whitesmallsquare = 9643; + e.whitesmilingface = 9786; + e.whitesquare = 9633; + e.whitestar = 9734; + e.whitetelephone = 9743; + e.whitetortoiseshellbracketleft = 12312; + e.whitetortoiseshellbracketright = 12313; + e.whiteuppointingsmalltriangle = 9653; + e.whiteuppointingtriangle = 9651; + e.wihiragana = 12432; + e.wikatakana = 12528; + e.wikorean = 12639; + e.wmonospace = 65367; + e.wohiragana = 12434; + e.wokatakana = 12530; + e.wokatakanahalfwidth = 65382; + e.won = 8361; + e.wonmonospace = 65510; + e.wowaenthai = 3623; + e.wparen = 9394; + e.wring = 7832; + e.wsuperior = 695; + e.wturned = 653; + e.wynn = 447; + e.x = 120; + e.xabovecmb = 829; + e.xbopomofo = 12562; + e.xcircle = 9447; + e.xdieresis = 7821; + e.xdotaccent = 7819; + e.xeharmenian = 1389; + e.xi = 958; + e.xmonospace = 65368; + e.xparen = 9395; + e.xsuperior = 739; + e.y = 121; + e.yaadosquare = 13134; + e.yabengali = 2479; + e.yacute = 253; + e.yadeva = 2351; + e.yaekorean = 12626; + e.yagujarati = 2735; + e.yagurmukhi = 2607; + e.yahiragana = 12420; + e.yakatakana = 12516; + e.yakatakanahalfwidth = 65428; + e.yakorean = 12625; + e.yamakkanthai = 3662; + e.yasmallhiragana = 12419; + e.yasmallkatakana = 12515; + e.yasmallkatakanahalfwidth = 65388; + e.yatcyrillic = 1123; + e.ycircle = 9448; + e.ycircumflex = 375; + e.ydieresis = 255; + e.ydotaccent = 7823; + e.ydotbelow = 7925; + e.yeharabic = 1610; + e.yehbarreearabic = 1746; + e.yehbarreefinalarabic = 64431; + e.yehfinalarabic = 65266; + e.yehhamzaabovearabic = 1574; + e.yehhamzaabovefinalarabic = 65162; + e.yehhamzaaboveinitialarabic = 65163; + e.yehhamzaabovemedialarabic = 65164; + e.yehinitialarabic = 65267; + e.yehmedialarabic = 65268; + e.yehmeeminitialarabic = 64733; + e.yehmeemisolatedarabic = 64600; + e.yehnoonfinalarabic = 64660; + e.yehthreedotsbelowarabic = 1745; + e.yekorean = 12630; + e.yen = 165; + e.yenmonospace = 65509; + e.yeokorean = 12629; + e.yeorinhieuhkorean = 12678; + e.yerahbenyomohebrew = 1450; + e.yerahbenyomolefthebrew = 1450; + e.yericyrillic = 1099; + e.yerudieresiscyrillic = 1273; + e.yesieungkorean = 12673; + e.yesieungpansioskorean = 12675; + e.yesieungsioskorean = 12674; + e.yetivhebrew = 1434; + e.ygrave = 7923; + e.yhook = 436; + e.yhookabove = 7927; + e.yiarmenian = 1397; + e.yicyrillic = 1111; + e.yikorean = 12642; + e.yinyang = 9775; + e.yiwnarmenian = 1410; + e.ymonospace = 65369; + e.yod = 1497; + e.yoddagesh = 64313; + e.yoddageshhebrew = 64313; + e.yodhebrew = 1497; + e.yodyodhebrew = 1522; + e.yodyodpatahhebrew = 64287; + e.yohiragana = 12424; + e.yoikorean = 12681; + e.yokatakana = 12520; + e.yokatakanahalfwidth = 65430; + e.yokorean = 12635; + e.yosmallhiragana = 12423; + e.yosmallkatakana = 12519; + e.yosmallkatakanahalfwidth = 65390; + e.yotgreek = 1011; + e.yoyaekorean = 12680; + e.yoyakorean = 12679; + e.yoyakthai = 3618; + e.yoyingthai = 3597; + e.yparen = 9396; + e.ypogegrammeni = 890; + e.ypogegrammenigreekcmb = 837; + e.yr = 422; + e.yring = 7833; + e.ysuperior = 696; + e.ytilde = 7929; + e.yturned = 654; + e.yuhiragana = 12422; + e.yuikorean = 12684; + e.yukatakana = 12518; + e.yukatakanahalfwidth = 65429; + e.yukorean = 12640; + e.yusbigcyrillic = 1131; + e.yusbigiotifiedcyrillic = 1133; + e.yuslittlecyrillic = 1127; + e.yuslittleiotifiedcyrillic = 1129; + e.yusmallhiragana = 12421; + e.yusmallkatakana = 12517; + e.yusmallkatakanahalfwidth = 65389; + e.yuyekorean = 12683; + e.yuyeokorean = 12682; + e.yyabengali = 2527; + e.yyadeva = 2399; + e.z = 122; + e.zaarmenian = 1382; + e.zacute = 378; + e.zadeva = 2395; + e.zagurmukhi = 2651; + e.zaharabic = 1592; + e.zahfinalarabic = 65222; + e.zahinitialarabic = 65223; + e.zahiragana = 12374; + e.zahmedialarabic = 65224; + e.zainarabic = 1586; + e.zainfinalarabic = 65200; + e.zakatakana = 12470; + e.zaqefgadolhebrew = 1429; + e.zaqefqatanhebrew = 1428; + e.zarqahebrew = 1432; + e.zayin = 1494; + e.zayindagesh = 64310; + e.zayindageshhebrew = 64310; + e.zayinhebrew = 1494; + e.zbopomofo = 12567; + e.zcaron = 382; + e.zcircle = 9449; + e.zcircumflex = 7825; + e.zcurl = 657; + e.zdot = 380; + e.zdotaccent = 380; + e.zdotbelow = 7827; + e.zecyrillic = 1079; + e.zedescendercyrillic = 1177; + e.zedieresiscyrillic = 1247; + e.zehiragana = 12380; + e.zekatakana = 12476; + e.zero = 48; + e.zeroarabic = 1632; + e.zerobengali = 2534; + e.zerodeva = 2406; + e.zerogujarati = 2790; + e.zerogurmukhi = 2662; + e.zerohackarabic = 1632; + e.zeroinferior = 8320; + e.zeromonospace = 65296; + e.zerooldstyle = 63280; + e.zeropersian = 1776; + e.zerosuperior = 8304; + e.zerothai = 3664; + e.zerowidthjoiner = 65279; + e.zerowidthnonjoiner = 8204; + e.zerowidthspace = 8203; + e.zeta = 950; + e.zhbopomofo = 12563; + e.zhearmenian = 1386; + e.zhebrevecyrillic = 1218; + e.zhecyrillic = 1078; + e.zhedescendercyrillic = 1175; + e.zhedieresiscyrillic = 1245; + e.zihiragana = 12376; + e.zikatakana = 12472; + e.zinorhebrew = 1454; + e.zlinebelow = 7829; + e.zmonospace = 65370; + e.zohiragana = 12382; + e.zokatakana = 12478; + e.zparen = 9397; + e.zretroflexhook = 656; + e.zstroke = 438; + e.zuhiragana = 12378; + e.zukatakana = 12474; + e[".notdef"] = 0; + e.angbracketleftbig = 9001; + e.angbracketleftBig = 9001; + e.angbracketleftbigg = 9001; + e.angbracketleftBigg = 9001; + e.angbracketrightBig = 9002; + e.angbracketrightbig = 9002; + e.angbracketrightBigg = 9002; + e.angbracketrightbigg = 9002; + e.arrowhookleft = 8618; + e.arrowhookright = 8617; + e.arrowlefttophalf = 8636; + e.arrowleftbothalf = 8637; + e.arrownortheast = 8599; + e.arrownorthwest = 8598; + e.arrowrighttophalf = 8640; + e.arrowrightbothalf = 8641; + e.arrowsoutheast = 8600; + e.arrowsouthwest = 8601; + e.backslashbig = 8726; + e.backslashBig = 8726; + e.backslashBigg = 8726; + e.backslashbigg = 8726; + e.bardbl = 8214; + e.bracehtipdownleft = 65079; + e.bracehtipdownright = 65079; + e.bracehtipupleft = 65080; + e.bracehtipupright = 65080; + e.braceleftBig = 123; + e.braceleftbig = 123; + e.braceleftbigg = 123; + e.braceleftBigg = 123; + e.bracerightBig = 125; + e.bracerightbig = 125; + e.bracerightbigg = 125; + e.bracerightBigg = 125; + e.bracketleftbig = 91; + e.bracketleftBig = 91; + e.bracketleftbigg = 91; + e.bracketleftBigg = 91; + e.bracketrightBig = 93; + e.bracketrightbig = 93; + e.bracketrightbigg = 93; + e.bracketrightBigg = 93; + e.ceilingleftbig = 8968; + e.ceilingleftBig = 8968; + e.ceilingleftBigg = 8968; + e.ceilingleftbigg = 8968; + e.ceilingrightbig = 8969; + e.ceilingrightBig = 8969; + e.ceilingrightbigg = 8969; + e.ceilingrightBigg = 8969; + e.circledotdisplay = 8857; + e.circledottext = 8857; + e.circlemultiplydisplay = 8855; + e.circlemultiplytext = 8855; + e.circleplusdisplay = 8853; + e.circleplustext = 8853; + e.contintegraldisplay = 8750; + e.contintegraltext = 8750; + e.coproductdisplay = 8720; + e.coproducttext = 8720; + e.floorleftBig = 8970; + e.floorleftbig = 8970; + e.floorleftbigg = 8970; + e.floorleftBigg = 8970; + e.floorrightbig = 8971; + e.floorrightBig = 8971; + e.floorrightBigg = 8971; + e.floorrightbigg = 8971; + e.hatwide = 770; + e.hatwider = 770; + e.hatwidest = 770; + e.intercal = 7488; + e.integraldisplay = 8747; + e.integraltext = 8747; + e.intersectiondisplay = 8898; + e.intersectiontext = 8898; + e.logicalanddisplay = 8743; + e.logicalandtext = 8743; + e.logicalordisplay = 8744; + e.logicalortext = 8744; + e.parenleftBig = 40; + e.parenleftbig = 40; + e.parenleftBigg = 40; + e.parenleftbigg = 40; + e.parenrightBig = 41; + e.parenrightbig = 41; + e.parenrightBigg = 41; + e.parenrightbigg = 41; + e.prime = 8242; + e.productdisplay = 8719; + e.producttext = 8719; + e.radicalbig = 8730; + e.radicalBig = 8730; + e.radicalBigg = 8730; + e.radicalbigg = 8730; + e.radicalbt = 8730; + e.radicaltp = 8730; + e.radicalvertex = 8730; + e.slashbig = 47; + e.slashBig = 47; + e.slashBigg = 47; + e.slashbigg = 47; + e.summationdisplay = 8721; + e.summationtext = 8721; + e.tildewide = 732; + e.tildewider = 732; + e.tildewidest = 732; + e.uniondisplay = 8899; + e.unionmultidisplay = 8846; + e.unionmultitext = 8846; + e.unionsqdisplay = 8852; + e.unionsqtext = 8852; + e.uniontext = 8899; + e.vextenddouble = 8741; + e.vextendsingle = 8739; + }), + Ir = getLookupTableFactory(function (e) { + e.space = 32; + e.a1 = 9985; + e.a2 = 9986; + e.a202 = 9987; + e.a3 = 9988; + e.a4 = 9742; + e.a5 = 9990; + e.a119 = 9991; + e.a118 = 9992; + e.a117 = 9993; + e.a11 = 9755; + e.a12 = 9758; + e.a13 = 9996; + e.a14 = 9997; + e.a15 = 9998; + e.a16 = 9999; + e.a105 = 1e4; + e.a17 = 10001; + e.a18 = 10002; + e.a19 = 10003; + e.a20 = 10004; + e.a21 = 10005; + e.a22 = 10006; + e.a23 = 10007; + e.a24 = 10008; + e.a25 = 10009; + e.a26 = 10010; + e.a27 = 10011; + e.a28 = 10012; + e.a6 = 10013; + e.a7 = 10014; + e.a8 = 10015; + e.a9 = 10016; + e.a10 = 10017; + e.a29 = 10018; + e.a30 = 10019; + e.a31 = 10020; + e.a32 = 10021; + e.a33 = 10022; + e.a34 = 10023; + e.a35 = 9733; + e.a36 = 10025; + e.a37 = 10026; + e.a38 = 10027; + e.a39 = 10028; + e.a40 = 10029; + e.a41 = 10030; + e.a42 = 10031; + e.a43 = 10032; + e.a44 = 10033; + e.a45 = 10034; + e.a46 = 10035; + e.a47 = 10036; + e.a48 = 10037; + e.a49 = 10038; + e.a50 = 10039; + e.a51 = 10040; + e.a52 = 10041; + e.a53 = 10042; + e.a54 = 10043; + e.a55 = 10044; + e.a56 = 10045; + e.a57 = 10046; + e.a58 = 10047; + e.a59 = 10048; + e.a60 = 10049; + e.a61 = 10050; + e.a62 = 10051; + e.a63 = 10052; + e.a64 = 10053; + e.a65 = 10054; + e.a66 = 10055; + e.a67 = 10056; + e.a68 = 10057; + e.a69 = 10058; + e.a70 = 10059; + e.a71 = 9679; + e.a72 = 10061; + e.a73 = 9632; + e.a74 = 10063; + e.a203 = 10064; + e.a75 = 10065; + e.a204 = 10066; + e.a76 = 9650; + e.a77 = 9660; + e.a78 = 9670; + e.a79 = 10070; + e.a81 = 9687; + e.a82 = 10072; + e.a83 = 10073; + e.a84 = 10074; + e.a97 = 10075; + e.a98 = 10076; + e.a99 = 10077; + e.a100 = 10078; + e.a101 = 10081; + e.a102 = 10082; + e.a103 = 10083; + e.a104 = 10084; + e.a106 = 10085; + e.a107 = 10086; + e.a108 = 10087; + e.a112 = 9827; + e.a111 = 9830; + e.a110 = 9829; + e.a109 = 9824; + e.a120 = 9312; + e.a121 = 9313; + e.a122 = 9314; + e.a123 = 9315; + e.a124 = 9316; + e.a125 = 9317; + e.a126 = 9318; + e.a127 = 9319; + e.a128 = 9320; + e.a129 = 9321; + e.a130 = 10102; + e.a131 = 10103; + e.a132 = 10104; + e.a133 = 10105; + e.a134 = 10106; + e.a135 = 10107; + e.a136 = 10108; + e.a137 = 10109; + e.a138 = 10110; + e.a139 = 10111; + e.a140 = 10112; + e.a141 = 10113; + e.a142 = 10114; + e.a143 = 10115; + e.a144 = 10116; + e.a145 = 10117; + e.a146 = 10118; + e.a147 = 10119; + e.a148 = 10120; + e.a149 = 10121; + e.a150 = 10122; + e.a151 = 10123; + e.a152 = 10124; + e.a153 = 10125; + e.a154 = 10126; + e.a155 = 10127; + e.a156 = 10128; + e.a157 = 10129; + e.a158 = 10130; + e.a159 = 10131; + e.a160 = 10132; + e.a161 = 8594; + e.a163 = 8596; + e.a164 = 8597; + e.a196 = 10136; + e.a165 = 10137; + e.a192 = 10138; + e.a166 = 10139; + e.a167 = 10140; + e.a168 = 10141; + e.a169 = 10142; + e.a170 = 10143; + e.a171 = 10144; + e.a172 = 10145; + e.a173 = 10146; + e.a162 = 10147; + e.a174 = 10148; + e.a175 = 10149; + e.a176 = 10150; + e.a177 = 10151; + e.a178 = 10152; + e.a179 = 10153; + e.a193 = 10154; + e.a180 = 10155; + e.a199 = 10156; + e.a181 = 10157; + e.a200 = 10158; + e.a182 = 10159; + e.a201 = 10161; + e.a183 = 10162; + e.a184 = 10163; + e.a197 = 10164; + e.a185 = 10165; + e.a194 = 10166; + e.a198 = 10167; + e.a186 = 10168; + e.a195 = 10169; + e.a187 = 10170; + e.a188 = 10171; + e.a189 = 10172; + e.a190 = 10173; + e.a191 = 10174; + e.a89 = 10088; + e.a90 = 10089; + e.a93 = 10090; + e.a94 = 10091; + e.a91 = 10092; + e.a92 = 10093; + e.a205 = 10094; + e.a85 = 10095; + e.a206 = 10096; + e.a86 = 10097; + e.a87 = 10098; + e.a88 = 10099; + e.a95 = 10100; + e.a96 = 10101; + e[".notdef"] = 0; + }), + Tr = getLookupTableFactory(function (e) { + e[63721] = 169; + e[63193] = 169; + e[63720] = 174; + e[63194] = 174; + e[63722] = 8482; + e[63195] = 8482; + e[63729] = 9127; + e[63730] = 9128; + e[63731] = 9129; + e[63740] = 9131; + e[63741] = 9132; + e[63742] = 9133; + e[63726] = 9121; + e[63727] = 9122; + e[63728] = 9123; + e[63737] = 9124; + e[63738] = 9125; + e[63739] = 9126; + e[63723] = 9115; + e[63724] = 9116; + e[63725] = 9117; + e[63734] = 9118; + e[63735] = 9119; + e[63736] = 9120; + }); +function getUnicodeForGlyph(e, t) { + let a = t[e]; + if (void 0 !== a) return a; + if (!e) return -1; + if ("u" === e[0]) { + const t = e.length; + let r; + if (7 === t && "n" === e[1] && "i" === e[2]) r = e.substring(3); + else { + if (!(t >= 5 && t <= 7)) return -1; + r = e.substring(1); + } + if (r === r.toUpperCase()) { + a = parseInt(r, 16); + if (a >= 0) return a; + } + } + return -1; +} +const Or = [ + [0, 127], + [128, 255], + [256, 383], + [384, 591], + [592, 687, 7424, 7551, 7552, 7615], + [688, 767, 42752, 42783], + [768, 879, 7616, 7679], + [880, 1023], + [11392, 11519], + [1024, 1279, 1280, 1327, 11744, 11775, 42560, 42655], + [1328, 1423], + [1424, 1535], + [42240, 42559], + [1536, 1791, 1872, 1919], + [1984, 2047], + [2304, 2431], + [2432, 2559], + [2560, 2687], + [2688, 2815], + [2816, 2943], + [2944, 3071], + [3072, 3199], + [3200, 3327], + [3328, 3455], + [3584, 3711], + [3712, 3839], + [4256, 4351, 11520, 11567], + [6912, 7039], + [4352, 4607], + [7680, 7935, 11360, 11391, 42784, 43007], + [7936, 8191], + [8192, 8303, 11776, 11903], + [8304, 8351], + [8352, 8399], + [8400, 8447], + [8448, 8527], + [8528, 8591], + [8592, 8703, 10224, 10239, 10496, 10623, 11008, 11263], + [8704, 8959, 10752, 11007, 10176, 10223, 10624, 10751], + [8960, 9215], + [9216, 9279], + [9280, 9311], + [9312, 9471], + [9472, 9599], + [9600, 9631], + [9632, 9727], + [9728, 9983], + [9984, 10175], + [12288, 12351], + [12352, 12447], + [12448, 12543, 12784, 12799], + [12544, 12591, 12704, 12735], + [12592, 12687], + [43072, 43135], + [12800, 13055], + [13056, 13311], + [44032, 55215], + [55296, 57343], + [67840, 67871], + [ + 19968, 40959, 11904, 12031, 12032, 12255, 12272, 12287, 13312, 19903, + 131072, 173791, 12688, 12703, + ], + [57344, 63743], + [12736, 12783, 63744, 64255, 194560, 195103], + [64256, 64335], + [64336, 65023], + [65056, 65071], + [65040, 65055], + [65104, 65135], + [65136, 65279], + [65280, 65519], + [65520, 65535], + [3840, 4095], + [1792, 1871], + [1920, 1983], + [3456, 3583], + [4096, 4255], + [4608, 4991, 4992, 5023, 11648, 11743], + [5024, 5119], + [5120, 5759], + [5760, 5791], + [5792, 5887], + [6016, 6143], + [6144, 6319], + [10240, 10495], + [40960, 42127], + [5888, 5919, 5920, 5951, 5952, 5983, 5984, 6015], + [66304, 66351], + [66352, 66383], + [66560, 66639], + [118784, 119039, 119040, 119295, 119296, 119375], + [119808, 120831], + [1044480, 1048573], + [65024, 65039, 917760, 917999], + [917504, 917631], + [6400, 6479], + [6480, 6527], + [6528, 6623], + [6656, 6687], + [11264, 11359], + [11568, 11647], + [19904, 19967], + [43008, 43055], + [65536, 65663, 65664, 65791, 65792, 65855], + [65856, 65935], + [66432, 66463], + [66464, 66527], + [66640, 66687], + [66688, 66735], + [67584, 67647], + [68096, 68191], + [119552, 119647], + [73728, 74751, 74752, 74879], + [119648, 119679], + [7040, 7103], + [7168, 7247], + [7248, 7295], + [43136, 43231], + [43264, 43311], + [43312, 43359], + [43520, 43615], + [65936, 65999], + [66e3, 66047], + [66208, 66271, 66176, 66207, 67872, 67903], + [127024, 127135, 126976, 127023], +]; +function getUnicodeRangeFor(e, t = -1) { + if (-1 !== t) { + const a = Or[t]; + for (let r = 0, i = a.length; r < i; r += 2) + if (e >= a[r] && e <= a[r + 1]) return t; + } + for (let t = 0, a = Or.length; t < a; t++) { + const a = Or[t]; + for (let r = 0, i = a.length; r < i; r += 2) + if (e >= a[r] && e <= a[r + 1]) return t; + } + return -1; +} +const Mr = new RegExp("^(\\s)|(\\p{Mn})|(\\p{Cf})$", "u"), + Dr = new Map(); +const Rr = !0, + Nr = 1, + Er = 2, + Pr = 4, + Lr = 32, + jr = [ + ".notdef", + ".null", + "nonmarkingreturn", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quotesingle", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "grave", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "Adieresis", + "Aring", + "Ccedilla", + "Eacute", + "Ntilde", + "Odieresis", + "Udieresis", + "aacute", + "agrave", + "acircumflex", + "adieresis", + "atilde", + "aring", + "ccedilla", + "eacute", + "egrave", + "ecircumflex", + "edieresis", + "iacute", + "igrave", + "icircumflex", + "idieresis", + "ntilde", + "oacute", + "ograve", + "ocircumflex", + "odieresis", + "otilde", + "uacute", + "ugrave", + "ucircumflex", + "udieresis", + "dagger", + "degree", + "cent", + "sterling", + "section", + "bullet", + "paragraph", + "germandbls", + "registered", + "copyright", + "trademark", + "acute", + "dieresis", + "notequal", + "AE", + "Oslash", + "infinity", + "plusminus", + "lessequal", + "greaterequal", + "yen", + "mu", + "partialdiff", + "summation", + "product", + "pi", + "integral", + "ordfeminine", + "ordmasculine", + "Omega", + "ae", + "oslash", + "questiondown", + "exclamdown", + "logicalnot", + "radical", + "florin", + "approxequal", + "Delta", + "guillemotleft", + "guillemotright", + "ellipsis", + "nonbreakingspace", + "Agrave", + "Atilde", + "Otilde", + "OE", + "oe", + "endash", + "emdash", + "quotedblleft", + "quotedblright", + "quoteleft", + "quoteright", + "divide", + "lozenge", + "ydieresis", + "Ydieresis", + "fraction", + "currency", + "guilsinglleft", + "guilsinglright", + "fi", + "fl", + "daggerdbl", + "periodcentered", + "quotesinglbase", + "quotedblbase", + "perthousand", + "Acircumflex", + "Ecircumflex", + "Aacute", + "Edieresis", + "Egrave", + "Iacute", + "Icircumflex", + "Idieresis", + "Igrave", + "Oacute", + "Ocircumflex", + "apple", + "Ograve", + "Uacute", + "Ucircumflex", + "Ugrave", + "dotlessi", + "circumflex", + "tilde", + "macron", + "breve", + "dotaccent", + "ring", + "cedilla", + "hungarumlaut", + "ogonek", + "caron", + "Lslash", + "lslash", + "Scaron", + "scaron", + "Zcaron", + "zcaron", + "brokenbar", + "Eth", + "eth", + "Yacute", + "yacute", + "Thorn", + "thorn", + "minus", + "multiply", + "onesuperior", + "twosuperior", + "threesuperior", + "onehalf", + "onequarter", + "threequarters", + "franc", + "Gbreve", + "gbreve", + "Idotaccent", + "Scedilla", + "scedilla", + "Cacute", + "cacute", + "Ccaron", + "ccaron", + "dcroat", + ]; +function recoverGlyphName(e, t) { + if (void 0 !== t[e]) return e; + const a = getUnicodeForGlyph(e, t); + if (-1 !== a) for (const e in t) if (t[e] === a) return e; + info("Unable to recover a standard glyph name for: " + e); + return e; +} +function type1FontGlyphMapping(e, t, a) { + const r = Object.create(null); + let i, n, s; + const o = !!(e.flags & Pr); + if (e.isInternalFont) { + s = t; + for (n = 0; n < s.length; n++) { + i = a.indexOf(s[n]); + r[n] = i >= 0 ? i : 0; + } + } else if (e.baseEncodingName) { + s = getEncoding(e.baseEncodingName); + for (n = 0; n < s.length; n++) { + i = a.indexOf(s[n]); + r[n] = i >= 0 ? i : 0; + } + } else if (o) for (n in t) r[n] = t[n]; + else { + s = kr; + for (n = 0; n < s.length; n++) { + i = a.indexOf(s[n]); + r[n] = i >= 0 ? i : 0; + } + } + const c = e.differences; + let l; + if (c) + for (n in c) { + const e = c[n]; + i = a.indexOf(e); + if (-1 === i) { + l || (l = Fr()); + const t = recoverGlyphName(e, l); + t !== e && (i = a.indexOf(t)); + } + r[n] = i >= 0 ? i : 0; + } + return r; +} +function normalizeFontName(e) { + return e.replaceAll(/[,_]/g, "-").replaceAll(/\s/g, ""); +} +const _r = getLookupTableFactory((e) => { + e[8211] = 65074; + e[8212] = 65073; + e[8229] = 65072; + e[8230] = 65049; + e[12289] = 65041; + e[12290] = 65042; + e[12296] = 65087; + e[12297] = 65088; + e[12298] = 65085; + e[12299] = 65086; + e[12300] = 65089; + e[12301] = 65090; + e[12302] = 65091; + e[12303] = 65092; + e[12304] = 65083; + e[12305] = 65084; + e[12308] = 65081; + e[12309] = 65082; + e[12310] = 65047; + e[12311] = 65048; + e[65103] = 65076; + e[65281] = 65045; + e[65288] = 65077; + e[65289] = 65078; + e[65292] = 65040; + e[65306] = 65043; + e[65307] = 65044; + e[65311] = 65046; + e[65339] = 65095; + e[65341] = 65096; + e[65343] = 65075; + e[65371] = 65079; + e[65373] = 65080; +}); +const Ur = [ + ".notdef", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quoteright", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "quoteleft", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "exclamdown", + "cent", + "sterling", + "fraction", + "yen", + "florin", + "section", + "currency", + "quotesingle", + "quotedblleft", + "guillemotleft", + "guilsinglleft", + "guilsinglright", + "fi", + "fl", + "endash", + "dagger", + "daggerdbl", + "periodcentered", + "paragraph", + "bullet", + "quotesinglbase", + "quotedblbase", + "quotedblright", + "guillemotright", + "ellipsis", + "perthousand", + "questiondown", + "grave", + "acute", + "circumflex", + "tilde", + "macron", + "breve", + "dotaccent", + "dieresis", + "ring", + "cedilla", + "hungarumlaut", + "ogonek", + "caron", + "emdash", + "AE", + "ordfeminine", + "Lslash", + "Oslash", + "OE", + "ordmasculine", + "ae", + "dotlessi", + "lslash", + "oslash", + "oe", + "germandbls", + "onesuperior", + "logicalnot", + "mu", + "trademark", + "Eth", + "onehalf", + "plusminus", + "Thorn", + "onequarter", + "divide", + "brokenbar", + "degree", + "thorn", + "threequarters", + "twosuperior", + "registered", + "minus", + "eth", + "multiply", + "threesuperior", + "copyright", + "Aacute", + "Acircumflex", + "Adieresis", + "Agrave", + "Aring", + "Atilde", + "Ccedilla", + "Eacute", + "Ecircumflex", + "Edieresis", + "Egrave", + "Iacute", + "Icircumflex", + "Idieresis", + "Igrave", + "Ntilde", + "Oacute", + "Ocircumflex", + "Odieresis", + "Ograve", + "Otilde", + "Scaron", + "Uacute", + "Ucircumflex", + "Udieresis", + "Ugrave", + "Yacute", + "Ydieresis", + "Zcaron", + "aacute", + "acircumflex", + "adieresis", + "agrave", + "aring", + "atilde", + "ccedilla", + "eacute", + "ecircumflex", + "edieresis", + "egrave", + "iacute", + "icircumflex", + "idieresis", + "igrave", + "ntilde", + "oacute", + "ocircumflex", + "odieresis", + "ograve", + "otilde", + "scaron", + "uacute", + "ucircumflex", + "udieresis", + "ugrave", + "yacute", + "ydieresis", + "zcaron", + ], + Xr = [ + ".notdef", + "space", + "exclamsmall", + "Hungarumlautsmall", + "dollaroldstyle", + "dollarsuperior", + "ampersandsmall", + "Acutesmall", + "parenleftsuperior", + "parenrightsuperior", + "twodotenleader", + "onedotenleader", + "comma", + "hyphen", + "period", + "fraction", + "zerooldstyle", + "oneoldstyle", + "twooldstyle", + "threeoldstyle", + "fouroldstyle", + "fiveoldstyle", + "sixoldstyle", + "sevenoldstyle", + "eightoldstyle", + "nineoldstyle", + "colon", + "semicolon", + "commasuperior", + "threequartersemdash", + "periodsuperior", + "questionsmall", + "asuperior", + "bsuperior", + "centsuperior", + "dsuperior", + "esuperior", + "isuperior", + "lsuperior", + "msuperior", + "nsuperior", + "osuperior", + "rsuperior", + "ssuperior", + "tsuperior", + "ff", + "fi", + "fl", + "ffi", + "ffl", + "parenleftinferior", + "parenrightinferior", + "Circumflexsmall", + "hyphensuperior", + "Gravesmall", + "Asmall", + "Bsmall", + "Csmall", + "Dsmall", + "Esmall", + "Fsmall", + "Gsmall", + "Hsmall", + "Ismall", + "Jsmall", + "Ksmall", + "Lsmall", + "Msmall", + "Nsmall", + "Osmall", + "Psmall", + "Qsmall", + "Rsmall", + "Ssmall", + "Tsmall", + "Usmall", + "Vsmall", + "Wsmall", + "Xsmall", + "Ysmall", + "Zsmall", + "colonmonetary", + "onefitted", + "rupiah", + "Tildesmall", + "exclamdownsmall", + "centoldstyle", + "Lslashsmall", + "Scaronsmall", + "Zcaronsmall", + "Dieresissmall", + "Brevesmall", + "Caronsmall", + "Dotaccentsmall", + "Macronsmall", + "figuredash", + "hypheninferior", + "Ogoneksmall", + "Ringsmall", + "Cedillasmall", + "onequarter", + "onehalf", + "threequarters", + "questiondownsmall", + "oneeighth", + "threeeighths", + "fiveeighths", + "seveneighths", + "onethird", + "twothirds", + "zerosuperior", + "onesuperior", + "twosuperior", + "threesuperior", + "foursuperior", + "fivesuperior", + "sixsuperior", + "sevensuperior", + "eightsuperior", + "ninesuperior", + "zeroinferior", + "oneinferior", + "twoinferior", + "threeinferior", + "fourinferior", + "fiveinferior", + "sixinferior", + "seveninferior", + "eightinferior", + "nineinferior", + "centinferior", + "dollarinferior", + "periodinferior", + "commainferior", + "Agravesmall", + "Aacutesmall", + "Acircumflexsmall", + "Atildesmall", + "Adieresissmall", + "Aringsmall", + "AEsmall", + "Ccedillasmall", + "Egravesmall", + "Eacutesmall", + "Ecircumflexsmall", + "Edieresissmall", + "Igravesmall", + "Iacutesmall", + "Icircumflexsmall", + "Idieresissmall", + "Ethsmall", + "Ntildesmall", + "Ogravesmall", + "Oacutesmall", + "Ocircumflexsmall", + "Otildesmall", + "Odieresissmall", + "OEsmall", + "Oslashsmall", + "Ugravesmall", + "Uacutesmall", + "Ucircumflexsmall", + "Udieresissmall", + "Yacutesmall", + "Thornsmall", + "Ydieresissmall", + ], + qr = [ + ".notdef", + "space", + "dollaroldstyle", + "dollarsuperior", + "parenleftsuperior", + "parenrightsuperior", + "twodotenleader", + "onedotenleader", + "comma", + "hyphen", + "period", + "fraction", + "zerooldstyle", + "oneoldstyle", + "twooldstyle", + "threeoldstyle", + "fouroldstyle", + "fiveoldstyle", + "sixoldstyle", + "sevenoldstyle", + "eightoldstyle", + "nineoldstyle", + "colon", + "semicolon", + "commasuperior", + "threequartersemdash", + "periodsuperior", + "asuperior", + "bsuperior", + "centsuperior", + "dsuperior", + "esuperior", + "isuperior", + "lsuperior", + "msuperior", + "nsuperior", + "osuperior", + "rsuperior", + "ssuperior", + "tsuperior", + "ff", + "fi", + "fl", + "ffi", + "ffl", + "parenleftinferior", + "parenrightinferior", + "hyphensuperior", + "colonmonetary", + "onefitted", + "rupiah", + "centoldstyle", + "figuredash", + "hypheninferior", + "onequarter", + "onehalf", + "threequarters", + "oneeighth", + "threeeighths", + "fiveeighths", + "seveneighths", + "onethird", + "twothirds", + "zerosuperior", + "onesuperior", + "twosuperior", + "threesuperior", + "foursuperior", + "fivesuperior", + "sixsuperior", + "sevensuperior", + "eightsuperior", + "ninesuperior", + "zeroinferior", + "oneinferior", + "twoinferior", + "threeinferior", + "fourinferior", + "fiveinferior", + "sixinferior", + "seveninferior", + "eightinferior", + "nineinferior", + "centinferior", + "dollarinferior", + "periodinferior", + "commainferior", + ], + Hr = [ + ".notdef", + "space", + "exclam", + "quotedbl", + "numbersign", + "dollar", + "percent", + "ampersand", + "quoteright", + "parenleft", + "parenright", + "asterisk", + "plus", + "comma", + "hyphen", + "period", + "slash", + "zero", + "one", + "two", + "three", + "four", + "five", + "six", + "seven", + "eight", + "nine", + "colon", + "semicolon", + "less", + "equal", + "greater", + "question", + "at", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "bracketleft", + "backslash", + "bracketright", + "asciicircum", + "underscore", + "quoteleft", + "a", + "b", + "c", + "d", + "e", + "f", + "g", + "h", + "i", + "j", + "k", + "l", + "m", + "n", + "o", + "p", + "q", + "r", + "s", + "t", + "u", + "v", + "w", + "x", + "y", + "z", + "braceleft", + "bar", + "braceright", + "asciitilde", + "exclamdown", + "cent", + "sterling", + "fraction", + "yen", + "florin", + "section", + "currency", + "quotesingle", + "quotedblleft", + "guillemotleft", + "guilsinglleft", + "guilsinglright", + "fi", + "fl", + "endash", + "dagger", + "daggerdbl", + "periodcentered", + "paragraph", + "bullet", + "quotesinglbase", + "quotedblbase", + "quotedblright", + "guillemotright", + "ellipsis", + "perthousand", + "questiondown", + "grave", + "acute", + "circumflex", + "tilde", + "macron", + "breve", + "dotaccent", + "dieresis", + "ring", + "cedilla", + "hungarumlaut", + "ogonek", + "caron", + "emdash", + "AE", + "ordfeminine", + "Lslash", + "Oslash", + "OE", + "ordmasculine", + "ae", + "dotlessi", + "lslash", + "oslash", + "oe", + "germandbls", + "onesuperior", + "logicalnot", + "mu", + "trademark", + "Eth", + "onehalf", + "plusminus", + "Thorn", + "onequarter", + "divide", + "brokenbar", + "degree", + "thorn", + "threequarters", + "twosuperior", + "registered", + "minus", + "eth", + "multiply", + "threesuperior", + "copyright", + "Aacute", + "Acircumflex", + "Adieresis", + "Agrave", + "Aring", + "Atilde", + "Ccedilla", + "Eacute", + "Ecircumflex", + "Edieresis", + "Egrave", + "Iacute", + "Icircumflex", + "Idieresis", + "Igrave", + "Ntilde", + "Oacute", + "Ocircumflex", + "Odieresis", + "Ograve", + "Otilde", + "Scaron", + "Uacute", + "Ucircumflex", + "Udieresis", + "Ugrave", + "Yacute", + "Ydieresis", + "Zcaron", + "aacute", + "acircumflex", + "adieresis", + "agrave", + "aring", + "atilde", + "ccedilla", + "eacute", + "ecircumflex", + "edieresis", + "egrave", + "iacute", + "icircumflex", + "idieresis", + "igrave", + "ntilde", + "oacute", + "ocircumflex", + "odieresis", + "ograve", + "otilde", + "scaron", + "uacute", + "ucircumflex", + "udieresis", + "ugrave", + "yacute", + "ydieresis", + "zcaron", + "exclamsmall", + "Hungarumlautsmall", + "dollaroldstyle", + "dollarsuperior", + "ampersandsmall", + "Acutesmall", + "parenleftsuperior", + "parenrightsuperior", + "twodotenleader", + "onedotenleader", + "zerooldstyle", + "oneoldstyle", + "twooldstyle", + "threeoldstyle", + "fouroldstyle", + "fiveoldstyle", + "sixoldstyle", + "sevenoldstyle", + "eightoldstyle", + "nineoldstyle", + "commasuperior", + "threequartersemdash", + "periodsuperior", + "questionsmall", + "asuperior", + "bsuperior", + "centsuperior", + "dsuperior", + "esuperior", + "isuperior", + "lsuperior", + "msuperior", + "nsuperior", + "osuperior", + "rsuperior", + "ssuperior", + "tsuperior", + "ff", + "ffi", + "ffl", + "parenleftinferior", + "parenrightinferior", + "Circumflexsmall", + "hyphensuperior", + "Gravesmall", + "Asmall", + "Bsmall", + "Csmall", + "Dsmall", + "Esmall", + "Fsmall", + "Gsmall", + "Hsmall", + "Ismall", + "Jsmall", + "Ksmall", + "Lsmall", + "Msmall", + "Nsmall", + "Osmall", + "Psmall", + "Qsmall", + "Rsmall", + "Ssmall", + "Tsmall", + "Usmall", + "Vsmall", + "Wsmall", + "Xsmall", + "Ysmall", + "Zsmall", + "colonmonetary", + "onefitted", + "rupiah", + "Tildesmall", + "exclamdownsmall", + "centoldstyle", + "Lslashsmall", + "Scaronsmall", + "Zcaronsmall", + "Dieresissmall", + "Brevesmall", + "Caronsmall", + "Dotaccentsmall", + "Macronsmall", + "figuredash", + "hypheninferior", + "Ogoneksmall", + "Ringsmall", + "Cedillasmall", + "questiondownsmall", + "oneeighth", + "threeeighths", + "fiveeighths", + "seveneighths", + "onethird", + "twothirds", + "zerosuperior", + "foursuperior", + "fivesuperior", + "sixsuperior", + "sevensuperior", + "eightsuperior", + "ninesuperior", + "zeroinferior", + "oneinferior", + "twoinferior", + "threeinferior", + "fourinferior", + "fiveinferior", + "sixinferior", + "seveninferior", + "eightinferior", + "nineinferior", + "centinferior", + "dollarinferior", + "periodinferior", + "commainferior", + "Agravesmall", + "Aacutesmall", + "Acircumflexsmall", + "Atildesmall", + "Adieresissmall", + "Aringsmall", + "AEsmall", + "Ccedillasmall", + "Egravesmall", + "Eacutesmall", + "Ecircumflexsmall", + "Edieresissmall", + "Igravesmall", + "Iacutesmall", + "Icircumflexsmall", + "Idieresissmall", + "Ethsmall", + "Ntildesmall", + "Ogravesmall", + "Oacutesmall", + "Ocircumflexsmall", + "Otildesmall", + "Odieresissmall", + "OEsmall", + "Oslashsmall", + "Ugravesmall", + "Uacutesmall", + "Ucircumflexsmall", + "Udieresissmall", + "Yacutesmall", + "Thornsmall", + "Ydieresissmall", + "001.000", + "001.001", + "001.002", + "001.003", + "Black", + "Bold", + "Book", + "Light", + "Medium", + "Regular", + "Roman", + "Semibold", + ], + Wr = 391, + zr = [ + null, + { id: "hstem", min: 2, stackClearing: !0, stem: !0 }, + null, + { id: "vstem", min: 2, stackClearing: !0, stem: !0 }, + { id: "vmoveto", min: 1, stackClearing: !0 }, + { id: "rlineto", min: 2, resetStack: !0 }, + { id: "hlineto", min: 1, resetStack: !0 }, + { id: "vlineto", min: 1, resetStack: !0 }, + { id: "rrcurveto", min: 6, resetStack: !0 }, + null, + { id: "callsubr", min: 1, undefStack: !0 }, + { id: "return", min: 0, undefStack: !0 }, + null, + null, + { id: "endchar", min: 0, stackClearing: !0 }, + null, + null, + null, + { id: "hstemhm", min: 2, stackClearing: !0, stem: !0 }, + { id: "hintmask", min: 0, stackClearing: !0 }, + { id: "cntrmask", min: 0, stackClearing: !0 }, + { id: "rmoveto", min: 2, stackClearing: !0 }, + { id: "hmoveto", min: 1, stackClearing: !0 }, + { id: "vstemhm", min: 2, stackClearing: !0, stem: !0 }, + { id: "rcurveline", min: 8, resetStack: !0 }, + { id: "rlinecurve", min: 8, resetStack: !0 }, + { id: "vvcurveto", min: 4, resetStack: !0 }, + { id: "hhcurveto", min: 4, resetStack: !0 }, + null, + { id: "callgsubr", min: 1, undefStack: !0 }, + { id: "vhcurveto", min: 4, resetStack: !0 }, + { id: "hvcurveto", min: 4, resetStack: !0 }, + ], + $r = [ + null, + null, + null, + { id: "and", min: 2, stackDelta: -1 }, + { id: "or", min: 2, stackDelta: -1 }, + { id: "not", min: 1, stackDelta: 0 }, + null, + null, + null, + { id: "abs", min: 1, stackDelta: 0 }, + { + id: "add", + min: 2, + stackDelta: -1, + stackFn(e, t) { + e[t - 2] = e[t - 2] + e[t - 1]; + }, + }, + { + id: "sub", + min: 2, + stackDelta: -1, + stackFn(e, t) { + e[t - 2] = e[t - 2] - e[t - 1]; + }, + }, + { + id: "div", + min: 2, + stackDelta: -1, + stackFn(e, t) { + e[t - 2] = e[t - 2] / e[t - 1]; + }, + }, + null, + { + id: "neg", + min: 1, + stackDelta: 0, + stackFn(e, t) { + e[t - 1] = -e[t - 1]; + }, + }, + { id: "eq", min: 2, stackDelta: -1 }, + null, + null, + { id: "drop", min: 1, stackDelta: -1 }, + null, + { id: "put", min: 2, stackDelta: -2 }, + { id: "get", min: 1, stackDelta: 0 }, + { id: "ifelse", min: 4, stackDelta: -3 }, + { id: "random", min: 0, stackDelta: 1 }, + { + id: "mul", + min: 2, + stackDelta: -1, + stackFn(e, t) { + e[t - 2] = e[t - 2] * e[t - 1]; + }, + }, + null, + { id: "sqrt", min: 1, stackDelta: 0 }, + { id: "dup", min: 1, stackDelta: 1 }, + { id: "exch", min: 2, stackDelta: 0 }, + { id: "index", min: 2, stackDelta: 0 }, + { id: "roll", min: 3, stackDelta: -2 }, + null, + null, + null, + { id: "hflex", min: 7, resetStack: !0 }, + { id: "flex", min: 13, resetStack: !0 }, + { id: "hflex1", min: 9, resetStack: !0 }, + { id: "flex1", min: 11, resetStack: !0 }, + ]; +class CFFParser { + constructor(e, t, a) { + this.bytes = e.getBytes(); + this.properties = t; + this.seacAnalysisEnabled = !!a; + } + parse() { + const e = this.properties, + t = new CFF(); + this.cff = t; + const a = this.parseHeader(), + r = this.parseIndex(a.endPos), + i = this.parseIndex(r.endPos), + n = this.parseIndex(i.endPos), + s = this.parseIndex(n.endPos), + o = this.parseDict(i.obj.get(0)), + c = this.createDict(CFFTopDict, o, t.strings); + t.header = a.obj; + t.names = this.parseNameIndex(r.obj); + t.strings = this.parseStringIndex(n.obj); + t.topDict = c; + t.globalSubrIndex = s.obj; + this.parsePrivateDict(t.topDict); + t.isCIDFont = c.hasName("ROS"); + const l = c.getByName("CharStrings"), + h = this.parseIndex(l).obj, + u = c.getByName("FontMatrix"); + u && (e.fontMatrix = u); + const d = c.getByName("FontBBox"); + if (d) { + e.ascent = Math.max(d[3], d[1]); + e.descent = Math.min(d[1], d[3]); + e.ascentScaled = !0; + } + let f, g; + if (t.isCIDFont) { + const e = this.parseIndex(c.getByName("FDArray")).obj; + for (let a = 0, r = e.count; a < r; ++a) { + const r = e.get(a), + i = this.createDict(CFFTopDict, this.parseDict(r), t.strings); + this.parsePrivateDict(i); + t.fdArray.push(i); + } + g = null; + f = this.parseCharsets(c.getByName("charset"), h.count, t.strings, !0); + t.fdSelect = this.parseFDSelect(c.getByName("FDSelect"), h.count); + } else { + f = this.parseCharsets(c.getByName("charset"), h.count, t.strings, !1); + g = this.parseEncoding(c.getByName("Encoding"), e, t.strings, f.charset); + } + t.charset = f; + t.encoding = g; + const p = this.parseCharStrings({ + charStrings: h, + localSubrIndex: c.privateDict.subrsIndex, + globalSubrIndex: s.obj, + fdSelect: t.fdSelect, + fdArray: t.fdArray, + privateDict: c.privateDict, + }); + t.charStrings = p.charStrings; + t.seacs = p.seacs; + t.widths = p.widths; + return t; + } + parseHeader() { + let e = this.bytes; + const t = e.length; + let a = 0; + for (; a < t && 1 !== e[a]; ) ++a; + if (a >= t) throw new FormatError("Invalid CFF header"); + if (0 !== a) { + info("cff data is shifted"); + e = e.subarray(a); + this.bytes = e; + } + const r = e[0], + i = e[1], + n = e[2], + s = e[3]; + return { obj: new CFFHeader(r, i, n, s), endPos: n }; + } + parseDict(e) { + let t = 0; + function parseOperand() { + let a = e[t++]; + if (30 === a) + return (function parseFloatOperand() { + let a = ""; + const r = 15, + i = [ + "0", + "1", + "2", + "3", + "4", + "5", + "6", + "7", + "8", + "9", + ".", + "E", + "E-", + null, + "-", + ], + n = e.length; + for (; t < n; ) { + const n = e[t++], + s = n >> 4, + o = 15 & n; + if (s === r) break; + a += i[s]; + if (o === r) break; + a += i[o]; + } + return parseFloat(a); + })(); + if (28 === a) { + a = readInt16(e, t); + t += 2; + return a; + } + if (29 === a) { + a = e[t++]; + a = (a << 8) | e[t++]; + a = (a << 8) | e[t++]; + a = (a << 8) | e[t++]; + return a; + } + if (a >= 32 && a <= 246) return a - 139; + if (a >= 247 && a <= 250) return 256 * (a - 247) + e[t++] + 108; + if (a >= 251 && a <= 254) return -256 * (a - 251) - e[t++] - 108; + warn('CFFParser_parseDict: "' + a + '" is a reserved command.'); + return NaN; + } + let a = []; + const r = []; + t = 0; + const i = e.length; + for (; t < i; ) { + let i = e[t]; + if (i <= 21) { + 12 === i && (i = (i << 8) | e[++t]); + r.push([i, a]); + a = []; + ++t; + } else a.push(parseOperand()); + } + return r; + } + parseIndex(e) { + const t = new CFFIndex(), + a = this.bytes, + r = (a[e++] << 8) | a[e++], + i = []; + let n, + s, + o = e; + if (0 !== r) { + const t = a[e++], + c = e + (r + 1) * t - 1; + for (n = 0, s = r + 1; n < s; ++n) { + let r = 0; + for (let i = 0; i < t; ++i) { + r <<= 8; + r += a[e++]; + } + i.push(c + r); + } + o = i[r]; + } + for (n = 0, s = i.length - 1; n < s; ++n) { + const e = i[n], + r = i[n + 1]; + t.add(a.subarray(e, r)); + } + return { obj: t, endPos: o }; + } + parseNameIndex(e) { + const t = []; + for (let a = 0, r = e.count; a < r; ++a) { + const r = e.get(a); + t.push(bytesToString(r)); + } + return t; + } + parseStringIndex(e) { + const t = new CFFStrings(); + for (let a = 0, r = e.count; a < r; ++a) { + const r = e.get(a); + t.add(bytesToString(r)); + } + return t; + } + createDict(e, t, a) { + const r = new e(a); + for (const [e, a] of t) r.setByKey(e, a); + return r; + } + parseCharString(e, t, a, r) { + if (!t || e.callDepth > 10) return !1; + let i = e.stackSize; + const n = e.stack; + let s = t.length; + for (let o = 0; o < s; ) { + const c = t[o++]; + let l = null; + if (12 === c) { + const e = t[o++]; + if (0 === e) { + t[o - 2] = 139; + t[o - 1] = 22; + i = 0; + } else l = $r[e]; + } else if (28 === c) { + n[i] = readInt16(t, o); + o += 2; + i++; + } else if (14 === c) { + if (i >= 4) { + i -= 4; + if (this.seacAnalysisEnabled) { + e.seac = n.slice(i, i + 4); + return !1; + } + } + l = zr[c]; + } else if (c >= 32 && c <= 246) { + n[i] = c - 139; + i++; + } else if (c >= 247 && c <= 254) { + n[i] = + c < 251 + ? ((c - 247) << 8) + t[o] + 108 + : -((c - 251) << 8) - t[o] - 108; + o++; + i++; + } else if (255 === c) { + n[i] = + ((t[o] << 24) | (t[o + 1] << 16) | (t[o + 2] << 8) | t[o + 3]) / + 65536; + o += 4; + i++; + } else if (19 === c || 20 === c) { + e.hints += i >> 1; + if (0 === e.hints) { + t.copyWithin(o - 1, o, -1); + o -= 1; + s -= 1; + continue; + } + o += (e.hints + 7) >> 3; + i %= 2; + l = zr[c]; + } else { + if (10 === c || 29 === c) { + const t = 10 === c ? a : r; + if (!t) { + l = zr[c]; + warn("Missing subrsIndex for " + l.id); + return !1; + } + let s = 32768; + t.count < 1240 ? (s = 107) : t.count < 33900 && (s = 1131); + const o = n[--i] + s; + if (o < 0 || o >= t.count || isNaN(o)) { + l = zr[c]; + warn("Out of bounds subrIndex for " + l.id); + return !1; + } + e.stackSize = i; + e.callDepth++; + if (!this.parseCharString(e, t.get(o), a, r)) return !1; + e.callDepth--; + i = e.stackSize; + continue; + } + if (11 === c) { + e.stackSize = i; + return !0; + } + if (0 === c && o === t.length) { + t[o - 1] = 14; + l = zr[14]; + } else { + if (9 === c) { + t.copyWithin(o - 1, o, -1); + o -= 1; + s -= 1; + continue; + } + l = zr[c]; + } + } + if (l) { + if (l.stem) { + e.hints += i >> 1; + if (3 === c || 23 === c) e.hasVStems = !0; + else if (e.hasVStems && (1 === c || 18 === c)) { + warn("CFF stem hints are in wrong order"); + t[o - 1] = 1 === c ? 3 : 23; + } + } + if ("min" in l && !e.undefStack && i < l.min) { + warn( + "Not enough parameters for " + + l.id + + "; actual: " + + i + + ", expected: " + + l.min, + ); + if (0 === i) { + t[o - 1] = 14; + return !0; + } + return !1; + } + if (e.firstStackClearing && l.stackClearing) { + e.firstStackClearing = !1; + i -= l.min; + i >= 2 && l.stem + ? (i %= 2) + : i > 1 && + warn("Found too many parameters for stack-clearing command"); + i > 0 && (e.width = n[i - 1]); + } + if ("stackDelta" in l) { + "stackFn" in l && l.stackFn(n, i); + i += l.stackDelta; + } else if (l.stackClearing) i = 0; + else if (l.resetStack) { + i = 0; + e.undefStack = !1; + } else if (l.undefStack) { + i = 0; + e.undefStack = !0; + e.firstStackClearing = !1; + } + } + } + s < t.length && t.fill(14, s); + e.stackSize = i; + return !0; + } + parseCharStrings({ + charStrings: e, + localSubrIndex: t, + globalSubrIndex: a, + fdSelect: r, + fdArray: i, + privateDict: n, + }) { + const s = [], + o = [], + c = e.count; + for (let l = 0; l < c; l++) { + const c = e.get(l), + h = { + callDepth: 0, + stackSize: 0, + stack: [], + undefStack: !0, + hints: 0, + firstStackClearing: !0, + seac: null, + width: null, + hasVStems: !1, + }; + let u = !0, + d = null, + f = n; + if (r && i.length) { + const e = r.getFDIndex(l); + if (-1 === e) { + warn("Glyph index is not in fd select."); + u = !1; + } + if (e >= i.length) { + warn("Invalid fd index for glyph index."); + u = !1; + } + if (u) { + f = i[e].privateDict; + d = f.subrsIndex; + } + } else t && (d = t); + u && (u = this.parseCharString(h, c, d, a)); + if (null !== h.width) { + const e = f.getByName("nominalWidthX"); + o[l] = e + h.width; + } else { + const e = f.getByName("defaultWidthX"); + o[l] = e; + } + null !== h.seac && (s[l] = h.seac); + u || e.set(l, new Uint8Array([14])); + } + return { charStrings: e, seacs: s, widths: o }; + } + emptyPrivateDictionary(e) { + const t = this.createDict(CFFPrivateDict, [], e.strings); + e.setByKey(18, [0, 0]); + e.privateDict = t; + } + parsePrivateDict(e) { + if (!e.hasName("Private")) { + this.emptyPrivateDictionary(e); + return; + } + const t = e.getByName("Private"); + if (!Array.isArray(t) || 2 !== t.length) { + e.removeByName("Private"); + return; + } + const a = t[0], + r = t[1]; + if (0 === a || r >= this.bytes.length) { + this.emptyPrivateDictionary(e); + return; + } + const i = r + a, + n = this.bytes.subarray(r, i), + s = this.parseDict(n), + o = this.createDict(CFFPrivateDict, s, e.strings); + e.privateDict = o; + 0 === o.getByName("ExpansionFactor") && + o.setByName("ExpansionFactor", 0.06); + if (!o.getByName("Subrs")) return; + const c = o.getByName("Subrs"), + l = r + c; + if (0 === c || l >= this.bytes.length) { + this.emptyPrivateDictionary(e); + return; + } + const h = this.parseIndex(l); + o.subrsIndex = h.obj; + } + parseCharsets(e, t, a, r) { + if (0 === e) return new CFFCharset(!0, Kr.ISO_ADOBE, Ur); + if (1 === e) return new CFFCharset(!0, Kr.EXPERT, Xr); + if (2 === e) return new CFFCharset(!0, Kr.EXPERT_SUBSET, qr); + const i = this.bytes, + n = e, + s = i[e++], + o = [r ? 0 : ".notdef"]; + let c, l, h; + t -= 1; + switch (s) { + case 0: + for (h = 0; h < t; h++) { + c = (i[e++] << 8) | i[e++]; + o.push(r ? c : a.get(c)); + } + break; + case 1: + for (; o.length <= t; ) { + c = (i[e++] << 8) | i[e++]; + l = i[e++]; + for (h = 0; h <= l; h++) o.push(r ? c++ : a.get(c++)); + } + break; + case 2: + for (; o.length <= t; ) { + c = (i[e++] << 8) | i[e++]; + l = (i[e++] << 8) | i[e++]; + for (h = 0; h <= l; h++) o.push(r ? c++ : a.get(c++)); + } + break; + default: + throw new FormatError("Unknown charset format"); + } + const u = e, + d = i.subarray(n, u); + return new CFFCharset(!1, s, o, d); + } + parseEncoding(e, t, a, r) { + const i = Object.create(null), + n = this.bytes; + let s, + o, + c, + l = !1, + h = null; + if (0 === e || 1 === e) { + l = !0; + s = e; + const t = e ? wr : kr; + for (o = 0, c = r.length; o < c; o++) { + const e = t.indexOf(r[o]); + -1 !== e && (i[e] = o); + } + } else { + const t = e; + s = n[e++]; + switch (127 & s) { + case 0: + const t = n[e++]; + for (o = 1; o <= t; o++) i[n[e++]] = o; + break; + case 1: + const a = n[e++]; + let r = 1; + for (o = 0; o < a; o++) { + const t = n[e++], + a = n[e++]; + for (let e = t; e <= t + a; e++) i[e] = r++; + } + break; + default: + throw new FormatError(`Unknown encoding format: ${s} in CFF`); + } + const c = e; + if (128 & s) { + n[t] &= 127; + !(function readSupplement() { + const t = n[e++]; + for (o = 0; o < t; o++) { + const t = n[e++], + s = (n[e++] << 8) + (255 & n[e++]); + i[t] = r.indexOf(a.get(s)); + } + })(); + } + h = n.subarray(t, c); + } + s &= 127; + return new CFFEncoding(l, s, i, h); + } + parseFDSelect(e, t) { + const a = this.bytes, + r = a[e++], + i = []; + let n; + switch (r) { + case 0: + for (n = 0; n < t; ++n) { + const t = a[e++]; + i.push(t); + } + break; + case 3: + const s = (a[e++] << 8) | a[e++]; + for (n = 0; n < s; ++n) { + let t = (a[e++] << 8) | a[e++]; + if (0 === n && 0 !== t) { + warn( + "parseFDSelect: The first range must have a first GID of 0 -- trying to recover.", + ); + t = 0; + } + const r = a[e++], + s = (a[e] << 8) | a[e + 1]; + for (let e = t; e < s; ++e) i.push(r); + } + e += 2; + break; + default: + throw new FormatError(`parseFDSelect: Unknown format "${r}".`); + } + if (i.length !== t) + throw new FormatError("parseFDSelect: Invalid font data."); + return new CFFFDSelect(r, i); + } +} +class CFF { + constructor() { + this.header = null; + this.names = []; + this.topDict = null; + this.strings = new CFFStrings(); + this.globalSubrIndex = null; + this.encoding = null; + this.charset = null; + this.charStrings = null; + this.fdArray = []; + this.fdSelect = null; + this.isCIDFont = !1; + } + duplicateFirstGlyph() { + if (this.charStrings.count >= 65535) { + warn("Not enough space in charstrings to duplicate first glyph."); + return; + } + const e = this.charStrings.get(0); + this.charStrings.add(e); + this.isCIDFont && this.fdSelect.fdSelect.push(this.fdSelect.fdSelect[0]); + } + hasGlyphId(e) { + if (e < 0 || e >= this.charStrings.count) return !1; + return this.charStrings.get(e).length > 0; + } +} +class CFFHeader { + constructor(e, t, a, r) { + this.major = e; + this.minor = t; + this.hdrSize = a; + this.offSize = r; + } +} +class CFFStrings { + constructor() { + this.strings = []; + } + get(e) { + return e >= 0 && e <= 390 + ? Hr[e] + : e - Wr <= this.strings.length + ? this.strings[e - Wr] + : Hr[0]; + } + getSID(e) { + let t = Hr.indexOf(e); + if (-1 !== t) return t; + t = this.strings.indexOf(e); + return -1 !== t ? t + Wr : -1; + } + add(e) { + this.strings.push(e); + } + get count() { + return this.strings.length; + } +} +class CFFIndex { + constructor() { + this.objects = []; + this.length = 0; + } + add(e) { + this.length += e.length; + this.objects.push(e); + } + set(e, t) { + this.length += t.length - this.objects[e].length; + this.objects[e] = t; + } + get(e) { + return this.objects[e]; + } + get count() { + return this.objects.length; + } +} +class CFFDict { + constructor(e, t) { + this.keyToNameMap = e.keyToNameMap; + this.nameToKeyMap = e.nameToKeyMap; + this.defaults = e.defaults; + this.types = e.types; + this.opcodes = e.opcodes; + this.order = e.order; + this.strings = t; + this.values = Object.create(null); + } + setByKey(e, t) { + if (!(e in this.keyToNameMap)) return !1; + if (0 === t.length) return !0; + for (const a of t) + if (isNaN(a)) { + warn(`Invalid CFFDict value: "${t}" for key "${e}".`); + return !0; + } + const a = this.types[e]; + ("num" !== a && "sid" !== a && "offset" !== a) || (t = t[0]); + this.values[e] = t; + return !0; + } + setByName(e, t) { + if (!(e in this.nameToKeyMap)) + throw new FormatError(`Invalid dictionary name "${e}"`); + this.values[this.nameToKeyMap[e]] = t; + } + hasName(e) { + return this.nameToKeyMap[e] in this.values; + } + getByName(e) { + if (!(e in this.nameToKeyMap)) + throw new FormatError(`Invalid dictionary name ${e}"`); + const t = this.nameToKeyMap[e]; + return t in this.values ? this.values[t] : this.defaults[t]; + } + removeByName(e) { + delete this.values[this.nameToKeyMap[e]]; + } + static createTables(e) { + const t = { + keyToNameMap: {}, + nameToKeyMap: {}, + defaults: {}, + types: {}, + opcodes: {}, + order: [], + }; + for (const a of e) { + const e = Array.isArray(a[0]) ? (a[0][0] << 8) + a[0][1] : a[0]; + t.keyToNameMap[e] = a[1]; + t.nameToKeyMap[a[1]] = e; + t.types[e] = a[2]; + t.defaults[e] = a[3]; + t.opcodes[e] = Array.isArray(a[0]) ? a[0] : [a[0]]; + t.order.push(e); + } + return t; + } +} +const Gr = [ + [[12, 30], "ROS", ["sid", "sid", "num"], null], + [[12, 20], "SyntheticBase", "num", null], + [0, "version", "sid", null], + [1, "Notice", "sid", null], + [[12, 0], "Copyright", "sid", null], + [2, "FullName", "sid", null], + [3, "FamilyName", "sid", null], + [4, "Weight", "sid", null], + [[12, 1], "isFixedPitch", "num", 0], + [[12, 2], "ItalicAngle", "num", 0], + [[12, 3], "UnderlinePosition", "num", -100], + [[12, 4], "UnderlineThickness", "num", 50], + [[12, 5], "PaintType", "num", 0], + [[12, 6], "CharstringType", "num", 2], + [ + [12, 7], + "FontMatrix", + ["num", "num", "num", "num", "num", "num"], + [0.001, 0, 0, 0.001, 0, 0], + ], + [13, "UniqueID", "num", null], + [5, "FontBBox", ["num", "num", "num", "num"], [0, 0, 0, 0]], + [[12, 8], "StrokeWidth", "num", 0], + [14, "XUID", "array", null], + [15, "charset", "offset", 0], + [16, "Encoding", "offset", 0], + [17, "CharStrings", "offset", 0], + [18, "Private", ["offset", "offset"], null], + [[12, 21], "PostScript", "sid", null], + [[12, 22], "BaseFontName", "sid", null], + [[12, 23], "BaseFontBlend", "delta", null], + [[12, 31], "CIDFontVersion", "num", 0], + [[12, 32], "CIDFontRevision", "num", 0], + [[12, 33], "CIDFontType", "num", 0], + [[12, 34], "CIDCount", "num", 8720], + [[12, 35], "UIDBase", "num", null], + [[12, 37], "FDSelect", "offset", null], + [[12, 36], "FDArray", "offset", null], + [[12, 38], "FontName", "sid", null], +]; +class CFFTopDict extends CFFDict { + static get tables() { + return shadow(this, "tables", this.createTables(Gr)); + } + constructor(e) { + super(CFFTopDict.tables, e); + this.privateDict = null; + } +} +const Vr = [ + [6, "BlueValues", "delta", null], + [7, "OtherBlues", "delta", null], + [8, "FamilyBlues", "delta", null], + [9, "FamilyOtherBlues", "delta", null], + [[12, 9], "BlueScale", "num", 0.039625], + [[12, 10], "BlueShift", "num", 7], + [[12, 11], "BlueFuzz", "num", 1], + [10, "StdHW", "num", null], + [11, "StdVW", "num", null], + [[12, 12], "StemSnapH", "delta", null], + [[12, 13], "StemSnapV", "delta", null], + [[12, 14], "ForceBold", "num", 0], + [[12, 17], "LanguageGroup", "num", 0], + [[12, 18], "ExpansionFactor", "num", 0.06], + [[12, 19], "initialRandomSeed", "num", 0], + [20, "defaultWidthX", "num", 0], + [21, "nominalWidthX", "num", 0], + [19, "Subrs", "offset", null], +]; +class CFFPrivateDict extends CFFDict { + static get tables() { + return shadow(this, "tables", this.createTables(Vr)); + } + constructor(e) { + super(CFFPrivateDict.tables, e); + this.subrsIndex = null; + } +} +const Kr = { ISO_ADOBE: 0, EXPERT: 1, EXPERT_SUBSET: 2 }; +class CFFCharset { + constructor(e, t, a, r) { + this.predefined = e; + this.format = t; + this.charset = a; + this.raw = r; + } +} +class CFFEncoding { + constructor(e, t, a, r) { + this.predefined = e; + this.format = t; + this.encoding = a; + this.raw = r; + } +} +class CFFFDSelect { + constructor(e, t) { + this.format = e; + this.fdSelect = t; + } + getFDIndex(e) { + return e < 0 || e >= this.fdSelect.length ? -1 : this.fdSelect[e]; + } +} +class CFFOffsetTracker { + constructor() { + this.offsets = Object.create(null); + } + isTracking(e) { + return e in this.offsets; + } + track(e, t) { + if (e in this.offsets) + throw new FormatError(`Already tracking location of ${e}`); + this.offsets[e] = t; + } + offset(e) { + for (const t in this.offsets) this.offsets[t] += e; + } + setEntryLocation(e, t, a) { + if (!(e in this.offsets)) + throw new FormatError(`Not tracking location of ${e}`); + const r = a.data, + i = this.offsets[e]; + for (let e = 0, a = t.length; e < a; ++e) { + const a = 5 * e + i, + n = a + 1, + s = a + 2, + o = a + 3, + c = a + 4; + if (29 !== r[a] || 0 !== r[n] || 0 !== r[s] || 0 !== r[o] || 0 !== r[c]) + throw new FormatError("writing to an offset that is not empty"); + const l = t[e]; + r[a] = 29; + r[n] = (l >> 24) & 255; + r[s] = (l >> 16) & 255; + r[o] = (l >> 8) & 255; + r[c] = 255 & l; + } + } +} +class CFFCompiler { + constructor(e) { + this.cff = e; + } + compile() { + const e = this.cff, + t = { + data: [], + length: 0, + add(e) { + try { + this.data.push(...e); + } catch { + this.data = this.data.concat(e); + } + this.length = this.data.length; + }, + }, + a = this.compileHeader(e.header); + t.add(a); + const r = this.compileNameIndex(e.names); + t.add(r); + if (e.isCIDFont && e.topDict.hasName("FontMatrix")) { + const t = e.topDict.getByName("FontMatrix"); + e.topDict.removeByName("FontMatrix"); + for (const a of e.fdArray) { + let e = t.slice(0); + a.hasName("FontMatrix") && + (e = Util.transform(e, a.getByName("FontMatrix"))); + a.setByName("FontMatrix", e); + } + } + const i = e.topDict.getByName("XUID"); + i?.length > 16 && e.topDict.removeByName("XUID"); + e.topDict.setByName("charset", 0); + let n = this.compileTopDicts([e.topDict], t.length, e.isCIDFont); + t.add(n.output); + const s = n.trackers[0], + o = this.compileStringIndex(e.strings.strings); + t.add(o); + const c = this.compileIndex(e.globalSubrIndex); + t.add(c); + if (e.encoding && e.topDict.hasName("Encoding")) + if (e.encoding.predefined) + s.setEntryLocation("Encoding", [e.encoding.format], t); + else { + const a = this.compileEncoding(e.encoding); + s.setEntryLocation("Encoding", [t.length], t); + t.add(a); + } + const l = this.compileCharset( + e.charset, + e.charStrings.count, + e.strings, + e.isCIDFont, + ); + s.setEntryLocation("charset", [t.length], t); + t.add(l); + const h = this.compileCharStrings(e.charStrings); + s.setEntryLocation("CharStrings", [t.length], t); + t.add(h); + if (e.isCIDFont) { + s.setEntryLocation("FDSelect", [t.length], t); + const a = this.compileFDSelect(e.fdSelect); + t.add(a); + n = this.compileTopDicts(e.fdArray, t.length, !0); + s.setEntryLocation("FDArray", [t.length], t); + t.add(n.output); + const r = n.trackers; + this.compilePrivateDicts(e.fdArray, r, t); + } + this.compilePrivateDicts([e.topDict], [s], t); + t.add([0]); + return t.data; + } + encodeNumber(e) { + return Number.isInteger(e) ? this.encodeInteger(e) : this.encodeFloat(e); + } + static get EncodeFloatRegExp() { + return shadow( + this, + "EncodeFloatRegExp", + /\.(\d*?)(?:9{5,20}|0{5,20})\d{0,2}(?:e(.+)|$)/, + ); + } + encodeFloat(e) { + let t = e.toString(); + const a = CFFCompiler.EncodeFloatRegExp.exec(t); + if (a) { + const r = parseFloat("1e" + ((a[2] ? +a[2] : 0) + a[1].length)); + t = (Math.round(e * r) / r).toString(); + } + let r, + i, + n = ""; + for (r = 0, i = t.length; r < i; ++r) { + const e = t[r]; + n += + "e" === e + ? "-" === t[++r] + ? "c" + : "b" + : "." === e + ? "a" + : "-" === e + ? "e" + : e; + } + n += 1 & n.length ? "f" : "ff"; + const s = [30]; + for (r = 0, i = n.length; r < i; r += 2) + s.push(parseInt(n.substring(r, r + 2), 16)); + return s; + } + encodeInteger(e) { + let t; + t = + e >= -107 && e <= 107 + ? [e + 139] + : e >= 108 && e <= 1131 + ? [247 + ((e -= 108) >> 8), 255 & e] + : e >= -1131 && e <= -108 + ? [251 + ((e = -e - 108) >> 8), 255 & e] + : e >= -32768 && e <= 32767 + ? [28, (e >> 8) & 255, 255 & e] + : [29, (e >> 24) & 255, (e >> 16) & 255, (e >> 8) & 255, 255 & e]; + return t; + } + compileHeader(e) { + return [e.major, e.minor, 4, e.offSize]; + } + compileNameIndex(e) { + const t = new CFFIndex(); + for (const a of e) { + const e = Math.min(a.length, 127); + let r = new Array(e); + for (let t = 0; t < e; t++) { + let e = a[t]; + (e < "!" || + e > "~" || + "[" === e || + "]" === e || + "(" === e || + ")" === e || + "{" === e || + "}" === e || + "<" === e || + ">" === e || + "/" === e || + "%" === e) && + (e = "_"); + r[t] = e; + } + r = r.join(""); + "" === r && (r = "Bad_Font_Name"); + t.add(stringToBytes(r)); + } + return this.compileIndex(t); + } + compileTopDicts(e, t, a) { + const r = []; + let i = new CFFIndex(); + for (const n of e) { + if (a) { + n.removeByName("CIDFontVersion"); + n.removeByName("CIDFontRevision"); + n.removeByName("CIDFontType"); + n.removeByName("CIDCount"); + n.removeByName("UIDBase"); + } + const e = new CFFOffsetTracker(), + s = this.compileDict(n, e); + r.push(e); + i.add(s); + e.offset(t); + } + i = this.compileIndex(i, r); + return { trackers: r, output: i }; + } + compilePrivateDicts(e, t, a) { + for (let r = 0, i = e.length; r < i; ++r) { + const i = e[r], + n = i.privateDict; + if (!n || !i.hasName("Private")) + throw new FormatError("There must be a private dictionary."); + const s = new CFFOffsetTracker(), + o = this.compileDict(n, s); + let c = a.length; + s.offset(c); + o.length || (c = 0); + t[r].setEntryLocation("Private", [o.length, c], a); + a.add(o); + if (n.subrsIndex && n.hasName("Subrs")) { + const e = this.compileIndex(n.subrsIndex); + s.setEntryLocation("Subrs", [o.length], a); + a.add(e); + } + } + } + compileDict(e, t) { + const a = []; + for (const r of e.order) { + if (!(r in e.values)) continue; + let i = e.values[r], + n = e.types[r]; + Array.isArray(n) || (n = [n]); + Array.isArray(i) || (i = [i]); + if (0 !== i.length) { + for (let s = 0, o = n.length; s < o; ++s) { + const o = n[s], + c = i[s]; + switch (o) { + case "num": + case "sid": + a.push(...this.encodeNumber(c)); + break; + case "offset": + const n = e.keyToNameMap[r]; + t.isTracking(n) || t.track(n, a.length); + a.push(29, 0, 0, 0, 0); + break; + case "array": + case "delta": + a.push(...this.encodeNumber(c)); + for (let e = 1, t = i.length; e < t; ++e) + a.push(...this.encodeNumber(i[e])); + break; + default: + throw new FormatError(`Unknown data type of ${o}`); + } + } + a.push(...e.opcodes[r]); + } + } + return a; + } + compileStringIndex(e) { + const t = new CFFIndex(); + for (const a of e) t.add(stringToBytes(a)); + return this.compileIndex(t); + } + compileCharStrings(e) { + const t = new CFFIndex(); + for (let a = 0; a < e.count; a++) { + const r = e.get(a); + 0 !== r.length ? t.add(r) : t.add(new Uint8Array([139, 14])); + } + return this.compileIndex(t); + } + compileCharset(e, t, a, r) { + let i; + const n = t - 1; + if (r) { + const e = n - 1; + i = new Uint8Array([2, 0, 1, (e >> 8) & 255, 255 & e]); + } else { + i = new Uint8Array(1 + 2 * n); + i[0] = 0; + let t = 0; + const r = e.charset.length; + let s = !1; + for (let n = 1; n < i.length; n += 2) { + let o = 0; + if (t < r) { + const r = e.charset[t++]; + o = a.getSID(r); + if (-1 === o) { + o = 0; + if (!s) { + s = !0; + warn(`Couldn't find ${r} in CFF strings`); + } + } + } + i[n] = (o >> 8) & 255; + i[n + 1] = 255 & o; + } + } + return this.compileTypedArray(i); + } + compileEncoding(e) { + return this.compileTypedArray(e.raw); + } + compileFDSelect(e) { + const t = e.format; + let a, r; + switch (t) { + case 0: + a = new Uint8Array(1 + e.fdSelect.length); + a[0] = t; + for (r = 0; r < e.fdSelect.length; r++) a[r + 1] = e.fdSelect[r]; + break; + case 3: + const i = 0; + let n = e.fdSelect[0]; + const s = [t, 0, 0, (i >> 8) & 255, 255 & i, n]; + for (r = 1; r < e.fdSelect.length; r++) { + const t = e.fdSelect[r]; + if (t !== n) { + s.push((r >> 8) & 255, 255 & r, t); + n = t; + } + } + const o = (s.length - 3) / 3; + s[1] = (o >> 8) & 255; + s[2] = 255 & o; + s.push((r >> 8) & 255, 255 & r); + a = new Uint8Array(s); + } + return this.compileTypedArray(a); + } + compileTypedArray(e) { + return Array.from(e); + } + compileIndex(e, t = []) { + const a = e.objects, + r = a.length; + if (0 === r) return [0, 0]; + const i = [(r >> 8) & 255, 255 & r]; + let n, + s, + o = 1; + for (n = 0; n < r; ++n) o += a[n].length; + s = o < 256 ? 1 : o < 65536 ? 2 : o < 16777216 ? 3 : 4; + i.push(s); + let c = 1; + for (n = 0; n < r + 1; n++) { + 1 === s + ? i.push(255 & c) + : 2 === s + ? i.push((c >> 8) & 255, 255 & c) + : 3 === s + ? i.push((c >> 16) & 255, (c >> 8) & 255, 255 & c) + : i.push( + (c >>> 24) & 255, + (c >> 16) & 255, + (c >> 8) & 255, + 255 & c, + ); + a[n] && (c += a[n].length); + } + for (n = 0; n < r; n++) { + t[n] && t[n].offset(i.length); + i.push(...a[n]); + } + return i; + } +} +const Jr = getLookupTableFactory(function (e) { + e["Times-Roman"] = "Times-Roman"; + e.Helvetica = "Helvetica"; + e.Courier = "Courier"; + e.Symbol = "Symbol"; + e["Times-Bold"] = "Times-Bold"; + e["Helvetica-Bold"] = "Helvetica-Bold"; + e["Courier-Bold"] = "Courier-Bold"; + e.ZapfDingbats = "ZapfDingbats"; + e["Times-Italic"] = "Times-Italic"; + e["Helvetica-Oblique"] = "Helvetica-Oblique"; + e["Courier-Oblique"] = "Courier-Oblique"; + e["Times-BoldItalic"] = "Times-BoldItalic"; + e["Helvetica-BoldOblique"] = "Helvetica-BoldOblique"; + e["Courier-BoldOblique"] = "Courier-BoldOblique"; + e.ArialNarrow = "Helvetica"; + e["ArialNarrow-Bold"] = "Helvetica-Bold"; + e["ArialNarrow-BoldItalic"] = "Helvetica-BoldOblique"; + e["ArialNarrow-Italic"] = "Helvetica-Oblique"; + e.ArialBlack = "Helvetica"; + e["ArialBlack-Bold"] = "Helvetica-Bold"; + e["ArialBlack-BoldItalic"] = "Helvetica-BoldOblique"; + e["ArialBlack-Italic"] = "Helvetica-Oblique"; + e["Arial-Black"] = "Helvetica"; + e["Arial-Black-Bold"] = "Helvetica-Bold"; + e["Arial-Black-BoldItalic"] = "Helvetica-BoldOblique"; + e["Arial-Black-Italic"] = "Helvetica-Oblique"; + e.Arial = "Helvetica"; + e["Arial-Bold"] = "Helvetica-Bold"; + e["Arial-BoldItalic"] = "Helvetica-BoldOblique"; + e["Arial-Italic"] = "Helvetica-Oblique"; + e.ArialMT = "Helvetica"; + e["Arial-BoldItalicMT"] = "Helvetica-BoldOblique"; + e["Arial-BoldMT"] = "Helvetica-Bold"; + e["Arial-ItalicMT"] = "Helvetica-Oblique"; + e["Arial-BoldItalicMT-BoldItalic"] = "Helvetica-BoldOblique"; + e["Arial-BoldMT-Bold"] = "Helvetica-Bold"; + e["Arial-ItalicMT-Italic"] = "Helvetica-Oblique"; + e.ArialUnicodeMS = "Helvetica"; + e["ArialUnicodeMS-Bold"] = "Helvetica-Bold"; + e["ArialUnicodeMS-BoldItalic"] = "Helvetica-BoldOblique"; + e["ArialUnicodeMS-Italic"] = "Helvetica-Oblique"; + e["Courier-BoldItalic"] = "Courier-BoldOblique"; + e["Courier-Italic"] = "Courier-Oblique"; + e.CourierNew = "Courier"; + e["CourierNew-Bold"] = "Courier-Bold"; + e["CourierNew-BoldItalic"] = "Courier-BoldOblique"; + e["CourierNew-Italic"] = "Courier-Oblique"; + e["CourierNewPS-BoldItalicMT"] = "Courier-BoldOblique"; + e["CourierNewPS-BoldMT"] = "Courier-Bold"; + e["CourierNewPS-ItalicMT"] = "Courier-Oblique"; + e.CourierNewPSMT = "Courier"; + e["Helvetica-BoldItalic"] = "Helvetica-BoldOblique"; + e["Helvetica-Italic"] = "Helvetica-Oblique"; + e["HelveticaLTStd-Bold"] = "Helvetica-Bold"; + e["Symbol-Bold"] = "Symbol"; + e["Symbol-BoldItalic"] = "Symbol"; + e["Symbol-Italic"] = "Symbol"; + e.TimesNewRoman = "Times-Roman"; + e["TimesNewRoman-Bold"] = "Times-Bold"; + e["TimesNewRoman-BoldItalic"] = "Times-BoldItalic"; + e["TimesNewRoman-Italic"] = "Times-Italic"; + e.TimesNewRomanPS = "Times-Roman"; + e["TimesNewRomanPS-Bold"] = "Times-Bold"; + e["TimesNewRomanPS-BoldItalic"] = "Times-BoldItalic"; + e["TimesNewRomanPS-BoldItalicMT"] = "Times-BoldItalic"; + e["TimesNewRomanPS-BoldMT"] = "Times-Bold"; + e["TimesNewRomanPS-Italic"] = "Times-Italic"; + e["TimesNewRomanPS-ItalicMT"] = "Times-Italic"; + e.TimesNewRomanPSMT = "Times-Roman"; + e["TimesNewRomanPSMT-Bold"] = "Times-Bold"; + e["TimesNewRomanPSMT-BoldItalic"] = "Times-BoldItalic"; + e["TimesNewRomanPSMT-Italic"] = "Times-Italic"; + }), + Yr = getLookupTableFactory(function (e) { + e.Courier = "FoxitFixed.pfb"; + e["Courier-Bold"] = "FoxitFixedBold.pfb"; + e["Courier-BoldOblique"] = "FoxitFixedBoldItalic.pfb"; + e["Courier-Oblique"] = "FoxitFixedItalic.pfb"; + e.Helvetica = "LiberationSans-Regular.ttf"; + e["Helvetica-Bold"] = "LiberationSans-Bold.ttf"; + e["Helvetica-BoldOblique"] = "LiberationSans-BoldItalic.ttf"; + e["Helvetica-Oblique"] = "LiberationSans-Italic.ttf"; + e["Times-Roman"] = "FoxitSerif.pfb"; + e["Times-Bold"] = "FoxitSerifBold.pfb"; + e["Times-BoldItalic"] = "FoxitSerifBoldItalic.pfb"; + e["Times-Italic"] = "FoxitSerifItalic.pfb"; + e.Symbol = "FoxitSymbol.pfb"; + e.ZapfDingbats = "FoxitDingbats.pfb"; + e["LiberationSans-Regular"] = "LiberationSans-Regular.ttf"; + e["LiberationSans-Bold"] = "LiberationSans-Bold.ttf"; + e["LiberationSans-Italic"] = "LiberationSans-Italic.ttf"; + e["LiberationSans-BoldItalic"] = "LiberationSans-BoldItalic.ttf"; + }), + Zr = getLookupTableFactory(function (e) { + e.Calibri = "Helvetica"; + e["Calibri-Bold"] = "Helvetica-Bold"; + e["Calibri-BoldItalic"] = "Helvetica-BoldOblique"; + e["Calibri-Italic"] = "Helvetica-Oblique"; + e.CenturyGothic = "Helvetica"; + e["CenturyGothic-Bold"] = "Helvetica-Bold"; + e["CenturyGothic-BoldItalic"] = "Helvetica-BoldOblique"; + e["CenturyGothic-Italic"] = "Helvetica-Oblique"; + e.ComicSansMS = "Comic Sans MS"; + e["ComicSansMS-Bold"] = "Comic Sans MS-Bold"; + e["ComicSansMS-BoldItalic"] = "Comic Sans MS-BoldItalic"; + e["ComicSansMS-Italic"] = "Comic Sans MS-Italic"; + e.GillSansMT = "Helvetica"; + e["GillSansMT-Bold"] = "Helvetica-Bold"; + e["GillSansMT-BoldItalic"] = "Helvetica-BoldOblique"; + e["GillSansMT-Italic"] = "Helvetica-Oblique"; + e.Impact = "Helvetica"; + e["ItcSymbol-Bold"] = "Helvetica-Bold"; + e["ItcSymbol-BoldItalic"] = "Helvetica-BoldOblique"; + e["ItcSymbol-Book"] = "Helvetica"; + e["ItcSymbol-BookItalic"] = "Helvetica-Oblique"; + e["ItcSymbol-Medium"] = "Helvetica"; + e["ItcSymbol-MediumItalic"] = "Helvetica-Oblique"; + e.LucidaConsole = "Courier"; + e["LucidaConsole-Bold"] = "Courier-Bold"; + e["LucidaConsole-BoldItalic"] = "Courier-BoldOblique"; + e["LucidaConsole-Italic"] = "Courier-Oblique"; + e["LucidaSans-Demi"] = "Helvetica-Bold"; + e["MS-Gothic"] = "MS Gothic"; + e["MS-Gothic-Bold"] = "MS Gothic-Bold"; + e["MS-Gothic-BoldItalic"] = "MS Gothic-BoldItalic"; + e["MS-Gothic-Italic"] = "MS Gothic-Italic"; + e["MS-Mincho"] = "MS Mincho"; + e["MS-Mincho-Bold"] = "MS Mincho-Bold"; + e["MS-Mincho-BoldItalic"] = "MS Mincho-BoldItalic"; + e["MS-Mincho-Italic"] = "MS Mincho-Italic"; + e["MS-PGothic"] = "MS PGothic"; + e["MS-PGothic-Bold"] = "MS PGothic-Bold"; + e["MS-PGothic-BoldItalic"] = "MS PGothic-BoldItalic"; + e["MS-PGothic-Italic"] = "MS PGothic-Italic"; + e["MS-PMincho"] = "MS PMincho"; + e["MS-PMincho-Bold"] = "MS PMincho-Bold"; + e["MS-PMincho-BoldItalic"] = "MS PMincho-BoldItalic"; + e["MS-PMincho-Italic"] = "MS PMincho-Italic"; + e.NuptialScript = "Times-Italic"; + e.SegoeUISymbol = "Helvetica"; + }), + Qr = getLookupTableFactory(function (e) { + e["Adobe Jenson"] = !0; + e["Adobe Text"] = !0; + e.Albertus = !0; + e.Aldus = !0; + e.Alexandria = !0; + e.Algerian = !0; + e["American Typewriter"] = !0; + e.Antiqua = !0; + e.Apex = !0; + e.Arno = !0; + e.Aster = !0; + e.Aurora = !0; + e.Baskerville = !0; + e.Bell = !0; + e.Bembo = !0; + e["Bembo Schoolbook"] = !0; + e.Benguiat = !0; + e["Berkeley Old Style"] = !0; + e["Bernhard Modern"] = !0; + e["Berthold City"] = !0; + e.Bodoni = !0; + e["Bauer Bodoni"] = !0; + e["Book Antiqua"] = !0; + e.Bookman = !0; + e["Bordeaux Roman"] = !0; + e["Californian FB"] = !0; + e.Calisto = !0; + e.Calvert = !0; + e.Capitals = !0; + e.Cambria = !0; + e.Cartier = !0; + e.Caslon = !0; + e.Catull = !0; + e.Centaur = !0; + e["Century Old Style"] = !0; + e["Century Schoolbook"] = !0; + e.Chaparral = !0; + e["Charis SIL"] = !0; + e.Cheltenham = !0; + e["Cholla Slab"] = !0; + e.Clarendon = !0; + e.Clearface = !0; + e.Cochin = !0; + e.Colonna = !0; + e["Computer Modern"] = !0; + e["Concrete Roman"] = !0; + e.Constantia = !0; + e["Cooper Black"] = !0; + e.Corona = !0; + e.Ecotype = !0; + e.Egyptienne = !0; + e.Elephant = !0; + e.Excelsior = !0; + e.Fairfield = !0; + e["FF Scala"] = !0; + e.Folkard = !0; + e.Footlight = !0; + e.FreeSerif = !0; + e["Friz Quadrata"] = !0; + e.Garamond = !0; + e.Gentium = !0; + e.Georgia = !0; + e.Gloucester = !0; + e["Goudy Old Style"] = !0; + e["Goudy Schoolbook"] = !0; + e["Goudy Pro Font"] = !0; + e.Granjon = !0; + e["Guardian Egyptian"] = !0; + e.Heather = !0; + e.Hercules = !0; + e["High Tower Text"] = !0; + e.Hiroshige = !0; + e["Hoefler Text"] = !0; + e["Humana Serif"] = !0; + e.Imprint = !0; + e["Ionic No. 5"] = !0; + e.Janson = !0; + e.Joanna = !0; + e.Korinna = !0; + e.Lexicon = !0; + e.LiberationSerif = !0; + e["Liberation Serif"] = !0; + e["Linux Libertine"] = !0; + e.Literaturnaya = !0; + e.Lucida = !0; + e["Lucida Bright"] = !0; + e.Melior = !0; + e.Memphis = !0; + e.Miller = !0; + e.Minion = !0; + e.Modern = !0; + e["Mona Lisa"] = !0; + e["Mrs Eaves"] = !0; + e["MS Serif"] = !0; + e["Museo Slab"] = !0; + e["New York"] = !0; + e["Nimbus Roman"] = !0; + e["NPS Rawlinson Roadway"] = !0; + e.NuptialScript = !0; + e.Palatino = !0; + e.Perpetua = !0; + e.Plantin = !0; + e["Plantin Schoolbook"] = !0; + e.Playbill = !0; + e["Poor Richard"] = !0; + e["Rawlinson Roadway"] = !0; + e.Renault = !0; + e.Requiem = !0; + e.Rockwell = !0; + e.Roman = !0; + e["Rotis Serif"] = !0; + e.Sabon = !0; + e.Scala = !0; + e.Seagull = !0; + e.Sistina = !0; + e.Souvenir = !0; + e.STIX = !0; + e["Stone Informal"] = !0; + e["Stone Serif"] = !0; + e.Sylfaen = !0; + e.Times = !0; + e.Trajan = !0; + e["Trinité"] = !0; + e["Trump Mediaeval"] = !0; + e.Utopia = !0; + e["Vale Type"] = !0; + e["Bitstream Vera"] = !0; + e["Vera Serif"] = !0; + e.Versailles = !0; + e.Wanted = !0; + e.Weiss = !0; + e["Wide Latin"] = !0; + e.Windsor = !0; + e.XITS = !0; + }), + ei = getLookupTableFactory(function (e) { + e.Dingbats = !0; + e.Symbol = !0; + e.ZapfDingbats = !0; + e.Wingdings = !0; + e["Wingdings-Bold"] = !0; + e["Wingdings-Regular"] = !0; + }), + ti = getLookupTableFactory(function (e) { + e[2] = 10; + e[3] = 32; + e[4] = 33; + e[5] = 34; + e[6] = 35; + e[7] = 36; + e[8] = 37; + e[9] = 38; + e[10] = 39; + e[11] = 40; + e[12] = 41; + e[13] = 42; + e[14] = 43; + e[15] = 44; + e[16] = 45; + e[17] = 46; + e[18] = 47; + e[19] = 48; + e[20] = 49; + e[21] = 50; + e[22] = 51; + e[23] = 52; + e[24] = 53; + e[25] = 54; + e[26] = 55; + e[27] = 56; + e[28] = 57; + e[29] = 58; + e[30] = 894; + e[31] = 60; + e[32] = 61; + e[33] = 62; + e[34] = 63; + e[35] = 64; + e[36] = 65; + e[37] = 66; + e[38] = 67; + e[39] = 68; + e[40] = 69; + e[41] = 70; + e[42] = 71; + e[43] = 72; + e[44] = 73; + e[45] = 74; + e[46] = 75; + e[47] = 76; + e[48] = 77; + e[49] = 78; + e[50] = 79; + e[51] = 80; + e[52] = 81; + e[53] = 82; + e[54] = 83; + e[55] = 84; + e[56] = 85; + e[57] = 86; + e[58] = 87; + e[59] = 88; + e[60] = 89; + e[61] = 90; + e[62] = 91; + e[63] = 92; + e[64] = 93; + e[65] = 94; + e[66] = 95; + e[67] = 96; + e[68] = 97; + e[69] = 98; + e[70] = 99; + e[71] = 100; + e[72] = 101; + e[73] = 102; + e[74] = 103; + e[75] = 104; + e[76] = 105; + e[77] = 106; + e[78] = 107; + e[79] = 108; + e[80] = 109; + e[81] = 110; + e[82] = 111; + e[83] = 112; + e[84] = 113; + e[85] = 114; + e[86] = 115; + e[87] = 116; + e[88] = 117; + e[89] = 118; + e[90] = 119; + e[91] = 120; + e[92] = 121; + e[93] = 122; + e[94] = 123; + e[95] = 124; + e[96] = 125; + e[97] = 126; + e[98] = 196; + e[99] = 197; + e[100] = 199; + e[101] = 201; + e[102] = 209; + e[103] = 214; + e[104] = 220; + e[105] = 225; + e[106] = 224; + e[107] = 226; + e[108] = 228; + e[109] = 227; + e[110] = 229; + e[111] = 231; + e[112] = 233; + e[113] = 232; + e[114] = 234; + e[115] = 235; + e[116] = 237; + e[117] = 236; + e[118] = 238; + e[119] = 239; + e[120] = 241; + e[121] = 243; + e[122] = 242; + e[123] = 244; + e[124] = 246; + e[125] = 245; + e[126] = 250; + e[127] = 249; + e[128] = 251; + e[129] = 252; + e[130] = 8224; + e[131] = 176; + e[132] = 162; + e[133] = 163; + e[134] = 167; + e[135] = 8226; + e[136] = 182; + e[137] = 223; + e[138] = 174; + e[139] = 169; + e[140] = 8482; + e[141] = 180; + e[142] = 168; + e[143] = 8800; + e[144] = 198; + e[145] = 216; + e[146] = 8734; + e[147] = 177; + e[148] = 8804; + e[149] = 8805; + e[150] = 165; + e[151] = 181; + e[152] = 8706; + e[153] = 8721; + e[154] = 8719; + e[156] = 8747; + e[157] = 170; + e[158] = 186; + e[159] = 8486; + e[160] = 230; + e[161] = 248; + e[162] = 191; + e[163] = 161; + e[164] = 172; + e[165] = 8730; + e[166] = 402; + e[167] = 8776; + e[168] = 8710; + e[169] = 171; + e[170] = 187; + e[171] = 8230; + e[179] = 8220; + e[180] = 8221; + e[181] = 8216; + e[182] = 8217; + e[200] = 193; + e[203] = 205; + e[207] = 211; + e[210] = 218; + e[223] = 711; + e[224] = 321; + e[225] = 322; + e[226] = 352; + e[227] = 353; + e[228] = 381; + e[229] = 382; + e[233] = 221; + e[234] = 253; + e[252] = 263; + e[253] = 268; + e[254] = 269; + e[258] = 258; + e[260] = 260; + e[261] = 261; + e[265] = 280; + e[266] = 281; + e[267] = 282; + e[268] = 283; + e[269] = 313; + e[275] = 323; + e[276] = 324; + e[278] = 328; + e[283] = 344; + e[284] = 345; + e[285] = 346; + e[286] = 347; + e[292] = 367; + e[295] = 377; + e[296] = 378; + e[298] = 380; + e[305] = 963; + e[306] = 964; + e[307] = 966; + e[308] = 8215; + e[309] = 8252; + e[310] = 8319; + e[311] = 8359; + e[312] = 8592; + e[313] = 8593; + e[337] = 9552; + e[493] = 1039; + e[494] = 1040; + e[570] = 1040; + e[571] = 1041; + e[572] = 1042; + e[573] = 1043; + e[574] = 1044; + e[575] = 1045; + e[576] = 1046; + e[577] = 1047; + e[578] = 1048; + e[579] = 1049; + e[580] = 1050; + e[581] = 1051; + e[582] = 1052; + e[583] = 1053; + e[584] = 1054; + e[585] = 1055; + e[586] = 1056; + e[587] = 1057; + e[588] = 1058; + e[589] = 1059; + e[590] = 1060; + e[591] = 1061; + e[592] = 1062; + e[593] = 1063; + e[594] = 1064; + e[595] = 1065; + e[596] = 1066; + e[597] = 1067; + e[598] = 1068; + e[599] = 1069; + e[600] = 1070; + e[672] = 1488; + e[673] = 1489; + e[674] = 1490; + e[675] = 1491; + e[676] = 1492; + e[677] = 1493; + e[678] = 1494; + e[679] = 1495; + e[680] = 1496; + e[681] = 1497; + e[682] = 1498; + e[683] = 1499; + e[684] = 1500; + e[685] = 1501; + e[686] = 1502; + e[687] = 1503; + e[688] = 1504; + e[689] = 1505; + e[690] = 1506; + e[691] = 1507; + e[692] = 1508; + e[693] = 1509; + e[694] = 1510; + e[695] = 1511; + e[696] = 1512; + e[697] = 1513; + e[698] = 1514; + e[705] = 1524; + e[706] = 8362; + e[710] = 64288; + e[711] = 64298; + e[759] = 1617; + e[761] = 1776; + e[763] = 1778; + e[775] = 1652; + e[777] = 1764; + e[778] = 1780; + e[779] = 1781; + e[780] = 1782; + e[782] = 771; + e[783] = 64726; + e[786] = 8363; + e[788] = 8532; + e[790] = 768; + e[791] = 769; + e[792] = 768; + e[795] = 803; + e[797] = 64336; + e[798] = 64337; + e[799] = 64342; + e[800] = 64343; + e[801] = 64344; + e[802] = 64345; + e[803] = 64362; + e[804] = 64363; + e[805] = 64364; + e[2424] = 7821; + e[2425] = 7822; + e[2426] = 7823; + e[2427] = 7824; + e[2428] = 7825; + e[2429] = 7826; + e[2430] = 7827; + e[2433] = 7682; + e[2678] = 8045; + e[2679] = 8046; + e[2830] = 1552; + e[2838] = 686; + e[2840] = 751; + e[2842] = 753; + e[2843] = 754; + e[2844] = 755; + e[2846] = 757; + e[2856] = 767; + e[2857] = 848; + e[2858] = 849; + e[2862] = 853; + e[2863] = 854; + e[2864] = 855; + e[2865] = 861; + e[2866] = 862; + e[2906] = 7460; + e[2908] = 7462; + e[2909] = 7463; + e[2910] = 7464; + e[2912] = 7466; + e[2913] = 7467; + e[2914] = 7468; + e[2916] = 7470; + e[2917] = 7471; + e[2918] = 7472; + e[2920] = 7474; + e[2921] = 7475; + e[2922] = 7476; + e[2924] = 7478; + e[2925] = 7479; + e[2926] = 7480; + e[2928] = 7482; + e[2929] = 7483; + e[2930] = 7484; + e[2932] = 7486; + e[2933] = 7487; + e[2934] = 7488; + e[2936] = 7490; + e[2937] = 7491; + e[2938] = 7492; + e[2940] = 7494; + e[2941] = 7495; + e[2942] = 7496; + e[2944] = 7498; + e[2946] = 7500; + e[2948] = 7502; + e[2950] = 7504; + e[2951] = 7505; + e[2952] = 7506; + e[2954] = 7508; + e[2955] = 7509; + e[2956] = 7510; + e[2958] = 7512; + e[2959] = 7513; + e[2960] = 7514; + e[2962] = 7516; + e[2963] = 7517; + e[2964] = 7518; + e[2966] = 7520; + e[2967] = 7521; + e[2968] = 7522; + e[2970] = 7524; + e[2971] = 7525; + e[2972] = 7526; + e[2974] = 7528; + e[2975] = 7529; + e[2976] = 7530; + e[2978] = 1537; + e[2979] = 1538; + e[2980] = 1539; + e[2982] = 1549; + e[2983] = 1551; + e[2984] = 1552; + e[2986] = 1554; + e[2987] = 1555; + e[2988] = 1556; + e[2990] = 1623; + e[2991] = 1624; + e[2995] = 1775; + e[2999] = 1791; + e[3002] = 64290; + e[3003] = 64291; + e[3004] = 64292; + e[3006] = 64294; + e[3007] = 64295; + e[3008] = 64296; + e[3011] = 1900; + e[3014] = 8223; + e[3015] = 8244; + e[3017] = 7532; + e[3018] = 7533; + e[3019] = 7534; + e[3075] = 7590; + e[3076] = 7591; + e[3079] = 7594; + e[3080] = 7595; + e[3083] = 7598; + e[3084] = 7599; + e[3087] = 7602; + e[3088] = 7603; + e[3091] = 7606; + e[3092] = 7607; + e[3095] = 7610; + e[3096] = 7611; + e[3099] = 7614; + e[3100] = 7615; + e[3103] = 7618; + e[3104] = 7619; + e[3107] = 8337; + e[3108] = 8338; + e[3116] = 1884; + e[3119] = 1885; + e[3120] = 1885; + e[3123] = 1886; + e[3124] = 1886; + e[3127] = 1887; + e[3128] = 1887; + e[3131] = 1888; + e[3132] = 1888; + e[3135] = 1889; + e[3136] = 1889; + e[3139] = 1890; + e[3140] = 1890; + e[3143] = 1891; + e[3144] = 1891; + e[3147] = 1892; + e[3148] = 1892; + e[3153] = 580; + e[3154] = 581; + e[3157] = 584; + e[3158] = 585; + e[3161] = 588; + e[3162] = 589; + e[3165] = 891; + e[3166] = 892; + e[3169] = 1274; + e[3170] = 1275; + e[3173] = 1278; + e[3174] = 1279; + e[3181] = 7622; + e[3182] = 7623; + e[3282] = 11799; + e[3316] = 578; + e[3379] = 42785; + e[3393] = 1159; + e[3416] = 8377; + }), + ai = getLookupTableFactory(function (e) { + e[227] = 322; + e[264] = 261; + e[291] = 346; + }), + ri = getLookupTableFactory(function (e) { + e[1] = 32; + e[4] = 65; + e[5] = 192; + e[6] = 193; + e[9] = 196; + e[17] = 66; + e[18] = 67; + e[21] = 268; + e[24] = 68; + e[28] = 69; + e[29] = 200; + e[30] = 201; + e[32] = 282; + e[38] = 70; + e[39] = 71; + e[44] = 72; + e[47] = 73; + e[48] = 204; + e[49] = 205; + e[58] = 74; + e[60] = 75; + e[62] = 76; + e[68] = 77; + e[69] = 78; + e[75] = 79; + e[76] = 210; + e[80] = 214; + e[87] = 80; + e[89] = 81; + e[90] = 82; + e[92] = 344; + e[94] = 83; + e[97] = 352; + e[100] = 84; + e[104] = 85; + e[109] = 220; + e[115] = 86; + e[116] = 87; + e[121] = 88; + e[122] = 89; + e[124] = 221; + e[127] = 90; + e[129] = 381; + e[258] = 97; + e[259] = 224; + e[260] = 225; + e[263] = 228; + e[268] = 261; + e[271] = 98; + e[272] = 99; + e[273] = 263; + e[275] = 269; + e[282] = 100; + e[286] = 101; + e[287] = 232; + e[288] = 233; + e[290] = 283; + e[295] = 281; + e[296] = 102; + e[336] = 103; + e[346] = 104; + e[349] = 105; + e[350] = 236; + e[351] = 237; + e[361] = 106; + e[364] = 107; + e[367] = 108; + e[371] = 322; + e[373] = 109; + e[374] = 110; + e[381] = 111; + e[382] = 242; + e[383] = 243; + e[386] = 246; + e[393] = 112; + e[395] = 113; + e[396] = 114; + e[398] = 345; + e[400] = 115; + e[401] = 347; + e[403] = 353; + e[410] = 116; + e[437] = 117; + e[442] = 252; + e[448] = 118; + e[449] = 119; + e[454] = 120; + e[455] = 121; + e[457] = 253; + e[460] = 122; + e[462] = 382; + e[463] = 380; + e[853] = 44; + e[855] = 58; + e[856] = 46; + e[876] = 47; + e[878] = 45; + e[882] = 45; + e[894] = 40; + e[895] = 41; + e[896] = 91; + e[897] = 93; + e[923] = 64; + e[940] = 163; + e[1004] = 48; + e[1005] = 49; + e[1006] = 50; + e[1007] = 51; + e[1008] = 52; + e[1009] = 53; + e[1010] = 54; + e[1011] = 55; + e[1012] = 56; + e[1013] = 57; + e[1081] = 37; + e[1085] = 43; + e[1086] = 45; + }); +function getStandardFontName(e) { + const t = normalizeFontName(e); + return Jr()[t]; +} +function isKnownFontName(e) { + const t = normalizeFontName(e); + return !!(Jr()[t] || Zr()[t] || Qr()[t] || ei()[t]); +} +class ToUnicodeMap { + constructor(e = []) { + this._map = e; + } + get length() { + return this._map.length; + } + forEach(e) { + for (const t in this._map) e(t, this._map[t].codePointAt(0)); + } + has(e) { + return void 0 !== this._map[e]; + } + get(e) { + return this._map[e]; + } + charCodeOf(e) { + const t = this._map; + if (t.length <= 65536) return t.indexOf(e); + for (const a in t) if (t[a] === e) return 0 | a; + return -1; + } + amend(e) { + for (const t in e) this._map[t] = e[t]; + } +} +class IdentityToUnicodeMap { + constructor(e, t) { + this.firstChar = e; + this.lastChar = t; + } + get length() { + return this.lastChar + 1 - this.firstChar; + } + forEach(e) { + for (let t = this.firstChar, a = this.lastChar; t <= a; t++) e(t, t); + } + has(e) { + return this.firstChar <= e && e <= this.lastChar; + } + get(e) { + if (this.firstChar <= e && e <= this.lastChar) + return String.fromCharCode(e); + } + charCodeOf(e) { + return Number.isInteger(e) && e >= this.firstChar && e <= this.lastChar + ? e + : -1; + } + amend(e) { + unreachable("Should not call amend()"); + } +} +class CFFFont { + constructor(e, t) { + this.properties = t; + const a = new CFFParser(e, t, Rr); + this.cff = a.parse(); + this.cff.duplicateFirstGlyph(); + const r = new CFFCompiler(this.cff); + this.seacs = this.cff.seacs; + try { + this.data = r.compile(); + } catch { + warn("Failed to compile font " + t.loadedName); + this.data = e; + } + this._createBuiltInEncoding(); + } + get numGlyphs() { + return this.cff.charStrings.count; + } + getCharset() { + return this.cff.charset.charset; + } + getGlyphMapping() { + const e = this.cff, + t = this.properties, + { cidToGidMap: a, cMap: r } = t, + i = e.charset.charset; + let n, s; + if (t.composite) { + let t, o; + if (a?.length > 0) { + t = Object.create(null); + for (let e = 0, r = a.length; e < r; e++) { + const r = a[e]; + void 0 !== r && (t[r] = e); + } + } + n = Object.create(null); + if (e.isCIDFont) + for (s = 0; s < i.length; s++) { + const e = i[s]; + o = r.charCodeOf(e); + void 0 !== t?.[o] && (o = t[o]); + n[o] = s; + } + else + for (s = 0; s < e.charStrings.count; s++) { + o = r.charCodeOf(s); + n[o] = s; + } + return n; + } + let o = e.encoding ? e.encoding.encoding : null; + t.isInternalFont && (o = t.defaultEncoding); + n = type1FontGlyphMapping(t, o, i); + return n; + } + hasGlyphId(e) { + return this.cff.hasGlyphId(e); + } + _createBuiltInEncoding() { + const { charset: e, encoding: t } = this.cff; + if (!e || !t) return; + const a = e.charset, + r = t.encoding, + i = []; + for (const e in r) { + const t = r[e]; + if (t >= 0) { + const r = a[t]; + r && (i[e] = r); + } + } + i.length > 0 && (this.properties.builtInEncoding = i); + } +} +function getFloat214(e, t) { + return readInt16(e, t) / 16384; +} +function getSubroutineBias(e) { + const t = e.length; + let a = 32768; + t < 1240 ? (a = 107) : t < 33900 && (a = 1131); + return a; +} +function parseCmap(e, t, a) { + const r = + 1 === readUint16(e, t + 2) ? readUint32(e, t + 8) : readUint32(e, t + 16), + i = readUint16(e, t + r); + let n, s, o; + if (4 === i) { + readUint16(e, t + r + 2); + const a = readUint16(e, t + r + 6) >> 1; + s = t + r + 14; + n = []; + for (o = 0; o < a; o++, s += 2) n[o] = { end: readUint16(e, s) }; + s += 2; + for (o = 0; o < a; o++, s += 2) n[o].start = readUint16(e, s); + for (o = 0; o < a; o++, s += 2) n[o].idDelta = readUint16(e, s); + for (o = 0; o < a; o++, s += 2) { + let t = readUint16(e, s); + if (0 !== t) { + n[o].ids = []; + for (let a = 0, r = n[o].end - n[o].start + 1; a < r; a++) { + n[o].ids[a] = readUint16(e, s + t); + t += 2; + } + } + } + return n; + } + if (12 === i) { + const a = readUint32(e, t + r + 12); + s = t + r + 16; + n = []; + for (o = 0; o < a; o++) { + t = readUint32(e, s); + n.push({ + start: t, + end: readUint32(e, s + 4), + idDelta: readUint32(e, s + 8) - t, + }); + s += 12; + } + return n; + } + throw new FormatError(`unsupported cmap: ${i}`); +} +function parseCff(e, t, a, r) { + const i = new CFFParser(new Stream(e, t, a - t), {}, r).parse(); + return { + glyphs: i.charStrings.objects, + subrs: i.topDict.privateDict?.subrsIndex?.objects, + gsubrs: i.globalSubrIndex?.objects, + isCFFCIDFont: i.isCIDFont, + fdSelect: i.fdSelect, + fdArray: i.fdArray, + }; +} +function lookupCmap(e, t) { + const a = t.codePointAt(0); + let r = 0, + i = 0, + n = e.length - 1; + for (; i < n; ) { + const t = (i + n + 1) >> 1; + a < e[t].start ? (n = t - 1) : (i = t); + } + e[i].start <= a && + a <= e[i].end && + (r = (e[i].idDelta + (e[i].ids ? e[i].ids[a - e[i].start] : a)) & 65535); + return { charCode: a, glyphId: r }; +} +function compileGlyf(e, t, a) { + function moveTo(e, a) { + s && t.add("L", s); + s = [e, a]; + t.add("M", [e, a]); + } + function lineTo(e, a) { + t.add("L", [e, a]); + } + function quadraticCurveTo(e, a, r, i) { + t.add("Q", [e, a, r, i]); + } + let r = 0; + const i = readInt16(e, r); + let n, + s = null, + o = 0, + c = 0; + r += 10; + if (i < 0) + do { + n = readUint16(e, r); + const i = readUint16(e, r + 2); + r += 4; + let s, l; + if (1 & n) { + if (2 & n) { + s = readInt16(e, r); + l = readInt16(e, r + 2); + } else { + s = readUint16(e, r); + l = readUint16(e, r + 2); + } + r += 4; + } else if (2 & n) { + s = readInt8(e, r++); + l = readInt8(e, r++); + } else { + s = e[r++]; + l = e[r++]; + } + if (2 & n) { + o = s; + c = l; + } else { + o = 0; + c = 0; + } + let h = 1, + u = 1, + d = 0, + f = 0; + if (8 & n) { + h = u = getFloat214(e, r); + r += 2; + } else if (64 & n) { + h = getFloat214(e, r); + u = getFloat214(e, r + 2); + r += 4; + } else if (128 & n) { + h = getFloat214(e, r); + d = getFloat214(e, r + 2); + f = getFloat214(e, r + 4); + u = getFloat214(e, r + 6); + r += 8; + } + const g = a.glyphs[i]; + if (g) { + t.save(); + t.transform([h, d, f, u, o, c]); + compileGlyf(g, t, a); + t.restore(); + } + } while (32 & n); + else { + const t = []; + let a, s; + for (a = 0; a < i; a++) { + t.push(readUint16(e, r)); + r += 2; + } + r += 2 + readUint16(e, r); + const l = t.at(-1) + 1, + h = []; + for (; h.length < l; ) { + n = e[r++]; + let t = 1; + 8 & n && (t += e[r++]); + for (; t-- > 0; ) h.push({ flags: n }); + } + for (a = 0; a < l; a++) { + switch (18 & h[a].flags) { + case 0: + o += readInt16(e, r); + r += 2; + break; + case 2: + o -= e[r++]; + break; + case 18: + o += e[r++]; + } + h[a].x = o; + } + for (a = 0; a < l; a++) { + switch (36 & h[a].flags) { + case 0: + c += readInt16(e, r); + r += 2; + break; + case 4: + c -= e[r++]; + break; + case 36: + c += e[r++]; + } + h[a].y = c; + } + let u = 0; + for (r = 0; r < i; r++) { + const e = t[r], + i = h.slice(u, e + 1); + if (1 & i[0].flags) i.push(i[0]); + else if (1 & i.at(-1).flags) i.unshift(i.at(-1)); + else { + const e = { + flags: 1, + x: (i[0].x + i.at(-1).x) / 2, + y: (i[0].y + i.at(-1).y) / 2, + }; + i.unshift(e); + i.push(e); + } + moveTo(i[0].x, i[0].y); + for (a = 1, s = i.length; a < s; a++) + if (1 & i[a].flags) lineTo(i[a].x, i[a].y); + else if (1 & i[a + 1].flags) { + quadraticCurveTo(i[a].x, i[a].y, i[a + 1].x, i[a + 1].y); + a++; + } else + quadraticCurveTo( + i[a].x, + i[a].y, + (i[a].x + i[a + 1].x) / 2, + (i[a].y + i[a + 1].y) / 2, + ); + u = e + 1; + } + } +} +function compileCharString(e, t, a, r) { + function moveTo(e, a) { + c && t.add("L", c); + c = [e, a]; + t.add("M", [e, a]); + } + function lineTo(e, a) { + t.add("L", [e, a]); + } + function bezierCurveTo(e, a, r, i, n, s) { + t.add("C", [e, a, r, i, n, s]); + } + const i = []; + let n = 0, + s = 0, + o = 0, + c = null; + !(function parse(e) { + let c = 0; + for (; c < e.length; ) { + let l, + h, + u, + d, + f, + g, + p, + m, + b, + y = !1, + w = e[c++]; + switch (w) { + case 1: + case 3: + case 18: + case 23: + o += i.length >> 1; + y = !0; + break; + case 4: + s += i.pop(); + moveTo(n, s); + y = !0; + break; + case 5: + for (; i.length > 0; ) { + n += i.shift(); + s += i.shift(); + lineTo(n, s); + } + break; + case 6: + for (; i.length > 0; ) { + n += i.shift(); + lineTo(n, s); + if (0 === i.length) break; + s += i.shift(); + lineTo(n, s); + } + break; + case 7: + for (; i.length > 0; ) { + s += i.shift(); + lineTo(n, s); + if (0 === i.length) break; + n += i.shift(); + lineTo(n, s); + } + break; + case 8: + for (; i.length > 0; ) { + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + } + break; + case 10: + m = i.pop(); + b = null; + if (a.isCFFCIDFont) { + const e = a.fdSelect.getFDIndex(r); + if (e >= 0 && e < a.fdArray.length) { + const t = a.fdArray[e]; + let r; + t.privateDict?.subrsIndex && + (r = t.privateDict.subrsIndex.objects); + if (r) { + m += getSubroutineBias(r); + b = r[m]; + } + } else warn("Invalid fd index for glyph index."); + } else b = a.subrs[m + a.subrsBias]; + b && parse(b); + break; + case 11: + return; + case 12: + w = e[c++]; + switch (w) { + case 34: + l = n + i.shift(); + h = l + i.shift(); + f = s + i.shift(); + n = h + i.shift(); + bezierCurveTo(l, s, h, f, n, f); + l = n + i.shift(); + h = l + i.shift(); + n = h + i.shift(); + bezierCurveTo(l, f, h, s, n, s); + break; + case 35: + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + i.pop(); + break; + case 36: + l = n + i.shift(); + f = s + i.shift(); + h = l + i.shift(); + g = f + i.shift(); + n = h + i.shift(); + bezierCurveTo(l, f, h, g, n, g); + l = n + i.shift(); + h = l + i.shift(); + p = g + i.shift(); + n = h + i.shift(); + bezierCurveTo(l, g, h, p, n, s); + break; + case 37: + const e = n, + t = s; + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h; + s = d; + Math.abs(n - e) > Math.abs(s - t) + ? (n += i.shift()) + : (s += i.shift()); + bezierCurveTo(l, u, h, d, n, s); + break; + default: + throw new FormatError(`unknown operator: 12 ${w}`); + } + break; + case 14: + if (i.length >= 4) { + const e = i.pop(), + r = i.pop(); + s = i.pop(); + n = i.pop(); + t.save(); + t.translate(n, s); + let o = lookupCmap( + a.cmap, + String.fromCharCode(a.glyphNameMap[kr[e]]), + ); + compileCharString(a.glyphs[o.glyphId], t, a, o.glyphId); + t.restore(); + o = lookupCmap(a.cmap, String.fromCharCode(a.glyphNameMap[kr[r]])); + compileCharString(a.glyphs[o.glyphId], t, a, o.glyphId); + } + return; + case 19: + case 20: + o += i.length >> 1; + c += (o + 7) >> 3; + y = !0; + break; + case 21: + s += i.pop(); + n += i.pop(); + moveTo(n, s); + y = !0; + break; + case 22: + n += i.pop(); + moveTo(n, s); + y = !0; + break; + case 24: + for (; i.length > 2; ) { + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + } + n += i.shift(); + s += i.shift(); + lineTo(n, s); + break; + case 25: + for (; i.length > 6; ) { + n += i.shift(); + s += i.shift(); + lineTo(n, s); + } + l = n + i.shift(); + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + break; + case 26: + i.length % 2 && (n += i.shift()); + for (; i.length > 0; ) { + l = n; + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h; + s = d + i.shift(); + bezierCurveTo(l, u, h, d, n, s); + } + break; + case 27: + i.length % 2 && (s += i.shift()); + for (; i.length > 0; ) { + l = n + i.shift(); + u = s; + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d; + bezierCurveTo(l, u, h, d, n, s); + } + break; + case 28: + i.push(readInt16(e, c)); + c += 2; + break; + case 29: + m = i.pop() + a.gsubrsBias; + b = a.gsubrs[m]; + b && parse(b); + break; + case 30: + for (; i.length > 0; ) { + l = n; + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + (1 === i.length ? i.shift() : 0); + bezierCurveTo(l, u, h, d, n, s); + if (0 === i.length) break; + l = n + i.shift(); + u = s; + h = l + i.shift(); + d = u + i.shift(); + s = d + i.shift(); + n = h + (1 === i.length ? i.shift() : 0); + bezierCurveTo(l, u, h, d, n, s); + } + break; + case 31: + for (; i.length > 0; ) { + l = n + i.shift(); + u = s; + h = l + i.shift(); + d = u + i.shift(); + s = d + i.shift(); + n = h + (1 === i.length ? i.shift() : 0); + bezierCurveTo(l, u, h, d, n, s); + if (0 === i.length) break; + l = n; + u = s + i.shift(); + h = l + i.shift(); + d = u + i.shift(); + n = h + i.shift(); + s = d + (1 === i.length ? i.shift() : 0); + bezierCurveTo(l, u, h, d, n, s); + } + break; + default: + if (w < 32) throw new FormatError(`unknown operator: ${w}`); + if (w < 247) i.push(w - 139); + else if (w < 251) i.push(256 * (w - 247) + e[c++] + 108); + else if (w < 255) i.push(256 * -(w - 251) - e[c++] - 108); + else { + i.push( + ((e[c] << 24) | (e[c + 1] << 16) | (e[c + 2] << 8) | e[c + 3]) / + 65536, + ); + c += 4; + } + } + y && (i.length = 0); + } + })(e); +} +class Commands { + cmds = []; + transformStack = []; + currentTransform = [1, 0, 0, 1, 0, 0]; + add(e, t) { + if (t) { + const { currentTransform: a } = this; + for (let e = 0, r = t.length; e < r; e += 2) Util.applyTransform(t, a, e); + this.cmds.push(`${e}${t.join(" ")}`); + } else this.cmds.push(e); + } + transform(e) { + this.currentTransform = Util.transform(this.currentTransform, e); + } + translate(e, t) { + this.transform([1, 0, 0, 1, e, t]); + } + save() { + this.transformStack.push(this.currentTransform.slice()); + } + restore() { + this.currentTransform = this.transformStack.pop() || [1, 0, 0, 1, 0, 0]; + } + getSVG() { + return this.cmds.join(""); + } +} +class CompiledFont { + constructor(e) { + this.fontMatrix = e; + this.compiledGlyphs = Object.create(null); + this.compiledCharCodeToGlyphId = Object.create(null); + } + getPathJs(e) { + const { charCode: t, glyphId: a } = lookupCmap(this.cmap, e); + let r, + i = this.compiledGlyphs[a]; + if (void 0 === i) { + try { + i = this.compileGlyph(this.glyphs[a], a); + } catch (e) { + i = ""; + r = e; + } + this.compiledGlyphs[a] = i; + } + this.compiledCharCodeToGlyphId[t] ??= a; + if (r) throw r; + return i; + } + compileGlyph(e, a) { + if (!e?.length || 14 === e[0]) return ""; + let r = this.fontMatrix; + if (this.isCFFCIDFont) { + const e = this.fdSelect.getFDIndex(a); + if (e >= 0 && e < this.fdArray.length) { + r = this.fdArray[e].getByName("FontMatrix") || t; + } else warn("Invalid fd index for glyph index."); + } + assert(isNumberArray(r, 6), "Expected a valid fontMatrix."); + const i = new Commands(); + i.transform(r.slice()); + this.compileGlyphImpl(e, i, a); + i.add("Z"); + return i.getSVG(); + } + compileGlyphImpl() { + unreachable("Children classes should implement this."); + } + hasBuiltPath(e) { + const { charCode: t, glyphId: a } = lookupCmap(this.cmap, e); + return ( + void 0 !== this.compiledGlyphs[a] && + void 0 !== this.compiledCharCodeToGlyphId[t] + ); + } +} +class TrueTypeCompiled extends CompiledFont { + constructor(e, t, a) { + super(a || [488e-6, 0, 0, 488e-6, 0, 0]); + this.glyphs = e; + this.cmap = t; + } + compileGlyphImpl(e, t) { + compileGlyf(e, t, this); + } +} +class Type2Compiled extends CompiledFont { + constructor(e, t, a) { + super(a || [0.001, 0, 0, 0.001, 0, 0]); + this.glyphs = e.glyphs; + this.gsubrs = e.gsubrs || []; + this.subrs = e.subrs || []; + this.cmap = t; + this.glyphNameMap = Fr(); + this.gsubrsBias = getSubroutineBias(this.gsubrs); + this.subrsBias = getSubroutineBias(this.subrs); + this.isCFFCIDFont = e.isCFFCIDFont; + this.fdSelect = e.fdSelect; + this.fdArray = e.fdArray; + } + compileGlyphImpl(e, t, a) { + compileCharString(e, t, this, a); + } +} +class FontRendererFactory { + static create(e, t) { + const a = new Uint8Array(e.data); + let r, i, n, s, o, c; + const l = readUint16(a, 4); + for (let e = 0, h = 12; e < l; e++, h += 16) { + const e = bytesToString(a.subarray(h, h + 4)), + l = readUint32(a, h + 8), + u = readUint32(a, h + 12); + switch (e) { + case "cmap": + r = parseCmap(a, l); + break; + case "glyf": + i = a.subarray(l, l + u); + break; + case "loca": + n = a.subarray(l, l + u); + break; + case "head": + c = readUint16(a, l + 18); + o = readUint16(a, l + 50); + break; + case "CFF ": + s = parseCff(a, l, l + u, t); + } + } + if (i) { + const t = c ? [1 / c, 0, 0, 1 / c, 0, 0] : e.fontMatrix; + return new TrueTypeCompiled( + (function parseGlyfTable(e, t, a) { + let r, i; + if (a) { + r = 4; + i = readUint32; + } else { + r = 2; + i = (e, t) => 2 * readUint16(e, t); + } + const n = []; + let s = i(t, 0); + for (let a = r; a < t.length; a += r) { + const r = i(t, a); + n.push(e.subarray(s, r)); + s = r; + } + return n; + })(i, n, o), + r, + t, + ); + } + return new Type2Compiled(s, r, e.fontMatrix); + } +} +const ii = getLookupTableFactory(function (e) { + e.Courier = 600; + e["Courier-Bold"] = 600; + e["Courier-BoldOblique"] = 600; + e["Courier-Oblique"] = 600; + e.Helvetica = getLookupTableFactory(function (e) { + e.space = 278; + e.exclam = 278; + e.quotedbl = 355; + e.numbersign = 556; + e.dollar = 556; + e.percent = 889; + e.ampersand = 667; + e.quoteright = 222; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 389; + e.plus = 584; + e.comma = 278; + e.hyphen = 333; + e.period = 278; + e.slash = 278; + e.zero = 556; + e.one = 556; + e.two = 556; + e.three = 556; + e.four = 556; + e.five = 556; + e.six = 556; + e.seven = 556; + e.eight = 556; + e.nine = 556; + e.colon = 278; + e.semicolon = 278; + e.less = 584; + e.equal = 584; + e.greater = 584; + e.question = 556; + e.at = 1015; + e.A = 667; + e.B = 667; + e.C = 722; + e.D = 722; + e.E = 667; + e.F = 611; + e.G = 778; + e.H = 722; + e.I = 278; + e.J = 500; + e.K = 667; + e.L = 556; + e.M = 833; + e.N = 722; + e.O = 778; + e.P = 667; + e.Q = 778; + e.R = 722; + e.S = 667; + e.T = 611; + e.U = 722; + e.V = 667; + e.W = 944; + e.X = 667; + e.Y = 667; + e.Z = 611; + e.bracketleft = 278; + e.backslash = 278; + e.bracketright = 278; + e.asciicircum = 469; + e.underscore = 556; + e.quoteleft = 222; + e.a = 556; + e.b = 556; + e.c = 500; + e.d = 556; + e.e = 556; + e.f = 278; + e.g = 556; + e.h = 556; + e.i = 222; + e.j = 222; + e.k = 500; + e.l = 222; + e.m = 833; + e.n = 556; + e.o = 556; + e.p = 556; + e.q = 556; + e.r = 333; + e.s = 500; + e.t = 278; + e.u = 556; + e.v = 500; + e.w = 722; + e.x = 500; + e.y = 500; + e.z = 500; + e.braceleft = 334; + e.bar = 260; + e.braceright = 334; + e.asciitilde = 584; + e.exclamdown = 333; + e.cent = 556; + e.sterling = 556; + e.fraction = 167; + e.yen = 556; + e.florin = 556; + e.section = 556; + e.currency = 556; + e.quotesingle = 191; + e.quotedblleft = 333; + e.guillemotleft = 556; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 500; + e.fl = 500; + e.endash = 556; + e.dagger = 556; + e.daggerdbl = 556; + e.periodcentered = 278; + e.paragraph = 537; + e.bullet = 350; + e.quotesinglbase = 222; + e.quotedblbase = 333; + e.quotedblright = 333; + e.guillemotright = 556; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 611; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 1e3; + e.ordfeminine = 370; + e.Lslash = 556; + e.Oslash = 778; + e.OE = 1e3; + e.ordmasculine = 365; + e.ae = 889; + e.dotlessi = 278; + e.lslash = 222; + e.oslash = 611; + e.oe = 944; + e.germandbls = 611; + e.Idieresis = 278; + e.eacute = 556; + e.abreve = 556; + e.uhungarumlaut = 556; + e.ecaron = 556; + e.Ydieresis = 667; + e.divide = 584; + e.Yacute = 667; + e.Acircumflex = 667; + e.aacute = 556; + e.Ucircumflex = 722; + e.yacute = 500; + e.scommaaccent = 500; + e.ecircumflex = 556; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 556; + e.Uacute = 722; + e.uogonek = 556; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 737; + e.Emacron = 667; + e.ccaron = 500; + e.aring = 556; + e.Ncommaaccent = 722; + e.lacute = 222; + e.agrave = 556; + e.Tcommaaccent = 611; + e.Cacute = 722; + e.atilde = 556; + e.Edotaccent = 667; + e.scaron = 500; + e.scedilla = 500; + e.iacute = 278; + e.lozenge = 471; + e.Rcaron = 722; + e.Gcommaaccent = 778; + e.ucircumflex = 556; + e.acircumflex = 556; + e.Amacron = 667; + e.rcaron = 333; + e.ccedilla = 500; + e.Zdotaccent = 611; + e.Thorn = 667; + e.Omacron = 778; + e.Racute = 722; + e.Sacute = 667; + e.dcaron = 643; + e.Umacron = 722; + e.uring = 556; + e.threesuperior = 333; + e.Ograve = 778; + e.Agrave = 667; + e.Abreve = 667; + e.multiply = 584; + e.uacute = 556; + e.Tcaron = 611; + e.partialdiff = 476; + e.ydieresis = 500; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 556; + e.edieresis = 556; + e.cacute = 500; + e.nacute = 556; + e.umacron = 556; + e.Ncaron = 722; + e.Iacute = 278; + e.plusminus = 584; + e.brokenbar = 260; + e.registered = 737; + e.Gbreve = 778; + e.Idotaccent = 278; + e.summation = 600; + e.Egrave = 667; + e.racute = 333; + e.omacron = 556; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 722; + e.lcommaaccent = 222; + e.tcaron = 317; + e.eogonek = 556; + e.Uogonek = 722; + e.Aacute = 667; + e.Adieresis = 667; + e.egrave = 556; + e.zacute = 500; + e.iogonek = 222; + e.Oacute = 778; + e.oacute = 556; + e.amacron = 556; + e.sacute = 500; + e.idieresis = 278; + e.Ocircumflex = 778; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 556; + e.twosuperior = 333; + e.Odieresis = 778; + e.mu = 556; + e.igrave = 278; + e.ohungarumlaut = 556; + e.Eogonek = 667; + e.dcroat = 556; + e.threequarters = 834; + e.Scedilla = 667; + e.lcaron = 299; + e.Kcommaaccent = 667; + e.Lacute = 556; + e.trademark = 1e3; + e.edotaccent = 556; + e.Igrave = 278; + e.Imacron = 278; + e.Lcaron = 556; + e.onehalf = 834; + e.lessequal = 549; + e.ocircumflex = 556; + e.ntilde = 556; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 556; + e.gbreve = 556; + e.onequarter = 834; + e.Scaron = 667; + e.Scommaaccent = 667; + e.Ohungarumlaut = 778; + e.degree = 400; + e.ograve = 556; + e.Ccaron = 722; + e.ugrave = 556; + e.radical = 453; + e.Dcaron = 722; + e.rcommaaccent = 333; + e.Ntilde = 722; + e.otilde = 556; + e.Rcommaaccent = 722; + e.Lcommaaccent = 556; + e.Atilde = 667; + e.Aogonek = 667; + e.Aring = 667; + e.Otilde = 778; + e.zdotaccent = 500; + e.Ecaron = 667; + e.Iogonek = 278; + e.kcommaaccent = 500; + e.minus = 584; + e.Icircumflex = 278; + e.ncaron = 556; + e.tcommaaccent = 278; + e.logicalnot = 584; + e.odieresis = 556; + e.udieresis = 556; + e.notequal = 549; + e.gcommaaccent = 556; + e.eth = 556; + e.zcaron = 500; + e.ncommaaccent = 556; + e.onesuperior = 333; + e.imacron = 278; + e.Euro = 556; + }); + e["Helvetica-Bold"] = getLookupTableFactory(function (e) { + e.space = 278; + e.exclam = 333; + e.quotedbl = 474; + e.numbersign = 556; + e.dollar = 556; + e.percent = 889; + e.ampersand = 722; + e.quoteright = 278; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 389; + e.plus = 584; + e.comma = 278; + e.hyphen = 333; + e.period = 278; + e.slash = 278; + e.zero = 556; + e.one = 556; + e.two = 556; + e.three = 556; + e.four = 556; + e.five = 556; + e.six = 556; + e.seven = 556; + e.eight = 556; + e.nine = 556; + e.colon = 333; + e.semicolon = 333; + e.less = 584; + e.equal = 584; + e.greater = 584; + e.question = 611; + e.at = 975; + e.A = 722; + e.B = 722; + e.C = 722; + e.D = 722; + e.E = 667; + e.F = 611; + e.G = 778; + e.H = 722; + e.I = 278; + e.J = 556; + e.K = 722; + e.L = 611; + e.M = 833; + e.N = 722; + e.O = 778; + e.P = 667; + e.Q = 778; + e.R = 722; + e.S = 667; + e.T = 611; + e.U = 722; + e.V = 667; + e.W = 944; + e.X = 667; + e.Y = 667; + e.Z = 611; + e.bracketleft = 333; + e.backslash = 278; + e.bracketright = 333; + e.asciicircum = 584; + e.underscore = 556; + e.quoteleft = 278; + e.a = 556; + e.b = 611; + e.c = 556; + e.d = 611; + e.e = 556; + e.f = 333; + e.g = 611; + e.h = 611; + e.i = 278; + e.j = 278; + e.k = 556; + e.l = 278; + e.m = 889; + e.n = 611; + e.o = 611; + e.p = 611; + e.q = 611; + e.r = 389; + e.s = 556; + e.t = 333; + e.u = 611; + e.v = 556; + e.w = 778; + e.x = 556; + e.y = 556; + e.z = 500; + e.braceleft = 389; + e.bar = 280; + e.braceright = 389; + e.asciitilde = 584; + e.exclamdown = 333; + e.cent = 556; + e.sterling = 556; + e.fraction = 167; + e.yen = 556; + e.florin = 556; + e.section = 556; + e.currency = 556; + e.quotesingle = 238; + e.quotedblleft = 500; + e.guillemotleft = 556; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 611; + e.fl = 611; + e.endash = 556; + e.dagger = 556; + e.daggerdbl = 556; + e.periodcentered = 278; + e.paragraph = 556; + e.bullet = 350; + e.quotesinglbase = 278; + e.quotedblbase = 500; + e.quotedblright = 500; + e.guillemotright = 556; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 611; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 1e3; + e.ordfeminine = 370; + e.Lslash = 611; + e.Oslash = 778; + e.OE = 1e3; + e.ordmasculine = 365; + e.ae = 889; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 611; + e.oe = 944; + e.germandbls = 611; + e.Idieresis = 278; + e.eacute = 556; + e.abreve = 556; + e.uhungarumlaut = 611; + e.ecaron = 556; + e.Ydieresis = 667; + e.divide = 584; + e.Yacute = 667; + e.Acircumflex = 722; + e.aacute = 556; + e.Ucircumflex = 722; + e.yacute = 556; + e.scommaaccent = 556; + e.ecircumflex = 556; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 556; + e.Uacute = 722; + e.uogonek = 611; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 737; + e.Emacron = 667; + e.ccaron = 556; + e.aring = 556; + e.Ncommaaccent = 722; + e.lacute = 278; + e.agrave = 556; + e.Tcommaaccent = 611; + e.Cacute = 722; + e.atilde = 556; + e.Edotaccent = 667; + e.scaron = 556; + e.scedilla = 556; + e.iacute = 278; + e.lozenge = 494; + e.Rcaron = 722; + e.Gcommaaccent = 778; + e.ucircumflex = 611; + e.acircumflex = 556; + e.Amacron = 722; + e.rcaron = 389; + e.ccedilla = 556; + e.Zdotaccent = 611; + e.Thorn = 667; + e.Omacron = 778; + e.Racute = 722; + e.Sacute = 667; + e.dcaron = 743; + e.Umacron = 722; + e.uring = 611; + e.threesuperior = 333; + e.Ograve = 778; + e.Agrave = 722; + e.Abreve = 722; + e.multiply = 584; + e.uacute = 611; + e.Tcaron = 611; + e.partialdiff = 494; + e.ydieresis = 556; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 556; + e.edieresis = 556; + e.cacute = 556; + e.nacute = 611; + e.umacron = 611; + e.Ncaron = 722; + e.Iacute = 278; + e.plusminus = 584; + e.brokenbar = 280; + e.registered = 737; + e.Gbreve = 778; + e.Idotaccent = 278; + e.summation = 600; + e.Egrave = 667; + e.racute = 389; + e.omacron = 611; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 722; + e.lcommaaccent = 278; + e.tcaron = 389; + e.eogonek = 556; + e.Uogonek = 722; + e.Aacute = 722; + e.Adieresis = 722; + e.egrave = 556; + e.zacute = 500; + e.iogonek = 278; + e.Oacute = 778; + e.oacute = 611; + e.amacron = 556; + e.sacute = 556; + e.idieresis = 278; + e.Ocircumflex = 778; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 611; + e.twosuperior = 333; + e.Odieresis = 778; + e.mu = 611; + e.igrave = 278; + e.ohungarumlaut = 611; + e.Eogonek = 667; + e.dcroat = 611; + e.threequarters = 834; + e.Scedilla = 667; + e.lcaron = 400; + e.Kcommaaccent = 722; + e.Lacute = 611; + e.trademark = 1e3; + e.edotaccent = 556; + e.Igrave = 278; + e.Imacron = 278; + e.Lcaron = 611; + e.onehalf = 834; + e.lessequal = 549; + e.ocircumflex = 611; + e.ntilde = 611; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 556; + e.gbreve = 611; + e.onequarter = 834; + e.Scaron = 667; + e.Scommaaccent = 667; + e.Ohungarumlaut = 778; + e.degree = 400; + e.ograve = 611; + e.Ccaron = 722; + e.ugrave = 611; + e.radical = 549; + e.Dcaron = 722; + e.rcommaaccent = 389; + e.Ntilde = 722; + e.otilde = 611; + e.Rcommaaccent = 722; + e.Lcommaaccent = 611; + e.Atilde = 722; + e.Aogonek = 722; + e.Aring = 722; + e.Otilde = 778; + e.zdotaccent = 500; + e.Ecaron = 667; + e.Iogonek = 278; + e.kcommaaccent = 556; + e.minus = 584; + e.Icircumflex = 278; + e.ncaron = 611; + e.tcommaaccent = 333; + e.logicalnot = 584; + e.odieresis = 611; + e.udieresis = 611; + e.notequal = 549; + e.gcommaaccent = 611; + e.eth = 611; + e.zcaron = 500; + e.ncommaaccent = 611; + e.onesuperior = 333; + e.imacron = 278; + e.Euro = 556; + }); + e["Helvetica-BoldOblique"] = getLookupTableFactory(function (e) { + e.space = 278; + e.exclam = 333; + e.quotedbl = 474; + e.numbersign = 556; + e.dollar = 556; + e.percent = 889; + e.ampersand = 722; + e.quoteright = 278; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 389; + e.plus = 584; + e.comma = 278; + e.hyphen = 333; + e.period = 278; + e.slash = 278; + e.zero = 556; + e.one = 556; + e.two = 556; + e.three = 556; + e.four = 556; + e.five = 556; + e.six = 556; + e.seven = 556; + e.eight = 556; + e.nine = 556; + e.colon = 333; + e.semicolon = 333; + e.less = 584; + e.equal = 584; + e.greater = 584; + e.question = 611; + e.at = 975; + e.A = 722; + e.B = 722; + e.C = 722; + e.D = 722; + e.E = 667; + e.F = 611; + e.G = 778; + e.H = 722; + e.I = 278; + e.J = 556; + e.K = 722; + e.L = 611; + e.M = 833; + e.N = 722; + e.O = 778; + e.P = 667; + e.Q = 778; + e.R = 722; + e.S = 667; + e.T = 611; + e.U = 722; + e.V = 667; + e.W = 944; + e.X = 667; + e.Y = 667; + e.Z = 611; + e.bracketleft = 333; + e.backslash = 278; + e.bracketright = 333; + e.asciicircum = 584; + e.underscore = 556; + e.quoteleft = 278; + e.a = 556; + e.b = 611; + e.c = 556; + e.d = 611; + e.e = 556; + e.f = 333; + e.g = 611; + e.h = 611; + e.i = 278; + e.j = 278; + e.k = 556; + e.l = 278; + e.m = 889; + e.n = 611; + e.o = 611; + e.p = 611; + e.q = 611; + e.r = 389; + e.s = 556; + e.t = 333; + e.u = 611; + e.v = 556; + e.w = 778; + e.x = 556; + e.y = 556; + e.z = 500; + e.braceleft = 389; + e.bar = 280; + e.braceright = 389; + e.asciitilde = 584; + e.exclamdown = 333; + e.cent = 556; + e.sterling = 556; + e.fraction = 167; + e.yen = 556; + e.florin = 556; + e.section = 556; + e.currency = 556; + e.quotesingle = 238; + e.quotedblleft = 500; + e.guillemotleft = 556; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 611; + e.fl = 611; + e.endash = 556; + e.dagger = 556; + e.daggerdbl = 556; + e.periodcentered = 278; + e.paragraph = 556; + e.bullet = 350; + e.quotesinglbase = 278; + e.quotedblbase = 500; + e.quotedblright = 500; + e.guillemotright = 556; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 611; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 1e3; + e.ordfeminine = 370; + e.Lslash = 611; + e.Oslash = 778; + e.OE = 1e3; + e.ordmasculine = 365; + e.ae = 889; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 611; + e.oe = 944; + e.germandbls = 611; + e.Idieresis = 278; + e.eacute = 556; + e.abreve = 556; + e.uhungarumlaut = 611; + e.ecaron = 556; + e.Ydieresis = 667; + e.divide = 584; + e.Yacute = 667; + e.Acircumflex = 722; + e.aacute = 556; + e.Ucircumflex = 722; + e.yacute = 556; + e.scommaaccent = 556; + e.ecircumflex = 556; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 556; + e.Uacute = 722; + e.uogonek = 611; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 737; + e.Emacron = 667; + e.ccaron = 556; + e.aring = 556; + e.Ncommaaccent = 722; + e.lacute = 278; + e.agrave = 556; + e.Tcommaaccent = 611; + e.Cacute = 722; + e.atilde = 556; + e.Edotaccent = 667; + e.scaron = 556; + e.scedilla = 556; + e.iacute = 278; + e.lozenge = 494; + e.Rcaron = 722; + e.Gcommaaccent = 778; + e.ucircumflex = 611; + e.acircumflex = 556; + e.Amacron = 722; + e.rcaron = 389; + e.ccedilla = 556; + e.Zdotaccent = 611; + e.Thorn = 667; + e.Omacron = 778; + e.Racute = 722; + e.Sacute = 667; + e.dcaron = 743; + e.Umacron = 722; + e.uring = 611; + e.threesuperior = 333; + e.Ograve = 778; + e.Agrave = 722; + e.Abreve = 722; + e.multiply = 584; + e.uacute = 611; + e.Tcaron = 611; + e.partialdiff = 494; + e.ydieresis = 556; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 556; + e.edieresis = 556; + e.cacute = 556; + e.nacute = 611; + e.umacron = 611; + e.Ncaron = 722; + e.Iacute = 278; + e.plusminus = 584; + e.brokenbar = 280; + e.registered = 737; + e.Gbreve = 778; + e.Idotaccent = 278; + e.summation = 600; + e.Egrave = 667; + e.racute = 389; + e.omacron = 611; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 722; + e.lcommaaccent = 278; + e.tcaron = 389; + e.eogonek = 556; + e.Uogonek = 722; + e.Aacute = 722; + e.Adieresis = 722; + e.egrave = 556; + e.zacute = 500; + e.iogonek = 278; + e.Oacute = 778; + e.oacute = 611; + e.amacron = 556; + e.sacute = 556; + e.idieresis = 278; + e.Ocircumflex = 778; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 611; + e.twosuperior = 333; + e.Odieresis = 778; + e.mu = 611; + e.igrave = 278; + e.ohungarumlaut = 611; + e.Eogonek = 667; + e.dcroat = 611; + e.threequarters = 834; + e.Scedilla = 667; + e.lcaron = 400; + e.Kcommaaccent = 722; + e.Lacute = 611; + e.trademark = 1e3; + e.edotaccent = 556; + e.Igrave = 278; + e.Imacron = 278; + e.Lcaron = 611; + e.onehalf = 834; + e.lessequal = 549; + e.ocircumflex = 611; + e.ntilde = 611; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 556; + e.gbreve = 611; + e.onequarter = 834; + e.Scaron = 667; + e.Scommaaccent = 667; + e.Ohungarumlaut = 778; + e.degree = 400; + e.ograve = 611; + e.Ccaron = 722; + e.ugrave = 611; + e.radical = 549; + e.Dcaron = 722; + e.rcommaaccent = 389; + e.Ntilde = 722; + e.otilde = 611; + e.Rcommaaccent = 722; + e.Lcommaaccent = 611; + e.Atilde = 722; + e.Aogonek = 722; + e.Aring = 722; + e.Otilde = 778; + e.zdotaccent = 500; + e.Ecaron = 667; + e.Iogonek = 278; + e.kcommaaccent = 556; + e.minus = 584; + e.Icircumflex = 278; + e.ncaron = 611; + e.tcommaaccent = 333; + e.logicalnot = 584; + e.odieresis = 611; + e.udieresis = 611; + e.notequal = 549; + e.gcommaaccent = 611; + e.eth = 611; + e.zcaron = 500; + e.ncommaaccent = 611; + e.onesuperior = 333; + e.imacron = 278; + e.Euro = 556; + }); + e["Helvetica-Oblique"] = getLookupTableFactory(function (e) { + e.space = 278; + e.exclam = 278; + e.quotedbl = 355; + e.numbersign = 556; + e.dollar = 556; + e.percent = 889; + e.ampersand = 667; + e.quoteright = 222; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 389; + e.plus = 584; + e.comma = 278; + e.hyphen = 333; + e.period = 278; + e.slash = 278; + e.zero = 556; + e.one = 556; + e.two = 556; + e.three = 556; + e.four = 556; + e.five = 556; + e.six = 556; + e.seven = 556; + e.eight = 556; + e.nine = 556; + e.colon = 278; + e.semicolon = 278; + e.less = 584; + e.equal = 584; + e.greater = 584; + e.question = 556; + e.at = 1015; + e.A = 667; + e.B = 667; + e.C = 722; + e.D = 722; + e.E = 667; + e.F = 611; + e.G = 778; + e.H = 722; + e.I = 278; + e.J = 500; + e.K = 667; + e.L = 556; + e.M = 833; + e.N = 722; + e.O = 778; + e.P = 667; + e.Q = 778; + e.R = 722; + e.S = 667; + e.T = 611; + e.U = 722; + e.V = 667; + e.W = 944; + e.X = 667; + e.Y = 667; + e.Z = 611; + e.bracketleft = 278; + e.backslash = 278; + e.bracketright = 278; + e.asciicircum = 469; + e.underscore = 556; + e.quoteleft = 222; + e.a = 556; + e.b = 556; + e.c = 500; + e.d = 556; + e.e = 556; + e.f = 278; + e.g = 556; + e.h = 556; + e.i = 222; + e.j = 222; + e.k = 500; + e.l = 222; + e.m = 833; + e.n = 556; + e.o = 556; + e.p = 556; + e.q = 556; + e.r = 333; + e.s = 500; + e.t = 278; + e.u = 556; + e.v = 500; + e.w = 722; + e.x = 500; + e.y = 500; + e.z = 500; + e.braceleft = 334; + e.bar = 260; + e.braceright = 334; + e.asciitilde = 584; + e.exclamdown = 333; + e.cent = 556; + e.sterling = 556; + e.fraction = 167; + e.yen = 556; + e.florin = 556; + e.section = 556; + e.currency = 556; + e.quotesingle = 191; + e.quotedblleft = 333; + e.guillemotleft = 556; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 500; + e.fl = 500; + e.endash = 556; + e.dagger = 556; + e.daggerdbl = 556; + e.periodcentered = 278; + e.paragraph = 537; + e.bullet = 350; + e.quotesinglbase = 222; + e.quotedblbase = 333; + e.quotedblright = 333; + e.guillemotright = 556; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 611; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 1e3; + e.ordfeminine = 370; + e.Lslash = 556; + e.Oslash = 778; + e.OE = 1e3; + e.ordmasculine = 365; + e.ae = 889; + e.dotlessi = 278; + e.lslash = 222; + e.oslash = 611; + e.oe = 944; + e.germandbls = 611; + e.Idieresis = 278; + e.eacute = 556; + e.abreve = 556; + e.uhungarumlaut = 556; + e.ecaron = 556; + e.Ydieresis = 667; + e.divide = 584; + e.Yacute = 667; + e.Acircumflex = 667; + e.aacute = 556; + e.Ucircumflex = 722; + e.yacute = 500; + e.scommaaccent = 500; + e.ecircumflex = 556; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 556; + e.Uacute = 722; + e.uogonek = 556; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 737; + e.Emacron = 667; + e.ccaron = 500; + e.aring = 556; + e.Ncommaaccent = 722; + e.lacute = 222; + e.agrave = 556; + e.Tcommaaccent = 611; + e.Cacute = 722; + e.atilde = 556; + e.Edotaccent = 667; + e.scaron = 500; + e.scedilla = 500; + e.iacute = 278; + e.lozenge = 471; + e.Rcaron = 722; + e.Gcommaaccent = 778; + e.ucircumflex = 556; + e.acircumflex = 556; + e.Amacron = 667; + e.rcaron = 333; + e.ccedilla = 500; + e.Zdotaccent = 611; + e.Thorn = 667; + e.Omacron = 778; + e.Racute = 722; + e.Sacute = 667; + e.dcaron = 643; + e.Umacron = 722; + e.uring = 556; + e.threesuperior = 333; + e.Ograve = 778; + e.Agrave = 667; + e.Abreve = 667; + e.multiply = 584; + e.uacute = 556; + e.Tcaron = 611; + e.partialdiff = 476; + e.ydieresis = 500; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 556; + e.edieresis = 556; + e.cacute = 500; + e.nacute = 556; + e.umacron = 556; + e.Ncaron = 722; + e.Iacute = 278; + e.plusminus = 584; + e.brokenbar = 260; + e.registered = 737; + e.Gbreve = 778; + e.Idotaccent = 278; + e.summation = 600; + e.Egrave = 667; + e.racute = 333; + e.omacron = 556; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 722; + e.lcommaaccent = 222; + e.tcaron = 317; + e.eogonek = 556; + e.Uogonek = 722; + e.Aacute = 667; + e.Adieresis = 667; + e.egrave = 556; + e.zacute = 500; + e.iogonek = 222; + e.Oacute = 778; + e.oacute = 556; + e.amacron = 556; + e.sacute = 500; + e.idieresis = 278; + e.Ocircumflex = 778; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 556; + e.twosuperior = 333; + e.Odieresis = 778; + e.mu = 556; + e.igrave = 278; + e.ohungarumlaut = 556; + e.Eogonek = 667; + e.dcroat = 556; + e.threequarters = 834; + e.Scedilla = 667; + e.lcaron = 299; + e.Kcommaaccent = 667; + e.Lacute = 556; + e.trademark = 1e3; + e.edotaccent = 556; + e.Igrave = 278; + e.Imacron = 278; + e.Lcaron = 556; + e.onehalf = 834; + e.lessequal = 549; + e.ocircumflex = 556; + e.ntilde = 556; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 556; + e.gbreve = 556; + e.onequarter = 834; + e.Scaron = 667; + e.Scommaaccent = 667; + e.Ohungarumlaut = 778; + e.degree = 400; + e.ograve = 556; + e.Ccaron = 722; + e.ugrave = 556; + e.radical = 453; + e.Dcaron = 722; + e.rcommaaccent = 333; + e.Ntilde = 722; + e.otilde = 556; + e.Rcommaaccent = 722; + e.Lcommaaccent = 556; + e.Atilde = 667; + e.Aogonek = 667; + e.Aring = 667; + e.Otilde = 778; + e.zdotaccent = 500; + e.Ecaron = 667; + e.Iogonek = 278; + e.kcommaaccent = 500; + e.minus = 584; + e.Icircumflex = 278; + e.ncaron = 556; + e.tcommaaccent = 278; + e.logicalnot = 584; + e.odieresis = 556; + e.udieresis = 556; + e.notequal = 549; + e.gcommaaccent = 556; + e.eth = 556; + e.zcaron = 500; + e.ncommaaccent = 556; + e.onesuperior = 333; + e.imacron = 278; + e.Euro = 556; + }); + e.Symbol = getLookupTableFactory(function (e) { + e.space = 250; + e.exclam = 333; + e.universal = 713; + e.numbersign = 500; + e.existential = 549; + e.percent = 833; + e.ampersand = 778; + e.suchthat = 439; + e.parenleft = 333; + e.parenright = 333; + e.asteriskmath = 500; + e.plus = 549; + e.comma = 250; + e.minus = 549; + e.period = 250; + e.slash = 278; + e.zero = 500; + e.one = 500; + e.two = 500; + e.three = 500; + e.four = 500; + e.five = 500; + e.six = 500; + e.seven = 500; + e.eight = 500; + e.nine = 500; + e.colon = 278; + e.semicolon = 278; + e.less = 549; + e.equal = 549; + e.greater = 549; + e.question = 444; + e.congruent = 549; + e.Alpha = 722; + e.Beta = 667; + e.Chi = 722; + e.Delta = 612; + e.Epsilon = 611; + e.Phi = 763; + e.Gamma = 603; + e.Eta = 722; + e.Iota = 333; + e.theta1 = 631; + e.Kappa = 722; + e.Lambda = 686; + e.Mu = 889; + e.Nu = 722; + e.Omicron = 722; + e.Pi = 768; + e.Theta = 741; + e.Rho = 556; + e.Sigma = 592; + e.Tau = 611; + e.Upsilon = 690; + e.sigma1 = 439; + e.Omega = 768; + e.Xi = 645; + e.Psi = 795; + e.Zeta = 611; + e.bracketleft = 333; + e.therefore = 863; + e.bracketright = 333; + e.perpendicular = 658; + e.underscore = 500; + e.radicalex = 500; + e.alpha = 631; + e.beta = 549; + e.chi = 549; + e.delta = 494; + e.epsilon = 439; + e.phi = 521; + e.gamma = 411; + e.eta = 603; + e.iota = 329; + e.phi1 = 603; + e.kappa = 549; + e.lambda = 549; + e.mu = 576; + e.nu = 521; + e.omicron = 549; + e.pi = 549; + e.theta = 521; + e.rho = 549; + e.sigma = 603; + e.tau = 439; + e.upsilon = 576; + e.omega1 = 713; + e.omega = 686; + e.xi = 493; + e.psi = 686; + e.zeta = 494; + e.braceleft = 480; + e.bar = 200; + e.braceright = 480; + e.similar = 549; + e.Euro = 750; + e.Upsilon1 = 620; + e.minute = 247; + e.lessequal = 549; + e.fraction = 167; + e.infinity = 713; + e.florin = 500; + e.club = 753; + e.diamond = 753; + e.heart = 753; + e.spade = 753; + e.arrowboth = 1042; + e.arrowleft = 987; + e.arrowup = 603; + e.arrowright = 987; + e.arrowdown = 603; + e.degree = 400; + e.plusminus = 549; + e.second = 411; + e.greaterequal = 549; + e.multiply = 549; + e.proportional = 713; + e.partialdiff = 494; + e.bullet = 460; + e.divide = 549; + e.notequal = 549; + e.equivalence = 549; + e.approxequal = 549; + e.ellipsis = 1e3; + e.arrowvertex = 603; + e.arrowhorizex = 1e3; + e.carriagereturn = 658; + e.aleph = 823; + e.Ifraktur = 686; + e.Rfraktur = 795; + e.weierstrass = 987; + e.circlemultiply = 768; + e.circleplus = 768; + e.emptyset = 823; + e.intersection = 768; + e.union = 768; + e.propersuperset = 713; + e.reflexsuperset = 713; + e.notsubset = 713; + e.propersubset = 713; + e.reflexsubset = 713; + e.element = 713; + e.notelement = 713; + e.angle = 768; + e.gradient = 713; + e.registerserif = 790; + e.copyrightserif = 790; + e.trademarkserif = 890; + e.product = 823; + e.radical = 549; + e.dotmath = 250; + e.logicalnot = 713; + e.logicaland = 603; + e.logicalor = 603; + e.arrowdblboth = 1042; + e.arrowdblleft = 987; + e.arrowdblup = 603; + e.arrowdblright = 987; + e.arrowdbldown = 603; + e.lozenge = 494; + e.angleleft = 329; + e.registersans = 790; + e.copyrightsans = 790; + e.trademarksans = 786; + e.summation = 713; + e.parenlefttp = 384; + e.parenleftex = 384; + e.parenleftbt = 384; + e.bracketlefttp = 384; + e.bracketleftex = 384; + e.bracketleftbt = 384; + e.bracelefttp = 494; + e.braceleftmid = 494; + e.braceleftbt = 494; + e.braceex = 494; + e.angleright = 329; + e.integral = 274; + e.integraltp = 686; + e.integralex = 686; + e.integralbt = 686; + e.parenrighttp = 384; + e.parenrightex = 384; + e.parenrightbt = 384; + e.bracketrighttp = 384; + e.bracketrightex = 384; + e.bracketrightbt = 384; + e.bracerighttp = 494; + e.bracerightmid = 494; + e.bracerightbt = 494; + e.apple = 790; + }); + e["Times-Roman"] = getLookupTableFactory(function (e) { + e.space = 250; + e.exclam = 333; + e.quotedbl = 408; + e.numbersign = 500; + e.dollar = 500; + e.percent = 833; + e.ampersand = 778; + e.quoteright = 333; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 500; + e.plus = 564; + e.comma = 250; + e.hyphen = 333; + e.period = 250; + e.slash = 278; + e.zero = 500; + e.one = 500; + e.two = 500; + e.three = 500; + e.four = 500; + e.five = 500; + e.six = 500; + e.seven = 500; + e.eight = 500; + e.nine = 500; + e.colon = 278; + e.semicolon = 278; + e.less = 564; + e.equal = 564; + e.greater = 564; + e.question = 444; + e.at = 921; + e.A = 722; + e.B = 667; + e.C = 667; + e.D = 722; + e.E = 611; + e.F = 556; + e.G = 722; + e.H = 722; + e.I = 333; + e.J = 389; + e.K = 722; + e.L = 611; + e.M = 889; + e.N = 722; + e.O = 722; + e.P = 556; + e.Q = 722; + e.R = 667; + e.S = 556; + e.T = 611; + e.U = 722; + e.V = 722; + e.W = 944; + e.X = 722; + e.Y = 722; + e.Z = 611; + e.bracketleft = 333; + e.backslash = 278; + e.bracketright = 333; + e.asciicircum = 469; + e.underscore = 500; + e.quoteleft = 333; + e.a = 444; + e.b = 500; + e.c = 444; + e.d = 500; + e.e = 444; + e.f = 333; + e.g = 500; + e.h = 500; + e.i = 278; + e.j = 278; + e.k = 500; + e.l = 278; + e.m = 778; + e.n = 500; + e.o = 500; + e.p = 500; + e.q = 500; + e.r = 333; + e.s = 389; + e.t = 278; + e.u = 500; + e.v = 500; + e.w = 722; + e.x = 500; + e.y = 500; + e.z = 444; + e.braceleft = 480; + e.bar = 200; + e.braceright = 480; + e.asciitilde = 541; + e.exclamdown = 333; + e.cent = 500; + e.sterling = 500; + e.fraction = 167; + e.yen = 500; + e.florin = 500; + e.section = 500; + e.currency = 500; + e.quotesingle = 180; + e.quotedblleft = 444; + e.guillemotleft = 500; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 556; + e.fl = 556; + e.endash = 500; + e.dagger = 500; + e.daggerdbl = 500; + e.periodcentered = 250; + e.paragraph = 453; + e.bullet = 350; + e.quotesinglbase = 333; + e.quotedblbase = 444; + e.quotedblright = 444; + e.guillemotright = 500; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 444; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 889; + e.ordfeminine = 276; + e.Lslash = 611; + e.Oslash = 722; + e.OE = 889; + e.ordmasculine = 310; + e.ae = 667; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 500; + e.oe = 722; + e.germandbls = 500; + e.Idieresis = 333; + e.eacute = 444; + e.abreve = 444; + e.uhungarumlaut = 500; + e.ecaron = 444; + e.Ydieresis = 722; + e.divide = 564; + e.Yacute = 722; + e.Acircumflex = 722; + e.aacute = 444; + e.Ucircumflex = 722; + e.yacute = 500; + e.scommaaccent = 389; + e.ecircumflex = 444; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 444; + e.Uacute = 722; + e.uogonek = 500; + e.Edieresis = 611; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 760; + e.Emacron = 611; + e.ccaron = 444; + e.aring = 444; + e.Ncommaaccent = 722; + e.lacute = 278; + e.agrave = 444; + e.Tcommaaccent = 611; + e.Cacute = 667; + e.atilde = 444; + e.Edotaccent = 611; + e.scaron = 389; + e.scedilla = 389; + e.iacute = 278; + e.lozenge = 471; + e.Rcaron = 667; + e.Gcommaaccent = 722; + e.ucircumflex = 500; + e.acircumflex = 444; + e.Amacron = 722; + e.rcaron = 333; + e.ccedilla = 444; + e.Zdotaccent = 611; + e.Thorn = 556; + e.Omacron = 722; + e.Racute = 667; + e.Sacute = 556; + e.dcaron = 588; + e.Umacron = 722; + e.uring = 500; + e.threesuperior = 300; + e.Ograve = 722; + e.Agrave = 722; + e.Abreve = 722; + e.multiply = 564; + e.uacute = 500; + e.Tcaron = 611; + e.partialdiff = 476; + e.ydieresis = 500; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 611; + e.adieresis = 444; + e.edieresis = 444; + e.cacute = 444; + e.nacute = 500; + e.umacron = 500; + e.Ncaron = 722; + e.Iacute = 333; + e.plusminus = 564; + e.brokenbar = 200; + e.registered = 760; + e.Gbreve = 722; + e.Idotaccent = 333; + e.summation = 600; + e.Egrave = 611; + e.racute = 333; + e.omacron = 500; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 667; + e.lcommaaccent = 278; + e.tcaron = 326; + e.eogonek = 444; + e.Uogonek = 722; + e.Aacute = 722; + e.Adieresis = 722; + e.egrave = 444; + e.zacute = 444; + e.iogonek = 278; + e.Oacute = 722; + e.oacute = 500; + e.amacron = 444; + e.sacute = 389; + e.idieresis = 278; + e.Ocircumflex = 722; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 500; + e.twosuperior = 300; + e.Odieresis = 722; + e.mu = 500; + e.igrave = 278; + e.ohungarumlaut = 500; + e.Eogonek = 611; + e.dcroat = 500; + e.threequarters = 750; + e.Scedilla = 556; + e.lcaron = 344; + e.Kcommaaccent = 722; + e.Lacute = 611; + e.trademark = 980; + e.edotaccent = 444; + e.Igrave = 333; + e.Imacron = 333; + e.Lcaron = 611; + e.onehalf = 750; + e.lessequal = 549; + e.ocircumflex = 500; + e.ntilde = 500; + e.Uhungarumlaut = 722; + e.Eacute = 611; + e.emacron = 444; + e.gbreve = 500; + e.onequarter = 750; + e.Scaron = 556; + e.Scommaaccent = 556; + e.Ohungarumlaut = 722; + e.degree = 400; + e.ograve = 500; + e.Ccaron = 667; + e.ugrave = 500; + e.radical = 453; + e.Dcaron = 722; + e.rcommaaccent = 333; + e.Ntilde = 722; + e.otilde = 500; + e.Rcommaaccent = 667; + e.Lcommaaccent = 611; + e.Atilde = 722; + e.Aogonek = 722; + e.Aring = 722; + e.Otilde = 722; + e.zdotaccent = 444; + e.Ecaron = 611; + e.Iogonek = 333; + e.kcommaaccent = 500; + e.minus = 564; + e.Icircumflex = 333; + e.ncaron = 500; + e.tcommaaccent = 278; + e.logicalnot = 564; + e.odieresis = 500; + e.udieresis = 500; + e.notequal = 549; + e.gcommaaccent = 500; + e.eth = 500; + e.zcaron = 444; + e.ncommaaccent = 500; + e.onesuperior = 300; + e.imacron = 278; + e.Euro = 500; + }); + e["Times-Bold"] = getLookupTableFactory(function (e) { + e.space = 250; + e.exclam = 333; + e.quotedbl = 555; + e.numbersign = 500; + e.dollar = 500; + e.percent = 1e3; + e.ampersand = 833; + e.quoteright = 333; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 500; + e.plus = 570; + e.comma = 250; + e.hyphen = 333; + e.period = 250; + e.slash = 278; + e.zero = 500; + e.one = 500; + e.two = 500; + e.three = 500; + e.four = 500; + e.five = 500; + e.six = 500; + e.seven = 500; + e.eight = 500; + e.nine = 500; + e.colon = 333; + e.semicolon = 333; + e.less = 570; + e.equal = 570; + e.greater = 570; + e.question = 500; + e.at = 930; + e.A = 722; + e.B = 667; + e.C = 722; + e.D = 722; + e.E = 667; + e.F = 611; + e.G = 778; + e.H = 778; + e.I = 389; + e.J = 500; + e.K = 778; + e.L = 667; + e.M = 944; + e.N = 722; + e.O = 778; + e.P = 611; + e.Q = 778; + e.R = 722; + e.S = 556; + e.T = 667; + e.U = 722; + e.V = 722; + e.W = 1e3; + e.X = 722; + e.Y = 722; + e.Z = 667; + e.bracketleft = 333; + e.backslash = 278; + e.bracketright = 333; + e.asciicircum = 581; + e.underscore = 500; + e.quoteleft = 333; + e.a = 500; + e.b = 556; + e.c = 444; + e.d = 556; + e.e = 444; + e.f = 333; + e.g = 500; + e.h = 556; + e.i = 278; + e.j = 333; + e.k = 556; + e.l = 278; + e.m = 833; + e.n = 556; + e.o = 500; + e.p = 556; + e.q = 556; + e.r = 444; + e.s = 389; + e.t = 333; + e.u = 556; + e.v = 500; + e.w = 722; + e.x = 500; + e.y = 500; + e.z = 444; + e.braceleft = 394; + e.bar = 220; + e.braceright = 394; + e.asciitilde = 520; + e.exclamdown = 333; + e.cent = 500; + e.sterling = 500; + e.fraction = 167; + e.yen = 500; + e.florin = 500; + e.section = 500; + e.currency = 500; + e.quotesingle = 278; + e.quotedblleft = 500; + e.guillemotleft = 500; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 556; + e.fl = 556; + e.endash = 500; + e.dagger = 500; + e.daggerdbl = 500; + e.periodcentered = 250; + e.paragraph = 540; + e.bullet = 350; + e.quotesinglbase = 333; + e.quotedblbase = 500; + e.quotedblright = 500; + e.guillemotright = 500; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 500; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 1e3; + e.ordfeminine = 300; + e.Lslash = 667; + e.Oslash = 778; + e.OE = 1e3; + e.ordmasculine = 330; + e.ae = 722; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 500; + e.oe = 722; + e.germandbls = 556; + e.Idieresis = 389; + e.eacute = 444; + e.abreve = 500; + e.uhungarumlaut = 556; + e.ecaron = 444; + e.Ydieresis = 722; + e.divide = 570; + e.Yacute = 722; + e.Acircumflex = 722; + e.aacute = 500; + e.Ucircumflex = 722; + e.yacute = 500; + e.scommaaccent = 389; + e.ecircumflex = 444; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 500; + e.Uacute = 722; + e.uogonek = 556; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 747; + e.Emacron = 667; + e.ccaron = 444; + e.aring = 500; + e.Ncommaaccent = 722; + e.lacute = 278; + e.agrave = 500; + e.Tcommaaccent = 667; + e.Cacute = 722; + e.atilde = 500; + e.Edotaccent = 667; + e.scaron = 389; + e.scedilla = 389; + e.iacute = 278; + e.lozenge = 494; + e.Rcaron = 722; + e.Gcommaaccent = 778; + e.ucircumflex = 556; + e.acircumflex = 500; + e.Amacron = 722; + e.rcaron = 444; + e.ccedilla = 444; + e.Zdotaccent = 667; + e.Thorn = 611; + e.Omacron = 778; + e.Racute = 722; + e.Sacute = 556; + e.dcaron = 672; + e.Umacron = 722; + e.uring = 556; + e.threesuperior = 300; + e.Ograve = 778; + e.Agrave = 722; + e.Abreve = 722; + e.multiply = 570; + e.uacute = 556; + e.Tcaron = 667; + e.partialdiff = 494; + e.ydieresis = 500; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 500; + e.edieresis = 444; + e.cacute = 444; + e.nacute = 556; + e.umacron = 556; + e.Ncaron = 722; + e.Iacute = 389; + e.plusminus = 570; + e.brokenbar = 220; + e.registered = 747; + e.Gbreve = 778; + e.Idotaccent = 389; + e.summation = 600; + e.Egrave = 667; + e.racute = 444; + e.omacron = 500; + e.Zacute = 667; + e.Zcaron = 667; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 722; + e.lcommaaccent = 278; + e.tcaron = 416; + e.eogonek = 444; + e.Uogonek = 722; + e.Aacute = 722; + e.Adieresis = 722; + e.egrave = 444; + e.zacute = 444; + e.iogonek = 278; + e.Oacute = 778; + e.oacute = 500; + e.amacron = 500; + e.sacute = 389; + e.idieresis = 278; + e.Ocircumflex = 778; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 556; + e.twosuperior = 300; + e.Odieresis = 778; + e.mu = 556; + e.igrave = 278; + e.ohungarumlaut = 500; + e.Eogonek = 667; + e.dcroat = 556; + e.threequarters = 750; + e.Scedilla = 556; + e.lcaron = 394; + e.Kcommaaccent = 778; + e.Lacute = 667; + e.trademark = 1e3; + e.edotaccent = 444; + e.Igrave = 389; + e.Imacron = 389; + e.Lcaron = 667; + e.onehalf = 750; + e.lessequal = 549; + e.ocircumflex = 500; + e.ntilde = 556; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 444; + e.gbreve = 500; + e.onequarter = 750; + e.Scaron = 556; + e.Scommaaccent = 556; + e.Ohungarumlaut = 778; + e.degree = 400; + e.ograve = 500; + e.Ccaron = 722; + e.ugrave = 556; + e.radical = 549; + e.Dcaron = 722; + e.rcommaaccent = 444; + e.Ntilde = 722; + e.otilde = 500; + e.Rcommaaccent = 722; + e.Lcommaaccent = 667; + e.Atilde = 722; + e.Aogonek = 722; + e.Aring = 722; + e.Otilde = 778; + e.zdotaccent = 444; + e.Ecaron = 667; + e.Iogonek = 389; + e.kcommaaccent = 556; + e.minus = 570; + e.Icircumflex = 389; + e.ncaron = 556; + e.tcommaaccent = 333; + e.logicalnot = 570; + e.odieresis = 500; + e.udieresis = 556; + e.notequal = 549; + e.gcommaaccent = 500; + e.eth = 500; + e.zcaron = 444; + e.ncommaaccent = 556; + e.onesuperior = 300; + e.imacron = 278; + e.Euro = 500; + }); + e["Times-BoldItalic"] = getLookupTableFactory(function (e) { + e.space = 250; + e.exclam = 389; + e.quotedbl = 555; + e.numbersign = 500; + e.dollar = 500; + e.percent = 833; + e.ampersand = 778; + e.quoteright = 333; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 500; + e.plus = 570; + e.comma = 250; + e.hyphen = 333; + e.period = 250; + e.slash = 278; + e.zero = 500; + e.one = 500; + e.two = 500; + e.three = 500; + e.four = 500; + e.five = 500; + e.six = 500; + e.seven = 500; + e.eight = 500; + e.nine = 500; + e.colon = 333; + e.semicolon = 333; + e.less = 570; + e.equal = 570; + e.greater = 570; + e.question = 500; + e.at = 832; + e.A = 667; + e.B = 667; + e.C = 667; + e.D = 722; + e.E = 667; + e.F = 667; + e.G = 722; + e.H = 778; + e.I = 389; + e.J = 500; + e.K = 667; + e.L = 611; + e.M = 889; + e.N = 722; + e.O = 722; + e.P = 611; + e.Q = 722; + e.R = 667; + e.S = 556; + e.T = 611; + e.U = 722; + e.V = 667; + e.W = 889; + e.X = 667; + e.Y = 611; + e.Z = 611; + e.bracketleft = 333; + e.backslash = 278; + e.bracketright = 333; + e.asciicircum = 570; + e.underscore = 500; + e.quoteleft = 333; + e.a = 500; + e.b = 500; + e.c = 444; + e.d = 500; + e.e = 444; + e.f = 333; + e.g = 500; + e.h = 556; + e.i = 278; + e.j = 278; + e.k = 500; + e.l = 278; + e.m = 778; + e.n = 556; + e.o = 500; + e.p = 500; + e.q = 500; + e.r = 389; + e.s = 389; + e.t = 278; + e.u = 556; + e.v = 444; + e.w = 667; + e.x = 500; + e.y = 444; + e.z = 389; + e.braceleft = 348; + e.bar = 220; + e.braceright = 348; + e.asciitilde = 570; + e.exclamdown = 389; + e.cent = 500; + e.sterling = 500; + e.fraction = 167; + e.yen = 500; + e.florin = 500; + e.section = 500; + e.currency = 500; + e.quotesingle = 278; + e.quotedblleft = 500; + e.guillemotleft = 500; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 556; + e.fl = 556; + e.endash = 500; + e.dagger = 500; + e.daggerdbl = 500; + e.periodcentered = 250; + e.paragraph = 500; + e.bullet = 350; + e.quotesinglbase = 333; + e.quotedblbase = 500; + e.quotedblright = 500; + e.guillemotright = 500; + e.ellipsis = 1e3; + e.perthousand = 1e3; + e.questiondown = 500; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 1e3; + e.AE = 944; + e.ordfeminine = 266; + e.Lslash = 611; + e.Oslash = 722; + e.OE = 944; + e.ordmasculine = 300; + e.ae = 722; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 500; + e.oe = 722; + e.germandbls = 500; + e.Idieresis = 389; + e.eacute = 444; + e.abreve = 500; + e.uhungarumlaut = 556; + e.ecaron = 444; + e.Ydieresis = 611; + e.divide = 570; + e.Yacute = 611; + e.Acircumflex = 667; + e.aacute = 500; + e.Ucircumflex = 722; + e.yacute = 444; + e.scommaaccent = 389; + e.ecircumflex = 444; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 500; + e.Uacute = 722; + e.uogonek = 556; + e.Edieresis = 667; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 747; + e.Emacron = 667; + e.ccaron = 444; + e.aring = 500; + e.Ncommaaccent = 722; + e.lacute = 278; + e.agrave = 500; + e.Tcommaaccent = 611; + e.Cacute = 667; + e.atilde = 500; + e.Edotaccent = 667; + e.scaron = 389; + e.scedilla = 389; + e.iacute = 278; + e.lozenge = 494; + e.Rcaron = 667; + e.Gcommaaccent = 722; + e.ucircumflex = 556; + e.acircumflex = 500; + e.Amacron = 667; + e.rcaron = 389; + e.ccedilla = 444; + e.Zdotaccent = 611; + e.Thorn = 611; + e.Omacron = 722; + e.Racute = 667; + e.Sacute = 556; + e.dcaron = 608; + e.Umacron = 722; + e.uring = 556; + e.threesuperior = 300; + e.Ograve = 722; + e.Agrave = 667; + e.Abreve = 667; + e.multiply = 570; + e.uacute = 556; + e.Tcaron = 611; + e.partialdiff = 494; + e.ydieresis = 444; + e.Nacute = 722; + e.icircumflex = 278; + e.Ecircumflex = 667; + e.adieresis = 500; + e.edieresis = 444; + e.cacute = 444; + e.nacute = 556; + e.umacron = 556; + e.Ncaron = 722; + e.Iacute = 389; + e.plusminus = 570; + e.brokenbar = 220; + e.registered = 747; + e.Gbreve = 722; + e.Idotaccent = 389; + e.summation = 600; + e.Egrave = 667; + e.racute = 389; + e.omacron = 500; + e.Zacute = 611; + e.Zcaron = 611; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 667; + e.lcommaaccent = 278; + e.tcaron = 366; + e.eogonek = 444; + e.Uogonek = 722; + e.Aacute = 667; + e.Adieresis = 667; + e.egrave = 444; + e.zacute = 389; + e.iogonek = 278; + e.Oacute = 722; + e.oacute = 500; + e.amacron = 500; + e.sacute = 389; + e.idieresis = 278; + e.Ocircumflex = 722; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 500; + e.twosuperior = 300; + e.Odieresis = 722; + e.mu = 576; + e.igrave = 278; + e.ohungarumlaut = 500; + e.Eogonek = 667; + e.dcroat = 500; + e.threequarters = 750; + e.Scedilla = 556; + e.lcaron = 382; + e.Kcommaaccent = 667; + e.Lacute = 611; + e.trademark = 1e3; + e.edotaccent = 444; + e.Igrave = 389; + e.Imacron = 389; + e.Lcaron = 611; + e.onehalf = 750; + e.lessequal = 549; + e.ocircumflex = 500; + e.ntilde = 556; + e.Uhungarumlaut = 722; + e.Eacute = 667; + e.emacron = 444; + e.gbreve = 500; + e.onequarter = 750; + e.Scaron = 556; + e.Scommaaccent = 556; + e.Ohungarumlaut = 722; + e.degree = 400; + e.ograve = 500; + e.Ccaron = 667; + e.ugrave = 556; + e.radical = 549; + e.Dcaron = 722; + e.rcommaaccent = 389; + e.Ntilde = 722; + e.otilde = 500; + e.Rcommaaccent = 667; + e.Lcommaaccent = 611; + e.Atilde = 667; + e.Aogonek = 667; + e.Aring = 667; + e.Otilde = 722; + e.zdotaccent = 389; + e.Ecaron = 667; + e.Iogonek = 389; + e.kcommaaccent = 500; + e.minus = 606; + e.Icircumflex = 389; + e.ncaron = 556; + e.tcommaaccent = 278; + e.logicalnot = 606; + e.odieresis = 500; + e.udieresis = 556; + e.notequal = 549; + e.gcommaaccent = 500; + e.eth = 500; + e.zcaron = 389; + e.ncommaaccent = 556; + e.onesuperior = 300; + e.imacron = 278; + e.Euro = 500; + }); + e["Times-Italic"] = getLookupTableFactory(function (e) { + e.space = 250; + e.exclam = 333; + e.quotedbl = 420; + e.numbersign = 500; + e.dollar = 500; + e.percent = 833; + e.ampersand = 778; + e.quoteright = 333; + e.parenleft = 333; + e.parenright = 333; + e.asterisk = 500; + e.plus = 675; + e.comma = 250; + e.hyphen = 333; + e.period = 250; + e.slash = 278; + e.zero = 500; + e.one = 500; + e.two = 500; + e.three = 500; + e.four = 500; + e.five = 500; + e.six = 500; + e.seven = 500; + e.eight = 500; + e.nine = 500; + e.colon = 333; + e.semicolon = 333; + e.less = 675; + e.equal = 675; + e.greater = 675; + e.question = 500; + e.at = 920; + e.A = 611; + e.B = 611; + e.C = 667; + e.D = 722; + e.E = 611; + e.F = 611; + e.G = 722; + e.H = 722; + e.I = 333; + e.J = 444; + e.K = 667; + e.L = 556; + e.M = 833; + e.N = 667; + e.O = 722; + e.P = 611; + e.Q = 722; + e.R = 611; + e.S = 500; + e.T = 556; + e.U = 722; + e.V = 611; + e.W = 833; + e.X = 611; + e.Y = 556; + e.Z = 556; + e.bracketleft = 389; + e.backslash = 278; + e.bracketright = 389; + e.asciicircum = 422; + e.underscore = 500; + e.quoteleft = 333; + e.a = 500; + e.b = 500; + e.c = 444; + e.d = 500; + e.e = 444; + e.f = 278; + e.g = 500; + e.h = 500; + e.i = 278; + e.j = 278; + e.k = 444; + e.l = 278; + e.m = 722; + e.n = 500; + e.o = 500; + e.p = 500; + e.q = 500; + e.r = 389; + e.s = 389; + e.t = 278; + e.u = 500; + e.v = 444; + e.w = 667; + e.x = 444; + e.y = 444; + e.z = 389; + e.braceleft = 400; + e.bar = 275; + e.braceright = 400; + e.asciitilde = 541; + e.exclamdown = 389; + e.cent = 500; + e.sterling = 500; + e.fraction = 167; + e.yen = 500; + e.florin = 500; + e.section = 500; + e.currency = 500; + e.quotesingle = 214; + e.quotedblleft = 556; + e.guillemotleft = 500; + e.guilsinglleft = 333; + e.guilsinglright = 333; + e.fi = 500; + e.fl = 500; + e.endash = 500; + e.dagger = 500; + e.daggerdbl = 500; + e.periodcentered = 250; + e.paragraph = 523; + e.bullet = 350; + e.quotesinglbase = 333; + e.quotedblbase = 556; + e.quotedblright = 556; + e.guillemotright = 500; + e.ellipsis = 889; + e.perthousand = 1e3; + e.questiondown = 500; + e.grave = 333; + e.acute = 333; + e.circumflex = 333; + e.tilde = 333; + e.macron = 333; + e.breve = 333; + e.dotaccent = 333; + e.dieresis = 333; + e.ring = 333; + e.cedilla = 333; + e.hungarumlaut = 333; + e.ogonek = 333; + e.caron = 333; + e.emdash = 889; + e.AE = 889; + e.ordfeminine = 276; + e.Lslash = 556; + e.Oslash = 722; + e.OE = 944; + e.ordmasculine = 310; + e.ae = 667; + e.dotlessi = 278; + e.lslash = 278; + e.oslash = 500; + e.oe = 667; + e.germandbls = 500; + e.Idieresis = 333; + e.eacute = 444; + e.abreve = 500; + e.uhungarumlaut = 500; + e.ecaron = 444; + e.Ydieresis = 556; + e.divide = 675; + e.Yacute = 556; + e.Acircumflex = 611; + e.aacute = 500; + e.Ucircumflex = 722; + e.yacute = 444; + e.scommaaccent = 389; + e.ecircumflex = 444; + e.Uring = 722; + e.Udieresis = 722; + e.aogonek = 500; + e.Uacute = 722; + e.uogonek = 500; + e.Edieresis = 611; + e.Dcroat = 722; + e.commaaccent = 250; + e.copyright = 760; + e.Emacron = 611; + e.ccaron = 444; + e.aring = 500; + e.Ncommaaccent = 667; + e.lacute = 278; + e.agrave = 500; + e.Tcommaaccent = 556; + e.Cacute = 667; + e.atilde = 500; + e.Edotaccent = 611; + e.scaron = 389; + e.scedilla = 389; + e.iacute = 278; + e.lozenge = 471; + e.Rcaron = 611; + e.Gcommaaccent = 722; + e.ucircumflex = 500; + e.acircumflex = 500; + e.Amacron = 611; + e.rcaron = 389; + e.ccedilla = 444; + e.Zdotaccent = 556; + e.Thorn = 611; + e.Omacron = 722; + e.Racute = 611; + e.Sacute = 500; + e.dcaron = 544; + e.Umacron = 722; + e.uring = 500; + e.threesuperior = 300; + e.Ograve = 722; + e.Agrave = 611; + e.Abreve = 611; + e.multiply = 675; + e.uacute = 500; + e.Tcaron = 556; + e.partialdiff = 476; + e.ydieresis = 444; + e.Nacute = 667; + e.icircumflex = 278; + e.Ecircumflex = 611; + e.adieresis = 500; + e.edieresis = 444; + e.cacute = 444; + e.nacute = 500; + e.umacron = 500; + e.Ncaron = 667; + e.Iacute = 333; + e.plusminus = 675; + e.brokenbar = 275; + e.registered = 760; + e.Gbreve = 722; + e.Idotaccent = 333; + e.summation = 600; + e.Egrave = 611; + e.racute = 389; + e.omacron = 500; + e.Zacute = 556; + e.Zcaron = 556; + e.greaterequal = 549; + e.Eth = 722; + e.Ccedilla = 667; + e.lcommaaccent = 278; + e.tcaron = 300; + e.eogonek = 444; + e.Uogonek = 722; + e.Aacute = 611; + e.Adieresis = 611; + e.egrave = 444; + e.zacute = 389; + e.iogonek = 278; + e.Oacute = 722; + e.oacute = 500; + e.amacron = 500; + e.sacute = 389; + e.idieresis = 278; + e.Ocircumflex = 722; + e.Ugrave = 722; + e.Delta = 612; + e.thorn = 500; + e.twosuperior = 300; + e.Odieresis = 722; + e.mu = 500; + e.igrave = 278; + e.ohungarumlaut = 500; + e.Eogonek = 611; + e.dcroat = 500; + e.threequarters = 750; + e.Scedilla = 500; + e.lcaron = 300; + e.Kcommaaccent = 667; + e.Lacute = 556; + e.trademark = 980; + e.edotaccent = 444; + e.Igrave = 333; + e.Imacron = 333; + e.Lcaron = 611; + e.onehalf = 750; + e.lessequal = 549; + e.ocircumflex = 500; + e.ntilde = 500; + e.Uhungarumlaut = 722; + e.Eacute = 611; + e.emacron = 444; + e.gbreve = 500; + e.onequarter = 750; + e.Scaron = 500; + e.Scommaaccent = 500; + e.Ohungarumlaut = 722; + e.degree = 400; + e.ograve = 500; + e.Ccaron = 667; + e.ugrave = 500; + e.radical = 453; + e.Dcaron = 722; + e.rcommaaccent = 389; + e.Ntilde = 667; + e.otilde = 500; + e.Rcommaaccent = 611; + e.Lcommaaccent = 556; + e.Atilde = 611; + e.Aogonek = 611; + e.Aring = 611; + e.Otilde = 722; + e.zdotaccent = 389; + e.Ecaron = 611; + e.Iogonek = 333; + e.kcommaaccent = 444; + e.minus = 675; + e.Icircumflex = 333; + e.ncaron = 500; + e.tcommaaccent = 278; + e.logicalnot = 675; + e.odieresis = 500; + e.udieresis = 500; + e.notequal = 549; + e.gcommaaccent = 500; + e.eth = 500; + e.zcaron = 389; + e.ncommaaccent = 500; + e.onesuperior = 300; + e.imacron = 278; + e.Euro = 500; + }); + e.ZapfDingbats = getLookupTableFactory(function (e) { + e.space = 278; + e.a1 = 974; + e.a2 = 961; + e.a202 = 974; + e.a3 = 980; + e.a4 = 719; + e.a5 = 789; + e.a119 = 790; + e.a118 = 791; + e.a117 = 690; + e.a11 = 960; + e.a12 = 939; + e.a13 = 549; + e.a14 = 855; + e.a15 = 911; + e.a16 = 933; + e.a105 = 911; + e.a17 = 945; + e.a18 = 974; + e.a19 = 755; + e.a20 = 846; + e.a21 = 762; + e.a22 = 761; + e.a23 = 571; + e.a24 = 677; + e.a25 = 763; + e.a26 = 760; + e.a27 = 759; + e.a28 = 754; + e.a6 = 494; + e.a7 = 552; + e.a8 = 537; + e.a9 = 577; + e.a10 = 692; + e.a29 = 786; + e.a30 = 788; + e.a31 = 788; + e.a32 = 790; + e.a33 = 793; + e.a34 = 794; + e.a35 = 816; + e.a36 = 823; + e.a37 = 789; + e.a38 = 841; + e.a39 = 823; + e.a40 = 833; + e.a41 = 816; + e.a42 = 831; + e.a43 = 923; + e.a44 = 744; + e.a45 = 723; + e.a46 = 749; + e.a47 = 790; + e.a48 = 792; + e.a49 = 695; + e.a50 = 776; + e.a51 = 768; + e.a52 = 792; + e.a53 = 759; + e.a54 = 707; + e.a55 = 708; + e.a56 = 682; + e.a57 = 701; + e.a58 = 826; + e.a59 = 815; + e.a60 = 789; + e.a61 = 789; + e.a62 = 707; + e.a63 = 687; + e.a64 = 696; + e.a65 = 689; + e.a66 = 786; + e.a67 = 787; + e.a68 = 713; + e.a69 = 791; + e.a70 = 785; + e.a71 = 791; + e.a72 = 873; + e.a73 = 761; + e.a74 = 762; + e.a203 = 762; + e.a75 = 759; + e.a204 = 759; + e.a76 = 892; + e.a77 = 892; + e.a78 = 788; + e.a79 = 784; + e.a81 = 438; + e.a82 = 138; + e.a83 = 277; + e.a84 = 415; + e.a97 = 392; + e.a98 = 392; + e.a99 = 668; + e.a100 = 668; + e.a89 = 390; + e.a90 = 390; + e.a93 = 317; + e.a94 = 317; + e.a91 = 276; + e.a92 = 276; + e.a205 = 509; + e.a85 = 509; + e.a206 = 410; + e.a86 = 410; + e.a87 = 234; + e.a88 = 234; + e.a95 = 334; + e.a96 = 334; + e.a101 = 732; + e.a102 = 544; + e.a103 = 544; + e.a104 = 910; + e.a106 = 667; + e.a107 = 760; + e.a108 = 760; + e.a112 = 776; + e.a111 = 595; + e.a110 = 694; + e.a109 = 626; + e.a120 = 788; + e.a121 = 788; + e.a122 = 788; + e.a123 = 788; + e.a124 = 788; + e.a125 = 788; + e.a126 = 788; + e.a127 = 788; + e.a128 = 788; + e.a129 = 788; + e.a130 = 788; + e.a131 = 788; + e.a132 = 788; + e.a133 = 788; + e.a134 = 788; + e.a135 = 788; + e.a136 = 788; + e.a137 = 788; + e.a138 = 788; + e.a139 = 788; + e.a140 = 788; + e.a141 = 788; + e.a142 = 788; + e.a143 = 788; + e.a144 = 788; + e.a145 = 788; + e.a146 = 788; + e.a147 = 788; + e.a148 = 788; + e.a149 = 788; + e.a150 = 788; + e.a151 = 788; + e.a152 = 788; + e.a153 = 788; + e.a154 = 788; + e.a155 = 788; + e.a156 = 788; + e.a157 = 788; + e.a158 = 788; + e.a159 = 788; + e.a160 = 894; + e.a161 = 838; + e.a163 = 1016; + e.a164 = 458; + e.a196 = 748; + e.a165 = 924; + e.a192 = 748; + e.a166 = 918; + e.a167 = 927; + e.a168 = 928; + e.a169 = 928; + e.a170 = 834; + e.a171 = 873; + e.a172 = 828; + e.a173 = 924; + e.a162 = 924; + e.a174 = 917; + e.a175 = 930; + e.a176 = 931; + e.a177 = 463; + e.a178 = 883; + e.a179 = 836; + e.a193 = 836; + e.a180 = 867; + e.a199 = 867; + e.a181 = 696; + e.a200 = 696; + e.a182 = 874; + e.a201 = 874; + e.a183 = 760; + e.a184 = 946; + e.a197 = 771; + e.a185 = 865; + e.a194 = 771; + e.a198 = 888; + e.a186 = 967; + e.a195 = 888; + e.a187 = 831; + e.a188 = 873; + e.a189 = 927; + e.a190 = 970; + e.a191 = 918; + }); + }), + ni = getLookupTableFactory(function (e) { + e.Courier = { ascent: 629, descent: -157, capHeight: 562, xHeight: -426 }; + e["Courier-Bold"] = { + ascent: 629, + descent: -157, + capHeight: 562, + xHeight: 439, + }; + e["Courier-Oblique"] = { + ascent: 629, + descent: -157, + capHeight: 562, + xHeight: 426, + }; + e["Courier-BoldOblique"] = { + ascent: 629, + descent: -157, + capHeight: 562, + xHeight: 426, + }; + e.Helvetica = { ascent: 718, descent: -207, capHeight: 718, xHeight: 523 }; + e["Helvetica-Bold"] = { + ascent: 718, + descent: -207, + capHeight: 718, + xHeight: 532, + }; + e["Helvetica-Oblique"] = { + ascent: 718, + descent: -207, + capHeight: 718, + xHeight: 523, + }; + e["Helvetica-BoldOblique"] = { + ascent: 718, + descent: -207, + capHeight: 718, + xHeight: 532, + }; + e["Times-Roman"] = { + ascent: 683, + descent: -217, + capHeight: 662, + xHeight: 450, + }; + e["Times-Bold"] = { + ascent: 683, + descent: -217, + capHeight: 676, + xHeight: 461, + }; + e["Times-Italic"] = { + ascent: 683, + descent: -217, + capHeight: 653, + xHeight: 441, + }; + e["Times-BoldItalic"] = { + ascent: 683, + descent: -217, + capHeight: 669, + xHeight: 462, + }; + e.Symbol = { + ascent: Math.NaN, + descent: Math.NaN, + capHeight: Math.NaN, + xHeight: Math.NaN, + }; + e.ZapfDingbats = { + ascent: Math.NaN, + descent: Math.NaN, + capHeight: Math.NaN, + xHeight: Math.NaN, + }; + }); +class GlyfTable { + constructor({ + glyfTable: e, + isGlyphLocationsLong: t, + locaTable: a, + numGlyphs: r, + }) { + this.glyphs = []; + const i = new DataView(a.buffer, a.byteOffset, a.byteLength), + n = new DataView(e.buffer, e.byteOffset, e.byteLength), + s = t ? 4 : 2; + let o = t ? i.getUint32(0) : 2 * i.getUint16(0), + c = 0; + for (let e = 0; e < r; e++) { + c += s; + const e = t ? i.getUint32(c) : 2 * i.getUint16(c); + if (e === o) { + this.glyphs.push(new Glyph({})); + continue; + } + const a = Glyph.parse(o, n); + this.glyphs.push(a); + o = e; + } + } + getSize() { + return Math.sumPrecise(this.glyphs.map((e) => (e.getSize() + 3) & -4)); + } + write() { + const e = this.getSize(), + t = new DataView(new ArrayBuffer(e)), + a = e > 131070, + r = a ? 4 : 2, + i = new DataView(new ArrayBuffer((this.glyphs.length + 1) * r)); + a ? i.setUint32(0, 0) : i.setUint16(0, 0); + let n = 0, + s = 0; + for (const e of this.glyphs) { + n += e.write(n, t); + n = (n + 3) & -4; + s += r; + a ? i.setUint32(s, n) : i.setUint16(s, n >> 1); + } + return { + isLocationLong: a, + loca: new Uint8Array(i.buffer), + glyf: new Uint8Array(t.buffer), + }; + } + scale(e) { + for (let t = 0, a = this.glyphs.length; t < a; t++) + this.glyphs[t].scale(e[t]); + } +} +class Glyph { + constructor({ header: e = null, simple: t = null, composites: a = null }) { + this.header = e; + this.simple = t; + this.composites = a; + } + static parse(e, t) { + const [a, r] = GlyphHeader.parse(e, t); + e += a; + if (r.numberOfContours < 0) { + const a = []; + for (;;) { + const [r, i] = CompositeGlyph.parse(e, t); + e += r; + a.push(i); + if (!(32 & i.flags)) break; + } + return new Glyph({ header: r, composites: a }); + } + const i = SimpleGlyph.parse(e, t, r.numberOfContours); + return new Glyph({ header: r, simple: i }); + } + getSize() { + if (!this.header) return 0; + const e = this.simple + ? this.simple.getSize() + : Math.sumPrecise(this.composites.map((e) => e.getSize())); + return this.header.getSize() + e; + } + write(e, t) { + if (!this.header) return 0; + const a = e; + e += this.header.write(e, t); + if (this.simple) e += this.simple.write(e, t); + else for (const a of this.composites) e += a.write(e, t); + return e - a; + } + scale(e) { + if (!this.header) return; + const t = (this.header.xMin + this.header.xMax) / 2; + this.header.scale(t, e); + if (this.simple) this.simple.scale(t, e); + else for (const a of this.composites) a.scale(t, e); + } +} +class GlyphHeader { + constructor({ numberOfContours: e, xMin: t, yMin: a, xMax: r, yMax: i }) { + this.numberOfContours = e; + this.xMin = t; + this.yMin = a; + this.xMax = r; + this.yMax = i; + } + static parse(e, t) { + return [ + 10, + new GlyphHeader({ + numberOfContours: t.getInt16(e), + xMin: t.getInt16(e + 2), + yMin: t.getInt16(e + 4), + xMax: t.getInt16(e + 6), + yMax: t.getInt16(e + 8), + }), + ]; + } + getSize() { + return 10; + } + write(e, t) { + t.setInt16(e, this.numberOfContours); + t.setInt16(e + 2, this.xMin); + t.setInt16(e + 4, this.yMin); + t.setInt16(e + 6, this.xMax); + t.setInt16(e + 8, this.yMax); + return 10; + } + scale(e, t) { + this.xMin = Math.round(e + (this.xMin - e) * t); + this.xMax = Math.round(e + (this.xMax - e) * t); + } +} +class Contour { + constructor({ flags: e, xCoordinates: t, yCoordinates: a }) { + this.xCoordinates = t; + this.yCoordinates = a; + this.flags = e; + } +} +class SimpleGlyph { + constructor({ contours: e, instructions: t }) { + this.contours = e; + this.instructions = t; + } + static parse(e, t, a) { + const r = []; + for (let i = 0; i < a; i++) { + const a = t.getUint16(e); + e += 2; + r.push(a); + } + const i = r[a - 1] + 1, + n = t.getUint16(e); + e += 2; + const s = new Uint8Array(t).slice(e, e + n); + e += n; + const o = []; + for (let a = 0; a < i; e++, a++) { + let r = t.getUint8(e); + o.push(r); + if (8 & r) { + const i = t.getUint8(++e); + r ^= 8; + for (let e = 0; e < i; e++) o.push(r); + a += i; + } + } + const c = []; + let l = [], + h = [], + u = []; + const d = []; + let f = 0, + g = 0; + for (let a = 0; a < i; a++) { + const i = o[a]; + if (2 & i) { + const a = t.getUint8(e++); + g += 16 & i ? a : -a; + l.push(g); + } else if (16 & i) l.push(g); + else { + g += t.getInt16(e); + e += 2; + l.push(g); + } + if (r[f] === a) { + f++; + c.push(l); + l = []; + } + } + g = 0; + f = 0; + for (let a = 0; a < i; a++) { + const i = o[a]; + if (4 & i) { + const a = t.getUint8(e++); + g += 32 & i ? a : -a; + h.push(g); + } else if (32 & i) h.push(g); + else { + g += t.getInt16(e); + e += 2; + h.push(g); + } + u.push((1 & i) | (64 & i)); + if (r[f] === a) { + l = c[f]; + f++; + d.push(new Contour({ flags: u, xCoordinates: l, yCoordinates: h })); + h = []; + u = []; + } + } + return new SimpleGlyph({ contours: d, instructions: s }); + } + getSize() { + let e = 2 * this.contours.length + 2 + this.instructions.length, + t = 0, + a = 0; + for (const r of this.contours) { + e += r.flags.length; + for (let i = 0, n = r.xCoordinates.length; i < n; i++) { + const n = r.xCoordinates[i], + s = r.yCoordinates[i]; + let o = Math.abs(n - t); + o > 255 ? (e += 2) : o > 0 && (e += 1); + t = n; + o = Math.abs(s - a); + o > 255 ? (e += 2) : o > 0 && (e += 1); + a = s; + } + } + return e; + } + write(e, t) { + const a = e, + r = [], + i = [], + n = []; + let s = 0, + o = 0; + for (const a of this.contours) { + for (let e = 0, t = a.xCoordinates.length; e < t; e++) { + let t = a.flags[e]; + const c = a.xCoordinates[e]; + let l = c - s; + if (0 === l) { + t |= 16; + r.push(0); + } else { + const e = Math.abs(l); + if (e <= 255) { + t |= l >= 0 ? 18 : 2; + r.push(e); + } else r.push(l); + } + s = c; + const h = a.yCoordinates[e]; + l = h - o; + if (0 === l) { + t |= 32; + i.push(0); + } else { + const e = Math.abs(l); + if (e <= 255) { + t |= l >= 0 ? 36 : 4; + i.push(e); + } else i.push(l); + } + o = h; + n.push(t); + } + t.setUint16(e, r.length - 1); + e += 2; + } + t.setUint16(e, this.instructions.length); + e += 2; + if (this.instructions.length) { + new Uint8Array(t.buffer, 0, t.buffer.byteLength).set( + this.instructions, + e, + ); + e += this.instructions.length; + } + for (const a of n) t.setUint8(e++, a); + for (let a = 0, i = r.length; a < i; a++) { + const i = r[a], + s = n[a]; + if (2 & s) t.setUint8(e++, i); + else if (!(16 & s)) { + t.setInt16(e, i); + e += 2; + } + } + for (let a = 0, r = i.length; a < r; a++) { + const r = i[a], + s = n[a]; + if (4 & s) t.setUint8(e++, r); + else if (!(32 & s)) { + t.setInt16(e, r); + e += 2; + } + } + return e - a; + } + scale(e, t) { + for (const a of this.contours) + if (0 !== a.xCoordinates.length) + for (let r = 0, i = a.xCoordinates.length; r < i; r++) + a.xCoordinates[r] = Math.round(e + (a.xCoordinates[r] - e) * t); + } +} +class CompositeGlyph { + constructor({ + flags: e, + glyphIndex: t, + argument1: a, + argument2: r, + transf: i, + instructions: n, + }) { + this.flags = e; + this.glyphIndex = t; + this.argument1 = a; + this.argument2 = r; + this.transf = i; + this.instructions = n; + } + static parse(e, t) { + const a = e, + r = []; + let i = t.getUint16(e); + const n = t.getUint16(e + 2); + e += 4; + let s, o; + if (1 & i) { + if (2 & i) { + s = t.getInt16(e); + o = t.getInt16(e + 2); + } else { + s = t.getUint16(e); + o = t.getUint16(e + 2); + } + e += 4; + i ^= 1; + } else { + if (2 & i) { + s = t.getInt8(e); + o = t.getInt8(e + 1); + } else { + s = t.getUint8(e); + o = t.getUint8(e + 1); + } + e += 2; + } + if (8 & i) { + r.push(t.getUint16(e)); + e += 2; + } else if (64 & i) { + r.push(t.getUint16(e), t.getUint16(e + 2)); + e += 4; + } else if (128 & i) { + r.push( + t.getUint16(e), + t.getUint16(e + 2), + t.getUint16(e + 4), + t.getUint16(e + 6), + ); + e += 8; + } + let c = null; + if (256 & i) { + const a = t.getUint16(e); + e += 2; + c = new Uint8Array(t).slice(e, e + a); + e += a; + } + return [ + e - a, + new CompositeGlyph({ + flags: i, + glyphIndex: n, + argument1: s, + argument2: o, + transf: r, + instructions: c, + }), + ]; + } + getSize() { + let e = 4 + 2 * this.transf.length; + 256 & this.flags && (e += 2 + this.instructions.length); + e += 2; + 2 & this.flags + ? (this.argument1 >= -128 && + this.argument1 <= 127 && + this.argument2 >= -128 && + this.argument2 <= 127) || + (e += 2) + : (this.argument1 >= 0 && + this.argument1 <= 255 && + this.argument2 >= 0 && + this.argument2 <= 255) || + (e += 2); + return e; + } + write(e, t) { + const a = e; + 2 & this.flags + ? (this.argument1 >= -128 && + this.argument1 <= 127 && + this.argument2 >= -128 && + this.argument2 <= 127) || + (this.flags |= 1) + : (this.argument1 >= 0 && + this.argument1 <= 255 && + this.argument2 >= 0 && + this.argument2 <= 255) || + (this.flags |= 1); + t.setUint16(e, this.flags); + t.setUint16(e + 2, this.glyphIndex); + e += 4; + if (1 & this.flags) { + if (2 & this.flags) { + t.setInt16(e, this.argument1); + t.setInt16(e + 2, this.argument2); + } else { + t.setUint16(e, this.argument1); + t.setUint16(e + 2, this.argument2); + } + e += 4; + } else { + t.setUint8(e, this.argument1); + t.setUint8(e + 1, this.argument2); + e += 2; + } + if (256 & this.flags) { + t.setUint16(e, this.instructions.length); + e += 2; + if (this.instructions.length) { + new Uint8Array(t.buffer, 0, t.buffer.byteLength).set( + this.instructions, + e, + ); + e += this.instructions.length; + } + } + return e - a; + } + scale(e, t) {} +} +function writeInt16(e, t, a) { + e[t] = (a >> 8) & 255; + e[t + 1] = 255 & a; +} +function writeInt32(e, t, a) { + e[t] = (a >> 24) & 255; + e[t + 1] = (a >> 16) & 255; + e[t + 2] = (a >> 8) & 255; + e[t + 3] = 255 & a; +} +function writeData(e, t, a) { + if (a instanceof Uint8Array) e.set(a, t); + else if ("string" == typeof a) + for (let r = 0, i = a.length; r < i; r++) e[t++] = 255 & a.charCodeAt(r); + else for (const r of a) e[t++] = 255 & r; +} +class OpenTypeFileBuilder { + constructor(e) { + this.sfnt = e; + this.tables = Object.create(null); + } + static getSearchParams(e, t) { + let a = 1, + r = 0; + for (; (a ^ e) > a; ) { + a <<= 1; + r++; + } + const i = a * t; + return { range: i, entry: r, rangeShift: t * e - i }; + } + toArray() { + let e = this.sfnt; + const t = this.tables, + a = Object.keys(t); + a.sort(); + const r = a.length; + let i, + n, + s, + o, + c, + l = 12 + 16 * r; + const h = [l]; + for (i = 0; i < r; i++) { + o = t[a[i]]; + l += ((o.length + 3) & -4) >>> 0; + h.push(l); + } + const u = new Uint8Array(l); + for (i = 0; i < r; i++) { + o = t[a[i]]; + writeData(u, h[i], o); + } + "true" === e && (e = string32(65536)); + u[0] = 255 & e.charCodeAt(0); + u[1] = 255 & e.charCodeAt(1); + u[2] = 255 & e.charCodeAt(2); + u[3] = 255 & e.charCodeAt(3); + writeInt16(u, 4, r); + const d = OpenTypeFileBuilder.getSearchParams(r, 16); + writeInt16(u, 6, d.range); + writeInt16(u, 8, d.entry); + writeInt16(u, 10, d.rangeShift); + l = 12; + for (i = 0; i < r; i++) { + c = a[i]; + u[l] = 255 & c.charCodeAt(0); + u[l + 1] = 255 & c.charCodeAt(1); + u[l + 2] = 255 & c.charCodeAt(2); + u[l + 3] = 255 & c.charCodeAt(3); + let e = 0; + for (n = h[i], s = h[i + 1]; n < s; n += 4) { + e = (e + readUint32(u, n)) >>> 0; + } + writeInt32(u, l + 4, e); + writeInt32(u, l + 8, h[i]); + writeInt32(u, l + 12, t[c].length); + l += 16; + } + return u; + } + addTable(e, t) { + if (e in this.tables) throw new Error("Table " + e + " already exists"); + this.tables[e] = t; + } +} +const si = [4], + oi = [5], + ci = [6], + li = [7], + hi = [8], + ui = [12, 35], + di = [14], + fi = [21], + gi = [22], + pi = [30], + mi = [31]; +class Type1CharString { + constructor() { + this.width = 0; + this.lsb = 0; + this.flexing = !1; + this.output = []; + this.stack = []; + } + convert(e, t, a) { + const r = e.length; + let i, + n, + s, + o = !1; + for (let c = 0; c < r; c++) { + let r = e[c]; + if (r < 32) { + 12 === r && (r = (r << 8) + e[++c]); + switch (r) { + case 1: + case 3: + case 9: + case 3072: + case 3073: + case 3074: + case 3105: + this.stack = []; + break; + case 4: + if (this.flexing) { + if (this.stack.length < 1) { + o = !0; + break; + } + const e = this.stack.pop(); + this.stack.push(0, e); + break; + } + o = this.executeCommand(1, si); + break; + case 5: + o = this.executeCommand(2, oi); + break; + case 6: + o = this.executeCommand(1, ci); + break; + case 7: + o = this.executeCommand(1, li); + break; + case 8: + o = this.executeCommand(6, hi); + break; + case 10: + if (this.stack.length < 1) { + o = !0; + break; + } + s = this.stack.pop(); + if (!t[s]) { + o = !0; + break; + } + o = this.convert(t[s], t, a); + break; + case 11: + return o; + case 13: + if (this.stack.length < 2) { + o = !0; + break; + } + i = this.stack.pop(); + n = this.stack.pop(); + this.lsb = n; + this.width = i; + this.stack.push(i, n); + o = this.executeCommand(2, gi); + break; + case 14: + this.output.push(di[0]); + break; + case 21: + if (this.flexing) break; + o = this.executeCommand(2, fi); + break; + case 22: + if (this.flexing) { + this.stack.push(0); + break; + } + o = this.executeCommand(1, gi); + break; + case 30: + o = this.executeCommand(4, pi); + break; + case 31: + o = this.executeCommand(4, mi); + break; + case 3078: + if (a) { + const e = this.stack.at(-5); + this.seac = this.stack.splice(-4, 4); + this.seac[0] += this.lsb - e; + o = this.executeCommand(0, di); + } else o = this.executeCommand(4, di); + break; + case 3079: + if (this.stack.length < 4) { + o = !0; + break; + } + this.stack.pop(); + i = this.stack.pop(); + const e = this.stack.pop(); + n = this.stack.pop(); + this.lsb = n; + this.width = i; + this.stack.push(i, n, e); + o = this.executeCommand(3, fi); + break; + case 3084: + if (this.stack.length < 2) { + o = !0; + break; + } + const c = this.stack.pop(), + l = this.stack.pop(); + this.stack.push(l / c); + break; + case 3088: + if (this.stack.length < 2) { + o = !0; + break; + } + s = this.stack.pop(); + const h = this.stack.pop(); + if (0 === s && 3 === h) { + const e = this.stack.splice(-17, 17); + this.stack.push( + e[2] + e[0], + e[3] + e[1], + e[4], + e[5], + e[6], + e[7], + e[8], + e[9], + e[10], + e[11], + e[12], + e[13], + e[14], + ); + o = this.executeCommand(13, ui, !0); + this.flexing = !1; + this.stack.push(e[15], e[16]); + } else 1 === s && 0 === h && (this.flexing = !0); + break; + case 3089: + break; + default: + warn('Unknown type 1 charstring command of "' + r + '"'); + } + if (o) break; + } else { + r <= 246 + ? (r -= 139) + : (r = + r <= 250 + ? 256 * (r - 247) + e[++c] + 108 + : r <= 254 + ? -256 * (r - 251) - e[++c] - 108 + : ((255 & e[++c]) << 24) | + ((255 & e[++c]) << 16) | + ((255 & e[++c]) << 8) | + (255 & e[++c])); + this.stack.push(r); + } + } + return o; + } + executeCommand(e, t, a) { + const r = this.stack.length; + if (e > r) return !0; + const i = r - e; + for (let e = i; e < r; e++) { + let t = this.stack[e]; + if (Number.isInteger(t)) this.output.push(28, (t >> 8) & 255, 255 & t); + else { + t = (65536 * t) | 0; + this.output.push( + 255, + (t >> 24) & 255, + (t >> 16) & 255, + (t >> 8) & 255, + 255 & t, + ); + } + } + this.output.push(...t); + a ? this.stack.splice(i, e) : (this.stack.length = 0); + return !1; + } +} +function isHexDigit(e) { + return (e >= 48 && e <= 57) || (e >= 65 && e <= 70) || (e >= 97 && e <= 102); +} +function decrypt(e, t, a) { + if (a >= e.length) return new Uint8Array(0); + let r, + i, + n = 0 | t; + for (r = 0; r < a; r++) n = (52845 * (e[r] + n) + 22719) & 65535; + const s = e.length - a, + o = new Uint8Array(s); + for (r = a, i = 0; i < s; r++, i++) { + const t = e[r]; + o[i] = t ^ (n >> 8); + n = (52845 * (t + n) + 22719) & 65535; + } + return o; +} +function isSpecial(e) { + return ( + 47 === e || + 91 === e || + 93 === e || + 123 === e || + 125 === e || + 40 === e || + 41 === e + ); +} +class Type1Parser { + constructor(e, t, a) { + if (t) { + const t = e.getBytes(), + a = !( + (isHexDigit(t[0]) || isWhiteSpace(t[0])) && + isHexDigit(t[1]) && + isHexDigit(t[2]) && + isHexDigit(t[3]) && + isHexDigit(t[4]) && + isHexDigit(t[5]) && + isHexDigit(t[6]) && + isHexDigit(t[7]) + ); + e = new Stream( + a + ? decrypt(t, 55665, 4) + : (function decryptAscii(e, t, a) { + let r = 0 | t; + const i = e.length, + n = new Uint8Array(i >>> 1); + let s, o; + for (s = 0, o = 0; s < i; s++) { + const t = e[s]; + if (!isHexDigit(t)) continue; + s++; + let a; + for (; s < i && !isHexDigit((a = e[s])); ) s++; + if (s < i) { + const e = parseInt(String.fromCharCode(t, a), 16); + n[o++] = e ^ (r >> 8); + r = (52845 * (e + r) + 22719) & 65535; + } + } + return n.slice(a, o); + })(t, 55665, 4), + ); + } + this.seacAnalysisEnabled = !!a; + this.stream = e; + this.nextChar(); + } + readNumberArray() { + this.getToken(); + const e = []; + for (;;) { + const t = this.getToken(); + if (null === t || "]" === t || "}" === t) break; + e.push(parseFloat(t || 0)); + } + return e; + } + readNumber() { + const e = this.getToken(); + return parseFloat(e || 0); + } + readInt() { + const e = this.getToken(); + return 0 | parseInt(e || 0, 10); + } + readBoolean() { + return "true" === this.getToken() ? 1 : 0; + } + nextChar() { + return (this.currentChar = this.stream.getByte()); + } + prevChar() { + this.stream.skip(-2); + return (this.currentChar = this.stream.getByte()); + } + getToken() { + let e = !1, + t = this.currentChar; + for (;;) { + if (-1 === t) return null; + if (e) (10 !== t && 13 !== t) || (e = !1); + else if (37 === t) e = !0; + else if (!isWhiteSpace(t)) break; + t = this.nextChar(); + } + if (isSpecial(t)) { + this.nextChar(); + return String.fromCharCode(t); + } + let a = ""; + do { + a += String.fromCharCode(t); + t = this.nextChar(); + } while (t >= 0 && !isWhiteSpace(t) && !isSpecial(t)); + return a; + } + readCharStrings(e, t) { + return -1 === t ? e : decrypt(e, 4330, t); + } + extractFontProgram(e) { + const t = this.stream, + a = [], + r = [], + i = Object.create(null); + i.lenIV = 4; + const n = { subrs: [], charstrings: [], properties: { privateData: i } }; + let s, o, c, l; + for (; null !== (s = this.getToken()); ) + if ("/" === s) { + s = this.getToken(); + switch (s) { + case "CharStrings": + this.getToken(); + this.getToken(); + this.getToken(); + this.getToken(); + for (;;) { + s = this.getToken(); + if (null === s || "end" === s) break; + if ("/" !== s) continue; + const e = this.getToken(); + o = this.readInt(); + this.getToken(); + c = o > 0 ? t.getBytes(o) : new Uint8Array(0); + l = n.properties.privateData.lenIV; + const a = this.readCharStrings(c, l); + this.nextChar(); + s = this.getToken(); + "noaccess" === s ? this.getToken() : "/" === s && this.prevChar(); + r.push({ glyph: e, encoded: a }); + } + break; + case "Subrs": + this.readInt(); + this.getToken(); + for (; "dup" === this.getToken(); ) { + const e = this.readInt(); + o = this.readInt(); + this.getToken(); + c = o > 0 ? t.getBytes(o) : new Uint8Array(0); + l = n.properties.privateData.lenIV; + const r = this.readCharStrings(c, l); + this.nextChar(); + s = this.getToken(); + "noaccess" === s && this.getToken(); + a[e] = r; + } + break; + case "BlueValues": + case "OtherBlues": + case "FamilyBlues": + case "FamilyOtherBlues": + const e = this.readNumberArray(); + (e.length > 0 && e.length, 0); + break; + case "StemSnapH": + case "StemSnapV": + n.properties.privateData[s] = this.readNumberArray(); + break; + case "StdHW": + case "StdVW": + n.properties.privateData[s] = this.readNumberArray()[0]; + break; + case "BlueShift": + case "lenIV": + case "BlueFuzz": + case "BlueScale": + case "LanguageGroup": + n.properties.privateData[s] = this.readNumber(); + break; + case "ExpansionFactor": + n.properties.privateData[s] = this.readNumber() || 0.06; + break; + case "ForceBold": + n.properties.privateData[s] = this.readBoolean(); + } + } + for (const { encoded: t, glyph: i } of r) { + const r = new Type1CharString(), + s = r.convert(t, a, this.seacAnalysisEnabled); + let o = r.output; + s && (o = [14]); + const c = { + glyphName: i, + charstring: o, + width: r.width, + lsb: r.lsb, + seac: r.seac, + }; + ".notdef" === i ? n.charstrings.unshift(c) : n.charstrings.push(c); + if (e.builtInEncoding) { + const t = e.builtInEncoding.indexOf(i); + t > -1 && + void 0 === e.widths[t] && + t >= e.firstChar && + t <= e.lastChar && + (e.widths[t] = r.width); + } + } + return n; + } + extractFontHeader(e) { + let t; + for (; null !== (t = this.getToken()); ) + if ("/" === t) { + t = this.getToken(); + switch (t) { + case "FontMatrix": + const a = this.readNumberArray(); + e.fontMatrix = a; + break; + case "Encoding": + const r = this.getToken(); + let i; + if (/^\d+$/.test(r)) { + i = []; + const e = 0 | parseInt(r, 10); + this.getToken(); + for (let a = 0; a < e; a++) { + t = this.getToken(); + for (; "dup" !== t && "def" !== t; ) { + t = this.getToken(); + if (null === t) return; + } + if ("def" === t) break; + const e = this.readInt(); + this.getToken(); + const a = this.getToken(); + i[e] = a; + this.getToken(); + } + } else i = getEncoding(r); + e.builtInEncoding = i; + break; + case "FontBBox": + const n = this.readNumberArray(); + e.ascent = Math.max(n[3], n[1]); + e.descent = Math.min(n[1], n[3]); + e.ascentScaled = !0; + } + } + } +} +function findBlock(e, t, a) { + const r = e.length, + i = t.length, + n = r - i; + let s = a, + o = !1; + for (; s < n; ) { + let a = 0; + for (; a < i && e[s + a] === t[a]; ) a++; + if (a >= i) { + s += a; + for (; s < r && isWhiteSpace(e[s]); ) s++; + o = !0; + break; + } + s++; + } + return { found: o, length: s }; +} +class Type1Font { + constructor(e, t, a) { + let r = a.length1, + i = a.length2, + n = t.peekBytes(6); + const s = 128 === n[0] && 1 === n[1]; + if (s) { + t.skip(6); + r = (n[5] << 24) | (n[4] << 16) | (n[3] << 8) | n[2]; + } + const o = (function getHeaderBlock(e, t) { + const a = [101, 101, 120, 101, 99], + r = e.pos; + let i, n, s, o; + try { + i = e.getBytes(t); + n = i.length; + } catch {} + if (n === t) { + s = findBlock(i, a, t - 2 * a.length); + if (s.found && s.length === t) + return { stream: new Stream(i), length: t }; + } + warn('Invalid "Length1" property in Type1 font -- trying to recover.'); + e.pos = r; + for (;;) { + s = findBlock(e.peekBytes(2048), a, 0); + if (0 === s.length) break; + e.pos += s.length; + if (s.found) { + o = e.pos - r; + break; + } + } + e.pos = r; + if (o) return { stream: new Stream(e.getBytes(o)), length: o }; + warn( + 'Unable to recover "Length1" property in Type1 font -- using as is.', + ); + return { stream: new Stream(e.getBytes(t)), length: t }; + })(t, r); + new Type1Parser(o.stream, !1, Rr).extractFontHeader(a); + if (s) { + n = t.getBytes(6); + i = (n[5] << 24) | (n[4] << 16) | (n[3] << 8) | n[2]; + } + const c = (function getEexecBlock(e, t) { + const a = e.getBytes(); + if (0 === a.length) + throw new FormatError("getEexecBlock - no font program found."); + return { stream: new Stream(a), length: a.length }; + })(t), + l = new Type1Parser(c.stream, !0, Rr).extractFontProgram(a); + for (const e in l.properties) a[e] = l.properties[e]; + const h = l.charstrings, + u = this.getType2Charstrings(h), + d = this.getType2Subrs(l.subrs); + this.charstrings = h; + this.data = this.wrap(e, u, this.charstrings, d, a); + this.seacs = this.getSeacs(l.charstrings); + } + get numGlyphs() { + return this.charstrings.length + 1; + } + getCharset() { + const e = [".notdef"]; + for (const { glyphName: t } of this.charstrings) e.push(t); + return e; + } + getGlyphMapping(e) { + const t = this.charstrings; + if (e.composite) { + const a = Object.create(null); + for (let r = 0, i = t.length; r < i; r++) { + a[e.cMap.charCodeOf(r)] = r + 1; + } + return a; + } + const a = [".notdef"]; + let r, i; + for (i = 0; i < t.length; i++) a.push(t[i].glyphName); + const n = e.builtInEncoding; + if (n) { + r = Object.create(null); + for (const e in n) { + i = a.indexOf(n[e]); + i >= 0 && (r[e] = i); + } + } + return type1FontGlyphMapping(e, r, a); + } + hasGlyphId(e) { + if (e < 0 || e >= this.numGlyphs) return !1; + if (0 === e) return !0; + return this.charstrings[e - 1].charstring.length > 0; + } + getSeacs(e) { + const t = []; + for (let a = 0, r = e.length; a < r; a++) { + const r = e[a]; + r.seac && (t[a + 1] = r.seac); + } + return t; + } + getType2Charstrings(e) { + const t = []; + for (const a of e) t.push(a.charstring); + return t; + } + getType2Subrs(e) { + let t = 0; + const a = e.length; + t = a < 1133 ? 107 : a < 33769 ? 1131 : 32768; + const r = []; + let i; + for (i = 0; i < t; i++) r.push([11]); + for (i = 0; i < a; i++) r.push(e[i]); + return r; + } + wrap(e, t, a, r, i) { + const n = new CFF(); + n.header = new CFFHeader(1, 0, 4, 4); + n.names = [e]; + const s = new CFFTopDict(); + s.setByName("version", 391); + s.setByName("Notice", 392); + s.setByName("FullName", 393); + s.setByName("FamilyName", 394); + s.setByName("Weight", 395); + s.setByName("Encoding", null); + s.setByName("FontMatrix", i.fontMatrix); + s.setByName("FontBBox", i.bbox); + s.setByName("charset", null); + s.setByName("CharStrings", null); + s.setByName("Private", null); + n.topDict = s; + const o = new CFFStrings(); + o.add("Version 0.11"); + o.add("See original notice"); + o.add(e); + o.add(e); + o.add("Medium"); + n.strings = o; + n.globalSubrIndex = new CFFIndex(); + const c = t.length, + l = [".notdef"]; + let h, u; + for (h = 0; h < c; h++) { + const e = a[h].glyphName; + -1 === Hr.indexOf(e) && o.add(e); + l.push(e); + } + n.charset = new CFFCharset(!1, 0, l); + const d = new CFFIndex(); + d.add([139, 14]); + for (h = 0; h < c; h++) d.add(t[h]); + n.charStrings = d; + const f = new CFFPrivateDict(); + f.setByName("Subrs", null); + const g = [ + "BlueValues", + "OtherBlues", + "FamilyBlues", + "FamilyOtherBlues", + "StemSnapH", + "StemSnapV", + "BlueShift", + "BlueFuzz", + "BlueScale", + "LanguageGroup", + "ExpansionFactor", + "ForceBold", + "StdHW", + "StdVW", + ]; + for (h = 0, u = g.length; h < u; h++) { + const e = g[h]; + if (!(e in i.privateData)) continue; + const t = i.privateData[e]; + if (Array.isArray(t)) + for (let e = t.length - 1; e > 0; e--) t[e] -= t[e - 1]; + f.setByName(e, t); + } + n.topDict.privateDict = f; + const p = new CFFIndex(); + for (h = 0, u = r.length; h < u; h++) p.add(r[h]); + f.subrsIndex = p; + return new CFFCompiler(n).compile(); + } +} +const bi = [ + [57344, 63743], + [1048576, 1114109], + ], + yi = 1e3, + wi = [ + "ascent", + "bbox", + "black", + "bold", + "charProcOperatorList", + "cssFontInfo", + "data", + "defaultVMetrics", + "defaultWidth", + "descent", + "disableFontFace", + "fallbackName", + "fontExtraProperties", + "fontMatrix", + "isInvalidPDFjsFont", + "isType3Font", + "italic", + "loadedName", + "mimetype", + "missingFile", + "name", + "remeasure", + "systemFontInfo", + "vertical", + ], + xi = [ + "cMap", + "composite", + "defaultEncoding", + "differences", + "isMonospace", + "isSerifFont", + "isSymbolicFont", + "seacMap", + "subtype", + "toFontChar", + "toUnicode", + "type", + "vmetrics", + "widths", + ]; +function adjustWidths(e) { + if (!e.fontMatrix) return; + if (e.fontMatrix[0] === t[0]) return; + const a = 0.001 / e.fontMatrix[0], + r = e.widths; + for (const e in r) r[e] *= a; + e.defaultWidth *= a; +} +function amendFallbackToUnicode(e) { + if (!e.fallbackToUnicode) return; + if (e.toUnicode instanceof IdentityToUnicodeMap) return; + const t = []; + for (const a in e.fallbackToUnicode) + e.toUnicode.has(a) || (t[a] = e.fallbackToUnicode[a]); + t.length > 0 && e.toUnicode.amend(t); +} +class fonts_Glyph { + constructor(e, t, a, r, i, n, s, o, c) { + this.originalCharCode = e; + this.fontChar = t; + this.unicode = a; + this.accent = r; + this.width = i; + this.vmetric = n; + this.operatorListId = s; + this.isSpace = o; + this.isInFont = c; + } + get category() { + return shadow( + this, + "category", + (function getCharUnicodeCategory(e) { + const t = Dr.get(e); + if (t) return t; + const a = e.match(Mr), + r = { + isWhitespace: !!a?.[1], + isZeroWidthDiacritic: !!a?.[2], + isInvisibleFormatMark: !!a?.[3], + }; + Dr.set(e, r); + return r; + })(this.unicode), + !0, + ); + } +} +function int16(e, t) { + return (e << 8) + t; +} +function writeSignedInt16(e, t, a) { + e[t + 1] = a; + e[t] = a >>> 8; +} +function signedInt16(e, t) { + const a = (e << 8) + t; + return 32768 & a ? a - 65536 : a; +} +function string16(e) { + return String.fromCharCode((e >> 8) & 255, 255 & e); +} +function safeString16(e) { + e > 32767 ? (e = 32767) : e < -32768 && (e = -32768); + return String.fromCharCode((e >> 8) & 255, 255 & e); +} +function isTrueTypeCollectionFile(e) { + return "ttcf" === bytesToString(e.peekBytes(4)); +} +function getFontFileType(e, { type: t, subtype: a, composite: r }) { + let i, n; + if ( + (function isTrueTypeFile(e) { + const t = e.peekBytes(4); + return 65536 === readUint32(t, 0) || "true" === bytesToString(t); + })(e) || + isTrueTypeCollectionFile(e) + ) + i = r ? "CIDFontType2" : "TrueType"; + else if ( + (function isOpenTypeFile(e) { + return "OTTO" === bytesToString(e.peekBytes(4)); + })(e) + ) + i = r ? "CIDFontType2" : "OpenType"; + else if ( + (function isType1File(e) { + const t = e.peekBytes(2); + return (37 === t[0] && 33 === t[1]) || (128 === t[0] && 1 === t[1]); + })(e) + ) + i = r ? "CIDFontType0" : "MMType1" === t ? "MMType1" : "Type1"; + else if ( + (function isCFFFile(e) { + const t = e.peekBytes(4); + return t[0] >= 1 && t[3] >= 1 && t[3] <= 4; + })(e) + ) + if (r) { + i = "CIDFontType0"; + n = "CIDFontType0C"; + } else { + i = "MMType1" === t ? "MMType1" : "Type1"; + n = "Type1C"; + } + else { + warn("getFontFileType: Unable to detect correct font file Type/Subtype."); + i = t; + n = a; + } + return [i, n]; +} +function applyStandardFontGlyphMap(e, t) { + for (const a in t) e[+a] = t[a]; +} +function buildToFontChar(e, t, a) { + const r = []; + let i; + for (let a = 0, n = e.length; a < n; a++) { + i = getUnicodeForGlyph(e[a], t); + -1 !== i && (r[a] = i); + } + for (const e in a) { + i = getUnicodeForGlyph(a[e], t); + -1 !== i && (r[+e] = i); + } + return r; +} +function isMacNameRecord(e) { + return 1 === e.platform && 0 === e.encoding && 0 === e.language; +} +function isWinNameRecord(e) { + return 3 === e.platform && 1 === e.encoding && 1033 === e.language; +} +function convertCidString(e, t, a = !1) { + switch (t.length) { + case 1: + return t.charCodeAt(0); + case 2: + return (t.charCodeAt(0) << 8) | t.charCodeAt(1); + } + const r = `Unsupported CID string (charCode ${e}): "${t}".`; + if (a) throw new FormatError(r); + warn(r); + return t; +} +function adjustMapping(e, t, a, r) { + const i = Object.create(null), + n = new Map(), + s = [], + o = new Set(); + let c = 0; + let l = bi[c][0], + h = bi[c][1]; + let u = null; + for (const f in e) { + let g = e[f]; + if (!t(g)) continue; + if (l > h) { + c++; + if (c >= bi.length) { + warn("Ran out of space in font private use area."); + break; + } + l = bi[c][0]; + h = bi[c][1]; + } + const p = l++; + 0 === g && (g = a); + let m = r.get(f); + if ("string" == typeof m) + if (1 === m.length) m = m.codePointAt(0); + else { + if (!u) { + u = new Map(); + for (let e = 64256; e <= 64335; e++) { + const t = String.fromCharCode(e).normalize("NFKD"); + t.length > 1 && u.set(t, e); + } + } + m = u.get(m) || m.codePointAt(0); + } + if ( + m && + !((d = m), + (bi[0][0] <= d && d <= bi[0][1]) || (bi[1][0] <= d && d <= bi[1][1])) && + !o.has(g) + ) { + n.set(m, g); + o.add(g); + } + i[p] = g; + s[f] = p; + } + var d; + return { + toFontChar: s, + charCodeToGlyphId: i, + toUnicodeExtraMap: n, + nextAvailableFontCharCode: l, + }; +} +function createCmapTable(e, t, a) { + const r = (function getRanges(e, t, a) { + const r = []; + for (const t in e) + e[t] >= a || r.push({ fontCharCode: 0 | t, glyphId: e[t] }); + if (t) + for (const [e, i] of t) + i >= a || r.push({ fontCharCode: e, glyphId: i }); + 0 === r.length && r.push({ fontCharCode: 0, glyphId: 0 }); + r.sort((e, t) => e.fontCharCode - t.fontCharCode); + const i = [], + n = r.length; + for (let e = 0; e < n; ) { + const t = r[e].fontCharCode, + a = [r[e].glyphId]; + ++e; + let s = t; + for (; e < n && s + 1 === r[e].fontCharCode; ) { + a.push(r[e].glyphId); + ++s; + ++e; + if (65535 === s) break; + } + i.push([t, s, a]); + } + return i; + })(e, t, a), + i = r.at(-1)[1] > 65535 ? 2 : 1; + let n, + s, + o, + c, + l = "\0\0" + string16(i) + "\0\0" + string32(4 + 8 * i); + for (n = r.length - 1; n >= 0 && !(r[n][0] <= 65535); --n); + const h = n + 1; + r[n][0] < 65535 && 65535 === r[n][1] && (r[n][1] = 65534); + const u = r[n][1] < 65535 ? 1 : 0, + d = h + u, + f = OpenTypeFileBuilder.getSearchParams(d, 2); + let g, + p, + m, + b, + y = "", + w = "", + x = "", + S = "", + k = "", + C = 0; + for (n = 0, s = h; n < s; n++) { + g = r[n]; + p = g[0]; + m = g[1]; + y += string16(p); + w += string16(m); + b = g[2]; + let e = !0; + for (o = 1, c = b.length; o < c; ++o) + if (b[o] !== b[o - 1] + 1) { + e = !1; + break; + } + if (e) { + x += string16((b[0] - p) & 65535); + S += string16(0); + } else { + const e = 2 * (d - n) + 2 * C; + C += m - p + 1; + x += string16(0); + S += string16(e); + for (o = 0, c = b.length; o < c; ++o) k += string16(b[o]); + } + } + if (u > 0) { + w += "ÿÿ"; + y += "ÿÿ"; + x += "\0"; + S += "\0\0"; + } + const v = + "\0\0" + + string16(2 * d) + + string16(f.range) + + string16(f.entry) + + string16(f.rangeShift) + + w + + "\0\0" + + y + + x + + S + + k; + let F = "", + T = ""; + if (i > 1) { + l += "\0\0\n" + string32(4 + 8 * i + 4 + v.length); + F = ""; + for (n = 0, s = r.length; n < s; n++) { + g = r[n]; + p = g[0]; + b = g[2]; + let e = b[0]; + for (o = 1, c = b.length; o < c; ++o) + if (b[o] !== b[o - 1] + 1) { + m = g[0] + o - 1; + F += string32(p) + string32(m) + string32(e); + p = m + 1; + e = b[o]; + } + F += string32(p) + string32(g[1]) + string32(e); + } + T = + "\0\f\0\0" + + string32(F.length + 16) + + "\0\0\0\0" + + string32(F.length / 12); + } + return l + "\0" + string16(v.length + 4) + v + T + F; +} +function createOS2Table(e, t, a) { + a ||= { unitsPerEm: 0, yMax: 0, yMin: 0, ascent: 0, descent: 0 }; + let r = 0, + i = 0, + n = 0, + s = 0, + o = null, + c = 0, + l = -1; + if (t) { + for (let e in t) { + e |= 0; + (o > e || !o) && (o = e); + c < e && (c = e); + l = getUnicodeRangeFor(e, l); + if (l < 32) r |= 1 << l; + else if (l < 64) i |= 1 << (l - 32); + else if (l < 96) n |= 1 << (l - 64); + else { + if (!(l < 123)) + throw new FormatError( + "Unicode ranges Bits > 123 are reserved for internal usage", + ); + s |= 1 << (l - 96); + } + } + c > 65535 && (c = 65535); + } else { + o = 0; + c = 255; + } + const h = e.bbox || [0, 0, 0, 0], + u = + a.unitsPerEm || + (e.fontMatrix + ? 1 / Math.max(...e.fontMatrix.slice(0, 4).map(Math.abs)) + : 1e3), + d = e.ascentScaled ? 1 : u / yi, + f = a.ascent || Math.round(d * (e.ascent || h[3])); + let g = a.descent || Math.round(d * (e.descent || h[1])); + g > 0 && e.descent > 0 && h[1] < 0 && (g = -g); + const p = a.yMax || f, + m = -a.yMin || -g; + return ( + "\0$ô\0\0\0Š»\0\0\0ŒŠ»\0\0ß\x001\0\0\0\0" + + String.fromCharCode(e.fixedPitch ? 9 : 0) + + "\0\0\0\0\0\0" + + string32(r) + + string32(i) + + string32(n) + + string32(s) + + "*21*" + + string16(e.italicAngle ? 1 : 0) + + string16(o || e.firstChar) + + string16(c || e.lastChar) + + string16(f) + + string16(g) + + "\0d" + + string16(p) + + string16(m) + + "\0\0\0\0\0\0\0\0" + + string16(e.xHeight) + + string16(e.capHeight) + + string16(0) + + string16(o || e.firstChar) + + "\0" + ); +} +function createPostTable(e) { + return ( + "\0\0\0" + + string32(Math.floor(65536 * e.italicAngle)) + + "\0\0\0\0" + + string32(e.fixedPitch ? 1 : 0) + + "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" + ); +} +function createPostscriptName(e) { + return e.replaceAll(/[^\x21-\x7E]|[[\](){}<>/%]/g, "").slice(0, 63); +} +function createNameTable(e, t) { + t || (t = [[], []]); + const a = [ + t[0][0] || "Original licence", + t[0][1] || e, + t[0][2] || "Unknown", + t[0][3] || "uniqueID", + t[0][4] || e, + t[0][5] || "Version 0.11", + t[0][6] || createPostscriptName(e), + t[0][7] || "Unknown", + t[0][8] || "Unknown", + t[0][9] || "Unknown", + ], + r = []; + let i, n, s, o, c; + for (i = 0, n = a.length; i < n; i++) { + c = t[1][i] || a[i]; + const e = []; + for (s = 0, o = c.length; s < o; s++) e.push(string16(c.charCodeAt(s))); + r.push(e.join("")); + } + const l = [a, r], + h = ["\0", "\0"], + u = ["\0\0", "\0"], + d = ["\0\0", "\t"], + f = a.length * h.length; + let g = "\0\0" + string16(f) + string16(12 * f + 6), + p = 0; + for (i = 0, n = h.length; i < n; i++) { + const e = l[i]; + for (s = 0, o = e.length; s < o; s++) { + c = e[s]; + g += h[i] + u[i] + d[i] + string16(s) + string16(c.length) + string16(p); + p += c.length; + } + } + g += a.join("") + r.join(""); + return g; +} +class Font { + constructor(e, t, a, r) { + this.name = e; + this.psName = null; + this.mimetype = null; + this.disableFontFace = r.disableFontFace; + this.fontExtraProperties = r.fontExtraProperties; + this.loadedName = a.loadedName; + this.isType3Font = a.isType3Font; + this.missingFile = !1; + this.cssFontInfo = a.cssFontInfo; + this._charsCache = Object.create(null); + this._glyphCache = Object.create(null); + let i = !!(a.flags & Er); + if (!i && !a.isSimulatedFlags) { + const t = e.replaceAll(/[,_]/g, "-").split("-", 1)[0], + a = Qr(); + for (const e of t.split("+")) + if (a[e]) { + i = !0; + break; + } + } + this.isSerifFont = i; + this.isSymbolicFont = !!(a.flags & Pr); + this.isMonospace = !!(a.flags & Nr); + let { type: n, subtype: s } = a; + this.type = n; + this.subtype = s; + this.systemFontInfo = a.systemFontInfo; + const o = e.match(/^InvalidPDFjsFont_(.*)_\d+$/); + this.isInvalidPDFjsFont = !!o; + this.isInvalidPDFjsFont + ? (this.fallbackName = o[1]) + : this.isMonospace + ? (this.fallbackName = "monospace") + : this.isSerifFont + ? (this.fallbackName = "serif") + : (this.fallbackName = "sans-serif"); + if (this.systemFontInfo?.guessFallback) { + this.systemFontInfo.guessFallback = !1; + this.systemFontInfo.css += `,${this.fallbackName}`; + } + this.differences = a.differences; + this.widths = a.widths; + this.defaultWidth = a.defaultWidth; + this.composite = a.composite; + this.cMap = a.cMap; + this.capHeight = a.capHeight / yi; + this.ascent = a.ascent / yi; + this.descent = a.descent / yi; + this.lineHeight = this.ascent - this.descent; + this.fontMatrix = a.fontMatrix; + this.bbox = a.bbox; + this.defaultEncoding = a.defaultEncoding; + this.toUnicode = a.toUnicode; + this.toFontChar = []; + if ("Type3" === a.type) { + for (let e = 0; e < 256; e++) + this.toFontChar[e] = this.differences[e] || a.defaultEncoding[e]; + return; + } + this.cidEncoding = a.cidEncoding || ""; + this.vertical = !!a.vertical; + if (this.vertical) { + this.vmetrics = a.vmetrics; + this.defaultVMetrics = a.defaultVMetrics; + } + if (!t || t.isEmpty) { + t && warn('Font file is empty in "' + e + '" (' + this.loadedName + ")"); + this.fallbackToSystemFont(a); + return; + } + [n, s] = getFontFileType(t, a); + (n === this.type && s === this.subtype) || + info( + `Inconsistent font file Type/SubType, expected: ${this.type}/${this.subtype} but found: ${n}/${s}.`, + ); + let c; + try { + switch (n) { + case "MMType1": + info("MMType1 font (" + e + "), falling back to Type1."); + case "Type1": + case "CIDFontType0": + this.mimetype = "font/opentype"; + const r = + "Type1C" === s || "CIDFontType0C" === s + ? new CFFFont(t, a) + : new Type1Font(e, t, a); + adjustWidths(a); + c = this.convert(e, r, a); + break; + case "OpenType": + case "TrueType": + case "CIDFontType2": + this.mimetype = "font/opentype"; + c = this.checkAndRepair(e, t, a); + adjustWidths(a); + this.isOpenType && (n = "OpenType"); + break; + default: + throw new FormatError(`Font ${n} is not supported`); + } + } catch (e) { + warn(e); + this.fallbackToSystemFont(a); + return; + } + amendFallbackToUnicode(a); + this.data = c; + this.type = n; + this.subtype = s; + this.fontMatrix = a.fontMatrix; + this.widths = a.widths; + this.defaultWidth = a.defaultWidth; + this.toUnicode = a.toUnicode; + this.seacMap = a.seacMap; + } + get renderer() { + return shadow(this, "renderer", FontRendererFactory.create(this, Rr)); + } + exportData() { + const e = this.fontExtraProperties ? [...wi, ...xi] : wi, + t = Object.create(null); + for (const a of e) { + const e = this[a]; + void 0 !== e && (t[a] = e); + } + return t; + } + fallbackToSystemFont(e) { + this.missingFile = !0; + const { name: t, type: a } = this; + let r = normalizeFontName(t); + const i = Jr(), + n = Zr(), + s = !!i[r], + o = !(!n[r] || !i[n[r]]); + r = i[r] || n[r] || r; + const c = ni()[r]; + if (c) { + isNaN(this.ascent) && (this.ascent = c.ascent / yi); + isNaN(this.descent) && (this.descent = c.descent / yi); + isNaN(this.capHeight) && (this.capHeight = c.capHeight / yi); + } + this.bold = /bold/gi.test(r); + this.italic = /oblique|italic/gi.test(r); + this.black = /Black/g.test(t); + const l = /Narrow/g.test(t); + this.remeasure = (!s || l) && Object.keys(this.widths).length > 0; + if ( + (s || o) && + "CIDFontType2" === a && + this.cidEncoding.startsWith("Identity-") + ) { + const a = e.cidToGidMap, + r = []; + applyStandardFontGlyphMap(r, ti()); + /Arial-?Black/i.test(t) + ? applyStandardFontGlyphMap(r, ai()) + : /Calibri/i.test(t) && applyStandardFontGlyphMap(r, ri()); + if (a) { + for (const e in r) { + const t = r[e]; + void 0 !== a[t] && (r[+e] = a[t]); + } + a.length !== this.toUnicode.length && + e.hasIncludedToUnicodeMap && + this.toUnicode instanceof IdentityToUnicodeMap && + this.toUnicode.forEach(function (e, t) { + const i = r[e]; + void 0 === a[i] && (r[+e] = t); + }); + } + this.toUnicode instanceof IdentityToUnicodeMap || + this.toUnicode.forEach(function (e, t) { + r[+e] = t; + }); + this.toFontChar = r; + this.toUnicode = new ToUnicodeMap(r); + } else if (/Symbol/i.test(r)) + this.toFontChar = buildToFontChar(Cr, Fr(), this.differences); + else if (/Dingbats/i.test(r)) + this.toFontChar = buildToFontChar(vr, Ir(), this.differences); + else if (s || o) { + const e = buildToFontChar(this.defaultEncoding, Fr(), this.differences); + "CIDFontType2" !== a || + this.cidEncoding.startsWith("Identity-") || + this.toUnicode instanceof IdentityToUnicodeMap || + this.toUnicode.forEach(function (t, a) { + e[+t] = a; + }); + this.toFontChar = e; + } else { + const e = Fr(), + a = []; + this.toUnicode.forEach((t, r) => { + if (!this.composite) { + const a = getUnicodeForGlyph( + this.differences[t] || this.defaultEncoding[t], + e, + ); + -1 !== a && (r = a); + } + a[+t] = r; + }); + this.composite && + this.toUnicode instanceof IdentityToUnicodeMap && + /Tahoma|Verdana/i.test(t) && + applyStandardFontGlyphMap(a, ti()); + this.toFontChar = a; + } + amendFallbackToUnicode(e); + this.loadedName = r.split("-", 1)[0]; + } + checkAndRepair(e, t, a) { + const r = [ + "OS/2", + "cmap", + "head", + "hhea", + "hmtx", + "maxp", + "name", + "post", + "loca", + "glyf", + "fpgm", + "prep", + "cvt ", + "CFF ", + ]; + function readTables(e, t) { + const a = Object.create(null); + a["OS/2"] = null; + a.cmap = null; + a.head = null; + a.hhea = null; + a.hmtx = null; + a.maxp = null; + a.name = null; + a.post = null; + for (let i = 0; i < t; i++) { + const t = readTableEntry(e); + r.includes(t.tag) && 0 !== t.length && (a[t.tag] = t); + } + return a; + } + function readTableEntry(e) { + const t = e.getString(4), + a = e.getInt32() >>> 0, + r = e.getInt32() >>> 0, + i = e.getInt32() >>> 0, + n = e.pos; + e.pos = e.start || 0; + e.skip(r); + const s = e.getBytes(i); + e.pos = n; + if ("head" === t) { + s[8] = s[9] = s[10] = s[11] = 0; + s[17] |= 32; + } + return { tag: t, checksum: a, length: i, offset: r, data: s }; + } + function readOpenTypeHeader(e) { + return { + version: e.getString(4), + numTables: e.getUint16(), + searchRange: e.getUint16(), + entrySelector: e.getUint16(), + rangeShift: e.getUint16(), + }; + } + function sanitizeGlyph(e, t, a, r, i, n) { + const s = { length: 0, sizeOfInstructions: 0 }; + if (t < 0 || t >= e.length || a > e.length || a - t <= 12) return s; + const o = e.subarray(t, a), + c = signedInt16(o[2], o[3]), + l = signedInt16(o[4], o[5]), + h = signedInt16(o[6], o[7]), + u = signedInt16(o[8], o[9]); + if (c > h) { + writeSignedInt16(o, 2, h); + writeSignedInt16(o, 6, c); + } + if (l > u) { + writeSignedInt16(o, 4, u); + writeSignedInt16(o, 8, l); + } + const d = signedInt16(o[0], o[1]); + if (d < 0) { + if (d < -1) return s; + r.set(o, i); + s.length = o.length; + return s; + } + let f, + g = 10, + p = 0; + for (f = 0; f < d; f++) { + p = ((o[g] << 8) | o[g + 1]) + 1; + g += 2; + } + const m = g, + b = (o[g] << 8) | o[g + 1]; + s.sizeOfInstructions = b; + g += 2 + b; + const y = g; + let w = 0; + for (f = 0; f < p; f++) { + const e = o[g++]; + 192 & e && (o[g - 1] = 63 & e); + let t = 2; + 2 & e ? (t = 1) : 16 & e && (t = 0); + let a = 2; + 4 & e ? (a = 1) : 32 & e && (a = 0); + const r = t + a; + w += r; + if (8 & e) { + const e = o[g++]; + 0 === e && (o[g - 1] ^= 8); + f += e; + w += e * r; + } + } + if (0 === w) return s; + let x = g + w; + if (x > o.length) return s; + if (!n && b > 0) { + r.set(o.subarray(0, m), i); + r.set([0, 0], i + m); + r.set(o.subarray(y, x), i + m + 2); + x -= b; + o.length - x > 3 && (x = (x + 3) & -4); + s.length = x; + return s; + } + if (o.length - x > 3) { + x = (x + 3) & -4; + r.set(o.subarray(0, x), i); + s.length = x; + return s; + } + r.set(o, i); + s.length = o.length; + return s; + } + function readNameTable(e) { + const a = (t.start || 0) + e.offset; + t.pos = a; + const r = [[], []], + i = [], + n = e.length, + s = a + n; + if (0 !== t.getUint16() || n < 6) return [r, i]; + const o = t.getUint16(), + c = t.getUint16(); + let l, h; + for (l = 0; l < o && t.pos + 12 <= s; l++) { + const e = { + platform: t.getUint16(), + encoding: t.getUint16(), + language: t.getUint16(), + name: t.getUint16(), + length: t.getUint16(), + offset: t.getUint16(), + }; + (isMacNameRecord(e) || isWinNameRecord(e)) && i.push(e); + } + for (l = 0, h = i.length; l < h; l++) { + const e = i[l]; + if (e.length <= 0) continue; + const n = a + c + e.offset; + if (n + e.length > s) continue; + t.pos = n; + const o = e.name; + if (e.encoding) { + let a = ""; + for (let r = 0, i = e.length; r < i; r += 2) + a += String.fromCharCode(t.getUint16()); + r[1][o] = a; + } else r[0][o] = t.getString(e.length); + } + return [r, i]; + } + const i = [ + 0, 0, 0, 0, 0, 0, 0, 0, -2, -2, -2, -2, 0, 0, -2, -5, -1, -1, -1, -1, -1, + -1, -1, -1, 0, 0, -1, 0, -1, -1, -1, -1, 1, -1, -999, 0, 1, 0, -1, -2, 0, + -1, -2, -1, -1, 0, -1, -1, 0, 0, -999, -999, -1, -1, -1, -1, -2, -999, -2, + -2, -999, 0, -2, -2, 0, 0, -2, 0, -2, 0, 0, 0, -2, -1, -1, 1, 1, 0, 0, -1, + -1, -1, -1, -1, -1, -1, 0, 0, -1, 0, -1, -1, 0, -999, -1, -1, -1, -1, -1, + -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -2, -999, -999, -999, -999, -999, + -1, -1, -2, -2, 0, 0, 0, 0, -1, -1, -999, -2, -2, 0, 0, -1, -2, -2, 0, 0, + 0, -1, -1, -1, -2, + ]; + function sanitizeTTProgram(e, t) { + let a, + r, + n, + s, + o, + c = e.data, + l = 0, + h = 0, + u = 0; + const d = [], + f = [], + g = []; + let p = t.tooComplexToFollowFunctions, + m = !1, + b = 0, + y = 0; + for (let e = c.length; l < e; ) { + const e = c[l++]; + if (64 === e) { + r = c[l++]; + if (m || y) l += r; + else for (a = 0; a < r; a++) d.push(c[l++]); + } else if (65 === e) { + r = c[l++]; + if (m || y) l += 2 * r; + else + for (a = 0; a < r; a++) { + n = c[l++]; + d.push((n << 8) | c[l++]); + } + } else if (176 == (248 & e)) { + r = e - 176 + 1; + if (m || y) l += r; + else for (a = 0; a < r; a++) d.push(c[l++]); + } else if (184 == (248 & e)) { + r = e - 184 + 1; + if (m || y) l += 2 * r; + else + for (a = 0; a < r; a++) { + n = c[l++]; + d.push(signedInt16(n, c[l++])); + } + } else if (43 !== e || p) + if (44 !== e || p) { + if (45 === e) + if (m) { + m = !1; + h = l; + } else { + o = f.pop(); + if (!o) { + warn("TT: ENDF bad stack"); + t.hintsValid = !1; + return; + } + s = g.pop(); + c = o.data; + l = o.i; + t.functionsStackDeltas[s] = d.length - o.stackTop; + } + else if (137 === e) { + if (m || y) { + warn("TT: nested IDEFs not allowed"); + p = !0; + } + m = !0; + u = l; + } else if (88 === e) ++b; + else if (27 === e) y = b; + else if (89 === e) { + y === b && (y = 0); + --b; + } else if (28 === e && !m && !y) { + const e = d.at(-1); + e > 0 && (l += e - 1); + } + } else { + if (m || y) { + warn("TT: nested FDEFs not allowed"); + p = !0; + } + m = !0; + u = l; + s = d.pop(); + t.functionsDefined[s] = { data: c, i: l }; + } + else if (!m && !y) { + s = d.at(-1); + if (isNaN(s)) info("TT: CALL empty stack (or invalid entry)."); + else { + t.functionsUsed[s] = !0; + if (s in t.functionsStackDeltas) { + const e = d.length + t.functionsStackDeltas[s]; + if (e < 0) { + warn("TT: CALL invalid functions stack delta."); + t.hintsValid = !1; + return; + } + d.length = e; + } else if (s in t.functionsDefined && !g.includes(s)) { + f.push({ data: c, i: l, stackTop: d.length - 1 }); + g.push(s); + o = t.functionsDefined[s]; + if (!o) { + warn("TT: CALL non-existent function"); + t.hintsValid = !1; + return; + } + c = o.data; + l = o.i; + } + } + } + if (!m && !y) { + let t = 0; + e <= 142 + ? (t = i[e]) + : e >= 192 && e <= 223 + ? (t = -1) + : e >= 224 && (t = -2); + if (e >= 113 && e <= 117) { + r = d.pop(); + isNaN(r) || (t = 2 * -r); + } + for (; t < 0 && d.length > 0; ) { + d.pop(); + t++; + } + for (; t > 0; ) { + d.push(NaN); + t--; + } + } + } + t.tooComplexToFollowFunctions = p; + const w = [c]; + l > c.length && w.push(new Uint8Array(l - c.length)); + if (u > h) { + warn("TT: complementing a missing function tail"); + w.push(new Uint8Array([34, 45])); + } + !(function foldTTTable(e, t) { + if (t.length > 1) { + let a, + r, + i = 0; + for (a = 0, r = t.length; a < r; a++) i += t[a].length; + i = (i + 3) & -4; + const n = new Uint8Array(i); + let s = 0; + for (a = 0, r = t.length; a < r; a++) { + n.set(t[a], s); + s += t[a].length; + } + e.data = n; + e.length = i; + } + })(e, w); + } + let n, s, o, c; + if ( + isTrueTypeCollectionFile((t = new Stream(new Uint8Array(t.getBytes())))) + ) { + const e = (function readTrueTypeCollectionData(e, t) { + const { numFonts: a, offsetTable: r } = + (function readTrueTypeCollectionHeader(e) { + const t = e.getString(4); + assert("ttcf" === t, "Must be a TrueType Collection font."); + const a = e.getUint16(), + r = e.getUint16(), + i = e.getInt32() >>> 0, + n = []; + for (let t = 0; t < i; t++) n.push(e.getInt32() >>> 0); + const s = { + ttcTag: t, + majorVersion: a, + minorVersion: r, + numFonts: i, + offsetTable: n, + }; + switch (a) { + case 1: + return s; + case 2: + s.dsigTag = e.getInt32() >>> 0; + s.dsigLength = e.getInt32() >>> 0; + s.dsigOffset = e.getInt32() >>> 0; + return s; + } + throw new FormatError( + `Invalid TrueType Collection majorVersion: ${a}.`, + ); + })(e), + i = t.split("+"); + let n; + for (let s = 0; s < a; s++) { + e.pos = (e.start || 0) + r[s]; + const a = readOpenTypeHeader(e), + o = readTables(e, a.numTables); + if (!o.name) + throw new FormatError( + 'TrueType Collection font must contain a "name" table.', + ); + const [c] = readNameTable(o.name); + for (let e = 0, r = c.length; e < r; e++) + for (let r = 0, s = c[e].length; r < s; r++) { + const s = c[e][r]?.replaceAll(/\s/g, ""); + if (s) { + if (s === t) return { header: a, tables: o }; + if (!(i.length < 2)) + for (const e of i) + s === e && (n = { name: e, header: a, tables: o }); + } + } + } + if (n) { + warn( + `TrueType Collection does not contain "${t}" font, falling back to "${n.name}" font instead.`, + ); + return { header: n.header, tables: n.tables }; + } + throw new FormatError( + `TrueType Collection does not contain "${t}" font.`, + ); + })(t, this.name); + n = e.header; + s = e.tables; + } else { + n = readOpenTypeHeader(t); + s = readTables(t, n.numTables); + } + const l = !s["CFF "]; + if (l) { + if (!s.loca) throw new FormatError('Required "loca" table is not found'); + if (!s.glyf) { + warn('Required "glyf" table is not found -- trying to recover.'); + s.glyf = { tag: "glyf", data: new Uint8Array(0) }; + } + this.isOpenType = !1; + } else { + const t = + a.composite && + (a.cidToGidMap?.length > 0 || !(a.cMap instanceof IdentityCMap)); + if ( + ("OTTO" === n.version && !t) || + !s.head || + !s.hhea || + !s.maxp || + !s.post + ) { + c = new Stream(s["CFF "].data); + o = new CFFFont(c, a); + return this.convert(e, o, a); + } + delete s.glyf; + delete s.loca; + delete s.fpgm; + delete s.prep; + delete s["cvt "]; + this.isOpenType = !0; + } + if (!s.maxp) throw new FormatError('Required "maxp" table is not found'); + t.pos = (t.start || 0) + s.maxp.offset; + let h = t.getInt32(); + const u = t.getUint16(); + if (65536 !== h && 20480 !== h) { + if (6 === s.maxp.length) h = 20480; + else { + if (!(s.maxp.length >= 32)) + throw new FormatError('"maxp" table has a wrong version number'); + h = 65536; + } + !(function writeUint32(e, t, a) { + e[t + 3] = 255 & a; + e[t + 2] = a >>> 8; + e[t + 1] = a >>> 16; + e[t] = a >>> 24; + })(s.maxp.data, 0, h); + } + if (a.scaleFactors?.length === u && l) { + const { scaleFactors: e } = a, + t = int16(s.head.data[50], s.head.data[51]), + r = new GlyfTable({ + glyfTable: s.glyf.data, + isGlyphLocationsLong: t, + locaTable: s.loca.data, + numGlyphs: u, + }); + r.scale(e); + const { glyf: i, loca: n, isLocationLong: o } = r.write(); + s.glyf.data = i; + s.loca.data = n; + if (o !== !!t) { + s.head.data[50] = 0; + s.head.data[51] = o ? 1 : 0; + } + const c = s.hmtx.data; + for (let t = 0; t < u; t++) { + const a = 4 * t, + r = Math.round(e[t] * int16(c[a], c[a + 1])); + c[a] = (r >> 8) & 255; + c[a + 1] = 255 & r; + writeSignedInt16( + c, + a + 2, + Math.round(e[t] * signedInt16(c[a + 2], c[a + 3])), + ); + } + } + let d = u + 1, + f = !0; + if (d > 65535) { + f = !1; + d = u; + warn("Not enough space in glyfs to duplicate first glyph."); + } + let g = 0, + p = 0; + if (h >= 65536 && s.maxp.length >= 32) { + t.pos += 8; + if (t.getUint16() > 2) { + s.maxp.data[14] = 0; + s.maxp.data[15] = 2; + } + t.pos += 4; + g = t.getUint16(); + t.pos += 4; + p = t.getUint16(); + } + s.maxp.data[4] = d >> 8; + s.maxp.data[5] = 255 & d; + const m = (function sanitizeTTPrograms(e, t, a, r) { + const i = { + functionsDefined: [], + functionsUsed: [], + functionsStackDeltas: [], + tooComplexToFollowFunctions: !1, + hintsValid: !0, + }; + e && sanitizeTTProgram(e, i); + t && sanitizeTTProgram(t, i); + e && + (function checkInvalidFunctions(e, t) { + if (!e.tooComplexToFollowFunctions) + if (e.functionsDefined.length > t) { + warn("TT: more functions defined than expected"); + e.hintsValid = !1; + } else + for (let a = 0, r = e.functionsUsed.length; a < r; a++) { + if (a > t) { + warn("TT: invalid function id: " + a); + e.hintsValid = !1; + return; + } + if (e.functionsUsed[a] && !e.functionsDefined[a]) { + warn("TT: undefined function: " + a); + e.hintsValid = !1; + return; + } + } + })(i, r); + if (a && 1 & a.length) { + const e = new Uint8Array(a.length + 1); + e.set(a.data); + a.data = e; + } + return i.hintsValid; + })(s.fpgm, s.prep, s["cvt "], g); + if (!m) { + delete s.fpgm; + delete s.prep; + delete s["cvt "]; + } + !(function sanitizeMetrics(e, t, a, r, i, n) { + if (!t) { + a && (a.data = null); + return; + } + e.pos = (e.start || 0) + t.offset; + e.pos += 4; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + e.pos += 2; + const s = e.getUint16(); + e.pos += 8; + e.pos += 2; + let o = e.getUint16(); + if (0 !== s) { + if (!(2 & int16(r.data[44], r.data[45]))) { + t.data[22] = 0; + t.data[23] = 0; + } + } + if (o > i) { + info( + `The numOfMetrics (${o}) should not be greater than the numGlyphs (${i}).`, + ); + o = i; + t.data[34] = (65280 & o) >> 8; + t.data[35] = 255 & o; + } + const c = i - o - ((a.length - 4 * o) >> 1); + if (c > 0) { + const e = new Uint8Array(a.length + 2 * c); + e.set(a.data); + if (n) { + e[a.length] = a.data[2]; + e[a.length + 1] = a.data[3]; + } + a.data = e; + } + })(t, s.hhea, s.hmtx, s.head, d, f); + if (!s.head) throw new FormatError('Required "head" table is not found'); + !(function sanitizeHead(e, t, a) { + const r = e.data, + i = (function int32(e, t, a, r) { + return (e << 24) + (t << 16) + (a << 8) + r; + })(r[0], r[1], r[2], r[3]); + if (i >> 16 != 1) { + info("Attempting to fix invalid version in head table: " + i); + r[0] = 0; + r[1] = 1; + r[2] = 0; + r[3] = 0; + } + const n = int16(r[50], r[51]); + if (n < 0 || n > 1) { + info("Attempting to fix invalid indexToLocFormat in head table: " + n); + const e = t + 1; + if (a === e << 1) { + r[50] = 0; + r[51] = 0; + } else { + if (a !== e << 2) + throw new FormatError("Could not fix indexToLocFormat: " + n); + r[50] = 0; + r[51] = 1; + } + } + })(s.head, u, l ? s.loca.length : 0); + let b = Object.create(null); + if (l) { + const e = int16(s.head.data[50], s.head.data[51]), + t = (function sanitizeGlyphLocations(e, t, a, r, i, n, s) { + let o, c, l; + if (r) { + o = 4; + c = function fontItemDecodeLong(e, t) { + return ( + (e[t] << 24) | (e[t + 1] << 16) | (e[t + 2] << 8) | e[t + 3] + ); + }; + l = function fontItemEncodeLong(e, t, a) { + e[t] = (a >>> 24) & 255; + e[t + 1] = (a >> 16) & 255; + e[t + 2] = (a >> 8) & 255; + e[t + 3] = 255 & a; + }; + } else { + o = 2; + c = function fontItemDecode(e, t) { + return (e[t] << 9) | (e[t + 1] << 1); + }; + l = function fontItemEncode(e, t, a) { + e[t] = (a >> 9) & 255; + e[t + 1] = (a >> 1) & 255; + }; + } + const h = n ? a + 1 : a, + u = o * (1 + h), + d = new Uint8Array(u); + d.set(e.data.subarray(0, u)); + e.data = d; + const f = t.data, + g = f.length, + p = new Uint8Array(g); + let m, b; + const y = []; + for (m = 0, b = 0; m < a + 1; m++, b += o) { + let e = c(d, b); + e > g && (e = g); + y.push({ index: m, offset: e, endOffset: 0 }); + } + y.sort((e, t) => e.offset - t.offset); + for (m = 0; m < a; m++) y[m].endOffset = y[m + 1].offset; + y.sort((e, t) => e.index - t.index); + for (m = 0; m < a; m++) { + const { offset: e, endOffset: t } = y[m]; + if (0 !== e || 0 !== t) break; + const a = y[m + 1].offset; + if (0 !== a) { + y[m].endOffset = a; + break; + } + } + const w = y.at(-2); + 0 !== w.offset && 0 === w.endOffset && (w.endOffset = g); + const x = Object.create(null); + let S = 0; + l(d, 0, S); + for (m = 0, b = o; m < a; m++, b += o) { + const e = sanitizeGlyph(f, y[m].offset, y[m].endOffset, p, S, i), + t = e.length; + 0 === t && (x[m] = !0); + e.sizeOfInstructions > s && (s = e.sizeOfInstructions); + S += t; + l(d, b, S); + } + if (0 === S) { + const e = new Uint8Array([ + 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 49, 0, + ]); + for (m = 0, b = o; m < h; m++, b += o) l(d, b, e.length); + t.data = e; + } else if (n) { + const a = c(d, o); + if (p.length > a + S) t.data = p.subarray(0, a + S); + else { + t.data = new Uint8Array(a + S); + t.data.set(p.subarray(0, S)); + } + t.data.set(p.subarray(0, a), S); + l(e.data, d.length - o, S + a); + } else t.data = p.subarray(0, S); + return { missingGlyphs: x, maxSizeOfInstructions: s }; + })(s.loca, s.glyf, u, e, m, f, p); + b = t.missingGlyphs; + if (h >= 65536 && s.maxp.length >= 32) { + s.maxp.data[26] = t.maxSizeOfInstructions >> 8; + s.maxp.data[27] = 255 & t.maxSizeOfInstructions; + } + } + if (!s.hhea) throw new FormatError('Required "hhea" table is not found'); + if (0 === s.hhea.data[10] && 0 === s.hhea.data[11]) { + s.hhea.data[10] = 255; + s.hhea.data[11] = 255; + } + const y = { + unitsPerEm: int16(s.head.data[18], s.head.data[19]), + yMax: signedInt16(s.head.data[42], s.head.data[43]), + yMin: signedInt16(s.head.data[38], s.head.data[39]), + ascent: signedInt16(s.hhea.data[4], s.hhea.data[5]), + descent: signedInt16(s.hhea.data[6], s.hhea.data[7]), + lineGap: signedInt16(s.hhea.data[8], s.hhea.data[9]), + }; + this.ascent = y.ascent / y.unitsPerEm; + this.descent = y.descent / y.unitsPerEm; + this.lineGap = y.lineGap / y.unitsPerEm; + if (this.cssFontInfo?.lineHeight) { + this.lineHeight = this.cssFontInfo.metrics.lineHeight; + this.lineGap = this.cssFontInfo.metrics.lineGap; + } else this.lineHeight = this.ascent - this.descent + this.lineGap; + s.post && + (function readPostScriptTable(e, a, r) { + const i = (t.start || 0) + e.offset; + t.pos = i; + const n = i + e.length, + s = t.getInt32(); + t.skip(28); + let o, + c, + l = !0; + switch (s) { + case 65536: + o = jr; + break; + case 131072: + const e = t.getUint16(); + if (e !== r) { + l = !1; + break; + } + const i = []; + for (c = 0; c < e; ++c) { + const e = t.getUint16(); + if (e >= 32768) { + l = !1; + break; + } + i.push(e); + } + if (!l) break; + const h = [], + u = []; + for (; t.pos < n; ) { + const e = t.getByte(); + u.length = e; + for (c = 0; c < e; ++c) u[c] = String.fromCharCode(t.getByte()); + h.push(u.join("")); + } + o = []; + for (c = 0; c < e; ++c) { + const e = i[c]; + e < 258 ? o.push(jr[e]) : o.push(h[e - 258]); + } + break; + case 196608: + break; + default: + warn("Unknown/unsupported post table version " + s); + l = !1; + a.defaultEncoding && (o = a.defaultEncoding); + } + a.glyphNames = o; + return l; + })(s.post, a, u); + s.post = { tag: "post", data: createPostTable(a) }; + const w = Object.create(null); + function hasGlyph(e) { + return !b[e]; + } + if (a.composite) { + const e = a.cidToGidMap || [], + t = 0 === e.length; + a.cMap.forEach(function (a, r) { + "string" == typeof r && (r = convertCidString(a, r, !0)); + if (r > 65535) throw new FormatError("Max size of CID is 65,535"); + let i = -1; + t ? (i = r) : void 0 !== e[r] && (i = e[r]); + i >= 0 && i < u && hasGlyph(i) && (w[a] = i); + }); + } else { + const e = (function readCmapTable(e, t, a, r) { + if (!e) { + warn("No cmap table available."); + return { + platformId: -1, + encodingId: -1, + mappings: [], + hasShortCmap: !1, + }; + } + let i, + n = (t.start || 0) + e.offset; + t.pos = n; + t.skip(2); + const s = t.getUint16(); + let o, + c = !1; + for (let e = 0; e < s; e++) { + const i = t.getUint16(), + n = t.getUint16(), + l = t.getInt32() >>> 0; + let h = !1; + if (o?.platformId !== i || o?.encodingId !== n) { + if (0 !== i || (0 !== n && 1 !== n && 3 !== n)) + if (1 === i && 0 === n) h = !0; + else if (3 !== i || 1 !== n || (!r && o)) { + if (a && 3 === i && 0 === n) { + h = !0; + let a = !0; + if (e < s - 1) { + const e = t.peekBytes(2); + int16(e[0], e[1]) < i && (a = !1); + } + a && (c = !0); + } + } else { + h = !0; + a || (c = !0); + } + else h = !0; + h && (o = { platformId: i, encodingId: n, offset: l }); + if (c) break; + } + } + o && (t.pos = n + o.offset); + if (!o || -1 === t.peekByte()) { + warn("Could not find a preferred cmap table."); + return { + platformId: -1, + encodingId: -1, + mappings: [], + hasShortCmap: !1, + }; + } + const l = t.getUint16(); + let h = !1; + const u = []; + let d, f; + if (0 === l) { + t.skip(4); + for (d = 0; d < 256; d++) { + const e = t.getByte(); + e && u.push({ charCode: d, glyphId: e }); + } + h = !0; + } else if (2 === l) { + t.skip(4); + const e = []; + let a = 0; + for (let r = 0; r < 256; r++) { + const r = t.getUint16() >> 3; + e.push(r); + a = Math.max(r, a); + } + const r = []; + for (let e = 0; e <= a; e++) + r.push({ + firstCode: t.getUint16(), + entryCount: t.getUint16(), + idDelta: signedInt16(t.getByte(), t.getByte()), + idRangePos: t.pos + t.getUint16(), + }); + for (let a = 0; a < 256; a++) + if (0 === e[a]) { + t.pos = r[0].idRangePos + 2 * a; + f = t.getUint16(); + u.push({ charCode: a, glyphId: f }); + } else { + const i = r[e[a]]; + for (d = 0; d < i.entryCount; d++) { + const e = (a << 8) + d + i.firstCode; + t.pos = i.idRangePos + 2 * d; + f = t.getUint16(); + 0 !== f && (f = (f + i.idDelta) % 65536); + u.push({ charCode: e, glyphId: f }); + } + } + } else if (4 === l) { + t.skip(4); + const e = t.getUint16() >> 1; + t.skip(6); + const a = []; + let r; + for (r = 0; r < e; r++) a.push({ end: t.getUint16() }); + t.skip(2); + for (r = 0; r < e; r++) a[r].start = t.getUint16(); + for (r = 0; r < e; r++) a[r].delta = t.getUint16(); + let s, + o = 0; + for (r = 0; r < e; r++) { + i = a[r]; + const n = t.getUint16(); + if (n) { + s = (n >> 1) - (e - r); + i.offsetIndex = s; + o = Math.max(o, s + i.end - i.start + 1); + } else i.offsetIndex = -1; + } + const c = []; + for (d = 0; d < o; d++) c.push(t.getUint16()); + for (r = 0; r < e; r++) { + i = a[r]; + n = i.start; + const e = i.end, + t = i.delta; + s = i.offsetIndex; + for (d = n; d <= e; d++) + if (65535 !== d) { + f = s < 0 ? d : c[s + d - n]; + f = (f + t) & 65535; + u.push({ charCode: d, glyphId: f }); + } + } + } else if (6 === l) { + t.skip(4); + const e = t.getUint16(), + a = t.getUint16(); + for (d = 0; d < a; d++) { + f = t.getUint16(); + const a = e + d; + u.push({ charCode: a, glyphId: f }); + } + } else { + if (12 !== l) { + warn("cmap table has unsupported format: " + l); + return { + platformId: -1, + encodingId: -1, + mappings: [], + hasShortCmap: !1, + }; + } + { + t.skip(10); + const e = t.getInt32() >>> 0; + for (d = 0; d < e; d++) { + const e = t.getInt32() >>> 0, + a = t.getInt32() >>> 0; + let r = t.getInt32() >>> 0; + for (let t = e; t <= a; t++) + u.push({ charCode: t, glyphId: r++ }); + } + } + } + u.sort((e, t) => e.charCode - t.charCode); + const g = [], + p = new Set(); + for (const e of u) { + const { charCode: t } = e; + if (!p.has(t)) { + p.add(t); + g.push(e); + } + } + return { + platformId: o.platformId, + encodingId: o.encodingId, + mappings: g, + hasShortCmap: h, + }; + })(s.cmap, t, this.isSymbolicFont, a.hasEncoding), + r = e.platformId, + i = e.encodingId, + n = e.mappings; + let o = [], + c = !1; + !a.hasEncoding || + ("MacRomanEncoding" !== a.baseEncodingName && + "WinAnsiEncoding" !== a.baseEncodingName) || + (o = getEncoding(a.baseEncodingName)); + if ( + a.hasEncoding && + !this.isSymbolicFont && + ((3 === r && 1 === i) || (1 === r && 0 === i)) + ) { + const e = Fr(); + for (let t = 0; t < 256; t++) { + let s; + s = + void 0 !== this.differences[t] + ? this.differences[t] + : o.length && "" !== o[t] + ? o[t] + : kr[t]; + if (!s) continue; + const c = recoverGlyphName(s, e); + let l; + 3 === r && 1 === i + ? (l = e[c]) + : 1 === r && 0 === i && (l = Sr.indexOf(c)); + if (void 0 === l) { + if ( + !a.glyphNames && + a.hasIncludedToUnicodeMap && + !(this.toUnicode instanceof IdentityToUnicodeMap) + ) { + const e = this.toUnicode.get(t); + e && (l = e.codePointAt(0)); + } + if (void 0 === l) continue; + } + for (const e of n) + if (e.charCode === l) { + w[t] = e.glyphId; + break; + } + } + } else if (0 === r) { + for (const e of n) w[e.charCode] = e.glyphId; + c = !0; + } else if (3 === r && 0 === i) + for (const e of n) { + let t = e.charCode; + t >= 61440 && t <= 61695 && (t &= 255); + w[t] = e.glyphId; + } + else for (const e of n) w[e.charCode] = e.glyphId; + if (a.glyphNames && (o.length || this.differences.length)) + for (let e = 0; e < 256; ++e) { + if (!c && void 0 !== w[e]) continue; + const t = this.differences[e] || o[e]; + if (!t) continue; + const r = a.glyphNames.indexOf(t); + r > 0 && hasGlyph(r) && (w[e] = r); + } + } + 0 === w.length && (w[0] = 0); + let x = d - 1; + f || (x = 0); + if (!a.cssFontInfo) { + const e = adjustMapping(w, hasGlyph, x, this.toUnicode); + this.toFontChar = e.toFontChar; + s.cmap = { + tag: "cmap", + data: createCmapTable(e.charCodeToGlyphId, e.toUnicodeExtraMap, d), + }; + (s["OS/2"] && + (function validateOS2Table(e, t) { + t.pos = (t.start || 0) + e.offset; + const a = t.getUint16(); + t.skip(60); + const r = t.getUint16(); + if (a < 4 && 768 & r) return !1; + if (t.getUint16() > t.getUint16()) return !1; + t.skip(6); + if (0 === t.getUint16()) return !1; + e.data[8] = e.data[9] = 0; + return !0; + })(s["OS/2"], t)) || + (s["OS/2"] = { + tag: "OS/2", + data: createOS2Table(a, e.charCodeToGlyphId, y), + }); + } + if (!l) + try { + c = new Stream(s["CFF "].data); + o = new CFFParser(c, a, Rr).parse(); + o.duplicateFirstGlyph(); + const e = new CFFCompiler(o); + s["CFF "].data = e.compile(); + } catch { + warn("Failed to compile font " + a.loadedName); + } + if (s.name) { + const [t, r] = readNameTable(s.name); + s.name.data = createNameTable(e, t); + this.psName = t[0][6] || null; + a.composite || + (function adjustTrueTypeToUnicode(e, t, a) { + if (e.isInternalFont) return; + if (e.hasIncludedToUnicodeMap) return; + if (e.hasEncoding) return; + if (e.toUnicode instanceof IdentityToUnicodeMap) return; + if (!t) return; + if (0 === a.length) return; + if (e.defaultEncoding === Ar) return; + for (const e of a) if (!isWinNameRecord(e)) return; + const r = Ar, + i = [], + n = Fr(); + for (const e in r) { + const t = r[e]; + if ("" === t) continue; + const a = n[t]; + void 0 !== a && (i[e] = String.fromCharCode(a)); + } + i.length > 0 && e.toUnicode.amend(i); + })(a, this.isSymbolicFont, r); + } else s.name = { tag: "name", data: createNameTable(this.name) }; + const S = new OpenTypeFileBuilder(n.version); + for (const e in s) S.addTable(e, s[e].data); + return S.toArray(); + } + convert(e, a, r) { + r.fixedPitch = !1; + r.builtInEncoding && + (function adjustType1ToUnicode(e, t) { + if (e.isInternalFont) return; + if (e.hasIncludedToUnicodeMap) return; + if (t === e.defaultEncoding) return; + if (e.toUnicode instanceof IdentityToUnicodeMap) return; + const a = [], + r = Fr(); + for (const i in t) { + if ( + e.hasEncoding && + (e.baseEncodingName || void 0 !== e.differences[i]) + ) + continue; + const n = getUnicodeForGlyph(t[i], r); + -1 !== n && (a[i] = String.fromCharCode(n)); + } + a.length > 0 && e.toUnicode.amend(a); + })(r, r.builtInEncoding); + let i = 1; + a instanceof CFFFont && (i = a.numGlyphs - 1); + const n = a.getGlyphMapping(r); + let s = null, + o = n, + c = null; + if (!r.cssFontInfo) { + s = adjustMapping(n, a.hasGlyphId.bind(a), i, this.toUnicode); + this.toFontChar = s.toFontChar; + o = s.charCodeToGlyphId; + c = s.toUnicodeExtraMap; + } + const l = a.numGlyphs; + function getCharCodes(e, t) { + let a = null; + for (const r in e) t === e[r] && (a ||= []).push(0 | r); + return a; + } + function createCharCode(e, t) { + for (const a in e) if (t === e[a]) return 0 | a; + s.charCodeToGlyphId[s.nextAvailableFontCharCode] = t; + return s.nextAvailableFontCharCode++; + } + const h = a.seacs; + if (s && h?.length) { + const e = r.fontMatrix || t, + i = a.getCharset(), + o = Object.create(null); + for (let t in h) { + t |= 0; + const a = h[t], + r = kr[a[2]], + c = kr[a[3]], + l = i.indexOf(r), + u = i.indexOf(c); + if (l < 0 || u < 0) continue; + const d = { + x: a[0] * e[0] + a[1] * e[2] + e[4], + y: a[0] * e[1] + a[1] * e[3] + e[5], + }, + f = getCharCodes(n, t); + if (f) + for (const e of f) { + const t = s.charCodeToGlyphId, + a = createCharCode(t, l), + r = createCharCode(t, u); + o[e] = { + baseFontCharCode: a, + accentFontCharCode: r, + accentOffset: d, + }; + } + } + r.seacMap = o; + } + const u = r.fontMatrix + ? 1 / Math.max(...r.fontMatrix.slice(0, 4).map(Math.abs)) + : 1e3, + d = new OpenTypeFileBuilder("OTTO"); + d.addTable("CFF ", a.data); + d.addTable("OS/2", createOS2Table(r, o)); + d.addTable("cmap", createCmapTable(o, c, l)); + d.addTable( + "head", + "\0\0\0\0\0\0\0\0\0\0_<õ\0\0" + + safeString16(u) + + "\0\0\0\0ž\v~'\0\0\0\0ž\v~'\0\0" + + safeString16(r.descent) + + "ÿ" + + safeString16(r.ascent) + + string16(r.italicAngle ? 2 : 0) + + "\0\0\0\0\0\0\0", + ); + d.addTable( + "hhea", + "\0\0\0" + + safeString16(r.ascent) + + safeString16(r.descent) + + "\0\0ÿÿ\0\0\0\0\0\0" + + safeString16(r.capHeight) + + safeString16(Math.tan(r.italicAngle) * r.xHeight) + + "\0\0\0\0\0\0\0\0\0\0\0\0" + + string16(l), + ); + d.addTable( + "hmtx", + (function fontFieldsHmtx() { + const e = a.charstrings, + t = a.cff ? a.cff.widths : null; + let r = "\0\0\0\0"; + for (let a = 1, i = l; a < i; a++) { + let i = 0; + if (e) { + const t = e[a - 1]; + i = "width" in t ? t.width : 0; + } else t && (i = Math.ceil(t[a] || 0)); + r += string16(i) + string16(0); + } + return r; + })(), + ); + d.addTable("maxp", "\0\0P\0" + string16(l)); + d.addTable("name", createNameTable(e)); + d.addTable("post", createPostTable(r)); + return d.toArray(); + } + get _spaceWidth() { + const e = ["space", "minus", "one", "i", "I"]; + let t; + for (const a of e) { + if (a in this.widths) { + t = this.widths[a]; + break; + } + const e = Fr()[a]; + let r = 0; + if (this.composite && this.cMap.contains(e)) { + r = this.cMap.lookup(e); + "string" == typeof r && (r = convertCidString(e, r)); + } + !r && this.toUnicode && (r = this.toUnicode.charCodeOf(e)); + r <= 0 && (r = e); + t = this.widths[r]; + if (t) break; + } + return shadow(this, "_spaceWidth", t || this.defaultWidth); + } + _charToGlyph(e, t = !1) { + let a, + r, + i, + n = this._glyphCache[e]; + if (n?.isSpace === t) return n; + let s = e; + if (this.cMap?.contains(e)) { + s = this.cMap.lookup(e); + "string" == typeof s && (s = convertCidString(e, s)); + } + r = this.widths[s]; + "number" != typeof r && (r = this.defaultWidth); + const o = this.vmetrics?.[s]; + let c = this.toUnicode.get(e) || e; + "number" == typeof c && (c = String.fromCharCode(c)); + let l = void 0 !== this.toFontChar[e]; + a = this.toFontChar[e] || e; + if (this.missingFile) { + const t = this.differences[e] || this.defaultEncoding[e]; + if ((".notdef" === t || "" === t) && "Type1" === this.type) { + a = 32; + if ("" === t) { + r ||= this._spaceWidth; + c = String.fromCharCode(a); + } + } + a = (function mapSpecialUnicodeValues(e) { + return e >= 65520 && e <= 65535 + ? 0 + : e >= 62976 && e <= 63743 + ? Tr()[e] || e + : 173 === e + ? 45 + : e; + })(a); + } + this.isType3Font && (i = a); + let h = null; + if (this.seacMap?.[e]) { + l = !0; + const t = this.seacMap[e]; + a = t.baseFontCharCode; + h = { + fontChar: String.fromCodePoint(t.accentFontCharCode), + offset: t.accentOffset, + }; + } + let u = ""; + "number" == typeof a && + (a <= 1114111 + ? (u = String.fromCodePoint(a)) + : warn(`charToGlyph - invalid fontCharCode: ${a}`)); + if (this.missingFile && this.vertical && 1 === u.length) { + const e = _r()[u.charCodeAt(0)]; + e && (u = c = String.fromCharCode(e)); + } + n = new fonts_Glyph(e, u, c, h, r, o, i, t, l); + return (this._glyphCache[e] = n); + } + charsToGlyphs(e) { + let t = this._charsCache[e]; + if (t) return t; + t = []; + if (this.cMap) { + const a = Object.create(null), + r = e.length; + let i = 0; + for (; i < r; ) { + this.cMap.readCharCode(e, i, a); + const { charcode: r, length: n } = a; + i += n; + const s = this._charToGlyph(r, 1 === n && 32 === e.charCodeAt(i - 1)); + t.push(s); + } + } else + for (let a = 0, r = e.length; a < r; ++a) { + const r = e.charCodeAt(a), + i = this._charToGlyph(r, 32 === r); + t.push(i); + } + return (this._charsCache[e] = t); + } + getCharPositions(e) { + const t = []; + if (this.cMap) { + const a = Object.create(null); + let r = 0; + for (; r < e.length; ) { + this.cMap.readCharCode(e, r, a); + const i = a.length; + t.push([r, r + i]); + r += i; + } + } else for (let a = 0, r = e.length; a < r; ++a) t.push([a, a + 1]); + return t; + } + get glyphCacheValues() { + return Object.values(this._glyphCache); + } + encodeString(e) { + const t = [], + a = [], + hasCurrentBufErrors = () => t.length % 2 == 1, + r = + this.toUnicode instanceof IdentityToUnicodeMap + ? (e) => this.toUnicode.charCodeOf(e) + : (e) => this.toUnicode.charCodeOf(String.fromCodePoint(e)); + for (let i = 0, n = e.length; i < n; i++) { + const n = e.codePointAt(i); + n > 55295 && (n < 57344 || n > 65533) && i++; + if (this.toUnicode) { + const e = r(n); + if (-1 !== e) { + if (hasCurrentBufErrors()) { + t.push(a.join("")); + a.length = 0; + } + for ( + let t = (this.cMap ? this.cMap.getCharCodeLength(e) : 1) - 1; + t >= 0; + t-- + ) + a.push(String.fromCharCode((e >> (8 * t)) & 255)); + continue; + } + } + if (!hasCurrentBufErrors()) { + t.push(a.join("")); + a.length = 0; + } + a.push(String.fromCodePoint(n)); + } + t.push(a.join("")); + return t; + } +} +class ErrorFont { + constructor(e) { + this.error = e; + this.loadedName = "g_font_error"; + this.missingFile = !0; + } + charsToGlyphs() { + return []; + } + encodeString(e) { + return [e]; + } + exportData() { + return { error: this.error }; + } +} +const Si = 2, + ki = 3, + Ai = 4, + Ci = 5, + vi = 6, + Fi = 7; +class Pattern { + constructor() { + unreachable("Cannot initialize Pattern."); + } + static parseShading(e, t, a, r, i, n) { + const s = e instanceof BaseStream ? e.dict : e, + o = s.get("ShadingType"); + try { + switch (o) { + case Si: + case ki: + return new RadialAxialShading(s, t, a, r, i, n); + case Ai: + case Ci: + case vi: + case Fi: + return new MeshShading(e, t, a, r, i, n); + default: + throw new FormatError("Unsupported ShadingType: " + o); + } + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(e); + return new DummyShading(); + } + } +} +class BaseShading { + static SMALL_NUMBER = 1e-6; + getIR() { + unreachable("Abstract method `getIR` called."); + } +} +class RadialAxialShading extends BaseShading { + constructor(e, t, a, r, i, n) { + super(); + this.shadingType = e.get("ShadingType"); + let s = 0; + this.shadingType === Si ? (s = 4) : this.shadingType === ki && (s = 6); + this.coordsArr = e.getArray("Coords"); + if (!isNumberArray(this.coordsArr, s)) + throw new FormatError("RadialAxialShading: Invalid /Coords array."); + const o = ColorSpaceUtils.parse({ + cs: e.getRaw("CS") || e.getRaw("ColorSpace"), + xref: t, + resources: a, + pdfFunctionFactory: r, + globalColorSpaceCache: i, + localColorSpaceCache: n, + }); + this.bbox = lookupNormalRect(e.getArray("BBox"), null); + let c = 0, + l = 1; + const h = e.getArray("Domain"); + isNumberArray(h, 2) && ([c, l] = h); + let u = !1, + d = !1; + const f = e.getArray("Extend"); + (function isBooleanArray(e, t) { + return ( + Array.isArray(e) && + (null === t || e.length === t) && + e.every((e) => "boolean" == typeof e) + ); + })(f, 2) && ([u, d] = f); + if (!(this.shadingType !== ki || (u && d))) { + const [e, t, a, r, i, n] = this.coordsArr, + s = Math.hypot(e - r, t - i); + a <= n + s && n <= a + s && warn("Unsupported radial gradient."); + } + this.extendStart = u; + this.extendEnd = d; + const g = e.getRaw("Function"), + p = r.create(g, !0), + m = (l - c) / 840, + b = (this.colorStops = []); + if (c >= l || m <= 0) { + info("Bad shading domain."); + return; + } + const y = new Float32Array(o.numComps), + w = new Float32Array(1); + let x = 0; + w[0] = c; + p(w, 0, y, 0); + const S = new Uint8ClampedArray(3); + o.getRgb(y, 0, S); + let [k, C, v] = S; + b.push([0, Util.makeHexColor(k, C, v)]); + let F = 1; + w[0] = c + m; + p(w, 0, y, 0); + o.getRgb(y, 0, S); + let [T, O, M] = S, + D = T - k + 1, + R = O - C + 1, + N = M - v + 1, + E = T - k - 1, + L = O - C - 1, + j = M - v - 1; + for (let e = 2; e < 840; e++) { + w[0] = c + e * m; + p(w, 0, y, 0); + o.getRgb(y, 0, S); + const [t, a, r] = S, + i = e - x; + D = Math.min(D, (t - k + 1) / i); + R = Math.min(R, (a - C + 1) / i); + N = Math.min(N, (r - v + 1) / i); + E = Math.max(E, (t - k - 1) / i); + L = Math.max(L, (a - C - 1) / i); + j = Math.max(j, (r - v - 1) / i); + if (!(E <= D && L <= R && j <= N)) { + const e = Util.makeHexColor(T, O, M); + b.push([F / 840, e]); + D = t - T + 1; + R = a - O + 1; + N = r - M + 1; + E = t - T - 1; + L = a - O - 1; + j = r - M - 1; + x = F; + k = T; + C = O; + v = M; + } + F = e; + T = t; + O = a; + M = r; + } + b.push([1, Util.makeHexColor(T, O, M)]); + let _ = "transparent"; + e.has("Background") && (_ = o.getRgbHex(e.get("Background"), 0)); + if (!u) { + b.unshift([0, _]); + b[1][0] += BaseShading.SMALL_NUMBER; + } + if (!d) { + b.at(-1)[0] -= BaseShading.SMALL_NUMBER; + b.push([1, _]); + } + this.colorStops = b; + } + getIR() { + const { coordsArr: e, shadingType: t } = this; + let a, r, i, n, s; + if (t === Si) { + r = [e[0], e[1]]; + i = [e[2], e[3]]; + n = null; + s = null; + a = "axial"; + } else if (t === ki) { + r = [e[0], e[1]]; + i = [e[3], e[4]]; + n = e[2]; + s = e[5]; + a = "radial"; + } else unreachable(`getPattern type unknown: ${t}`); + return ["RadialAxial", a, this.bbox, this.colorStops, r, i, n, s]; + } +} +class MeshStreamReader { + constructor(e, t) { + this.stream = e; + this.context = t; + this.buffer = 0; + this.bufferLength = 0; + const a = t.numComps; + this.tmpCompsBuf = new Float32Array(a); + const r = t.colorSpace.numComps; + this.tmpCsCompsBuf = t.colorFn ? new Float32Array(r) : this.tmpCompsBuf; + } + get hasData() { + if (this.stream.end) return this.stream.pos < this.stream.end; + if (this.bufferLength > 0) return !0; + const e = this.stream.getByte(); + if (e < 0) return !1; + this.buffer = e; + this.bufferLength = 8; + return !0; + } + readBits(e) { + const { stream: t } = this; + let { buffer: a, bufferLength: r } = this; + if (32 === e) { + if (0 === r) return t.getInt32() >>> 0; + a = (a << 24) | (t.getByte() << 16) | (t.getByte() << 8) | t.getByte(); + const e = t.getByte(); + this.buffer = e & ((1 << r) - 1); + return ((a << (8 - r)) | ((255 & e) >> r)) >>> 0; + } + if (8 === e && 0 === r) return t.getByte(); + for (; r < e; ) { + a = (a << 8) | t.getByte(); + r += 8; + } + r -= e; + this.bufferLength = r; + this.buffer = a & ((1 << r) - 1); + return a >> r; + } + align() { + this.buffer = 0; + this.bufferLength = 0; + } + readFlag() { + return this.readBits(this.context.bitsPerFlag); + } + readCoordinate() { + const { bitsPerCoordinate: e, decode: t } = this.context, + a = this.readBits(e), + r = this.readBits(e), + i = e < 32 ? 1 / ((1 << e) - 1) : 2.3283064365386963e-10; + return [a * i * (t[1] - t[0]) + t[0], r * i * (t[3] - t[2]) + t[2]]; + } + readComponents() { + const { + bitsPerComponent: e, + colorFn: t, + colorSpace: a, + decode: r, + numComps: i, + } = this.context, + n = e < 32 ? 1 / ((1 << e) - 1) : 2.3283064365386963e-10, + s = this.tmpCompsBuf; + for (let t = 0, a = 4; t < i; t++, a += 2) { + const i = this.readBits(e); + s[t] = i * n * (r[a + 1] - r[a]) + r[a]; + } + const o = this.tmpCsCompsBuf; + t?.(s, 0, o, 0); + return a.getRgb(o, 0); + } +} +let Ii = Object.create(null); +function getB(e) { + return (Ii[e] ||= (function buildB(e) { + const t = []; + for (let a = 0; a <= e; a++) { + const r = a / e, + i = 1 - r; + t.push( + new Float32Array([i ** 3, 3 * r * i ** 2, 3 * r ** 2 * i, r ** 3]), + ); + } + return t; + })(e)); +} +class MeshShading extends BaseShading { + static MIN_SPLIT_PATCH_CHUNKS_AMOUNT = 3; + static MAX_SPLIT_PATCH_CHUNKS_AMOUNT = 20; + static TRIANGLE_DENSITY = 20; + constructor(e, t, a, r, i, n) { + super(); + if (!(e instanceof BaseStream)) + throw new FormatError("Mesh data is not a stream"); + const s = e.dict; + this.shadingType = s.get("ShadingType"); + this.bbox = lookupNormalRect(s.getArray("BBox"), null); + const o = ColorSpaceUtils.parse({ + cs: s.getRaw("CS") || s.getRaw("ColorSpace"), + xref: t, + resources: a, + pdfFunctionFactory: r, + globalColorSpaceCache: i, + localColorSpaceCache: n, + }); + this.background = s.has("Background") + ? o.getRgb(s.get("Background"), 0) + : null; + const c = s.getRaw("Function"), + l = c ? r.create(c, !0) : null; + this.coords = []; + this.colors = []; + this.figures = []; + const h = { + bitsPerCoordinate: s.get("BitsPerCoordinate"), + bitsPerComponent: s.get("BitsPerComponent"), + bitsPerFlag: s.get("BitsPerFlag"), + decode: s.getArray("Decode"), + colorFn: l, + colorSpace: o, + numComps: l ? 1 : o.numComps, + }, + u = new MeshStreamReader(e, h); + let d = !1; + switch (this.shadingType) { + case Ai: + this._decodeType4Shading(u); + break; + case Ci: + const e = 0 | s.get("VerticesPerRow"); + if (e < 2) throw new FormatError("Invalid VerticesPerRow"); + this._decodeType5Shading(u, e); + break; + case vi: + this._decodeType6Shading(u); + d = !0; + break; + case Fi: + this._decodeType7Shading(u); + d = !0; + break; + default: + unreachable("Unsupported mesh type."); + } + if (d) { + this._updateBounds(); + for (let e = 0, t = this.figures.length; e < t; e++) + this._buildFigureFromPatch(e); + } + this._updateBounds(); + this._packData(); + } + _decodeType4Shading(e) { + const t = this.coords, + a = this.colors, + r = [], + i = []; + let n = 0; + for (; e.hasData; ) { + const s = e.readFlag(), + o = e.readCoordinate(), + c = e.readComponents(); + if (0 === n) { + if (!(0 <= s && s <= 2)) throw new FormatError("Unknown type4 flag"); + switch (s) { + case 0: + n = 3; + break; + case 1: + i.push(i.at(-2), i.at(-1)); + n = 1; + break; + case 2: + i.push(i.at(-3), i.at(-1)); + n = 1; + } + r.push(s); + } + i.push(t.length); + t.push(o); + a.push(c); + n--; + e.align(); + } + this.figures.push({ + type: "triangles", + coords: new Int32Array(i), + colors: new Int32Array(i), + }); + } + _decodeType5Shading(e, t) { + const a = this.coords, + r = this.colors, + i = []; + for (; e.hasData; ) { + const t = e.readCoordinate(), + n = e.readComponents(); + i.push(a.length); + a.push(t); + r.push(n); + } + this.figures.push({ + type: "lattice", + coords: new Int32Array(i), + colors: new Int32Array(i), + verticesPerRow: t, + }); + } + _decodeType6Shading(e) { + const t = this.coords, + a = this.colors, + r = new Int32Array(16), + i = new Int32Array(4); + for (; e.hasData; ) { + const n = e.readFlag(); + if (!(0 <= n && n <= 3)) throw new FormatError("Unknown type6 flag"); + const s = t.length; + for (let a = 0, r = 0 !== n ? 8 : 12; a < r; a++) + t.push(e.readCoordinate()); + const o = a.length; + for (let t = 0, r = 0 !== n ? 2 : 4; t < r; t++) + a.push(e.readComponents()); + let c, l, h, u; + switch (n) { + case 0: + r[12] = s + 3; + r[13] = s + 4; + r[14] = s + 5; + r[15] = s + 6; + r[8] = s + 2; + r[11] = s + 7; + r[4] = s + 1; + r[7] = s + 8; + r[0] = s; + r[1] = s + 11; + r[2] = s + 10; + r[3] = s + 9; + i[2] = o + 1; + i[3] = o + 2; + i[0] = o; + i[1] = o + 3; + break; + case 1: + c = r[12]; + l = r[13]; + h = r[14]; + u = r[15]; + r[12] = u; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = h; + r[11] = s + 3; + r[4] = l; + r[7] = s + 4; + r[0] = c; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + c = i[2]; + l = i[3]; + i[2] = l; + i[3] = o; + i[0] = c; + i[1] = o + 1; + break; + case 2: + c = r[15]; + l = r[11]; + r[12] = r[3]; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = r[7]; + r[11] = s + 3; + r[4] = l; + r[7] = s + 4; + r[0] = c; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + c = i[3]; + i[2] = i[1]; + i[3] = o; + i[0] = c; + i[1] = o + 1; + break; + case 3: + r[12] = r[0]; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = r[1]; + r[11] = s + 3; + r[4] = r[2]; + r[7] = s + 4; + r[0] = r[3]; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + i[2] = i[0]; + i[3] = o; + i[0] = i[1]; + i[1] = o + 1; + } + r[5] = t.length; + t.push([ + (-4 * t[r[0]][0] - + t[r[15]][0] + + 6 * (t[r[4]][0] + t[r[1]][0]) - + 2 * (t[r[12]][0] + t[r[3]][0]) + + 3 * (t[r[13]][0] + t[r[7]][0])) / + 9, + (-4 * t[r[0]][1] - + t[r[15]][1] + + 6 * (t[r[4]][1] + t[r[1]][1]) - + 2 * (t[r[12]][1] + t[r[3]][1]) + + 3 * (t[r[13]][1] + t[r[7]][1])) / + 9, + ]); + r[6] = t.length; + t.push([ + (-4 * t[r[3]][0] - + t[r[12]][0] + + 6 * (t[r[2]][0] + t[r[7]][0]) - + 2 * (t[r[0]][0] + t[r[15]][0]) + + 3 * (t[r[4]][0] + t[r[14]][0])) / + 9, + (-4 * t[r[3]][1] - + t[r[12]][1] + + 6 * (t[r[2]][1] + t[r[7]][1]) - + 2 * (t[r[0]][1] + t[r[15]][1]) + + 3 * (t[r[4]][1] + t[r[14]][1])) / + 9, + ]); + r[9] = t.length; + t.push([ + (-4 * t[r[12]][0] - + t[r[3]][0] + + 6 * (t[r[8]][0] + t[r[13]][0]) - + 2 * (t[r[0]][0] + t[r[15]][0]) + + 3 * (t[r[11]][0] + t[r[1]][0])) / + 9, + (-4 * t[r[12]][1] - + t[r[3]][1] + + 6 * (t[r[8]][1] + t[r[13]][1]) - + 2 * (t[r[0]][1] + t[r[15]][1]) + + 3 * (t[r[11]][1] + t[r[1]][1])) / + 9, + ]); + r[10] = t.length; + t.push([ + (-4 * t[r[15]][0] - + t[r[0]][0] + + 6 * (t[r[11]][0] + t[r[14]][0]) - + 2 * (t[r[12]][0] + t[r[3]][0]) + + 3 * (t[r[2]][0] + t[r[8]][0])) / + 9, + (-4 * t[r[15]][1] - + t[r[0]][1] + + 6 * (t[r[11]][1] + t[r[14]][1]) - + 2 * (t[r[12]][1] + t[r[3]][1]) + + 3 * (t[r[2]][1] + t[r[8]][1])) / + 9, + ]); + this.figures.push({ + type: "patch", + coords: new Int32Array(r), + colors: new Int32Array(i), + }); + } + } + _decodeType7Shading(e) { + const t = this.coords, + a = this.colors, + r = new Int32Array(16), + i = new Int32Array(4); + for (; e.hasData; ) { + const n = e.readFlag(); + if (!(0 <= n && n <= 3)) throw new FormatError("Unknown type7 flag"); + const s = t.length; + for (let a = 0, r = 0 !== n ? 12 : 16; a < r; a++) + t.push(e.readCoordinate()); + const o = a.length; + for (let t = 0, r = 0 !== n ? 2 : 4; t < r; t++) + a.push(e.readComponents()); + let c, l, h, u; + switch (n) { + case 0: + r[12] = s + 3; + r[13] = s + 4; + r[14] = s + 5; + r[15] = s + 6; + r[8] = s + 2; + r[9] = s + 13; + r[10] = s + 14; + r[11] = s + 7; + r[4] = s + 1; + r[5] = s + 12; + r[6] = s + 15; + r[7] = s + 8; + r[0] = s; + r[1] = s + 11; + r[2] = s + 10; + r[3] = s + 9; + i[2] = o + 1; + i[3] = o + 2; + i[0] = o; + i[1] = o + 3; + break; + case 1: + c = r[12]; + l = r[13]; + h = r[14]; + u = r[15]; + r[12] = u; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = h; + r[9] = s + 9; + r[10] = s + 10; + r[11] = s + 3; + r[4] = l; + r[5] = s + 8; + r[6] = s + 11; + r[7] = s + 4; + r[0] = c; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + c = i[2]; + l = i[3]; + i[2] = l; + i[3] = o; + i[0] = c; + i[1] = o + 1; + break; + case 2: + c = r[15]; + l = r[11]; + r[12] = r[3]; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = r[7]; + r[9] = s + 9; + r[10] = s + 10; + r[11] = s + 3; + r[4] = l; + r[5] = s + 8; + r[6] = s + 11; + r[7] = s + 4; + r[0] = c; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + c = i[3]; + i[2] = i[1]; + i[3] = o; + i[0] = c; + i[1] = o + 1; + break; + case 3: + r[12] = r[0]; + r[13] = s + 0; + r[14] = s + 1; + r[15] = s + 2; + r[8] = r[1]; + r[9] = s + 9; + r[10] = s + 10; + r[11] = s + 3; + r[4] = r[2]; + r[5] = s + 8; + r[6] = s + 11; + r[7] = s + 4; + r[0] = r[3]; + r[1] = s + 7; + r[2] = s + 6; + r[3] = s + 5; + i[2] = i[0]; + i[3] = o; + i[0] = i[1]; + i[1] = o + 1; + } + this.figures.push({ + type: "patch", + coords: new Int32Array(r), + colors: new Int32Array(i), + }); + } + } + _buildFigureFromPatch(e) { + const t = this.figures[e]; + assert("patch" === t.type, "Unexpected patch mesh figure"); + const a = this.coords, + r = this.colors, + i = t.coords, + n = t.colors, + s = Math.min(a[i[0]][0], a[i[3]][0], a[i[12]][0], a[i[15]][0]), + o = Math.min(a[i[0]][1], a[i[3]][1], a[i[12]][1], a[i[15]][1]), + c = Math.max(a[i[0]][0], a[i[3]][0], a[i[12]][0], a[i[15]][0]), + l = Math.max(a[i[0]][1], a[i[3]][1], a[i[12]][1], a[i[15]][1]); + let h = Math.ceil( + ((c - s) * MeshShading.TRIANGLE_DENSITY) / + (this.bounds[2] - this.bounds[0]), + ); + h = MathClamp( + h, + MeshShading.MIN_SPLIT_PATCH_CHUNKS_AMOUNT, + MeshShading.MAX_SPLIT_PATCH_CHUNKS_AMOUNT, + ); + let u = Math.ceil( + ((l - o) * MeshShading.TRIANGLE_DENSITY) / + (this.bounds[3] - this.bounds[1]), + ); + u = MathClamp( + u, + MeshShading.MIN_SPLIT_PATCH_CHUNKS_AMOUNT, + MeshShading.MAX_SPLIT_PATCH_CHUNKS_AMOUNT, + ); + const d = h + 1, + f = new Int32Array((u + 1) * d), + g = new Int32Array((u + 1) * d); + let p = 0; + const m = new Uint8Array(3), + b = new Uint8Array(3), + y = r[n[0]], + w = r[n[1]], + x = r[n[2]], + S = r[n[3]], + k = getB(u), + C = getB(h); + for (let e = 0; e <= u; e++) { + m[0] = ((y[0] * (u - e) + x[0] * e) / u) | 0; + m[1] = ((y[1] * (u - e) + x[1] * e) / u) | 0; + m[2] = ((y[2] * (u - e) + x[2] * e) / u) | 0; + b[0] = ((w[0] * (u - e) + S[0] * e) / u) | 0; + b[1] = ((w[1] * (u - e) + S[1] * e) / u) | 0; + b[2] = ((w[2] * (u - e) + S[2] * e) / u) | 0; + for (let t = 0; t <= h; t++, p++) { + if (!((0 !== e && e !== u) || (0 !== t && t !== h))) continue; + let n = 0, + s = 0, + o = 0; + for (let r = 0; r <= 3; r++) + for (let c = 0; c <= 3; c++, o++) { + const l = k[e][r] * C[t][c]; + n += a[i[o]][0] * l; + s += a[i[o]][1] * l; + } + f[p] = a.length; + a.push([n, s]); + g[p] = r.length; + const c = new Uint8Array(3); + c[0] = ((m[0] * (h - t) + b[0] * t) / h) | 0; + c[1] = ((m[1] * (h - t) + b[1] * t) / h) | 0; + c[2] = ((m[2] * (h - t) + b[2] * t) / h) | 0; + r.push(c); + } + } + f[0] = i[0]; + g[0] = n[0]; + f[h] = i[3]; + g[h] = n[1]; + f[d * u] = i[12]; + g[d * u] = n[2]; + f[d * u + h] = i[15]; + g[d * u + h] = n[3]; + this.figures[e] = { + type: "lattice", + coords: f, + colors: g, + verticesPerRow: d, + }; + } + _updateBounds() { + let e = this.coords[0][0], + t = this.coords[0][1], + a = e, + r = t; + for (let i = 1, n = this.coords.length; i < n; i++) { + const n = this.coords[i][0], + s = this.coords[i][1]; + e = e > n ? n : e; + t = t > s ? s : t; + a = a < n ? n : a; + r = r < s ? s : r; + } + this.bounds = [e, t, a, r]; + } + _packData() { + let e, t, a, r; + const i = this.coords, + n = new Float32Array(2 * i.length); + for (e = 0, a = 0, t = i.length; e < t; e++) { + const t = i[e]; + n[a++] = t[0]; + n[a++] = t[1]; + } + this.coords = n; + const s = this.colors, + o = new Uint8Array(3 * s.length); + for (e = 0, a = 0, t = s.length; e < t; e++) { + const t = s[e]; + o[a++] = t[0]; + o[a++] = t[1]; + o[a++] = t[2]; + } + this.colors = o; + const c = this.figures; + for (e = 0, t = c.length; e < t; e++) { + const t = c[e], + i = t.coords, + n = t.colors; + for (a = 0, r = i.length; a < r; a++) { + i[a] *= 2; + n[a] *= 3; + } + } + } + getIR() { + const { bounds: e } = this; + if (e[2] - e[0] == 0 || e[3] - e[1] == 0) + throw new FormatError(`Invalid MeshShading bounds: [${e}].`); + return [ + "Mesh", + this.shadingType, + this.coords, + this.colors, + this.figures, + e, + this.bbox, + this.background, + ]; + } +} +class DummyShading extends BaseShading { + getIR() { + return ["Dummy"]; + } +} +function getTilingPatternIR(e, t, a) { + const r = lookupMatrix(t.getArray("Matrix"), Fa), + i = lookupNormalRect(t.getArray("BBox"), null); + if (!i || i[2] - i[0] == 0 || i[3] - i[1] == 0) + throw new FormatError("Invalid getTilingPatternIR /BBox array."); + const n = t.get("XStep"); + if ("number" != typeof n) + throw new FormatError("Invalid getTilingPatternIR /XStep value."); + const s = t.get("YStep"); + if ("number" != typeof s) + throw new FormatError("Invalid getTilingPatternIR /YStep value."); + const o = t.get("PaintType"); + if (!Number.isInteger(o)) + throw new FormatError("Invalid getTilingPatternIR /PaintType value."); + const c = t.get("TilingType"); + if (!Number.isInteger(c)) + throw new FormatError("Invalid getTilingPatternIR /TilingType value."); + return ["TilingPattern", a, e, r, i, n, s, o, c]; +} +const Ti = [ + 1.3877, 1, 1, 1, 0.97801, 0.92482, 0.89552, 0.91133, 0.81988, 0.97566, + 0.98152, 0.93548, 0.93548, 1.2798, 0.85284, 0.92794, 1, 0.96134, 1.54657, + 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, + 0.91133, 0.91133, 0.82845, 0.82845, 0.85284, 0.85284, 0.85284, 0.75859, + 0.92138, 0.83908, 0.7762, 0.73293, 0.87289, 0.73133, 0.7514, 0.81921, + 0.87356, 0.95958, 0.59526, 0.75727, 0.69225, 1.04924, 0.9121, 0.86943, + 0.79795, 0.88198, 0.77958, 0.70864, 0.81055, 0.90399, 0.88653, 0.96017, + 0.82577, 0.77892, 0.78257, 0.97507, 1.54657, 0.97507, 0.85284, 0.89552, + 0.90176, 0.88762, 0.8785, 0.75241, 0.8785, 0.90518, 0.95015, 0.77618, + 0.8785, 0.88401, 0.91916, 0.86304, 0.88401, 0.91488, 0.8785, 0.8801, 0.8785, + 0.8785, 0.91343, 0.7173, 1.04106, 0.8785, 0.85075, 0.95794, 0.82616, + 0.85162, 0.79492, 0.88331, 1.69808, 0.88331, 0.85284, 0.97801, 0.89552, + 0.91133, 0.89552, 0.91133, 1.7801, 0.89552, 1.24487, 1.13254, 1.12401, + 0.96839, 0.85284, 0.68787, 0.70645, 0.85592, 0.90747, 1.01466, 1.0088, + 0.90323, 1, 1.07463, 1, 0.91056, 0.75806, 1.19118, 0.96839, 0.78864, + 0.82845, 0.84133, 0.75859, 0.83908, 0.83908, 0.83908, 0.83908, 0.83908, + 0.83908, 0.77539, 0.73293, 0.73133, 0.73133, 0.73133, 0.73133, 0.95958, + 0.95958, 0.95958, 0.95958, 0.88506, 0.9121, 0.86943, 0.86943, 0.86943, + 0.86943, 0.86943, 0.85284, 0.87508, 0.90399, 0.90399, 0.90399, 0.90399, + 0.77892, 0.79795, 0.90807, 0.88762, 0.88762, 0.88762, 0.88762, 0.88762, + 0.88762, 0.8715, 0.75241, 0.90518, 0.90518, 0.90518, 0.90518, 0.88401, + 0.88401, 0.88401, 0.88401, 0.8785, 0.8785, 0.8801, 0.8801, 0.8801, 0.8801, + 0.8801, 0.90747, 0.89049, 0.8785, 0.8785, 0.8785, 0.8785, 0.85162, 0.8785, + 0.85162, 0.83908, 0.88762, 0.83908, 0.88762, 0.83908, 0.88762, 0.73293, + 0.75241, 0.73293, 0.75241, 0.73293, 0.75241, 0.73293, 0.75241, 0.87289, + 0.83016, 0.88506, 0.93125, 0.73133, 0.90518, 0.73133, 0.90518, 0.73133, + 0.90518, 0.73133, 0.90518, 0.73133, 0.90518, 0.81921, 0.77618, 0.81921, + 0.77618, 0.81921, 0.77618, 1, 1, 0.87356, 0.8785, 0.91075, 0.89608, 0.95958, + 0.88401, 0.95958, 0.88401, 0.95958, 0.88401, 0.95958, 0.88401, 0.95958, + 0.88401, 0.76229, 0.90167, 0.59526, 0.91916, 1, 1, 0.86304, 0.69225, + 0.88401, 1, 1, 0.70424, 0.79468, 0.91926, 0.88175, 0.70823, 0.94903, 0.9121, + 0.8785, 1, 1, 0.9121, 0.8785, 0.87802, 0.88656, 0.8785, 0.86943, 0.8801, + 0.86943, 0.8801, 0.86943, 0.8801, 0.87402, 0.89291, 0.77958, 0.91343, 1, 1, + 0.77958, 0.91343, 0.70864, 0.7173, 0.70864, 0.7173, 0.70864, 0.7173, + 0.70864, 0.7173, 1, 1, 0.81055, 0.75841, 0.81055, 1.06452, 0.90399, 0.8785, + 0.90399, 0.8785, 0.90399, 0.8785, 0.90399, 0.8785, 0.90399, 0.8785, 0.90399, + 0.8785, 0.96017, 0.95794, 0.77892, 0.85162, 0.77892, 0.78257, 0.79492, + 0.78257, 0.79492, 0.78257, 0.79492, 0.9297, 0.56892, 0.83908, 0.88762, + 0.77539, 0.8715, 0.87508, 0.89049, 1, 1, 0.81055, 1.04106, 1.20528, 1.20528, + 1, 1.15543, 0.70674, 0.98387, 0.94721, 1.33431, 1.45894, 0.95161, 1.06303, + 0.83908, 0.80352, 0.57184, 0.6965, 0.56289, 0.82001, 0.56029, 0.81235, + 1.02988, 0.83908, 0.7762, 0.68156, 0.80367, 0.73133, 0.78257, 0.87356, + 0.86943, 0.95958, 0.75727, 0.89019, 1.04924, 0.9121, 0.7648, 0.86943, + 0.87356, 0.79795, 0.78275, 0.81055, 0.77892, 0.9762, 0.82577, 0.99819, + 0.84896, 0.95958, 0.77892, 0.96108, 1.01407, 0.89049, 1.02988, 0.94211, + 0.96108, 0.8936, 0.84021, 0.87842, 0.96399, 0.79109, 0.89049, 1.00813, + 1.02988, 0.86077, 0.87445, 0.92099, 0.84723, 0.86513, 0.8801, 0.75638, + 0.85714, 0.78216, 0.79586, 0.87965, 0.94211, 0.97747, 0.78287, 0.97926, + 0.84971, 1.02988, 0.94211, 0.8801, 0.94211, 0.84971, 0.73133, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 0.90264, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 0.90518, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.90548, 1, 1, 1, 1, 1, 1, + 0.96017, 0.95794, 0.96017, 0.95794, 0.96017, 0.95794, 0.77892, 0.85162, 1, + 1, 0.89552, 0.90527, 1, 0.90363, 0.92794, 0.92794, 0.92794, 0.92794, + 0.87012, 0.87012, 0.87012, 0.89552, 0.89552, 1.42259, 0.71143, 1.06152, 1, + 1, 1.03372, 1.03372, 0.97171, 1.4956, 2.2807, 0.93835, 0.83406, 0.91133, + 0.84107, 0.91133, 1, 1, 1, 0.72021, 1, 1.23108, 0.83489, 0.88525, 0.88525, + 0.81499, 0.90527, 1.81055, 0.90527, 1.81055, 1.31006, 1.53711, 0.94434, + 1.08696, 1, 0.95018, 0.77192, 0.85284, 0.90747, 1.17534, 0.69825, 0.9716, + 1.37077, 0.90747, 0.90747, 0.85356, 0.90747, 0.90747, 1.44947, 0.85284, + 0.8941, 0.8941, 0.70572, 0.8, 0.70572, 0.70572, 0.70572, 0.70572, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.99862, 0.99862, 1, 1, 1, + 1, 1, 1.08004, 0.91027, 1, 1, 1, 0.99862, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 0.90727, 0.90727, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + Oi = { lineHeight: 1.2207, lineGap: 0.2207 }, + Mi = [ + 1.3877, 1, 1, 1, 0.97801, 0.92482, 0.89552, 0.91133, 0.81988, 0.97566, + 0.98152, 0.93548, 0.93548, 1.2798, 0.85284, 0.92794, 1, 0.96134, 1.56239, + 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, + 0.91133, 0.91133, 0.82845, 0.82845, 0.85284, 0.85284, 0.85284, 0.75859, + 0.92138, 0.83908, 0.7762, 0.71805, 0.87289, 0.73133, 0.7514, 0.81921, + 0.87356, 0.95958, 0.59526, 0.75727, 0.69225, 1.04924, 0.90872, 0.85938, + 0.79795, 0.87068, 0.77958, 0.69766, 0.81055, 0.90399, 0.88653, 0.96068, + 0.82577, 0.77892, 0.78257, 0.97507, 1.529, 0.97507, 0.85284, 0.89552, + 0.90176, 0.94908, 0.86411, 0.74012, 0.86411, 0.88323, 0.95015, 0.86411, + 0.86331, 0.88401, 0.91916, 0.86304, 0.88401, 0.9039, 0.86331, 0.86331, + 0.86411, 0.86411, 0.90464, 0.70852, 1.04106, 0.86331, 0.84372, 0.95794, + 0.82616, 0.84548, 0.79492, 0.88331, 1.69808, 0.88331, 0.85284, 0.97801, + 0.89552, 0.91133, 0.89552, 0.91133, 1.7801, 0.89552, 1.24487, 1.13254, + 1.19129, 0.96839, 0.85284, 0.68787, 0.70645, 0.85592, 0.90747, 1.01466, + 1.0088, 0.90323, 1, 1.07463, 1, 0.91056, 0.75806, 1.19118, 0.96839, 0.78864, + 0.82845, 0.84133, 0.75859, 0.83908, 0.83908, 0.83908, 0.83908, 0.83908, + 0.83908, 0.77539, 0.71805, 0.73133, 0.73133, 0.73133, 0.73133, 0.95958, + 0.95958, 0.95958, 0.95958, 0.88506, 0.90872, 0.85938, 0.85938, 0.85938, + 0.85938, 0.85938, 0.85284, 0.87068, 0.90399, 0.90399, 0.90399, 0.90399, + 0.77892, 0.79795, 0.90807, 0.94908, 0.94908, 0.94908, 0.94908, 0.94908, + 0.94908, 0.85887, 0.74012, 0.88323, 0.88323, 0.88323, 0.88323, 0.88401, + 0.88401, 0.88401, 0.88401, 0.8785, 0.86331, 0.86331, 0.86331, 0.86331, + 0.86331, 0.86331, 0.90747, 0.89049, 0.86331, 0.86331, 0.86331, 0.86331, + 0.84548, 0.86411, 0.84548, 0.83908, 0.94908, 0.83908, 0.94908, 0.83908, + 0.94908, 0.71805, 0.74012, 0.71805, 0.74012, 0.71805, 0.74012, 0.71805, + 0.74012, 0.87289, 0.79538, 0.88506, 0.92726, 0.73133, 0.88323, 0.73133, + 0.88323, 0.73133, 0.88323, 0.73133, 0.88323, 0.73133, 0.88323, 0.81921, + 0.86411, 0.81921, 0.86411, 0.81921, 0.86411, 1, 1, 0.87356, 0.86331, + 0.91075, 0.8777, 0.95958, 0.88401, 0.95958, 0.88401, 0.95958, 0.88401, + 0.95958, 0.88401, 0.95958, 0.88401, 0.76467, 0.90167, 0.59526, 0.91916, 1, + 1, 0.86304, 0.69225, 0.88401, 1, 1, 0.70424, 0.77312, 0.91926, 0.88175, + 0.70823, 0.94903, 0.90872, 0.86331, 1, 1, 0.90872, 0.86331, 0.86906, + 0.88116, 0.86331, 0.85938, 0.86331, 0.85938, 0.86331, 0.85938, 0.86331, + 0.87402, 0.86549, 0.77958, 0.90464, 1, 1, 0.77958, 0.90464, 0.69766, + 0.70852, 0.69766, 0.70852, 0.69766, 0.70852, 0.69766, 0.70852, 1, 1, + 0.81055, 0.75841, 0.81055, 1.06452, 0.90399, 0.86331, 0.90399, 0.86331, + 0.90399, 0.86331, 0.90399, 0.86331, 0.90399, 0.86331, 0.90399, 0.86331, + 0.96068, 0.95794, 0.77892, 0.84548, 0.77892, 0.78257, 0.79492, 0.78257, + 0.79492, 0.78257, 0.79492, 0.9297, 0.56892, 0.83908, 0.94908, 0.77539, + 0.85887, 0.87068, 0.89049, 1, 1, 0.81055, 1.04106, 1.20528, 1.20528, 1, + 1.15543, 0.70088, 0.98387, 0.94721, 1.33431, 1.45894, 0.95161, 1.48387, + 0.83908, 0.80352, 0.57118, 0.6965, 0.56347, 0.79179, 0.55853, 0.80346, + 1.02988, 0.83908, 0.7762, 0.67174, 0.86036, 0.73133, 0.78257, 0.87356, + 0.86441, 0.95958, 0.75727, 0.89019, 1.04924, 0.90872, 0.74889, 0.85938, + 0.87891, 0.79795, 0.7957, 0.81055, 0.77892, 0.97447, 0.82577, 0.97466, + 0.87179, 0.95958, 0.77892, 0.94252, 0.95612, 0.8753, 1.02988, 0.92733, + 0.94252, 0.87411, 0.84021, 0.8728, 0.95612, 0.74081, 0.8753, 1.02189, + 1.02988, 0.84814, 0.87445, 0.91822, 0.84723, 0.85668, 0.86331, 0.81344, + 0.87581, 0.76422, 0.82046, 0.96057, 0.92733, 0.99375, 0.78022, 0.95452, + 0.86015, 1.02988, 0.92733, 0.86331, 0.92733, 0.86015, 0.73133, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 0.90631, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 0.88323, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.85174, 1, 1, 1, 1, 1, + 1, 0.96068, 0.95794, 0.96068, 0.95794, 0.96068, 0.95794, 0.77892, 0.84548, + 1, 1, 0.89552, 0.90527, 1, 0.90363, 0.92794, 0.92794, 0.92794, 0.89807, + 0.87012, 0.87012, 0.87012, 0.89552, 0.89552, 1.42259, 0.71094, 1.06152, 1, + 1, 1.03372, 1.03372, 0.97171, 1.4956, 2.2807, 0.92972, 0.83406, 0.91133, + 0.83326, 0.91133, 1, 1, 1, 0.72021, 1, 1.23108, 0.83489, 0.88525, 0.88525, + 0.81499, 0.90616, 1.81055, 0.90527, 1.81055, 1.3107, 1.53711, 0.94434, + 1.08696, 1, 0.95018, 0.77192, 0.85284, 0.90747, 1.17534, 0.69825, 0.9716, + 1.37077, 0.90747, 0.90747, 0.85356, 0.90747, 0.90747, 1.44947, 0.85284, + 0.8941, 0.8941, 0.70572, 0.8, 0.70572, 0.70572, 0.70572, 0.70572, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.99862, 0.99862, 1, 1, 1, + 1, 1, 1.08004, 0.91027, 1, 1, 1, 0.99862, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 0.90727, 0.90727, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + Di = { lineHeight: 1.2207, lineGap: 0.2207 }, + Bi = [ + 1.3877, 1, 1, 1, 1.17223, 1.1293, 0.89552, 0.91133, 0.80395, 1.02269, + 1.15601, 0.91056, 0.91056, 1.2798, 0.85284, 0.89807, 1, 0.90861, 1.39543, + 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, + 0.91133, 0.91133, 0.96309, 0.96309, 0.85284, 0.85284, 0.85284, 0.83319, + 0.88071, 0.8675, 0.81552, 0.72346, 0.85193, 0.73206, 0.7522, 0.81105, + 0.86275, 0.90685, 0.6377, 0.77892, 0.75593, 1.02638, 0.89249, 0.84118, + 0.77452, 0.85374, 0.75186, 0.67789, 0.79776, 0.88844, 0.85066, 0.94309, + 0.77818, 0.7306, 0.76659, 1.10369, 1.38313, 1.10369, 1.06139, 0.89552, + 0.8739, 0.9245, 0.9245, 0.83203, 0.9245, 0.85865, 1.09842, 0.9245, 0.9245, + 1.03297, 1.07692, 0.90918, 1.03297, 0.94959, 0.9245, 0.92274, 0.9245, + 0.9245, 1.02933, 0.77832, 1.20562, 0.9245, 0.8916, 0.98986, 0.86621, + 0.89453, 0.79004, 0.94152, 1.77256, 0.94152, 0.85284, 0.97801, 0.89552, + 0.91133, 0.89552, 0.91133, 1.91729, 0.89552, 1.17889, 1.13254, 1.16359, + 0.92098, 0.85284, 0.68787, 0.71353, 0.84737, 0.90747, 1.0088, 1.0044, + 0.87683, 1, 1.09091, 1, 0.92229, 0.739, 1.15642, 0.92098, 0.76288, 0.80504, + 0.80972, 0.75859, 0.8675, 0.8675, 0.8675, 0.8675, 0.8675, 0.8675, 0.76318, + 0.72346, 0.73206, 0.73206, 0.73206, 0.73206, 0.90685, 0.90685, 0.90685, + 0.90685, 0.86477, 0.89249, 0.84118, 0.84118, 0.84118, 0.84118, 0.84118, + 0.85284, 0.84557, 0.88844, 0.88844, 0.88844, 0.88844, 0.7306, 0.77452, + 0.86331, 0.9245, 0.9245, 0.9245, 0.9245, 0.9245, 0.9245, 0.84843, 0.83203, + 0.85865, 0.85865, 0.85865, 0.85865, 0.82601, 0.82601, 0.82601, 0.82601, + 0.94469, 0.9245, 0.92274, 0.92274, 0.92274, 0.92274, 0.92274, 0.90747, + 0.86651, 0.9245, 0.9245, 0.9245, 0.9245, 0.89453, 0.9245, 0.89453, 0.8675, + 0.9245, 0.8675, 0.9245, 0.8675, 0.9245, 0.72346, 0.83203, 0.72346, 0.83203, + 0.72346, 0.83203, 0.72346, 0.83203, 0.85193, 0.8875, 0.86477, 0.99034, + 0.73206, 0.85865, 0.73206, 0.85865, 0.73206, 0.85865, 0.73206, 0.85865, + 0.73206, 0.85865, 0.81105, 0.9245, 0.81105, 0.9245, 0.81105, 0.9245, 1, 1, + 0.86275, 0.9245, 0.90872, 0.93591, 0.90685, 0.82601, 0.90685, 0.82601, + 0.90685, 0.82601, 0.90685, 1.03297, 0.90685, 0.82601, 0.77896, 1.05611, + 0.6377, 1.07692, 1, 1, 0.90918, 0.75593, 1.03297, 1, 1, 0.76032, 0.9375, + 0.98156, 0.93407, 0.77261, 1.11429, 0.89249, 0.9245, 1, 1, 0.89249, 0.9245, + 0.92534, 0.86698, 0.9245, 0.84118, 0.92274, 0.84118, 0.92274, 0.84118, + 0.92274, 0.8667, 0.86291, 0.75186, 1.02933, 1, 1, 0.75186, 1.02933, 0.67789, + 0.77832, 0.67789, 0.77832, 0.67789, 0.77832, 0.67789, 0.77832, 1, 1, + 0.79776, 0.97655, 0.79776, 1.23023, 0.88844, 0.9245, 0.88844, 0.9245, + 0.88844, 0.9245, 0.88844, 0.9245, 0.88844, 0.9245, 0.88844, 0.9245, 0.94309, + 0.98986, 0.7306, 0.89453, 0.7306, 0.76659, 0.79004, 0.76659, 0.79004, + 0.76659, 0.79004, 1.09231, 0.54873, 0.8675, 0.9245, 0.76318, 0.84843, + 0.84557, 0.86651, 1, 1, 0.79776, 1.20562, 1.18622, 1.18622, 1, 1.1437, + 0.67009, 0.96334, 0.93695, 1.35191, 1.40909, 0.95161, 1.48387, 0.8675, + 0.90861, 0.6192, 0.7363, 0.64824, 0.82411, 0.56321, 0.85696, 1.23516, + 0.8675, 0.81552, 0.7286, 0.84134, 0.73206, 0.76659, 0.86275, 0.84369, + 0.90685, 0.77892, 0.85871, 1.02638, 0.89249, 0.75828, 0.84118, 0.85984, + 0.77452, 0.76466, 0.79776, 0.7306, 0.90782, 0.77818, 0.903, 0.87291, + 0.90685, 0.7306, 0.99058, 1.03667, 0.94635, 1.23516, 0.9849, 0.99058, + 0.92393, 0.8916, 0.942, 1.03667, 0.75026, 0.94635, 1.0297, 1.23516, 0.90918, + 0.94048, 0.98217, 0.89746, 0.84153, 0.92274, 0.82507, 0.88832, 0.84438, + 0.88178, 1.03525, 0.9849, 1.00225, 0.78086, 0.97248, 0.89404, 1.23516, + 0.9849, 0.92274, 0.9849, 0.89404, 0.73206, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 0.89693, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.85865, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.90933, 1, 1, 1, 1, 1, 1, 0.94309, 0.98986, + 0.94309, 0.98986, 0.94309, 0.98986, 0.7306, 0.89453, 1, 1, 0.89552, 0.90527, + 1, 0.90186, 1.12308, 1.12308, 1.12308, 1.12308, 1.2566, 1.2566, 1.2566, + 0.89552, 0.89552, 1.42259, 0.68994, 1.03809, 1, 1, 1.0176, 1.0176, 1.11523, + 1.4956, 2.01462, 0.97858, 0.82616, 0.91133, 0.83437, 0.91133, 1, 1, 1, + 0.70508, 1, 1.23108, 0.79801, 0.84426, 0.84426, 0.774, 0.90572, 1.81055, + 0.90749, 1.81055, 1.28809, 1.55469, 0.94434, 1.07806, 1, 0.97094, 0.7589, + 0.85284, 0.90747, 1.19658, 0.69825, 0.97622, 1.33512, 0.90747, 0.90747, + 0.85284, 0.90747, 0.90747, 1.44947, 0.85284, 0.8941, 0.8941, 0.70572, 0.8, + 0.70572, 0.70572, 0.70572, 0.70572, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 0.99862, 0.99862, 1, 1, 1, 1, 1, 1.0336, 0.91027, 1, 1, 1, + 0.99862, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.05859, 1.05859, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + Ri = { lineHeight: 1.2207, lineGap: 0.2207 }, + Ni = [ + 1.3877, 1, 1, 1, 1.17223, 1.1293, 0.89552, 0.91133, 0.80395, 1.02269, + 1.15601, 0.91056, 0.91056, 1.2798, 0.85284, 0.89807, 1, 0.90861, 1.39016, + 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, 0.91133, + 0.91133, 0.91133, 0.96309, 0.96309, 0.85284, 0.85284, 0.85284, 0.83319, + 0.88071, 0.8675, 0.81552, 0.73834, 0.85193, 0.73206, 0.7522, 0.81105, + 0.86275, 0.90685, 0.6377, 0.77892, 0.75593, 1.02638, 0.89385, 0.85122, + 0.77452, 0.86503, 0.75186, 0.68887, 0.79776, 0.88844, 0.85066, 0.94258, + 0.77818, 0.7306, 0.76659, 1.10369, 1.39016, 1.10369, 1.06139, 0.89552, + 0.8739, 0.86128, 0.94469, 0.8457, 0.94469, 0.89464, 1.09842, 0.84636, + 0.94469, 1.03297, 1.07692, 0.90918, 1.03297, 0.95897, 0.94469, 0.9482, + 0.94469, 0.94469, 1.04692, 0.78223, 1.20562, 0.94469, 0.90332, 0.98986, + 0.86621, 0.90527, 0.79004, 0.94152, 1.77256, 0.94152, 0.85284, 0.97801, + 0.89552, 0.91133, 0.89552, 0.91133, 1.91729, 0.89552, 1.17889, 1.13254, + 1.08707, 0.92098, 0.85284, 0.68787, 0.71353, 0.84737, 0.90747, 1.0088, + 1.0044, 0.87683, 1, 1.09091, 1, 0.92229, 0.739, 1.15642, 0.92098, 0.76288, + 0.80504, 0.80972, 0.75859, 0.8675, 0.8675, 0.8675, 0.8675, 0.8675, 0.8675, + 0.76318, 0.73834, 0.73206, 0.73206, 0.73206, 0.73206, 0.90685, 0.90685, + 0.90685, 0.90685, 0.86477, 0.89385, 0.85122, 0.85122, 0.85122, 0.85122, + 0.85122, 0.85284, 0.85311, 0.88844, 0.88844, 0.88844, 0.88844, 0.7306, + 0.77452, 0.86331, 0.86128, 0.86128, 0.86128, 0.86128, 0.86128, 0.86128, + 0.8693, 0.8457, 0.89464, 0.89464, 0.89464, 0.89464, 0.82601, 0.82601, + 0.82601, 0.82601, 0.94469, 0.94469, 0.9482, 0.9482, 0.9482, 0.9482, 0.9482, + 0.90747, 0.86651, 0.94469, 0.94469, 0.94469, 0.94469, 0.90527, 0.94469, + 0.90527, 0.8675, 0.86128, 0.8675, 0.86128, 0.8675, 0.86128, 0.73834, 0.8457, + 0.73834, 0.8457, 0.73834, 0.8457, 0.73834, 0.8457, 0.85193, 0.92454, + 0.86477, 0.9921, 0.73206, 0.89464, 0.73206, 0.89464, 0.73206, 0.89464, + 0.73206, 0.89464, 0.73206, 0.89464, 0.81105, 0.84636, 0.81105, 0.84636, + 0.81105, 0.84636, 1, 1, 0.86275, 0.94469, 0.90872, 0.95786, 0.90685, + 0.82601, 0.90685, 0.82601, 0.90685, 0.82601, 0.90685, 1.03297, 0.90685, + 0.82601, 0.77741, 1.05611, 0.6377, 1.07692, 1, 1, 0.90918, 0.75593, 1.03297, + 1, 1, 0.76032, 0.90452, 0.98156, 1.11842, 0.77261, 1.11429, 0.89385, + 0.94469, 1, 1, 0.89385, 0.94469, 0.95877, 0.86901, 0.94469, 0.85122, 0.9482, + 0.85122, 0.9482, 0.85122, 0.9482, 0.8667, 0.90016, 0.75186, 1.04692, 1, 1, + 0.75186, 1.04692, 0.68887, 0.78223, 0.68887, 0.78223, 0.68887, 0.78223, + 0.68887, 0.78223, 1, 1, 0.79776, 0.92188, 0.79776, 1.23023, 0.88844, + 0.94469, 0.88844, 0.94469, 0.88844, 0.94469, 0.88844, 0.94469, 0.88844, + 0.94469, 0.88844, 0.94469, 0.94258, 0.98986, 0.7306, 0.90527, 0.7306, + 0.76659, 0.79004, 0.76659, 0.79004, 0.76659, 0.79004, 1.09231, 0.54873, + 0.8675, 0.86128, 0.76318, 0.8693, 0.85311, 0.86651, 1, 1, 0.79776, 1.20562, + 1.18622, 1.18622, 1, 1.1437, 0.67742, 0.96334, 0.93695, 1.35191, 1.40909, + 0.95161, 1.48387, 0.86686, 0.90861, 0.62267, 0.74359, 0.65649, 0.85498, + 0.56963, 0.88254, 1.23516, 0.8675, 0.81552, 0.75443, 0.84503, 0.73206, + 0.76659, 0.86275, 0.85122, 0.90685, 0.77892, 0.85746, 1.02638, 0.89385, + 0.75657, 0.85122, 0.86275, 0.77452, 0.74171, 0.79776, 0.7306, 0.95165, + 0.77818, 0.89772, 0.88831, 0.90685, 0.7306, 0.98142, 1.02191, 0.96576, + 1.23516, 0.99018, 0.98142, 0.9236, 0.89258, 0.94035, 1.02191, 0.78848, + 0.96576, 0.9561, 1.23516, 0.90918, 0.92578, 0.95424, 0.89746, 0.83969, + 0.9482, 0.80113, 0.89442, 0.85208, 0.86155, 0.98022, 0.99018, 1.00452, + 0.81209, 0.99247, 0.89181, 1.23516, 0.99018, 0.9482, 0.99018, 0.89181, + 0.73206, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.88844, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.89464, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 0.96766, 1, 1, 1, 1, 1, 1, 0.94258, 0.98986, 0.94258, 0.98986, 0.94258, + 0.98986, 0.7306, 0.90527, 1, 1, 0.89552, 0.90527, 1, 0.90186, 1.12308, + 1.12308, 1.12308, 1.12308, 1.2566, 1.2566, 1.2566, 0.89552, 0.89552, + 1.42259, 0.69043, 1.03809, 1, 1, 1.0176, 1.0176, 1.11523, 1.4956, 2.01462, + 0.99331, 0.82616, 0.91133, 0.84286, 0.91133, 1, 1, 1, 0.70508, 1, 1.23108, + 0.79801, 0.84426, 0.84426, 0.774, 0.90527, 1.81055, 0.90527, 1.81055, + 1.28809, 1.55469, 0.94434, 1.07806, 1, 0.97094, 0.7589, 0.85284, 0.90747, + 1.19658, 0.69825, 0.97622, 1.33512, 0.90747, 0.90747, 0.85356, 0.90747, + 0.90747, 1.44947, 0.85284, 0.8941, 0.8941, 0.70572, 0.8, 0.70572, 0.70572, + 0.70572, 0.70572, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 0.99862, 0.99862, 1, 1, 1, 1, 1, 1.0336, 0.91027, 1, 1, 1, 0.99862, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.05859, 1.05859, 1, 1, 1, 1.07185, 0.99413, + 0.96334, 1.08065, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + Ei = { lineHeight: 1.2207, lineGap: 0.2207 }, + Pi = [ + 0.76116, 1, 1, 1.0006, 0.99998, 0.99974, 0.99973, 0.99973, 0.99982, 0.99977, + 1.00087, 0.99998, 0.99998, 0.99959, 1.00003, 1.0006, 0.99998, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 0.99998, 1, 1.00003, 1.00003, 1.00003, 1.00026, + 0.9999, 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, 1.00026, 1.00022, + 0.99977, 1.0006, 0.99973, 0.99977, 1.00026, 0.99999, 0.99977, 1.00022, + 1.00001, 1.00022, 0.99977, 1.00001, 1.00026, 0.99977, 1.00001, 1.00016, + 1.00001, 1.00001, 1.00026, 0.99998, 1.0006, 0.99998, 1.00003, 0.99973, + 0.99998, 0.99973, 1.00026, 0.99973, 1.00026, 0.99973, 0.99998, 1.00026, + 1.00026, 1.0006, 1.0006, 0.99973, 1.0006, 0.99982, 1.00026, 1.00026, + 1.00026, 1.00026, 0.99959, 0.99973, 0.99998, 1.00026, 0.99973, 1.00022, + 0.99973, 0.99973, 1, 0.99959, 1.00077, 0.99959, 1.00003, 0.99998, 0.99973, + 0.99973, 0.99973, 0.99973, 1.00077, 0.99973, 0.99998, 1.00025, 0.99968, + 0.99973, 1.00003, 1.00025, 0.60299, 1.00024, 1.06409, 1, 1, 0.99998, 1, + 0.99973, 1.0006, 0.99998, 1, 0.99936, 0.99973, 1.00002, 1.00002, 1.00002, + 1.00026, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 1, 0.99977, + 1.00001, 1.00001, 1.00001, 1.00001, 1.0006, 1.0006, 1.0006, 1.0006, 0.99977, + 0.99977, 1.00022, 1.00022, 1.00022, 1.00022, 1.00022, 1.00003, 1.00022, + 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, 1.00001, 1.00026, 0.99973, + 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99982, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 1.0006, 1.0006, 1.0006, 1.0006, 1.00026, 1.00026, + 1.00026, 1.00026, 1.00026, 1.00026, 1.00026, 1.06409, 1.00026, 1.00026, + 1.00026, 1.00026, 1.00026, 0.99973, 1.00026, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 1.03374, 0.99977, 1.00026, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, + 1.00001, 0.99973, 1.00022, 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, + 1.00022, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 1.0006, 1.0006, + 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.00042, + 0.99973, 0.99973, 1.0006, 0.99977, 0.99973, 0.99973, 1.00026, 1.0006, + 1.00026, 1.0006, 1.00026, 1.03828, 1.00026, 0.99999, 1.00026, 1.0006, + 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 0.9993, 0.9998, + 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, 1, 1.00016, + 0.99977, 0.99959, 0.99977, 0.99959, 0.99977, 0.99959, 1.00001, 0.99973, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00026, 0.99998, + 1.00026, 0.8121, 1.00026, 0.99998, 0.99977, 1.00026, 0.99977, 1.00026, + 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, + 1.00016, 1.00022, 1.00001, 0.99973, 1.00001, 1.00026, 1, 1.00026, 1, + 1.00026, 1, 1.0006, 0.99973, 0.99977, 0.99973, 1, 0.99982, 1.00022, 1.00026, + 1.00001, 0.99973, 1.00026, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, + 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 1.00034, 0.99977, 1, + 0.99997, 1.00026, 1.00078, 1.00036, 0.99973, 1.00013, 1.0006, 0.99977, + 0.99977, 0.99988, 0.85148, 1.00001, 1.00026, 0.99977, 1.00022, 1.0006, + 0.99977, 1.00001, 0.99999, 0.99977, 1.00069, 1.00022, 0.99977, 1.00001, + 0.99984, 1.00026, 1.00001, 1.00024, 1.00001, 0.9999, 1, 1.0006, 1.00001, + 1.00041, 0.99962, 1.00026, 1.0006, 0.99995, 1.00041, 0.99942, 0.99973, + 0.99927, 1.00082, 0.99902, 1.00026, 1.00087, 1.0006, 1.00069, 0.99973, + 0.99867, 0.99973, 0.9993, 1.00026, 1.00049, 1.00056, 1, 0.99988, 0.99935, + 0.99995, 0.99954, 1.00055, 0.99945, 1.00032, 1.0006, 0.99995, 1.00026, + 0.99995, 1.00032, 1.00001, 1.00008, 0.99971, 1.00019, 0.9994, 1.00001, + 1.0006, 1.00044, 0.99973, 1.00023, 1.00047, 1, 0.99942, 0.99561, 0.99989, + 1.00035, 0.99977, 1.00035, 0.99977, 1.00019, 0.99944, 1.00001, 1.00021, + 0.99926, 1.00035, 1.00035, 0.99942, 1.00048, 0.99999, 0.99977, 1.00022, + 1.00035, 1.00001, 0.99977, 1.00026, 0.99989, 1.00057, 1.00001, 0.99936, + 1.00052, 1.00012, 0.99996, 1.00043, 1, 1.00035, 0.9994, 0.99976, 1.00035, + 0.99973, 1.00052, 1.00041, 1.00119, 1.00037, 0.99973, 1.00002, 0.99986, + 1.00041, 1.00041, 0.99902, 0.9996, 1.00034, 0.99999, 1.00026, 0.99999, + 1.00026, 0.99973, 1.00052, 0.99973, 1, 0.99973, 1.00041, 1.00075, 0.9994, + 1.0003, 0.99999, 1, 1.00041, 0.99955, 1, 0.99915, 0.99973, 0.99973, 1.00026, + 1.00119, 0.99955, 0.99973, 1.0006, 0.99911, 1.0006, 1.00026, 0.99972, + 1.00026, 0.99902, 1.00041, 0.99973, 0.99999, 1, 1, 1.00038, 1.0005, 1.00016, + 1.00022, 1.00016, 1.00022, 1.00016, 1.00022, 1.00001, 0.99973, 1, 1, + 0.99973, 1, 1, 0.99955, 1.0006, 1.0006, 1.0006, 1.0006, 1, 1, 1, 0.99973, + 0.99973, 0.99972, 1, 1, 1.00106, 0.99999, 0.99998, 0.99998, 0.99999, + 0.99998, 1.66475, 1, 0.99973, 0.99973, 1.00023, 0.99973, 0.99971, 1.00047, + 1.00023, 1, 0.99991, 0.99984, 1.00002, 1.00002, 1.00002, 1.00002, 1, 1, 1, + 1, 1, 1, 1, 0.99972, 1, 1.20985, 1.39713, 1.00003, 1.00031, 1.00015, 1, + 0.99561, 1.00027, 1.00031, 1.00031, 0.99915, 1.00031, 1.00031, 0.99999, + 1.00003, 0.99999, 0.99999, 1.41144, 1.6, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.40579, + 1.40579, 1.36625, 0.99999, 1, 0.99861, 0.99861, 1, 1.00026, 1.00026, + 1.00026, 1.00026, 0.99972, 0.99999, 0.99999, 0.99999, 0.99999, 1.40483, 1, + 0.99977, 1.00054, 1, 1, 0.99953, 0.99962, 1.00042, 0.9995, 1, 1, 1, 1, 1, 1, + 1, 1, 0.99998, 0.99998, 0.99998, 0.99998, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + ji = { lineHeight: 1.2, lineGap: 0.2 }, + _i = [ + 0.76116, 1, 1, 1.0006, 0.99998, 0.99974, 0.99973, 0.99973, 0.99982, 0.99977, + 1.00087, 0.99998, 0.99998, 0.99959, 1.00003, 1.0006, 0.99998, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 0.99998, 1, 1.00003, 1.00003, 1.00003, 1.00026, + 0.9999, 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, 1.00026, 1.00022, + 0.99977, 1.0006, 0.99973, 0.99977, 1.00026, 0.99999, 0.99977, 1.00022, + 1.00001, 1.00022, 0.99977, 1.00001, 1.00026, 0.99977, 1.00001, 1.00016, + 1.00001, 1.00001, 1.00026, 0.99998, 1.0006, 0.99998, 1.00003, 0.99973, + 0.99998, 0.99973, 1.00026, 0.99973, 1.00026, 0.99973, 0.99998, 1.00026, + 1.00026, 1.0006, 1.0006, 0.99973, 1.0006, 0.99982, 1.00026, 1.00026, + 1.00026, 1.00026, 0.99959, 0.99973, 0.99998, 1.00026, 0.99973, 1.00022, + 0.99973, 0.99973, 1, 0.99959, 1.00077, 0.99959, 1.00003, 0.99998, 0.99973, + 0.99973, 0.99973, 0.99973, 1.00077, 0.99973, 0.99998, 1.00025, 0.99968, + 0.99973, 1.00003, 1.00025, 0.60299, 1.00024, 1.06409, 1, 1, 0.99998, 1, + 0.99973, 1.0006, 0.99998, 1, 0.99936, 0.99973, 1.00002, 1.00002, 1.00002, + 1.00026, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 1, 0.99977, + 1.00001, 1.00001, 1.00001, 1.00001, 1.0006, 1.0006, 1.0006, 1.0006, 0.99977, + 0.99977, 1.00022, 1.00022, 1.00022, 1.00022, 1.00022, 1.00003, 1.00022, + 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, 1.00001, 1.00026, 0.99973, + 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99982, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 1.0006, 1.0006, 1.0006, 1.0006, 1.00026, 1.00026, + 1.00026, 1.00026, 1.00026, 1.00026, 1.00026, 1.06409, 1.00026, 1.00026, + 1.00026, 1.00026, 1.00026, 0.99973, 1.00026, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 1.0044, 0.99977, 1.00026, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, + 1.00001, 0.99973, 1.00022, 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, + 1.00022, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 1.0006, 1.0006, + 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 1.0006, 0.99971, + 0.99973, 0.99973, 1.0006, 0.99977, 0.99973, 0.99973, 1.00026, 1.0006, + 1.00026, 1.0006, 1.00026, 1.01011, 1.00026, 0.99999, 1.00026, 1.0006, + 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 0.9993, 0.9998, + 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, 1.00022, 1.00026, 1, 1.00016, + 0.99977, 0.99959, 0.99977, 0.99959, 0.99977, 0.99959, 1.00001, 0.99973, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00026, 0.99998, + 1.00026, 0.8121, 1.00026, 0.99998, 0.99977, 1.00026, 0.99977, 1.00026, + 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, 0.99977, 1.00026, + 1.00016, 1.00022, 1.00001, 0.99973, 1.00001, 1.00026, 1, 1.00026, 1, + 1.00026, 1, 1.0006, 0.99973, 0.99977, 0.99973, 1, 0.99982, 1.00022, 1.00026, + 1.00001, 0.99973, 1.00026, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, + 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99977, 1, + 1, 1.00026, 0.99969, 0.99972, 0.99981, 0.9998, 1.0006, 0.99977, 0.99977, + 1.00022, 0.91155, 1.00001, 1.00026, 0.99977, 1.00022, 1.0006, 0.99977, + 1.00001, 0.99999, 0.99977, 0.99966, 1.00022, 1.00032, 1.00001, 0.99944, + 1.00026, 1.00001, 0.99968, 1.00001, 1.00047, 1, 1.0006, 1.00001, 0.99981, + 1.00101, 1.00026, 1.0006, 0.99948, 0.99981, 1.00064, 0.99973, 0.99942, + 1.00101, 1.00061, 1.00026, 1.00069, 1.0006, 1.00014, 0.99973, 1.01322, + 0.99973, 1.00065, 1.00026, 1.00012, 0.99923, 1, 1.00064, 1.00076, 0.99948, + 1.00055, 1.00063, 1.00007, 0.99943, 1.0006, 0.99948, 1.00026, 0.99948, + 0.99943, 1.00001, 1.00001, 1.00029, 1.00038, 1.00035, 1.00001, 1.0006, + 1.0006, 0.99973, 0.99978, 1.00001, 1.00057, 0.99989, 0.99967, 0.99964, + 0.99967, 0.99977, 0.99999, 0.99977, 1.00038, 0.99977, 1.00001, 0.99973, + 1.00066, 0.99967, 0.99967, 1.00041, 0.99998, 0.99999, 0.99977, 1.00022, + 0.99967, 1.00001, 0.99977, 1.00026, 0.99964, 1.00031, 1.00001, 0.99999, + 0.99999, 1, 1.00023, 1, 1, 0.99999, 1.00035, 1.00001, 0.99999, 0.99973, + 0.99977, 0.99999, 1.00058, 0.99973, 0.99973, 0.99955, 0.9995, 1.00026, + 1.00026, 1.00032, 0.99989, 1.00034, 0.99999, 1.00026, 1.00026, 1.00026, + 0.99973, 0.45998, 0.99973, 1.00026, 0.99973, 1.00001, 0.99999, 0.99982, + 0.99994, 0.99996, 1, 1.00042, 1.00044, 1.00029, 1.00023, 0.99973, 0.99973, + 1.00026, 0.99949, 1.00002, 0.99973, 1.0006, 1.0006, 1.0006, 0.99975, + 1.00026, 1.00026, 1.00032, 0.98685, 0.99973, 1.00026, 1, 1, 0.99966, + 1.00044, 1.00016, 1.00022, 1.00016, 1.00022, 1.00016, 1.00022, 1.00001, + 0.99973, 1, 1, 0.99973, 1, 1, 0.99955, 1.0006, 1.0006, 1.0006, 1.0006, 1, 1, + 1, 0.99973, 0.99973, 0.99972, 1, 1, 1.00106, 0.99999, 0.99998, 0.99998, + 0.99999, 0.99998, 1.66475, 1, 0.99973, 0.99973, 1, 0.99973, 0.99971, + 0.99978, 1, 1, 0.99991, 0.99984, 1.00002, 1.00002, 1.00002, 1.00002, + 1.00098, 1, 1, 1, 1.00049, 1, 1, 0.99972, 1, 1.20985, 1.39713, 1.00003, + 1.00031, 1.00015, 1, 0.99561, 1.00027, 1.00031, 1.00031, 0.99915, 1.00031, + 1.00031, 0.99999, 1.00003, 0.99999, 0.99999, 1.41144, 1.6, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.40579, 1.40579, 1.36625, 0.99999, 1, 0.99861, 0.99861, 1, + 1.00026, 1.00026, 1.00026, 1.00026, 0.99972, 0.99999, 0.99999, 0.99999, + 0.99999, 1.40483, 1, 0.99977, 1.00054, 1, 1, 0.99953, 0.99962, 1.00042, + 0.9995, 1, 1, 1, 1, 1, 1, 1, 1, 0.99998, 0.99998, 0.99998, 0.99998, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, + ], + Xi = { lineHeight: 1.35, lineGap: 0.2 }, + qi = [ + 0.76116, 1, 1, 1.0006, 1.0006, 1.00006, 0.99973, 0.99973, 0.99982, 1.00001, + 1.00043, 0.99998, 0.99998, 0.99959, 1.00003, 1.0006, 0.99998, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 1.0006, 1, 1.00003, 1.00003, 1.00003, 0.99973, + 0.99987, 1.00001, 1.00001, 0.99977, 0.99977, 1.00001, 1.00026, 1.00022, + 0.99977, 1.0006, 1, 1.00001, 0.99973, 0.99999, 0.99977, 1.00022, 1.00001, + 1.00022, 0.99977, 1.00001, 1.00026, 0.99977, 1.00001, 1.00016, 1.00001, + 1.00001, 1.00026, 1.0006, 1.0006, 1.0006, 0.99949, 0.99973, 0.99998, + 0.99973, 0.99973, 1, 0.99973, 0.99973, 1.0006, 0.99973, 0.99973, 0.99924, + 0.99924, 1, 0.99924, 0.99999, 0.99973, 0.99973, 0.99973, 0.99973, 0.99998, + 1, 1.0006, 0.99973, 1, 0.99977, 1, 1, 1, 1.00005, 1.0009, 1.00005, 1.00003, + 0.99998, 0.99973, 0.99973, 0.99973, 0.99973, 1.0009, 0.99973, 0.99998, + 1.00025, 0.99968, 0.99973, 1.00003, 1.00025, 0.60299, 1.00024, 1.06409, 1, + 1, 0.99998, 1, 0.9998, 1.0006, 0.99998, 1, 0.99936, 0.99973, 1.00002, + 1.00002, 1.00002, 1.00026, 1.00001, 1.00001, 1.00001, 1.00001, 1.00001, + 1.00001, 1, 0.99977, 1.00001, 1.00001, 1.00001, 1.00001, 1.0006, 1.0006, + 1.0006, 1.0006, 0.99977, 0.99977, 1.00022, 1.00022, 1.00022, 1.00022, + 1.00022, 1.00003, 1.00022, 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, + 1.00001, 1.00026, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99982, 1, 0.99973, 0.99973, 0.99973, 0.99973, 1.0006, 1.0006, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 1.06409, 1.00026, 0.99973, 0.99973, 0.99973, 0.99973, 1, 0.99973, 1, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 0.99977, 1, 0.99977, + 1, 0.99977, 1, 0.99977, 1, 0.99977, 1.0288, 0.99977, 0.99973, 1.00001, + 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, + 0.99973, 1.00022, 0.99973, 1.00022, 0.99973, 1.00022, 0.99973, 1.00022, + 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 1.0006, 1.0006, 1.0006, 1.0006, + 1.0006, 1.0006, 1.0006, 0.99924, 1.0006, 1.0006, 0.99946, 1.00034, 1, + 0.99924, 1.00001, 1, 1, 0.99973, 0.99924, 0.99973, 0.99924, 0.99973, + 1.06311, 0.99973, 1.00024, 0.99973, 0.99924, 0.99977, 0.99973, 0.99977, + 0.99973, 0.99977, 0.99973, 1.00041, 0.9998, 0.99973, 1.00022, 0.99973, + 1.00022, 0.99973, 1.00022, 0.99973, 1, 1.00016, 0.99977, 0.99998, 0.99977, + 0.99998, 0.99977, 0.99998, 1.00001, 1, 1.00001, 1, 1.00001, 1, 1.00001, 1, + 1.00026, 1.0006, 1.00026, 0.89547, 1.00026, 1.0006, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 1.00016, 0.99977, 1.00001, 1, 1.00001, 1.00026, 1, + 1.00026, 1, 1.00026, 1, 0.99924, 0.99973, 1.00001, 0.99973, 1, 0.99982, + 1.00022, 1.00026, 1.00001, 1, 1.00026, 1.0006, 0.99998, 0.99998, 0.99998, + 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, + 1.00001, 1, 1.00054, 0.99977, 1.00084, 1.00007, 0.99973, 1.00013, 0.99924, + 1.00001, 1.00001, 0.99945, 0.91221, 1.00001, 1.00026, 0.99977, 1.00022, + 1.0006, 1.00001, 1.00001, 0.99999, 0.99977, 0.99933, 1.00022, 1.00054, + 1.00001, 1.00065, 1.00026, 1.00001, 1.0001, 1.00001, 1.00052, 1, 1.0006, + 1.00001, 0.99945, 0.99897, 0.99968, 0.99924, 1.00036, 0.99945, 0.99949, 1, + 1.0006, 0.99897, 0.99918, 0.99968, 0.99911, 0.99924, 1, 0.99962, 1.01487, 1, + 1.0005, 0.99973, 1.00012, 1.00043, 1, 0.99995, 0.99994, 1.00036, 0.99947, + 1.00019, 1.00063, 1.00025, 0.99924, 1.00036, 0.99973, 1.00036, 1.00025, + 1.00001, 1.00001, 1.00027, 1.0001, 1.00068, 1.00001, 1.0006, 1.0006, 1, + 1.00008, 0.99957, 0.99972, 0.9994, 0.99954, 0.99975, 1.00051, 1.00001, + 1.00019, 1.00001, 1.0001, 0.99986, 1.00001, 1.00001, 1.00038, 0.99954, + 0.99954, 0.9994, 1.00066, 0.99999, 0.99977, 1.00022, 1.00054, 1.00001, + 0.99977, 1.00026, 0.99975, 1.0001, 1.00001, 0.99993, 0.9995, 0.99955, + 1.00016, 0.99978, 0.99974, 1.00019, 1.00022, 0.99955, 1.00053, 0.99973, + 1.00089, 1.00005, 0.99967, 1.00048, 0.99973, 1.00002, 1.00034, 0.99973, + 0.99973, 0.99964, 1.00006, 1.00066, 0.99947, 0.99973, 0.98894, 0.99973, 1, + 0.44898, 1, 0.99946, 1, 1.00039, 1.00082, 0.99991, 0.99991, 0.99985, + 1.00022, 1.00023, 1.00061, 1.00006, 0.99966, 0.99973, 0.99973, 0.99973, + 1.00019, 1.0008, 1, 0.99924, 0.99924, 0.99924, 0.99983, 1.00044, 0.99973, + 0.99964, 0.98332, 1, 0.99973, 1, 1, 0.99962, 0.99895, 1.00016, 0.99977, + 1.00016, 0.99977, 1.00016, 0.99977, 1.00001, 1, 1, 1, 0.99973, 1, 1, + 0.99955, 0.99924, 0.99924, 0.99924, 0.99924, 0.99998, 0.99998, 0.99998, + 0.99973, 0.99973, 0.99972, 1, 1, 1.00267, 0.99999, 0.99998, 0.99998, 1, + 0.99998, 1.66475, 1, 0.99973, 0.99973, 1.00023, 0.99973, 1.00423, 0.99925, + 0.99999, 1, 0.99991, 0.99984, 1.00002, 1.00002, 1.00002, 1.00002, 1.00049, + 1, 1.00245, 1, 1, 1, 1, 0.96329, 1, 1.20985, 1.39713, 1.00003, 0.8254, + 1.00015, 1, 1.00035, 1.00027, 1.00031, 1.00031, 1.00003, 1.00031, 1.00031, + 0.99999, 1.00003, 0.99999, 0.99999, 1.41144, 1.6, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.40579, 1.40579, 1.36625, 0.99999, 1, 0.99861, 0.99861, 1, 1.00026, + 1.00026, 1.00026, 1.00026, 0.95317, 0.99999, 0.99999, 0.99999, 0.99999, + 1.40483, 1, 0.99977, 1.00054, 1, 1, 0.99953, 0.99962, 1.00042, 0.9995, 1, 1, + 1, 1, 1, 1, 1, 1, 0.99998, 0.99998, 0.99998, 0.99998, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, + ], + Hi = { lineHeight: 1.35, lineGap: 0.2 }, + Wi = [ + 0.76116, 1, 1, 1.0006, 1.0006, 1.00006, 0.99973, 0.99973, 0.99982, 1.00001, + 1.00043, 0.99998, 0.99998, 0.99959, 1.00003, 1.0006, 0.99998, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99973, 0.99973, 0.99973, 1.0006, 1, 1.00003, 1.00003, 1.00003, 0.99973, + 0.99987, 1.00001, 1.00001, 0.99977, 0.99977, 1.00001, 1.00026, 1.00022, + 0.99977, 1.0006, 1, 1.00001, 0.99973, 0.99999, 0.99977, 1.00022, 1.00001, + 1.00022, 0.99977, 1.00001, 1.00026, 0.99977, 1.00001, 1.00016, 1.00001, + 1.00001, 1.00026, 1.0006, 1.0006, 1.0006, 0.99949, 0.99973, 0.99998, + 0.99973, 0.99973, 1, 0.99973, 0.99973, 1.0006, 0.99973, 0.99973, 0.99924, + 0.99924, 1, 0.99924, 0.99999, 0.99973, 0.99973, 0.99973, 0.99973, 0.99998, + 1, 1.0006, 0.99973, 1, 0.99977, 1, 1, 1, 1.00005, 1.0009, 1.00005, 1.00003, + 0.99998, 0.99973, 0.99973, 0.99973, 0.99973, 1.0009, 0.99973, 0.99998, + 1.00025, 0.99968, 0.99973, 1.00003, 1.00025, 0.60299, 1.00024, 1.06409, 1, + 1, 0.99998, 1, 0.9998, 1.0006, 0.99998, 1, 0.99936, 0.99973, 1.00002, + 1.00002, 1.00002, 1.00026, 1.00001, 1.00001, 1.00001, 1.00001, 1.00001, + 1.00001, 1, 0.99977, 1.00001, 1.00001, 1.00001, 1.00001, 1.0006, 1.0006, + 1.0006, 1.0006, 0.99977, 0.99977, 1.00022, 1.00022, 1.00022, 1.00022, + 1.00022, 1.00003, 1.00022, 0.99977, 0.99977, 0.99977, 0.99977, 1.00001, + 1.00001, 1.00026, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 0.99982, 1, 0.99973, 0.99973, 0.99973, 0.99973, 1.0006, 1.0006, 1.0006, + 1.0006, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, + 1.06409, 1.00026, 0.99973, 0.99973, 0.99973, 0.99973, 1, 0.99973, 1, + 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 0.99977, 1, 0.99977, + 1, 0.99977, 1, 0.99977, 1, 0.99977, 1.04596, 0.99977, 0.99973, 1.00001, + 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, 0.99973, 1.00001, + 0.99973, 1.00022, 0.99973, 1.00022, 0.99973, 1.00022, 0.99973, 1.00022, + 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 1.0006, 1.0006, 1.0006, 1.0006, + 1.0006, 1.0006, 1.0006, 0.99924, 1.0006, 1.0006, 1.00019, 1.00034, 1, + 0.99924, 1.00001, 1, 1, 0.99973, 0.99924, 0.99973, 0.99924, 0.99973, + 1.02572, 0.99973, 1.00005, 0.99973, 0.99924, 0.99977, 0.99973, 0.99977, + 0.99973, 0.99977, 0.99973, 0.99999, 0.9998, 0.99973, 1.00022, 0.99973, + 1.00022, 0.99973, 1.00022, 0.99973, 1, 1.00016, 0.99977, 0.99998, 0.99977, + 0.99998, 0.99977, 0.99998, 1.00001, 1, 1.00001, 1, 1.00001, 1, 1.00001, 1, + 1.00026, 1.0006, 1.00026, 0.84533, 1.00026, 1.0006, 0.99977, 0.99973, + 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, 0.99977, 0.99973, + 0.99977, 0.99973, 1.00016, 0.99977, 1.00001, 1, 1.00001, 1.00026, 1, + 1.00026, 1, 1.00026, 1, 0.99924, 0.99973, 1.00001, 0.99973, 1, 0.99982, + 1.00022, 1.00026, 1.00001, 1, 1.00026, 1.0006, 0.99998, 0.99998, 0.99998, + 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, 0.99998, + 0.99928, 1, 0.99977, 1.00013, 1.00055, 0.99947, 0.99945, 0.99941, 0.99924, + 1.00001, 1.00001, 1.0004, 0.91621, 1.00001, 1.00026, 0.99977, 1.00022, + 1.0006, 1.00001, 1.00005, 0.99999, 0.99977, 1.00015, 1.00022, 0.99977, + 1.00001, 0.99973, 1.00026, 1.00001, 1.00019, 1.00001, 0.99946, 1, 1.0006, + 1.00001, 0.99978, 1.00045, 0.99973, 0.99924, 1.00023, 0.99978, 0.99966, 1, + 1.00065, 1.00045, 1.00019, 0.99973, 0.99973, 0.99924, 1, 1, 0.96499, 1, + 1.00055, 0.99973, 1.00008, 1.00027, 1, 0.9997, 0.99995, 1.00023, 0.99933, + 1.00019, 1.00015, 1.00031, 0.99924, 1.00023, 0.99973, 1.00023, 1.00031, + 1.00001, 0.99928, 1.00029, 1.00092, 1.00035, 1.00001, 1.0006, 1.0006, 1, + 0.99988, 0.99975, 1, 1.00082, 0.99561, 0.9996, 1.00035, 1.00001, 0.99962, + 1.00001, 1.00092, 0.99964, 1.00001, 0.99963, 0.99999, 1.00035, 1.00035, + 1.00082, 0.99962, 0.99999, 0.99977, 1.00022, 1.00035, 1.00001, 0.99977, + 1.00026, 0.9996, 0.99967, 1.00001, 1.00034, 1.00074, 1.00054, 1.00053, + 1.00063, 0.99971, 0.99962, 1.00035, 0.99975, 0.99977, 0.99973, 1.00043, + 0.99953, 1.0007, 0.99915, 0.99973, 1.00008, 0.99892, 1.00073, 1.00073, + 1.00114, 0.99915, 1.00073, 0.99955, 0.99973, 1.00092, 0.99973, 1, 0.99998, + 1, 1.0003, 1, 1.00043, 1.00001, 0.99969, 1.0003, 1, 1.00035, 1.00001, + 0.9995, 1, 1.00092, 0.99973, 0.99973, 0.99973, 1.0007, 0.9995, 1, 0.99924, + 1.0006, 0.99924, 0.99972, 1.00062, 0.99973, 1.00114, 1.00073, 1, 0.99955, 1, + 1, 1.00047, 0.99968, 1.00016, 0.99977, 1.00016, 0.99977, 1.00016, 0.99977, + 1.00001, 1, 1, 1, 0.99973, 1, 1, 0.99955, 0.99924, 0.99924, 0.99924, + 0.99924, 0.99998, 0.99998, 0.99998, 0.99973, 0.99973, 0.99972, 1, 1, + 1.00267, 0.99999, 0.99998, 0.99998, 1, 0.99998, 1.66475, 1, 0.99973, + 0.99973, 1.00023, 0.99973, 0.99971, 0.99925, 1.00023, 1, 0.99991, 0.99984, + 1.00002, 1.00002, 1.00002, 1.00002, 1, 1, 1, 1, 1, 1, 1, 0.96329, 1, + 1.20985, 1.39713, 1.00003, 0.8254, 1.00015, 1, 1.00035, 1.00027, 1.00031, + 1.00031, 0.99915, 1.00031, 1.00031, 0.99999, 1.00003, 0.99999, 0.99999, + 1.41144, 1.6, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, 1.41144, + 1.41144, 1.41144, 1.41144, 1.41144, 1.40579, 1.40579, 1.36625, 0.99999, 1, + 0.99861, 0.99861, 1, 1.00026, 1.00026, 1.00026, 1.00026, 0.95317, 0.99999, + 0.99999, 0.99999, 0.99999, 1.40483, 1, 0.99977, 1.00054, 1, 1, 0.99953, + 0.99962, 1.00042, 0.9995, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, + ], + zi = { lineHeight: 1.2, lineGap: 0.2 }, + $i = [ + 365, 0, 333, 278, 333, 474, 556, 556, 889, 722, 238, 333, 333, 389, 584, + 278, 333, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 333, + 333, 584, 584, 584, 611, 975, 722, 722, 722, 722, 667, 611, 778, 722, 278, + 556, 722, 611, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, + 667, 611, 333, 278, 333, 584, 556, 333, 556, 611, 556, 611, 556, 333, 611, + 611, 278, 278, 556, 278, 889, 611, 611, 611, 611, 389, 556, 333, 611, 556, + 778, 556, 556, 500, 389, 280, 389, 584, 333, 556, 556, 556, 556, 280, 556, + 333, 737, 370, 556, 584, 737, 552, 400, 549, 333, 333, 333, 576, 556, 278, + 333, 333, 365, 556, 834, 834, 834, 611, 722, 722, 722, 722, 722, 722, 1e3, + 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, + 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, + 556, 889, 556, 556, 556, 556, 556, 278, 278, 278, 278, 611, 611, 611, 611, + 611, 611, 611, 549, 611, 611, 611, 611, 611, 556, 611, 556, 722, 556, 722, + 556, 722, 556, 722, 556, 722, 556, 722, 556, 722, 556, 722, 719, 722, 611, + 667, 556, 667, 556, 667, 556, 667, 556, 667, 556, 778, 611, 778, 611, 778, + 611, 778, 611, 722, 611, 722, 611, 278, 278, 278, 278, 278, 278, 278, 278, + 278, 278, 785, 556, 556, 278, 722, 556, 556, 611, 278, 611, 278, 611, 385, + 611, 479, 611, 278, 722, 611, 722, 611, 722, 611, 708, 723, 611, 778, 611, + 778, 611, 778, 611, 1e3, 944, 722, 389, 722, 389, 722, 389, 667, 556, 667, + 556, 667, 556, 667, 556, 611, 333, 611, 479, 611, 333, 722, 611, 722, 611, + 722, 611, 722, 611, 722, 611, 722, 611, 944, 778, 667, 556, 667, 611, 500, + 611, 500, 611, 500, 278, 556, 722, 556, 1e3, 889, 778, 611, 667, 556, 611, + 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 465, 722, 333, 853, + 906, 474, 825, 927, 838, 278, 722, 722, 601, 719, 667, 611, 722, 778, 278, + 722, 667, 833, 722, 644, 778, 722, 667, 600, 611, 667, 821, 667, 809, 802, + 278, 667, 615, 451, 611, 278, 582, 615, 610, 556, 606, 475, 460, 611, 541, + 278, 558, 556, 612, 556, 445, 611, 766, 619, 520, 684, 446, 582, 715, 576, + 753, 845, 278, 582, 611, 582, 845, 667, 669, 885, 567, 711, 667, 278, 276, + 556, 1094, 1062, 875, 610, 722, 622, 719, 722, 719, 722, 567, 712, 667, 904, + 626, 719, 719, 610, 702, 833, 722, 778, 719, 667, 722, 611, 622, 854, 667, + 730, 703, 1005, 1019, 870, 979, 719, 711, 1031, 719, 556, 618, 615, 417, + 635, 556, 709, 497, 615, 615, 500, 635, 740, 604, 611, 604, 611, 556, 490, + 556, 875, 556, 615, 581, 833, 844, 729, 854, 615, 552, 854, 583, 556, 556, + 611, 417, 552, 556, 278, 281, 278, 969, 906, 611, 500, 615, 556, 604, 778, + 611, 487, 447, 944, 778, 944, 778, 944, 778, 667, 556, 333, 333, 556, 1e3, + 1e3, 552, 278, 278, 278, 278, 500, 500, 500, 556, 556, 350, 1e3, 1e3, 240, + 479, 333, 333, 604, 333, 167, 396, 556, 556, 1094, 556, 885, 489, 1115, 1e3, + 768, 600, 834, 834, 834, 834, 1e3, 500, 1e3, 500, 1e3, 500, 500, 494, 612, + 823, 713, 584, 549, 713, 979, 722, 274, 549, 549, 583, 549, 549, 604, 584, + 604, 604, 708, 625, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 729, 604, 604, 354, 354, 1e3, 990, 990, 990, 990, 494, + 604, 604, 604, 604, 354, 1021, 1052, 917, 750, 750, 531, 656, 594, 510, 500, + 750, 750, 611, 611, 333, 333, 333, 333, 333, 333, 333, 333, 222, 222, 333, + 333, 333, 333, 333, 333, 333, 333, + ], + Gi = [ + -1, -1, -1, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, + 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, + 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 121, 122, 123, 124, 125, 126, 161, 162, 163, 164, 165, 166, 167, + 168, 169, 170, 171, 172, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, + 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, + 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, + 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, + 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, + 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, + 289, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299, 300, 301, 302, 303, + 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, + 319, 320, 321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 331, 332, 333, + 334, 335, 336, 337, 338, 339, 340, 341, 342, 343, 344, 345, 346, 347, 348, + 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, + 364, 365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377, 378, + 379, 380, 381, 382, 383, 402, 506, 507, 508, 509, 510, 511, 536, 537, 538, + 539, 710, 711, 713, 728, 729, 730, 731, 732, 733, 900, 901, 902, 903, 904, + 905, 906, 908, 910, 911, 912, 913, 914, 915, 916, 917, 918, 919, 920, 921, + 922, 923, 924, 925, 926, 927, 928, 929, 931, 932, 933, 934, 935, 936, 937, + 938, 939, 940, 941, 942, 943, 944, 945, 946, 947, 948, 949, 950, 951, 952, + 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964, 965, 966, 967, + 968, 969, 970, 971, 972, 973, 974, 1024, 1025, 1026, 1027, 1028, 1029, 1030, + 1031, 1032, 1033, 1034, 1035, 1036, 1037, 1038, 1039, 1040, 1041, 1042, + 1043, 1044, 1045, 1046, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 1054, + 1055, 1056, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, + 1067, 1068, 1069, 1070, 1071, 1072, 1073, 1074, 1075, 1076, 1077, 1078, + 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086, 1087, 1088, 1089, 1090, + 1091, 1092, 1093, 1094, 1095, 1096, 1097, 1098, 1099, 1100, 1101, 1102, + 1103, 1104, 1105, 1106, 1107, 1108, 1109, 1110, 1111, 1112, 1113, 1114, + 1115, 1116, 1117, 1118, 1119, 1138, 1139, 1168, 1169, 7808, 7809, 7810, + 7811, 7812, 7813, 7922, 7923, 8208, 8209, 8211, 8212, 8213, 8215, 8216, + 8217, 8218, 8219, 8220, 8221, 8222, 8224, 8225, 8226, 8230, 8240, 8242, + 8243, 8249, 8250, 8252, 8254, 8260, 8319, 8355, 8356, 8359, 8364, 8453, + 8467, 8470, 8482, 8486, 8494, 8539, 8540, 8541, 8542, 8592, 8593, 8594, + 8595, 8596, 8597, 8616, 8706, 8710, 8719, 8721, 8722, 8730, 8734, 8735, + 8745, 8747, 8776, 8800, 8801, 8804, 8805, 8962, 8976, 8992, 8993, 9472, + 9474, 9484, 9488, 9492, 9496, 9500, 9508, 9516, 9524, 9532, 9552, 9553, + 9554, 9555, 9556, 9557, 9558, 9559, 9560, 9561, 9562, 9563, 9564, 9565, + 9566, 9567, 9568, 9569, 9570, 9571, 9572, 9573, 9574, 9575, 9576, 9577, + 9578, 9579, 9580, 9600, 9604, 9608, 9612, 9616, 9617, 9618, 9619, 9632, + 9633, 9642, 9643, 9644, 9650, 9658, 9660, 9668, 9674, 9675, 9679, 9688, + 9689, 9702, 9786, 9787, 9788, 9792, 9794, 9824, 9827, 9829, 9830, 9834, + 9835, 9836, 61441, 61442, 61445, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, + ], + Vi = [ + 365, 0, 333, 278, 333, 474, 556, 556, 889, 722, 238, 333, 333, 389, 584, + 278, 333, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 333, + 333, 584, 584, 584, 611, 975, 722, 722, 722, 722, 667, 611, 778, 722, 278, + 556, 722, 611, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, + 667, 611, 333, 278, 333, 584, 556, 333, 556, 611, 556, 611, 556, 333, 611, + 611, 278, 278, 556, 278, 889, 611, 611, 611, 611, 389, 556, 333, 611, 556, + 778, 556, 556, 500, 389, 280, 389, 584, 333, 556, 556, 556, 556, 280, 556, + 333, 737, 370, 556, 584, 737, 552, 400, 549, 333, 333, 333, 576, 556, 278, + 333, 333, 365, 556, 834, 834, 834, 611, 722, 722, 722, 722, 722, 722, 1e3, + 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, + 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, + 556, 889, 556, 556, 556, 556, 556, 278, 278, 278, 278, 611, 611, 611, 611, + 611, 611, 611, 549, 611, 611, 611, 611, 611, 556, 611, 556, 722, 556, 722, + 556, 722, 556, 722, 556, 722, 556, 722, 556, 722, 556, 722, 740, 722, 611, + 667, 556, 667, 556, 667, 556, 667, 556, 667, 556, 778, 611, 778, 611, 778, + 611, 778, 611, 722, 611, 722, 611, 278, 278, 278, 278, 278, 278, 278, 278, + 278, 278, 782, 556, 556, 278, 722, 556, 556, 611, 278, 611, 278, 611, 396, + 611, 479, 611, 278, 722, 611, 722, 611, 722, 611, 708, 723, 611, 778, 611, + 778, 611, 778, 611, 1e3, 944, 722, 389, 722, 389, 722, 389, 667, 556, 667, + 556, 667, 556, 667, 556, 611, 333, 611, 479, 611, 333, 722, 611, 722, 611, + 722, 611, 722, 611, 722, 611, 722, 611, 944, 778, 667, 556, 667, 611, 500, + 611, 500, 611, 500, 278, 556, 722, 556, 1e3, 889, 778, 611, 667, 556, 611, + 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 722, 333, 854, + 906, 473, 844, 930, 847, 278, 722, 722, 610, 671, 667, 611, 722, 778, 278, + 722, 667, 833, 722, 657, 778, 718, 667, 590, 611, 667, 822, 667, 829, 781, + 278, 667, 620, 479, 611, 278, 591, 620, 621, 556, 610, 479, 492, 611, 558, + 278, 566, 556, 603, 556, 450, 611, 712, 605, 532, 664, 409, 591, 704, 578, + 773, 834, 278, 591, 611, 591, 834, 667, 667, 886, 614, 719, 667, 278, 278, + 556, 1094, 1042, 854, 622, 719, 677, 719, 722, 708, 722, 614, 722, 667, 927, + 643, 719, 719, 615, 687, 833, 722, 778, 719, 667, 722, 611, 677, 781, 667, + 729, 708, 979, 989, 854, 1e3, 708, 719, 1042, 729, 556, 619, 604, 534, 618, + 556, 736, 510, 611, 611, 507, 622, 740, 604, 611, 611, 611, 556, 889, 556, + 885, 556, 646, 583, 889, 935, 707, 854, 594, 552, 865, 589, 556, 556, 611, + 469, 563, 556, 278, 278, 278, 969, 906, 611, 507, 619, 556, 611, 778, 611, + 575, 467, 944, 778, 944, 778, 944, 778, 667, 556, 333, 333, 556, 1e3, 1e3, + 552, 278, 278, 278, 278, 500, 500, 500, 556, 556, 350, 1e3, 1e3, 240, 479, + 333, 333, 604, 333, 167, 396, 556, 556, 1104, 556, 885, 516, 1146, 1e3, 768, + 600, 834, 834, 834, 834, 999, 500, 1e3, 500, 1e3, 500, 500, 494, 612, 823, + 713, 584, 549, 713, 979, 722, 274, 549, 549, 583, 549, 549, 604, 584, 604, + 604, 708, 625, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 729, 604, 604, 354, 354, 1e3, 990, 990, 990, 990, 494, 604, + 604, 604, 604, 354, 1021, 1052, 917, 750, 750, 531, 656, 594, 510, 500, 750, + 750, 611, 611, 333, 333, 333, 333, 333, 333, 333, 333, 222, 222, 333, 333, + 333, 333, 333, 333, 333, 333, + ], + Ki = [ + -1, -1, -1, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, + 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, + 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 121, 122, 123, 124, 125, 126, 161, 162, 163, 164, 165, 166, 167, + 168, 169, 170, 171, 172, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, + 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, + 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, + 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, + 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, + 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, + 289, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299, 300, 301, 302, 303, + 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, + 319, 320, 321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 331, 332, 333, + 334, 335, 336, 337, 338, 339, 340, 341, 342, 343, 344, 345, 346, 347, 348, + 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, + 364, 365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377, 378, + 379, 380, 381, 382, 383, 402, 506, 507, 508, 509, 510, 511, 536, 537, 538, + 539, 710, 711, 713, 728, 729, 730, 731, 732, 733, 900, 901, 902, 903, 904, + 905, 906, 908, 910, 911, 912, 913, 914, 915, 916, 917, 918, 919, 920, 921, + 922, 923, 924, 925, 926, 927, 928, 929, 931, 932, 933, 934, 935, 936, 937, + 938, 939, 940, 941, 942, 943, 944, 945, 946, 947, 948, 949, 950, 951, 952, + 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964, 965, 966, 967, + 968, 969, 970, 971, 972, 973, 974, 1024, 1025, 1026, 1027, 1028, 1029, 1030, + 1031, 1032, 1033, 1034, 1035, 1036, 1037, 1038, 1039, 1040, 1041, 1042, + 1043, 1044, 1045, 1046, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 1054, + 1055, 1056, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, + 1067, 1068, 1069, 1070, 1071, 1072, 1073, 1074, 1075, 1076, 1077, 1078, + 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086, 1087, 1088, 1089, 1090, + 1091, 1092, 1093, 1094, 1095, 1096, 1097, 1098, 1099, 1100, 1101, 1102, + 1103, 1104, 1105, 1106, 1107, 1108, 1109, 1110, 1111, 1112, 1113, 1114, + 1115, 1116, 1117, 1118, 1119, 1138, 1139, 1168, 1169, 7808, 7809, 7810, + 7811, 7812, 7813, 7922, 7923, 8208, 8209, 8211, 8212, 8213, 8215, 8216, + 8217, 8218, 8219, 8220, 8221, 8222, 8224, 8225, 8226, 8230, 8240, 8242, + 8243, 8249, 8250, 8252, 8254, 8260, 8319, 8355, 8356, 8359, 8364, 8453, + 8467, 8470, 8482, 8486, 8494, 8539, 8540, 8541, 8542, 8592, 8593, 8594, + 8595, 8596, 8597, 8616, 8706, 8710, 8719, 8721, 8722, 8730, 8734, 8735, + 8745, 8747, 8776, 8800, 8801, 8804, 8805, 8962, 8976, 8992, 8993, 9472, + 9474, 9484, 9488, 9492, 9496, 9500, 9508, 9516, 9524, 9532, 9552, 9553, + 9554, 9555, 9556, 9557, 9558, 9559, 9560, 9561, 9562, 9563, 9564, 9565, + 9566, 9567, 9568, 9569, 9570, 9571, 9572, 9573, 9574, 9575, 9576, 9577, + 9578, 9579, 9580, 9600, 9604, 9608, 9612, 9616, 9617, 9618, 9619, 9632, + 9633, 9642, 9643, 9644, 9650, 9658, 9660, 9668, 9674, 9675, 9679, 9688, + 9689, 9702, 9786, 9787, 9788, 9792, 9794, 9824, 9827, 9829, 9830, 9834, + 9835, 9836, 61441, 61442, 61445, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, + ], + Ji = [ + 365, 0, 333, 278, 278, 355, 556, 556, 889, 667, 191, 333, 333, 389, 584, + 278, 333, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 278, + 278, 584, 584, 584, 556, 1015, 667, 667, 722, 722, 667, 611, 778, 722, 278, + 500, 667, 556, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, + 667, 611, 278, 278, 278, 469, 556, 333, 556, 556, 500, 556, 556, 278, 556, + 556, 222, 222, 500, 222, 833, 556, 556, 556, 556, 333, 500, 278, 556, 500, + 722, 500, 500, 500, 334, 260, 334, 584, 333, 556, 556, 556, 556, 260, 556, + 333, 737, 370, 556, 584, 737, 552, 400, 549, 333, 333, 333, 576, 537, 278, + 333, 333, 365, 556, 834, 834, 834, 611, 667, 667, 667, 667, 667, 667, 1e3, + 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, + 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, + 556, 889, 500, 556, 556, 556, 556, 278, 278, 278, 278, 556, 556, 556, 556, + 556, 556, 556, 549, 611, 556, 556, 556, 556, 500, 556, 500, 667, 556, 667, + 556, 667, 556, 722, 500, 722, 500, 722, 500, 722, 500, 722, 625, 722, 556, + 667, 556, 667, 556, 667, 556, 667, 556, 667, 556, 778, 556, 778, 556, 778, + 556, 778, 556, 722, 556, 722, 556, 278, 278, 278, 278, 278, 278, 278, 222, + 278, 278, 733, 444, 500, 222, 667, 500, 500, 556, 222, 556, 222, 556, 281, + 556, 400, 556, 222, 722, 556, 722, 556, 722, 556, 615, 723, 556, 778, 556, + 778, 556, 778, 556, 1e3, 944, 722, 333, 722, 333, 722, 333, 667, 500, 667, + 500, 667, 500, 667, 500, 611, 278, 611, 354, 611, 278, 722, 556, 722, 556, + 722, 556, 722, 556, 722, 556, 722, 556, 944, 722, 667, 500, 667, 611, 500, + 611, 500, 611, 500, 222, 556, 667, 556, 1e3, 889, 778, 611, 667, 500, 611, + 278, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 667, 278, 789, + 846, 389, 794, 865, 775, 222, 667, 667, 570, 671, 667, 611, 722, 778, 278, + 667, 667, 833, 722, 648, 778, 725, 667, 600, 611, 667, 837, 667, 831, 761, + 278, 667, 570, 439, 555, 222, 550, 570, 571, 500, 556, 439, 463, 555, 542, + 222, 500, 492, 548, 500, 447, 556, 670, 573, 486, 603, 374, 550, 652, 546, + 728, 779, 222, 550, 556, 550, 779, 667, 667, 843, 544, 708, 667, 278, 278, + 500, 1066, 982, 844, 589, 715, 639, 724, 667, 651, 667, 544, 704, 667, 917, + 614, 715, 715, 589, 686, 833, 722, 778, 725, 667, 722, 611, 639, 795, 667, + 727, 673, 920, 923, 805, 886, 651, 694, 1022, 682, 556, 562, 522, 493, 553, + 556, 688, 465, 556, 556, 472, 564, 686, 550, 556, 556, 556, 500, 833, 500, + 835, 500, 572, 518, 830, 851, 621, 736, 526, 492, 752, 534, 556, 556, 556, + 378, 496, 500, 222, 222, 222, 910, 828, 556, 472, 565, 500, 556, 778, 556, + 492, 339, 944, 722, 944, 722, 944, 722, 667, 500, 333, 333, 556, 1e3, 1e3, + 552, 222, 222, 222, 222, 333, 333, 333, 556, 556, 350, 1e3, 1e3, 188, 354, + 333, 333, 500, 333, 167, 365, 556, 556, 1094, 556, 885, 323, 1083, 1e3, 768, + 600, 834, 834, 834, 834, 1e3, 500, 998, 500, 1e3, 500, 500, 494, 612, 823, + 713, 584, 549, 713, 979, 719, 274, 549, 549, 584, 549, 549, 604, 584, 604, + 604, 708, 625, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 729, 604, 604, 354, 354, 1e3, 990, 990, 990, 990, 494, 604, + 604, 604, 604, 354, 1021, 1052, 917, 750, 750, 531, 656, 594, 510, 500, 750, + 750, 500, 500, 333, 333, 333, 333, 333, 333, 333, 333, 222, 222, 294, 294, + 324, 324, 316, 328, 398, 285, + ], + Yi = [ + -1, -1, -1, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, + 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, + 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 121, 122, 123, 124, 125, 126, 161, 162, 163, 164, 165, 166, 167, + 168, 169, 170, 171, 172, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, + 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, + 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, + 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, + 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, + 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, + 289, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299, 300, 301, 302, 303, + 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, + 319, 320, 321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 331, 332, 333, + 334, 335, 336, 337, 338, 339, 340, 341, 342, 343, 344, 345, 346, 347, 348, + 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, + 364, 365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377, 378, + 379, 380, 381, 382, 383, 402, 506, 507, 508, 509, 510, 511, 536, 537, 538, + 539, 710, 711, 713, 728, 729, 730, 731, 732, 733, 900, 901, 902, 903, 904, + 905, 906, 908, 910, 911, 912, 913, 914, 915, 916, 917, 918, 919, 920, 921, + 922, 923, 924, 925, 926, 927, 928, 929, 931, 932, 933, 934, 935, 936, 937, + 938, 939, 940, 941, 942, 943, 944, 945, 946, 947, 948, 949, 950, 951, 952, + 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964, 965, 966, 967, + 968, 969, 970, 971, 972, 973, 974, 1024, 1025, 1026, 1027, 1028, 1029, 1030, + 1031, 1032, 1033, 1034, 1035, 1036, 1037, 1038, 1039, 1040, 1041, 1042, + 1043, 1044, 1045, 1046, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 1054, + 1055, 1056, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, + 1067, 1068, 1069, 1070, 1071, 1072, 1073, 1074, 1075, 1076, 1077, 1078, + 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086, 1087, 1088, 1089, 1090, + 1091, 1092, 1093, 1094, 1095, 1096, 1097, 1098, 1099, 1100, 1101, 1102, + 1103, 1104, 1105, 1106, 1107, 1108, 1109, 1110, 1111, 1112, 1113, 1114, + 1115, 1116, 1117, 1118, 1119, 1138, 1139, 1168, 1169, 7808, 7809, 7810, + 7811, 7812, 7813, 7922, 7923, 8208, 8209, 8211, 8212, 8213, 8215, 8216, + 8217, 8218, 8219, 8220, 8221, 8222, 8224, 8225, 8226, 8230, 8240, 8242, + 8243, 8249, 8250, 8252, 8254, 8260, 8319, 8355, 8356, 8359, 8364, 8453, + 8467, 8470, 8482, 8486, 8494, 8539, 8540, 8541, 8542, 8592, 8593, 8594, + 8595, 8596, 8597, 8616, 8706, 8710, 8719, 8721, 8722, 8730, 8734, 8735, + 8745, 8747, 8776, 8800, 8801, 8804, 8805, 8962, 8976, 8992, 8993, 9472, + 9474, 9484, 9488, 9492, 9496, 9500, 9508, 9516, 9524, 9532, 9552, 9553, + 9554, 9555, 9556, 9557, 9558, 9559, 9560, 9561, 9562, 9563, 9564, 9565, + 9566, 9567, 9568, 9569, 9570, 9571, 9572, 9573, 9574, 9575, 9576, 9577, + 9578, 9579, 9580, 9600, 9604, 9608, 9612, 9616, 9617, 9618, 9619, 9632, + 9633, 9642, 9643, 9644, 9650, 9658, 9660, 9668, 9674, 9675, 9679, 9688, + 9689, 9702, 9786, 9787, 9788, 9792, 9794, 9824, 9827, 9829, 9830, 9834, + 9835, 9836, 61441, 61442, 61445, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, + ], + Zi = [ + 365, 0, 333, 278, 278, 355, 556, 556, 889, 667, 191, 333, 333, 389, 584, + 278, 333, 278, 278, 556, 556, 556, 556, 556, 556, 556, 556, 556, 556, 278, + 278, 584, 584, 584, 556, 1015, 667, 667, 722, 722, 667, 611, 778, 722, 278, + 500, 667, 556, 833, 722, 778, 667, 778, 722, 667, 611, 722, 667, 944, 667, + 667, 611, 278, 278, 278, 469, 556, 333, 556, 556, 500, 556, 556, 278, 556, + 556, 222, 222, 500, 222, 833, 556, 556, 556, 556, 333, 500, 278, 556, 500, + 722, 500, 500, 500, 334, 260, 334, 584, 333, 556, 556, 556, 556, 260, 556, + 333, 737, 370, 556, 584, 737, 552, 400, 549, 333, 333, 333, 576, 537, 278, + 333, 333, 365, 556, 834, 834, 834, 611, 667, 667, 667, 667, 667, 667, 1e3, + 722, 667, 667, 667, 667, 278, 278, 278, 278, 722, 722, 778, 778, 778, 778, + 778, 584, 778, 722, 722, 722, 722, 667, 667, 611, 556, 556, 556, 556, 556, + 556, 889, 500, 556, 556, 556, 556, 278, 278, 278, 278, 556, 556, 556, 556, + 556, 556, 556, 549, 611, 556, 556, 556, 556, 500, 556, 500, 667, 556, 667, + 556, 667, 556, 722, 500, 722, 500, 722, 500, 722, 500, 722, 615, 722, 556, + 667, 556, 667, 556, 667, 556, 667, 556, 667, 556, 778, 556, 778, 556, 778, + 556, 778, 556, 722, 556, 722, 556, 278, 278, 278, 278, 278, 278, 278, 222, + 278, 278, 735, 444, 500, 222, 667, 500, 500, 556, 222, 556, 222, 556, 292, + 556, 334, 556, 222, 722, 556, 722, 556, 722, 556, 604, 723, 556, 778, 556, + 778, 556, 778, 556, 1e3, 944, 722, 333, 722, 333, 722, 333, 667, 500, 667, + 500, 667, 500, 667, 500, 611, 278, 611, 375, 611, 278, 722, 556, 722, 556, + 722, 556, 722, 556, 722, 556, 722, 556, 944, 722, 667, 500, 667, 611, 500, + 611, 500, 611, 500, 222, 556, 667, 556, 1e3, 889, 778, 611, 667, 500, 611, + 278, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, 667, 278, 784, + 838, 384, 774, 855, 752, 222, 667, 667, 551, 668, 667, 611, 722, 778, 278, + 667, 668, 833, 722, 650, 778, 722, 667, 618, 611, 667, 798, 667, 835, 748, + 278, 667, 578, 446, 556, 222, 547, 578, 575, 500, 557, 446, 441, 556, 556, + 222, 500, 500, 576, 500, 448, 556, 690, 569, 482, 617, 395, 547, 648, 525, + 713, 781, 222, 547, 556, 547, 781, 667, 667, 865, 542, 719, 667, 278, 278, + 500, 1057, 1010, 854, 583, 722, 635, 719, 667, 656, 667, 542, 677, 667, 923, + 604, 719, 719, 583, 656, 833, 722, 778, 719, 667, 722, 611, 635, 760, 667, + 740, 667, 917, 938, 792, 885, 656, 719, 1010, 722, 556, 573, 531, 365, 583, + 556, 669, 458, 559, 559, 438, 583, 688, 552, 556, 542, 556, 500, 458, 500, + 823, 500, 573, 521, 802, 823, 625, 719, 521, 510, 750, 542, 556, 556, 556, + 365, 510, 500, 222, 278, 222, 906, 812, 556, 438, 559, 500, 552, 778, 556, + 489, 411, 944, 722, 944, 722, 944, 722, 667, 500, 333, 333, 556, 1e3, 1e3, + 552, 222, 222, 222, 222, 333, 333, 333, 556, 556, 350, 1e3, 1e3, 188, 354, + 333, 333, 500, 333, 167, 365, 556, 556, 1094, 556, 885, 323, 1073, 1e3, 768, + 600, 834, 834, 834, 834, 1e3, 500, 1e3, 500, 1e3, 500, 500, 494, 612, 823, + 713, 584, 549, 713, 979, 719, 274, 549, 549, 583, 549, 549, 604, 584, 604, + 604, 708, 625, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, 708, + 708, 708, 708, 729, 604, 604, 354, 354, 1e3, 990, 990, 990, 990, 494, 604, + 604, 604, 604, 354, 1021, 1052, 917, 750, 750, 531, 656, 594, 510, 500, 750, + 750, 500, 500, 333, 333, 333, 333, 333, 333, 333, 333, 222, 222, 294, 294, + 324, 324, 316, 328, 398, 285, + ], + Qi = [ + -1, -1, -1, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, + 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, + 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 121, 122, 123, 124, 125, 126, 161, 162, 163, 164, 165, 166, 167, + 168, 169, 170, 171, 172, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, + 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, + 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, + 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, + 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, + 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286, 287, 288, + 289, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299, 300, 301, 302, 303, + 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, + 319, 320, 321, 322, 323, 324, 325, 326, 327, 328, 329, 330, 331, 332, 333, + 334, 335, 336, 337, 338, 339, 340, 341, 342, 343, 344, 345, 346, 347, 348, + 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, + 364, 365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377, 378, + 379, 380, 381, 382, 383, 402, 506, 507, 508, 509, 510, 511, 536, 537, 538, + 539, 710, 711, 713, 728, 729, 730, 731, 732, 733, 900, 901, 902, 903, 904, + 905, 906, 908, 910, 911, 912, 913, 914, 915, 916, 917, 918, 919, 920, 921, + 922, 923, 924, 925, 926, 927, 928, 929, 931, 932, 933, 934, 935, 936, 937, + 938, 939, 940, 941, 942, 943, 944, 945, 946, 947, 948, 949, 950, 951, 952, + 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964, 965, 966, 967, + 968, 969, 970, 971, 972, 973, 974, 1024, 1025, 1026, 1027, 1028, 1029, 1030, + 1031, 1032, 1033, 1034, 1035, 1036, 1037, 1038, 1039, 1040, 1041, 1042, + 1043, 1044, 1045, 1046, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 1054, + 1055, 1056, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, + 1067, 1068, 1069, 1070, 1071, 1072, 1073, 1074, 1075, 1076, 1077, 1078, + 1079, 1080, 1081, 1082, 1083, 1084, 1085, 1086, 1087, 1088, 1089, 1090, + 1091, 1092, 1093, 1094, 1095, 1096, 1097, 1098, 1099, 1100, 1101, 1102, + 1103, 1104, 1105, 1106, 1107, 1108, 1109, 1110, 1111, 1112, 1113, 1114, + 1115, 1116, 1117, 1118, 1119, 1138, 1139, 1168, 1169, 7808, 7809, 7810, + 7811, 7812, 7813, 7922, 7923, 8208, 8209, 8211, 8212, 8213, 8215, 8216, + 8217, 8218, 8219, 8220, 8221, 8222, 8224, 8225, 8226, 8230, 8240, 8242, + 8243, 8249, 8250, 8252, 8254, 8260, 8319, 8355, 8356, 8359, 8364, 8453, + 8467, 8470, 8482, 8486, 8494, 8539, 8540, 8541, 8542, 8592, 8593, 8594, + 8595, 8596, 8597, 8616, 8706, 8710, 8719, 8721, 8722, 8730, 8734, 8735, + 8745, 8747, 8776, 8800, 8801, 8804, 8805, 8962, 8976, 8992, 8993, 9472, + 9474, 9484, 9488, 9492, 9496, 9500, 9508, 9516, 9524, 9532, 9552, 9553, + 9554, 9555, 9556, 9557, 9558, 9559, 9560, 9561, 9562, 9563, 9564, 9565, + 9566, 9567, 9568, 9569, 9570, 9571, 9572, 9573, 9574, 9575, 9576, 9577, + 9578, 9579, 9580, 9600, 9604, 9608, 9612, 9616, 9617, 9618, 9619, 9632, + 9633, 9642, 9643, 9644, 9650, 9658, 9660, 9668, 9674, 9675, 9679, 9688, + 9689, 9702, 9786, 9787, 9788, 9792, 9794, 9824, 9827, 9829, 9830, 9834, + 9835, 9836, 61441, 61442, 61445, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, + ], + en = [ + 1.36898, 1, 1, 0.72706, 0.80479, 0.83734, 0.98894, 0.99793, 0.9897, 0.93884, + 0.86209, 0.94292, 0.94292, 1.16661, 1.02058, 0.93582, 0.96694, 0.93582, + 1.19137, 0.99793, 0.99793, 0.99793, 0.99793, 0.99793, 0.99793, 0.99793, + 0.99793, 0.99793, 0.99793, 0.78076, 0.78076, 1.02058, 1.02058, 1.02058, + 0.72851, 0.78966, 0.90838, 0.83637, 0.82391, 0.96376, 0.80061, 0.86275, + 0.8768, 0.95407, 1.0258, 0.73901, 0.85022, 0.83655, 1.0156, 0.95546, + 0.92179, 0.87107, 0.92179, 0.82114, 0.8096, 0.89713, 0.94438, 0.95353, + 0.94083, 0.91905, 0.90406, 0.9446, 0.94292, 1.18777, 0.94292, 1.02058, + 0.89903, 0.90088, 0.94938, 0.97898, 0.81093, 0.97571, 0.94938, 1.024, + 0.9577, 0.95933, 0.98621, 1.0474, 0.97455, 0.98981, 0.9672, 0.95933, 0.9446, + 0.97898, 0.97407, 0.97646, 0.78036, 1.10208, 0.95442, 0.95298, 0.97579, + 0.9332, 0.94039, 0.938, 0.80687, 1.01149, 0.80687, 1.02058, 0.80479, + 0.99793, 0.99793, 0.99793, 0.99793, 1.01149, 1.00872, 0.90088, 0.91882, + 1.0213, 0.8361, 1.02058, 0.62295, 0.54324, 0.89022, 1.08595, 1, 1, 0.90088, + 1, 0.97455, 0.93582, 0.90088, 1, 1.05686, 0.8361, 0.99642, 0.99642, 0.99642, + 0.72851, 0.90838, 0.90838, 0.90838, 0.90838, 0.90838, 0.90838, 0.868, + 0.82391, 0.80061, 0.80061, 0.80061, 0.80061, 1.0258, 1.0258, 1.0258, 1.0258, + 0.97484, 0.95546, 0.92179, 0.92179, 0.92179, 0.92179, 0.92179, 1.02058, + 0.92179, 0.94438, 0.94438, 0.94438, 0.94438, 0.90406, 0.86958, 0.98225, + 0.94938, 0.94938, 0.94938, 0.94938, 0.94938, 0.94938, 0.9031, 0.81093, + 0.94938, 0.94938, 0.94938, 0.94938, 0.98621, 0.98621, 0.98621, 0.98621, + 0.93969, 0.95933, 0.9446, 0.9446, 0.9446, 0.9446, 0.9446, 1.08595, 0.9446, + 0.95442, 0.95442, 0.95442, 0.95442, 0.94039, 0.97898, 0.94039, 0.90838, + 0.94938, 0.90838, 0.94938, 0.90838, 0.94938, 0.82391, 0.81093, 0.82391, + 0.81093, 0.82391, 0.81093, 0.82391, 0.81093, 0.96376, 0.84313, 0.97484, + 0.97571, 0.80061, 0.94938, 0.80061, 0.94938, 0.80061, 0.94938, 0.80061, + 0.94938, 0.80061, 0.94938, 0.8768, 0.9577, 0.8768, 0.9577, 0.8768, 0.9577, + 1, 1, 0.95407, 0.95933, 0.97069, 0.95933, 1.0258, 0.98621, 1.0258, 0.98621, + 1.0258, 0.98621, 1.0258, 0.98621, 1.0258, 0.98621, 0.887, 1.01591, 0.73901, + 1.0474, 1, 1, 0.97455, 0.83655, 0.98981, 1, 1, 0.83655, 0.73977, 0.83655, + 0.73903, 0.84638, 1.033, 0.95546, 0.95933, 1, 1, 0.95546, 0.95933, 0.8271, + 0.95417, 0.95933, 0.92179, 0.9446, 0.92179, 0.9446, 0.92179, 0.9446, 0.936, + 0.91964, 0.82114, 0.97646, 1, 1, 0.82114, 0.97646, 0.8096, 0.78036, 0.8096, + 0.78036, 1, 1, 0.8096, 0.78036, 1, 1, 0.89713, 0.77452, 0.89713, 1.10208, + 0.94438, 0.95442, 0.94438, 0.95442, 0.94438, 0.95442, 0.94438, 0.95442, + 0.94438, 0.95442, 0.94438, 0.95442, 0.94083, 0.97579, 0.90406, 0.94039, + 0.90406, 0.9446, 0.938, 0.9446, 0.938, 0.9446, 0.938, 1, 0.99793, 0.90838, + 0.94938, 0.868, 0.9031, 0.92179, 0.9446, 1, 1, 0.89713, 1.10208, 0.90088, + 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, + 0.90989, 0.9358, 0.91945, 0.83181, 0.75261, 0.87992, 0.82976, 0.96034, + 0.83689, 0.97268, 1.0078, 0.90838, 0.83637, 0.8019, 0.90157, 0.80061, + 0.9446, 0.95407, 0.92436, 1.0258, 0.85022, 0.97153, 1.0156, 0.95546, + 0.89192, 0.92179, 0.92361, 0.87107, 0.96318, 0.89713, 0.93704, 0.95638, + 0.91905, 0.91709, 0.92796, 1.0258, 0.93704, 0.94836, 1.0373, 0.95933, + 1.0078, 0.95871, 0.94836, 0.96174, 0.92601, 0.9498, 0.98607, 0.95776, + 0.95933, 1.05453, 1.0078, 0.98275, 0.9314, 0.95617, 0.91701, 1.05993, + 0.9446, 0.78367, 0.9553, 1, 0.86832, 1.0128, 0.95871, 0.99394, 0.87548, + 0.96361, 0.86774, 1.0078, 0.95871, 0.9446, 0.95871, 0.86774, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.94083, + 0.97579, 0.94083, 0.97579, 0.94083, 0.97579, 0.90406, 0.94039, 0.96694, 1, + 0.89903, 1, 1, 1, 0.93582, 0.93582, 0.93582, 1, 0.908, 0.908, 0.918, + 0.94219, 0.94219, 0.96544, 1, 1.285, 1, 1, 0.81079, 0.81079, 1, 1, 0.74854, + 1, 1, 1, 1, 0.99793, 1, 1, 1, 0.65, 1, 1.36145, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1.17173, 1, 0.80535, 0.76169, 1.02058, 1.0732, 1.05486, 1, 1, 1.30692, + 1.08595, 1.08595, 1, 1.08595, 1.08595, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1.16161, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + tn = { lineHeight: 1.2, lineGap: 0.2 }, + an = [ + 1.36898, 1, 1, 0.66227, 0.80779, 0.81625, 0.97276, 0.97276, 0.97733, + 0.92222, 0.83266, 0.94292, 0.94292, 1.16148, 1.02058, 0.93582, 0.96694, + 0.93582, 1.17337, 0.97276, 0.97276, 0.97276, 0.97276, 0.97276, 0.97276, + 0.97276, 0.97276, 0.97276, 0.97276, 0.78076, 0.78076, 1.02058, 1.02058, + 1.02058, 0.71541, 0.76813, 0.85576, 0.80591, 0.80729, 0.94299, 0.77512, + 0.83655, 0.86523, 0.92222, 0.98621, 0.71743, 0.81698, 0.79726, 0.98558, + 0.92222, 0.90637, 0.83809, 0.90637, 0.80729, 0.76463, 0.86275, 0.90699, + 0.91605, 0.9154, 0.85308, 0.85458, 0.90531, 0.94292, 1.21296, 0.94292, + 1.02058, 0.89903, 1.18616, 0.99613, 0.91677, 0.78216, 0.91677, 0.90083, + 0.98796, 0.9135, 0.92168, 0.95381, 0.98981, 0.95298, 0.95381, 0.93459, + 0.92168, 0.91513, 0.92004, 0.91677, 0.95077, 0.748, 1.04502, 0.91677, + 0.92061, 0.94236, 0.89544, 0.89364, 0.9, 0.80687, 0.8578, 0.80687, 1.02058, + 0.80779, 0.97276, 0.97276, 0.97276, 0.97276, 0.8578, 0.99973, 1.18616, + 0.91339, 1.08074, 0.82891, 1.02058, 0.55509, 0.71526, 0.89022, 1.08595, 1, + 1, 1.18616, 1, 0.96736, 0.93582, 1.18616, 1, 1.04864, 0.82711, 0.99043, + 0.99043, 0.99043, 0.71541, 0.85576, 0.85576, 0.85576, 0.85576, 0.85576, + 0.85576, 0.845, 0.80729, 0.77512, 0.77512, 0.77512, 0.77512, 0.98621, + 0.98621, 0.98621, 0.98621, 0.95961, 0.92222, 0.90637, 0.90637, 0.90637, + 0.90637, 0.90637, 1.02058, 0.90251, 0.90699, 0.90699, 0.90699, 0.90699, + 0.85458, 0.83659, 0.94951, 0.99613, 0.99613, 0.99613, 0.99613, 0.99613, + 0.99613, 0.85811, 0.78216, 0.90083, 0.90083, 0.90083, 0.90083, 0.95381, + 0.95381, 0.95381, 0.95381, 0.9135, 0.92168, 0.91513, 0.91513, 0.91513, + 0.91513, 0.91513, 1.08595, 0.91677, 0.91677, 0.91677, 0.91677, 0.91677, + 0.89364, 0.92332, 0.89364, 0.85576, 0.99613, 0.85576, 0.99613, 0.85576, + 0.99613, 0.80729, 0.78216, 0.80729, 0.78216, 0.80729, 0.78216, 0.80729, + 0.78216, 0.94299, 0.76783, 0.95961, 0.91677, 0.77512, 0.90083, 0.77512, + 0.90083, 0.77512, 0.90083, 0.77512, 0.90083, 0.77512, 0.90083, 0.86523, + 0.9135, 0.86523, 0.9135, 0.86523, 0.9135, 1, 1, 0.92222, 0.92168, 0.92222, + 0.92168, 0.98621, 0.95381, 0.98621, 0.95381, 0.98621, 0.95381, 0.98621, + 0.95381, 0.98621, 0.95381, 0.86036, 0.97096, 0.71743, 0.98981, 1, 1, + 0.95298, 0.79726, 0.95381, 1, 1, 0.79726, 0.6894, 0.79726, 0.74321, 0.81691, + 1.0006, 0.92222, 0.92168, 1, 1, 0.92222, 0.92168, 0.79464, 0.92098, 0.92168, + 0.90637, 0.91513, 0.90637, 0.91513, 0.90637, 0.91513, 0.909, 0.87514, + 0.80729, 0.95077, 1, 1, 0.80729, 0.95077, 0.76463, 0.748, 0.76463, 0.748, 1, + 1, 0.76463, 0.748, 1, 1, 0.86275, 0.72651, 0.86275, 1.04502, 0.90699, + 0.91677, 0.90699, 0.91677, 0.90699, 0.91677, 0.90699, 0.91677, 0.90699, + 0.91677, 0.90699, 0.91677, 0.9154, 0.94236, 0.85458, 0.89364, 0.85458, + 0.90531, 0.9, 0.90531, 0.9, 0.90531, 0.9, 1, 0.97276, 0.85576, 0.99613, + 0.845, 0.85811, 0.90251, 0.91677, 1, 1, 0.86275, 1.04502, 1.18616, 1.18616, + 1.18616, 1.18616, 1.18616, 1.18616, 1.18616, 1.18616, 1.18616, 1.00899, + 1.30628, 0.85576, 0.80178, 0.66862, 0.7927, 0.69323, 0.88127, 0.72459, + 0.89711, 0.95381, 0.85576, 0.80591, 0.7805, 0.94729, 0.77512, 0.90531, + 0.92222, 0.90637, 0.98621, 0.81698, 0.92655, 0.98558, 0.92222, 0.85359, + 0.90637, 0.90976, 0.83809, 0.94523, 0.86275, 0.83509, 0.93157, 0.85308, + 0.83392, 0.92346, 0.98621, 0.83509, 0.92886, 0.91324, 0.92168, 0.95381, + 0.90646, 0.92886, 0.90557, 0.86847, 0.90276, 0.91324, 0.86842, 0.92168, + 0.99531, 0.95381, 0.9224, 0.85408, 0.92699, 0.86847, 1.0051, 0.91513, + 0.80487, 0.93481, 1, 0.88159, 1.05214, 0.90646, 0.97355, 0.81539, 0.89398, + 0.85923, 0.95381, 0.90646, 0.91513, 0.90646, 0.85923, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.9154, 0.94236, + 0.9154, 0.94236, 0.9154, 0.94236, 0.85458, 0.89364, 0.96694, 1, 0.89903, 1, + 1, 1, 0.91782, 0.91782, 0.91782, 1, 0.896, 0.896, 0.896, 0.9332, 0.9332, + 0.95973, 1, 1.26, 1, 1, 0.80479, 0.80178, 1, 1, 0.85633, 1, 1, 1, 1, + 0.97276, 1, 1, 1, 0.698, 1, 1.36145, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1.14542, 1, 0.79199, 0.78694, 1.02058, 1.03493, 1.05486, 1, 1, 1.23026, + 1.08595, 1.08595, 1, 1.08595, 1.08595, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1.20006, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + rn = { lineHeight: 1.2, lineGap: 0.2 }, + nn = [ + 1.36898, 1, 1, 0.65507, 0.84943, 0.85639, 0.88465, 0.88465, 0.86936, + 0.88307, 0.86948, 0.85283, 0.85283, 1.06383, 1.02058, 0.75945, 0.9219, + 0.75945, 1.17337, 0.88465, 0.88465, 0.88465, 0.88465, 0.88465, 0.88465, + 0.88465, 0.88465, 0.88465, 0.88465, 0.75945, 0.75945, 1.02058, 1.02058, + 1.02058, 0.69046, 0.70926, 0.85158, 0.77812, 0.76852, 0.89591, 0.70466, + 0.76125, 0.80094, 0.86822, 0.83864, 0.728, 0.77212, 0.79475, 0.93637, + 0.87514, 0.8588, 0.76013, 0.8588, 0.72421, 0.69866, 0.77598, 0.85991, + 0.80811, 0.87832, 0.78112, 0.77512, 0.8562, 1.0222, 1.18417, 1.0222, + 1.27014, 0.89903, 1.15012, 0.93859, 0.94399, 0.846, 0.94399, 0.81453, + 1.0186, 0.94219, 0.96017, 1.03075, 1.02175, 0.912, 1.03075, 0.96998, + 0.96017, 0.93859, 0.94399, 0.94399, 0.95493, 0.746, 1.12658, 0.94578, 0.91, + 0.979, 0.882, 0.882, 0.83, 0.85034, 0.83537, 0.85034, 1.02058, 0.70869, + 0.88465, 0.88465, 0.88465, 0.88465, 0.83537, 0.90083, 1.15012, 0.9161, + 0.94565, 0.73541, 1.02058, 0.53609, 0.69353, 0.79519, 1.08595, 1, 1, + 1.15012, 1, 0.91974, 0.75945, 1.15012, 1, 0.9446, 0.73361, 0.9005, 0.9005, + 0.9005, 0.62864, 0.85158, 0.85158, 0.85158, 0.85158, 0.85158, 0.85158, + 0.773, 0.76852, 0.70466, 0.70466, 0.70466, 0.70466, 0.83864, 0.83864, + 0.83864, 0.83864, 0.90561, 0.87514, 0.8588, 0.8588, 0.8588, 0.8588, 0.8588, + 1.02058, 0.85751, 0.85991, 0.85991, 0.85991, 0.85991, 0.77512, 0.76013, + 0.88075, 0.93859, 0.93859, 0.93859, 0.93859, 0.93859, 0.93859, 0.8075, + 0.846, 0.81453, 0.81453, 0.81453, 0.81453, 0.82424, 0.82424, 0.82424, + 0.82424, 0.9278, 0.96017, 0.93859, 0.93859, 0.93859, 0.93859, 0.93859, + 1.08595, 0.8562, 0.94578, 0.94578, 0.94578, 0.94578, 0.882, 0.94578, 0.882, + 0.85158, 0.93859, 0.85158, 0.93859, 0.85158, 0.93859, 0.76852, 0.846, + 0.76852, 0.846, 0.76852, 0.846, 0.76852, 0.846, 0.89591, 0.8544, 0.90561, + 0.94399, 0.70466, 0.81453, 0.70466, 0.81453, 0.70466, 0.81453, 0.70466, + 0.81453, 0.70466, 0.81453, 0.80094, 0.94219, 0.80094, 0.94219, 0.80094, + 0.94219, 1, 1, 0.86822, 0.96017, 0.86822, 0.96017, 0.83864, 0.82424, + 0.83864, 0.82424, 0.83864, 0.82424, 0.83864, 1.03075, 0.83864, 0.82424, + 0.81402, 1.02738, 0.728, 1.02175, 1, 1, 0.912, 0.79475, 1.03075, 1, 1, + 0.79475, 0.83911, 0.79475, 0.66266, 0.80553, 1.06676, 0.87514, 0.96017, 1, + 1, 0.87514, 0.96017, 0.86865, 0.87396, 0.96017, 0.8588, 0.93859, 0.8588, + 0.93859, 0.8588, 0.93859, 0.867, 0.84759, 0.72421, 0.95493, 1, 1, 0.72421, + 0.95493, 0.69866, 0.746, 0.69866, 0.746, 1, 1, 0.69866, 0.746, 1, 1, + 0.77598, 0.88417, 0.77598, 1.12658, 0.85991, 0.94578, 0.85991, 0.94578, + 0.85991, 0.94578, 0.85991, 0.94578, 0.85991, 0.94578, 0.85991, 0.94578, + 0.87832, 0.979, 0.77512, 0.882, 0.77512, 0.8562, 0.83, 0.8562, 0.83, 0.8562, + 0.83, 1, 0.88465, 0.85158, 0.93859, 0.773, 0.8075, 0.85751, 0.8562, 1, 1, + 0.77598, 1.12658, 1.15012, 1.15012, 1.15012, 1.15012, 1.15012, 1.15313, + 1.15012, 1.15012, 1.15012, 1.08106, 1.03901, 0.85158, 0.77025, 0.62264, + 0.7646, 0.65351, 0.86026, 0.69461, 0.89947, 1.03075, 0.85158, 0.77812, + 0.76449, 0.88836, 0.70466, 0.8562, 0.86822, 0.8588, 0.83864, 0.77212, + 0.85308, 0.93637, 0.87514, 0.82352, 0.8588, 0.85701, 0.76013, 0.89058, + 0.77598, 0.8156, 0.82565, 0.78112, 0.77899, 0.89386, 0.83864, 0.8156, + 0.9486, 0.92388, 0.96186, 1.03075, 0.91123, 0.9486, 0.93298, 0.878, 0.93942, + 0.92388, 0.84596, 0.96186, 0.95119, 1.03075, 0.922, 0.88787, 0.95829, 0.88, + 0.93559, 0.93859, 0.78815, 0.93758, 1, 0.89217, 1.03737, 0.91123, 0.93969, + 0.77487, 0.85769, 0.86799, 1.03075, 0.91123, 0.93859, 0.91123, 0.86799, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 0.87832, 0.979, 0.87832, 0.979, 0.87832, 0.979, 0.77512, 0.882, 0.9219, 1, + 0.89903, 1, 1, 1, 0.87321, 0.87321, 0.87321, 1, 1.027, 1.027, 1.027, + 0.86847, 0.86847, 0.79121, 1, 1.124, 1, 1, 0.73572, 0.73572, 1, 1, 0.85034, + 1, 1, 1, 1, 0.88465, 1, 1, 1, 0.669, 1, 1.36145, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1.04828, 1, 0.74948, 0.75187, 1.02058, 0.98391, 1.02119, 1, 1, + 1.06233, 1.08595, 1.08595, 1, 1.08595, 1.08595, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1.05233, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + sn = { lineHeight: 1.2, lineGap: 0.2 }, + on = [ + 1.36898, 1, 1, 0.76305, 0.82784, 0.94935, 0.89364, 0.92241, 0.89073, + 0.90706, 0.98472, 0.85283, 0.85283, 1.0664, 1.02058, 0.74505, 0.9219, + 0.74505, 1.23456, 0.92241, 0.92241, 0.92241, 0.92241, 0.92241, 0.92241, + 0.92241, 0.92241, 0.92241, 0.92241, 0.74505, 0.74505, 1.02058, 1.02058, + 1.02058, 0.73002, 0.72601, 0.91755, 0.8126, 0.80314, 0.92222, 0.73764, + 0.79726, 0.83051, 0.90284, 0.86023, 0.74, 0.8126, 0.84869, 0.96518, 0.91115, + 0.8858, 0.79761, 0.8858, 0.74498, 0.73914, 0.81363, 0.89591, 0.83659, + 0.89633, 0.85608, 0.8111, 0.90531, 1.0222, 1.22736, 1.0222, 1.27014, + 0.89903, 0.90088, 0.86667, 1.0231, 0.896, 1.01411, 0.90083, 1.05099, + 1.00512, 0.99793, 1.05326, 1.09377, 0.938, 1.06226, 1.00119, 0.99793, + 0.98714, 1.0231, 1.01231, 0.98196, 0.792, 1.19137, 0.99074, 0.962, 1.01915, + 0.926, 0.942, 0.856, 0.85034, 0.92006, 0.85034, 1.02058, 0.69067, 0.92241, + 0.92241, 0.92241, 0.92241, 0.92006, 0.9332, 0.90088, 0.91882, 0.93484, + 0.75339, 1.02058, 0.56866, 0.54324, 0.79519, 1.08595, 1, 1, 0.90088, 1, + 0.95325, 0.74505, 0.90088, 1, 0.97198, 0.75339, 0.91009, 0.91009, 0.91009, + 0.66466, 0.91755, 0.91755, 0.91755, 0.91755, 0.91755, 0.91755, 0.788, + 0.80314, 0.73764, 0.73764, 0.73764, 0.73764, 0.86023, 0.86023, 0.86023, + 0.86023, 0.92915, 0.91115, 0.8858, 0.8858, 0.8858, 0.8858, 0.8858, 1.02058, + 0.8858, 0.89591, 0.89591, 0.89591, 0.89591, 0.8111, 0.79611, 0.89713, + 0.86667, 0.86667, 0.86667, 0.86667, 0.86667, 0.86667, 0.86936, 0.896, + 0.90083, 0.90083, 0.90083, 0.90083, 0.84224, 0.84224, 0.84224, 0.84224, + 0.97276, 0.99793, 0.98714, 0.98714, 0.98714, 0.98714, 0.98714, 1.08595, + 0.89876, 0.99074, 0.99074, 0.99074, 0.99074, 0.942, 1.0231, 0.942, 0.91755, + 0.86667, 0.91755, 0.86667, 0.91755, 0.86667, 0.80314, 0.896, 0.80314, 0.896, + 0.80314, 0.896, 0.80314, 0.896, 0.92222, 0.93372, 0.92915, 1.01411, 0.73764, + 0.90083, 0.73764, 0.90083, 0.73764, 0.90083, 0.73764, 0.90083, 0.73764, + 0.90083, 0.83051, 1.00512, 0.83051, 1.00512, 0.83051, 1.00512, 1, 1, + 0.90284, 0.99793, 0.90976, 0.99793, 0.86023, 0.84224, 0.86023, 0.84224, + 0.86023, 0.84224, 0.86023, 1.05326, 0.86023, 0.84224, 0.82873, 1.07469, + 0.74, 1.09377, 1, 1, 0.938, 0.84869, 1.06226, 1, 1, 0.84869, 0.83704, + 0.84869, 0.81441, 0.85588, 1.08927, 0.91115, 0.99793, 1, 1, 0.91115, + 0.99793, 0.91887, 0.90991, 0.99793, 0.8858, 0.98714, 0.8858, 0.98714, + 0.8858, 0.98714, 0.894, 0.91434, 0.74498, 0.98196, 1, 1, 0.74498, 0.98196, + 0.73914, 0.792, 0.73914, 0.792, 1, 1, 0.73914, 0.792, 1, 1, 0.81363, 0.904, + 0.81363, 1.19137, 0.89591, 0.99074, 0.89591, 0.99074, 0.89591, 0.99074, + 0.89591, 0.99074, 0.89591, 0.99074, 0.89591, 0.99074, 0.89633, 1.01915, + 0.8111, 0.942, 0.8111, 0.90531, 0.856, 0.90531, 0.856, 0.90531, 0.856, 1, + 0.92241, 0.91755, 0.86667, 0.788, 0.86936, 0.8858, 0.89876, 1, 1, 0.81363, + 1.19137, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, 0.90088, + 0.90088, 0.90088, 0.90388, 1.03901, 0.92138, 0.78105, 0.7154, 0.86169, + 0.80513, 0.94007, 0.82528, 0.98612, 1.06226, 0.91755, 0.8126, 0.81884, + 0.92819, 0.73764, 0.90531, 0.90284, 0.8858, 0.86023, 0.8126, 0.91172, + 0.96518, 0.91115, 0.83089, 0.8858, 0.87791, 0.79761, 0.89297, 0.81363, + 0.88157, 0.89992, 0.85608, 0.81992, 0.94307, 0.86023, 0.88157, 0.95308, + 0.98699, 0.99793, 1.06226, 0.95817, 0.95308, 0.97358, 0.928, 0.98088, + 0.98699, 0.92761, 0.99793, 0.96017, 1.06226, 0.986, 0.944, 0.95978, 0.938, + 0.96705, 0.98714, 0.80442, 0.98972, 1, 0.89762, 1.04552, 0.95817, 0.99007, + 0.87064, 0.91879, 0.88888, 1.06226, 0.95817, 0.98714, 0.95817, 0.88888, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 0.89633, 1.01915, 0.89633, 1.01915, 0.89633, 1.01915, 0.8111, 0.942, 0.9219, + 1, 0.89903, 1, 1, 1, 0.93173, 0.93173, 0.93173, 1, 1.06304, 1.06304, + 1.06904, 0.89903, 0.89903, 0.80549, 1, 1.156, 1, 1, 0.76575, 0.76575, 1, 1, + 0.72458, 1, 1, 1, 1, 0.92241, 1, 1, 1, 0.619, 1, 1.36145, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1.07257, 1, 0.74705, 0.71119, 1.02058, 1.024, 1.02119, 1, 1, + 1.1536, 1.08595, 1.08595, 1, 1.08595, 1.08595, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1.05638, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + cn = { lineHeight: 1.2, lineGap: 0.2 }, + ln = [ + 1.76738, 1, 1, 0.99297, 0.9824, 1.04016, 1.06497, 1.03424, 0.97529, 1.17647, + 1.23203, 1.1085, 1.1085, 1.16939, 1.2107, 0.9754, 1.21408, 0.9754, 1.59578, + 1.03424, 1.03424, 1.03424, 1.03424, 1.03424, 1.03424, 1.03424, 1.03424, + 1.03424, 1.03424, 0.81378, 0.81378, 1.2107, 1.2107, 1.2107, 0.71703, + 0.97847, 0.97363, 0.88776, 0.8641, 1.02096, 0.79795, 0.85132, 0.914, + 1.06085, 1.1406, 0.8007, 0.89858, 0.83693, 1.14889, 1.09398, 0.97489, + 0.92094, 0.97489, 0.90399, 0.84041, 0.95923, 1.00135, 1, 1.06467, 0.98243, + 0.90996, 0.99361, 1.1085, 1.56942, 1.1085, 1.2107, 0.74627, 0.94282, + 0.96752, 1.01519, 0.86304, 1.01359, 0.97278, 1.15103, 1.01359, 0.98561, + 1.02285, 1.02285, 1.00527, 1.02285, 1.0302, 0.99041, 1.0008, 1.01519, + 1.01359, 1.02258, 0.79104, 1.16862, 0.99041, 0.97454, 1.02511, 0.99298, + 0.96752, 0.95801, 0.94856, 1.16579, 0.94856, 1.2107, 0.9824, 1.03424, + 1.03424, 1, 1.03424, 1.16579, 0.8727, 1.3871, 1.18622, 1.10818, 1.04478, + 1.2107, 1.18622, 0.75155, 0.94994, 1.28826, 1.21408, 1.21408, 0.91056, 1, + 0.91572, 0.9754, 0.64663, 1.18328, 1.24866, 1.04478, 1.14169, 1.15749, + 1.17389, 0.71703, 0.97363, 0.97363, 0.97363, 0.97363, 0.97363, 0.97363, + 0.93506, 0.8641, 0.79795, 0.79795, 0.79795, 0.79795, 1.1406, 1.1406, 1.1406, + 1.1406, 1.02096, 1.09398, 0.97426, 0.97426, 0.97426, 0.97426, 0.97426, + 1.2107, 0.97489, 1.00135, 1.00135, 1.00135, 1.00135, 0.90996, 0.92094, + 1.02798, 0.96752, 0.96752, 0.96752, 0.96752, 0.96752, 0.96752, 0.93136, + 0.86304, 0.97278, 0.97278, 0.97278, 0.97278, 1.02285, 1.02285, 1.02285, + 1.02285, 0.97122, 0.99041, 1, 1, 1, 1, 1, 1.28826, 1.0008, 0.99041, 0.99041, + 0.99041, 0.99041, 0.96752, 1.01519, 0.96752, 0.97363, 0.96752, 0.97363, + 0.96752, 0.97363, 0.96752, 0.8641, 0.86304, 0.8641, 0.86304, 0.8641, + 0.86304, 0.8641, 0.86304, 1.02096, 1.03057, 1.02096, 1.03517, 0.79795, + 0.97278, 0.79795, 0.97278, 0.79795, 0.97278, 0.79795, 0.97278, 0.79795, + 0.97278, 0.914, 1.01359, 0.914, 1.01359, 0.914, 1.01359, 1, 1, 1.06085, + 0.98561, 1.06085, 1.00879, 1.1406, 1.02285, 1.1406, 1.02285, 1.1406, + 1.02285, 1.1406, 1.02285, 1.1406, 1.02285, 0.97138, 1.08692, 0.8007, + 1.02285, 1, 1, 1.00527, 0.83693, 1.02285, 1, 1, 0.83693, 0.9455, 0.83693, + 0.90418, 0.83693, 1.13005, 1.09398, 0.99041, 1, 1, 1.09398, 0.99041, + 0.96692, 1.09251, 0.99041, 0.97489, 1.0008, 0.97489, 1.0008, 0.97489, + 1.0008, 0.93994, 0.97931, 0.90399, 1.02258, 1, 1, 0.90399, 1.02258, 0.84041, + 0.79104, 0.84041, 0.79104, 0.84041, 0.79104, 0.84041, 0.79104, 1, 1, + 0.95923, 1.07034, 0.95923, 1.16862, 1.00135, 0.99041, 1.00135, 0.99041, + 1.00135, 0.99041, 1.00135, 0.99041, 1.00135, 0.99041, 1.00135, 0.99041, + 1.06467, 1.02511, 0.90996, 0.96752, 0.90996, 0.99361, 0.95801, 0.99361, + 0.95801, 0.99361, 0.95801, 1.07733, 1.03424, 0.97363, 0.96752, 0.93506, + 0.93136, 0.97489, 1.0008, 1, 1, 0.95923, 1.16862, 1.15103, 1.15103, 1.01173, + 1.03959, 0.75953, 0.81378, 0.79912, 1.15103, 1.21994, 0.95161, 0.87815, + 1.01149, 0.81525, 0.7676, 0.98167, 1.01134, 1.02546, 0.84097, 1.03089, + 1.18102, 0.97363, 0.88776, 0.85134, 0.97826, 0.79795, 0.99361, 1.06085, + 0.97489, 1.1406, 0.89858, 1.0388, 1.14889, 1.09398, 0.86039, 0.97489, + 1.0595, 0.92094, 0.94793, 0.95923, 0.90996, 0.99346, 0.98243, 1.02112, + 0.95493, 1.1406, 0.90996, 1.03574, 1.02597, 1.0008, 1.18102, 1.06628, + 1.03574, 1.0192, 1.01932, 1.00886, 0.97531, 1.0106, 1.0008, 1.13189, + 1.18102, 1.02277, 0.98683, 1.0016, 0.99561, 1.07237, 1.0008, 0.90434, + 0.99921, 0.93803, 0.8965, 1.23085, 1.06628, 1.04983, 0.96268, 1.0499, + 0.98439, 1.18102, 1.06628, 1.0008, 1.06628, 0.98439, 0.79795, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1.09466, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 0.97278, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.02065, 1, 1, 1, 1, 1, 1, + 1.06467, 1.02511, 1.06467, 1.02511, 1.06467, 1.02511, 0.90996, 0.96752, 1, + 1.21408, 0.89903, 1, 1, 0.75155, 1.04394, 1.04394, 1.04394, 1.04394, + 0.98633, 0.98633, 0.98633, 0.73047, 0.73047, 1.20642, 0.91211, 1.25635, + 1.222, 1.02956, 1.03372, 1.03372, 0.96039, 1.24633, 1, 1.12454, 0.93503, + 1.03424, 1.19687, 1.03424, 1, 1, 1, 0.771, 1, 1, 1.15749, 1.15749, 1.15749, + 1.10948, 0.86279, 0.94434, 0.86279, 0.94434, 0.86182, 1, 1, 1.16897, 1, + 0.96085, 0.90137, 1.2107, 1.18416, 1.13973, 0.69825, 0.9716, 2.10339, + 1.29004, 1.29004, 1.21172, 1.29004, 1.29004, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.42603, 1, 0.99862, + 0.99862, 1, 0.87025, 0.87025, 0.87025, 0.87025, 1.18874, 1.42603, 1, + 1.42603, 1.42603, 0.99862, 1, 1, 1, 1, 1, 1.2886, 1.04315, 1.15296, 1.34163, + 1, 1, 1, 1.09193, 1.09193, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, + ], + hn = { lineHeight: 1.33008, lineGap: 0 }, + un = [ + 1.76738, 1, 1, 0.98946, 1.03959, 1.04016, 1.02809, 1.036, 0.97639, 1.10953, + 1.23203, 1.11144, 1.11144, 1.16939, 1.21237, 0.9754, 1.21261, 0.9754, + 1.59754, 1.036, 1.036, 1.036, 1.036, 1.036, 1.036, 1.036, 1.036, 1.036, + 1.036, 0.81378, 0.81378, 1.21237, 1.21237, 1.21237, 0.73541, 0.97847, + 0.97363, 0.89723, 0.87897, 1.0426, 0.79429, 0.85292, 0.91149, 1.05815, + 1.1406, 0.79631, 0.90128, 0.83853, 1.04396, 1.10615, 0.97552, 0.94436, + 0.97552, 0.88641, 0.80527, 0.96083, 1.00135, 1, 1.06777, 0.9817, 0.91142, + 0.99361, 1.11144, 1.57293, 1.11144, 1.21237, 0.74627, 1.31818, 1.06585, + 0.97042, 0.83055, 0.97042, 0.93503, 1.1261, 0.97042, 0.97922, 1.14236, + 0.94552, 1.01054, 1.14236, 1.02471, 0.97922, 0.94165, 0.97042, 0.97042, + 1.0276, 0.78929, 1.1261, 0.97922, 0.95874, 1.02197, 0.98507, 0.96752, + 0.97168, 0.95107, 1.16579, 0.95107, 1.21237, 1.03959, 1.036, 1.036, 1, + 1.036, 1.16579, 0.87357, 1.31818, 1.18754, 1.26781, 1.05356, 1.21237, + 1.18622, 0.79487, 0.94994, 1.29004, 1.24047, 1.24047, 1.31818, 1, 0.91484, + 0.9754, 1.31818, 1.1349, 1.24866, 1.05356, 1.13934, 1.15574, 1.17389, + 0.73541, 0.97363, 0.97363, 0.97363, 0.97363, 0.97363, 0.97363, 0.94385, + 0.87897, 0.79429, 0.79429, 0.79429, 0.79429, 1.1406, 1.1406, 1.1406, 1.1406, + 1.0426, 1.10615, 0.97552, 0.97552, 0.97552, 0.97552, 0.97552, 1.21237, + 0.97552, 1.00135, 1.00135, 1.00135, 1.00135, 0.91142, 0.94436, 0.98721, + 1.06585, 1.06585, 1.06585, 1.06585, 1.06585, 1.06585, 0.96705, 0.83055, + 0.93503, 0.93503, 0.93503, 0.93503, 1.14236, 1.14236, 1.14236, 1.14236, + 0.93125, 0.97922, 0.94165, 0.94165, 0.94165, 0.94165, 0.94165, 1.29004, + 0.94165, 0.97922, 0.97922, 0.97922, 0.97922, 0.96752, 0.97042, 0.96752, + 0.97363, 1.06585, 0.97363, 1.06585, 0.97363, 1.06585, 0.87897, 0.83055, + 0.87897, 0.83055, 0.87897, 0.83055, 0.87897, 0.83055, 1.0426, 1.0033, + 1.0426, 0.97042, 0.79429, 0.93503, 0.79429, 0.93503, 0.79429, 0.93503, + 0.79429, 0.93503, 0.79429, 0.93503, 0.91149, 0.97042, 0.91149, 0.97042, + 0.91149, 0.97042, 1, 1, 1.05815, 0.97922, 1.05815, 0.97922, 1.1406, 1.14236, + 1.1406, 1.14236, 1.1406, 1.14236, 1.1406, 1.14236, 1.1406, 1.14236, 0.97441, + 1.04302, 0.79631, 1.01582, 1, 1, 1.01054, 0.83853, 1.14236, 1, 1, 0.83853, + 1.09125, 0.83853, 0.90418, 0.83853, 1.19508, 1.10615, 0.97922, 1, 1, + 1.10615, 0.97922, 1.01034, 1.10466, 0.97922, 0.97552, 0.94165, 0.97552, + 0.94165, 0.97552, 0.94165, 0.91602, 0.91981, 0.88641, 1.0276, 1, 1, 0.88641, + 1.0276, 0.80527, 0.78929, 0.80527, 0.78929, 0.80527, 0.78929, 0.80527, + 0.78929, 1, 1, 0.96083, 1.05403, 0.95923, 1.16862, 1.00135, 0.97922, + 1.00135, 0.97922, 1.00135, 0.97922, 1.00135, 0.97922, 1.00135, 0.97922, + 1.00135, 0.97922, 1.06777, 1.02197, 0.91142, 0.96752, 0.91142, 0.99361, + 0.97168, 0.99361, 0.97168, 0.99361, 0.97168, 1.23199, 1.036, 0.97363, + 1.06585, 0.94385, 0.96705, 0.97552, 0.94165, 1, 1, 0.96083, 1.1261, 1.31818, + 1.31818, 1.31818, 1.31818, 1.31818, 1.31818, 1.31818, 1.31818, 1.31818, + 0.95161, 1.27126, 1.00811, 0.83284, 0.77702, 0.99137, 0.95253, 1.0347, + 0.86142, 1.07205, 1.14236, 0.97363, 0.89723, 0.86869, 1.09818, 0.79429, + 0.99361, 1.05815, 0.97552, 1.1406, 0.90128, 1.06662, 1.04396, 1.10615, + 0.84918, 0.97552, 1.04694, 0.94436, 0.98015, 0.96083, 0.91142, 1.00356, + 0.9817, 1.01945, 0.98999, 1.1406, 0.91142, 1.04961, 0.9898, 1.00639, + 1.14236, 1.07514, 1.04961, 0.99607, 1.02897, 1.008, 0.9898, 0.95134, + 1.00639, 1.11121, 1.14236, 1.00518, 0.97981, 1.02186, 1, 1.08578, 0.94165, + 0.99314, 0.98387, 0.93028, 0.93377, 1.35125, 1.07514, 1.10687, 0.93491, + 1.04232, 1.00351, 1.14236, 1.07514, 0.94165, 1.07514, 1.00351, 0.79429, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.09097, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 0.93503, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.96609, 1, 1, + 1, 1, 1, 1, 1.06777, 1.02197, 1.06777, 1.02197, 1.06777, 1.02197, 0.91142, + 0.96752, 1, 1.21261, 0.89903, 1, 1, 0.75155, 1.04745, 1.04745, 1.04745, + 1.04394, 0.98633, 0.98633, 0.98633, 0.72959, 0.72959, 1.20502, 0.91406, + 1.26514, 1.222, 1.02956, 1.03372, 1.03372, 0.96039, 1.24633, 1, 1.09125, + 0.93327, 1.03336, 1.16541, 1.036, 1, 1, 1, 0.771, 1, 1, 1.15574, 1.15574, + 1.15574, 1.15574, 0.86364, 0.94434, 0.86279, 0.94434, 0.86224, 1, 1, + 1.16798, 1, 0.96085, 0.90068, 1.21237, 1.18416, 1.13904, 0.69825, 0.9716, + 2.10339, 1.29004, 1.29004, 1.21339, 1.29004, 1.29004, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.42603, 1, + 0.99862, 0.99862, 1, 0.87025, 0.87025, 0.87025, 0.87025, 1.18775, 1.42603, + 1, 1.42603, 1.42603, 0.99862, 1, 1, 1, 1, 1, 1.2886, 1.04315, 1.15296, + 1.34163, 1, 1, 1, 1.13269, 1.13269, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, + ], + dn = { lineHeight: 1.33008, lineGap: 0 }, + fn = [ + 1.76738, 1, 1, 0.98946, 1.14763, 1.05365, 1.06234, 0.96927, 0.92586, + 1.15373, 1.18414, 0.91349, 0.91349, 1.07403, 1.17308, 0.78383, 1.20088, + 0.78383, 1.42531, 0.96927, 0.96927, 0.96927, 0.96927, 0.96927, 0.96927, + 0.96927, 0.96927, 0.96927, 0.96927, 0.78383, 0.78383, 1.17308, 1.17308, + 1.17308, 0.77349, 0.94565, 0.94729, 0.85944, 0.88506, 0.9858, 0.74817, + 0.80016, 0.88449, 0.98039, 0.95782, 0.69238, 0.89898, 0.83231, 0.98183, + 1.03989, 0.96924, 0.86237, 0.96924, 0.80595, 0.74524, 0.86091, 0.95402, + 0.94143, 0.98448, 0.8858, 0.83089, 0.93285, 1.0949, 1.39016, 1.0949, + 1.45994, 0.74627, 1.04839, 0.97454, 0.97454, 0.87207, 0.97454, 0.87533, + 1.06151, 0.97454, 1.00176, 1.16484, 1.08132, 0.98047, 1.16484, 1.02989, + 1.01054, 0.96225, 0.97454, 0.97454, 1.06598, 0.79004, 1.16344, 1.00351, + 0.94629, 0.9973, 0.91016, 0.96777, 0.9043, 0.91082, 0.92481, 0.91082, + 1.17308, 0.95748, 0.96927, 0.96927, 1, 0.96927, 0.92481, 0.80597, 1.04839, + 1.23393, 1.1781, 0.9245, 1.17308, 1.20808, 0.63218, 0.94261, 1.24822, + 1.09971, 1.09971, 1.04839, 1, 0.85273, 0.78032, 1.04839, 1.09971, 1.22326, + 0.9245, 1.09836, 1.13525, 1.15222, 0.70424, 0.94729, 0.94729, 0.94729, + 0.94729, 0.94729, 0.94729, 0.85498, 0.88506, 0.74817, 0.74817, 0.74817, + 0.74817, 0.95782, 0.95782, 0.95782, 0.95782, 0.9858, 1.03989, 0.96924, + 0.96924, 0.96924, 0.96924, 0.96924, 1.17308, 0.96924, 0.95402, 0.95402, + 0.95402, 0.95402, 0.83089, 0.86237, 0.88409, 0.97454, 0.97454, 0.97454, + 0.97454, 0.97454, 0.97454, 0.92916, 0.87207, 0.87533, 0.87533, 0.87533, + 0.87533, 0.93146, 0.93146, 0.93146, 0.93146, 0.93854, 1.01054, 0.96225, + 0.96225, 0.96225, 0.96225, 0.96225, 1.24822, 0.8761, 1.00351, 1.00351, + 1.00351, 1.00351, 0.96777, 0.97454, 0.96777, 0.94729, 0.97454, 0.94729, + 0.97454, 0.94729, 0.97454, 0.88506, 0.87207, 0.88506, 0.87207, 0.88506, + 0.87207, 0.88506, 0.87207, 0.9858, 0.95391, 0.9858, 0.97454, 0.74817, + 0.87533, 0.74817, 0.87533, 0.74817, 0.87533, 0.74817, 0.87533, 0.74817, + 0.87533, 0.88449, 0.97454, 0.88449, 0.97454, 0.88449, 0.97454, 1, 1, + 0.98039, 1.00176, 0.98039, 1.00176, 0.95782, 0.93146, 0.95782, 0.93146, + 0.95782, 0.93146, 0.95782, 1.16484, 0.95782, 0.93146, 0.84421, 1.12761, + 0.69238, 1.08132, 1, 1, 0.98047, 0.83231, 1.16484, 1, 1, 0.84723, 1.04861, + 0.84723, 0.78755, 0.83231, 1.23736, 1.03989, 1.01054, 1, 1, 1.03989, + 1.01054, 0.9857, 1.03849, 1.01054, 0.96924, 0.96225, 0.96924, 0.96225, + 0.96924, 0.96225, 0.92383, 0.90171, 0.80595, 1.06598, 1, 1, 0.80595, + 1.06598, 0.74524, 0.79004, 0.74524, 0.79004, 0.74524, 0.79004, 0.74524, + 0.79004, 1, 1, 0.86091, 1.02759, 0.85771, 1.16344, 0.95402, 1.00351, + 0.95402, 1.00351, 0.95402, 1.00351, 0.95402, 1.00351, 0.95402, 1.00351, + 0.95402, 1.00351, 0.98448, 0.9973, 0.83089, 0.96777, 0.83089, 0.93285, + 0.9043, 0.93285, 0.9043, 0.93285, 0.9043, 1.31868, 0.96927, 0.94729, + 0.97454, 0.85498, 0.92916, 0.96924, 0.8761, 1, 1, 0.86091, 1.16344, 1.04839, + 1.04839, 1.04839, 1.04839, 1.04839, 1.04839, 1.04839, 1.04839, 1.04839, + 0.81965, 0.81965, 0.94729, 0.78032, 0.71022, 0.90883, 0.84171, 0.99877, + 0.77596, 1.05734, 1.2, 0.94729, 0.85944, 0.82791, 0.9607, 0.74817, 0.93285, + 0.98039, 0.96924, 0.95782, 0.89898, 0.98316, 0.98183, 1.03989, 0.78614, + 0.96924, 0.97642, 0.86237, 0.86075, 0.86091, 0.83089, 0.90082, 0.8858, + 0.97296, 1.01284, 0.95782, 0.83089, 1.0976, 1.04, 1.03342, 1.2, 1.0675, + 1.0976, 0.98205, 1.03809, 1.05097, 1.04, 0.95364, 1.03342, 1.05401, 1.2, + 1.02148, 1.0119, 1.04724, 1.0127, 1.02732, 0.96225, 0.8965, 0.97783, + 0.93574, 0.94818, 1.30679, 1.0675, 1.11826, 0.99821, 1.0557, 1.0326, 1.2, + 1.0675, 0.96225, 1.0675, 1.0326, 0.74817, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1.03754, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.87533, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0.98705, 1, 1, 1, 1, 1, 1, 0.98448, 0.9973, + 0.98448, 0.9973, 0.98448, 0.9973, 0.83089, 0.96777, 1, 1.20088, 0.89903, 1, + 1, 0.75155, 0.94945, 0.94945, 0.94945, 0.94945, 1.12317, 1.12317, 1.12317, + 0.67603, 0.67603, 1.15621, 0.73584, 1.21191, 1.22135, 1.06483, 0.94868, + 0.94868, 0.95996, 1.24633, 1, 1.07497, 0.87709, 0.96927, 1.01473, 0.96927, + 1, 1, 1, 0.77295, 1, 1, 1.09836, 1.09836, 1.09836, 1.01522, 0.86321, + 0.94434, 0.8649, 0.94434, 0.86182, 1, 1, 1.083, 1, 0.91578, 0.86438, + 1.17308, 1.18416, 1.14589, 0.69825, 0.97622, 1.96791, 1.24822, 1.24822, + 1.17308, 1.24822, 1.24822, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.42603, 1, 0.99862, 0.99862, 1, 0.87025, + 0.87025, 0.87025, 0.87025, 1.17984, 1.42603, 1, 1.42603, 1.42603, 0.99862, + 1, 1, 1, 1, 1, 1.2886, 1.04315, 1.15296, 1.34163, 1, 1, 1, 1.10742, 1.10742, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + gn = { lineHeight: 1.33008, lineGap: 0 }, + pn = [ + 1.76738, 1, 1, 0.98594, 1.02285, 1.10454, 1.06234, 0.96927, 0.92037, + 1.19985, 1.2046, 0.90616, 0.90616, 1.07152, 1.1714, 0.78032, 1.20088, + 0.78032, 1.40246, 0.96927, 0.96927, 0.96927, 0.96927, 0.96927, 0.96927, + 0.96927, 0.96927, 0.96927, 0.96927, 0.78032, 0.78032, 1.1714, 1.1714, + 1.1714, 0.80597, 0.94084, 0.96706, 0.85944, 0.85734, 0.97093, 0.75842, + 0.79936, 0.88198, 0.9831, 0.95782, 0.71387, 0.86969, 0.84636, 1.07796, + 1.03584, 0.96924, 0.83968, 0.96924, 0.82826, 0.79649, 0.85771, 0.95132, + 0.93119, 0.98965, 0.88433, 0.8287, 0.93365, 1.08612, 1.3638, 1.08612, + 1.45786, 0.74627, 0.80499, 0.91484, 1.05707, 0.92383, 1.05882, 0.9403, + 1.12654, 1.05882, 1.01756, 1.09011, 1.09011, 0.99414, 1.09011, 1.034, + 1.01756, 1.05356, 1.05707, 1.05882, 1.04399, 0.84863, 1.21968, 1.01756, + 0.95801, 1.00068, 0.91797, 0.96777, 0.9043, 0.90351, 0.92105, 0.90351, + 1.1714, 0.85337, 0.96927, 0.96927, 0.99912, 0.96927, 0.92105, 0.80597, + 1.2434, 1.20808, 1.05937, 0.90957, 1.1714, 1.20808, 0.75155, 0.94261, + 1.24644, 1.09971, 1.09971, 0.84751, 1, 0.85273, 0.78032, 0.61584, 1.05425, + 1.17914, 0.90957, 1.08665, 1.11593, 1.14169, 0.73381, 0.96706, 0.96706, + 0.96706, 0.96706, 0.96706, 0.96706, 0.86035, 0.85734, 0.75842, 0.75842, + 0.75842, 0.75842, 0.95782, 0.95782, 0.95782, 0.95782, 0.97093, 1.03584, + 0.96924, 0.96924, 0.96924, 0.96924, 0.96924, 1.1714, 0.96924, 0.95132, + 0.95132, 0.95132, 0.95132, 0.8287, 0.83968, 0.89049, 0.91484, 0.91484, + 0.91484, 0.91484, 0.91484, 0.91484, 0.93575, 0.92383, 0.9403, 0.9403, + 0.9403, 0.9403, 0.8717, 0.8717, 0.8717, 0.8717, 1.00527, 1.01756, 1.05356, + 1.05356, 1.05356, 1.05356, 1.05356, 1.24644, 0.95923, 1.01756, 1.01756, + 1.01756, 1.01756, 0.96777, 1.05707, 0.96777, 0.96706, 0.91484, 0.96706, + 0.91484, 0.96706, 0.91484, 0.85734, 0.92383, 0.85734, 0.92383, 0.85734, + 0.92383, 0.85734, 0.92383, 0.97093, 1.0969, 0.97093, 1.05882, 0.75842, + 0.9403, 0.75842, 0.9403, 0.75842, 0.9403, 0.75842, 0.9403, 0.75842, 0.9403, + 0.88198, 1.05882, 0.88198, 1.05882, 0.88198, 1.05882, 1, 1, 0.9831, 1.01756, + 0.9831, 1.01756, 0.95782, 0.8717, 0.95782, 0.8717, 0.95782, 0.8717, 0.95782, + 1.09011, 0.95782, 0.8717, 0.84784, 1.11551, 0.71387, 1.09011, 1, 1, 0.99414, + 0.84636, 1.09011, 1, 1, 0.84636, 1.0536, 0.84636, 0.94298, 0.84636, 1.23297, + 1.03584, 1.01756, 1, 1, 1.03584, 1.01756, 1.00323, 1.03444, 1.01756, + 0.96924, 1.05356, 0.96924, 1.05356, 0.96924, 1.05356, 0.93066, 0.98293, + 0.82826, 1.04399, 1, 1, 0.82826, 1.04399, 0.79649, 0.84863, 0.79649, + 0.84863, 0.79649, 0.84863, 0.79649, 0.84863, 1, 1, 0.85771, 1.17318, + 0.85771, 1.21968, 0.95132, 1.01756, 0.95132, 1.01756, 0.95132, 1.01756, + 0.95132, 1.01756, 0.95132, 1.01756, 0.95132, 1.01756, 0.98965, 1.00068, + 0.8287, 0.96777, 0.8287, 0.93365, 0.9043, 0.93365, 0.9043, 0.93365, 0.9043, + 1.08571, 0.96927, 0.96706, 0.91484, 0.86035, 0.93575, 0.96924, 0.95923, 1, + 1, 0.85771, 1.21968, 1.11437, 1.11437, 0.93109, 0.91202, 0.60411, 0.84164, + 0.55572, 1.01173, 0.97361, 0.81818, 0.81818, 0.96635, 0.78032, 0.72727, + 0.92366, 0.98601, 1.03405, 0.77968, 1.09799, 1.2, 0.96706, 0.85944, 0.85638, + 0.96491, 0.75842, 0.93365, 0.9831, 0.96924, 0.95782, 0.86969, 0.94152, + 1.07796, 1.03584, 0.78437, 0.96924, 0.98715, 0.83968, 0.83491, 0.85771, + 0.8287, 0.94492, 0.88433, 0.9287, 1.0098, 0.95782, 0.8287, 1.0625, 0.98248, + 1.03424, 1.2, 1.01071, 1.0625, 0.95246, 1.03809, 1.04912, 0.98248, 1.00221, + 1.03424, 1.05443, 1.2, 1.04785, 0.99609, 1.00169, 1.05176, 0.99346, 1.05356, + 0.9087, 1.03004, 0.95542, 0.93117, 1.23362, 1.01071, 1.07831, 1.02512, + 1.05205, 1.03502, 1.2, 1.01071, 1.05356, 1.01071, 1.03502, 0.75842, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.03719, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 0.9403, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.04021, 1, 1, 1, 1, 1, + 1, 0.98965, 1.00068, 0.98965, 1.00068, 0.98965, 1.00068, 0.8287, 0.96777, 1, + 1.20088, 0.89903, 1, 1, 0.75155, 1.03077, 1.03077, 1.03077, 1.03077, + 1.13196, 1.13196, 1.13196, 0.67428, 0.67428, 1.16039, 0.73291, 1.20996, + 1.22135, 1.06483, 0.94868, 0.94868, 0.95996, 1.24633, 1, 1.07497, 0.87796, + 0.96927, 1.01518, 0.96927, 1, 1, 1, 0.77295, 1, 1, 1.10539, 1.10539, + 1.11358, 1.06967, 0.86279, 0.94434, 0.86279, 0.94434, 0.86182, 1, 1, 1.083, + 1, 0.91578, 0.86507, 1.1714, 1.18416, 1.14589, 0.69825, 0.97622, 1.9697, + 1.24822, 1.24822, 1.17238, 1.24822, 1.24822, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1.42603, 1, 0.99862, + 0.99862, 1, 0.87025, 0.87025, 0.87025, 0.87025, 1.18083, 1.42603, 1, + 1.42603, 1.42603, 0.99862, 1, 1, 1, 1, 1, 1.2886, 1.04315, 1.15296, 1.34163, + 1, 1, 1, 1.10938, 1.10938, 1, 1, 1, 1.05425, 1.09971, 1.09971, 1.09971, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + ], + mn = { lineHeight: 1.33008, lineGap: 0 }, + bn = getLookupTableFactory(function (e) { + e["MyriadPro-Regular"] = e["PdfJS-Fallback-Regular"] = { + name: "LiberationSans-Regular", + factors: on, + baseWidths: Zi, + baseMapping: Qi, + metrics: cn, + }; + e["MyriadPro-Bold"] = e["PdfJS-Fallback-Bold"] = { + name: "LiberationSans-Bold", + factors: en, + baseWidths: $i, + baseMapping: Gi, + metrics: tn, + }; + e["MyriadPro-It"] = + e["MyriadPro-Italic"] = + e["PdfJS-Fallback-Italic"] = + { + name: "LiberationSans-Italic", + factors: nn, + baseWidths: Ji, + baseMapping: Yi, + metrics: sn, + }; + e["MyriadPro-BoldIt"] = + e["MyriadPro-BoldItalic"] = + e["PdfJS-Fallback-BoldItalic"] = + { + name: "LiberationSans-BoldItalic", + factors: an, + baseWidths: Vi, + baseMapping: Ki, + metrics: rn, + }; + e.ArialMT = + e.Arial = + e["Arial-Regular"] = + { name: "LiberationSans-Regular", baseWidths: Zi, baseMapping: Qi }; + e["Arial-BoldMT"] = e["Arial-Bold"] = { + name: "LiberationSans-Bold", + baseWidths: $i, + baseMapping: Gi, + }; + e["Arial-ItalicMT"] = e["Arial-Italic"] = { + name: "LiberationSans-Italic", + baseWidths: Ji, + baseMapping: Yi, + }; + e["Arial-BoldItalicMT"] = e["Arial-BoldItalic"] = { + name: "LiberationSans-BoldItalic", + baseWidths: Vi, + baseMapping: Ki, + }; + e["Calibri-Regular"] = { + name: "LiberationSans-Regular", + factors: Ni, + baseWidths: Zi, + baseMapping: Qi, + metrics: Ei, + }; + e["Calibri-Bold"] = { + name: "LiberationSans-Bold", + factors: Ti, + baseWidths: $i, + baseMapping: Gi, + metrics: Oi, + }; + e["Calibri-Italic"] = { + name: "LiberationSans-Italic", + factors: Bi, + baseWidths: Ji, + baseMapping: Yi, + metrics: Ri, + }; + e["Calibri-BoldItalic"] = { + name: "LiberationSans-BoldItalic", + factors: Mi, + baseWidths: Vi, + baseMapping: Ki, + metrics: Di, + }; + e["Segoeui-Regular"] = { + name: "LiberationSans-Regular", + factors: pn, + baseWidths: Zi, + baseMapping: Qi, + metrics: mn, + }; + e["Segoeui-Bold"] = { + name: "LiberationSans-Bold", + factors: ln, + baseWidths: $i, + baseMapping: Gi, + metrics: hn, + }; + e["Segoeui-Italic"] = { + name: "LiberationSans-Italic", + factors: fn, + baseWidths: Ji, + baseMapping: Yi, + metrics: gn, + }; + e["Segoeui-BoldItalic"] = { + name: "LiberationSans-BoldItalic", + factors: un, + baseWidths: Vi, + baseMapping: Ki, + metrics: dn, + }; + e["Helvetica-Regular"] = e.Helvetica = { + name: "LiberationSans-Regular", + factors: Wi, + baseWidths: Zi, + baseMapping: Qi, + metrics: zi, + }; + e["Helvetica-Bold"] = { + name: "LiberationSans-Bold", + factors: Pi, + baseWidths: $i, + baseMapping: Gi, + metrics: ji, + }; + e["Helvetica-Italic"] = { + name: "LiberationSans-Italic", + factors: qi, + baseWidths: Ji, + baseMapping: Yi, + metrics: Hi, + }; + e["Helvetica-BoldItalic"] = { + name: "LiberationSans-BoldItalic", + factors: _i, + baseWidths: Vi, + baseMapping: Ki, + metrics: Xi, + }; + }); +function getXfaFontName(e) { + const t = normalizeFontName(e); + return bn()[t]; +} +function getXfaFontDict(e) { + const t = (function getXfaFontWidths(e) { + const t = getXfaFontName(e); + if (!t) return null; + const { baseWidths: a, baseMapping: r, factors: i } = t, + n = i ? a.map((e, t) => e * i[t]) : a; + let s, + o = -2; + const c = []; + for (const [e, t] of r.map((e, t) => [e, t]).sort(([e], [t]) => e - t)) + if (-1 !== e) + if (e === o + 1) { + s.push(n[t]); + o += 1; + } else { + o = e; + s = [n[t]]; + c.push(e, s); + } + return c; + })(e), + a = new Dict(null); + a.set("BaseFont", Name.get(e)); + a.set("Type", Name.get("Font")); + a.set("Subtype", Name.get("CIDFontType2")); + a.set("Encoding", Name.get("Identity-H")); + a.set("CIDToGIDMap", Name.get("Identity")); + a.set("W", t); + a.set("FirstChar", t[0]); + a.set("LastChar", t.at(-2) + t.at(-1).length - 1); + const r = new Dict(null); + a.set("FontDescriptor", r); + const i = new Dict(null); + i.set("Ordering", "Identity"); + i.set("Registry", "Adobe"); + i.set("Supplement", 0); + a.set("CIDSystemInfo", i); + return a; +} +class PostScriptParser { + constructor(e) { + this.lexer = e; + this.operators = []; + this.token = null; + this.prev = null; + } + nextToken() { + this.prev = this.token; + this.token = this.lexer.getToken(); + } + accept(e) { + if (this.token.type === e) { + this.nextToken(); + return !0; + } + return !1; + } + expect(e) { + if (this.accept(e)) return !0; + throw new FormatError( + `Unexpected symbol: found ${this.token.type} expected ${e}.`, + ); + } + parse() { + this.nextToken(); + this.expect(yn.LBRACE); + this.parseBlock(); + this.expect(yn.RBRACE); + return this.operators; + } + parseBlock() { + for (;;) + if (this.accept(yn.NUMBER)) this.operators.push(this.prev.value); + else if (this.accept(yn.OPERATOR)) this.operators.push(this.prev.value); + else { + if (!this.accept(yn.LBRACE)) return; + this.parseCondition(); + } + } + parseCondition() { + const e = this.operators.length; + this.operators.push(null, null); + this.parseBlock(); + this.expect(yn.RBRACE); + if (this.accept(yn.IF)) { + this.operators[e] = this.operators.length; + this.operators[e + 1] = "jz"; + } else { + if (!this.accept(yn.LBRACE)) + throw new FormatError("PS Function: error parsing conditional."); + { + const t = this.operators.length; + this.operators.push(null, null); + const a = this.operators.length; + this.parseBlock(); + this.expect(yn.RBRACE); + this.expect(yn.IFELSE); + this.operators[t] = this.operators.length; + this.operators[t + 1] = "j"; + this.operators[e] = a; + this.operators[e + 1] = "jz"; + } + } + } +} +const yn = { LBRACE: 0, RBRACE: 1, NUMBER: 2, OPERATOR: 3, IF: 4, IFELSE: 5 }; +class PostScriptToken { + static get opCache() { + return shadow(this, "opCache", Object.create(null)); + } + constructor(e, t) { + this.type = e; + this.value = t; + } + static getOperator(e) { + return (PostScriptToken.opCache[e] ||= new PostScriptToken(yn.OPERATOR, e)); + } + static get LBRACE() { + return shadow(this, "LBRACE", new PostScriptToken(yn.LBRACE, "{")); + } + static get RBRACE() { + return shadow(this, "RBRACE", new PostScriptToken(yn.RBRACE, "}")); + } + static get IF() { + return shadow(this, "IF", new PostScriptToken(yn.IF, "IF")); + } + static get IFELSE() { + return shadow(this, "IFELSE", new PostScriptToken(yn.IFELSE, "IFELSE")); + } +} +class PostScriptLexer { + constructor(e) { + this.stream = e; + this.nextChar(); + this.strBuf = []; + } + nextChar() { + return (this.currentChar = this.stream.getByte()); + } + getToken() { + let e = !1, + t = this.currentChar; + for (;;) { + if (t < 0) return wa; + if (e) (10 !== t && 13 !== t) || (e = !1); + else if (37 === t) e = !0; + else if (!isWhiteSpace(t)) break; + t = this.nextChar(); + } + switch (0 | t) { + case 48: + case 49: + case 50: + case 51: + case 52: + case 53: + case 54: + case 55: + case 56: + case 57: + case 43: + case 45: + case 46: + return new PostScriptToken(yn.NUMBER, this.getNumber()); + case 123: + this.nextChar(); + return PostScriptToken.LBRACE; + case 125: + this.nextChar(); + return PostScriptToken.RBRACE; + } + const a = this.strBuf; + a.length = 0; + a[0] = String.fromCharCode(t); + for ( + ; + (t = this.nextChar()) >= 0 && + ((t >= 65 && t <= 90) || (t >= 97 && t <= 122)); + + ) + a.push(String.fromCharCode(t)); + const r = a.join(""); + switch (r.toLowerCase()) { + case "if": + return PostScriptToken.IF; + case "ifelse": + return PostScriptToken.IFELSE; + default: + return PostScriptToken.getOperator(r); + } + } + getNumber() { + let e = this.currentChar; + const t = this.strBuf; + t.length = 0; + t[0] = String.fromCharCode(e); + for ( + ; + (e = this.nextChar()) >= 0 && + ((e >= 48 && e <= 57) || 45 === e || 46 === e); + + ) + t.push(String.fromCharCode(e)); + const a = parseFloat(t.join("")); + if (isNaN(a)) throw new FormatError(`Invalid floating point number: ${a}`); + return a; + } +} +class BaseLocalCache { + constructor(e) { + this._onlyRefs = !0 === e?.onlyRefs; + if (!this._onlyRefs) { + this._nameRefMap = new Map(); + this._imageMap = new Map(); + } + this._imageCache = new RefSetCache(); + } + getByName(e) { + this._onlyRefs && unreachable("Should not call `getByName` method."); + const t = this._nameRefMap.get(e); + return t ? this.getByRef(t) : this._imageMap.get(e) || null; + } + getByRef(e) { + return this._imageCache.get(e) || null; + } + set(e, t, a) { + unreachable("Abstract method `set` called."); + } +} +class LocalImageCache extends BaseLocalCache { + set(e, t = null, a) { + if ("string" != typeof e) + throw new Error('LocalImageCache.set - expected "name" argument.'); + if (t) { + if (this._imageCache.has(t)) return; + this._nameRefMap.set(e, t); + this._imageCache.put(t, a); + } else this._imageMap.has(e) || this._imageMap.set(e, a); + } +} +class LocalColorSpaceCache extends BaseLocalCache { + set(e = null, t = null, a) { + if ("string" != typeof e && !t) + throw new Error( + 'LocalColorSpaceCache.set - expected "name" and/or "ref" argument.', + ); + if (t) { + if (this._imageCache.has(t)) return; + null !== e && this._nameRefMap.set(e, t); + this._imageCache.put(t, a); + } else this._imageMap.has(e) || this._imageMap.set(e, a); + } +} +class LocalFunctionCache extends BaseLocalCache { + constructor(e) { + super({ onlyRefs: !0 }); + } + set(e = null, t, a) { + if (!t) + throw new Error('LocalFunctionCache.set - expected "ref" argument.'); + this._imageCache.has(t) || this._imageCache.put(t, a); + } +} +class LocalGStateCache extends BaseLocalCache { + set(e, t = null, a) { + if ("string" != typeof e) + throw new Error('LocalGStateCache.set - expected "name" argument.'); + if (t) { + if (this._imageCache.has(t)) return; + this._nameRefMap.set(e, t); + this._imageCache.put(t, a); + } else this._imageMap.has(e) || this._imageMap.set(e, a); + } +} +class LocalTilingPatternCache extends BaseLocalCache { + constructor(e) { + super({ onlyRefs: !0 }); + } + set(e = null, t, a) { + if (!t) + throw new Error('LocalTilingPatternCache.set - expected "ref" argument.'); + this._imageCache.has(t) || this._imageCache.put(t, a); + } +} +class RegionalImageCache extends BaseLocalCache { + constructor(e) { + super({ onlyRefs: !0 }); + } + set(e = null, t, a) { + if (!t) + throw new Error('RegionalImageCache.set - expected "ref" argument.'); + this._imageCache.has(t) || this._imageCache.put(t, a); + } +} +class GlobalColorSpaceCache extends BaseLocalCache { + constructor(e) { + super({ onlyRefs: !0 }); + } + set(e = null, t, a) { + if (!t) + throw new Error('GlobalColorSpaceCache.set - expected "ref" argument.'); + this._imageCache.has(t) || this._imageCache.put(t, a); + } + clear() { + this._imageCache.clear(); + } +} +class GlobalImageCache { + static NUM_PAGES_THRESHOLD = 2; + static MIN_IMAGES_TO_CACHE = 10; + static MAX_BYTE_SIZE = 5e7; + #H = new RefSet(); + constructor() { + this._refCache = new RefSetCache(); + this._imageCache = new RefSetCache(); + } + get #W() { + let e = 0; + for (const t of this._imageCache) e += t.byteSize; + return e; + } + get #z() { + return ( + !(this._imageCache.size < GlobalImageCache.MIN_IMAGES_TO_CACHE) && + !(this.#W < GlobalImageCache.MAX_BYTE_SIZE) + ); + } + shouldCache(e, t) { + let a = this._refCache.get(e); + if (!a) { + a = new Set(); + this._refCache.put(e, a); + } + a.add(t); + return ( + !(a.size < GlobalImageCache.NUM_PAGES_THRESHOLD) && + !(!this._imageCache.has(e) && this.#z) + ); + } + addDecodeFailed(e) { + this.#H.put(e); + } + hasDecodeFailed(e) { + return this.#H.has(e); + } + addByteSize(e, t) { + const a = this._imageCache.get(e); + a && (a.byteSize || (a.byteSize = t)); + } + getData(e, t) { + const a = this._refCache.get(e); + if (!a) return null; + if (a.size < GlobalImageCache.NUM_PAGES_THRESHOLD) return null; + const r = this._imageCache.get(e); + if (!r) return null; + a.add(t); + return r; + } + setData(e, t) { + if (!this._refCache.has(e)) + throw new Error( + 'GlobalImageCache.setData - expected "shouldCache" to have been called.', + ); + this._imageCache.has(e) || + (this.#z + ? warn("GlobalImageCache.setData - cache limit reached.") + : this._imageCache.put(e, t)); + } + clear(e = !1) { + if (!e) { + this.#H.clear(); + this._refCache.clear(); + } + this._imageCache.clear(); + } +} +class PDFFunctionFactory { + constructor({ xref: e, isEvalSupported: t = !0 }) { + this.xref = e; + this.isEvalSupported = !1 !== t; + } + create(e, t = !1) { + let a, r; + e instanceof Ref + ? (a = e) + : e instanceof Dict + ? (a = e.objId) + : e instanceof BaseStream && (a = e.dict?.objId); + if (a) { + const e = this._localFunctionCache.getByRef(a); + if (e) return e; + } + const i = this.xref.fetchIfRef(e); + if (Array.isArray(i)) { + if (!t) + throw new Error( + 'PDFFunctionFactory.create - expected "parseArray" argument.', + ); + r = PDFFunction.parseArray(this, i); + } else r = PDFFunction.parse(this, i); + a && this._localFunctionCache.set(null, a, r); + return r; + } + get _localFunctionCache() { + return shadow(this, "_localFunctionCache", new LocalFunctionCache()); + } +} +function toNumberArray(e) { + return Array.isArray(e) + ? isNumberArray(e, null) + ? e + : e.map((e) => +e) + : null; +} +class PDFFunction { + static getSampleArray(e, t, a, r) { + let i, + n, + s = 1; + for (i = 0, n = e.length; i < n; i++) s *= e[i]; + s *= t; + const o = new Array(s); + let c = 0, + l = 0; + const h = 1 / (2 ** a - 1), + u = r.getBytes((s * a + 7) / 8); + let d = 0; + for (i = 0; i < s; i++) { + for (; c < a; ) { + l <<= 8; + l |= u[d++]; + c += 8; + } + c -= a; + o[i] = (l >> c) * h; + l &= (1 << c) - 1; + } + return o; + } + static parse(e, t) { + const a = t.dict || t; + switch (a.get("FunctionType")) { + case 0: + return this.constructSampled(e, t, a); + case 1: + break; + case 2: + return this.constructInterpolated(e, a); + case 3: + return this.constructStiched(e, a); + case 4: + return this.constructPostScript(e, t, a); + } + throw new FormatError("Unknown type of function"); + } + static parseArray(e, t) { + const { xref: a } = e, + r = []; + for (const i of t) r.push(this.parse(e, a.fetchIfRef(i))); + return function (e, t, a, i) { + for (let n = 0, s = r.length; n < s; n++) r[n](e, t, a, i + n); + }; + } + static constructSampled(e, t, a) { + function toMultiArray(e) { + const t = e.length, + a = []; + let r = 0; + for (let i = 0; i < t; i += 2) a[r++] = [e[i], e[i + 1]]; + return a; + } + function interpolate(e, t, a, r, i) { + return r + ((i - r) / (a - t)) * (e - t); + } + let r = toNumberArray(a.getArray("Domain")), + i = toNumberArray(a.getArray("Range")); + if (!r || !i) throw new FormatError("No domain or range"); + const n = r.length / 2, + s = i.length / 2; + r = toMultiArray(r); + i = toMultiArray(i); + const o = toNumberArray(a.getArray("Size")), + c = a.get("BitsPerSample"), + l = a.get("Order") || 1; + 1 !== l && info("No support for cubic spline interpolation: " + l); + let h = toNumberArray(a.getArray("Encode")); + if (h) h = toMultiArray(h); + else { + h = []; + for (let e = 0; e < n; ++e) h.push([0, o[e] - 1]); + } + let u = toNumberArray(a.getArray("Decode")); + u = u ? toMultiArray(u) : i; + const d = this.getSampleArray(o, s, c, t); + return function constructSampledFn(e, t, a, c) { + const l = 1 << n, + f = new Float64Array(l).fill(1), + g = new Uint32Array(l); + let p, + m, + b = s, + y = 1; + for (p = 0; p < n; ++p) { + const a = r[p][0], + i = r[p][1]; + let n = interpolate(MathClamp(e[t + p], a, i), a, i, h[p][0], h[p][1]); + const s = o[p]; + n = MathClamp(n, 0, s - 1); + const c = n < s - 1 ? Math.floor(n) : n - 1, + u = c + 1 - n, + d = n - c, + w = c * b, + x = w + b; + for (m = 0; m < l; m++) + if (m & y) { + f[m] *= d; + g[m] += x; + } else { + f[m] *= u; + g[m] += w; + } + b *= s; + y <<= 1; + } + for (m = 0; m < s; ++m) { + let e = 0; + for (p = 0; p < l; p++) e += d[g[p] + m] * f[p]; + e = interpolate(e, 0, 1, u[m][0], u[m][1]); + a[c + m] = MathClamp(e, i[m][0], i[m][1]); + } + }; + } + static constructInterpolated(e, t) { + const a = toNumberArray(t.getArray("C0")) || [0], + r = toNumberArray(t.getArray("C1")) || [1], + i = t.get("N"), + n = []; + for (let e = 0, t = a.length; e < t; ++e) n.push(r[e] - a[e]); + const s = n.length; + return function constructInterpolatedFn(e, t, r, o) { + const c = 1 === i ? e[t] : e[t] ** i; + for (let e = 0; e < s; ++e) r[o + e] = a[e] + c * n[e]; + }; + } + static constructStiched(e, t) { + const a = toNumberArray(t.getArray("Domain")); + if (!a) throw new FormatError("No domain"); + if (1 !== a.length / 2) + throw new FormatError("Bad domain for stiched function"); + const { xref: r } = e, + i = []; + for (const a of t.get("Functions")) i.push(this.parse(e, r.fetchIfRef(a))); + const n = toNumberArray(t.getArray("Bounds")), + s = toNumberArray(t.getArray("Encode")), + o = new Float32Array(1); + return function constructStichedFn(e, t, r, c) { + const l = MathClamp(e[t], a[0], a[1]), + h = n.length; + let u; + for (u = 0; u < h && !(l < n[u]); ++u); + let d = a[0]; + u > 0 && (d = n[u - 1]); + let f = a[1]; + u < n.length && (f = n[u]); + const g = s[2 * u], + p = s[2 * u + 1]; + o[0] = d === f ? g : g + ((l - d) * (p - g)) / (f - d); + i[u](o, 0, r, c); + }; + } + static constructPostScript(e, t, a) { + const r = toNumberArray(a.getArray("Domain")), + i = toNumberArray(a.getArray("Range")); + if (!r) throw new FormatError("No domain."); + if (!i) throw new FormatError("No range."); + const n = new PostScriptLexer(t), + s = new PostScriptParser(n).parse(); + if (e.isEvalSupported && FeatureTest.isEvalSupported) { + const e = new PostScriptCompiler().compile(s, r, i); + if (e) return new Function("src", "srcOffset", "dest", "destOffset", e); + } + info("Unable to compile PS function"); + const o = i.length >> 1, + c = r.length >> 1, + l = new PostScriptEvaluator(s), + h = Object.create(null); + let u = 8192; + const d = new Float32Array(c); + return function constructPostScriptFn(e, t, a, r) { + let n, + s, + f = ""; + const g = d; + for (n = 0; n < c; n++) { + s = e[t + n]; + g[n] = s; + f += s + "_"; + } + const p = h[f]; + if (void 0 !== p) { + a.set(p, r); + return; + } + const m = new Float32Array(o), + b = l.execute(g), + y = b.length - o; + for (n = 0; n < o; n++) { + s = b[y + n]; + let e = i[2 * n]; + if (s < e) s = e; + else { + e = i[2 * n + 1]; + s > e && (s = e); + } + m[n] = s; + } + if (u > 0) { + u--; + h[f] = m; + } + a.set(m, r); + }; + } +} +function isPDFFunction(e) { + let t; + if (e instanceof Dict) t = e; + else { + if (!(e instanceof BaseStream)) return !1; + t = e.dict; + } + return t.has("FunctionType"); +} +class PostScriptStack { + static MAX_STACK_SIZE = 100; + constructor(e) { + this.stack = e ? Array.from(e) : []; + } + push(e) { + if (this.stack.length >= PostScriptStack.MAX_STACK_SIZE) + throw new Error("PostScript function stack overflow."); + this.stack.push(e); + } + pop() { + if (this.stack.length <= 0) + throw new Error("PostScript function stack underflow."); + return this.stack.pop(); + } + copy(e) { + if (this.stack.length + e >= PostScriptStack.MAX_STACK_SIZE) + throw new Error("PostScript function stack overflow."); + const t = this.stack; + for (let a = t.length - e, r = e - 1; r >= 0; r--, a++) t.push(t[a]); + } + index(e) { + this.push(this.stack[this.stack.length - e - 1]); + } + roll(e, t) { + const a = this.stack, + r = a.length - e, + i = a.length - 1, + n = r + (t - Math.floor(t / e) * e); + for (let e = r, t = i; e < t; e++, t--) { + const r = a[e]; + a[e] = a[t]; + a[t] = r; + } + for (let e = r, t = n - 1; e < t; e++, t--) { + const r = a[e]; + a[e] = a[t]; + a[t] = r; + } + for (let e = n, t = i; e < t; e++, t--) { + const r = a[e]; + a[e] = a[t]; + a[t] = r; + } + } +} +class PostScriptEvaluator { + constructor(e) { + this.operators = e; + } + execute(e) { + const t = new PostScriptStack(e); + let a = 0; + const r = this.operators, + i = r.length; + let n, s, o; + for (; a < i; ) { + n = r[a++]; + if ("number" != typeof n) + switch (n) { + case "jz": + o = t.pop(); + s = t.pop(); + s || (a = o); + break; + case "j": + s = t.pop(); + a = s; + break; + case "abs": + s = t.pop(); + t.push(Math.abs(s)); + break; + case "add": + o = t.pop(); + s = t.pop(); + t.push(s + o); + break; + case "and": + o = t.pop(); + s = t.pop(); + "boolean" == typeof s && "boolean" == typeof o + ? t.push(s && o) + : t.push(s & o); + break; + case "atan": + o = t.pop(); + s = t.pop(); + s = (Math.atan2(s, o) / Math.PI) * 180; + s < 0 && (s += 360); + t.push(s); + break; + case "bitshift": + o = t.pop(); + s = t.pop(); + s > 0 ? t.push(s << o) : t.push(s >> o); + break; + case "ceiling": + s = t.pop(); + t.push(Math.ceil(s)); + break; + case "copy": + s = t.pop(); + t.copy(s); + break; + case "cos": + s = t.pop(); + t.push(Math.cos(((s % 360) / 180) * Math.PI)); + break; + case "cvi": + s = 0 | t.pop(); + t.push(s); + break; + case "cvr": + break; + case "div": + o = t.pop(); + s = t.pop(); + t.push(s / o); + break; + case "dup": + t.copy(1); + break; + case "eq": + o = t.pop(); + s = t.pop(); + t.push(s === o); + break; + case "exch": + t.roll(2, 1); + break; + case "exp": + o = t.pop(); + s = t.pop(); + t.push(s ** o); + break; + case "false": + t.push(!1); + break; + case "floor": + s = t.pop(); + t.push(Math.floor(s)); + break; + case "ge": + o = t.pop(); + s = t.pop(); + t.push(s >= o); + break; + case "gt": + o = t.pop(); + s = t.pop(); + t.push(s > o); + break; + case "idiv": + o = t.pop(); + s = t.pop(); + t.push((s / o) | 0); + break; + case "index": + s = t.pop(); + t.index(s); + break; + case "le": + o = t.pop(); + s = t.pop(); + t.push(s <= o); + break; + case "ln": + s = t.pop(); + t.push(Math.log(s)); + break; + case "log": + s = t.pop(); + t.push(Math.log10(s)); + break; + case "lt": + o = t.pop(); + s = t.pop(); + t.push(s < o); + break; + case "mod": + o = t.pop(); + s = t.pop(); + t.push(s % o); + break; + case "mul": + o = t.pop(); + s = t.pop(); + t.push(s * o); + break; + case "ne": + o = t.pop(); + s = t.pop(); + t.push(s !== o); + break; + case "neg": + s = t.pop(); + t.push(-s); + break; + case "not": + s = t.pop(); + "boolean" == typeof s ? t.push(!s) : t.push(~s); + break; + case "or": + o = t.pop(); + s = t.pop(); + "boolean" == typeof s && "boolean" == typeof o + ? t.push(s || o) + : t.push(s | o); + break; + case "pop": + t.pop(); + break; + case "roll": + o = t.pop(); + s = t.pop(); + t.roll(s, o); + break; + case "round": + s = t.pop(); + t.push(Math.round(s)); + break; + case "sin": + s = t.pop(); + t.push(Math.sin(((s % 360) / 180) * Math.PI)); + break; + case "sqrt": + s = t.pop(); + t.push(Math.sqrt(s)); + break; + case "sub": + o = t.pop(); + s = t.pop(); + t.push(s - o); + break; + case "true": + t.push(!0); + break; + case "truncate": + s = t.pop(); + s = s < 0 ? Math.ceil(s) : Math.floor(s); + t.push(s); + break; + case "xor": + o = t.pop(); + s = t.pop(); + "boolean" == typeof s && "boolean" == typeof o + ? t.push(s !== o) + : t.push(s ^ o); + break; + default: + throw new FormatError(`Unknown operator ${n}`); + } + else t.push(n); + } + return t.stack; + } +} +class AstNode { + constructor(e) { + this.type = e; + } + visit(e) { + unreachable("abstract method"); + } +} +class AstArgument extends AstNode { + constructor(e, t, a) { + super("args"); + this.index = e; + this.min = t; + this.max = a; + } + visit(e) { + e.visitArgument(this); + } +} +class AstLiteral extends AstNode { + constructor(e) { + super("literal"); + this.number = e; + this.min = e; + this.max = e; + } + visit(e) { + e.visitLiteral(this); + } +} +class AstBinaryOperation extends AstNode { + constructor(e, t, a, r, i) { + super("binary"); + this.op = e; + this.arg1 = t; + this.arg2 = a; + this.min = r; + this.max = i; + } + visit(e) { + e.visitBinaryOperation(this); + } +} +class AstMin extends AstNode { + constructor(e, t) { + super("max"); + this.arg = e; + this.min = e.min; + this.max = t; + } + visit(e) { + e.visitMin(this); + } +} +class AstVariable extends AstNode { + constructor(e, t, a) { + super("var"); + this.index = e; + this.min = t; + this.max = a; + } + visit(e) { + e.visitVariable(this); + } +} +class AstVariableDefinition extends AstNode { + constructor(e, t) { + super("definition"); + this.variable = e; + this.arg = t; + } + visit(e) { + e.visitVariableDefinition(this); + } +} +class ExpressionBuilderVisitor { + constructor() { + this.parts = []; + } + visitArgument(e) { + this.parts.push( + "Math.max(", + e.min, + ", Math.min(", + e.max, + ", src[srcOffset + ", + e.index, + "]))", + ); + } + visitVariable(e) { + this.parts.push("v", e.index); + } + visitLiteral(e) { + this.parts.push(e.number); + } + visitBinaryOperation(e) { + this.parts.push("("); + e.arg1.visit(this); + this.parts.push(" ", e.op, " "); + e.arg2.visit(this); + this.parts.push(")"); + } + visitVariableDefinition(e) { + this.parts.push("var "); + e.variable.visit(this); + this.parts.push(" = "); + e.arg.visit(this); + this.parts.push(";"); + } + visitMin(e) { + this.parts.push("Math.min("); + e.arg.visit(this); + this.parts.push(", ", e.max, ")"); + } + toString() { + return this.parts.join(""); + } +} +function buildAddOperation(e, t) { + return "literal" === t.type && 0 === t.number + ? e + : "literal" === e.type && 0 === e.number + ? t + : "literal" === t.type && "literal" === e.type + ? new AstLiteral(e.number + t.number) + : new AstBinaryOperation("+", e, t, e.min + t.min, e.max + t.max); +} +function buildMulOperation(e, t) { + if ("literal" === t.type) { + if (0 === t.number) return new AstLiteral(0); + if (1 === t.number) return e; + if ("literal" === e.type) return new AstLiteral(e.number * t.number); + } + if ("literal" === e.type) { + if (0 === e.number) return new AstLiteral(0); + if (1 === e.number) return t; + } + const a = Math.min( + e.min * t.min, + e.min * t.max, + e.max * t.min, + e.max * t.max, + ), + r = Math.max(e.min * t.min, e.min * t.max, e.max * t.min, e.max * t.max); + return new AstBinaryOperation("*", e, t, a, r); +} +function buildSubOperation(e, t) { + if ("literal" === t.type) { + if (0 === t.number) return e; + if ("literal" === e.type) return new AstLiteral(e.number - t.number); + } + return "binary" === t.type && + "-" === t.op && + "literal" === e.type && + 1 === e.number && + "literal" === t.arg1.type && + 1 === t.arg1.number + ? t.arg2 + : new AstBinaryOperation("-", e, t, e.min - t.max, e.max - t.min); +} +function buildMinOperation(e, t) { + return e.min >= t ? new AstLiteral(t) : e.max <= t ? e : new AstMin(e, t); +} +class PostScriptCompiler { + compile(e, t, a) { + const r = [], + i = [], + n = t.length >> 1, + s = a.length >> 1; + let o, + c, + l, + h, + u, + d, + f, + g, + p = 0; + for (let e = 0; e < n; e++) + r.push(new AstArgument(e, t[2 * e], t[2 * e + 1])); + for (let t = 0, a = e.length; t < a; t++) { + g = e[t]; + if ("number" != typeof g) + switch (g) { + case "add": + if (r.length < 2) return null; + h = r.pop(); + l = r.pop(); + r.push(buildAddOperation(l, h)); + break; + case "cvr": + if (r.length < 1) return null; + break; + case "mul": + if (r.length < 2) return null; + h = r.pop(); + l = r.pop(); + r.push(buildMulOperation(l, h)); + break; + case "sub": + if (r.length < 2) return null; + h = r.pop(); + l = r.pop(); + r.push(buildSubOperation(l, h)); + break; + case "exch": + if (r.length < 2) return null; + u = r.pop(); + d = r.pop(); + r.push(u, d); + break; + case "pop": + if (r.length < 1) return null; + r.pop(); + break; + case "index": + if (r.length < 1) return null; + l = r.pop(); + if ("literal" !== l.type) return null; + o = l.number; + if (o < 0 || !Number.isInteger(o) || r.length < o) return null; + u = r[r.length - o - 1]; + if ("literal" === u.type || "var" === u.type) { + r.push(u); + break; + } + f = new AstVariable(p++, u.min, u.max); + r[r.length - o - 1] = f; + r.push(f); + i.push(new AstVariableDefinition(f, u)); + break; + case "dup": + if (r.length < 1) return null; + if ( + "number" == typeof e[t + 1] && + "gt" === e[t + 2] && + e[t + 3] === t + 7 && + "jz" === e[t + 4] && + "pop" === e[t + 5] && + e[t + 6] === e[t + 1] + ) { + l = r.pop(); + r.push(buildMinOperation(l, e[t + 1])); + t += 6; + break; + } + u = r.at(-1); + if ("literal" === u.type || "var" === u.type) { + r.push(u); + break; + } + f = new AstVariable(p++, u.min, u.max); + r[r.length - 1] = f; + r.push(f); + i.push(new AstVariableDefinition(f, u)); + break; + case "roll": + if (r.length < 2) return null; + h = r.pop(); + l = r.pop(); + if ("literal" !== h.type || "literal" !== l.type) return null; + c = h.number; + o = l.number; + if ( + o <= 0 || + !Number.isInteger(o) || + !Number.isInteger(c) || + r.length < o + ) + return null; + c = ((c % o) + o) % o; + if (0 === c) break; + r.push(...r.splice(r.length - o, o - c)); + break; + default: + return null; + } + else r.push(new AstLiteral(g)); + } + if (r.length !== s) return null; + const m = []; + for (const e of i) { + const t = new ExpressionBuilderVisitor(); + e.visit(t); + m.push(t.toString()); + } + for (let e = 0, t = r.length; e < t; e++) { + const t = r[e], + i = new ExpressionBuilderVisitor(); + t.visit(i); + const n = a[2 * e], + s = a[2 * e + 1], + o = [i.toString()]; + if (n > t.min) { + o.unshift("Math.max(", n, ", "); + o.push(")"); + } + if (s < t.max) { + o.unshift("Math.min(", s, ", "); + o.push(")"); + } + o.unshift("dest[destOffset + ", e, "] = "); + o.push(";"); + m.push(o.join("")); + } + return m.join("\n"); + } +} +const wn = [ + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "S", + "B", + "S", + "WS", + "B", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "B", + "B", + "B", + "S", + "WS", + "ON", + "ON", + "ET", + "ET", + "ET", + "ON", + "ON", + "ON", + "ON", + "ON", + "ES", + "CS", + "ES", + "CS", + "CS", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "CS", + "ON", + "ON", + "ON", + "ON", + "ON", + "ON", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "ON", + "ON", + "ON", + "ON", + "ON", + "ON", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "ON", + "ON", + "ON", + "ON", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "B", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "BN", + "CS", + "ON", + "ET", + "ET", + "ET", + "ET", + "ON", + "ON", + "ON", + "ON", + "L", + "ON", + "ON", + "BN", + "ON", + "ON", + "ET", + "ET", + "EN", + "EN", + "ON", + "L", + "ON", + "ON", + "ON", + "EN", + "L", + "ON", + "ON", + "ON", + "ON", + "ON", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "ON", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "ON", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + "L", + ], + xn = [ + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "ON", + "ON", + "AL", + "ET", + "ET", + "AL", + "CS", + "AL", + "ON", + "ON", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "AL", + "AL", + "", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "AN", + "ET", + "AN", + "AN", + "AL", + "AL", + "AL", + "NSM", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "AN", + "ON", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "NSM", + "AL", + "AL", + "NSM", + "NSM", + "ON", + "NSM", + "NSM", + "NSM", + "NSM", + "AL", + "AL", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "EN", + "AL", + "AL", + "AL", + "AL", + "AL", + "AL", + ]; +function isOdd(e) { + return !!(1 & e); +} +function isEven(e) { + return !(1 & e); +} +function findUnequal(e, t, a) { + let r, i; + for (r = t, i = e.length; r < i; ++r) if (e[r] !== a) return r; + return r; +} +function reverseValues(e, t, a) { + for (let r = t, i = a - 1; r < i; ++r, --i) { + const t = e[r]; + e[r] = e[i]; + e[i] = t; + } +} +function createBidiText(e, t, a = !1) { + let r = "ltr"; + a ? (r = "ttb") : t || (r = "rtl"); + return { str: e, dir: r }; +} +const Sn = [], + kn = []; +function bidi(e, t = -1, a = !1) { + let r = !0; + const i = e.length; + if (0 === i || a) return createBidiText(e, r, a); + Sn.length = i; + kn.length = i; + let n, + s, + o = 0; + for (n = 0; n < i; ++n) { + Sn[n] = e.charAt(n); + const t = e.charCodeAt(n); + let a = "L"; + if (t <= 255) a = wn[t]; + else if (1424 <= t && t <= 1524) a = "R"; + else if (1536 <= t && t <= 1791) { + a = xn[255 & t]; + a || warn("Bidi: invalid Unicode character " + t.toString(16)); + } else + ((1792 <= t && t <= 2220) || + (64336 <= t && t <= 65023) || + (65136 <= t && t <= 65279)) && + (a = "AL"); + ("R" !== a && "AL" !== a && "AN" !== a) || o++; + kn[n] = a; + } + if (0 === o) { + r = !0; + return createBidiText(e, r); + } + if (-1 === t) + if (o / i < 0.3 && i > 4) { + r = !0; + t = 0; + } else { + r = !1; + t = 1; + } + const c = []; + for (n = 0; n < i; ++n) c[n] = t; + const l = isOdd(t) ? "R" : "L", + h = l, + u = h; + let d, + f = h; + for (n = 0; n < i; ++n) "NSM" === kn[n] ? (kn[n] = f) : (f = kn[n]); + f = h; + for (n = 0; n < i; ++n) { + d = kn[n]; + "EN" === d + ? (kn[n] = "AL" === f ? "AN" : "EN") + : ("R" !== d && "L" !== d && "AL" !== d) || (f = d); + } + for (n = 0; n < i; ++n) { + d = kn[n]; + "AL" === d && (kn[n] = "R"); + } + for (n = 1; n < i - 1; ++n) { + "ES" === kn[n] && + "EN" === kn[n - 1] && + "EN" === kn[n + 1] && + (kn[n] = "EN"); + "CS" !== kn[n] || + ("EN" !== kn[n - 1] && "AN" !== kn[n - 1]) || + kn[n + 1] !== kn[n - 1] || + (kn[n] = kn[n - 1]); + } + for (n = 0; n < i; ++n) + if ("EN" === kn[n]) { + for (let e = n - 1; e >= 0 && "ET" === kn[e]; --e) kn[e] = "EN"; + for (let e = n + 1; e < i && "ET" === kn[e]; ++e) kn[e] = "EN"; + } + for (n = 0; n < i; ++n) { + d = kn[n]; + ("WS" !== d && "ES" !== d && "ET" !== d && "CS" !== d) || (kn[n] = "ON"); + } + f = h; + for (n = 0; n < i; ++n) { + d = kn[n]; + "EN" === d + ? (kn[n] = "L" === f ? "L" : "EN") + : ("R" !== d && "L" !== d) || (f = d); + } + for (n = 0; n < i; ++n) + if ("ON" === kn[n]) { + const e = findUnequal(kn, n + 1, "ON"); + let t = h; + n > 0 && (t = kn[n - 1]); + let a = u; + e + 1 < i && (a = kn[e + 1]); + "L" !== t && (t = "R"); + "L" !== a && (a = "R"); + t === a && kn.fill(t, n, e); + n = e - 1; + } + for (n = 0; n < i; ++n) "ON" === kn[n] && (kn[n] = l); + for (n = 0; n < i; ++n) { + d = kn[n]; + isEven(c[n]) + ? "R" === d + ? (c[n] += 1) + : ("AN" !== d && "EN" !== d) || (c[n] += 2) + : ("L" !== d && "AN" !== d && "EN" !== d) || (c[n] += 1); + } + let g, + p = -1, + m = 99; + for (n = 0, s = c.length; n < s; ++n) { + g = c[n]; + p < g && (p = g); + m > g && isOdd(g) && (m = g); + } + for (g = p; g >= m; --g) { + let e = -1; + for (n = 0, s = c.length; n < s; ++n) + if (c[n] < g) { + if (e >= 0) { + reverseValues(Sn, e, n); + e = -1; + } + } else e < 0 && (e = n); + e >= 0 && reverseValues(Sn, e, c.length); + } + for (n = 0, s = Sn.length; n < s; ++n) { + const e = Sn[n]; + ("<" !== e && ">" !== e) || (Sn[n] = ""); + } + return createBidiText(Sn.join(""), r); +} +const An = { style: "normal", weight: "normal" }, + Cn = { style: "normal", weight: "bold" }, + vn = { style: "italic", weight: "normal" }, + Fn = { style: "italic", weight: "bold" }, + In = new Map([ + [ + "Times-Roman", + { + local: [ + "Times New Roman", + "Times-Roman", + "Times", + "Liberation Serif", + "Nimbus Roman", + "Nimbus Roman L", + "Tinos", + "Thorndale", + "TeX Gyre Termes", + "FreeSerif", + "Linux Libertine O", + "Libertinus Serif", + "DejaVu Serif", + "Bitstream Vera Serif", + "Ubuntu", + ], + style: An, + ultimate: "serif", + }, + ], + ["Times-Bold", { alias: "Times-Roman", style: Cn, ultimate: "serif" }], + ["Times-Italic", { alias: "Times-Roman", style: vn, ultimate: "serif" }], + [ + "Times-BoldItalic", + { alias: "Times-Roman", style: Fn, ultimate: "serif" }, + ], + [ + "Helvetica", + { + local: [ + "Helvetica", + "Helvetica Neue", + "Arial", + "Arial Nova", + "Liberation Sans", + "Arimo", + "Nimbus Sans", + "Nimbus Sans L", + "A030", + "TeX Gyre Heros", + "FreeSans", + "DejaVu Sans", + "Albany", + "Bitstream Vera Sans", + "Arial Unicode MS", + "Microsoft Sans Serif", + "Apple Symbols", + "Cantarell", + ], + path: "LiberationSans-Regular.ttf", + style: An, + ultimate: "sans-serif", + }, + ], + [ + "Helvetica-Bold", + { + alias: "Helvetica", + path: "LiberationSans-Bold.ttf", + style: Cn, + ultimate: "sans-serif", + }, + ], + [ + "Helvetica-Oblique", + { + alias: "Helvetica", + path: "LiberationSans-Italic.ttf", + style: vn, + ultimate: "sans-serif", + }, + ], + [ + "Helvetica-BoldOblique", + { + alias: "Helvetica", + path: "LiberationSans-BoldItalic.ttf", + style: Fn, + ultimate: "sans-serif", + }, + ], + [ + "Courier", + { + local: [ + "Courier", + "Courier New", + "Liberation Mono", + "Nimbus Mono", + "Nimbus Mono L", + "Cousine", + "Cumberland", + "TeX Gyre Cursor", + "FreeMono", + "Linux Libertine Mono O", + "Libertinus Mono", + ], + style: An, + ultimate: "monospace", + }, + ], + ["Courier-Bold", { alias: "Courier", style: Cn, ultimate: "monospace" }], + ["Courier-Oblique", { alias: "Courier", style: vn, ultimate: "monospace" }], + [ + "Courier-BoldOblique", + { alias: "Courier", style: Fn, ultimate: "monospace" }, + ], + [ + "ArialBlack", + { + local: ["Arial Black"], + style: { style: "normal", weight: "900" }, + fallback: "Helvetica-Bold", + }, + ], + ["ArialBlack-Bold", { alias: "ArialBlack" }], + [ + "ArialBlack-Italic", + { + alias: "ArialBlack", + style: { style: "italic", weight: "900" }, + fallback: "Helvetica-BoldOblique", + }, + ], + ["ArialBlack-BoldItalic", { alias: "ArialBlack-Italic" }], + [ + "ArialNarrow", + { + local: [ + "Arial Narrow", + "Liberation Sans Narrow", + "Helvetica Condensed", + "Nimbus Sans Narrow", + "TeX Gyre Heros Cn", + ], + style: An, + fallback: "Helvetica", + }, + ], + [ + "ArialNarrow-Bold", + { alias: "ArialNarrow", style: Cn, fallback: "Helvetica-Bold" }, + ], + [ + "ArialNarrow-Italic", + { alias: "ArialNarrow", style: vn, fallback: "Helvetica-Oblique" }, + ], + [ + "ArialNarrow-BoldItalic", + { alias: "ArialNarrow", style: Fn, fallback: "Helvetica-BoldOblique" }, + ], + [ + "Calibri", + { local: ["Calibri", "Carlito"], style: An, fallback: "Helvetica" }, + ], + [ + "Calibri-Bold", + { alias: "Calibri", style: Cn, fallback: "Helvetica-Bold" }, + ], + [ + "Calibri-Italic", + { alias: "Calibri", style: vn, fallback: "Helvetica-Oblique" }, + ], + [ + "Calibri-BoldItalic", + { alias: "Calibri", style: Fn, fallback: "Helvetica-BoldOblique" }, + ], + ["Wingdings", { local: ["Wingdings", "URW Dingbats"], style: An }], + ["Wingdings-Regular", { alias: "Wingdings" }], + ["Wingdings-Bold", { alias: "Wingdings" }], + ]), + Tn = new Map([["Arial-Black", "ArialBlack"]]); +function getFamilyName(e) { + const t = new Set([ + "thin", + "extralight", + "ultralight", + "demilight", + "semilight", + "light", + "book", + "regular", + "normal", + "medium", + "demibold", + "semibold", + "bold", + "extrabold", + "ultrabold", + "black", + "heavy", + "extrablack", + "ultrablack", + "roman", + "italic", + "oblique", + "ultracondensed", + "extracondensed", + "condensed", + "semicondensed", + "normal", + "semiexpanded", + "expanded", + "extraexpanded", + "ultraexpanded", + "bolditalic", + ]); + return e + .split(/[- ,+]+/g) + .filter((e) => !t.has(e.toLowerCase())) + .join(" "); +} +function generateFont( + { alias: e, local: t, path: a, fallback: r, style: i, ultimate: n }, + s, + o, + c = !0, + l = !0, + h = "", +) { + const u = { style: null, ultimate: null }; + if (t) { + const e = h ? ` ${h}` : ""; + for (const a of t) s.push(`local(${a}${e})`); + } + if (e) { + const t = In.get(e), + n = + h || + (function getStyleToAppend(e) { + switch (e) { + case Cn: + return "Bold"; + case vn: + return "Italic"; + case Fn: + return "Bold Italic"; + default: + if ("bold" === e?.weight) return "Bold"; + if ("italic" === e?.style) return "Italic"; + } + return ""; + })(i); + Object.assign(u, generateFont(t, s, o, c && !r, l && !a, n)); + } + i && (u.style = i); + n && (u.ultimate = n); + if (c && r) { + const e = In.get(r), + { ultimate: t } = generateFont(e, s, o, c, l && !a, h); + u.ultimate ||= t; + } + l && a && o && s.push(`url(${o}${a})`); + return u; +} +function getFontSubstitution(e, t, a, r, i, n) { + if (r.startsWith("InvalidPDFjsFont_")) return null; + ("TrueType" !== n && "Type1" !== n) || + !/^[A-Z]{6}\+/.test(r) || + (r = r.slice(7)); + const s = (r = normalizeFontName(r)); + let o = e.get(s); + if (o) return o; + let c = In.get(r); + if (!c) + for (const [e, t] of Tn) + if (r.startsWith(e)) { + r = `${t}${r.substring(e.length)}`; + c = In.get(r); + break; + } + let l = !1; + if (!c) { + c = In.get(i); + l = !0; + } + const h = `${t.getDocId()}_s${t.createFontId()}`; + if (!c) { + if (!validateFontName(r)) { + warn(`Cannot substitute the font because of its name: ${r}`); + e.set(s, null); + return null; + } + const t = /bold/gi.test(r), + a = /oblique|italic/gi.test(r), + i = (t && a && Fn) || (t && Cn) || (a && vn) || An; + o = { + css: `"${getFamilyName(r)}",${h}`, + guessFallback: !0, + loadedName: h, + baseFontName: r, + src: `local(${r})`, + style: i, + }; + e.set(s, o); + return o; + } + const u = []; + l && validateFontName(r) && u.push(`local(${r})`); + const { style: d, ultimate: f } = generateFont(c, u, a), + g = null === f, + p = g ? "" : `,${f}`; + o = { + css: `"${getFamilyName(r)}",${h}${p}`, + guessFallback: g, + loadedName: h, + baseFontName: r, + src: u.join(","), + style: d, + }; + e.set(s, o); + return o; +} +const On = 3285377520, + Mn = 4294901760, + Dn = 65535; +class MurmurHash3_64 { + constructor(e) { + this.h1 = e ? 4294967295 & e : On; + this.h2 = e ? 4294967295 & e : On; + } + update(e) { + let t, a; + if ("string" == typeof e) { + t = new Uint8Array(2 * e.length); + a = 0; + for (let r = 0, i = e.length; r < i; r++) { + const i = e.charCodeAt(r); + if (i <= 255) t[a++] = i; + else { + t[a++] = i >>> 8; + t[a++] = 255 & i; + } + } + } else { + if (!ArrayBuffer.isView(e)) + throw new Error("Invalid data format, must be a string or TypedArray."); + t = e.slice(); + a = t.byteLength; + } + const r = a >> 2, + i = a - 4 * r, + n = new Uint32Array(t.buffer, 0, r); + let s = 0, + o = 0, + c = this.h1, + l = this.h2; + const h = 3432918353, + u = 461845907, + d = 11601, + f = 13715; + for (let e = 0; e < r; e++) + if (1 & e) { + s = n[e]; + s = ((s * h) & Mn) | ((s * d) & Dn); + s = (s << 15) | (s >>> 17); + s = ((s * u) & Mn) | ((s * f) & Dn); + c ^= s; + c = (c << 13) | (c >>> 19); + c = 5 * c + 3864292196; + } else { + o = n[e]; + o = ((o * h) & Mn) | ((o * d) & Dn); + o = (o << 15) | (o >>> 17); + o = ((o * u) & Mn) | ((o * f) & Dn); + l ^= o; + l = (l << 13) | (l >>> 19); + l = 5 * l + 3864292196; + } + s = 0; + switch (i) { + case 3: + s ^= t[4 * r + 2] << 16; + case 2: + s ^= t[4 * r + 1] << 8; + case 1: + s ^= t[4 * r]; + s = ((s * h) & Mn) | ((s * d) & Dn); + s = (s << 15) | (s >>> 17); + s = ((s * u) & Mn) | ((s * f) & Dn); + 1 & r ? (c ^= s) : (l ^= s); + } + this.h1 = c; + this.h2 = l; + } + hexdigest() { + let e = this.h1, + t = this.h2; + e ^= t >>> 1; + e = ((3981806797 * e) & Mn) | ((36045 * e) & Dn); + t = + ((4283543511 * t) & Mn) | + (((2950163797 * ((t << 16) | (e >>> 16))) & Mn) >>> 16); + e ^= t >>> 1; + e = ((444984403 * e) & Mn) | ((60499 * e) & Dn); + t = + ((3301882366 * t) & Mn) | + (((3120437893 * ((t << 16) | (e >>> 16))) & Mn) >>> 16); + e ^= t >>> 1; + return ( + (e >>> 0).toString(16).padStart(8, "0") + + (t >>> 0).toString(16).padStart(8, "0") + ); + } +} +function resizeImageMask(e, t, a, r, i, n) { + const s = i * n; + let o; + o = + t <= 8 + ? new Uint8Array(s) + : t <= 16 + ? new Uint16Array(s) + : new Uint32Array(s); + const c = a / i, + l = r / n; + let h, + u, + d, + f, + g = 0; + const p = new Uint16Array(i), + m = a; + for (h = 0; h < i; h++) p[h] = Math.floor(h * c); + for (h = 0; h < n; h++) { + d = Math.floor(h * l) * m; + for (u = 0; u < i; u++) { + f = d + p[u]; + o[g++] = e[f]; + } + } + return o; +} +class PDFImage { + constructor({ + xref: e, + res: t, + image: a, + isInline: r = !1, + smask: i = null, + mask: n = null, + isMask: s = !1, + pdfFunctionFactory: o, + globalColorSpaceCache: c, + localColorSpaceCache: l, + }) { + this.image = a; + const h = a.dict, + u = h.get("F", "Filter"); + let d; + if (u instanceof Name) d = u.name; + else if (Array.isArray(u)) { + const t = e.fetchIfRef(u[0]); + t instanceof Name && (d = t.name); + } + switch (d) { + case "JPXDecode": + ({ + width: a.width, + height: a.height, + componentsCount: a.numComps, + bitsPerComponent: a.bitsPerComponent, + } = JpxImage.parseImageProperties(a.stream)); + a.stream.reset(); + const e = ImageResizer.getReducePowerForJPX( + a.width, + a.height, + a.numComps, + ); + this.jpxDecoderOptions = { + numComponents: 0, + isIndexedColormap: !1, + smaskInData: h.has("SMaskInData"), + reducePower: e, + }; + if (e) { + const t = 2 ** e; + a.width = Math.ceil(a.width / t); + a.height = Math.ceil(a.height / t); + } + break; + case "JBIG2Decode": + a.bitsPerComponent = 1; + a.numComps = 1; + } + let f = h.get("W", "Width"), + g = h.get("H", "Height"); + if ( + Number.isInteger(a.width) && + a.width > 0 && + Number.isInteger(a.height) && + a.height > 0 && + (a.width !== f || a.height !== g) + ) { + warn( + "PDFImage - using the Width/Height of the image data, rather than the image dictionary.", + ); + f = a.width; + g = a.height; + } else { + const e = "number" == typeof f && f > 0, + t = "number" == typeof g && g > 0; + if (!e || !t) { + if (!a.fallbackDims) + throw new FormatError(`Invalid image width: ${f} or height: ${g}`); + warn( + "PDFImage - using the Width/Height of the parent image, for SMask/Mask data.", + ); + e || (f = a.fallbackDims.width); + t || (g = a.fallbackDims.height); + } + } + this.width = f; + this.height = g; + this.interpolate = h.get("I", "Interpolate"); + this.imageMask = h.get("IM", "ImageMask") || !1; + this.matte = h.get("Matte") || !1; + let p = a.bitsPerComponent; + if (!p) { + p = h.get("BPC", "BitsPerComponent"); + if (!p) { + if (!this.imageMask) + throw new FormatError( + `Bits per component missing in image: ${this.imageMask}`, + ); + p = 1; + } + } + this.bpc = p; + if (!this.imageMask) { + let i = h.getRaw("CS") || h.getRaw("ColorSpace"); + const n = !!i; + if (n) + this.jpxDecoderOptions?.smaskInData && (i = Name.get("DeviceRGBA")); + else if (this.jpxDecoderOptions) i = Name.get("DeviceRGBA"); + else + switch (a.numComps) { + case 1: + i = Name.get("DeviceGray"); + break; + case 3: + i = Name.get("DeviceRGB"); + break; + case 4: + i = Name.get("DeviceCMYK"); + break; + default: + throw new Error( + `Images with ${a.numComps} color components not supported.`, + ); + } + this.colorSpace = ColorSpaceUtils.parse({ + cs: i, + xref: e, + resources: r ? t : null, + pdfFunctionFactory: o, + globalColorSpaceCache: c, + localColorSpaceCache: l, + }); + this.numComps = this.colorSpace.numComps; + if (this.jpxDecoderOptions) { + this.jpxDecoderOptions.numComponents = n ? this.numComps : 0; + this.jpxDecoderOptions.isIndexedColormap = + "Indexed" === this.colorSpace.name; + } + } + this.decode = h.getArray("D", "Decode"); + this.needsDecode = !1; + if ( + this.decode && + ((this.colorSpace && !this.colorSpace.isDefaultDecode(this.decode, p)) || + (s && !ColorSpace.isDefaultDecode(this.decode, 1))) + ) { + this.needsDecode = !0; + const e = (1 << p) - 1; + this.decodeCoefficients = []; + this.decodeAddends = []; + const t = "Indexed" === this.colorSpace?.name; + for (let a = 0, r = 0; a < this.decode.length; a += 2, ++r) { + const i = this.decode[a], + n = this.decode[a + 1]; + this.decodeCoefficients[r] = t ? (n - i) / e : n - i; + this.decodeAddends[r] = t ? i : e * i; + } + } + if (i) { + i.fallbackDims ??= { width: f, height: g }; + this.smask = new PDFImage({ + xref: e, + res: t, + image: i, + isInline: r, + pdfFunctionFactory: o, + globalColorSpaceCache: c, + localColorSpaceCache: l, + }); + } else if (n) + if (n instanceof BaseStream) { + if (n.dict.get("IM", "ImageMask")) { + n.fallbackDims ??= { width: f, height: g }; + this.mask = new PDFImage({ + xref: e, + res: t, + image: n, + isInline: r, + isMask: !0, + pdfFunctionFactory: o, + globalColorSpaceCache: c, + localColorSpaceCache: l, + }); + } else warn("Ignoring /Mask in image without /ImageMask."); + } else this.mask = n; + } + static async buildImage({ + xref: e, + res: t, + image: a, + isInline: r = !1, + pdfFunctionFactory: i, + globalColorSpaceCache: n, + localColorSpaceCache: s, + }) { + const o = a; + let c = null, + l = null; + const h = a.dict.get("SMask"), + u = a.dict.get("Mask"); + h + ? h instanceof BaseStream + ? (c = h) + : warn("Unsupported /SMask format.") + : u && + (u instanceof BaseStream || Array.isArray(u) + ? (l = u) + : warn("Unsupported /Mask format.")); + return new PDFImage({ + xref: e, + res: t, + image: o, + isInline: r, + smask: c, + mask: l, + pdfFunctionFactory: i, + globalColorSpaceCache: n, + localColorSpaceCache: s, + }); + } + static async createMask({ image: e, isOffscreenCanvasSupported: t = !1 }) { + const { dict: a } = e, + r = a.get("W", "Width"), + i = a.get("H", "Height"), + n = a.get("I", "Interpolate"), + s = a.getArray("D", "Decode"), + o = s?.[0] > 0, + c = ((r + 7) >> 3) * i, + l = e.getBytes(c), + h = 1 === r && 1 === i && o === (0 === l.length || !!(128 & l[0])); + if (h) return { isSingleOpaquePixel: h }; + if (t) { + if (ImageResizer.needsToBeResized(r, i)) { + const e = new Uint8ClampedArray(r * i * 4); + convertBlackAndWhiteToRGBA({ + src: l, + dest: e, + width: r, + height: i, + nonBlackColor: 0, + inverseDecode: o, + }); + return ImageResizer.createImage({ + kind: v, + data: e, + width: r, + height: i, + interpolate: n, + }); + } + const e = new OffscreenCanvas(r, i), + t = e.getContext("2d"), + a = t.createImageData(r, i); + convertBlackAndWhiteToRGBA({ + src: l, + dest: a.data, + width: r, + height: i, + nonBlackColor: 0, + inverseDecode: o, + }); + t.putImageData(a, 0, 0); + return { + data: null, + width: r, + height: i, + interpolate: n, + bitmap: e.transferToImageBitmap(), + }; + } + const u = l.byteLength; + let d; + if (e instanceof DecodeStream && (!o || c === u)) d = l; + else if (o) { + d = new Uint8Array(c); + d.set(l); + d.fill(255, u); + } else d = new Uint8Array(l); + if (o) for (let e = 0; e < u; e++) d[e] ^= 255; + return { data: d, width: r, height: i, interpolate: n }; + } + get drawWidth() { + return Math.max(this.width, this.smask?.width || 0, this.mask?.width || 0); + } + get drawHeight() { + return Math.max( + this.height, + this.smask?.height || 0, + this.mask?.height || 0, + ); + } + decodeBuffer(e) { + const t = this.bpc, + a = this.numComps, + r = this.decodeAddends, + i = this.decodeCoefficients, + n = (1 << t) - 1; + let s, o; + if (1 === t) { + for (s = 0, o = e.length; s < o; s++) e[s] = +!e[s]; + return; + } + let c = 0; + for (s = 0, o = this.width * this.height; s < o; s++) + for (let t = 0; t < a; t++) { + e[c] = MathClamp(r[t] + e[c] * i[t], 0, n); + c++; + } + } + getComponents(e) { + const t = this.bpc; + if (8 === t) return e; + const a = this.width, + r = this.height, + i = this.numComps, + n = a * r * i; + let s, + o = 0; + s = + t <= 8 + ? new Uint8Array(n) + : t <= 16 + ? new Uint16Array(n) + : new Uint32Array(n); + const c = a * i, + l = (1 << t) - 1; + let h, + u, + d = 0; + if (1 === t) { + let t, a, i; + for (let n = 0; n < r; n++) { + a = d + (-8 & c); + i = d + c; + for (; d < a; ) { + u = e[o++]; + s[d] = (u >> 7) & 1; + s[d + 1] = (u >> 6) & 1; + s[d + 2] = (u >> 5) & 1; + s[d + 3] = (u >> 4) & 1; + s[d + 4] = (u >> 3) & 1; + s[d + 5] = (u >> 2) & 1; + s[d + 6] = (u >> 1) & 1; + s[d + 7] = 1 & u; + d += 8; + } + if (d < i) { + u = e[o++]; + t = 128; + for (; d < i; ) { + s[d++] = +!!(u & t); + t >>= 1; + } + } + } + } else { + let a = 0; + u = 0; + for (d = 0, h = n; d < h; ++d) { + if (d % c == 0) { + u = 0; + a = 0; + } + for (; a < t; ) { + u = (u << 8) | e[o++]; + a += 8; + } + const r = a - t; + let i = u >> r; + i < 0 ? (i = 0) : i > l && (i = l); + s[d] = i; + u &= (1 << r) - 1; + a = r; + } + } + return s; + } + async fillOpacity(e, t, a, r, i) { + const n = this.smask, + s = this.mask; + let o, c, l, h, u, d; + if (n) { + c = n.width; + l = n.height; + o = new Uint8ClampedArray(c * l); + await n.fillGrayBuffer(o); + (c === t && l === a) || (o = resizeImageMask(o, n.bpc, c, l, t, a)); + } else if (s) + if (s instanceof PDFImage) { + c = s.width; + l = s.height; + o = new Uint8ClampedArray(c * l); + s.numComps = 1; + await s.fillGrayBuffer(o); + for (h = 0, u = c * l; h < u; ++h) o[h] = 255 - o[h]; + (c === t && l === a) || (o = resizeImageMask(o, s.bpc, c, l, t, a)); + } else { + if (!Array.isArray(s)) throw new FormatError("Unknown mask format."); + { + o = new Uint8ClampedArray(t * a); + const e = this.numComps; + for (h = 0, u = t * a; h < u; ++h) { + let t = 0; + const a = h * e; + for (d = 0; d < e; ++d) { + const e = i[a + d], + r = 2 * d; + if (e < s[r] || e > s[r + 1]) { + t = 255; + break; + } + } + o[h] = t; + } + } + } + if (o) for (h = 0, d = 3, u = t * r; h < u; ++h, d += 4) e[d] = o[h]; + else for (h = 0, d = 3, u = t * r; h < u; ++h, d += 4) e[d] = 255; + } + undoPreblend(e, t, a) { + const r = this.smask?.matte; + if (!r) return; + const i = this.colorSpace.getRgb(r, 0), + n = i[0], + s = i[1], + o = i[2], + c = t * a * 4; + for (let t = 0; t < c; t += 4) { + const a = e[t + 3]; + if (0 === a) { + e[t] = 255; + e[t + 1] = 255; + e[t + 2] = 255; + continue; + } + const r = 255 / a; + e[t] = (e[t] - n) * r + n; + e[t + 1] = (e[t + 1] - s) * r + s; + e[t + 2] = (e[t + 2] - o) * r + o; + } + } + async createImageData(e = !1, t = !1) { + const a = this.drawWidth, + r = this.drawHeight, + i = { + width: a, + height: r, + interpolate: this.interpolate, + kind: 0, + data: null, + }, + n = this.numComps, + s = this.width, + o = this.height, + c = this.bpc, + l = (s * n * c + 7) >> 3, + h = t && ImageResizer.needsToBeResized(a, r); + if (!this.smask && !this.mask && "DeviceRGBA" === this.colorSpace.name) { + i.kind = v; + const e = (i.data = await this.getImageBytes(o * s * 4, {})); + return t + ? h + ? ImageResizer.createImage(i, !1) + : this.createBitmap(v, a, r, e) + : i; + } + if (!e) { + let e; + "DeviceGray" === this.colorSpace.name && 1 === c + ? (e = k) + : "DeviceRGB" !== this.colorSpace.name || + 8 !== c || + this.needsDecode || + (e = C); + if (e && !this.smask && !this.mask && a === s && r === o) { + const n = await this.#$(s, o); + if (n) return n; + const c = await this.getImageBytes(o * l, {}); + if (t) + return h + ? ImageResizer.createImage( + { + data: c, + kind: e, + width: a, + height: r, + interpolate: this.interpolate, + }, + this.needsDecode, + ) + : this.createBitmap(e, s, o, c); + i.kind = e; + i.data = c; + if (this.needsDecode) { + assert( + e === k, + "PDFImage.createImageData: The image must be grayscale.", + ); + const t = i.data; + for (let e = 0, a = t.length; e < a; e++) t[e] ^= 255; + } + return i; + } + if ( + this.image instanceof JpegStream && + !this.smask && + !this.mask && + !this.needsDecode + ) { + let e = o * l; + if (t && !h) { + let t = !1; + switch (this.colorSpace.name) { + case "DeviceGray": + e *= 4; + t = !0; + break; + case "DeviceRGB": + e = (e / 3) * 4; + t = !0; + break; + case "DeviceCMYK": + t = !0; + } + if (t) { + const t = await this.#$(a, r); + if (t) return t; + const i = await this.getImageBytes(e, { + drawWidth: a, + drawHeight: r, + forceRGBA: !0, + }); + return this.createBitmap(v, a, r, i); + } + } else + switch (this.colorSpace.name) { + case "DeviceGray": + e *= 3; + case "DeviceRGB": + case "DeviceCMYK": + i.kind = C; + i.data = await this.getImageBytes(e, { + drawWidth: a, + drawHeight: r, + forceRGB: !0, + }); + return h ? ImageResizer.createImage(i) : i; + } + } + } + const u = await this.getImageBytes(o * l, { internal: !0 }), + d = 0 | (((u.length / l) * r) / o), + f = this.getComponents(u); + let g, p, m, b, y, w; + if (t && !h) { + m = new OffscreenCanvas(a, r); + b = m.getContext("2d"); + y = b.createImageData(a, r); + w = y.data; + } + i.kind = v; + if (e || this.smask || this.mask) { + (t && !h) || (w = new Uint8ClampedArray(a * r * 4)); + g = 1; + p = !0; + await this.fillOpacity(w, a, r, d, f); + } else { + if (!t || h) { + i.kind = C; + w = new Uint8ClampedArray(a * r * 3); + g = 0; + } else { + new Uint32Array(w.buffer).fill( + FeatureTest.isLittleEndian ? 4278190080 : 255, + ); + g = 1; + } + p = !1; + } + this.needsDecode && this.decodeBuffer(f); + this.colorSpace.fillRgb(w, s, o, a, r, d, c, f, g); + p && this.undoPreblend(w, a, d); + if (t && !h) { + b.putImageData(y, 0, 0); + return { + data: null, + width: a, + height: r, + bitmap: m.transferToImageBitmap(), + interpolate: this.interpolate, + }; + } + i.data = w; + return h ? ImageResizer.createImage(i) : i; + } + async fillGrayBuffer(e) { + const t = this.numComps; + if (1 !== t) + throw new FormatError(`Reading gray scale from a color image: ${t}`); + const a = this.width, + r = this.height, + i = this.bpc, + n = (a * t * i + 7) >> 3, + s = await this.getImageBytes(r * n, { internal: !0 }), + o = this.getComponents(s); + let c, l; + if (1 === i) { + l = a * r; + if (this.needsDecode) for (c = 0; c < l; ++c) e[c] = (o[c] - 1) & 255; + else for (c = 0; c < l; ++c) e[c] = 255 & -o[c]; + return; + } + this.needsDecode && this.decodeBuffer(o); + l = a * r; + const h = 255 / ((1 << i) - 1); + for (c = 0; c < l; ++c) e[c] = h * o[c]; + } + createBitmap(e, t, a, r) { + const i = new OffscreenCanvas(t, a), + n = i.getContext("2d"); + let s; + if (e === v) s = new ImageData(r, t, a); + else { + s = n.createImageData(t, a); + convertToRGBA({ + kind: e, + src: r, + dest: new Uint32Array(s.data.buffer), + width: t, + height: a, + inverseDecode: this.needsDecode, + }); + } + n.putImageData(s, 0, 0); + return { + data: null, + width: t, + height: a, + bitmap: i.transferToImageBitmap(), + interpolate: this.interpolate, + }; + } + async #$(e, t) { + const a = await this.image.getTransferableImage(); + return a + ? { + data: null, + width: e, + height: t, + bitmap: a, + interpolate: this.interpolate, + } + : null; + } + async getImageBytes( + e, + { + drawWidth: t, + drawHeight: a, + forceRGBA: r = !1, + forceRGB: i = !1, + internal: n = !1, + }, + ) { + this.image.reset(); + this.image.drawWidth = t || this.width; + this.image.drawHeight = a || this.height; + this.image.forceRGBA = !!r; + this.image.forceRGB = !!i; + const s = await this.image.getImageData(e, this.jpxDecoderOptions); + if (n || this.image instanceof DecodeStream) return s; + assert( + s instanceof Uint8Array, + 'PDFImage.getImageBytes: Unsupported "imageBytes" type.', + ); + return new Uint8Array(s); + } +} +const Bn = Object.freeze({ + maxImageSize: -1, + disableFontFace: !1, + ignoreErrors: !1, + isEvalSupported: !0, + isOffscreenCanvasSupported: !1, + isImageDecoderSupported: !1, + canvasMaxAreaInBytes: -1, + fontExtraProperties: !1, + useSystemFonts: !0, + useWasm: !0, + useWorkerFetch: !0, + cMapUrl: null, + iccUrl: null, + standardFontDataUrl: null, + wasmUrl: null, + }), + Rn = 1, + Nn = 2, + En = Promise.resolve(); +function normalizeBlendMode(e, t = !1) { + if (Array.isArray(e)) { + for (const t of e) { + const e = normalizeBlendMode(t, !0); + if (e) return e; + } + warn(`Unsupported blend mode Array: ${e}`); + return "source-over"; + } + if (!(e instanceof Name)) return t ? null : "source-over"; + switch (e.name) { + case "Normal": + case "Compatible": + return "source-over"; + case "Multiply": + return "multiply"; + case "Screen": + return "screen"; + case "Overlay": + return "overlay"; + case "Darken": + return "darken"; + case "Lighten": + return "lighten"; + case "ColorDodge": + return "color-dodge"; + case "ColorBurn": + return "color-burn"; + case "HardLight": + return "hard-light"; + case "SoftLight": + return "soft-light"; + case "Difference": + return "difference"; + case "Exclusion": + return "exclusion"; + case "Hue": + return "hue"; + case "Saturation": + return "saturation"; + case "Color": + return "color"; + case "Luminosity": + return "luminosity"; + } + if (t) return null; + warn(`Unsupported blend mode: ${e.name}`); + return "source-over"; +} +function addCachedImageOps( + e, + { objId: t, fn: a, args: r, optionalContent: i, hasMask: n }, +) { + t && e.addDependency(t); + e.addImageOps(a, r, i, n); + a === Vt && r[0]?.count > 0 && r[0].count++; +} +class TimeSlotManager { + static TIME_SLOT_DURATION_MS = 20; + static CHECK_TIME_EVERY = 100; + constructor() { + this.reset(); + } + check() { + if (++this.checked < TimeSlotManager.CHECK_TIME_EVERY) return !1; + this.checked = 0; + return this.endTime <= Date.now(); + } + reset() { + this.endTime = Date.now() + TimeSlotManager.TIME_SLOT_DURATION_MS; + this.checked = 0; + } +} +class PartialEvaluator { + constructor({ + xref: e, + handler: t, + pageIndex: a, + idFactory: r, + fontCache: i, + builtInCMapCache: n, + standardFontDataCache: s, + globalColorSpaceCache: o, + globalImageCache: c, + systemFontCache: l, + options: h = null, + }) { + this.xref = e; + this.handler = t; + this.pageIndex = a; + this.idFactory = r; + this.fontCache = i; + this.builtInCMapCache = n; + this.standardFontDataCache = s; + this.globalColorSpaceCache = o; + this.globalImageCache = c; + this.systemFontCache = l; + this.options = h || Bn; + this.type3FontRefs = null; + this._regionalImageCache = new RegionalImageCache(); + this._fetchBuiltInCMapBound = this.fetchBuiltInCMap.bind(this); + } + get _pdfFunctionFactory() { + return shadow( + this, + "_pdfFunctionFactory", + new PDFFunctionFactory({ + xref: this.xref, + isEvalSupported: this.options.isEvalSupported, + }), + ); + } + get parsingType3Font() { + return !!this.type3FontRefs; + } + clone(e = null) { + const t = Object.create(this); + t.options = Object.assign(Object.create(null), this.options, e); + return t; + } + hasBlendModes(e, t) { + if (!(e instanceof Dict)) return !1; + if (e.objId && t.has(e.objId)) return !1; + const a = new RefSet(t); + e.objId && a.put(e.objId); + const r = [e], + i = this.xref; + for (; r.length; ) { + const e = r.shift(), + t = e.get("ExtGState"); + if (t instanceof Dict) + for (let e of t.getRawValues()) { + if (e instanceof Ref) { + if (a.has(e)) continue; + try { + e = i.fetch(e); + } catch (t) { + a.put(e); + info(`hasBlendModes - ignoring ExtGState: "${t}".`); + continue; + } + } + if (!(e instanceof Dict)) continue; + e.objId && a.put(e.objId); + const t = e.get("BM"); + if (t instanceof Name) { + if ("Normal" !== t.name) return !0; + } else if (void 0 !== t && Array.isArray(t)) + for (const e of t) + if (e instanceof Name && "Normal" !== e.name) return !0; + } + const n = e.get("XObject"); + if (n instanceof Dict) + for (let e of n.getRawValues()) { + if (e instanceof Ref) { + if (a.has(e)) continue; + try { + e = i.fetch(e); + } catch (t) { + a.put(e); + info(`hasBlendModes - ignoring XObject: "${t}".`); + continue; + } + } + if (!(e instanceof BaseStream)) continue; + e.dict.objId && a.put(e.dict.objId); + const t = e.dict.get("Resources"); + if (t instanceof Dict && (!t.objId || !a.has(t.objId))) { + r.push(t); + t.objId && a.put(t.objId); + } + } + } + for (const e of a) t.put(e); + return !1; + } + async fetchBuiltInCMap(e) { + const t = this.builtInCMapCache.get(e); + if (t) return t; + let a; + a = this.options.useWorkerFetch + ? { + cMapData: await fetchBinaryData(`${this.options.cMapUrl}${e}.bcmap`), + isCompressed: !0, + } + : await this.handler.sendWithPromise("FetchBinaryData", { + type: "cMapReaderFactory", + name: e, + }); + this.builtInCMapCache.set(e, a); + return a; + } + async fetchStandardFontData(e) { + const t = this.standardFontDataCache.get(e); + if (t) return new Stream(t); + if (this.options.useSystemFonts && "Symbol" !== e && "ZapfDingbats" !== e) + return null; + const a = Yr()[e]; + let r; + try { + r = this.options.useWorkerFetch + ? await fetchBinaryData(`${this.options.standardFontDataUrl}${a}`) + : await this.handler.sendWithPromise("FetchBinaryData", { + type: "standardFontDataFactory", + filename: a, + }); + } catch (e) { + warn(e); + return null; + } + this.standardFontDataCache.set(e, r); + return new Stream(r); + } + async buildFormXObject(e, t, a, r, i, n, s, o) { + const { dict: c } = t, + l = lookupMatrix(c.getArray("Matrix"), null), + h = lookupNormalRect(c.getArray("BBox"), null); + let u, d; + c.has("OC") && (u = await this.parseMarkedContentProps(c.get("OC"), e)); + void 0 !== u && r.addOp(jt, ["OC", u]); + const f = c.get("Group"); + if (f) { + d = { matrix: l, bbox: h, smask: a, isolated: !1, knockout: !1 }; + let t = null; + if (isName(f.get("S"), "Transparency")) { + d.isolated = f.get("I") || !1; + d.knockout = f.get("K") || !1; + if (f.has("CS")) { + const a = this._getColorSpace(f.getRaw("CS"), e, s); + t = a instanceof ColorSpace ? a : await this._handleColorSpace(a); + } + } + if (a?.backdrop) { + t ||= ColorSpaceUtils.rgb; + a.backdrop = t.getRgbHex(a.backdrop, 0); + } + r.addOp(Wt, [d]); + } + const g = [ + l && new Float32Array(l), + (!f && h && new Float32Array(h)) || null, + ]; + r.addOp(qt, g); + const p = c.get("Resources"); + await this.getOperatorList({ + stream: t, + task: i, + resources: p instanceof Dict ? p : e, + operatorList: r, + initialState: n, + prevRefs: o, + }); + r.addOp(Ht, []); + f && r.addOp(zt, [d]); + void 0 !== u && r.addOp(_t, []); + } + _sendImgData(e, t, a = !1) { + const r = t ? [t.bitmap || t.data.buffer] : null; + return this.parsingType3Font || a + ? this.handler.send("commonobj", [e, "Image", t], r) + : this.handler.send("obj", [e, this.pageIndex, "Image", t], r); + } + async buildPaintImageXObject({ + resources: e, + image: t, + isInline: a = !1, + operatorList: r, + cacheKey: i, + localImageCache: n, + localColorSpaceCache: s, + }) { + const { + maxImageSize: o, + ignoreErrors: c, + isOffscreenCanvasSupported: l, + } = this.options, + { dict: h } = t, + u = h.objId, + d = h.get("W", "Width"), + f = h.get("H", "Height"); + if (!d || "number" != typeof d || !f || "number" != typeof f) { + warn("Image dimensions are missing, or not numbers."); + return; + } + if (-1 !== o && d * f > o) { + const e = "Image exceeded maximum allowed size and was removed."; + if (!c) throw new Error(e); + warn(e); + return; + } + let g; + h.has("OC") && (g = await this.parseMarkedContentProps(h.get("OC"), e)); + let p, m, b; + if (h.get("IM", "ImageMask") || !1) { + p = await PDFImage.createMask({ + image: t, + isOffscreenCanvasSupported: l && !this.parsingType3Font, + }); + if (p.isSingleOpaquePixel) { + m = ta; + b = []; + r.addImageOps(m, b, g); + if (i) { + const e = { fn: m, args: b, optionalContent: g }; + n.set(i, u, e); + u && this._regionalImageCache.set(null, u, e); + } + return; + } + if (this.parsingType3Font) { + b = (function compileType3Glyph({ data: e, width: t, height: a }) { + if (t > 1e3 || a > 1e3) return null; + const r = new Uint8Array([ + 0, 2, 4, 0, 1, 0, 5, 4, 8, 10, 0, 8, 0, 2, 1, 0, + ]), + i = t + 1, + n = new Uint8Array(i * (a + 1)); + let s, o, c; + const l = (t + 7) & -8, + h = new Uint8Array(l * a); + let u = 0; + for (const t of e) { + let e = 128; + for (; e > 0; ) { + h[u++] = t & e ? 0 : 255; + e >>= 1; + } + } + let d = 0; + u = 0; + if (0 !== h[u]) { + n[0] = 1; + ++d; + } + for (o = 1; o < t; o++) { + if (h[u] !== h[u + 1]) { + n[o] = h[u] ? 2 : 1; + ++d; + } + u++; + } + if (0 !== h[u]) { + n[o] = 2; + ++d; + } + for (s = 1; s < a; s++) { + u = s * l; + c = s * i; + if (h[u - l] !== h[u]) { + n[c] = h[u] ? 1 : 8; + ++d; + } + let e = (h[u] ? 4 : 0) + (h[u - l] ? 8 : 0); + for (o = 1; o < t; o++) { + e = (e >> 2) + (h[u + 1] ? 4 : 0) + (h[u - l + 1] ? 8 : 0); + if (r[e]) { + n[c + o] = r[e]; + ++d; + } + u++; + } + if (h[u - l] !== h[u]) { + n[c + o] = h[u] ? 2 : 4; + ++d; + } + if (d > 1e3) return null; + } + u = l * (a - 1); + c = s * i; + if (0 !== h[u]) { + n[c] = 8; + ++d; + } + for (o = 1; o < t; o++) { + if (h[u] !== h[u + 1]) { + n[c + o] = h[u] ? 4 : 8; + ++d; + } + u++; + } + if (0 !== h[u]) { + n[c + o] = 4; + ++d; + } + if (d > 1e3) return null; + const f = new Int32Array([0, i, -1, 0, -i, 0, 0, 0, 1]), + g = [], + { + a: p, + b: m, + c: b, + d: y, + e: w, + f: x, + } = new DOMMatrix().scaleSelf(1 / t, -1 / a).translateSelf(0, -a); + for (s = 0; d && s <= a; s++) { + let e = s * i; + const a = e + t; + for (; e < a && !n[e]; ) e++; + if (e === a) continue; + let r = e % i, + o = s; + g.push(sa, p * r + b * o + w, m * r + y * o + x); + const c = e; + let l = n[e]; + do { + const t = f[l]; + do { + e += t; + } while (!n[e]); + const a = n[e]; + if (5 !== a && 10 !== a) { + l = a; + n[e] = 0; + } else { + l = a & ((51 * l) >> 4); + n[e] &= (l >> 2) | (l << 2); + } + r = e % i; + o = (e / i) | 0; + g.push(oa, p * r + b * o + w, m * r + y * o + x); + n[e] || --d; + } while (c !== e); + --s; + } + return [na, [new Float32Array(g)], new Float32Array([0, 0, t, a])]; + })(p); + if (b) { + r.addImageOps(aa, b, g); + return; + } + warn("Cannot compile Type3 glyph."); + r.addImageOps(Vt, [p], g); + return; + } + const e = `mask_${this.idFactory.createObjId()}`; + r.addDependency(e); + p.dataLen = p.bitmap ? p.width * p.height * 4 : p.data.length; + this._sendImgData(e, p); + m = Vt; + b = [ + { + data: e, + width: p.width, + height: p.height, + interpolate: p.interpolate, + count: 1, + }, + ]; + r.addImageOps(m, b, g); + if (i) { + const t = { objId: e, fn: m, args: b, optionalContent: g }; + n.set(i, u, t); + u && this._regionalImageCache.set(null, u, t); + } + return; + } + const y = h.has("SMask") || h.has("Mask"); + if (a && d + f < 200 && !y) { + try { + const i = new PDFImage({ + xref: this.xref, + res: e, + image: t, + isInline: a, + pdfFunctionFactory: this._pdfFunctionFactory, + globalColorSpaceCache: this.globalColorSpaceCache, + localColorSpaceCache: s, + }); + p = await i.createImageData(!0, !1); + r.addImageOps(Yt, [p], g); + } catch (e) { + const t = `Unable to decode inline image: "${e}".`; + if (!c) throw new Error(t); + warn(t); + } + return; + } + let w = `img_${this.idFactory.createObjId()}`, + x = !1, + S = null; + if (this.parsingType3Font) w = `${this.idFactory.getDocId()}_type3_${w}`; + else if (i && u) { + x = this.globalImageCache.shouldCache(u, this.pageIndex); + if (x) { + assert(!a, "Cannot cache an inline image globally."); + w = `${this.idFactory.getDocId()}_${w}`; + } + } + r.addDependency(w); + m = Jt; + b = [w, d, f]; + r.addImageOps(m, b, g, y); + if (x) { + S = { + objId: w, + fn: m, + args: b, + optionalContent: g, + hasMask: y, + byteSize: 0, + }; + if (this.globalImageCache.hasDecodeFailed(u)) { + this.globalImageCache.setData(u, S); + this._sendImgData(w, null, x); + return; + } + if (d * f > 25e4 || y) { + const e = await this.handler.sendWithPromise("commonobj", [ + w, + "CopyLocalImage", + { imageRef: u }, + ]); + if (e) { + this.globalImageCache.setData(u, S); + this.globalImageCache.addByteSize(u, e); + return; + } + } + } + PDFImage.buildImage({ + xref: this.xref, + res: e, + image: t, + isInline: a, + pdfFunctionFactory: this._pdfFunctionFactory, + globalColorSpaceCache: this.globalColorSpaceCache, + localColorSpaceCache: s, + }) + .then(async (e) => { + p = await e.createImageData(!1, l); + p.dataLen = p.bitmap ? p.width * p.height * 4 : p.data.length; + p.ref = u; + x && this.globalImageCache.addByteSize(u, p.dataLen); + return this._sendImgData(w, p, x); + }) + .catch((e) => { + warn(`Unable to decode image "${w}": "${e}".`); + u && this.globalImageCache.addDecodeFailed(u); + return this._sendImgData(w, null, x); + }); + if (i) { + const e = { objId: w, fn: m, args: b, optionalContent: g, hasMask: y }; + n.set(i, u, e); + if (u) { + this._regionalImageCache.set(null, u, e); + if (x) { + assert(S, "The global cache-data must be available."); + this.globalImageCache.setData(u, S); + } + } + } + } + handleSMask(e, t, a, r, i, n, s) { + const o = e.get("G"), + c = { subtype: e.get("S").name, backdrop: e.get("BC") }, + l = e.get("TR"); + if (isPDFFunction(l)) { + const e = this._pdfFunctionFactory.create(l), + t = new Uint8Array(256), + a = new Float32Array(1); + for (let r = 0; r < 256; r++) { + a[0] = r / 255; + e(a, 0, a, 0); + t[r] = (255 * a[0]) | 0; + } + c.transferMap = t; + } + return this.buildFormXObject( + t, + o, + c, + a, + r, + i.state.clone({ newPath: !0 }), + n, + s, + ); + } + handleTransferFunction(e) { + let t; + if (Array.isArray(e)) t = e; + else { + if (!isPDFFunction(e)) return null; + t = [e]; + } + const a = []; + let r = 0, + i = 0; + for (const e of t) { + const t = this.xref.fetchIfRef(e); + r++; + if (isName(t, "Identity")) { + a.push(null); + continue; + } + if (!isPDFFunction(t)) return null; + const n = this._pdfFunctionFactory.create(t), + s = new Uint8Array(256), + o = new Float32Array(1); + for (let e = 0; e < 256; e++) { + o[0] = e / 255; + n(o, 0, o, 0); + s[e] = (255 * o[0]) | 0; + } + a.push(s); + i++; + } + return (1 !== r && 4 !== r) || 0 === i ? null : a; + } + handleTilingType(e, t, a, r, i, n, s, o) { + const c = new OperatorList(), + l = Dict.merge({ xref: this.xref, dictArray: [i.get("Resources"), a] }); + return this.getOperatorList({ + stream: r, + task: s, + resources: l, + operatorList: c, + }) + .then(function () { + const a = c.getIR(), + r = getTilingPatternIR(a, i, t); + n.addDependencies(c.dependencies); + n.addOp(e, r); + i.objId && o.set(null, i.objId, { operatorListIR: a, dict: i }); + }) + .catch((e) => { + if (!(e instanceof AbortException)) { + if (!this.options.ignoreErrors) throw e; + warn(`handleTilingType - ignoring pattern: "${e}".`); + } + }); + } + async handleSetFont(e, t, a, r, i, n, s = null, o = null) { + const c = t?.[0] instanceof Name ? t[0].name : null, + l = await this.loadFont(c, a, e, i, s, o); + l.font.isType3Font && r.addDependencies(l.type3Dependencies); + n.font = l.font; + l.send(this.handler); + return l.loadedName; + } + handleText(e, t) { + const a = t.font, + r = a.charsToGlyphs(e); + if (a.data) { + (!!(t.textRenderingMode & S) || + "Pattern" === t.fillColorSpace.name || + a.disableFontFace) && + PartialEvaluator.buildFontPaths(a, r, this.handler, this.options); + } + return r; + } + ensureStateFont(e) { + if (e.font) return; + const t = new FormatError( + "Missing setFont (Tf) operator before text rendering operator.", + ); + if (!this.options.ignoreErrors) throw t; + warn(`ensureStateFont: "${t}".`); + } + async setGState({ + resources: e, + gState: t, + operatorList: a, + cacheKey: r, + task: i, + stateManager: n, + localGStateCache: s, + localColorSpaceCache: o, + seenRefs: c, + }) { + const l = t.objId; + let h = !0; + const u = []; + let d = Promise.resolve(); + for (const [r, s] of t) + switch (r) { + case "Type": + break; + case "LW": + if ("number" != typeof s) { + warn(`Invalid LW (line width): ${s}`); + break; + } + u.push([r, Math.abs(s)]); + break; + case "LC": + case "LJ": + case "ML": + case "D": + case "RI": + case "FL": + case "CA": + case "ca": + u.push([r, s]); + break; + case "Font": + h = !1; + d = d.then(() => + this.handleSetFont(e, null, s[0], a, i, n.state).then(function (e) { + a.addDependency(e); + u.push([r, [e, s[1]]]); + }), + ); + break; + case "BM": + u.push([r, normalizeBlendMode(s)]); + break; + case "SMask": + if (isName(s, "None")) { + u.push([r, !1]); + break; + } + if (s instanceof Dict) { + h = !1; + d = d.then(() => this.handleSMask(s, e, a, i, n, o, c)); + u.push([r, !0]); + } else warn("Unsupported SMask type"); + break; + case "TR": + const t = this.handleTransferFunction(s); + u.push([r, t]); + break; + case "OP": + case "op": + case "OPM": + case "BG": + case "BG2": + case "UCR": + case "UCR2": + case "TR2": + case "HT": + case "SM": + case "SA": + case "AIS": + case "TK": + info("graphic state operator " + r); + break; + default: + info("Unknown graphic state operator " + r); + } + await d; + u.length > 0 && a.addOp(De, [u]); + h && s.set(r, l, u); + } + loadFont(e, t, a, r, i = null, n = null) { + const errorFont = async () => + new TranslatedFont({ + loadedName: "g_font_error", + font: new ErrorFont(`Font "${e}" is not available.`), + dict: t, + }); + let s; + if (t) t instanceof Ref && (s = t); + else { + const t = a.get("Font"); + t && (s = t.getRaw(e)); + } + if (s) { + if (this.type3FontRefs?.has(s)) return errorFont(); + if (this.fontCache.has(s)) return this.fontCache.get(s); + try { + t = this.xref.fetchIfRef(s); + } catch (e) { + warn(`loadFont - lookup failed: "${e}".`); + } + } + if (!(t instanceof Dict)) { + if (!this.options.ignoreErrors && !this.parsingType3Font) { + warn(`Font "${e}" is not available.`); + return errorFont(); + } + warn( + `Font "${e}" is not available -- attempting to fallback to a default font.`, + ); + t = i || PartialEvaluator.fallbackFontDict; + } + if (t.cacheKey && this.fontCache.has(t.cacheKey)) + return this.fontCache.get(t.cacheKey); + const { promise: o, resolve: c } = Promise.withResolvers(); + let l; + try { + l = this.preEvaluateFont(t); + l.cssFontInfo = n; + } catch (e) { + warn(`loadFont - preEvaluateFont failed: "${e}".`); + return errorFont(); + } + const { descriptor: h, hash: u } = l, + d = s instanceof Ref; + let f; + if (u && h instanceof Dict) { + const e = (h.fontAliases ||= Object.create(null)); + if (e[u]) { + const t = e[u].aliasRef; + if (d && t && this.fontCache.has(t)) { + this.fontCache.putAlias(s, t); + return this.fontCache.get(s); + } + } else e[u] = { fontID: this.idFactory.createFontId() }; + d && (e[u].aliasRef = s); + f = e[u].fontID; + } else f = this.idFactory.createFontId(); + assert(f?.startsWith("f"), 'The "fontID" must be (correctly) defined.'); + if (d) this.fontCache.put(s, o); + else { + t.cacheKey = `cacheKey_${f}`; + this.fontCache.put(t.cacheKey, o); + } + t.loadedName = `${this.idFactory.getDocId()}_${f}`; + this.translateFont(l) + .then(async (e) => { + const i = new TranslatedFont({ + loadedName: t.loadedName, + font: e, + dict: t, + }); + if (e.isType3Font) + try { + await i.loadType3Data(this, a, r); + } catch (e) { + throw new Error(`Type3 font load error: ${e}`); + } + c(i); + }) + .catch((e) => { + warn(`loadFont - translateFont failed: "${e}".`); + c( + new TranslatedFont({ + loadedName: t.loadedName, + font: new ErrorFont(e?.message), + dict: t, + }), + ); + }); + return o; + } + buildPath(e, t, a) { + const { pathMinMax: r, pathBuffer: i } = a; + switch (0 | e) { + case Xe: { + const e = (a.currentPointX = t[0]), + n = (a.currentPointY = t[1]), + s = t[2], + o = t[3], + c = e + s, + l = n + o; + 0 === s || 0 === o + ? i.push(sa, e, n, oa, c, l, la) + : i.push(sa, e, n, oa, c, n, oa, c, l, oa, e, l, la); + Util.rectBoundingBox(e, n, c, l, r); + break; + } + case Ee: { + const e = (a.currentPointX = t[0]), + n = (a.currentPointY = t[1]); + i.push(sa, e, n); + Util.pointBoundingBox(e, n, r); + break; + } + case Pe: { + const e = (a.currentPointX = t[0]), + n = (a.currentPointY = t[1]); + i.push(oa, e, n); + Util.pointBoundingBox(e, n, r); + break; + } + case Le: { + const e = a.currentPointX, + n = a.currentPointY, + [s, o, c, l, h, u] = t; + a.currentPointX = h; + a.currentPointY = u; + i.push(ca, s, o, c, l, h, u); + Util.bezierBoundingBox(e, n, s, o, c, l, h, u, r); + break; + } + case je: { + const e = a.currentPointX, + n = a.currentPointY, + [s, o, c, l] = t; + a.currentPointX = c; + a.currentPointY = l; + i.push(ca, e, n, s, o, c, l); + Util.bezierBoundingBox(e, n, e, n, s, o, c, l, r); + break; + } + case _e: { + const e = a.currentPointX, + n = a.currentPointY, + [s, o, c, l] = t; + a.currentPointX = c; + a.currentPointY = l; + i.push(ca, s, o, c, l, c, l); + Util.bezierBoundingBox(e, n, s, o, c, l, c, l, r); + break; + } + case Ue: + i.push(la); + } + } + _getColorSpace(e, t, a) { + return ColorSpaceUtils.parse({ + cs: e, + xref: this.xref, + resources: t, + pdfFunctionFactory: this._pdfFunctionFactory, + globalColorSpaceCache: this.globalColorSpaceCache, + localColorSpaceCache: a, + asyncIfNotCached: !0, + }); + } + async _handleColorSpace(e) { + try { + return await e; + } catch (e) { + if (e instanceof AbortException) return null; + if (this.options.ignoreErrors) { + warn(`_handleColorSpace - ignoring ColorSpace: "${e}".`); + return null; + } + throw e; + } + } + parseShading({ + shading: e, + resources: t, + localColorSpaceCache: a, + localShadingPatternCache: r, + }) { + let i, + n = r.get(e); + if (n) return n; + try { + i = Pattern.parseShading( + e, + this.xref, + t, + this._pdfFunctionFactory, + this.globalColorSpaceCache, + a, + ).getIR(); + } catch (t) { + if (t instanceof AbortException) return null; + if (this.options.ignoreErrors) { + warn(`parseShading - ignoring shading: "${t}".`); + r.set(e, null); + return null; + } + throw t; + } + n = `pattern_${this.idFactory.createObjId()}`; + this.parsingType3Font && (n = `${this.idFactory.getDocId()}_type3_${n}`); + r.set(e, n); + this.parsingType3Font + ? this.handler.send("commonobj", [n, "Pattern", i]) + : this.handler.send("obj", [n, this.pageIndex, "Pattern", i]); + return n; + } + handleColorN(e, t, a, r, i, n, s, o, c, l) { + const h = a.pop(); + if (h instanceof Name) { + const u = i.getRaw(h.name), + d = u instanceof Ref && c.getByRef(u); + if (d) + try { + const i = r.base ? r.base.getRgbHex(a, 0) : null, + n = getTilingPatternIR(d.operatorListIR, d.dict, i); + e.addOp(t, n); + return; + } catch {} + const f = this.xref.fetchIfRef(u); + if (f) { + const i = f instanceof BaseStream ? f.dict : f, + h = i.get("PatternType"); + if (h === Rn) { + const o = r.base ? r.base.getRgbHex(a, 0) : null; + return this.handleTilingType(t, o, n, f, i, e, s, c); + } + if (h === Nn) { + const a = i.get("Shading"), + r = this.parseShading({ + shading: a, + resources: n, + localColorSpaceCache: o, + localShadingPatternCache: l, + }); + if (r) { + const a = lookupMatrix(i.getArray("Matrix"), null); + e.addOp(t, ["Shading", r, a]); + } + return; + } + throw new FormatError(`Unknown PatternType: ${h}`); + } + } + throw new FormatError(`Unknown PatternName: ${h}`); + } + _parseVisibilityExpression(e, t, a) { + if (++t > 10) { + warn("Visibility expression is too deeply nested"); + return; + } + const r = e.length, + i = this.xref.fetchIfRef(e[0]); + if (!(r < 2) && i instanceof Name) { + switch (i.name) { + case "And": + case "Or": + case "Not": + a.push(i.name); + break; + default: + warn(`Invalid operator ${i.name} in visibility expression`); + return; + } + for (let i = 1; i < r; i++) { + const r = e[i], + n = this.xref.fetchIfRef(r); + if (Array.isArray(n)) { + const e = []; + a.push(e); + this._parseVisibilityExpression(n, t, e); + } else r instanceof Ref && a.push(r.toString()); + } + } else warn("Invalid visibility expression"); + } + async parseMarkedContentProps(e, t) { + let a; + if (e instanceof Name) { + a = t.get("Properties").get(e.name); + } else { + if (!(e instanceof Dict)) + throw new FormatError("Optional content properties malformed."); + a = e; + } + const r = a.get("Type")?.name; + if ("OCG" === r) return { type: r, id: a.objId }; + if ("OCMD" === r) { + const e = a.get("VE"); + if (Array.isArray(e)) { + const t = []; + this._parseVisibilityExpression(e, 0, t); + if (t.length > 0) return { type: "OCMD", expression: t }; + } + const t = a.get("OCGs"); + if (Array.isArray(t) || t instanceof Dict) { + const e = []; + if (Array.isArray(t)) for (const a of t) e.push(a.toString()); + else e.push(t.objId); + return { + type: r, + ids: e, + policy: a.get("P") instanceof Name ? a.get("P").name : null, + expression: null, + }; + } + if (t instanceof Ref) return { type: r, id: t.toString() }; + } + return null; + } + getOperatorList({ + stream: e, + task: t, + resources: a, + operatorList: r, + initialState: i = null, + fallbackFontDict: n = null, + prevRefs: s = null, + }) { + const o = e.dict?.objId, + c = new RefSet(s); + if (o) { + if (s?.has(o)) + throw new Error(`getOperatorList - ignoring circular reference: ${o}`); + c.put(o); + } + a ||= Dict.empty; + i ||= new EvalState(); + if (!r) + throw new Error('getOperatorList: missing "operatorList" parameter'); + const l = this, + h = this.xref, + u = new LocalImageCache(), + d = new LocalColorSpaceCache(), + f = new LocalGStateCache(), + g = new LocalTilingPatternCache(), + p = new Map(), + m = a.get("XObject") || Dict.empty, + b = a.get("Pattern") || Dict.empty, + y = new StateManager(i), + w = new EvaluatorPreprocessor(e, h, y), + x = new TimeSlotManager(); + function closePendingRestoreOPS(e) { + for (let e = 0, t = w.savedStatesDepth; e < t; e++) r.addOp(Re, []); + } + return new Promise(function promiseBody(e, i) { + const next = function (t) { + Promise.all([t, r.ready]).then(function () { + try { + promiseBody(e, i); + } catch (e) { + i(e); + } + }, i); + }; + t.ensureNotTerminated(); + x.reset(); + const s = {}; + let o, S, k, C, v, F; + for (; !(o = x.check()); ) { + s.args = null; + if (!w.read(s)) break; + let e = s.args, + i = s.fn; + switch (0 | i) { + case Nt: + F = e[0] instanceof Name; + v = e[0].name; + if (F) { + const t = u.getByName(v); + if (t) { + addCachedImageOps(r, t); + e = null; + continue; + } + } + next( + new Promise(function (e, i) { + if (!F) + throw new FormatError("XObject must be referred to by name."); + let n = m.getRaw(v); + if (n instanceof Ref) { + const t = + u.getByRef(n) || + l._regionalImageCache.getByRef(n) || + l.globalImageCache.getData(n, l.pageIndex); + if (t) { + addCachedImageOps(r, t); + e(); + return; + } + n = h.fetch(n); + } + if (!(n instanceof BaseStream)) + throw new FormatError("XObject should be a stream"); + const s = n.dict.get("Subtype"); + if (!(s instanceof Name)) + throw new FormatError("XObject should have a Name subtype"); + if ("Form" !== s.name) + if ("Image" !== s.name) { + if ("PS" !== s.name) + throw new FormatError( + `Unhandled XObject subtype ${s.name}`, + ); + info("Ignored XObject subtype PS"); + e(); + } else + l.buildPaintImageXObject({ + resources: a, + image: n, + operatorList: r, + cacheKey: v, + localImageCache: u, + localColorSpaceCache: d, + }).then(e, i); + else { + y.save(); + l.buildFormXObject( + a, + n, + null, + r, + t, + y.state.clone({ newPath: !0 }), + d, + c, + ).then(function () { + y.restore(); + e(); + }, i); + } + }).catch(function (e) { + if (!(e instanceof AbortException)) { + if (!l.options.ignoreErrors) throw e; + warn(`getOperatorList - ignoring XObject: "${e}".`); + } + }), + ); + return; + case nt: + const s = e[1]; + next( + l.handleSetFont(a, e, null, r, t, y.state, n).then(function (e) { + r.addDependency(e); + r.addOp(nt, [e, s]); + }), + ); + return; + case Rt: + const o = e[0].cacheKey; + if (o) { + const t = u.getByName(o); + if (t) { + addCachedImageOps(r, t); + e = null; + continue; + } + } + next( + l.buildPaintImageXObject({ + resources: a, + image: e[0], + isInline: !0, + operatorList: r, + cacheKey: o, + localImageCache: u, + localColorSpaceCache: d, + }), + ); + return; + case dt: + if (!y.state.font) { + l.ensureStateFont(y.state); + continue; + } + e[0] = l.handleText(e[0], y.state); + break; + case ft: + if (!y.state.font) { + l.ensureStateFont(y.state); + continue; + } + const w = [], + x = y.state; + for (const t of e[0]) + "string" == typeof t + ? w.push(...l.handleText(t, x)) + : "number" == typeof t && w.push(t); + e[0] = w; + i = dt; + break; + case gt: + if (!y.state.font) { + l.ensureStateFont(y.state); + continue; + } + r.addOp(ut); + e[0] = l.handleText(e[0], y.state); + i = dt; + break; + case pt: + if (!y.state.font) { + l.ensureStateFont(y.state); + continue; + } + r.addOp(ut); + r.addOp(at, [e.shift()]); + r.addOp(tt, [e.shift()]); + e[0] = l.handleText(e[0], y.state); + i = dt; + break; + case st: + y.state.textRenderingMode = e[0]; + break; + case wt: { + const t = l._getColorSpace(e[0], a, d); + if (t instanceof ColorSpace) { + y.state.fillColorSpace = t; + continue; + } + next( + l._handleColorSpace(t).then((e) => { + y.state.fillColorSpace = e || ColorSpaceUtils.gray; + }), + ); + return; + } + case yt: { + const t = l._getColorSpace(e[0], a, d); + if (t instanceof ColorSpace) { + y.state.strokeColorSpace = t; + continue; + } + next( + l._handleColorSpace(t).then((e) => { + y.state.strokeColorSpace = e || ColorSpaceUtils.gray; + }), + ); + return; + } + case kt: + C = y.state.fillColorSpace; + e = [C.getRgbHex(e, 0)]; + i = It; + break; + case xt: + C = y.state.strokeColorSpace; + e = [C.getRgbHex(e, 0)]; + i = Ft; + break; + case vt: + y.state.fillColorSpace = ColorSpaceUtils.gray; + e = [ColorSpaceUtils.gray.getRgbHex(e, 0)]; + i = It; + break; + case Ct: + y.state.strokeColorSpace = ColorSpaceUtils.gray; + e = [ColorSpaceUtils.gray.getRgbHex(e, 0)]; + i = Ft; + break; + case Ot: + y.state.fillColorSpace = ColorSpaceUtils.cmyk; + e = [ColorSpaceUtils.cmyk.getRgbHex(e, 0)]; + i = It; + break; + case Tt: + y.state.strokeColorSpace = ColorSpaceUtils.cmyk; + e = [ColorSpaceUtils.cmyk.getRgbHex(e, 0)]; + i = Ft; + break; + case It: + y.state.fillColorSpace = ColorSpaceUtils.rgb; + e = [ColorSpaceUtils.rgb.getRgbHex(e, 0)]; + break; + case Ft: + y.state.strokeColorSpace = ColorSpaceUtils.rgb; + e = [ColorSpaceUtils.rgb.getRgbHex(e, 0)]; + break; + case At: + C = y.state.patternFillColorSpace; + if (!C) { + if (isNumberArray(e, null)) { + e = [ColorSpaceUtils.gray.getRgbHex(e, 0)]; + i = It; + break; + } + e = []; + i = ia; + break; + } + if ("Pattern" === C.name) { + next(l.handleColorN(r, At, e, C, b, a, t, d, g, p)); + return; + } + e = [C.getRgbHex(e, 0)]; + i = It; + break; + case St: + C = y.state.patternStrokeColorSpace; + if (!C) { + if (isNumberArray(e, null)) { + e = [ColorSpaceUtils.gray.getRgbHex(e, 0)]; + i = Ft; + break; + } + e = []; + i = ra; + break; + } + if ("Pattern" === C.name) { + next(l.handleColorN(r, St, e, C, b, a, t, d, g, p)); + return; + } + e = [C.getRgbHex(e, 0)]; + i = Ft; + break; + case Mt: + let T; + try { + const t = a.get("Shading"); + if (!t) throw new FormatError("No shading resource found"); + T = t.get(e[0].name); + if (!T) throw new FormatError("No shading object found"); + } catch (e) { + if (e instanceof AbortException) continue; + if (l.options.ignoreErrors) { + warn(`getOperatorList - ignoring Shading: "${e}".`); + continue; + } + throw e; + } + const O = l.parseShading({ + shading: T, + resources: a, + localColorSpaceCache: d, + localShadingPatternCache: p, + }); + if (!O) continue; + e = [O]; + i = Mt; + break; + case De: + F = e[0] instanceof Name; + v = e[0].name; + if (F) { + const t = f.getByName(v); + if (t) { + t.length > 0 && r.addOp(De, [t]); + e = null; + continue; + } + } + next( + new Promise(function (e, i) { + if (!F) + throw new FormatError("GState must be referred to by name."); + const n = a.get("ExtGState"); + if (!(n instanceof Dict)) + throw new FormatError("ExtGState should be a dictionary."); + const s = n.get(v); + if (!(s instanceof Dict)) + throw new FormatError("GState should be a dictionary."); + l.setGState({ + resources: a, + gState: s, + operatorList: r, + cacheKey: v, + task: t, + stateManager: y, + localGStateCache: f, + localColorSpaceCache: d, + seenRefs: c, + }).then(e, i); + }).catch(function (e) { + if (!(e instanceof AbortException)) { + if (!l.options.ignoreErrors) throw e; + warn(`getOperatorList - ignoring ExtGState: "${e}".`); + } + }), + ); + return; + case Ce: { + const [t] = e; + if ("number" != typeof t) { + warn(`Invalid setLineWidth: ${t}`); + continue; + } + e[0] = Math.abs(t); + break; + } + case Ee: + case Pe: + case Le: + case je: + case _e: + case Ue: + case Xe: + l.buildPath(i, e, y.state); + continue; + case qe: + case He: + case We: + case ze: + case $e: + case Ge: + case Ve: + case Ke: + case Je: { + const { + state: { pathBuffer: e, pathMinMax: t }, + } = y; + (i !== He && i !== Ve && i !== Ke) || e.push(la); + if (0 === e.length) r.addOp(aa, [i, [null], null]); + else { + r.addOp(aa, [i, [new Float32Array(e)], t.slice()]); + e.length = 0; + t.set([1 / 0, 1 / 0, -1 / 0, -1 / 0], 0); + } + continue; + } + case ht: + r.addOp(i, [new Float32Array(e)]); + continue; + case Et: + case Pt: + case Ut: + case Xt: + continue; + case jt: + if (!(e[0] instanceof Name)) { + warn(`Expected name for beginMarkedContentProps arg0=${e[0]}`); + r.addOp(jt, ["OC", null]); + continue; + } + if ("OC" === e[0].name) { + next( + l + .parseMarkedContentProps(e[1], a) + .then((e) => { + r.addOp(jt, ["OC", e]); + }) + .catch((e) => { + if (!(e instanceof AbortException)) { + if (!l.options.ignoreErrors) throw e; + warn( + `getOperatorList - ignoring beginMarkedContentProps: "${e}".`, + ); + r.addOp(jt, ["OC", null]); + } + }), + ); + return; + } + e = [e[0].name, e[1] instanceof Dict ? e[1].get("MCID") : null]; + break; + default: + if (null !== e) { + for (S = 0, k = e.length; S < k && !(e[S] instanceof Dict); S++); + if (S < k) { + warn("getOperatorList - ignoring operator: " + i); + continue; + } + } + } + r.addOp(i, e); + } + if (o) next(En); + else { + closePendingRestoreOPS(); + e(); + } + }).catch((e) => { + if (!(e instanceof AbortException)) { + if (!this.options.ignoreErrors) throw e; + warn( + `getOperatorList - ignoring errors during "${t.name}" task: "${e}".`, + ); + closePendingRestoreOPS(); + } + }); + } + getTextContent({ + stream: e, + task: a, + resources: r, + stateManager: i = null, + includeMarkedContent: n = !1, + sink: s, + seenStyles: o = new Set(), + viewBox: c, + lang: l = null, + markedContentData: h = null, + disableNormalization: u = !1, + keepWhiteSpace: d = !1, + prevRefs: f = null, + intersector: g = null, + }) { + const p = e.dict?.objId, + m = new RefSet(f); + if (p) { + if (f?.has(p)) + throw new Error(`getTextContent - ignoring circular reference: ${p}`); + m.put(p); + } + r ||= Dict.empty; + i ||= new StateManager(new TextState()); + n && (h ||= { level: 0 }); + const b = { items: [], styles: Object.create(null), lang: l }, + y = { + initialized: !1, + str: [], + totalWidth: 0, + totalHeight: 0, + width: 0, + height: 0, + vertical: !1, + prevTransform: null, + textAdvanceScale: 0, + spaceInFlowMin: 0, + spaceInFlowMax: 0, + trackingSpaceMin: 1 / 0, + negativeSpaceMax: -1 / 0, + notASpace: -1 / 0, + transform: null, + fontName: null, + hasEOL: !1, + }, + w = [" ", " "]; + let x = 0; + function saveLastChar(e) { + const t = (x + 1) % 2, + a = " " !== w[x] && " " === w[t]; + w[x] = e; + x = t; + return !d && a; + } + function shouldAddWhitepsace() { + return !d && " " !== w[x] && " " === w[(x + 1) % 2]; + } + function resetLastChars() { + w[0] = w[1] = " "; + x = 0; + } + const S = this, + k = this.xref, + C = []; + let v = null; + const F = new LocalImageCache(), + T = new LocalGStateCache(), + O = new EvaluatorPreprocessor(e, k, i); + let M; + function pushWhitespace({ + width: e = 0, + height: t = 0, + transform: a = y.prevTransform, + fontName: r = y.fontName, + }) { + g?.addExtraChar(" "); + b.items.push({ + str: " ", + dir: "ltr", + width: e, + height: t, + transform: a, + fontName: r, + hasEOL: !1, + }); + } + function getCurrentTextTransform() { + const e = M.font, + a = [M.fontSize * M.textHScale, 0, 0, M.fontSize, 0, M.textRise]; + if ( + e.isType3Font && + (M.fontSize <= 1 || e.isCharBBox) && + !isArrayEqual(M.fontMatrix, t) + ) { + const t = e.bbox[3] - e.bbox[1]; + t > 0 && (a[3] *= t * M.fontMatrix[3]); + } + return Util.transform(M.ctm, Util.transform(M.textMatrix, a)); + } + function ensureTextContentItem() { + if (y.initialized) return y; + const { font: e, loadedName: t } = M; + if (!o.has(t)) { + o.add(t); + b.styles[t] = { + fontFamily: e.fallbackName, + ascent: e.ascent, + descent: e.descent, + vertical: e.vertical, + }; + if (S.options.fontExtraProperties && e.systemFontInfo) { + const a = b.styles[t]; + a.fontSubstitution = e.systemFontInfo.css; + a.fontSubstitutionLoadedName = e.systemFontInfo.loadedName; + } + } + y.fontName = t; + const a = (y.transform = getCurrentTextTransform()); + if (e.vertical) { + y.width = y.totalWidth = Math.hypot(a[0], a[1]); + y.height = y.totalHeight = 0; + y.vertical = !0; + } else { + y.width = y.totalWidth = 0; + y.height = y.totalHeight = Math.hypot(a[2], a[3]); + y.vertical = !1; + } + const r = Math.hypot(M.textLineMatrix[0], M.textLineMatrix[1]), + i = Math.hypot(M.ctm[0], M.ctm[1]); + y.textAdvanceScale = i * r; + const { fontSize: n } = M; + y.trackingSpaceMin = 0.102 * n; + y.notASpace = 0.03 * n; + y.negativeSpaceMax = -0.2 * n; + y.spaceInFlowMin = 0.102 * n; + y.spaceInFlowMax = 0.6 * n; + y.hasEOL = !1; + y.initialized = !0; + return y; + } + function updateAdvanceScale() { + if (!y.initialized) return; + const e = Math.hypot(M.textLineMatrix[0], M.textLineMatrix[1]), + t = Math.hypot(M.ctm[0], M.ctm[1]) * e; + if (t !== y.textAdvanceScale) { + if (y.vertical) { + y.totalHeight += y.height * y.textAdvanceScale; + y.height = 0; + } else { + y.totalWidth += y.width * y.textAdvanceScale; + y.width = 0; + } + y.textAdvanceScale = t; + } + } + function runBidiTransform(e) { + let t = e.str.join(""); + u || + (t = (function normalizeUnicode(e) { + if (!ma) { + ma = + /([\u00a0\u00b5\u037e\u0eb3\u2000-\u200a\u202f\u2126\ufb00-\ufb04\ufb06\ufb20-\ufb36\ufb38-\ufb3c\ufb3e\ufb40-\ufb41\ufb43-\ufb44\ufb46-\ufba1\ufba4-\ufba9\ufbae-\ufbb1\ufbd3-\ufbdc\ufbde-\ufbe7\ufbea-\ufbf8\ufbfc-\ufbfd\ufc00-\ufc5d\ufc64-\ufcf1\ufcf5-\ufd3d\ufd88\ufdf4\ufdfa-\ufdfb\ufe71\ufe77\ufe79\ufe7b\ufe7d]+)|(\ufb05+)/gu; + ba = new Map([["ſt", "ſt"]]); + } + return e.replaceAll(ma, (e, t, a) => + t ? t.normalize("NFKC") : ba.get(a), + ); + })(t)); + const a = bidi(t, -1, e.vertical); + return { + str: a.str, + dir: a.dir, + width: Math.abs(e.totalWidth), + height: Math.abs(e.totalHeight), + transform: e.transform, + fontName: e.fontName, + hasEOL: e.hasEOL, + }; + } + async function handleSetFont(e, i) { + const n = await S.loadFont(e, i, r, a); + M.loadedName = n.loadedName; + M.font = n.font; + M.fontMatrix = n.font.fontMatrix || t; + } + function applyInverseRotation(e, t, a) { + const r = Math.hypot(a[0], a[1]); + return [(a[0] * e + a[1] * t) / r, (a[2] * e + a[3] * t) / r]; + } + function compareWithLastPosition(e) { + const t = getCurrentTextTransform(); + let a = t[4], + r = t[5]; + if (M.font?.vertical) { + if (a < c[0] || a > c[2] || r + e < c[1] || r > c[3]) return !1; + } else if (a + e < c[0] || a > c[2] || r < c[1] || r > c[3]) return !1; + if (!M.font || !y.prevTransform) return !0; + let i = y.prevTransform[4], + n = y.prevTransform[5]; + if (i === a && n === r) return !0; + let s = -1; + t[0] && 0 === t[1] && 0 === t[2] + ? (s = t[0] > 0 ? 0 : 180) + : t[1] && 0 === t[0] && 0 === t[3] && (s = t[1] > 0 ? 90 : 270); + switch (s) { + case 0: + break; + case 90: + [a, r] = [r, a]; + [i, n] = [n, i]; + break; + case 180: + [a, r, i, n] = [-a, -r, -i, -n]; + break; + case 270: + [a, r] = [-r, -a]; + [i, n] = [-n, -i]; + break; + default: + [a, r] = applyInverseRotation(a, r, t); + [i, n] = applyInverseRotation(i, n, y.prevTransform); + } + if (M.font.vertical) { + const e = (n - r) / y.textAdvanceScale, + t = a - i, + s = Math.sign(y.height); + if (e < s * y.negativeSpaceMax) { + if (Math.abs(t) > 0.5 * y.width) { + appendEOL(); + return !0; + } + resetLastChars(); + flushTextContentItem(); + return !0; + } + if (Math.abs(t) > y.width) { + appendEOL(); + return !0; + } + e <= s * y.notASpace && resetLastChars(); + if (e <= s * y.trackingSpaceMin) + if (shouldAddWhitepsace()) { + resetLastChars(); + flushTextContentItem(); + pushWhitespace({ height: Math.abs(e) }); + } else y.height += e; + else if (!addFakeSpaces(e, y.prevTransform, s)) + if (0 === y.str.length) { + resetLastChars(); + pushWhitespace({ height: Math.abs(e) }); + } else y.height += e; + Math.abs(t) > 0.25 * y.width && flushTextContentItem(); + return !0; + } + const o = (a - i) / y.textAdvanceScale, + l = r - n, + h = Math.sign(y.width); + if (o < h * y.negativeSpaceMax) { + if (Math.abs(l) > 0.5 * y.height) { + appendEOL(); + return !0; + } + resetLastChars(); + flushTextContentItem(); + return !0; + } + if (Math.abs(l) > y.height) { + appendEOL(); + return !0; + } + o <= h * y.notASpace && resetLastChars(); + if (o <= h * y.trackingSpaceMin) + if (shouldAddWhitepsace()) { + resetLastChars(); + flushTextContentItem(); + pushWhitespace({ width: Math.abs(o) }); + } else y.width += o; + else if (!addFakeSpaces(o, y.prevTransform, h)) + if (0 === y.str.length) { + resetLastChars(); + pushWhitespace({ width: Math.abs(o) }); + } else y.width += o; + Math.abs(l) > 0.25 * y.height && flushTextContentItem(); + return !0; + } + function buildTextContentItem({ chars: e, extraSpacing: t }) { + const a = M.font; + if (!e) { + const e = M.charSpacing + t; + e && + (a.vertical + ? M.translateTextMatrix(0, -e) + : M.translateTextMatrix(e * M.textHScale, 0)); + d && compareWithLastPosition(0); + return; + } + const r = a.charsToGlyphs(e), + i = M.fontMatrix[0] * M.fontSize; + for (let e = 0, n = r.length; e < n; e++) { + const s = r[e], + { category: o } = s; + if (o.isInvisibleFormatMark) continue; + let c = M.charSpacing + (e + 1 === n ? t : 0), + l = s.width; + a.vertical && (l = s.vmetric ? s.vmetric[0] : -l); + let h = l * i; + if (!d && o.isWhitespace) { + if (a.vertical) { + c += -h + M.wordSpacing; + M.translateTextMatrix(0, -c); + } else { + c += h + M.wordSpacing; + M.translateTextMatrix(c * M.textHScale, 0); + } + saveLastChar(" "); + continue; + } + if (!o.isZeroWidthDiacritic && !compareWithLastPosition(h)) { + a.vertical + ? M.translateTextMatrix(0, h) + : M.translateTextMatrix(h * M.textHScale, 0); + continue; + } + const u = ensureTextContentItem(); + o.isZeroWidthDiacritic && (h = 0); + if (a.vertical) { + g?.addGlyph(getCurrentTextTransform(), 0, h, s.unicode); + M.translateTextMatrix(0, h); + h = Math.abs(h); + u.height += h; + } else { + h *= M.textHScale; + g?.addGlyph(getCurrentTextTransform(), h, 0, s.unicode); + M.translateTextMatrix(h, 0); + u.width += h; + } + h && (u.prevTransform = getCurrentTextTransform()); + const f = s.unicode; + if (saveLastChar(f)) { + u.str.push(" "); + g?.addExtraChar(" "); + } + g || u.str.push(f); + c && + (a.vertical + ? M.translateTextMatrix(0, -c) + : M.translateTextMatrix(c * M.textHScale, 0)); + } + } + function appendEOL() { + g?.addExtraChar("\n"); + resetLastChars(); + if (y.initialized) { + y.hasEOL = !0; + flushTextContentItem(); + } else + b.items.push({ + str: "", + dir: "ltr", + width: 0, + height: 0, + transform: getCurrentTextTransform(), + fontName: M.loadedName, + hasEOL: !0, + }); + } + function addFakeSpaces(e, t, a) { + if (a * y.spaceInFlowMin <= e && e <= a * y.spaceInFlowMax) { + if (y.initialized) { + resetLastChars(); + y.str.push(" "); + g?.addExtraChar(" "); + } + return !1; + } + const r = y.fontName; + let i = 0; + if (y.vertical) { + i = e; + e = 0; + } + flushTextContentItem(); + resetLastChars(); + pushWhitespace({ + width: Math.abs(e), + height: Math.abs(i), + transform: t || getCurrentTextTransform(), + fontName: r, + }); + return !0; + } + function flushTextContentItem() { + if (y.initialized && y.str) { + y.vertical + ? (y.totalHeight += y.height * y.textAdvanceScale) + : (y.totalWidth += y.width * y.textAdvanceScale); + b.items.push(runBidiTransform(y)); + y.initialized = !1; + y.str.length = 0; + } + } + function enqueueChunk(e = !1) { + const t = b.items.length; + if (0 !== t && !(e && t < 10)) { + s?.enqueue(b, t); + b.items = []; + b.styles = Object.create(null); + } + } + const D = new TimeSlotManager(); + return new Promise(function promiseBody(e, t) { + const next = function (a) { + enqueueChunk(!0); + Promise.all([a, s?.ready]).then(function () { + try { + promiseBody(e, t); + } catch (e) { + t(e); + } + }, t); + }; + a.ensureNotTerminated(); + D.reset(); + const f = {}; + let g, + p, + y, + w = []; + for (; !(g = D.check()); ) { + w.length = 0; + f.args = w; + if (!O.read(f)) break; + const e = M; + M = i.state; + const t = f.fn; + w = f.args; + switch (0 | t) { + case nt: + const t = w[0].name, + f = w[1]; + if (M.font && t === M.fontName && f === M.fontSize) break; + flushTextContentItem(); + M.fontName = t; + M.fontSize = f; + next(handleSetFont(t, null)); + return; + case ot: + M.textRise = w[0]; + break; + case rt: + M.textHScale = w[0] / 100; + break; + case it: + M.leading = w[0]; + break; + case ct: + M.translateTextLineMatrix(w[0], w[1]); + M.textMatrix = M.textLineMatrix.slice(); + break; + case lt: + M.leading = -w[1]; + M.translateTextLineMatrix(w[0], w[1]); + M.textMatrix = M.textLineMatrix.slice(); + break; + case ut: + M.carriageReturn(); + break; + case ht: + M.setTextMatrix(w[0], w[1], w[2], w[3], w[4], w[5]); + M.setTextLineMatrix(w[0], w[1], w[2], w[3], w[4], w[5]); + updateAdvanceScale(); + break; + case tt: + M.charSpacing = w[0]; + break; + case at: + M.wordSpacing = w[0]; + break; + case Qe: + M.textMatrix = Fa.slice(); + M.textLineMatrix = Fa.slice(); + break; + case ft: + if (!i.state.font) { + S.ensureStateFont(i.state); + continue; + } + const g = ((M.font.vertical ? 1 : -1) * M.fontSize) / 1e3, + x = w[0]; + for (let e = 0, t = x.length; e < t; e++) { + const t = x[e]; + if ("string" == typeof t) C.push(t); + else if ("number" == typeof t && 0 !== t) { + const e = C.join(""); + C.length = 0; + buildTextContentItem({ chars: e, extraSpacing: t * g }); + } + } + if (C.length > 0) { + const e = C.join(""); + C.length = 0; + buildTextContentItem({ chars: e, extraSpacing: 0 }); + } + break; + case dt: + if (!i.state.font) { + S.ensureStateFont(i.state); + continue; + } + buildTextContentItem({ chars: w[0], extraSpacing: 0 }); + break; + case gt: + if (!i.state.font) { + S.ensureStateFont(i.state); + continue; + } + M.carriageReturn(); + buildTextContentItem({ chars: w[0], extraSpacing: 0 }); + break; + case pt: + if (!i.state.font) { + S.ensureStateFont(i.state); + continue; + } + M.wordSpacing = w[0]; + M.charSpacing = w[1]; + M.carriageReturn(); + buildTextContentItem({ chars: w[2], extraSpacing: 0 }); + break; + case Nt: + flushTextContentItem(); + v ??= r.get("XObject") || Dict.empty; + y = w[0] instanceof Name; + p = w[0].name; + if (y && F.getByName(p)) break; + next( + new Promise(function (e, t) { + if (!y) + throw new FormatError("XObject must be referred to by name."); + let f = v.getRaw(p); + if (f instanceof Ref) { + if (F.getByRef(f)) { + e(); + return; + } + if (S.globalImageCache.getData(f, S.pageIndex)) { + e(); + return; + } + f = k.fetch(f); + } + if (!(f instanceof BaseStream)) + throw new FormatError("XObject should be a stream"); + const { dict: g } = f, + b = g.get("Subtype"); + if (!(b instanceof Name)) + throw new FormatError("XObject should have a Name subtype"); + if ("Form" !== b.name) { + F.set(p, g.objId, !0); + e(); + return; + } + const w = i.state.clone(), + x = new StateManager(w), + C = lookupMatrix(g.getArray("Matrix"), null); + C && x.transform(C); + const T = g.get("Resources"); + enqueueChunk(); + const O = { + enqueueInvoked: !1, + enqueue(e, t) { + this.enqueueInvoked = !0; + s.enqueue(e, t); + }, + get desiredSize() { + return s.desiredSize ?? 0; + }, + get ready() { + return s.ready; + }, + }; + S.getTextContent({ + stream: f, + task: a, + resources: T instanceof Dict ? T : r, + stateManager: x, + includeMarkedContent: n, + sink: s && O, + seenStyles: o, + viewBox: c, + lang: l, + markedContentData: h, + disableNormalization: u, + keepWhiteSpace: d, + prevRefs: m, + }).then(function () { + O.enqueueInvoked || F.set(p, g.objId, !0); + e(); + }, t); + }).catch(function (e) { + if (!(e instanceof AbortException)) { + if (!S.options.ignoreErrors) throw e; + warn(`getTextContent - ignoring XObject: "${e}".`); + } + }), + ); + return; + case De: + y = w[0] instanceof Name; + p = w[0].name; + if (y && T.getByName(p)) break; + next( + new Promise(function (e, t) { + if (!y) + throw new FormatError("GState must be referred to by name."); + const a = r.get("ExtGState"); + if (!(a instanceof Dict)) + throw new FormatError("ExtGState should be a dictionary."); + const i = a.get(p); + if (!(i instanceof Dict)) + throw new FormatError("GState should be a dictionary."); + const n = i.get("Font"); + if (n) { + flushTextContentItem(); + M.fontName = null; + M.fontSize = n[1]; + handleSetFont(null, n[0]).then(e, t); + } else { + T.set(p, i.objId, !0); + e(); + } + }).catch(function (e) { + if (!(e instanceof AbortException)) { + if (!S.options.ignoreErrors) throw e; + warn(`getTextContent - ignoring ExtGState: "${e}".`); + } + }), + ); + return; + case Lt: + flushTextContentItem(); + if (n) { + h.level++; + b.items.push({ + type: "beginMarkedContent", + tag: w[0] instanceof Name ? w[0].name : null, + }); + } + break; + case jt: + flushTextContentItem(); + if (n) { + h.level++; + let e = null; + w[1] instanceof Dict && (e = w[1].get("MCID")); + b.items.push({ + type: "beginMarkedContentProps", + id: Number.isInteger(e) + ? `${S.idFactory.getPageObjId()}_mc${e}` + : null, + tag: w[0] instanceof Name ? w[0].name : null, + }); + } + break; + case _t: + flushTextContentItem(); + if (n) { + if (0 === h.level) break; + h.level--; + b.items.push({ type: "endMarkedContent" }); + } + break; + case Re: + !e || + (e.font === M.font && + e.fontSize === M.fontSize && + e.fontName === M.fontName) || + flushTextContentItem(); + } + if (b.items.length >= (s?.desiredSize ?? 1)) { + g = !0; + break; + } + } + if (g) next(En); + else { + flushTextContentItem(); + enqueueChunk(); + e(); + } + }).catch((e) => { + if (!(e instanceof AbortException)) { + if (!this.options.ignoreErrors) throw e; + warn( + `getTextContent - ignoring errors during "${a.name}" task: "${e}".`, + ); + flushTextContentItem(); + enqueueChunk(); + } + }); + } + async extractDataStructures(e, t) { + const a = this.xref; + let r; + const i = this.readToUnicode(t.toUnicode); + if (t.composite) { + const a = e.get("CIDSystemInfo"); + a instanceof Dict && + (t.cidSystemInfo = { + registry: stringToPDFString(a.get("Registry")), + ordering: stringToPDFString(a.get("Ordering")), + supplement: a.get("Supplement"), + }); + try { + const t = e.get("CIDToGIDMap"); + t instanceof BaseStream && (r = t.getBytes()); + } catch (e) { + if (!this.options.ignoreErrors) throw e; + warn(`extractDataStructures - ignoring CIDToGIDMap data: "${e}".`); + } + } + const n = []; + let s, + o = null; + if (e.has("Encoding")) { + s = e.get("Encoding"); + if (s instanceof Dict) { + o = s.get("BaseEncoding"); + o = o instanceof Name ? o.name : null; + if (s.has("Differences")) { + const e = s.get("Differences"); + let t = 0; + for (const r of e) { + const e = a.fetchIfRef(r); + if ("number" == typeof e) t = e; + else { + if (!(e instanceof Name)) + throw new FormatError( + `Invalid entry in 'Differences' array: ${e}`, + ); + n[t++] = e.name; + } + } + } + } else if (s instanceof Name) o = s.name; + else { + const e = "Encoding is not a Name nor a Dict"; + if (!this.options.ignoreErrors) throw new FormatError(e); + warn(e); + } + "MacRomanEncoding" !== o && + "MacExpertEncoding" !== o && + "WinAnsiEncoding" !== o && + (o = null); + } + const c = !t.file || t.isInternalFont, + l = ei()[t.name]; + o && c && l && (o = null); + if (o) t.defaultEncoding = getEncoding(o); + else { + const e = !!(t.flags & Pr), + a = !!(t.flags & Lr); + s = kr; + "TrueType" !== t.type || a || (s = Ar); + if (e || l) { + s = Sr; + c && + (/Symbol/i.test(t.name) + ? (s = Cr) + : /Dingbats/i.test(t.name) + ? (s = vr) + : /Wingdings/i.test(t.name) && (s = Ar)); + } + t.defaultEncoding = s; + } + t.differences = n; + t.baseEncodingName = o; + t.hasEncoding = !!o || n.length > 0; + t.dict = e; + t.toUnicode = await i; + const h = await this.buildToUnicode(t); + t.toUnicode = h; + r && (t.cidToGidMap = this.readCidToGidMap(r, h)); + return t; + } + _simpleFontToUnicode(e, t = !1) { + assert(!e.composite, "Must be a simple font."); + const a = [], + r = e.defaultEncoding.slice(), + i = e.baseEncodingName, + n = e.differences; + for (const e in n) { + const t = n[e]; + ".notdef" !== t && (r[e] = t); + } + const s = Fr(); + for (const n in r) { + let o = r[n]; + if ("" === o) continue; + let c = s[o]; + if (void 0 !== c) { + a[n] = String.fromCharCode(c); + continue; + } + let l = 0; + switch (o[0]) { + case "G": + 3 === o.length && (l = parseInt(o.substring(1), 16)); + break; + case "g": + 5 === o.length && (l = parseInt(o.substring(1), 16)); + break; + case "C": + case "c": + if (o.length >= 3 && o.length <= 4) { + const a = o.substring(1); + if (t) { + l = parseInt(a, 16); + break; + } + l = +a; + if (Number.isNaN(l) && Number.isInteger(parseInt(a, 16))) + return this._simpleFontToUnicode(e, !0); + } + break; + case "u": + c = getUnicodeForGlyph(o, s); + -1 !== c && (l = c); + break; + default: + switch (o) { + case "f_h": + case "f_t": + case "T_h": + a[n] = o.replaceAll("_", ""); + continue; + } + } + if (l > 0 && l <= 1114111 && Number.isInteger(l)) { + if (i && l === +n) { + const e = getEncoding(i); + if (e && (o = e[n])) { + a[n] = String.fromCharCode(s[o]); + continue; + } + } + a[n] = String.fromCodePoint(l); + } + } + return a; + } + async buildToUnicode(e) { + e.hasIncludedToUnicodeMap = e.toUnicode?.length > 0; + if (e.hasIncludedToUnicodeMap) { + !e.composite && + e.hasEncoding && + (e.fallbackToUnicode = this._simpleFontToUnicode(e)); + return e.toUnicode; + } + if (!e.composite) return new ToUnicodeMap(this._simpleFontToUnicode(e)); + if ( + e.composite && + ((e.cMap.builtInCMap && !(e.cMap instanceof IdentityCMap)) || + ("Adobe" === e.cidSystemInfo?.registry && + ("GB1" === e.cidSystemInfo.ordering || + "CNS1" === e.cidSystemInfo.ordering || + "Japan1" === e.cidSystemInfo.ordering || + "Korea1" === e.cidSystemInfo.ordering))) + ) { + const { registry: t, ordering: a } = e.cidSystemInfo, + r = Name.get(`${t}-${a}-UCS2`), + i = await CMapFactory.create({ + encoding: r, + fetchBuiltInCMap: this._fetchBuiltInCMapBound, + useCMap: null, + }), + n = [], + s = []; + e.cMap.forEach(function (e, t) { + if (t > 65535) throw new FormatError("Max size of CID is 65,535"); + const a = i.lookup(t); + if (a) { + s.length = 0; + for (let e = 0, t = a.length; e < t; e += 2) + s.push((a.charCodeAt(e) << 8) + a.charCodeAt(e + 1)); + n[e] = String.fromCharCode(...s); + } + }); + return new ToUnicodeMap(n); + } + return new IdentityToUnicodeMap(e.firstChar, e.lastChar); + } + async readToUnicode(e) { + if (!e) return null; + if (e instanceof Name) { + const t = await CMapFactory.create({ + encoding: e, + fetchBuiltInCMap: this._fetchBuiltInCMapBound, + useCMap: null, + }); + return t instanceof IdentityCMap + ? new IdentityToUnicodeMap(0, 65535) + : new ToUnicodeMap(t.getMap()); + } + if (e instanceof BaseStream) + try { + const t = await CMapFactory.create({ + encoding: e, + fetchBuiltInCMap: this._fetchBuiltInCMapBound, + useCMap: null, + }); + if (t instanceof IdentityCMap) + return new IdentityToUnicodeMap(0, 65535); + const a = new Array(t.length); + t.forEach(function (e, t) { + if ("number" == typeof t) { + a[e] = String.fromCodePoint(t); + return; + } + t.length % 2 != 0 && (t = "\0" + t); + const r = []; + for (let e = 0; e < t.length; e += 2) { + const a = (t.charCodeAt(e) << 8) | t.charCodeAt(e + 1); + if (55296 != (63488 & a)) { + r.push(a); + continue; + } + e += 2; + const i = (t.charCodeAt(e) << 8) | t.charCodeAt(e + 1); + r.push(((1023 & a) << 10) + (1023 & i) + 65536); + } + a[e] = String.fromCodePoint(...r); + }); + return new ToUnicodeMap(a); + } catch (e) { + if (e instanceof AbortException) return null; + if (this.options.ignoreErrors) { + warn(`readToUnicode - ignoring ToUnicode data: "${e}".`); + return null; + } + throw e; + } + return null; + } + readCidToGidMap(e, t) { + const a = []; + for (let r = 0, i = e.length; r < i; r++) { + const i = (e[r++] << 8) | e[r], + n = r >> 1; + (0 !== i || t.has(n)) && (a[n] = i); + } + return a; + } + extractWidths(e, t, a) { + const r = this.xref; + let i = [], + n = 0; + const s = []; + let o; + if (a.composite) { + const t = e.get("DW"); + n = "number" == typeof t ? Math.ceil(t) : 1e3; + const c = e.get("W"); + if (Array.isArray(c)) + for (let e = 0, t = c.length; e < t; e++) { + let t = r.fetchIfRef(c[e++]); + if (!Number.isInteger(t)) break; + const a = r.fetchIfRef(c[e]); + if (Array.isArray(a)) + for (const e of a) { + const a = r.fetchIfRef(e); + "number" == typeof a && (i[t] = a); + t++; + } + else { + if (!Number.isInteger(a)) break; + { + const n = r.fetchIfRef(c[++e]); + if ("number" != typeof n) continue; + for (let e = t; e <= a; e++) i[e] = n; + } + } + } + if (a.vertical) { + const t = e.getArray("DW2"); + let a = isNumberArray(t, 2) ? t : [880, -1e3]; + o = [a[1], 0.5 * n, a[0]]; + a = e.get("W2"); + if (Array.isArray(a)) + for (let e = 0, t = a.length; e < t; e++) { + let t = r.fetchIfRef(a[e++]); + if (!Number.isInteger(t)) break; + const i = r.fetchIfRef(a[e]); + if (Array.isArray(i)) + for (let e = 0, a = i.length; e < a; e++) { + const a = [ + r.fetchIfRef(i[e++]), + r.fetchIfRef(i[e++]), + r.fetchIfRef(i[e]), + ]; + isNumberArray(a, null) && (s[t] = a); + t++; + } + else { + if (!Number.isInteger(i)) break; + { + const n = [ + r.fetchIfRef(a[++e]), + r.fetchIfRef(a[++e]), + r.fetchIfRef(a[++e]), + ]; + if (!isNumberArray(n, null)) continue; + for (let e = t; e <= i; e++) s[e] = n; + } + } + } + } + } else { + const s = e.get("Widths"); + if (Array.isArray(s)) { + let e = a.firstChar; + for (const t of s) { + const a = r.fetchIfRef(t); + "number" == typeof a && (i[e] = a); + e++; + } + const o = t.get("MissingWidth"); + n = "number" == typeof o ? o : 0; + } else { + const t = e.get("BaseFont"); + if (t instanceof Name) { + const e = this.getBaseFontMetrics(t.name); + i = this.buildCharCodeToWidth(e.widths, a); + n = e.defaultWidth; + } + } + } + let c = !0, + l = n; + for (const e in i) { + const t = i[e]; + if (t) + if (l) { + if (l !== t) { + c = !1; + break; + } + } else l = t; + } + c ? (a.flags |= Nr) : (a.flags &= ~Nr); + a.defaultWidth = n; + a.widths = i; + a.defaultVMetrics = o; + a.vmetrics = s; + } + isSerifFont(e) { + const t = e.split("-", 1)[0]; + return t in Qr() || /serif/gi.test(t); + } + getBaseFontMetrics(e) { + let t = 0, + a = Object.create(null), + r = !1; + let i = Jr()[e] || e; + const n = ii(); + i in n || (i = this.isSerifFont(e) ? "Times-Roman" : "Helvetica"); + const s = n[i]; + if ("number" == typeof s) { + t = s; + r = !0; + } else a = s(); + return { defaultWidth: t, monospace: r, widths: a }; + } + buildCharCodeToWidth(e, t) { + const a = Object.create(null), + r = t.differences, + i = t.defaultEncoding; + for (let t = 0; t < 256; t++) + t in r && e[r[t]] + ? (a[t] = e[r[t]]) + : t in i && e[i[t]] && (a[t] = e[i[t]]); + return a; + } + preEvaluateFont(e) { + const t = e; + let a = e.get("Subtype"); + if (!(a instanceof Name)) throw new FormatError("invalid font Subtype"); + let r, + i = !1; + if ("Type0" === a.name) { + const t = e.get("DescendantFonts"); + if (!t) throw new FormatError("Descendant fonts are not specified"); + if ( + !( + (e = Array.isArray(t) ? this.xref.fetchIfRef(t[0]) : t) instanceof + Dict + ) + ) + throw new FormatError("Descendant font is not a dictionary."); + a = e.get("Subtype"); + if (!(a instanceof Name)) throw new FormatError("invalid font Subtype"); + i = !0; + } + let n = e.get("FirstChar"); + Number.isInteger(n) || (n = 0); + let s = e.get("LastChar"); + Number.isInteger(s) || (s = i ? 65535 : 255); + const o = e.get("FontDescriptor"), + c = e.get("ToUnicode") || t.get("ToUnicode"); + if (o) { + r = new MurmurHash3_64(); + const a = t.getRaw("Encoding"); + if (a instanceof Name) r.update(a.name); + else if (a instanceof Ref) r.update(a.toString()); + else if (a instanceof Dict) + for (const e of a.getRawValues()) + if (e instanceof Name) r.update(e.name); + else if (e instanceof Ref) r.update(e.toString()); + else if (Array.isArray(e)) { + const t = e.length, + a = new Array(t); + for (let r = 0; r < t; r++) { + const t = e[r]; + t instanceof Name + ? (a[r] = t.name) + : ("number" == typeof t || t instanceof Ref) && + (a[r] = t.toString()); + } + r.update(a.join()); + } + r.update(`${n}-${s}`); + if (c instanceof BaseStream) { + const e = c.str || c, + t = e.buffer + ? new Uint8Array(e.buffer.buffer, 0, e.bufferLength) + : new Uint8Array(e.bytes.buffer, e.start, e.end - e.start); + r.update(t); + } else c instanceof Name && r.update(c.name); + const o = e.get("Widths") || t.get("Widths"); + if (Array.isArray(o)) { + const e = []; + for (const t of o) + ("number" == typeof t || t instanceof Ref) && e.push(t.toString()); + r.update(e.join()); + } + if (i) { + r.update("compositeFont"); + const a = e.get("W") || t.get("W"); + if (Array.isArray(a)) { + const e = []; + for (const t of a) + if ("number" == typeof t || t instanceof Ref) e.push(t.toString()); + else if (Array.isArray(t)) { + const a = []; + for (const e of t) + ("number" == typeof e || e instanceof Ref) && + a.push(e.toString()); + e.push(`[${a.join()}]`); + } + r.update(e.join()); + } + const i = e.getRaw("CIDToGIDMap") || t.getRaw("CIDToGIDMap"); + i instanceof Name + ? r.update(i.name) + : i instanceof Ref + ? r.update(i.toString()) + : i instanceof BaseStream && r.update(i.peekBytes()); + } + } + return { + descriptor: o, + dict: e, + baseDict: t, + composite: i, + type: a.name, + firstChar: n, + lastChar: s, + toUnicode: c, + hash: r ? r.hexdigest() : "", + }; + } + async translateFont({ + descriptor: e, + dict: a, + baseDict: r, + composite: i, + type: n, + firstChar: s, + lastChar: o, + toUnicode: c, + cssFontInfo: l, + }) { + const h = "Type3" === n; + if (!e) { + if (!h) { + let e = a.get("BaseFont"); + if (!(e instanceof Name)) + throw new FormatError("Base font is not specified"); + e = e.name.replaceAll(/[,_]/g, "-"); + const t = this.getBaseFontMetrics(e), + i = e.split("-", 1)[0], + l = + (this.isSerifFont(i) ? Er : 0) | + (t.monospace ? Nr : 0) | + (ei()[i] ? Pr : Lr), + u = { + type: n, + name: e, + loadedName: r.loadedName, + systemFontInfo: null, + widths: t.widths, + defaultWidth: t.defaultWidth, + isSimulatedFlags: !0, + flags: l, + firstChar: s, + lastChar: o, + toUnicode: c, + xHeight: 0, + capHeight: 0, + italicAngle: 0, + isType3Font: h, + }, + d = a.get("Widths"), + f = getStandardFontName(e); + let g = null; + if (f) { + g = await this.fetchStandardFontData(f); + u.isInternalFont = !!g; + } + !u.isInternalFont && + this.options.useSystemFonts && + (u.systemFontInfo = getFontSubstitution( + this.systemFontCache, + this.idFactory, + this.options.standardFontDataUrl, + e, + f, + n, + )); + const p = await this.extractDataStructures(a, u); + if (Array.isArray(d)) { + const e = []; + let t = s; + for (const a of d) { + const r = this.xref.fetchIfRef(a); + "number" == typeof r && (e[t] = r); + t++; + } + p.widths = e; + } else p.widths = this.buildCharCodeToWidth(t.widths, p); + return new Font(e, g, p, this.options); + } + e = Dict.empty; + } + let u = e.get("FontName"), + d = a.get("BaseFont"); + "string" == typeof u && (u = Name.get(u)); + "string" == typeof d && (d = Name.get(d)); + const f = u?.name, + g = d?.name; + if (h) f || (u = Name.get(n)); + else if (f !== g) { + info( + `The FontDescriptor's FontName is "${f}" but should be the same as the Font's BaseFont "${g}".`, + ); + f && + g && + (g.startsWith(f) || (!isKnownFontName(f) && isKnownFontName(g))) && + (u = null); + u ||= d; + } + if (!(u instanceof Name)) throw new FormatError("invalid font name"); + let p, m, b, y, w; + try { + p = e.get("FontFile", "FontFile2", "FontFile3"); + if (p) { + if (!(p instanceof BaseStream)) + throw new FormatError("FontFile should be a stream"); + if (p.isEmpty) throw new FormatError("FontFile is empty"); + } + } catch (e) { + if (!this.options.ignoreErrors) throw e; + warn(`translateFont - fetching "${u.name}" font file: "${e}".`); + p = null; + } + let x = !1, + S = null, + k = null; + if (p) { + if (p.dict) { + const e = p.dict.get("Subtype"); + e instanceof Name && (m = e.name); + b = p.dict.get("Length1"); + y = p.dict.get("Length2"); + w = p.dict.get("Length3"); + } + } else if (l) { + const e = getXfaFontName(u.name); + if (e) { + l.fontFamily = `${l.fontFamily}-PdfJS-XFA`; + l.metrics = e.metrics || null; + S = e.factors || null; + p = await this.fetchStandardFontData(e.name); + x = !!p; + r = a = getXfaFontDict(u.name); + i = !0; + } + } else if (!h) { + const e = getStandardFontName(u.name); + if (e) { + p = await this.fetchStandardFontData(e); + x = !!p; + } + !x && + this.options.useSystemFonts && + (k = getFontSubstitution( + this.systemFontCache, + this.idFactory, + this.options.standardFontDataUrl, + u.name, + e, + n, + )); + } + const C = lookupMatrix(a.getArray("FontMatrix"), t), + v = lookupNormalRect( + e.getArray("FontBBox") || a.getArray("FontBBox"), + h ? [0, 0, 0, 0] : void 0, + ); + let F = e.get("Ascent"); + "number" != typeof F && (F = void 0); + let T = e.get("Descent"); + "number" != typeof T && (T = void 0); + let O = e.get("XHeight"); + "number" != typeof O && (O = 0); + let M = e.get("CapHeight"); + "number" != typeof M && (M = 0); + let D = e.get("Flags"); + Number.isInteger(D) || (D = 0); + let R = e.get("ItalicAngle"); + "number" != typeof R && (R = 0); + const N = { + type: n, + name: u.name, + subtype: m, + file: p, + length1: b, + length2: y, + length3: w, + isInternalFont: x, + loadedName: r.loadedName, + composite: i, + fixedPitch: !1, + fontMatrix: C, + firstChar: s, + lastChar: o, + toUnicode: c, + bbox: v, + ascent: F, + descent: T, + xHeight: O, + capHeight: M, + flags: D, + italicAngle: R, + isType3Font: h, + cssFontInfo: l, + scaleFactors: S, + systemFontInfo: k, + }; + if (i) { + const e = r.get("Encoding"); + e instanceof Name && (N.cidEncoding = e.name); + const t = await CMapFactory.create({ + encoding: e, + fetchBuiltInCMap: this._fetchBuiltInCMapBound, + useCMap: null, + }); + N.cMap = t; + N.vertical = N.cMap.vertical; + } + const E = await this.extractDataStructures(a, N); + this.extractWidths(a, e, E); + return new Font(u.name, p, E, this.options); + } + static buildFontPaths(e, t, a, r) { + function buildPath(t) { + const i = `${e.loadedName}_path_${t}`; + try { + if (e.renderer.hasBuiltPath(t)) return; + a.send("commonobj", [i, "FontPath", e.renderer.getPathJs(t)]); + } catch (e) { + if (r.ignoreErrors) { + warn(`buildFontPaths - ignoring ${i} glyph: "${e}".`); + return; + } + throw e; + } + } + for (const e of t) { + buildPath(e.fontChar); + const t = e.accent; + t?.fontChar && buildPath(t.fontChar); + } + } + static get fallbackFontDict() { + const e = new Dict(); + e.set("BaseFont", Name.get("Helvetica")); + e.set("Type", Name.get("FallbackType")); + e.set("Subtype", Name.get("FallbackType")); + e.set("Encoding", Name.get("WinAnsiEncoding")); + return shadow(this, "fallbackFontDict", e); + } +} +class TranslatedFont { + #G = !1; + #V = null; + constructor({ loadedName: e, font: t, dict: a }) { + this.loadedName = e; + this.font = t; + this.dict = a; + this.type3Dependencies = t.isType3Font ? new Set() : null; + } + send(e) { + if (!this.#G) { + this.#G = !0; + e.send("commonobj", [this.loadedName, "Font", this.font.exportData()]); + } + } + fallback(e, t) { + if (this.font.data) { + this.font.disableFontFace = !0; + PartialEvaluator.buildFontPaths( + this.font, + this.font.glyphCacheValues, + e, + t, + ); + } + } + loadType3Data(e, t, a) { + if (this.#V) return this.#V; + const { font: r, type3Dependencies: i } = this; + assert(r.isType3Font, "Must be a Type3 font."); + const n = e.clone({ ignoreErrors: !1 }), + s = new RefSet(e.type3FontRefs); + this.dict.objId && !s.has(this.dict.objId) && s.put(this.dict.objId); + n.type3FontRefs = s; + let o = Promise.resolve(); + const c = this.dict.get("CharProcs"), + l = this.dict.get("Resources") || t, + h = Object.create(null), + [u, d, f, g] = r.bbox, + p = f - u, + m = g - d, + b = Math.hypot(p, m); + for (const e of c.getKeys()) + o = o.then(() => { + const t = c.get(e), + r = new OperatorList(); + return n + .getOperatorList({ + stream: t, + task: a, + resources: l, + operatorList: r, + }) + .then(() => { + switch (r.fnArray[0]) { + case bt: + this.#K(r, b); + break; + case mt: + b || this.#J(r); + } + h[e] = r.getIR(); + for (const e of r.dependencies) i.add(e); + }) + .catch(function (t) { + warn(`Type3 font resource "${e}" is not available.`); + const a = new OperatorList(); + h[e] = a.getIR(); + }); + }); + this.#V = o.then(() => { + r.charProcOperatorList = h; + if (this._bbox) { + r.isCharBBox = !0; + r.bbox = this._bbox; + } + }); + return this.#V; + } + #K(e, t = NaN) { + const a = Util.normalizeRect(e.argsArray[0].slice(2)), + r = a[2] - a[0], + i = a[3] - a[1], + n = Math.hypot(r, i); + if (0 === r || 0 === i) { + e.fnArray.splice(0, 1); + e.argsArray.splice(0, 1); + } else if (0 === t || Math.round(n / t) >= 10) { + this._bbox ??= [1 / 0, 1 / 0, -1 / 0, -1 / 0]; + Util.rectBoundingBox(...a, this._bbox); + } + let s = 0, + o = e.length; + for (; s < o; ) { + switch (e.fnArray[s]) { + case bt: + break; + case yt: + case wt: + case xt: + case St: + case kt: + case At: + case Ct: + case vt: + case Ft: + case It: + case Tt: + case Ot: + case Mt: + case Oe: + e.fnArray.splice(s, 1); + e.argsArray.splice(s, 1); + o--; + continue; + case De: + const [t] = e.argsArray[s]; + let a = 0, + r = t.length; + for (; a < r; ) { + const [e] = t[a]; + switch (e) { + case "TR": + case "TR2": + case "HT": + case "BG": + case "BG2": + case "UCR": + case "UCR2": + t.splice(a, 1); + r--; + continue; + } + a++; + } + } + s++; + } + } + #J(e) { + let t = 1; + const a = e.length; + for (; t < a; ) { + if (e.fnArray[t] === aa) { + const a = e.argsArray[t][2]; + this._bbox ??= [1 / 0, 1 / 0, -1 / 0, -1 / 0]; + Util.rectBoundingBox(...a, this._bbox); + } + t++; + } + } +} +class StateManager { + constructor(e = new EvalState()) { + this.state = e; + this.stateStack = []; + } + save() { + const e = this.state; + this.stateStack.push(this.state); + this.state = e.clone(); + } + restore() { + const e = this.stateStack.pop(); + e && (this.state = e); + } + transform(e) { + this.state.ctm = Util.transform(this.state.ctm, e); + } +} +class TextState { + constructor() { + this.ctm = new Float32Array(Fa); + this.fontName = null; + this.fontSize = 0; + this.loadedName = null; + this.font = null; + this.fontMatrix = t; + this.textMatrix = Fa.slice(); + this.textLineMatrix = Fa.slice(); + this.charSpacing = 0; + this.wordSpacing = 0; + this.leading = 0; + this.textHScale = 1; + this.textRise = 0; + } + setTextMatrix(e, t, a, r, i, n) { + const s = this.textMatrix; + s[0] = e; + s[1] = t; + s[2] = a; + s[3] = r; + s[4] = i; + s[5] = n; + } + setTextLineMatrix(e, t, a, r, i, n) { + const s = this.textLineMatrix; + s[0] = e; + s[1] = t; + s[2] = a; + s[3] = r; + s[4] = i; + s[5] = n; + } + translateTextMatrix(e, t) { + const a = this.textMatrix; + a[4] = a[0] * e + a[2] * t + a[4]; + a[5] = a[1] * e + a[3] * t + a[5]; + } + translateTextLineMatrix(e, t) { + const a = this.textLineMatrix; + a[4] = a[0] * e + a[2] * t + a[4]; + a[5] = a[1] * e + a[3] * t + a[5]; + } + carriageReturn() { + this.translateTextLineMatrix(0, -this.leading); + this.textMatrix = this.textLineMatrix.slice(); + } + clone() { + const e = Object.create(this); + e.textMatrix = this.textMatrix.slice(); + e.textLineMatrix = this.textLineMatrix.slice(); + e.fontMatrix = this.fontMatrix.slice(); + return e; + } +} +class EvalState { + constructor() { + this.ctm = new Float32Array(Fa); + this.font = null; + this.textRenderingMode = x; + this._fillColorSpace = this._strokeColorSpace = ColorSpaceUtils.gray; + this.patternFillColorSpace = null; + this.patternStrokeColorSpace = null; + this.currentPointX = this.currentPointY = 0; + this.pathMinMax = new Float32Array([1 / 0, 1 / 0, -1 / 0, -1 / 0]); + this.pathBuffer = []; + } + get fillColorSpace() { + return this._fillColorSpace; + } + set fillColorSpace(e) { + this._fillColorSpace = this.patternFillColorSpace = e; + } + get strokeColorSpace() { + return this._strokeColorSpace; + } + set strokeColorSpace(e) { + this._strokeColorSpace = this.patternStrokeColorSpace = e; + } + clone({ newPath: e = !1 } = {}) { + const t = Object.create(this); + if (e) { + t.pathBuffer = []; + t.pathMinMax = new Float32Array([1 / 0, 1 / 0, -1 / 0, -1 / 0]); + } + return t; + } +} +class EvaluatorPreprocessor { + static get opMap() { + return shadow( + this, + "opMap", + Object.assign(Object.create(null), { + w: { id: Ce, numArgs: 1, variableArgs: !1 }, + J: { id: ve, numArgs: 1, variableArgs: !1 }, + j: { id: Fe, numArgs: 1, variableArgs: !1 }, + M: { id: Ie, numArgs: 1, variableArgs: !1 }, + d: { id: Te, numArgs: 2, variableArgs: !1 }, + ri: { id: Oe, numArgs: 1, variableArgs: !1 }, + i: { id: Me, numArgs: 1, variableArgs: !1 }, + gs: { id: De, numArgs: 1, variableArgs: !1 }, + q: { id: Be, numArgs: 0, variableArgs: !1 }, + Q: { id: Re, numArgs: 0, variableArgs: !1 }, + cm: { id: Ne, numArgs: 6, variableArgs: !1 }, + m: { id: Ee, numArgs: 2, variableArgs: !1 }, + l: { id: Pe, numArgs: 2, variableArgs: !1 }, + c: { id: Le, numArgs: 6, variableArgs: !1 }, + v: { id: je, numArgs: 4, variableArgs: !1 }, + y: { id: _e, numArgs: 4, variableArgs: !1 }, + h: { id: Ue, numArgs: 0, variableArgs: !1 }, + re: { id: Xe, numArgs: 4, variableArgs: !1 }, + S: { id: qe, numArgs: 0, variableArgs: !1 }, + s: { id: He, numArgs: 0, variableArgs: !1 }, + f: { id: We, numArgs: 0, variableArgs: !1 }, + F: { id: We, numArgs: 0, variableArgs: !1 }, + "f*": { id: ze, numArgs: 0, variableArgs: !1 }, + B: { id: $e, numArgs: 0, variableArgs: !1 }, + "B*": { id: Ge, numArgs: 0, variableArgs: !1 }, + b: { id: Ve, numArgs: 0, variableArgs: !1 }, + "b*": { id: Ke, numArgs: 0, variableArgs: !1 }, + n: { id: Je, numArgs: 0, variableArgs: !1 }, + W: { id: Ye, numArgs: 0, variableArgs: !1 }, + "W*": { id: Ze, numArgs: 0, variableArgs: !1 }, + BT: { id: Qe, numArgs: 0, variableArgs: !1 }, + ET: { id: et, numArgs: 0, variableArgs: !1 }, + Tc: { id: tt, numArgs: 1, variableArgs: !1 }, + Tw: { id: at, numArgs: 1, variableArgs: !1 }, + Tz: { id: rt, numArgs: 1, variableArgs: !1 }, + TL: { id: it, numArgs: 1, variableArgs: !1 }, + Tf: { id: nt, numArgs: 2, variableArgs: !1 }, + Tr: { id: st, numArgs: 1, variableArgs: !1 }, + Ts: { id: ot, numArgs: 1, variableArgs: !1 }, + Td: { id: ct, numArgs: 2, variableArgs: !1 }, + TD: { id: lt, numArgs: 2, variableArgs: !1 }, + Tm: { id: ht, numArgs: 6, variableArgs: !1 }, + "T*": { id: ut, numArgs: 0, variableArgs: !1 }, + Tj: { id: dt, numArgs: 1, variableArgs: !1 }, + TJ: { id: ft, numArgs: 1, variableArgs: !1 }, + "'": { id: gt, numArgs: 1, variableArgs: !1 }, + '"': { id: pt, numArgs: 3, variableArgs: !1 }, + d0: { id: mt, numArgs: 2, variableArgs: !1 }, + d1: { id: bt, numArgs: 6, variableArgs: !1 }, + CS: { id: yt, numArgs: 1, variableArgs: !1 }, + cs: { id: wt, numArgs: 1, variableArgs: !1 }, + SC: { id: xt, numArgs: 4, variableArgs: !0 }, + SCN: { id: St, numArgs: 33, variableArgs: !0 }, + sc: { id: kt, numArgs: 4, variableArgs: !0 }, + scn: { id: At, numArgs: 33, variableArgs: !0 }, + G: { id: Ct, numArgs: 1, variableArgs: !1 }, + g: { id: vt, numArgs: 1, variableArgs: !1 }, + RG: { id: Ft, numArgs: 3, variableArgs: !1 }, + rg: { id: It, numArgs: 3, variableArgs: !1 }, + K: { id: Tt, numArgs: 4, variableArgs: !1 }, + k: { id: Ot, numArgs: 4, variableArgs: !1 }, + sh: { id: Mt, numArgs: 1, variableArgs: !1 }, + BI: { id: Dt, numArgs: 0, variableArgs: !1 }, + ID: { id: Bt, numArgs: 0, variableArgs: !1 }, + EI: { id: Rt, numArgs: 1, variableArgs: !1 }, + Do: { id: Nt, numArgs: 1, variableArgs: !1 }, + MP: { id: Et, numArgs: 1, variableArgs: !1 }, + DP: { id: Pt, numArgs: 2, variableArgs: !1 }, + BMC: { id: Lt, numArgs: 1, variableArgs: !1 }, + BDC: { id: jt, numArgs: 2, variableArgs: !1 }, + EMC: { id: _t, numArgs: 0, variableArgs: !1 }, + BX: { id: Ut, numArgs: 0, variableArgs: !1 }, + EX: { id: Xt, numArgs: 0, variableArgs: !1 }, + BM: null, + BD: null, + true: null, + fa: null, + fal: null, + fals: null, + false: null, + nu: null, + nul: null, + null: null, + }), + ); + } + static MAX_INVALID_PATH_OPS = 10; + constructor(e, t, a = new StateManager()) { + this.parser = new Parser({ + lexer: new Lexer(e, EvaluatorPreprocessor.opMap), + xref: t, + }); + this.stateManager = a; + this.nonProcessedArgs = []; + this._isPathOp = !1; + this._numInvalidPathOPS = 0; + } + get savedStatesDepth() { + return this.stateManager.stateStack.length; + } + read(e) { + let t = e.args; + for (;;) { + const a = this.parser.getObj(); + if (a instanceof Cmd) { + const r = a.cmd, + i = EvaluatorPreprocessor.opMap[r]; + if (!i) { + warn(`Unknown command "${r}".`); + continue; + } + const n = i.id, + s = i.numArgs; + let o = null !== t ? t.length : 0; + this._isPathOp || (this._numInvalidPathOPS = 0); + this._isPathOp = n >= Ee && n <= Je; + if (i.variableArgs) + o > s && + info( + `Command ${r}: expected [0, ${s}] args, but received ${o} args.`, + ); + else { + if (o !== s) { + const e = this.nonProcessedArgs; + for (; o > s; ) { + e.push(t.shift()); + o--; + } + for (; o < s && 0 !== e.length; ) { + null === t && (t = []); + t.unshift(e.pop()); + o++; + } + } + if (o < s) { + const e = `command ${r}: expected ${s} args, but received ${o} args.`; + if ( + this._isPathOp && + ++this._numInvalidPathOPS > + EvaluatorPreprocessor.MAX_INVALID_PATH_OPS + ) + throw new FormatError(`Invalid ${e}`); + warn(`Skipping ${e}`); + null !== t && (t.length = 0); + continue; + } + } + this.preprocessCommand(n, t); + e.fn = n; + e.args = t; + return !0; + } + if (a === wa) return !1; + if (null !== a) { + null === t && (t = []); + t.push(a); + if (t.length > 33) throw new FormatError("Too many arguments"); + } + } + } + preprocessCommand(e, t) { + switch (0 | e) { + case Be: + this.stateManager.save(); + break; + case Re: + this.stateManager.restore(); + break; + case Ne: + this.stateManager.transform(t); + } + } +} +class DefaultAppearanceEvaluator extends EvaluatorPreprocessor { + constructor(e) { + super(new StringStream(e)); + } + parse() { + const e = { fn: 0, args: [] }, + t = { fontSize: 0, fontName: "", fontColor: new Uint8ClampedArray(3) }; + try { + for (;;) { + e.args.length = 0; + if (!this.read(e)) break; + if (0 !== this.savedStatesDepth) continue; + const { fn: a, args: r } = e; + switch (0 | a) { + case nt: + const [e, a] = r; + e instanceof Name && (t.fontName = e.name); + "number" == typeof a && a > 0 && (t.fontSize = a); + break; + case It: + ColorSpaceUtils.rgb.getRgbItem(r, 0, t.fontColor, 0); + break; + case vt: + ColorSpaceUtils.gray.getRgbItem(r, 0, t.fontColor, 0); + break; + case Ot: + ColorSpaceUtils.cmyk.getRgbItem(r, 0, t.fontColor, 0); + } + } + } catch (e) { + warn(`parseDefaultAppearance - ignoring errors: "${e}".`); + } + return t; + } +} +function parseDefaultAppearance(e) { + return new DefaultAppearanceEvaluator(e).parse(); +} +class AppearanceStreamEvaluator extends EvaluatorPreprocessor { + constructor(e, t, a, r) { + super(e); + this.stream = e; + this.evaluatorOptions = t; + this.xref = a; + this.globalColorSpaceCache = r; + this.resources = e.dict?.get("Resources"); + } + parse() { + const e = { fn: 0, args: [] }; + let t = { + scaleFactor: 1, + fontSize: 0, + fontName: "", + fontColor: new Uint8ClampedArray(3), + fillColorSpace: ColorSpaceUtils.gray, + }, + a = !1; + const r = []; + try { + for (;;) { + e.args.length = 0; + if (a || !this.read(e)) break; + const { fn: i, args: n } = e; + switch (0 | i) { + case Be: + r.push({ + scaleFactor: t.scaleFactor, + fontSize: t.fontSize, + fontName: t.fontName, + fontColor: t.fontColor.slice(), + fillColorSpace: t.fillColorSpace, + }); + break; + case Re: + t = r.pop() || t; + break; + case ht: + t.scaleFactor *= Math.hypot(n[0], n[1]); + break; + case nt: + const [e, i] = n; + e instanceof Name && (t.fontName = e.name); + "number" == typeof i && i > 0 && (t.fontSize = i * t.scaleFactor); + break; + case wt: + t.fillColorSpace = ColorSpaceUtils.parse({ + cs: n[0], + xref: this.xref, + resources: this.resources, + pdfFunctionFactory: this._pdfFunctionFactory, + globalColorSpaceCache: this.globalColorSpaceCache, + localColorSpaceCache: this._localColorSpaceCache, + }); + break; + case kt: + t.fillColorSpace.getRgbItem(n, 0, t.fontColor, 0); + break; + case It: + ColorSpaceUtils.rgb.getRgbItem(n, 0, t.fontColor, 0); + break; + case vt: + ColorSpaceUtils.gray.getRgbItem(n, 0, t.fontColor, 0); + break; + case Ot: + ColorSpaceUtils.cmyk.getRgbItem(n, 0, t.fontColor, 0); + break; + case dt: + case ft: + case gt: + case pt: + a = !0; + } + } + } catch (e) { + warn(`parseAppearanceStream - ignoring errors: "${e}".`); + } + this.stream.reset(); + delete t.scaleFactor; + delete t.fillColorSpace; + return t; + } + get _localColorSpaceCache() { + return shadow(this, "_localColorSpaceCache", new LocalColorSpaceCache()); + } + get _pdfFunctionFactory() { + return shadow( + this, + "_pdfFunctionFactory", + new PDFFunctionFactory({ + xref: this.xref, + isEvalSupported: this.evaluatorOptions.isEvalSupported, + }), + ); + } +} +function getPdfColor(e, t) { + if (e[0] === e[1] && e[1] === e[2]) { + return `${numberToString(e[0] / 255)} ${t ? "g" : "G"}`; + } + return ( + Array.from(e, (e) => numberToString(e / 255)).join(" ") + + " " + + (t ? "rg" : "RG") + ); +} +class FakeUnicodeFont { + constructor(e, t) { + this.xref = e; + this.widths = null; + this.firstChar = 1 / 0; + this.lastChar = -1 / 0; + this.fontFamily = t; + const a = new OffscreenCanvas(1, 1); + this.ctxMeasure = a.getContext("2d", { willReadFrequently: !0 }); + FakeUnicodeFont._fontNameId || (FakeUnicodeFont._fontNameId = 1); + this.fontName = Name.get( + `InvalidPDFjsFont_${t}_${FakeUnicodeFont._fontNameId++}`, + ); + } + get fontDescriptorRef() { + if (!FakeUnicodeFont._fontDescriptorRef) { + const e = new Dict(this.xref); + e.set("Type", Name.get("FontDescriptor")); + e.set("FontName", this.fontName); + e.set("FontFamily", "MyriadPro Regular"); + e.set("FontBBox", [0, 0, 0, 0]); + e.set("FontStretch", Name.get("Normal")); + e.set("FontWeight", 400); + e.set("ItalicAngle", 0); + FakeUnicodeFont._fontDescriptorRef = this.xref.getNewPersistentRef(e); + } + return FakeUnicodeFont._fontDescriptorRef; + } + get descendantFontRef() { + const e = new Dict(this.xref); + e.set("BaseFont", this.fontName); + e.set("Type", Name.get("Font")); + e.set("Subtype", Name.get("CIDFontType0")); + e.set("CIDToGIDMap", Name.get("Identity")); + e.set("FirstChar", this.firstChar); + e.set("LastChar", this.lastChar); + e.set("FontDescriptor", this.fontDescriptorRef); + e.set("DW", 1e3); + const t = [], + a = [...this.widths.entries()].sort(); + let r = null, + i = null; + for (const [e, n] of a) + if (r) + if (e === r + i.length) i.push(n); + else { + t.push(r, i); + r = e; + i = [n]; + } + else { + r = e; + i = [n]; + } + r && t.push(r, i); + e.set("W", t); + const n = new Dict(this.xref); + n.set("Ordering", "Identity"); + n.set("Registry", "Adobe"); + n.set("Supplement", 0); + e.set("CIDSystemInfo", n); + return this.xref.getNewPersistentRef(e); + } + get baseFontRef() { + const e = new Dict(this.xref); + e.set("BaseFont", this.fontName); + e.set("Type", Name.get("Font")); + e.set("Subtype", Name.get("Type0")); + e.set("Encoding", Name.get("Identity-H")); + e.set("DescendantFonts", [this.descendantFontRef]); + e.set("ToUnicode", Name.get("Identity-H")); + return this.xref.getNewPersistentRef(e); + } + get resources() { + const e = new Dict(this.xref), + t = new Dict(this.xref); + t.set(this.fontName.name, this.baseFontRef); + e.set("Font", t); + return e; + } + _createContext() { + this.widths = new Map(); + this.ctxMeasure.font = `1000px ${this.fontFamily}`; + return this.ctxMeasure; + } + createFontResources(e) { + const t = this._createContext(); + for (const a of e.split(/\r\n?|\n/)) + for (const e of a.split("")) { + const a = e.charCodeAt(0); + if (this.widths.has(a)) continue; + const r = t.measureText(e), + i = Math.ceil(r.width); + this.widths.set(a, i); + this.firstChar = Math.min(a, this.firstChar); + this.lastChar = Math.max(a, this.lastChar); + } + return this.resources; + } + static getFirstPositionInfo(e, t, i) { + const [n, s, o, c] = e; + let l = o - n, + h = c - s; + t % 180 != 0 && ([l, h] = [h, l]); + const u = a * i; + return { + coords: [0, h + r * i - u], + bbox: [0, 0, l, h], + matrix: 0 !== t ? getRotationMatrix(t, h, u) : void 0, + }; + } + createAppearance(e, t, i, n, s, o) { + const c = this._createContext(), + l = []; + let h = -1 / 0; + for (const t of e.split(/\r\n?|\n/)) { + l.push(t); + const e = c.measureText(t).width; + h = Math.max(h, e); + for (const e of codePointIter(t)) { + const t = String.fromCodePoint(e); + let a = this.widths.get(e); + if (void 0 === a) { + const r = c.measureText(t); + a = Math.ceil(r.width); + this.widths.set(e, a); + this.firstChar = Math.min(e, this.firstChar); + this.lastChar = Math.max(e, this.lastChar); + } + } + } + h *= n / 1e3; + const [u, d, f, g] = t; + let p = f - u, + m = g - d; + i % 180 != 0 && ([p, m] = [m, p]); + let b = 1; + h > p && (b = p / h); + let y = 1; + const w = a * n, + x = r * n, + S = w * l.length; + S > m && (y = m / S); + const k = n * Math.min(b, y), + C = [ + "q", + `0 0 ${numberToString(p)} ${numberToString(m)} re W n`, + "BT", + `1 0 0 1 0 ${numberToString(m + x)} Tm 0 Tc ${getPdfColor(s, !0)}`, + `/${this.fontName.name} ${numberToString(k)} Tf`, + ], + { resources: v } = this; + if (1 !== (o = "number" == typeof o && o >= 0 && o <= 1 ? o : 1)) { + C.push("/R0 gs"); + const e = new Dict(this.xref), + t = new Dict(this.xref); + t.set("ca", o); + t.set("CA", o); + t.set("Type", Name.get("ExtGState")); + e.set("R0", t); + v.set("ExtGState", e); + } + const F = numberToString(w); + for (const e of l) C.push(`0 -${F} Td <${stringToUTF16HexString(e)}> Tj`); + C.push("ET", "Q"); + const T = C.join("\n"), + O = new Dict(this.xref); + O.set("Subtype", Name.get("Form")); + O.set("Type", Name.get("XObject")); + O.set("BBox", [0, 0, p, m]); + O.set("Length", T.length); + O.set("Resources", v); + if (i) { + const e = getRotationMatrix(i, p, m); + O.set("Matrix", e); + } + const M = new StringStream(T); + M.dict = O; + return M; + } +} +const Pn = [ + "m/d", + "m/d/yy", + "mm/dd/yy", + "mm/yy", + "d-mmm", + "d-mmm-yy", + "dd-mmm-yy", + "yy-mm-dd", + "mmm-yy", + "mmmm-yy", + "mmm d, yyyy", + "mmmm d, yyyy", + "m/d/yy h:MM tt", + "m/d/yy HH:MM", + ], + Ln = ["HH:MM", "h:MM tt", "HH:MM:ss", "h:MM:ss tt"]; +class NameOrNumberTree { + constructor(e, t, a) { + this.root = e; + this.xref = t; + this._type = a; + } + getAll() { + const e = new Map(); + if (!this.root) return e; + const t = this.xref, + a = new RefSet(); + a.put(this.root); + const r = [this.root]; + for (; r.length > 0; ) { + const i = t.fetchIfRef(r.shift()); + if (!(i instanceof Dict)) continue; + if (i.has("Kids")) { + const e = i.get("Kids"); + if (!Array.isArray(e)) continue; + for (const t of e) { + if (a.has(t)) + throw new FormatError(`Duplicate entry in "${this._type}" tree.`); + r.push(t); + a.put(t); + } + continue; + } + const n = i.get(this._type); + if (Array.isArray(n)) + for (let a = 0, r = n.length; a < r; a += 2) + e.set(t.fetchIfRef(n[a]), t.fetchIfRef(n[a + 1])); + } + return e; + } + getRaw(e) { + if (!this.root) return null; + const t = this.xref; + let a = t.fetchIfRef(this.root), + r = 0; + for (; a.has("Kids"); ) { + if (++r > 10) { + warn(`Search depth limit reached for "${this._type}" tree.`); + return null; + } + const i = a.get("Kids"); + if (!Array.isArray(i)) return null; + let n = 0, + s = i.length - 1; + for (; n <= s; ) { + const r = (n + s) >> 1, + o = t.fetchIfRef(i[r]), + c = o.get("Limits"); + if (e < t.fetchIfRef(c[0])) s = r - 1; + else { + if (!(e > t.fetchIfRef(c[1]))) { + a = o; + break; + } + n = r + 1; + } + } + if (n > s) return null; + } + const i = a.get(this._type); + if (Array.isArray(i)) { + let a = 0, + r = i.length - 2; + for (; a <= r; ) { + const n = (a + r) >> 1, + s = n + (1 & n), + o = t.fetchIfRef(i[s]); + if (e < o) r = s - 2; + else { + if (!(e > o)) return i[s + 1]; + a = s + 2; + } + } + } + return null; + } + get(e) { + return this.xref.fetchIfRef(this.getRaw(e)); + } +} +class NameTree extends NameOrNumberTree { + constructor(e, t) { + super(e, t, "Names"); + } +} +class NumberTree extends NameOrNumberTree { + constructor(e, t) { + super(e, t, "Nums"); + } +} +function clearGlobalCaches() { + !(function clearPatternCaches() { + Ii = Object.create(null); + })(); + !(function clearPrimitiveCaches() { + xa = Object.create(null); + Sa = Object.create(null); + ka = Object.create(null); + })(); + !(function clearUnicodeCaches() { + Dr.clear(); + })(); + JpxImage.cleanup(); +} +function pickPlatformItem(e) { + return e instanceof Dict + ? e.has("UF") + ? e.get("UF") + : e.has("F") + ? e.get("F") + : e.has("Unix") + ? e.get("Unix") + : e.has("Mac") + ? e.get("Mac") + : e.has("DOS") + ? e.get("DOS") + : null + : null; +} +class FileSpec { + #Y = !1; + constructor(e, t, a = !1) { + if (e instanceof Dict) { + this.xref = t; + this.root = e; + e.has("FS") && (this.fs = e.get("FS")); + e.has("RF") && warn("Related file specifications are not supported"); + a || + (e.has("EF") + ? (this.#Y = !0) + : warn("Non-embedded file specifications are not supported")); + } + } + get filename() { + let e = ""; + const t = pickPlatformItem(this.root); + t && + "string" == typeof t && + (e = stringToPDFString(t, !0) + .replaceAll("\\\\", "\\") + .replaceAll("\\/", "/") + .replaceAll("\\", "/")); + return shadow(this, "filename", e || "unnamed"); + } + get content() { + if (!this.#Y) return null; + this._contentRef ||= pickPlatformItem(this.root?.get("EF")); + let e = null; + if (this._contentRef) { + const t = this.xref.fetchIfRef(this._contentRef); + t instanceof BaseStream + ? (e = t.getBytes()) + : warn( + "Embedded file specification points to non-existing/invalid content", + ); + } else warn("Embedded file specification does not have any content"); + return e; + } + get description() { + let e = ""; + const t = this.root?.get("Desc"); + t && "string" == typeof t && (e = stringToPDFString(t)); + return shadow(this, "description", e); + } + get serializable() { + return { + rawFilename: this.filename, + filename: ((e = this.filename), e.substring(e.lastIndexOf("/") + 1)), + content: this.content, + description: this.description, + }; + var e; + } +} +const jn = 0, + _n = -2, + Un = -3, + Xn = -4, + qn = -5, + Hn = -6, + Wn = -9; +function isWhitespace(e, t) { + const a = e[t]; + return " " === a || "\n" === a || "\r" === a || "\t" === a; +} +class XMLParserBase { + _resolveEntities(e) { + return e.replaceAll(/&([^;]+);/g, (e, t) => { + if ("#x" === t.substring(0, 2)) + return String.fromCodePoint(parseInt(t.substring(2), 16)); + if ("#" === t.substring(0, 1)) + return String.fromCodePoint(parseInt(t.substring(1), 10)); + switch (t) { + case "lt": + return "<"; + case "gt": + return ">"; + case "amp": + return "&"; + case "quot": + return '"'; + case "apos": + return "'"; + } + return this.onResolveEntity(t); + }); + } + _parseContent(e, t) { + const a = []; + let r = t; + function skipWs() { + for (; r < e.length && isWhitespace(e, r); ) ++r; + } + for ( + ; + r < e.length && !isWhitespace(e, r) && ">" !== e[r] && "/" !== e[r]; + + ) + ++r; + const i = e.substring(t, r); + skipWs(); + for (; r < e.length && ">" !== e[r] && "/" !== e[r] && "?" !== e[r]; ) { + skipWs(); + let t = "", + i = ""; + for (; r < e.length && !isWhitespace(e, r) && "=" !== e[r]; ) { + t += e[r]; + ++r; + } + skipWs(); + if ("=" !== e[r]) return null; + ++r; + skipWs(); + const n = e[r]; + if ('"' !== n && "'" !== n) return null; + const s = e.indexOf(n, ++r); + if (s < 0) return null; + i = e.substring(r, s); + a.push({ name: t, value: this._resolveEntities(i) }); + r = s + 1; + skipWs(); + } + return { name: i, attributes: a, parsed: r - t }; + } + _parseProcessingInstruction(e, t) { + let a = t; + for ( + ; + a < e.length && + !isWhitespace(e, a) && + ">" !== e[a] && + "?" !== e[a] && + "/" !== e[a]; + + ) + ++a; + const r = e.substring(t, a); + !(function skipWs() { + for (; a < e.length && isWhitespace(e, a); ) ++a; + })(); + const i = a; + for (; a < e.length && ("?" !== e[a] || ">" !== e[a + 1]); ) ++a; + return { name: r, value: e.substring(i, a), parsed: a - t }; + } + parseXml(e) { + let t = 0; + for (; t < e.length; ) { + let a = t; + if ("<" === e[t]) { + ++a; + let t; + switch (e[a]) { + case "/": + ++a; + t = e.indexOf(">", a); + if (t < 0) { + this.onError(Wn); + return; + } + this.onEndElement(e.substring(a, t)); + a = t + 1; + break; + case "?": + ++a; + const r = this._parseProcessingInstruction(e, a); + if ("?>" !== e.substring(a + r.parsed, a + r.parsed + 2)) { + this.onError(Un); + return; + } + this.onPi(r.name, r.value); + a += r.parsed + 2; + break; + case "!": + if ("--" === e.substring(a + 1, a + 3)) { + t = e.indexOf("--\x3e", a + 3); + if (t < 0) { + this.onError(qn); + return; + } + this.onComment(e.substring(a + 3, t)); + a = t + 3; + } else if ("[CDATA[" === e.substring(a + 1, a + 8)) { + t = e.indexOf("]]>", a + 8); + if (t < 0) { + this.onError(_n); + return; + } + this.onCdata(e.substring(a + 8, t)); + a = t + 3; + } else { + if ("DOCTYPE" !== e.substring(a + 1, a + 8)) { + this.onError(Hn); + return; + } + { + const r = e.indexOf("[", a + 8); + let i = !1; + t = e.indexOf(">", a + 8); + if (t < 0) { + this.onError(Xn); + return; + } + if (r > 0 && t > r) { + t = e.indexOf("]>", a + 8); + if (t < 0) { + this.onError(Xn); + return; + } + i = !0; + } + const n = e.substring(a + 8, t + (i ? 1 : 0)); + this.onDoctype(n); + a = t + (i ? 2 : 1); + } + } + break; + default: + const i = this._parseContent(e, a); + if (null === i) { + this.onError(Hn); + return; + } + let n = !1; + if ("/>" === e.substring(a + i.parsed, a + i.parsed + 2)) n = !0; + else if (">" !== e.substring(a + i.parsed, a + i.parsed + 1)) { + this.onError(Wn); + return; + } + this.onBeginElement(i.name, i.attributes, n); + a += i.parsed + (n ? 2 : 1); + } + } else { + for (; a < e.length && "<" !== e[a]; ) a++; + const r = e.substring(t, a); + this.onText(this._resolveEntities(r)); + } + t = a; + } + } + onResolveEntity(e) { + return `&${e};`; + } + onPi(e, t) {} + onComment(e) {} + onCdata(e) {} + onDoctype(e) {} + onText(e) {} + onBeginElement(e, t, a) {} + onEndElement(e) {} + onError(e) {} +} +class SimpleDOMNode { + constructor(e, t) { + this.nodeName = e; + this.nodeValue = t; + Object.defineProperty(this, "parentNode", { value: null, writable: !0 }); + } + get firstChild() { + return this.childNodes?.[0]; + } + get nextSibling() { + const e = this.parentNode.childNodes; + if (!e) return; + const t = e.indexOf(this); + return -1 !== t ? e[t + 1] : void 0; + } + get textContent() { + return this.childNodes + ? this.childNodes.map((e) => e.textContent).join("") + : this.nodeValue || ""; + } + get children() { + return this.childNodes || []; + } + hasChildNodes() { + return this.childNodes?.length > 0; + } + searchNode(e, t) { + if (t >= e.length) return this; + const a = e[t]; + if (a.name.startsWith("#") && t < e.length - 1) + return this.searchNode(e, t + 1); + const r = []; + let i = this; + for (;;) { + if (a.name === i.nodeName) { + if (0 !== a.pos) { + if (0 === r.length) return null; + { + const [n] = r.pop(); + let s = 0; + for (const r of n.childNodes) + if (a.name === r.nodeName) { + if (s === a.pos) return r.searchNode(e, t + 1); + s++; + } + return i.searchNode(e, t + 1); + } + } + { + const a = i.searchNode(e, t + 1); + if (null !== a) return a; + } + } + if (i.childNodes?.length > 0) { + r.push([i, 0]); + i = i.childNodes[0]; + } else { + if (0 === r.length) return null; + for (; 0 !== r.length; ) { + const [e, t] = r.pop(), + a = t + 1; + if (a < e.childNodes.length) { + r.push([e, a]); + i = e.childNodes[a]; + break; + } + } + if (0 === r.length) return null; + } + } + } + dump(e) { + if ("#text" !== this.nodeName) { + e.push(`<${this.nodeName}`); + if (this.attributes) + for (const t of this.attributes) + e.push(` ${t.name}="${encodeToXmlString(t.value)}"`); + if (this.hasChildNodes()) { + e.push(">"); + for (const t of this.childNodes) t.dump(e); + e.push(``); + } else + this.nodeValue + ? e.push(`>${encodeToXmlString(this.nodeValue)}`) + : e.push("/>"); + } else e.push(encodeToXmlString(this.nodeValue)); + } +} +class SimpleXMLParser extends XMLParserBase { + constructor({ hasAttributes: e = !1, lowerCaseName: t = !1 }) { + super(); + this._currentFragment = null; + this._stack = null; + this._errorCode = jn; + this._hasAttributes = e; + this._lowerCaseName = t; + } + parseFromString(e) { + this._currentFragment = []; + this._stack = []; + this._errorCode = jn; + this.parseXml(e); + if (this._errorCode !== jn) return; + const [t] = this._currentFragment; + return t ? { documentElement: t } : void 0; + } + onText(e) { + if ( + (function isWhitespaceString(e) { + for (let t = 0, a = e.length; t < a; t++) + if (!isWhitespace(e, t)) return !1; + return !0; + })(e) + ) + return; + const t = new SimpleDOMNode("#text", e); + this._currentFragment.push(t); + } + onCdata(e) { + const t = new SimpleDOMNode("#text", e); + this._currentFragment.push(t); + } + onBeginElement(e, t, a) { + this._lowerCaseName && (e = e.toLowerCase()); + const r = new SimpleDOMNode(e); + r.childNodes = []; + this._hasAttributes && (r.attributes = t); + this._currentFragment.push(r); + if (!a) { + this._stack.push(this._currentFragment); + this._currentFragment = r.childNodes; + } + } + onEndElement(e) { + this._currentFragment = this._stack.pop() || []; + const t = this._currentFragment.at(-1); + if (!t) return null; + for (const e of t.childNodes) e.parentNode = t; + return t; + } + onError(e) { + this._errorCode = e; + } +} +class MetadataParser { + constructor(e) { + e = this._repair(e); + const t = new SimpleXMLParser({ lowerCaseName: !0 }).parseFromString(e); + this._metadataMap = new Map(); + this._data = e; + t && this._parse(t); + } + _repair(e) { + return e + .replace(/^[^<]+/, "") + .replaceAll(/>\\376\\377([^<]+)/g, function (e, t) { + const a = t + .replaceAll(/\\([0-3])([0-7])([0-7])/g, function (e, t, a, r) { + return String.fromCharCode(64 * t + 8 * a + 1 * r); + }) + .replaceAll(/&(amp|apos|gt|lt|quot);/g, function (e, t) { + switch (t) { + case "amp": + return "&"; + case "apos": + return "'"; + case "gt": + return ">"; + case "lt": + return "<"; + case "quot": + return '"'; + } + throw new Error(`_repair: ${t} isn't defined.`); + }), + r = [">"]; + for (let e = 0, t = a.length; e < t; e += 2) { + const t = 256 * a.charCodeAt(e) + a.charCodeAt(e + 1); + t >= 32 && t < 127 && 60 !== t && 62 !== t && 38 !== t + ? r.push(String.fromCharCode(t)) + : r.push("&#x" + (65536 + t).toString(16).substring(1) + ";"); + } + return r.join(""); + }); + } + _getSequence(e) { + const t = e.nodeName; + return "rdf:bag" !== t && "rdf:seq" !== t && "rdf:alt" !== t + ? null + : e.childNodes.filter((e) => "rdf:li" === e.nodeName); + } + _parseArray(e) { + if (!e.hasChildNodes()) return; + const [t] = e.childNodes, + a = this._getSequence(t) || []; + this._metadataMap.set( + e.nodeName, + a.map((e) => e.textContent.trim()), + ); + } + _parse(e) { + let t = e.documentElement; + if ("rdf:rdf" !== t.nodeName) { + t = t.firstChild; + for (; t && "rdf:rdf" !== t.nodeName; ) t = t.nextSibling; + } + if (t && "rdf:rdf" === t.nodeName && t.hasChildNodes()) + for (const e of t.childNodes) + if ("rdf:description" === e.nodeName) + for (const t of e.childNodes) { + const e = t.nodeName; + switch (e) { + case "#text": + continue; + case "dc:creator": + case "dc:subject": + this._parseArray(t); + continue; + } + this._metadataMap.set(e, t.textContent.trim()); + } + } + get serializable() { + return { parsedData: this._metadataMap, rawData: this._data }; + } +} +const zn = 1, + $n = 2, + Gn = 3, + Vn = 4, + Kn = 5; +class StructTreeRoot { + constructor(e, t, a) { + this.xref = e; + this.dict = t; + this.ref = a instanceof Ref ? a : null; + this.roleMap = new Map(); + this.structParentIds = null; + } + init() { + this.readRoleMap(); + } + #Z(e, t, a) { + if (!(e instanceof Ref) || t < 0) return; + this.structParentIds ||= new RefSetCache(); + let r = this.structParentIds.get(e); + if (!r) { + r = []; + this.structParentIds.put(e, r); + } + r.push([t, a]); + } + addAnnotationIdToPage(e, t) { + this.#Z(e, t, Vn); + } + readRoleMap() { + const e = this.dict.get("RoleMap"); + if (e instanceof Dict) + for (const [t, a] of e) a instanceof Name && this.roleMap.set(t, a.name); + } + static async canCreateStructureTree({ + catalogRef: e, + pdfManager: t, + newAnnotationsByPage: a, + }) { + if (!(e instanceof Ref)) { + warn("Cannot save the struct tree: no catalog reference."); + return !1; + } + let r = 0, + i = !0; + for (const [e, n] of a) { + const { ref: a } = await t.getPage(e); + if (!(a instanceof Ref)) { + warn(`Cannot save the struct tree: page ${e} has no ref.`); + i = !0; + break; + } + for (const e of n) + if (e.accessibilityData?.type) { + e.parentTreeId = r++; + i = !1; + } + } + if (i) { + for (const e of a.values()) for (const t of e) delete t.parentTreeId; + return !1; + } + return !0; + } + static async createStructureTree({ + newAnnotationsByPage: e, + xref: t, + catalogRef: a, + pdfManager: r, + changes: i, + }) { + const n = await r.ensureCatalog("cloneDict"), + s = new RefSetCache(); + s.put(a, n); + const o = t.getNewTemporaryRef(); + n.set("StructTreeRoot", o); + const c = new Dict(t); + c.set("Type", Name.get("StructTreeRoot")); + const l = t.getNewTemporaryRef(); + c.set("ParentTree", l); + const h = []; + c.set("K", h); + s.put(o, c); + const u = new Dict(t), + d = []; + u.set("Nums", d); + const f = await this.#Q({ + newAnnotationsByPage: e, + structTreeRootRef: o, + structTreeRoot: null, + kids: h, + nums: d, + xref: t, + pdfManager: r, + changes: i, + cache: s, + }); + c.set("ParentTreeNextKey", f); + s.put(l, u); + for (const [e, t] of s.items()) i.put(e, { data: t }); + } + async canUpdateStructTree({ pdfManager: e, newAnnotationsByPage: t }) { + if (!this.ref) { + warn("Cannot update the struct tree: no root reference."); + return !1; + } + let a = this.dict.get("ParentTreeNextKey"); + if (!Number.isInteger(a) || a < 0) { + warn("Cannot update the struct tree: invalid next key."); + return !1; + } + const r = this.dict.get("ParentTree"); + if (!(r instanceof Dict)) { + warn("Cannot update the struct tree: ParentTree isn't a dict."); + return !1; + } + const i = r.get("Nums"); + if (!Array.isArray(i)) { + warn("Cannot update the struct tree: nums isn't an array."); + return !1; + } + const n = new NumberTree(r, this.xref); + for (const a of t.keys()) { + const { pageDict: t } = await e.getPage(a); + if (!t.has("StructParents")) continue; + const r = t.get("StructParents"); + if (!Number.isInteger(r) || !Array.isArray(n.get(r))) { + warn(`Cannot save the struct tree: page ${a} has a wrong id.`); + return !1; + } + } + let s = !0; + for (const [r, i] of t) { + const { pageDict: t } = await e.getPage(r); + StructTreeRoot.#ee({ + elements: i, + xref: this.xref, + pageDict: t, + numberTree: n, + }); + for (const e of i) + if (e.accessibilityData?.type) { + e.accessibilityData.structParent >= 0 || (e.parentTreeId = a++); + s = !1; + } + } + if (s) { + for (const e of t.values()) + for (const t of e) { + delete t.parentTreeId; + delete t.structTreeParent; + } + return !1; + } + return !0; + } + async updateStructureTree({ + newAnnotationsByPage: e, + pdfManager: t, + changes: a, + }) { + const { ref: r, xref: i } = this, + n = this.dict.clone(), + s = new RefSetCache(); + s.put(r, n); + let o, + c = n.getRaw("ParentTree"); + if (c instanceof Ref) o = i.fetch(c); + else { + o = c; + c = i.getNewTemporaryRef(); + n.set("ParentTree", c); + } + o = o.clone(); + s.put(c, o); + let l = o.getRaw("Nums"), + h = null; + if (l instanceof Ref) { + h = l; + l = i.fetch(h); + } + l = l.slice(); + h || o.set("Nums", l); + const u = await StructTreeRoot.#Q({ + newAnnotationsByPage: e, + structTreeRootRef: r, + structTreeRoot: this, + kids: null, + nums: l, + xref: i, + pdfManager: t, + changes: a, + cache: s, + }); + if (-1 !== u) { + n.set("ParentTreeNextKey", u); + h && s.put(h, l); + for (const [e, t] of s.items()) a.put(e, { data: t }); + } + } + static async #Q({ + newAnnotationsByPage: e, + structTreeRootRef: t, + structTreeRoot: a, + kids: r, + nums: i, + xref: n, + pdfManager: s, + changes: o, + cache: c, + }) { + const l = Name.get("OBJR"); + let h, + u = -1; + for (const [d, f] of e) { + const e = await s.getPage(d), + { ref: g } = e, + p = g instanceof Ref; + for (const { + accessibilityData: s, + ref: m, + parentTreeId: b, + structTreeParent: y, + } of f) { + if (!s?.type) continue; + const { structParent: f } = s; + if (a && Number.isInteger(f) && f >= 0) { + let t = (h ||= new Map()).get(d); + if (void 0 === t) { + t = new StructTreePage(a, e.pageDict).collectObjects(g); + h.set(d, t); + } + const r = t?.get(f); + if (r) { + const e = n.fetch(r).clone(); + StructTreeRoot.#te(e, s); + o.put(r, { data: e }); + continue; + } + } + u = Math.max(u, b); + const w = n.getNewTemporaryRef(), + x = new Dict(n); + StructTreeRoot.#te(x, s); + await this.#ae({ + structTreeParent: y, + tagDict: x, + newTagRef: w, + structTreeRootRef: t, + fallbackKids: r, + xref: n, + cache: c, + }); + const S = new Dict(n); + x.set("K", S); + S.set("Type", l); + p && S.set("Pg", g); + S.set("Obj", m); + c.put(w, x); + i.push(b, w); + } + } + return u + 1; + } + static #te( + e, + { type: t, title: a, lang: r, alt: i, expanded: n, actualText: s }, + ) { + e.set("S", Name.get(t)); + a && e.set("T", stringToAsciiOrUTF16BE(a)); + r && e.set("Lang", stringToAsciiOrUTF16BE(r)); + i && e.set("Alt", stringToAsciiOrUTF16BE(i)); + n && e.set("E", stringToAsciiOrUTF16BE(n)); + s && e.set("ActualText", stringToAsciiOrUTF16BE(s)); + } + static #ee({ elements: e, xref: t, pageDict: a, numberTree: r }) { + const i = new Map(); + for (const t of e) + if (t.structTreeParentId) { + const e = parseInt(t.structTreeParentId.split("_mc")[1], 10); + let a = i.get(e); + if (!a) { + a = []; + i.set(e, a); + } + a.push(t); + } + const n = a.get("StructParents"); + if (!Number.isInteger(n)) return; + const s = r.get(n), + updateElement = (e, a, r) => { + const n = i.get(e); + if (n) { + const e = a.getRaw("P"), + i = t.fetchIfRef(e); + if (e instanceof Ref && i instanceof Dict) { + const e = { ref: r, dict: a }; + for (const t of n) t.structTreeParent = e; + } + return !0; + } + return !1; + }; + for (const e of s) { + if (!(e instanceof Ref)) continue; + const a = t.fetch(e), + r = a.get("K"); + if (Number.isInteger(r)) updateElement(r, a, e); + else if (Array.isArray(r)) + for (let i of r) { + i = t.fetchIfRef(i); + if (Number.isInteger(i) && updateElement(i, a, e)) break; + if (!(i instanceof Dict)) continue; + if (!isName(i.get("Type"), "MCR")) break; + const r = i.get("MCID"); + if (Number.isInteger(r) && updateElement(r, a, e)) break; + } + } + } + static async #ae({ + structTreeParent: e, + tagDict: t, + newTagRef: a, + structTreeRootRef: r, + fallbackKids: i, + xref: n, + cache: s, + }) { + let o, + c = null; + if (e) { + ({ ref: c } = e); + o = e.dict.getRaw("P") || r; + } else o = r; + t.set("P", o); + const l = n.fetchIfRef(o); + if (!l) { + i.push(a); + return; + } + let h = s.get(o); + if (!h) { + h = l.clone(); + s.put(o, h); + } + const u = h.getRaw("K"); + let d = u instanceof Ref ? s.get(u) : null; + if (!d) { + d = n.fetchIfRef(u); + d = Array.isArray(d) ? d.slice() : [u]; + const e = n.getNewTemporaryRef(); + h.set("K", e); + s.put(e, d); + } + const f = d.indexOf(c); + d.splice(f >= 0 ? f + 1 : d.length, 0, a); + } +} +class StructElementNode { + constructor(e, t) { + this.tree = e; + this.xref = e.xref; + this.dict = t; + this.kids = []; + this.parseKids(); + } + get role() { + const e = this.dict.get("S"), + t = e instanceof Name ? e.name : "", + { root: a } = this.tree; + return a.roleMap.get(t) ?? t; + } + parseKids() { + let e = null; + const t = this.dict.getRaw("Pg"); + t instanceof Ref && (e = t.toString()); + const a = this.dict.get("K"); + if (Array.isArray(a)) + for (const t of a) { + const a = this.parseKid(e, this.xref.fetchIfRef(t)); + a && this.kids.push(a); + } + else { + const t = this.parseKid(e, a); + t && this.kids.push(t); + } + } + parseKid(e, t) { + if (Number.isInteger(t)) + return this.tree.pageDict.objId !== e + ? null + : new StructElement({ type: zn, mcid: t, pageObjId: e }); + if (!(t instanceof Dict)) return null; + const a = t.getRaw("Pg"); + a instanceof Ref && (e = a.toString()); + const r = t.get("Type") instanceof Name ? t.get("Type").name : null; + if ("MCR" === r) { + if (this.tree.pageDict.objId !== e) return null; + const a = t.getRaw("Stm"); + return new StructElement({ + type: $n, + refObjId: a instanceof Ref ? a.toString() : null, + pageObjId: e, + mcid: t.get("MCID"), + }); + } + if ("OBJR" === r) { + if (this.tree.pageDict.objId !== e) return null; + const a = t.getRaw("Obj"); + return new StructElement({ + type: Gn, + refObjId: a instanceof Ref ? a.toString() : null, + pageObjId: e, + }); + } + return new StructElement({ type: Kn, dict: t }); + } +} +class StructElement { + constructor({ + type: e, + dict: t = null, + mcid: a = null, + pageObjId: r = null, + refObjId: i = null, + }) { + this.type = e; + this.dict = t; + this.mcid = a; + this.pageObjId = r; + this.refObjId = i; + this.parentNode = null; + } +} +class StructTreePage { + constructor(e, t) { + this.root = e; + this.xref = e?.xref ?? null; + this.rootDict = e?.dict ?? null; + this.pageDict = t; + this.nodes = []; + } + collectObjects(e) { + if (!(this.root && this.rootDict && e instanceof Ref)) return null; + const t = this.rootDict.get("ParentTree"); + if (!t) return null; + const a = this.root.structParentIds?.get(e); + if (!a) return null; + const r = new Map(), + i = new NumberTree(t, this.xref); + for (const [e] of a) { + const t = i.getRaw(e); + t instanceof Ref && r.set(e, t); + } + return r; + } + parse(e) { + if (!(this.root && this.rootDict && e instanceof Ref)) return; + const t = this.rootDict.get("ParentTree"); + if (!t) return; + const a = this.pageDict.get("StructParents"), + r = this.root.structParentIds?.get(e); + if (!Number.isInteger(a) && !r) return; + const i = new Map(), + n = new NumberTree(t, this.xref); + if (Number.isInteger(a)) { + const e = n.get(a); + if (Array.isArray(e)) + for (const t of e) + t instanceof Ref && this.addNode(this.xref.fetch(t), i); + } + if (r) + for (const [e, t] of r) { + const a = n.get(e); + if (a) { + const e = this.addNode(this.xref.fetchIfRef(a), i); + 1 === e?.kids?.length && + e.kids[0].type === Gn && + (e.kids[0].type = t); + } + } + } + addNode(e, t, a = 0) { + if (a > 40) { + warn("StructTree MAX_DEPTH reached."); + return null; + } + if (!(e instanceof Dict)) return null; + if (t.has(e)) return t.get(e); + const r = new StructElementNode(this, e); + t.set(e, r); + const i = e.get("P"); + if (!(i instanceof Dict) || isName(i.get("Type"), "StructTreeRoot")) { + this.addTopLevelNode(e, r) || t.delete(e); + return r; + } + const n = this.addNode(i, t, a + 1); + if (!n) return r; + let s = !1; + for (const t of n.kids) + if (t.type === Kn && t.dict === e) { + t.parentNode = r; + s = !0; + } + s || t.delete(e); + return r; + } + addTopLevelNode(e, t) { + const a = this.rootDict.get("K"); + if (!a) return !1; + if (a instanceof Dict) { + if (a.objId !== e.objId) return !1; + this.nodes[0] = t; + return !0; + } + if (!Array.isArray(a)) return !0; + let r = !1; + for (let i = 0; i < a.length; i++) { + const n = a[i]; + if (n?.toString() === e.objId) { + this.nodes[i] = t; + r = !0; + } + } + return r; + } + get serializable() { + function nodeToSerializable(e, t, a = 0) { + if (a > 40) { + warn("StructTree too deep to be fully serialized."); + return; + } + const r = Object.create(null); + r.role = e.role; + r.children = []; + t.children.push(r); + let i = e.dict.get("Alt"); + "string" != typeof i && (i = e.dict.get("ActualText")); + "string" == typeof i && (r.alt = stringToPDFString(i)); + const n = e.dict.get("A"); + if (n instanceof Dict) { + const e = lookupNormalRect(n.getArray("BBox"), null); + if (e) r.bbox = e; + else { + const e = n.get("Width"), + t = n.get("Height"); + "number" == typeof e && + e > 0 && + "number" == typeof t && + t > 0 && + (r.bbox = [0, 0, e, t]); + } + } + const s = e.dict.get("Lang"); + "string" == typeof s && (r.lang = stringToPDFString(s)); + for (const t of e.kids) { + const e = t.type === Kn ? t.parentNode : null; + e + ? nodeToSerializable(e, r, a + 1) + : t.type === zn || t.type === $n + ? r.children.push({ + type: "content", + id: `p${t.pageObjId}_mc${t.mcid}`, + }) + : t.type === Gn + ? r.children.push({ type: "object", id: t.refObjId }) + : t.type === Vn && + r.children.push({ + type: "annotation", + id: `pdfjs_internal_id_${t.refObjId}`, + }); + } + } + const e = Object.create(null); + e.children = []; + e.role = "Root"; + for (const t of this.nodes) t && nodeToSerializable(t, e); + return e; + } +} +const Jn = function _isValidExplicitDest(e, t, a) { + if (!Array.isArray(a) || a.length < 2) return !1; + const [r, i, ...n] = a; + if (!e(r) && !Number.isInteger(r)) return !1; + if (!t(i)) return !1; + const s = n.length; + let o = !0; + switch (i.name) { + case "XYZ": + if (s < 2 || s > 3) return !1; + break; + case "Fit": + case "FitB": + return 0 === s; + case "FitH": + case "FitBH": + case "FitV": + case "FitBV": + if (s > 1) return !1; + break; + case "FitR": + if (4 !== s) return !1; + o = !1; + break; + default: + return !1; + } + for (const e of n) + if (!("number" == typeof e || (o && null === e))) return !1; + return !0; +}.bind(null, (e) => e instanceof Ref, isName); +function fetchDest(e) { + e instanceof Dict && (e = e.get("D")); + return Jn(e) ? e : null; +} +function fetchRemoteDest(e) { + let t = e.get("D"); + if (t) { + t instanceof Name && (t = t.name); + if ("string" == typeof t) return stringToPDFString(t, !0); + if (Jn(t)) return JSON.stringify(t); + } + return null; +} +class Catalog { + #re = null; + #ie = null; + builtInCMapCache = new Map(); + fontCache = new RefSetCache(); + globalColorSpaceCache = new GlobalColorSpaceCache(); + globalImageCache = new GlobalImageCache(); + nonBlendModesSet = new RefSet(); + pageDictCache = new RefSetCache(); + pageIndexCache = new RefSetCache(); + pageKidsCountCache = new RefSetCache(); + standardFontDataCache = new Map(); + systemFontCache = new Map(); + constructor(e, t) { + this.pdfManager = e; + this.xref = t; + this.#ie = t.getCatalogObj(); + if (!(this.#ie instanceof Dict)) + throw new FormatError("Catalog object is not a dictionary."); + this.toplevelPagesDict; + } + cloneDict() { + return this.#ie.clone(); + } + get version() { + const e = this.#ie.get("Version"); + if (e instanceof Name) { + if (Ca.test(e.name)) return shadow(this, "version", e.name); + warn(`Invalid PDF catalog version: ${e.name}`); + } + return shadow(this, "version", null); + } + get lang() { + const e = this.#ie.get("Lang"); + return shadow( + this, + "lang", + e && "string" == typeof e ? stringToPDFString(e) : null, + ); + } + get needsRendering() { + const e = this.#ie.get("NeedsRendering"); + return shadow(this, "needsRendering", "boolean" == typeof e && e); + } + get collection() { + let e = null; + try { + const t = this.#ie.get("Collection"); + t instanceof Dict && t.size > 0 && (e = t); + } catch (e) { + if (e instanceof MissingDataException) throw e; + info("Cannot fetch Collection entry; assuming no collection is present."); + } + return shadow(this, "collection", e); + } + get acroForm() { + let e = null; + try { + const t = this.#ie.get("AcroForm"); + t instanceof Dict && t.size > 0 && (e = t); + } catch (e) { + if (e instanceof MissingDataException) throw e; + info("Cannot fetch AcroForm entry; assuming no forms are present."); + } + return shadow(this, "acroForm", e); + } + get acroFormRef() { + const e = this.#ie.getRaw("AcroForm"); + return shadow(this, "acroFormRef", e instanceof Ref ? e : null); + } + get metadata() { + const e = this.#ie.getRaw("Metadata"); + if (!(e instanceof Ref)) return shadow(this, "metadata", null); + let t = null; + try { + const a = this.xref.fetch(e, !this.xref.encrypt?.encryptMetadata); + if (a instanceof BaseStream && a.dict instanceof Dict) { + const e = a.dict.get("Type"), + r = a.dict.get("Subtype"); + if (isName(e, "Metadata") && isName(r, "XML")) { + const e = stringToUTF8String(a.getString()); + e && (t = new MetadataParser(e).serializable); + } + } + } catch (e) { + if (e instanceof MissingDataException) throw e; + info(`Skipping invalid Metadata: "${e}".`); + } + return shadow(this, "metadata", t); + } + get markInfo() { + let e = null; + try { + e = this.#ne(); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Unable to read mark info."); + } + return shadow(this, "markInfo", e); + } + #ne() { + const e = this.#ie.get("MarkInfo"); + if (!(e instanceof Dict)) return null; + const t = { Marked: !1, UserProperties: !1, Suspects: !1 }; + for (const a in t) { + const r = e.get(a); + "boolean" == typeof r && (t[a] = r); + } + return t; + } + get structTreeRoot() { + let e = null; + try { + e = this.#se(); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Unable read to structTreeRoot info."); + } + return shadow(this, "structTreeRoot", e); + } + #se() { + const e = this.#ie.getRaw("StructTreeRoot"), + t = this.xref.fetchIfRef(e); + if (!(t instanceof Dict)) return null; + const a = new StructTreeRoot(this.xref, t, e); + a.init(); + return a; + } + get toplevelPagesDict() { + const e = this.#ie.get("Pages"); + if (!(e instanceof Dict)) + throw new FormatError("Invalid top-level pages dictionary."); + return shadow(this, "toplevelPagesDict", e); + } + get documentOutline() { + let e = null; + try { + e = this.#oe(); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Unable to read document outline."); + } + return shadow(this, "documentOutline", e); + } + #oe() { + let e = this.#ie.get("Outlines"); + if (!(e instanceof Dict)) return null; + e = e.getRaw("First"); + if (!(e instanceof Ref)) return null; + const t = { items: [] }, + a = [{ obj: e, parent: t }], + r = new RefSet(); + r.put(e); + const i = this.xref, + n = new Uint8ClampedArray(3); + for (; a.length > 0; ) { + const t = a.shift(), + s = i.fetchIfRef(t.obj); + if (null === s) continue; + s.has("Title") || warn("Invalid outline item encountered."); + const o = { url: null, dest: null, action: null }; + Catalog.parseDestDictionary({ + destDict: s, + resultObj: o, + docBaseUrl: this.baseUrl, + docAttachments: this.attachments, + }); + const c = s.get("Title"), + l = s.get("F") || 0, + h = s.getArray("C"), + u = s.get("Count"); + let d = n; + !isNumberArray(h, 3) || + (0 === h[0] && 0 === h[1] && 0 === h[2]) || + (d = ColorSpaceUtils.rgb.getRgb(h, 0)); + const f = { + action: o.action, + attachment: o.attachment, + dest: o.dest, + url: o.url, + unsafeUrl: o.unsafeUrl, + newWindow: o.newWindow, + setOCGState: o.setOCGState, + title: "string" == typeof c ? stringToPDFString(c) : "", + color: d, + count: Number.isInteger(u) ? u : void 0, + bold: !!(2 & l), + italic: !!(1 & l), + items: [], + }; + t.parent.items.push(f); + e = s.getRaw("First"); + if (e instanceof Ref && !r.has(e)) { + a.push({ obj: e, parent: f }); + r.put(e); + } + e = s.getRaw("Next"); + if (e instanceof Ref && !r.has(e)) { + a.push({ obj: e, parent: t.parent }); + r.put(e); + } + } + return t.items.length > 0 ? t.items : null; + } + get permissions() { + let e = null; + try { + e = this.#ce(); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Unable to read permissions."); + } + return shadow(this, "permissions", e); + } + #ce() { + const e = this.xref.trailer.get("Encrypt"); + if (!(e instanceof Dict)) return null; + let t = e.get("P"); + if ("number" != typeof t) return null; + t += 2 ** 32; + const a = []; + for (const e in w) { + const r = w[e]; + t & r && a.push(r); + } + return a; + } + get optionalContentConfig() { + let e = null; + try { + const t = this.#ie.get("OCProperties"); + if (!t) return shadow(this, "optionalContentConfig", null); + const a = t.get("D"); + if (!a) return shadow(this, "optionalContentConfig", null); + const r = t.get("OCGs"); + if (!Array.isArray(r)) return shadow(this, "optionalContentConfig", null); + const i = new RefSetCache(); + for (const e of r) e instanceof Ref && !i.has(e) && i.put(e, this.#le(e)); + e = this.#he(a, i); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`Unable to read optional content config: ${e}`); + } + return shadow(this, "optionalContentConfig", e); + } + #le(e) { + const t = this.xref.fetch(e), + a = { + id: e.toString(), + name: null, + intent: null, + usage: { print: null, view: null }, + rbGroups: [], + }, + r = t.get("Name"); + "string" == typeof r && (a.name = stringToPDFString(r)); + let i = t.getArray("Intent"); + Array.isArray(i) || (i = [i]); + i.every((e) => e instanceof Name) && (a.intent = i.map((e) => e.name)); + const n = t.get("Usage"); + if (!(n instanceof Dict)) return a; + const s = a.usage, + o = n.get("Print"); + if (o instanceof Dict) { + const e = o.get("PrintState"); + if (e instanceof Name) + switch (e.name) { + case "ON": + case "OFF": + s.print = { printState: e.name }; + } + } + const c = n.get("View"); + if (c instanceof Dict) { + const e = c.get("ViewState"); + if (e instanceof Name) + switch (e.name) { + case "ON": + case "OFF": + s.view = { viewState: e.name }; + } + } + return a; + } + #he(e, t) { + function parseOnOff(e) { + const a = []; + if (Array.isArray(e)) + for (const r of e) r instanceof Ref && t.has(r) && a.push(r.toString()); + return a; + } + function parseOrder(e, a = 0) { + if (!Array.isArray(e)) return null; + const i = []; + for (const n of e) { + if (n instanceof Ref && t.has(n)) { + r.put(n); + i.push(n.toString()); + continue; + } + const e = parseNestedOrder(n, a); + e && i.push(e); + } + if (a > 0) return i; + const n = []; + for (const [e] of t.items()) r.has(e) || n.push(e.toString()); + n.length && i.push({ name: null, order: n }); + return i; + } + function parseNestedOrder(e, t) { + if (++t > i) { + warn("parseNestedOrder - reached MAX_NESTED_LEVELS."); + return null; + } + const r = a.fetchIfRef(e); + if (!Array.isArray(r)) return null; + const n = a.fetchIfRef(r[0]); + if ("string" != typeof n) return null; + const s = parseOrder(r.slice(1), t); + return s?.length ? { name: stringToPDFString(n), order: s } : null; + } + const a = this.xref, + r = new RefSet(), + i = 10; + !(function parseRBGroups(e) { + if (Array.isArray(e)) + for (const r of e) { + const e = a.fetchIfRef(r); + if (!Array.isArray(e) || !e.length) continue; + const i = new Set(); + for (const a of e) + if (a instanceof Ref && t.has(a) && !i.has(a.toString())) { + i.add(a.toString()); + t.get(a).rbGroups.push(i); + } + } + })(e.get("RBGroups")); + return { + name: + "string" == typeof e.get("Name") + ? stringToPDFString(e.get("Name")) + : null, + creator: + "string" == typeof e.get("Creator") + ? stringToPDFString(e.get("Creator")) + : null, + baseState: + e.get("BaseState") instanceof Name ? e.get("BaseState").name : null, + on: parseOnOff(e.get("ON")), + off: parseOnOff(e.get("OFF")), + order: parseOrder(e.get("Order")), + groups: [...t], + }; + } + setActualNumPages(e = null) { + this.#re = e; + } + get hasActualNumPages() { + return null !== this.#re; + } + get _pagesCount() { + const e = this.toplevelPagesDict.get("Count"); + if (!Number.isInteger(e)) + throw new FormatError( + "Page count in top-level pages dictionary is not an integer.", + ); + return shadow(this, "_pagesCount", e); + } + get numPages() { + return this.#re ?? this._pagesCount; + } + get destinations() { + const e = this.#ue(), + t = Object.create(null); + for (const a of e) + if (a instanceof NameTree) + for (const [e, r] of a.getAll()) { + const a = fetchDest(r); + a && (t[stringToPDFString(e, !0)] = a); + } + else if (a instanceof Dict) + for (const [e, r] of a) { + const a = fetchDest(r); + a && (t[stringToPDFString(e, !0)] ||= a); + } + return shadow(this, "destinations", t); + } + getDestination(e) { + if (this.hasOwnProperty("destinations")) + return this.destinations[e] ?? null; + const t = this.#ue(); + for (const a of t) + if (a instanceof NameTree || a instanceof Dict) { + const t = fetchDest(a.get(e)); + if (t) return t; + } + if (t.length) { + const t = this.destinations[e]; + if (t) return t; + } + return null; + } + #ue() { + const e = this.#ie.get("Names"), + t = []; + e?.has("Dests") && t.push(new NameTree(e.getRaw("Dests"), this.xref)); + this.#ie.has("Dests") && t.push(this.#ie.get("Dests")); + return t; + } + get pageLabels() { + let e = null; + try { + e = this.#de(); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn("Unable to read page labels."); + } + return shadow(this, "pageLabels", e); + } + #de() { + const e = this.#ie.getRaw("PageLabels"); + if (!e) return null; + const t = new Array(this.numPages); + let a = null, + r = ""; + const i = new NumberTree(e, this.xref).getAll(); + let n = "", + s = 1; + for (let e = 0, o = this.numPages; e < o; e++) { + const o = i.get(e); + if (void 0 !== o) { + if (!(o instanceof Dict)) + throw new FormatError("PageLabel is not a dictionary."); + if (o.has("Type") && !isName(o.get("Type"), "PageLabel")) + throw new FormatError("Invalid type in PageLabel dictionary."); + if (o.has("S")) { + const e = o.get("S"); + if (!(e instanceof Name)) + throw new FormatError("Invalid style in PageLabel dictionary."); + a = e.name; + } else a = null; + if (o.has("P")) { + const e = o.get("P"); + if ("string" != typeof e) + throw new FormatError("Invalid prefix in PageLabel dictionary."); + r = stringToPDFString(e); + } else r = ""; + if (o.has("St")) { + const e = o.get("St"); + if (!(Number.isInteger(e) && e >= 1)) + throw new FormatError("Invalid start in PageLabel dictionary."); + s = e; + } else s = 1; + } + switch (a) { + case "D": + n = s; + break; + case "R": + case "r": + n = toRomanNumerals(s, "r" === a); + break; + case "A": + case "a": + const e = 26, + t = "a" === a ? 97 : 65, + r = s - 1; + n = String.fromCharCode(t + (r % e)).repeat(Math.floor(r / e) + 1); + break; + default: + if (a) + throw new FormatError( + `Invalid style "${a}" in PageLabel dictionary.`, + ); + n = ""; + } + t[e] = r + n; + s++; + } + return t; + } + get pageLayout() { + const e = this.#ie.get("PageLayout"); + let t = ""; + if (e instanceof Name) + switch (e.name) { + case "SinglePage": + case "OneColumn": + case "TwoColumnLeft": + case "TwoColumnRight": + case "TwoPageLeft": + case "TwoPageRight": + t = e.name; + } + return shadow(this, "pageLayout", t); + } + get pageMode() { + const e = this.#ie.get("PageMode"); + let t = "UseNone"; + if (e instanceof Name) + switch (e.name) { + case "UseNone": + case "UseOutlines": + case "UseThumbs": + case "FullScreen": + case "UseOC": + case "UseAttachments": + t = e.name; + } + return shadow(this, "pageMode", t); + } + get viewerPreferences() { + const e = this.#ie.get("ViewerPreferences"); + if (!(e instanceof Dict)) return shadow(this, "viewerPreferences", null); + let t = null; + for (const [a, r] of e) { + let e; + switch (a) { + case "HideToolbar": + case "HideMenubar": + case "HideWindowUI": + case "FitWindow": + case "CenterWindow": + case "DisplayDocTitle": + case "PickTrayByPDFSize": + "boolean" == typeof r && (e = r); + break; + case "NonFullScreenPageMode": + if (r instanceof Name) + switch (r.name) { + case "UseNone": + case "UseOutlines": + case "UseThumbs": + case "UseOC": + e = r.name; + break; + default: + e = "UseNone"; + } + break; + case "Direction": + if (r instanceof Name) + switch (r.name) { + case "L2R": + case "R2L": + e = r.name; + break; + default: + e = "L2R"; + } + break; + case "ViewArea": + case "ViewClip": + case "PrintArea": + case "PrintClip": + if (r instanceof Name) + switch (r.name) { + case "MediaBox": + case "CropBox": + case "BleedBox": + case "TrimBox": + case "ArtBox": + e = r.name; + break; + default: + e = "CropBox"; + } + break; + case "PrintScaling": + if (r instanceof Name) + switch (r.name) { + case "None": + case "AppDefault": + e = r.name; + break; + default: + e = "AppDefault"; + } + break; + case "Duplex": + if (r instanceof Name) + switch (r.name) { + case "Simplex": + case "DuplexFlipShortEdge": + case "DuplexFlipLongEdge": + e = r.name; + break; + default: + e = "None"; + } + break; + case "PrintPageRange": + if (Array.isArray(r) && r.length % 2 == 0) { + r.every( + (e, t, a) => + Number.isInteger(e) && + e > 0 && + (0 === t || e >= a[t - 1]) && + e <= this.numPages, + ) && (e = r); + } + break; + case "NumCopies": + Number.isInteger(r) && r > 0 && (e = r); + break; + default: + warn(`Ignoring non-standard key in ViewerPreferences: ${a}.`); + continue; + } + if (void 0 !== e) { + t ??= Object.create(null); + t[a] = e; + } else warn(`Bad value, for key "${a}", in ViewerPreferences: ${r}.`); + } + return shadow(this, "viewerPreferences", t); + } + get openAction() { + const e = this.#ie.get("OpenAction"), + t = Object.create(null); + if (e instanceof Dict) { + const a = new Dict(this.xref); + a.set("A", e); + const r = { url: null, dest: null, action: null }; + Catalog.parseDestDictionary({ destDict: a, resultObj: r }); + Array.isArray(r.dest) + ? (t.dest = r.dest) + : r.action && (t.action = r.action); + } else Jn(e) && (t.dest = e); + return shadow(this, "openAction", objectSize(t) > 0 ? t : null); + } + get attachments() { + const e = this.#ie.get("Names"); + let t = null; + if (e instanceof Dict && e.has("EmbeddedFiles")) { + const a = new NameTree(e.getRaw("EmbeddedFiles"), this.xref); + for (const [e, r] of a.getAll()) { + const a = new FileSpec(r, this.xref); + t ??= Object.create(null); + t[stringToPDFString(e, !0)] = a.serializable; + } + } + return shadow(this, "attachments", t); + } + get xfaImages() { + const e = this.#ie.get("Names"); + let t = null; + if (e instanceof Dict && e.has("XFAImages")) { + const a = new NameTree(e.getRaw("XFAImages"), this.xref); + for (const [e, r] of a.getAll()) + if (r instanceof BaseStream) { + t ??= new Map(); + t.set(stringToPDFString(e, !0), r.getBytes()); + } + } + return shadow(this, "xfaImages", t); + } + #fe() { + const e = this.#ie.get("Names"); + let t = null; + function appendIfJavaScriptDict(e, a) { + if (!(a instanceof Dict)) return; + if (!isName(a.get("S"), "JavaScript")) return; + let r = a.get("JS"); + if (r instanceof BaseStream) r = r.getString(); + else if ("string" != typeof r) return; + r = stringToPDFString(r, !0).replaceAll("\0", ""); + r && (t ||= new Map()).set(e, r); + } + if (e instanceof Dict && e.has("JavaScript")) { + const t = new NameTree(e.getRaw("JavaScript"), this.xref); + for (const [e, a] of t.getAll()) + appendIfJavaScriptDict(stringToPDFString(e, !0), a); + } + const a = this.#ie.get("OpenAction"); + a && appendIfJavaScriptDict("OpenAction", a); + return t; + } + get jsActions() { + const e = this.#fe(); + let t = collectActions(this.xref, this.#ie, we); + if (e) { + t ||= Object.create(null); + for (const [a, r] of e) a in t ? t[a].push(r) : (t[a] = [r]); + } + return shadow(this, "jsActions", t); + } + async cleanup(e = !1) { + clearGlobalCaches(); + this.globalColorSpaceCache.clear(); + this.globalImageCache.clear(e); + this.pageKidsCountCache.clear(); + this.pageIndexCache.clear(); + this.pageDictCache.clear(); + this.nonBlendModesSet.clear(); + for (const { dict: e } of await Promise.all(this.fontCache)) + delete e.cacheKey; + this.fontCache.clear(); + this.builtInCMapCache.clear(); + this.standardFontDataCache.clear(); + this.systemFontCache.clear(); + } + async getPageDict(e) { + const t = [this.toplevelPagesDict], + a = new RefSet(), + r = this.#ie.getRaw("Pages"); + r instanceof Ref && a.put(r); + const i = this.xref, + n = this.pageKidsCountCache, + s = this.pageIndexCache, + o = this.pageDictCache; + let c = 0; + for (; t.length; ) { + const r = t.pop(); + if (r instanceof Ref) { + const l = n.get(r); + if (l >= 0 && c + l <= e) { + c += l; + continue; + } + if (a.has(r)) + throw new FormatError("Pages tree contains circular reference."); + a.put(r); + const h = await (o.get(r) || i.fetchAsync(r)); + if (h instanceof Dict) { + let t = h.getRaw("Type"); + t instanceof Ref && (t = await i.fetchAsync(t)); + if (isName(t, "Page") || !h.has("Kids")) { + n.has(r) || n.put(r, 1); + s.has(r) || s.put(r, c); + if (c === e) return [h, r]; + c++; + continue; + } + } + t.push(h); + continue; + } + if (!(r instanceof Dict)) + throw new FormatError( + "Page dictionary kid reference points to wrong type of object.", + ); + const { objId: l } = r; + let h = r.getRaw("Count"); + h instanceof Ref && (h = await i.fetchAsync(h)); + if (Number.isInteger(h) && h >= 0) { + l && !n.has(l) && n.put(l, h); + if (c + h <= e) { + c += h; + continue; + } + } + let u = r.getRaw("Kids"); + u instanceof Ref && (u = await i.fetchAsync(u)); + if (!Array.isArray(u)) { + let t = r.getRaw("Type"); + t instanceof Ref && (t = await i.fetchAsync(t)); + if (isName(t, "Page") || !r.has("Kids")) { + if (c === e) return [r, null]; + c++; + continue; + } + throw new FormatError("Page dictionary kids object is not an array."); + } + for (let e = u.length - 1; e >= 0; e--) { + const a = u[e]; + t.push(a); + r === this.toplevelPagesDict && + a instanceof Ref && + !o.has(a) && + o.put(a, i.fetchAsync(a)); + } + } + throw new Error(`Page index ${e} not found.`); + } + async getAllPageDicts(e = !1) { + const { ignoreErrors: t } = this.pdfManager.evaluatorOptions, + a = [{ currentNode: this.toplevelPagesDict, posInKids: 0 }], + r = new RefSet(), + i = this.#ie.getRaw("Pages"); + i instanceof Ref && r.put(i); + const n = new Map(), + s = this.xref, + o = this.pageIndexCache; + let c = 0; + function addPageDict(e, t) { + t && !o.has(t) && o.put(t, c); + n.set(c++, [e, t]); + } + function addPageError(a) { + if (a instanceof XRefEntryException && !e) throw a; + if (e && t && 0 === c) { + warn(`getAllPageDicts - Skipping invalid first page: "${a}".`); + a = Dict.empty; + } + n.set(c++, [a, null]); + } + for (; a.length > 0; ) { + const e = a.at(-1), + { currentNode: t, posInKids: i } = e; + let n = t.getRaw("Kids"); + if (n instanceof Ref) + try { + n = await s.fetchAsync(n); + } catch (e) { + addPageError(e); + break; + } + if (!Array.isArray(n)) { + addPageError( + new FormatError("Page dictionary kids object is not an array."), + ); + break; + } + if (i >= n.length) { + a.pop(); + continue; + } + const o = n[i]; + let c; + if (o instanceof Ref) { + if (r.has(o)) { + addPageError( + new FormatError("Pages tree contains circular reference."), + ); + break; + } + r.put(o); + try { + c = await s.fetchAsync(o); + } catch (e) { + addPageError(e); + break; + } + } else c = o; + if (!(c instanceof Dict)) { + addPageError( + new FormatError( + "Page dictionary kid reference points to wrong type of object.", + ), + ); + break; + } + let l = c.getRaw("Type"); + if (l instanceof Ref) + try { + l = await s.fetchAsync(l); + } catch (e) { + addPageError(e); + break; + } + isName(l, "Page") || !c.has("Kids") + ? addPageDict(c, o instanceof Ref ? o : null) + : a.push({ currentNode: c, posInKids: 0 }); + e.posInKids++; + } + return n; + } + getPageIndex(e) { + const t = this.pageIndexCache.get(e); + if (void 0 !== t) return Promise.resolve(t); + const a = this.xref; + let r = 0; + const next = (t) => + (function pagesBeforeRef(t) { + let r, + i = 0; + return a + .fetchAsync(t) + .then(function (a) { + if ( + isRefsEqual(t, e) && + !isDict(a, "Page") && + !(a instanceof Dict && !a.has("Type") && a.has("Contents")) + ) + throw new FormatError( + "The reference does not point to a /Page dictionary.", + ); + if (!a) return null; + if (!(a instanceof Dict)) + throw new FormatError("Node must be a dictionary."); + r = a.getRaw("Parent"); + return a.getAsync("Parent"); + }) + .then(function (e) { + if (!e) return null; + if (!(e instanceof Dict)) + throw new FormatError("Parent must be a dictionary."); + return e.getAsync("Kids"); + }) + .then(function (e) { + if (!e) return null; + const n = []; + let s = !1; + for (const r of e) { + if (!(r instanceof Ref)) + throw new FormatError("Kid must be a reference."); + if (isRefsEqual(r, t)) { + s = !0; + break; + } + n.push( + a.fetchAsync(r).then(function (e) { + if (!(e instanceof Dict)) + throw new FormatError("Kid node must be a dictionary."); + e.has("Count") ? (i += e.get("Count")) : i++; + }), + ); + } + if (!s) + throw new FormatError( + "Kid reference not found in parent's kids.", + ); + return Promise.all(n).then(() => [i, r]); + }); + })(t).then((t) => { + if (!t) { + this.pageIndexCache.put(e, r); + return r; + } + const [a, i] = t; + r += a; + return next(i); + }); + return next(e); + } + get baseUrl() { + const e = this.#ie.get("URI"); + if (e instanceof Dict) { + const t = e.get("Base"); + if ("string" == typeof t) { + const e = createValidAbsoluteUrl(t, null, { tryConvertEncoding: !0 }); + if (e) return shadow(this, "baseUrl", e.href); + } + } + return shadow(this, "baseUrl", this.pdfManager.docBaseUrl); + } + static parseDestDictionary({ + destDict: e, + resultObj: t, + docBaseUrl: a = null, + docAttachments: r = null, + }) { + if (!(e instanceof Dict)) { + warn("parseDestDictionary: `destDict` must be a dictionary."); + return; + } + let i, + n, + s = e.get("A"); + if (!(s instanceof Dict)) + if (e.has("Dest")) s = e.get("Dest"); + else { + s = e.get("AA"); + s instanceof Dict && + (s.has("D") ? (s = s.get("D")) : s.has("U") && (s = s.get("U"))); + } + if (s instanceof Dict) { + const e = s.get("S"); + if (!(e instanceof Name)) { + warn("parseDestDictionary: Invalid type in Action dictionary."); + return; + } + const a = e.name; + switch (a) { + case "ResetForm": + const e = s.get("Flags"), + o = !(1 & ("number" == typeof e ? e : 0)), + c = [], + l = []; + for (const e of s.get("Fields") || []) + e instanceof Ref + ? l.push(e.toString()) + : "string" == typeof e && c.push(stringToPDFString(e)); + t.resetForm = { fields: c, refs: l, include: o }; + break; + case "URI": + i = s.get("URI"); + i instanceof Name && (i = "/" + i.name); + break; + case "GoTo": + n = s.get("D"); + break; + case "Launch": + case "GoToR": + const h = s.get("F"); + if (h instanceof Dict) { + const e = new FileSpec(h, null, !0), + { rawFilename: t } = e.serializable; + i = t; + } else "string" == typeof h && (i = h); + const u = fetchRemoteDest(s); + u && "string" == typeof i && (i = i.split("#", 1)[0] + "#" + u); + const d = s.get("NewWindow"); + "boolean" == typeof d && (t.newWindow = d); + break; + case "GoToE": + const f = s.get("T"); + let g; + if (r && f instanceof Dict) { + const e = f.get("R"), + t = f.get("N"); + isName(e, "C") && + "string" == typeof t && + (g = r[stringToPDFString(t, !0)]); + } + if (g) { + t.attachment = g; + const e = fetchRemoteDest(s); + e && (t.attachmentDest = e); + } else warn('parseDestDictionary - unimplemented "GoToE" action.'); + break; + case "Named": + const p = s.get("N"); + p instanceof Name && (t.action = p.name); + break; + case "SetOCGState": + const m = s.get("State"), + b = s.get("PreserveRB"); + if (!Array.isArray(m) || 0 === m.length) break; + const y = []; + for (const e of m) + if (e instanceof Name) + switch (e.name) { + case "ON": + case "OFF": + case "Toggle": + y.push(e.name); + } + else e instanceof Ref && y.push(e.toString()); + if (y.length !== m.length) break; + t.setOCGState = { state: y, preserveRB: "boolean" != typeof b || b }; + break; + case "JavaScript": + const w = s.get("JS"); + let x; + w instanceof BaseStream + ? (x = w.getString()) + : "string" == typeof w && (x = w); + const S = x && recoverJsURL(stringToPDFString(x, !0)); + if (S) { + i = S.url; + t.newWindow = S.newWindow; + break; + } + default: + if ("JavaScript" === a || "SubmitForm" === a) break; + warn(`parseDestDictionary - unsupported action: "${a}".`); + } + } else e.has("Dest") && (n = e.get("Dest")); + if ("string" == typeof i) { + const e = createValidAbsoluteUrl(i, a, { + addDefaultProtocol: !0, + tryConvertEncoding: !0, + }); + e && (t.url = e.href); + t.unsafeUrl = i; + } + if (n) { + n instanceof Name && (n = n.name); + "string" == typeof n + ? (t.dest = stringToPDFString(n, !0)) + : Jn(n) && (t.dest = n); + } + } +} +function addChildren(e, t) { + if (e instanceof Dict) e = e.getRawValues(); + else if (e instanceof BaseStream) e = e.dict.getRawValues(); + else if (!Array.isArray(e)) return; + for (const r of e) + ((a = r) instanceof Ref || + a instanceof Dict || + a instanceof BaseStream || + Array.isArray(a)) && + t.push(r); + var a; +} +class ObjectLoader { + refSet = new RefSet(); + constructor(e, t, a) { + this.dict = e; + this.keys = t; + this.xref = a; + } + async load() { + const { keys: e, dict: t } = this, + a = []; + for (const r of e) { + const e = t.getRaw(r); + void 0 !== e && a.push(e); + } + await this.#ge(a); + this.refSet = null; + } + async #ge(e) { + const t = [], + a = []; + for (; e.length; ) { + let r = e.pop(); + if (r instanceof Ref) { + if (this.refSet.has(r)) continue; + try { + this.refSet.put(r); + r = this.xref.fetch(r); + } catch (e) { + if (!(e instanceof MissingDataException)) { + warn(`ObjectLoader.#walk - requesting all data: "${e}".`); + await this.xref.stream.manager.requestAllChunks(); + return; + } + t.push(r); + a.push({ begin: e.begin, end: e.end }); + } + } + if (r instanceof BaseStream) { + const e = r.getBaseStreams(); + if (e) { + let i = !1; + for (const t of e) + if (!t.isDataLoaded) { + i = !0; + a.push({ begin: t.start, end: t.end }); + } + i && t.push(r); + } + } + addChildren(r, e); + } + if (a.length) { + await this.xref.stream.manager.requestRanges(a); + for (const e of t) e instanceof Ref && this.refSet.remove(e); + await this.#ge(t); + } + } + static async load(e, t, a) { + if (a.stream.isDataLoaded) return; + const r = new ObjectLoader(e, t, a); + await r.load(); + } +} +const Yn = Symbol(), + Zn = Symbol(), + Qn = Symbol(), + es = Symbol(), + ts = Symbol(), + as = Symbol(), + rs = Symbol(), + is = Symbol(), + ns = Symbol(), + ss = Symbol("content"), + os = Symbol("data"), + cs = Symbol(), + ls = Symbol("extra"), + hs = Symbol(), + us = Symbol(), + ds = Symbol(), + fs = Symbol(), + gs = Symbol(), + ps = Symbol(), + ms = Symbol(), + bs = Symbol(), + ys = Symbol(), + ws = Symbol(), + xs = Symbol(), + Ss = Symbol(), + ks = Symbol(), + As = Symbol(), + Cs = Symbol(), + vs = Symbol(), + Fs = Symbol(), + Is = Symbol(), + Ts = Symbol(), + Os = Symbol(), + Ms = Symbol(), + Ds = Symbol(), + Bs = Symbol(), + Rs = Symbol(), + Ns = Symbol(), + Es = Symbol(), + Ls = Symbol(), + js = Symbol(), + _s = Symbol(), + Us = Symbol(), + Xs = Symbol(), + qs = Symbol(), + Hs = Symbol("namespaceId"), + Ws = Symbol("nodeName"), + zs = Symbol(), + $s = Symbol(), + Gs = Symbol(), + Vs = Symbol(), + Ks = Symbol(), + Js = Symbol(), + Ys = Symbol(), + Zs = Symbol(), + Qs = Symbol("root"), + eo = Symbol(), + to = Symbol(), + ao = Symbol(), + ro = Symbol(), + io = Symbol(), + no = Symbol(), + so = Symbol(), + oo = Symbol(), + co = Symbol(), + lo = Symbol(), + ho = Symbol(), + uo = Symbol("uid"), + fo = Symbol(), + go = { + config: { + id: 0, + check: (e) => e.startsWith("http://www.xfa.org/schema/xci/"), + }, + connectionSet: { + id: 1, + check: (e) => + e.startsWith("http://www.xfa.org/schema/xfa-connection-set/"), + }, + datasets: { + id: 2, + check: (e) => e.startsWith("http://www.xfa.org/schema/xfa-data/"), + }, + form: { + id: 3, + check: (e) => e.startsWith("http://www.xfa.org/schema/xfa-form/"), + }, + localeSet: { + id: 4, + check: (e) => e.startsWith("http://www.xfa.org/schema/xfa-locale-set/"), + }, + pdf: { id: 5, check: (e) => "http://ns.adobe.com/xdp/pdf/" === e }, + signature: { + id: 6, + check: (e) => "http://www.w3.org/2000/09/xmldsig#" === e, + }, + sourceSet: { + id: 7, + check: (e) => e.startsWith("http://www.xfa.org/schema/xfa-source-set/"), + }, + stylesheet: { + id: 8, + check: (e) => "http://www.w3.org/1999/XSL/Transform" === e, + }, + template: { + id: 9, + check: (e) => e.startsWith("http://www.xfa.org/schema/xfa-template/"), + }, + xdc: { + id: 10, + check: (e) => e.startsWith("http://www.xfa.org/schema/xdc/"), + }, + xdp: { id: 11, check: (e) => "http://ns.adobe.com/xdp/" === e }, + xfdf: { id: 12, check: (e) => "http://ns.adobe.com/xfdf/" === e }, + xhtml: { id: 13, check: (e) => "http://www.w3.org/1999/xhtml" === e }, + xmpmeta: { id: 14, check: (e) => "http://ns.adobe.com/xmpmeta/" === e }, + }, + po = { + pt: (e) => e, + cm: (e) => (e / 2.54) * 72, + mm: (e) => (e / 25.4) * 72, + in: (e) => 72 * e, + px: (e) => e, + }, + mo = /([+-]?\d+\.?\d*)(.*)/; +function stripQuotes(e) { + return e.startsWith("'") || e.startsWith('"') ? e.slice(1, -1) : e; +} +function getInteger({ data: e, defaultValue: t, validate: a }) { + if (!e) return t; + e = e.trim(); + const r = parseInt(e, 10); + return !isNaN(r) && a(r) ? r : t; +} +function getFloat({ data: e, defaultValue: t, validate: a }) { + if (!e) return t; + e = e.trim(); + const r = parseFloat(e); + return !isNaN(r) && a(r) ? r : t; +} +function getKeyword({ data: e, defaultValue: t, validate: a }) { + return e && a((e = e.trim())) ? e : t; +} +function getStringOption(e, t) { + return getKeyword({ + data: e, + defaultValue: t[0], + validate: (e) => t.includes(e), + }); +} +function getMeasurement(e, t = "0") { + t ||= "0"; + if (!e) return getMeasurement(t); + const a = e.trim().match(mo); + if (!a) return getMeasurement(t); + const [, r, i] = a, + n = parseFloat(r); + if (isNaN(n)) return getMeasurement(t); + if (0 === n) return 0; + const s = po[i]; + return s ? s(n) : n; +} +function getRatio(e) { + if (!e) return { num: 1, den: 1 }; + const t = e + .split(":", 2) + .map((e) => parseFloat(e.trim())) + .filter((e) => !isNaN(e)); + 1 === t.length && t.push(1); + if (0 === t.length) return { num: 1, den: 1 }; + const [a, r] = t; + return { num: a, den: r }; +} +function getRelevant(e) { + return e + ? e + .trim() + .split(/\s+/) + .map((e) => ({ excluded: "-" === e[0], viewname: e.substring(1) })) + : []; +} +class HTMLResult { + static get FAILURE() { + return shadow(this, "FAILURE", new HTMLResult(!1, null, null, null)); + } + static get EMPTY() { + return shadow(this, "EMPTY", new HTMLResult(!0, null, null, null)); + } + constructor(e, t, a, r) { + this.success = e; + this.html = t; + this.bbox = a; + this.breakNode = r; + } + isBreak() { + return !!this.breakNode; + } + static breakNode(e) { + return new HTMLResult(!1, null, null, e); + } + static success(e, t = null) { + return new HTMLResult(!0, e, t, null); + } +} +class FontFinder { + constructor(e) { + this.fonts = new Map(); + this.cache = new Map(); + this.warned = new Set(); + this.defaultFont = null; + this.add(e); + } + add(e, t = null) { + for (const t of e) this.addPdfFont(t); + for (const e of this.fonts.values()) + e.regular || (e.regular = e.italic || e.bold || e.bolditalic); + if (!t || 0 === t.size) return; + const a = this.fonts.get("PdfJS-Fallback-PdfJS-XFA"); + for (const e of t) this.fonts.set(e, a); + } + addPdfFont(e) { + const t = e.cssFontInfo, + a = t.fontFamily; + let r = this.fonts.get(a); + if (!r) { + r = Object.create(null); + this.fonts.set(a, r); + this.defaultFont || (this.defaultFont = r); + } + let i = ""; + const n = parseFloat(t.fontWeight); + 0 !== parseFloat(t.italicAngle) + ? (i = n >= 700 ? "bolditalic" : "italic") + : n >= 700 && (i = "bold"); + if (!i) { + (e.name.includes("Bold") || e.psName?.includes("Bold")) && (i = "bold"); + (e.name.includes("Italic") || + e.name.endsWith("It") || + e.psName?.includes("Italic") || + e.psName?.endsWith("It")) && + (i += "italic"); + } + i || (i = "regular"); + r[i] = e; + } + getDefault() { + return this.defaultFont; + } + find(e, t = !0) { + let a = this.fonts.get(e) || this.cache.get(e); + if (a) return a; + const r = /,|-|_| |bolditalic|bold|italic|regular|it/gi; + let i = e.replaceAll(r, ""); + a = this.fonts.get(i); + if (a) { + this.cache.set(e, a); + return a; + } + i = i.toLowerCase(); + const n = []; + for (const [e, t] of this.fonts.entries()) + e.replaceAll(r, "").toLowerCase().startsWith(i) && n.push(t); + if (0 === n.length) + for (const [, e] of this.fonts.entries()) + e.regular.name?.replaceAll(r, "").toLowerCase().startsWith(i) && + n.push(e); + if (0 === n.length) { + i = i.replaceAll(/psmt|mt/gi, ""); + for (const [e, t] of this.fonts.entries()) + e.replaceAll(r, "").toLowerCase().startsWith(i) && n.push(t); + } + if (0 === n.length) + for (const e of this.fonts.values()) + e.regular.name?.replaceAll(r, "").toLowerCase().startsWith(i) && + n.push(e); + if (n.length >= 1) { + 1 !== n.length && + t && + warn(`XFA - Too many choices to guess the correct font: ${e}`); + this.cache.set(e, n[0]); + return n[0]; + } + if (t && !this.warned.has(e)) { + this.warned.add(e); + warn(`XFA - Cannot find the font: ${e}`); + } + return null; + } +} +function selectFont(e, t) { + return "italic" === e.posture + ? "bold" === e.weight + ? t.bolditalic + : t.italic + : "bold" === e.weight + ? t.bold + : t.regular; +} +class FontInfo { + constructor(e, t, a, r) { + this.lineHeight = a; + this.paraMargin = t || { top: 0, bottom: 0, left: 0, right: 0 }; + if (!e) { + [this.pdfFont, this.xfaFont] = this.defaultFont(r); + return; + } + this.xfaFont = { + typeface: e.typeface, + posture: e.posture, + weight: e.weight, + size: e.size, + letterSpacing: e.letterSpacing, + }; + const i = r.find(e.typeface); + if (i) { + this.pdfFont = selectFont(e, i); + this.pdfFont || ([this.pdfFont, this.xfaFont] = this.defaultFont(r)); + } else [this.pdfFont, this.xfaFont] = this.defaultFont(r); + } + defaultFont(e) { + const t = + e.find("Helvetica", !1) || + e.find("Myriad Pro", !1) || + e.find("Arial", !1) || + e.getDefault(); + if (t?.regular) { + const e = t.regular; + return [ + e, + { + typeface: e.cssFontInfo.fontFamily, + posture: "normal", + weight: "normal", + size: 10, + letterSpacing: 0, + }, + ]; + } + return [ + null, + { + typeface: "Courier", + posture: "normal", + weight: "normal", + size: 10, + letterSpacing: 0, + }, + ]; + } +} +class FontSelector { + constructor(e, t, a, r) { + this.fontFinder = r; + this.stack = [new FontInfo(e, t, a, r)]; + } + pushData(e, t, a) { + const r = this.stack.at(-1); + for (const t of ["typeface", "posture", "weight", "size", "letterSpacing"]) + e[t] || (e[t] = r.xfaFont[t]); + for (const e of ["top", "bottom", "left", "right"]) + isNaN(t[e]) && (t[e] = r.paraMargin[e]); + const i = new FontInfo(e, t, a || r.lineHeight, this.fontFinder); + i.pdfFont || (i.pdfFont = r.pdfFont); + this.stack.push(i); + } + popFont() { + this.stack.pop(); + } + topFont() { + return this.stack.at(-1); + } +} +class TextMeasure { + constructor(e, t, a, r) { + this.glyphs = []; + this.fontSelector = new FontSelector(e, t, a, r); + this.extraHeight = 0; + } + pushData(e, t, a) { + this.fontSelector.pushData(e, t, a); + } + popFont(e) { + return this.fontSelector.popFont(); + } + addPara() { + const e = this.fontSelector.topFont(); + this.extraHeight += e.paraMargin.top + e.paraMargin.bottom; + } + addString(e) { + if (!e) return; + const t = this.fontSelector.topFont(), + a = t.xfaFont.size; + if (t.pdfFont) { + const r = t.xfaFont.letterSpacing, + i = t.pdfFont, + n = i.lineHeight || 1.2, + s = t.lineHeight || Math.max(1.2, n) * a, + o = n - (void 0 === i.lineGap ? 0.2 : i.lineGap), + c = Math.max(1, o) * a, + l = a / 1e3, + h = i.defaultWidth || i.charsToGlyphs(" ")[0].width; + for (const t of e.split(/[\u2029\n]/)) { + const e = i.encodeString(t).join(""), + a = i.charsToGlyphs(e); + for (const e of a) { + const t = e.width || h; + this.glyphs.push([t * l + r, s, c, e.unicode, !1]); + } + this.glyphs.push([0, 0, 0, "\n", !0]); + } + this.glyphs.pop(); + } else { + for (const t of e.split(/[\u2029\n]/)) { + for (const e of t.split("")) this.glyphs.push([a, 1.2 * a, a, e, !1]); + this.glyphs.push([0, 0, 0, "\n", !0]); + } + this.glyphs.pop(); + } + } + compute(e) { + let t = -1, + a = 0, + r = 0, + i = 0, + n = 0, + s = 0, + o = !1, + c = !0; + for (let l = 0, h = this.glyphs.length; l < h; l++) { + const [h, u, d, f, g] = this.glyphs[l], + p = " " === f, + m = c ? d : u; + if (g) { + r = Math.max(r, n); + n = 0; + i += s; + s = m; + t = -1; + a = 0; + c = !1; + } else if (p) + if (n + h > e) { + r = Math.max(r, n); + n = 0; + i += s; + s = m; + t = -1; + a = 0; + o = !0; + c = !1; + } else { + s = Math.max(m, s); + a = n; + n += h; + t = l; + } + else if (n + h > e) { + i += s; + s = m; + if (-1 !== t) { + l = t; + r = Math.max(r, a); + n = 0; + t = -1; + a = 0; + } else { + r = Math.max(r, n); + n = h; + } + o = !0; + c = !1; + } else { + n += h; + s = Math.max(m, s); + } + } + r = Math.max(r, n); + i += s + this.extraHeight; + return { width: 1.02 * r, height: i, isBroken: o }; + } +} +const bo = /^[^.[]+/, + yo = /^[^\]]+/, + wo = 0, + xo = 1, + So = 2, + ko = 3, + Ao = 4, + Co = new Map([ + ["$data", (e, t) => (e.datasets ? e.datasets.data : e)], + ["$record", (e, t) => (e.datasets ? e.datasets.data : e)[Ss]()[0]], + ["$template", (e, t) => e.template], + ["$connectionSet", (e, t) => e.connectionSet], + ["$form", (e, t) => e.form], + ["$layout", (e, t) => e.layout], + ["$host", (e, t) => e.host], + ["$dataWindow", (e, t) => e.dataWindow], + ["$event", (e, t) => e.event], + ["!", (e, t) => e.datasets], + ["$xfa", (e, t) => e], + ["xfa", (e, t) => e], + ["$", (e, t) => t], + ]), + vo = new WeakMap(); +function parseExpression(e, t, a = !0) { + let r = e.match(bo); + if (!r) return null; + let [i] = r; + const n = [ + { + name: i, + cacheName: "." + i, + index: 0, + js: null, + formCalc: null, + operator: wo, + }, + ]; + let s = i.length; + for (; s < e.length; ) { + const c = s; + if ("[" === e.charAt(s++)) { + r = e.slice(s).match(yo); + if (!r) { + warn("XFA - Invalid index in SOM expression"); + return null; + } + n.at(-1).index = + "*" === (o = (o = r[0]).trim()) ? 1 / 0 : parseInt(o, 10) || 0; + s += r[0].length + 1; + continue; + } + let l; + switch (e.charAt(s)) { + case ".": + if (!t) return null; + s++; + l = xo; + break; + case "#": + s++; + l = So; + break; + case "[": + if (a) { + warn( + "XFA - SOM expression contains a FormCalc subexpression which is not supported for now.", + ); + return null; + } + l = ko; + break; + case "(": + if (a) { + warn( + "XFA - SOM expression contains a JavaScript subexpression which is not supported for now.", + ); + return null; + } + l = Ao; + break; + default: + l = wo; + } + r = e.slice(s).match(bo); + if (!r) break; + [i] = r; + s += i.length; + n.push({ + name: i, + cacheName: e.slice(c, s), + operator: l, + index: 0, + js: null, + formCalc: null, + }); + } + var o; + return n; +} +function searchNode(e, t, a, r = !0, i = !0) { + const n = parseExpression(a, r); + if (!n) return null; + const s = Co.get(n[0].name); + let o, + c = 0; + if (s) { + o = !0; + e = [s(e, t)]; + c = 1; + } else { + o = null === t; + e = [t || e]; + } + for (let a = n.length; c < a; c++) { + const { name: a, cacheName: r, operator: s, index: l } = n[c], + h = []; + for (const t of e) { + if (!t.isXFAObject) continue; + let e, n; + if (i) { + n = vo.get(t); + if (!n) { + n = new Map(); + vo.set(t, n); + } + e = n.get(r); + } + if (!e) { + switch (s) { + case wo: + e = t[ms](a, !1); + break; + case xo: + e = t[ms](a, !0); + break; + case So: + e = t[ps](a); + e = e.isXFAObjectArray ? e.children : [e]; + } + i && n.set(r, e); + } + e.length > 0 && h.push(e); + } + if (0 !== h.length || o || 0 !== c) + e = isFinite(l) + ? h.filter((e) => l < e.length).map((e) => e[l]) + : h.flat(); + else { + const a = t[vs](); + if (!(t = a)) return null; + c = -1; + e = [t]; + } + } + return 0 === e.length ? null : e; +} +function createDataNode(e, t, a) { + const r = parseExpression(a); + if (!r) return null; + if (r.some((e) => e.operator === xo)) return null; + const i = Co.get(r[0].name); + let n = 0; + if (i) { + e = i(e, t); + n = 1; + } else e = t || e; + for (let t = r.length; n < t; n++) { + const { name: t, operator: a, index: i } = r[n]; + if (!isFinite(i)) { + r[n].index = 0; + return e.createNodes(r.slice(n)); + } + let s; + switch (a) { + case wo: + s = e[ms](t, !1); + break; + case xo: + s = e[ms](t, !0); + break; + case So: + s = e[ps](t); + s = s.isXFAObjectArray ? s.children : [s]; + } + if (0 === s.length) return e.createNodes(r.slice(n)); + if (!(i < s.length)) { + r[n].index = i - s.length; + return e.createNodes(r.slice(n)); + } + { + const t = s[i]; + if (!t.isXFAObject) { + warn("XFA - Cannot create a node."); + return null; + } + e = t; + } + } + return null; +} +const Fo = Symbol(), + Io = Symbol(), + Oo = Symbol(), + Mo = Symbol("_children"), + Do = Symbol(), + Bo = Symbol(), + Ro = Symbol(), + No = Symbol(), + Eo = Symbol(), + Po = Symbol(), + Lo = Symbol(), + jo = Symbol(), + _o = Symbol(), + Uo = Symbol("parent"), + Xo = Symbol(), + qo = Symbol(), + Ho = Symbol(); +let Wo = 0; +const zo = go.datasets.id; +class XFAObject { + constructor(e, t, a = !1) { + this[Hs] = e; + this[Ws] = t; + this[Lo] = a; + this[Uo] = null; + this[Mo] = []; + this[uo] = `${t}${Wo++}`; + this[Is] = null; + } + get isXFAObject() { + return !0; + } + get isXFAObjectArray() { + return !1; + } + createNodes(e) { + let t = this, + a = null; + for (const { name: r, index: i } of e) { + for (let e = 0, n = isFinite(i) ? i : 0; e <= n; e++) { + const e = t[Hs] === zo ? -1 : t[Hs]; + a = new XmlObject(e, r); + t[Qn](a); + } + t = a; + } + return a; + } + [$s](e) { + if (!this[Lo] || !this[Gs](e)) return !1; + const t = e[Ws], + a = this[t]; + if (!(a instanceof XFAObjectArray)) { + null !== a && this[Zs](a); + this[t] = e; + this[Qn](e); + return !0; + } + if (a.push(e)) { + this[Qn](e); + return !0; + } + let r = ""; + this.id + ? (r = ` (id: ${this.id})`) + : this.name && (r = ` (name: ${this.name} ${this.h.value})`); + warn(`XFA - node "${this[Ws]}"${r} has already enough "${t}"!`); + return !1; + } + [Gs](e) { + return this.hasOwnProperty(e[Ws]) && e[Hs] === this[Hs]; + } + [Ls]() { + return !1; + } + [Yn]() { + return !1; + } + [Bs]() { + return !1; + } + [Rs]() { + return !1; + } + [Js]() { + this.para && this[Fs]()[ls].paraStack.pop(); + } + [Ys]() { + this[Fs]()[ls].paraStack.push(this.para); + } + [ao](e) { + this.id && this[Hs] === go.template.id && e.set(this.id, this); + } + [Fs]() { + return this[Is].template; + } + [js]() { + return !1; + } + [_s]() { + return !1; + } + [Qn](e) { + e[Uo] = this; + this[Mo].push(e); + !e[Is] && this[Is] && (e[Is] = this[Is]); + } + [Zs](e) { + const t = this[Mo].indexOf(e); + this[Mo].splice(t, 1); + } + [Ts]() { + return this.hasOwnProperty("value"); + } + [io](e) {} + [Vs](e) {} + [hs]() {} + [ts](e) { + delete this[Lo]; + if (this[rs]) { + e.clean(this[rs]); + delete this[rs]; + } + } + [Ms](e) { + return this[Mo].indexOf(e); + } + [Ds](e, t) { + t[Uo] = this; + this[Mo].splice(e, 0, t); + !t[Is] && this[Is] && (t[Is] = this[Is]); + } + [Us]() { + return !this.name; + } + [qs]() { + return ""; + } + [so]() { + return 0 === this[Mo].length + ? this[ss] + : this[Mo].map((e) => e[so]()).join(""); + } + get [Oo]() { + const e = Object.getPrototypeOf(this); + if (!e._attributes) { + const t = (e._attributes = new Set()); + for (const e of Object.getOwnPropertyNames(this)) { + if ( + null === this[e] || + this[e] instanceof XFAObject || + this[e] instanceof XFAObjectArray + ) + break; + t.add(e); + } + } + return shadow(this, Oo, e._attributes); + } + [Es](e) { + let t = this; + for (; t; ) { + if (t === e) return !0; + t = t[vs](); + } + return !1; + } + [vs]() { + return this[Uo]; + } + [Cs]() { + return this[vs](); + } + [Ss](e = null) { + return e ? this[e] : this[Mo]; + } + [cs]() { + const e = Object.create(null); + this[ss] && (e.$content = this[ss]); + for (const t of Object.getOwnPropertyNames(this)) { + const a = this[t]; + null !== a && + (a instanceof XFAObject + ? (e[t] = a[cs]()) + : a instanceof XFAObjectArray + ? a.isEmpty() || (e[t] = a.dump()) + : (e[t] = a)); + } + return e; + } + [ho]() { + return null; + } + [co]() { + return HTMLResult.EMPTY; + } + *[ks]() { + for (const e of this[Ss]()) yield e; + } + *[No](e, t) { + for (const a of this[ks]()) + if (!e || t === e.has(a[Ws])) { + const e = this[gs](), + t = a[co](e); + t.success || (this[ls].failingNode = a); + yield t; + } + } + [us]() { + return null; + } + [Zn](e, t) { + this[ls].children.push(e); + } + [gs]() {} + [es]({ filter: e = null, include: t = !0 }) { + if (this[ls].generator) { + const e = this[gs](), + t = this[ls].failingNode[co](e); + if (!t.success) return t; + t.html && this[Zn](t.html, t.bbox); + delete this[ls].failingNode; + } else this[ls].generator = this[No](e, t); + for (;;) { + const e = this[ls].generator.next(); + if (e.done) break; + const t = e.value; + if (!t.success) return t; + t.html && this[Zn](t.html, t.bbox); + } + this[ls].generator = null; + return HTMLResult.EMPTY; + } + [ro](e) { + this[qo] = new Set(Object.keys(e)); + } + [Po](e) { + const t = this[Oo], + a = this[qo]; + return [...e].filter((e) => t.has(e) && !a.has(e)); + } + [eo](e, t = new Set()) { + for (const a of this[Mo]) a[Xo](e, t); + } + [Xo](e, t) { + const a = this[Eo](e, t); + a ? this[Fo](a, e, t) : this[eo](e, t); + } + [Eo](e, t) { + const { use: a, usehref: r } = this; + if (!a && !r) return null; + let i = null, + n = null, + s = null, + o = a; + if (r) { + o = r; + r.startsWith("#som(") && r.endsWith(")") + ? (n = r.slice(5, -1)) + : r.startsWith(".#som(") && r.endsWith(")") + ? (n = r.slice(6, -1)) + : r.startsWith("#") + ? (s = r.slice(1)) + : r.startsWith(".#") && (s = r.slice(2)); + } else a.startsWith("#") ? (s = a.slice(1)) : (n = a); + this.use = this.usehref = ""; + if (s) i = e.get(s); + else { + i = searchNode(e.get(Qs), this, n, !0, !1); + i && (i = i[0]); + } + if (!i) { + warn(`XFA - Invalid prototype reference: ${o}.`); + return null; + } + if (i[Ws] !== this[Ws]) { + warn(`XFA - Incompatible prototype: ${i[Ws]} !== ${this[Ws]}.`); + return null; + } + if (t.has(i)) { + warn("XFA - Cycle detected in prototypes use."); + return null; + } + t.add(i); + const c = i[Eo](e, t); + c && i[Fo](c, e, t); + i[eo](e, t); + t.delete(i); + return i; + } + [Fo](e, t, a) { + if (a.has(e)) { + warn("XFA - Cycle detected in prototypes use."); + return; + } + !this[ss] && e[ss] && (this[ss] = e[ss]); + new Set(a).add(e); + for (const t of this[Po](e[qo])) { + this[t] = e[t]; + this[qo] && this[qo].add(t); + } + for (const r of Object.getOwnPropertyNames(this)) { + if (this[Oo].has(r)) continue; + const i = this[r], + n = e[r]; + if (i instanceof XFAObjectArray) { + for (const e of i[Mo]) e[Xo](t, a); + for (let r = i[Mo].length, s = n[Mo].length; r < s; r++) { + const n = e[Mo][r][is](); + if (!i.push(n)) break; + n[Uo] = this; + this[Mo].push(n); + n[Xo](t, a); + } + } else if (null === i) { + if (null !== n) { + const e = n[is](); + e[Uo] = this; + this[r] = e; + this[Mo].push(e); + e[Xo](t, a); + } + } else { + i[eo](t, a); + n && i[Fo](n, t, a); + } + } + } + static [Do](e) { + return Array.isArray(e) + ? e.map((e) => XFAObject[Do](e)) + : "object" == typeof e && null !== e + ? Object.assign({}, e) + : e; + } + [is]() { + const e = Object.create(Object.getPrototypeOf(this)); + for (const t of Object.getOwnPropertySymbols(this)) + try { + e[t] = this[t]; + } catch { + shadow(e, t, this[t]); + } + e[uo] = `${e[Ws]}${Wo++}`; + e[Mo] = []; + for (const t of Object.getOwnPropertyNames(this)) { + if (this[Oo].has(t)) { + e[t] = XFAObject[Do](this[t]); + continue; + } + const a = this[t]; + e[t] = a instanceof XFAObjectArray ? new XFAObjectArray(a[jo]) : null; + } + for (const t of this[Mo]) { + const a = t[Ws], + r = t[is](); + e[Mo].push(r); + r[Uo] = e; + null === e[a] ? (e[a] = r) : e[a][Mo].push(r); + } + return e; + } + [Ss](e = null) { + return e ? this[Mo].filter((t) => t[Ws] === e) : this[Mo]; + } + [ps](e) { + return this[e]; + } + [ms](e, t, a = !0) { + return Array.from(this[bs](e, t, a)); + } + *[bs](e, t, a = !0) { + if ("parent" !== e) { + for (const a of this[Mo]) { + a[Ws] === e && (yield a); + a.name === e && (yield a); + (t || a[Us]()) && (yield* a[bs](e, t, !1)); + } + a && this[Oo].has(e) && (yield new XFAAttribute(this, e, this[e])); + } else yield this[Uo]; + } +} +class XFAObjectArray { + constructor(e = 1 / 0) { + this[jo] = e; + this[Mo] = []; + } + get isXFAObject() { + return !1; + } + get isXFAObjectArray() { + return !0; + } + push(e) { + if (this[Mo].length <= this[jo]) { + this[Mo].push(e); + return !0; + } + warn(`XFA - node "${e[Ws]}" accepts no more than ${this[jo]} children`); + return !1; + } + isEmpty() { + return 0 === this[Mo].length; + } + dump() { + return 1 === this[Mo].length + ? this[Mo][0][cs]() + : this[Mo].map((e) => e[cs]()); + } + [is]() { + const e = new XFAObjectArray(this[jo]); + e[Mo] = this[Mo].map((e) => e[is]()); + return e; + } + get children() { + return this[Mo]; + } + clear() { + this[Mo].length = 0; + } +} +class XFAAttribute { + constructor(e, t, a) { + this[Uo] = e; + this[Ws] = t; + this[ss] = a; + this[ns] = !1; + this[uo] = "attribute" + Wo++; + } + [vs]() { + return this[Uo]; + } + [Ns]() { + return !0; + } + [ys]() { + return this[ss].trim(); + } + [io](e) { + e = e.value || ""; + this[ss] = e.toString(); + } + [so]() { + return this[ss]; + } + [Es](e) { + return this[Uo] === e || this[Uo][Es](e); + } +} +class XmlObject extends XFAObject { + constructor(e, t, a = {}) { + super(e, t); + this[ss] = ""; + this[Bo] = null; + if ("#text" !== t) { + const e = new Map(); + this[Io] = e; + for (const [t, r] of Object.entries(a)) + e.set(t, new XFAAttribute(this, t, r)); + if (a.hasOwnProperty(zs)) { + const e = a[zs].xfa.dataNode; + void 0 !== e && + ("dataGroup" === e + ? (this[Bo] = !1) + : "dataValue" === e && (this[Bo] = !0)); + } + } + this[ns] = !1; + } + [lo](e) { + const t = this[Ws]; + if ("#text" === t) { + e.push(encodeToXmlString(this[ss])); + return; + } + const a = utf8StringToString(t), + r = this[Hs] === zo ? "xfa:" : ""; + e.push(`<${r}${a}`); + for (const [t, a] of this[Io].entries()) { + const r = utf8StringToString(t); + e.push(` ${r}="${encodeToXmlString(a[ss])}"`); + } + null !== this[Bo] && + (this[Bo] + ? e.push(' xfa:dataNode="dataValue"') + : e.push(' xfa:dataNode="dataGroup"')); + if (this[ss] || 0 !== this[Mo].length) { + e.push(">"); + if (this[ss]) + "string" == typeof this[ss] + ? e.push(encodeToXmlString(this[ss])) + : this[ss][lo](e); + else for (const t of this[Mo]) t[lo](e); + e.push(``); + } else e.push("/>"); + } + [$s](e) { + if (this[ss]) { + const e = new XmlObject(this[Hs], "#text"); + this[Qn](e); + e[ss] = this[ss]; + this[ss] = ""; + } + this[Qn](e); + return !0; + } + [Vs](e) { + this[ss] += e; + } + [hs]() { + if (this[ss] && this[Mo].length > 0) { + const e = new XmlObject(this[Hs], "#text"); + this[Qn](e); + e[ss] = this[ss]; + delete this[ss]; + } + } + [co]() { + return "#text" === this[Ws] + ? HTMLResult.success({ name: "#text", value: this[ss] }) + : HTMLResult.EMPTY; + } + [Ss](e = null) { + return e ? this[Mo].filter((t) => t[Ws] === e) : this[Mo]; + } + [fs]() { + return this[Io]; + } + [ps](e) { + const t = this[Io].get(e); + return void 0 !== t ? t : this[Ss](e); + } + *[bs](e, t) { + const a = this[Io].get(e); + a && (yield a); + for (const a of this[Mo]) { + a[Ws] === e && (yield a); + t && (yield* a[bs](e, t)); + } + } + *[ds](e, t) { + const a = this[Io].get(e); + !a || (t && a[ns]) || (yield a); + for (const a of this[Mo]) yield* a[ds](e, t); + } + *[xs](e, t, a) { + for (const r of this[Mo]) { + r[Ws] !== e || (a && r[ns]) || (yield r); + t && (yield* r[xs](e, t, a)); + } + } + [Ns]() { + return null === this[Bo] + ? 0 === this[Mo].length || this[Mo][0][Hs] === go.xhtml.id + : this[Bo]; + } + [ys]() { + return null === this[Bo] + ? 0 === this[Mo].length + ? this[ss].trim() + : this[Mo][0][Hs] === go.xhtml.id + ? this[Mo][0][so]().trim() + : null + : this[ss].trim(); + } + [io](e) { + e = e.value || ""; + this[ss] = e.toString(); + } + [cs](e = !1) { + const t = Object.create(null); + e && (t.$ns = this[Hs]); + this[ss] && (t.$content = this[ss]); + t.$name = this[Ws]; + t.children = []; + for (const a of this[Mo]) t.children.push(a[cs](e)); + t.attributes = Object.create(null); + for (const [e, a] of this[Io]) t.attributes[e] = a[ss]; + return t; + } +} +class ContentObject extends XFAObject { + constructor(e, t) { + super(e, t); + this[ss] = ""; + } + [Vs](e) { + this[ss] += e; + } + [hs]() {} +} +class OptionObject extends ContentObject { + constructor(e, t, a) { + super(e, t); + this[_o] = a; + } + [hs]() { + this[ss] = getKeyword({ + data: this[ss], + defaultValue: this[_o][0], + validate: (e) => this[_o].includes(e), + }); + } + [ts](e) { + super[ts](e); + delete this[_o]; + } +} +class StringObject extends ContentObject { + [hs]() { + this[ss] = this[ss].trim(); + } +} +class IntegerObject extends ContentObject { + constructor(e, t, a, r) { + super(e, t); + this[Ro] = a; + this[Ho] = r; + } + [hs]() { + this[ss] = getInteger({ + data: this[ss], + defaultValue: this[Ro], + validate: this[Ho], + }); + } + [ts](e) { + super[ts](e); + delete this[Ro]; + delete this[Ho]; + } +} +class Option01 extends IntegerObject { + constructor(e, t) { + super(e, t, 0, (e) => 1 === e); + } +} +class Option10 extends IntegerObject { + constructor(e, t) { + super(e, t, 1, (e) => 0 === e); + } +} +function measureToString(e) { + return "string" == typeof e + ? "0px" + : Number.isInteger(e) + ? `${e}px` + : `${e.toFixed(2)}px`; +} +const $o = { + anchorType(e, t) { + const a = e[Cs](); + if (a && (!a.layout || "position" === a.layout)) { + "transform" in t || (t.transform = ""); + switch (e.anchorType) { + case "bottomCenter": + t.transform += "translate(-50%, -100%)"; + break; + case "bottomLeft": + t.transform += "translate(0,-100%)"; + break; + case "bottomRight": + t.transform += "translate(-100%,-100%)"; + break; + case "middleCenter": + t.transform += "translate(-50%,-50%)"; + break; + case "middleLeft": + t.transform += "translate(0,-50%)"; + break; + case "middleRight": + t.transform += "translate(-100%,-50%)"; + break; + case "topCenter": + t.transform += "translate(-50%,0)"; + break; + case "topRight": + t.transform += "translate(-100%,0)"; + } + } + }, + dimensions(e, t) { + const a = e[Cs](); + let r = e.w; + const i = e.h; + if (a.layout?.includes("row")) { + const t = a[ls], + i = e.colSpan; + let n; + if (-1 === i) { + n = Math.sumPrecise(t.columnWidths.slice(t.currentColumn)); + t.currentColumn = 0; + } else { + n = Math.sumPrecise( + t.columnWidths.slice(t.currentColumn, t.currentColumn + i), + ); + t.currentColumn = (t.currentColumn + e.colSpan) % t.columnWidths.length; + } + isNaN(n) || (r = e.w = n); + } + t.width = "" !== r ? measureToString(r) : "auto"; + t.height = "" !== i ? measureToString(i) : "auto"; + }, + position(e, t) { + const a = e[Cs](); + if (!a?.layout || "position" === a.layout) { + t.position = "absolute"; + t.left = measureToString(e.x); + t.top = measureToString(e.y); + } + }, + rotate(e, t) { + if (e.rotate) { + "transform" in t || (t.transform = ""); + t.transform += `rotate(-${e.rotate}deg)`; + t.transformOrigin = "top left"; + } + }, + presence(e, t) { + switch (e.presence) { + case "invisible": + t.visibility = "hidden"; + break; + case "hidden": + case "inactive": + t.display = "none"; + } + }, + hAlign(e, t) { + if ("para" === e[Ws]) + switch (e.hAlign) { + case "justifyAll": + t.textAlign = "justify-all"; + break; + case "radix": + t.textAlign = "left"; + break; + default: + t.textAlign = e.hAlign; + } + else + switch (e.hAlign) { + case "left": + t.alignSelf = "start"; + break; + case "center": + t.alignSelf = "center"; + break; + case "right": + t.alignSelf = "end"; + } + }, + margin(e, t) { + e.margin && (t.margin = e.margin[ho]().margin); + }, +}; +function setMinMaxDimensions(e, t) { + if ("position" === e[Cs]().layout) { + e.minW > 0 && (t.minWidth = measureToString(e.minW)); + e.maxW > 0 && (t.maxWidth = measureToString(e.maxW)); + e.minH > 0 && (t.minHeight = measureToString(e.minH)); + e.maxH > 0 && (t.maxHeight = measureToString(e.maxH)); + } +} +function layoutText(e, t, a, r, i, n) { + const s = new TextMeasure(t, a, r, i); + "string" == typeof e ? s.addString(e) : e[Ks](s); + return s.compute(n); +} +function layoutNode(e, t) { + let a = null, + r = null, + i = !1; + if ((!e.w || !e.h) && e.value) { + let n = 0, + s = 0; + if (e.margin) { + n = e.margin.leftInset + e.margin.rightInset; + s = e.margin.topInset + e.margin.bottomInset; + } + let o = null, + c = null; + if (e.para) { + c = Object.create(null); + o = "" === e.para.lineHeight ? null : e.para.lineHeight; + c.top = "" === e.para.spaceAbove ? 0 : e.para.spaceAbove; + c.bottom = "" === e.para.spaceBelow ? 0 : e.para.spaceBelow; + c.left = "" === e.para.marginLeft ? 0 : e.para.marginLeft; + c.right = "" === e.para.marginRight ? 0 : e.para.marginRight; + } + let l = e.font; + if (!l) { + const t = e[Fs](); + let a = e[vs](); + for (; a && a !== t; ) { + if (a.font) { + l = a.font; + break; + } + a = a[vs](); + } + } + const h = (e.w || t.width) - n, + u = e[Is].fontFinder; + if ( + e.value.exData && + e.value.exData[ss] && + "text/html" === e.value.exData.contentType + ) { + const t = layoutText(e.value.exData[ss], l, c, o, u, h); + r = t.width; + a = t.height; + i = t.isBroken; + } else { + const t = e.value[so](); + if (t) { + const e = layoutText(t, l, c, o, u, h); + r = e.width; + a = e.height; + i = e.isBroken; + } + } + null === r || e.w || (r += n); + null === a || e.h || (a += s); + } + return { w: r, h: a, isBroken: i }; +} +function computeBbox(e, t, a) { + let r; + if ("" !== e.w && "" !== e.h) r = [e.x, e.y, e.w, e.h]; + else { + if (!a) return null; + let i = e.w; + if ("" === i) { + if (0 === e.maxW) { + const t = e[Cs](); + i = "position" === t.layout && "" !== t.w ? 0 : e.minW; + } else i = Math.min(e.maxW, a.width); + t.attributes.style.width = measureToString(i); + } + let n = e.h; + if ("" === n) { + if (0 === e.maxH) { + const t = e[Cs](); + n = "position" === t.layout && "" !== t.h ? 0 : e.minH; + } else n = Math.min(e.maxH, a.height); + t.attributes.style.height = measureToString(n); + } + r = [e.x, e.y, i, n]; + } + return r; +} +function fixDimensions(e) { + const t = e[Cs](); + if (t.layout?.includes("row")) { + const a = t[ls], + r = e.colSpan; + let i; + i = + -1 === r + ? Math.sumPrecise(a.columnWidths.slice(a.currentColumn)) + : Math.sumPrecise( + a.columnWidths.slice(a.currentColumn, a.currentColumn + r), + ); + isNaN(i) || (e.w = i); + } + t.layout && "position" !== t.layout && (e.x = e.y = 0); + "table" === e.layout && + "" === e.w && + Array.isArray(e.columnWidths) && + (e.w = Math.sumPrecise(e.columnWidths)); +} +function layoutClass(e) { + switch (e.layout) { + case "position": + default: + return "xfaPosition"; + case "lr-tb": + return "xfaLrTb"; + case "rl-row": + return "xfaRlRow"; + case "rl-tb": + return "xfaRlTb"; + case "row": + return "xfaRow"; + case "table": + return "xfaTable"; + case "tb": + return "xfaTb"; + } +} +function toStyle(e, ...t) { + const a = Object.create(null); + for (const r of t) { + const t = e[r]; + if (null !== t) + if ($o.hasOwnProperty(r)) $o[r](e, a); + else if (t instanceof XFAObject) { + const e = t[ho](); + e + ? Object.assign(a, e) + : warn(`(DEBUG) - XFA - style for ${r} not implemented yet`); + } + } + return a; +} +function createWrapper(e, t) { + const { attributes: a } = t, + { style: r } = a, + i = { + name: "div", + attributes: { class: ["xfaWrapper"], style: Object.create(null) }, + children: [], + }; + a.class.push("xfaWrapped"); + if (e.border) { + const { widths: a, insets: n } = e.border[ls]; + let s, + o, + c = n[0], + l = n[3]; + const h = n[0] + n[2], + u = n[1] + n[3]; + switch (e.border.hand) { + case "even": + c -= a[0] / 2; + l -= a[3] / 2; + s = `calc(100% + ${(a[1] + a[3]) / 2 - u}px)`; + o = `calc(100% + ${(a[0] + a[2]) / 2 - h}px)`; + break; + case "left": + c -= a[0]; + l -= a[3]; + s = `calc(100% + ${a[1] + a[3] - u}px)`; + o = `calc(100% + ${a[0] + a[2] - h}px)`; + break; + case "right": + s = u ? `calc(100% - ${u}px)` : "100%"; + o = h ? `calc(100% - ${h}px)` : "100%"; + } + const d = ["xfaBorder"]; + isPrintOnly(e.border) && d.push("xfaPrintOnly"); + const f = { + name: "div", + attributes: { + class: d, + style: { top: `${c}px`, left: `${l}px`, width: s, height: o }, + }, + children: [], + }; + for (const e of [ + "border", + "borderWidth", + "borderColor", + "borderRadius", + "borderStyle", + ]) + if (void 0 !== r[e]) { + f.attributes.style[e] = r[e]; + delete r[e]; + } + i.children.push(f, t); + } else i.children.push(t); + for (const e of [ + "background", + "backgroundClip", + "top", + "left", + "width", + "height", + "minWidth", + "minHeight", + "maxWidth", + "maxHeight", + "transform", + "transformOrigin", + "visibility", + ]) + if (void 0 !== r[e]) { + i.attributes.style[e] = r[e]; + delete r[e]; + } + i.attributes.style.position = + "absolute" === r.position ? "absolute" : "relative"; + delete r.position; + if (r.alignSelf) { + i.attributes.style.alignSelf = r.alignSelf; + delete r.alignSelf; + } + return i; +} +function fixTextIndent(e) { + const t = getMeasurement(e.textIndent, "0px"); + if (t >= 0) return; + const a = + "padding" + + ("left" === ("right" === e.textAlign ? "right" : "left") + ? "Left" + : "Right"), + r = getMeasurement(e[a], "0px"); + e[a] = r - t + "px"; +} +function setAccess(e, t) { + switch (e.access) { + case "nonInteractive": + t.push("xfaNonInteractive"); + break; + case "readOnly": + t.push("xfaReadOnly"); + break; + case "protected": + t.push("xfaDisabled"); + } +} +function isPrintOnly(e) { + return ( + e.relevant.length > 0 && + !e.relevant[0].excluded && + "print" === e.relevant[0].viewname + ); +} +function getCurrentPara(e) { + const t = e[Fs]()[ls].paraStack; + return t.length ? t.at(-1) : null; +} +function setPara(e, t, a) { + if (a.attributes.class?.includes("xfaRich")) { + if (t) { + "" === e.h && (t.height = "auto"); + "" === e.w && (t.width = "auto"); + } + const r = getCurrentPara(e); + if (r) { + const e = a.attributes.style; + e.display = "flex"; + e.flexDirection = "column"; + switch (r.vAlign) { + case "top": + e.justifyContent = "start"; + break; + case "bottom": + e.justifyContent = "end"; + break; + case "middle": + e.justifyContent = "center"; + } + const t = r[ho](); + for (const [a, r] of Object.entries(t)) a in e || (e[a] = r); + } + } +} +function setFontFamily(e, t, a, r) { + if (!a) { + delete r.fontFamily; + return; + } + const i = stripQuotes(e.typeface); + r.fontFamily = `"${i}"`; + const n = a.find(i); + if (n) { + const { fontFamily: a } = n.regular.cssFontInfo; + a !== i && (r.fontFamily = `"${a}"`); + const s = getCurrentPara(t); + if (s && "" !== s.lineHeight) return; + if (r.lineHeight) return; + const o = selectFont(e, n); + o && (r.lineHeight = Math.max(1.2, o.lineHeight)); + } +} +function fixURL(e) { + const t = createValidAbsoluteUrl(e, null, { + addDefaultProtocol: !0, + tryConvertEncoding: !0, + }); + return t ? t.href : null; +} +function createLine(e, t) { + return { + name: "div", + attributes: { class: ["lr-tb" === e.layout ? "xfaLr" : "xfaRl"] }, + children: t, + }; +} +function flushHTML(e) { + if (!e[ls]) return null; + const t = { + name: "div", + attributes: e[ls].attributes, + children: e[ls].children, + }; + if (e[ls].failingNode) { + const a = e[ls].failingNode[us](); + a && + (e.layout.endsWith("-tb") + ? t.children.push(createLine(e, [a])) + : t.children.push(a)); + } + return 0 === t.children.length ? null : t; +} +function addHTML(e, t, a) { + const r = e[ls], + i = r.availableSpace, + [n, s, o, c] = a; + switch (e.layout) { + case "position": + r.width = Math.max(r.width, n + o); + r.height = Math.max(r.height, s + c); + r.children.push(t); + break; + case "lr-tb": + case "rl-tb": + if (!r.line || 1 === r.attempt) { + r.line = createLine(e, []); + r.children.push(r.line); + r.numberInLine = 0; + } + r.numberInLine += 1; + r.line.children.push(t); + if (0 === r.attempt) { + r.currentWidth += o; + r.height = Math.max(r.height, r.prevHeight + c); + } else { + r.currentWidth = o; + r.prevHeight = r.height; + r.height += c; + r.attempt = 0; + } + r.width = Math.max(r.width, r.currentWidth); + break; + case "rl-row": + case "row": { + r.children.push(t); + r.width += o; + r.height = Math.max(r.height, c); + const e = measureToString(r.height); + for (const t of r.children) t.attributes.style.height = e; + break; + } + case "table": + case "tb": + r.width = MathClamp(o, r.width, i.width); + r.height += c; + r.children.push(t); + } +} +function getAvailableSpace(e) { + const t = e[ls].availableSpace, + a = e.margin ? e.margin.topInset + e.margin.bottomInset : 0, + r = e.margin ? e.margin.leftInset + e.margin.rightInset : 0; + switch (e.layout) { + case "lr-tb": + case "rl-tb": + return 0 === e[ls].attempt + ? { + width: t.width - r - e[ls].currentWidth, + height: t.height - a - e[ls].prevHeight, + } + : { width: t.width - r, height: t.height - a - e[ls].height }; + case "rl-row": + case "row": + return { + width: Math.sumPrecise(e[ls].columnWidths.slice(e[ls].currentColumn)), + height: t.height - r, + }; + case "table": + case "tb": + return { width: t.width - r, height: t.height - a - e[ls].height }; + default: + return t; + } +} +function checkDimensions(e, t) { + if (null === e[Fs]()[ls].firstUnsplittable) return !0; + if (0 === e.w || 0 === e.h) return !0; + const a = e[Cs](), + r = a[ls]?.attempt || 0, + [, i, n, s] = (function getTransformedBBox(e) { + let t, + a, + r = "" === e.w ? NaN : e.w, + i = "" === e.h ? NaN : e.h, + [n, s] = [0, 0]; + switch (e.anchorType || "") { + case "bottomCenter": + [n, s] = [r / 2, i]; + break; + case "bottomLeft": + [n, s] = [0, i]; + break; + case "bottomRight": + [n, s] = [r, i]; + break; + case "middleCenter": + [n, s] = [r / 2, i / 2]; + break; + case "middleLeft": + [n, s] = [0, i / 2]; + break; + case "middleRight": + [n, s] = [r, i / 2]; + break; + case "topCenter": + [n, s] = [r / 2, 0]; + break; + case "topRight": + [n, s] = [r, 0]; + } + switch (e.rotate || 0) { + case 0: + [t, a] = [-n, -s]; + break; + case 90: + [t, a] = [-s, n]; + [r, i] = [i, -r]; + break; + case 180: + [t, a] = [n, s]; + [r, i] = [-r, -i]; + break; + case 270: + [t, a] = [s, -n]; + [r, i] = [-i, r]; + } + return [ + e.x + t + Math.min(0, r), + e.y + a + Math.min(0, i), + Math.abs(r), + Math.abs(i), + ]; + })(e); + switch (a.layout) { + case "lr-tb": + case "rl-tb": + return 0 === r + ? e[Fs]()[ls].noLayoutFailure + ? "" !== e.w + ? Math.round(n - t.width) <= 2 + : t.width > 2 + : !("" !== e.h && Math.round(s - t.height) > 2) && + ("" !== e.w + ? Math.round(n - t.width) <= 2 || + (0 === a[ls].numberInLine && t.height > 2) + : t.width > 2) + : !!e[Fs]()[ls].noLayoutFailure || + (!("" !== e.h && Math.round(s - t.height) > 2) && + ("" === e.w || Math.round(n - t.width) <= 2 || !a[_s]()) && + t.height > 2); + case "table": + case "tb": + return ( + !!e[Fs]()[ls].noLayoutFailure || + ("" === e.h || e[js]() + ? ("" === e.w || Math.round(n - t.width) <= 2 || !a[_s]()) && + t.height > 2 + : Math.round(s - t.height) <= 2) + ); + case "position": + if (e[Fs]()[ls].noLayoutFailure) return !0; + if ("" === e.h || Math.round(s + i - t.height) <= 2) return !0; + return s + i > e[Fs]()[ls].currentContentArea.h; + case "rl-row": + case "row": + return ( + !!e[Fs]()[ls].noLayoutFailure || + "" === e.h || + Math.round(s - t.height) <= 2 + ); + default: + return !0; + } +} +const Go = go.template.id, + Vo = "http://www.w3.org/2000/svg", + Ko = /^H(\d+)$/, + Jo = new Set([ + "image/gif", + "image/jpeg", + "image/jpg", + "image/pjpeg", + "image/png", + "image/apng", + "image/x-png", + "image/bmp", + "image/x-ms-bmp", + "image/tiff", + "image/tif", + "application/octet-stream", + ]), + Yo = [ + [[66, 77], "image/bmp"], + [[255, 216, 255], "image/jpeg"], + [[73, 73, 42, 0], "image/tiff"], + [[77, 77, 0, 42], "image/tiff"], + [[71, 73, 70, 56, 57, 97], "image/gif"], + [[137, 80, 78, 71, 13, 10, 26, 10], "image/png"], + ]; +function getBorderDims(e) { + if (!e || !e.border) return { w: 0, h: 0 }; + const t = e.border[ws](); + return t + ? { + w: t.widths[0] + t.widths[2] + t.insets[0] + t.insets[2], + h: t.widths[1] + t.widths[3] + t.insets[1] + t.insets[3], + } + : { w: 0, h: 0 }; +} +function hasMargin(e) { + return ( + e.margin && + (e.margin.topInset || + e.margin.rightInset || + e.margin.bottomInset || + e.margin.leftInset) + ); +} +function _setValue(e, t) { + if (!e.value) { + const t = new Value({}); + e[Qn](t); + e.value = t; + } + e.value[io](t); +} +function* getContainedChildren(e) { + for (const t of e[Ss]()) t instanceof SubformSet ? yield* t[ks]() : yield t; +} +function isRequired(e) { + return "error" === e.validate?.nullTest; +} +function setTabIndex(e) { + for (; e; ) { + if (!e.traversal) { + e[no] = e[vs]()[no]; + return; + } + if (e[no]) return; + let t = null; + for (const a of e.traversal[Ss]()) + if ("next" === a.operation) { + t = a; + break; + } + if (!t || !t.ref) { + e[no] = e[vs]()[no]; + return; + } + const a = e[Fs](); + e[no] = ++a[no]; + const r = a[to](t.ref, e); + if (!r) return; + e = r[0]; + } +} +function applyAssist(e, t) { + const a = e.assist; + if (a) { + const e = a[co](); + e && (t.title = e); + const r = a.role.match(Ko); + if (r) { + const e = "heading", + a = r[1]; + t.role = e; + t["aria-level"] = a; + } + } + if ("table" === e.layout) t.role = "table"; + else if ("row" === e.layout) t.role = "row"; + else { + const a = e[vs](); + "row" === a.layout && + (t.role = "TH" === a.assist?.role ? "columnheader" : "cell"); + } +} +function ariaLabel(e) { + if (!e.assist) return null; + const t = e.assist; + return t.speak && "" !== t.speak[ss] + ? t.speak[ss] + : t.toolTip + ? t.toolTip[ss] + : null; +} +function valueToHtml(e) { + return HTMLResult.success({ + name: "div", + attributes: { class: ["xfaRich"], style: Object.create(null) }, + children: [ + { name: "span", attributes: { style: Object.create(null) }, value: e }, + ], + }); +} +function setFirstUnsplittable(e) { + const t = e[Fs](); + if (null === t[ls].firstUnsplittable) { + t[ls].firstUnsplittable = e; + t[ls].noLayoutFailure = !0; + } +} +function unsetFirstUnsplittable(e) { + const t = e[Fs](); + t[ls].firstUnsplittable === e && (t[ls].noLayoutFailure = !1); +} +function handleBreak(e) { + if (e[ls]) return !1; + e[ls] = Object.create(null); + if ("auto" === e.targetType) return !1; + const t = e[Fs](); + let a = null; + if (e.target) { + a = t[to](e.target, e[vs]()); + if (!a) return !1; + a = a[0]; + } + const { currentPageArea: r, currentContentArea: i } = t[ls]; + if ("pageArea" === e.targetType) { + a instanceof PageArea || (a = null); + if (e.startNew) { + e[ls].target = a || r; + return !0; + } + if (a && a !== r) { + e[ls].target = a; + return !0; + } + return !1; + } + a instanceof ContentArea || (a = null); + const n = a && a[vs](); + let s, + o = n; + if (e.startNew) + if (a) { + const e = n.contentArea.children, + t = e.indexOf(i), + r = e.indexOf(a); + -1 !== t && t < r && (o = null); + s = r - 1; + } else s = r.contentArea.children.indexOf(i); + else { + if (!a || a === i) return !1; + s = n.contentArea.children.indexOf(a) - 1; + o = n === r ? null : n; + } + e[ls].target = o; + e[ls].index = s; + return !0; +} +function handleOverflow(e, t, a) { + const r = e[Fs](), + i = r[ls].noLayoutFailure, + n = t[Cs]; + t[Cs] = () => e; + r[ls].noLayoutFailure = !0; + const s = t[co](a); + e[Zn](s.html, s.bbox); + r[ls].noLayoutFailure = i; + t[Cs] = n; +} +class AppearanceFilter extends StringObject { + constructor(e) { + super(Go, "appearanceFilter"); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Arc extends XFAObject { + constructor(e) { + super(Go, "arc", !0); + this.circular = getInteger({ + data: e.circular, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.hand = getStringOption(e.hand, ["even", "left", "right"]); + this.id = e.id || ""; + this.startAngle = getFloat({ + data: e.startAngle, + defaultValue: 0, + validate: (e) => !0, + }); + this.sweepAngle = getFloat({ + data: e.sweepAngle, + defaultValue: 360, + validate: (e) => !0, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.edge = null; + this.fill = null; + } + [co]() { + const e = this.edge || new Edge({}), + t = e[ho](), + a = Object.create(null); + "visible" === this.fill?.presence + ? Object.assign(a, this.fill[ho]()) + : (a.fill = "transparent"); + a.strokeWidth = measureToString("visible" === e.presence ? e.thickness : 0); + a.stroke = t.color; + let r; + const i = { + xmlns: Vo, + style: { width: "100%", height: "100%", overflow: "visible" }, + }; + if (360 === this.sweepAngle) + r = { + name: "ellipse", + attributes: { + xmlns: Vo, + cx: "50%", + cy: "50%", + rx: "50%", + ry: "50%", + style: a, + }, + }; + else { + const e = (this.startAngle * Math.PI) / 180, + t = (this.sweepAngle * Math.PI) / 180, + n = this.sweepAngle > 180 ? 1 : 0, + [s, o, c, l] = [ + 50 * (1 + Math.cos(e)), + 50 * (1 - Math.sin(e)), + 50 * (1 + Math.cos(e + t)), + 50 * (1 - Math.sin(e + t)), + ]; + r = { + name: "path", + attributes: { + xmlns: Vo, + d: `M ${s} ${o} A 50 50 0 ${n} 0 ${c} ${l}`, + vectorEffect: "non-scaling-stroke", + style: a, + }, + }; + Object.assign(i, { viewBox: "0 0 100 100", preserveAspectRatio: "none" }); + } + const n = { name: "svg", children: [r], attributes: i }; + if (hasMargin(this[vs]()[vs]())) + return HTMLResult.success({ + name: "div", + attributes: { + style: { display: "inline", width: "100%", height: "100%" }, + }, + children: [n], + }); + n.attributes.style.position = "absolute"; + return HTMLResult.success(n); + } +} +class Area extends XFAObject { + constructor(e) { + super(Go, "area", !0); + this.colSpan = getInteger({ + data: e.colSpan, + defaultValue: 1, + validate: (e) => e >= 1 || -1 === e, + }); + this.id = e.id || ""; + this.name = e.name || ""; + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.desc = null; + this.extras = null; + this.area = new XFAObjectArray(); + this.draw = new XFAObjectArray(); + this.exObject = new XFAObjectArray(); + this.exclGroup = new XFAObjectArray(); + this.field = new XFAObjectArray(); + this.subform = new XFAObjectArray(); + this.subformSet = new XFAObjectArray(); + } + *[ks]() { + yield* getContainedChildren(this); + } + [Us]() { + return !0; + } + [Rs]() { + return !0; + } + [Zn](e, t) { + const [a, r, i, n] = t; + this[ls].width = Math.max(this[ls].width, a + i); + this[ls].height = Math.max(this[ls].height, r + n); + this[ls].children.push(e); + } + [gs]() { + return this[ls].availableSpace; + } + [co](e) { + const t = toStyle(this, "position"), + a = { style: t, id: this[uo], class: ["xfaArea"] }; + isPrintOnly(this) && a.class.push("xfaPrintOnly"); + this.name && (a.xfaName = this.name); + const r = []; + this[ls] = { children: r, width: 0, height: 0, availableSpace: e }; + const i = this[es]({ + filter: new Set([ + "area", + "draw", + "field", + "exclGroup", + "subform", + "subformSet", + ]), + include: !0, + }); + if (!i.success) { + if (i.isBreak()) return i; + delete this[ls]; + return HTMLResult.FAILURE; + } + t.width = measureToString(this[ls].width); + t.height = measureToString(this[ls].height); + const n = { name: "div", attributes: a, children: r }, + s = [this.x, this.y, this[ls].width, this[ls].height]; + delete this[ls]; + return HTMLResult.success(n, s); + } +} +class Assist extends XFAObject { + constructor(e) { + super(Go, "assist", !0); + this.id = e.id || ""; + this.role = e.role || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.speak = null; + this.toolTip = null; + } + [co]() { + return this.toolTip?.[ss] || null; + } +} +class Barcode extends XFAObject { + constructor(e) { + super(Go, "barcode", !0); + this.charEncoding = getKeyword({ + data: e.charEncoding ? e.charEncoding.toLowerCase() : "", + defaultValue: "", + validate: (e) => + [ + "utf-8", + "big-five", + "fontspecific", + "gbk", + "gb-18030", + "gb-2312", + "ksc-5601", + "none", + "shift-jis", + "ucs-2", + "utf-16", + ].includes(e) || e.match(/iso-8859-\d{2}/), + }); + this.checksum = getStringOption(e.checksum, [ + "none", + "1mod10", + "1mod10_1mod11", + "2mod10", + "auto", + ]); + this.dataColumnCount = getInteger({ + data: e.dataColumnCount, + defaultValue: -1, + validate: (e) => e >= 0, + }); + this.dataLength = getInteger({ + data: e.dataLength, + defaultValue: -1, + validate: (e) => e >= 0, + }); + this.dataPrep = getStringOption(e.dataPrep, ["none", "flateCompress"]); + this.dataRowCount = getInteger({ + data: e.dataRowCount, + defaultValue: -1, + validate: (e) => e >= 0, + }); + this.endChar = e.endChar || ""; + this.errorCorrectionLevel = getInteger({ + data: e.errorCorrectionLevel, + defaultValue: -1, + validate: (e) => e >= 0 && e <= 8, + }); + this.id = e.id || ""; + this.moduleHeight = getMeasurement(e.moduleHeight, "5mm"); + this.moduleWidth = getMeasurement(e.moduleWidth, "0.25mm"); + this.printCheckDigit = getInteger({ + data: e.printCheckDigit, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.rowColumnRatio = getRatio(e.rowColumnRatio); + this.startChar = e.startChar || ""; + this.textLocation = getStringOption(e.textLocation, [ + "below", + "above", + "aboveEmbedded", + "belowEmbedded", + "none", + ]); + this.truncate = getInteger({ + data: e.truncate, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.type = getStringOption(e.type ? e.type.toLowerCase() : "", [ + "aztec", + "codabar", + "code2of5industrial", + "code2of5interleaved", + "code2of5matrix", + "code2of5standard", + "code3of9", + "code3of9extended", + "code11", + "code49", + "code93", + "code128", + "code128a", + "code128b", + "code128c", + "code128sscc", + "datamatrix", + "ean8", + "ean8add2", + "ean8add5", + "ean13", + "ean13add2", + "ean13add5", + "ean13pwcd", + "fim", + "logmars", + "maxicode", + "msi", + "pdf417", + "pdf417macro", + "plessey", + "postauscust2", + "postauscust3", + "postausreplypaid", + "postausstandard", + "postukrm4scc", + "postusdpbc", + "postusimb", + "postusstandard", + "postus5zip", + "qrcode", + "rfid", + "rss14", + "rss14expanded", + "rss14limited", + "rss14stacked", + "rss14stackedomni", + "rss14truncated", + "telepen", + "ucc128", + "ucc128random", + "ucc128sscc", + "upca", + "upcaadd2", + "upcaadd5", + "upcapwcd", + "upce", + "upceadd2", + "upceadd5", + "upcean2", + "upcean5", + "upsmaxicode", + ]); + this.upsMode = getStringOption(e.upsMode, [ + "usCarrier", + "internationalCarrier", + "secureSymbol", + "standardSymbol", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.wideNarrowRatio = getRatio(e.wideNarrowRatio); + this.encrypt = null; + this.extras = null; + } +} +class Bind extends XFAObject { + constructor(e) { + super(Go, "bind", !0); + this.match = getStringOption(e.match, [ + "once", + "dataRef", + "global", + "none", + ]); + this.ref = e.ref || ""; + this.picture = null; + } +} +class BindItems extends XFAObject { + constructor(e) { + super(Go, "bindItems"); + this.connection = e.connection || ""; + this.labelRef = e.labelRef || ""; + this.ref = e.ref || ""; + this.valueRef = e.valueRef || ""; + } +} +class Bookend extends XFAObject { + constructor(e) { + super(Go, "bookend"); + this.id = e.id || ""; + this.leader = e.leader || ""; + this.trailer = e.trailer || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class BooleanElement extends Option01 { + constructor(e) { + super(Go, "boolean"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [co](e) { + return valueToHtml(1 === this[ss] ? "1" : "0"); + } +} +class Border extends XFAObject { + constructor(e) { + super(Go, "border", !0); + this.break = getStringOption(e.break, ["close", "open"]); + this.hand = getStringOption(e.hand, ["even", "left", "right"]); + this.id = e.id || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.corner = new XFAObjectArray(4); + this.edge = new XFAObjectArray(4); + this.extras = null; + this.fill = null; + this.margin = null; + } + [ws]() { + if (!this[ls]) { + const e = this.edge.children.slice(); + if (e.length < 4) { + const t = e.at(-1) || new Edge({}); + for (let a = e.length; a < 4; a++) e.push(t); + } + const t = e.map((e) => e.thickness), + a = [0, 0, 0, 0]; + if (this.margin) { + a[0] = this.margin.topInset; + a[1] = this.margin.rightInset; + a[2] = this.margin.bottomInset; + a[3] = this.margin.leftInset; + } + this[ls] = { widths: t, insets: a, edges: e }; + } + return this[ls]; + } + [ho]() { + const { edges: e } = this[ws](), + t = e.map((e) => { + const t = e[ho](); + t.color ||= "#000000"; + return t; + }), + a = Object.create(null); + this.margin && Object.assign(a, this.margin[ho]()); + "visible" === this.fill?.presence && Object.assign(a, this.fill[ho]()); + if (this.corner.children.some((e) => 0 !== e.radius)) { + const e = this.corner.children.map((e) => e[ho]()); + if (2 === e.length || 3 === e.length) { + const t = e.at(-1); + for (let a = e.length; a < 4; a++) e.push(t); + } + a.borderRadius = e.map((e) => e.radius).join(" "); + } + switch (this.presence) { + case "invisible": + case "hidden": + a.borderStyle = ""; + break; + case "inactive": + a.borderStyle = "none"; + break; + default: + a.borderStyle = t.map((e) => e.style).join(" "); + } + a.borderWidth = t.map((e) => e.width).join(" "); + a.borderColor = t.map((e) => e.color).join(" "); + return a; + } +} +class Break extends XFAObject { + constructor(e) { + super(Go, "break", !0); + this.after = getStringOption(e.after, [ + "auto", + "contentArea", + "pageArea", + "pageEven", + "pageOdd", + ]); + this.afterTarget = e.afterTarget || ""; + this.before = getStringOption(e.before, [ + "auto", + "contentArea", + "pageArea", + "pageEven", + "pageOdd", + ]); + this.beforeTarget = e.beforeTarget || ""; + this.bookendLeader = e.bookendLeader || ""; + this.bookendTrailer = e.bookendTrailer || ""; + this.id = e.id || ""; + this.overflowLeader = e.overflowLeader || ""; + this.overflowTarget = e.overflowTarget || ""; + this.overflowTrailer = e.overflowTrailer || ""; + this.startNew = getInteger({ + data: e.startNew, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } +} +class BreakAfter extends XFAObject { + constructor(e) { + super(Go, "breakAfter", !0); + this.id = e.id || ""; + this.leader = e.leader || ""; + this.startNew = getInteger({ + data: e.startNew, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.target = e.target || ""; + this.targetType = getStringOption(e.targetType, [ + "auto", + "contentArea", + "pageArea", + ]); + this.trailer = e.trailer || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.script = null; + } +} +class BreakBefore extends XFAObject { + constructor(e) { + super(Go, "breakBefore", !0); + this.id = e.id || ""; + this.leader = e.leader || ""; + this.startNew = getInteger({ + data: e.startNew, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.target = e.target || ""; + this.targetType = getStringOption(e.targetType, [ + "auto", + "contentArea", + "pageArea", + ]); + this.trailer = e.trailer || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.script = null; + } + [co](e) { + this[ls] = {}; + return HTMLResult.FAILURE; + } +} +class Button extends XFAObject { + constructor(e) { + super(Go, "button", !0); + this.highlight = getStringOption(e.highlight, [ + "inverted", + "none", + "outline", + "push", + ]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } + [co](e) { + const t = this[vs]()[vs](), + a = { + name: "button", + attributes: { id: this[uo], class: ["xfaButton"], style: {} }, + children: [], + }; + for (const e of t.event.children) { + if ("click" !== e.activity || !e.script) continue; + const t = recoverJsURL(e.script[ss]); + if (!t) continue; + const r = fixURL(t.url); + r && + a.children.push({ + name: "a", + attributes: { + id: "link" + this[uo], + href: r, + newWindow: t.newWindow, + class: ["xfaLink"], + style: {}, + }, + children: [], + }); + } + return HTMLResult.success(a); + } +} +class Calculate extends XFAObject { + constructor(e) { + super(Go, "calculate", !0); + this.id = e.id || ""; + this.override = getStringOption(e.override, [ + "disabled", + "error", + "ignore", + "warning", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.message = null; + this.script = null; + } +} +class Caption extends XFAObject { + constructor(e) { + super(Go, "caption", !0); + this.id = e.id || ""; + this.placement = getStringOption(e.placement, [ + "left", + "bottom", + "inline", + "right", + "top", + ]); + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.reserve = Math.ceil(getMeasurement(e.reserve)); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.font = null; + this.margin = null; + this.para = null; + this.value = null; + } + [io](e) { + _setValue(this, e); + } + [ws](e) { + if (!this[ls]) { + let { width: t, height: a } = e; + switch (this.placement) { + case "left": + case "right": + case "inline": + t = this.reserve <= 0 ? t : this.reserve; + break; + case "top": + case "bottom": + a = this.reserve <= 0 ? a : this.reserve; + } + this[ls] = layoutNode(this, { width: t, height: a }); + } + return this[ls]; + } + [co](e) { + if (!this.value) return HTMLResult.EMPTY; + this[Ys](); + const t = this.value[co](e).html; + if (!t) { + this[Js](); + return HTMLResult.EMPTY; + } + const a = this.reserve; + if (this.reserve <= 0) { + const { w: t, h: a } = this[ws](e); + switch (this.placement) { + case "left": + case "right": + case "inline": + this.reserve = t; + break; + case "top": + case "bottom": + this.reserve = a; + } + } + const r = []; + "string" == typeof t ? r.push({ name: "#text", value: t }) : r.push(t); + const i = toStyle(this, "font", "margin", "visibility"); + switch (this.placement) { + case "left": + case "right": + this.reserve > 0 && (i.width = measureToString(this.reserve)); + break; + case "top": + case "bottom": + this.reserve > 0 && (i.height = measureToString(this.reserve)); + } + setPara(this, null, t); + this[Js](); + this.reserve = a; + return HTMLResult.success({ + name: "div", + attributes: { style: i, class: ["xfaCaption"] }, + children: r, + }); + } +} +class Certificate extends StringObject { + constructor(e) { + super(Go, "certificate"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Certificates extends XFAObject { + constructor(e) { + super(Go, "certificates", !0); + this.credentialServerPolicy = getStringOption(e.credentialServerPolicy, [ + "optional", + "required", + ]); + this.id = e.id || ""; + this.url = e.url || ""; + this.urlPolicy = e.urlPolicy || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.encryption = null; + this.issuers = null; + this.keyUsage = null; + this.oids = null; + this.signing = null; + this.subjectDNs = null; + } +} +class CheckButton extends XFAObject { + constructor(e) { + super(Go, "checkButton", !0); + this.id = e.id || ""; + this.mark = getStringOption(e.mark, [ + "default", + "check", + "circle", + "cross", + "diamond", + "square", + "star", + ]); + this.shape = getStringOption(e.shape, ["square", "round"]); + this.size = getMeasurement(e.size, "10pt"); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.extras = null; + this.margin = null; + } + [co](e) { + const t = toStyle(this, "margin"), + a = measureToString(this.size); + t.width = t.height = a; + let r, i, n; + const s = this[vs]()[vs](), + o = (s.items.children.length && s.items.children[0][co]().html) || [], + c = { + on: (void 0 !== o[0] ? o[0] : "on").toString(), + off: (void 0 !== o[1] ? o[1] : "off").toString(), + }, + l = (s.value?.[so]() || "off") === c.on || void 0, + h = s[Cs](), + u = s[uo]; + let d; + if (h instanceof ExclGroup) { + n = h[uo]; + r = "radio"; + i = "xfaRadio"; + d = h[os]?.[uo] || h[uo]; + } else { + r = "checkbox"; + i = "xfaCheckbox"; + d = s[os]?.[uo] || s[uo]; + } + const f = { + name: "input", + attributes: { + class: [i], + style: t, + fieldId: u, + dataId: d, + type: r, + checked: l, + xfaOn: c.on, + xfaOff: c.off, + "aria-label": ariaLabel(s), + "aria-required": !1, + }, + }; + n && (f.attributes.name = n); + if (isRequired(s)) { + f.attributes["aria-required"] = !0; + f.attributes.required = !0; + } + return HTMLResult.success({ + name: "label", + attributes: { class: ["xfaLabel"] }, + children: [f], + }); + } +} +class ChoiceList extends XFAObject { + constructor(e) { + super(Go, "choiceList", !0); + this.commitOn = getStringOption(e.commitOn, ["select", "exit"]); + this.id = e.id || ""; + this.open = getStringOption(e.open, [ + "userControl", + "always", + "multiSelect", + "onEntry", + ]); + this.textEntry = getInteger({ + data: e.textEntry, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.extras = null; + this.margin = null; + } + [co](e) { + const t = toStyle(this, "border", "margin"), + a = this[vs]()[vs](), + r = { + fontSize: `calc(${a.font?.size || 10}px * var(--total-scale-factor))`, + }, + i = []; + if (a.items.children.length > 0) { + const e = a.items; + let t = 0, + n = 0; + if (2 === e.children.length) { + t = e.children[0].save; + n = 1 - t; + } + const s = e.children[t][co]().html, + o = e.children[n][co]().html; + let c = !1; + const l = a.value?.[so]() || ""; + for (let e = 0, t = s.length; e < t; e++) { + const t = { + name: "option", + attributes: { value: o[e] || s[e], style: r }, + value: s[e], + }; + o[e] === l && (t.attributes.selected = c = !0); + i.push(t); + } + c || + i.splice(0, 0, { + name: "option", + attributes: { hidden: !0, selected: !0 }, + value: " ", + }); + } + const n = { + class: ["xfaSelect"], + fieldId: a[uo], + dataId: a[os]?.[uo] || a[uo], + style: t, + "aria-label": ariaLabel(a), + "aria-required": !1, + }; + if (isRequired(a)) { + n["aria-required"] = !0; + n.required = !0; + } + "multiSelect" === this.open && (n.multiple = !0); + return HTMLResult.success({ + name: "label", + attributes: { class: ["xfaLabel"] }, + children: [{ name: "select", children: i, attributes: n }], + }); + } +} +class Color extends XFAObject { + constructor(e) { + super(Go, "color", !0); + this.cSpace = getStringOption(e.cSpace, ["SRGB"]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.value = e.value + ? (function getColor(e, t = [0, 0, 0]) { + let [a, r, i] = t; + if (!e) return { r: a, g: r, b: i }; + const n = e + .split(",", 3) + .map((e) => MathClamp(parseInt(e.trim(), 10), 0, 255)) + .map((e) => (isNaN(e) ? 0 : e)); + if (n.length < 3) return { r: a, g: r, b: i }; + [a, r, i] = n; + return { r: a, g: r, b: i }; + })(e.value) + : ""; + this.extras = null; + } + [Ts]() { + return !1; + } + [ho]() { + return this.value + ? Util.makeHexColor(this.value.r, this.value.g, this.value.b) + : null; + } +} +class Comb extends XFAObject { + constructor(e) { + super(Go, "comb"); + this.id = e.id || ""; + this.numberOfCells = getInteger({ + data: e.numberOfCells, + defaultValue: 0, + validate: (e) => e >= 0, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Connect extends XFAObject { + constructor(e) { + super(Go, "connect", !0); + this.connection = e.connection || ""; + this.id = e.id || ""; + this.ref = e.ref || ""; + this.usage = getStringOption(e.usage, [ + "exportAndImport", + "exportOnly", + "importOnly", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.picture = null; + } +} +class ContentArea extends XFAObject { + constructor(e) { + super(Go, "contentArea", !0); + this.h = getMeasurement(e.h); + this.id = e.id || ""; + this.name = e.name || ""; + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.w = getMeasurement(e.w); + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.desc = null; + this.extras = null; + } + [co](e) { + const t = { + left: measureToString(this.x), + top: measureToString(this.y), + width: measureToString(this.w), + height: measureToString(this.h), + }, + a = ["xfaContentarea"]; + isPrintOnly(this) && a.push("xfaPrintOnly"); + return HTMLResult.success({ + name: "div", + children: [], + attributes: { style: t, class: a, id: this[uo] }, + }); + } +} +class Corner extends XFAObject { + constructor(e) { + super(Go, "corner", !0); + this.id = e.id || ""; + this.inverted = getInteger({ + data: e.inverted, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.join = getStringOption(e.join, ["square", "round"]); + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.radius = getMeasurement(e.radius); + this.stroke = getStringOption(e.stroke, [ + "solid", + "dashDot", + "dashDotDot", + "dashed", + "dotted", + "embossed", + "etched", + "lowered", + "raised", + ]); + this.thickness = getMeasurement(e.thickness, "0.5pt"); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho]() { + const e = toStyle(this, "visibility"); + e.radius = measureToString("square" === this.join ? 0 : this.radius); + return e; + } +} +class DateElement extends ContentObject { + constructor(e) { + super(Go, "date"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = this[ss].trim(); + this[ss] = e ? new Date(e) : null; + } + [co](e) { + return valueToHtml(this[ss] ? this[ss].toString() : ""); + } +} +class DateTime extends ContentObject { + constructor(e) { + super(Go, "dateTime"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = this[ss].trim(); + this[ss] = e ? new Date(e) : null; + } + [co](e) { + return valueToHtml(this[ss] ? this[ss].toString() : ""); + } +} +class DateTimeEdit extends XFAObject { + constructor(e) { + super(Go, "dateTimeEdit", !0); + this.hScrollPolicy = getStringOption(e.hScrollPolicy, [ + "auto", + "off", + "on", + ]); + this.id = e.id || ""; + this.picker = getStringOption(e.picker, ["host", "none"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.comb = null; + this.extras = null; + this.margin = null; + } + [co](e) { + const t = toStyle(this, "border", "font", "margin"), + a = this[vs]()[vs](), + r = { + name: "input", + attributes: { + type: "text", + fieldId: a[uo], + dataId: a[os]?.[uo] || a[uo], + class: ["xfaTextfield"], + style: t, + "aria-label": ariaLabel(a), + "aria-required": !1, + }, + }; + if (isRequired(a)) { + r.attributes["aria-required"] = !0; + r.attributes.required = !0; + } + return HTMLResult.success({ + name: "label", + attributes: { class: ["xfaLabel"] }, + children: [r], + }); + } +} +class Decimal extends ContentObject { + constructor(e) { + super(Go, "decimal"); + this.fracDigits = getInteger({ + data: e.fracDigits, + defaultValue: 2, + validate: (e) => !0, + }); + this.id = e.id || ""; + this.leadDigits = getInteger({ + data: e.leadDigits, + defaultValue: -1, + validate: (e) => !0, + }); + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = parseFloat(this[ss].trim()); + this[ss] = isNaN(e) ? null : e; + } + [co](e) { + return valueToHtml(null !== this[ss] ? this[ss].toString() : ""); + } +} +class DefaultUi extends XFAObject { + constructor(e) { + super(Go, "defaultUi", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } +} +class Desc extends XFAObject { + constructor(e) { + super(Go, "desc", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.boolean = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.time = new XFAObjectArray(); + } +} +class DigestMethod extends OptionObject { + constructor(e) { + super(Go, "digestMethod", ["", "SHA1", "SHA256", "SHA512", "RIPEMD160"]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class DigestMethods extends XFAObject { + constructor(e) { + super(Go, "digestMethods", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.digestMethod = new XFAObjectArray(); + } +} +class Draw extends XFAObject { + constructor(e) { + super(Go, "draw", !0); + this.anchorType = getStringOption(e.anchorType, [ + "topLeft", + "bottomCenter", + "bottomLeft", + "bottomRight", + "middleCenter", + "middleLeft", + "middleRight", + "topCenter", + "topRight", + ]); + this.colSpan = getInteger({ + data: e.colSpan, + defaultValue: 1, + validate: (e) => e >= 1 || -1 === e, + }); + this.h = e.h ? getMeasurement(e.h) : ""; + this.hAlign = getStringOption(e.hAlign, [ + "left", + "center", + "justify", + "justifyAll", + "radix", + "right", + ]); + this.id = e.id || ""; + this.locale = e.locale || ""; + this.maxH = getMeasurement(e.maxH, "0pt"); + this.maxW = getMeasurement(e.maxW, "0pt"); + this.minH = getMeasurement(e.minH, "0pt"); + this.minW = getMeasurement(e.minW, "0pt"); + this.name = e.name || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.relevant = getRelevant(e.relevant); + this.rotate = getInteger({ + data: e.rotate, + defaultValue: 0, + validate: (e) => e % 90 == 0, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.w = e.w ? getMeasurement(e.w) : ""; + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.assist = null; + this.border = null; + this.caption = null; + this.desc = null; + this.extras = null; + this.font = null; + this.keep = null; + this.margin = null; + this.para = null; + this.traversal = null; + this.ui = null; + this.value = null; + this.setProperty = new XFAObjectArray(); + } + [io](e) { + _setValue(this, e); + } + [co](e) { + setTabIndex(this); + if ("hidden" === this.presence || "inactive" === this.presence) + return HTMLResult.EMPTY; + fixDimensions(this); + this[Ys](); + const t = this.w, + a = this.h, + { w: r, h: i, isBroken: n } = layoutNode(this, e); + if (r && "" === this.w) { + if (n && this[Cs]()[_s]()) { + this[Js](); + return HTMLResult.FAILURE; + } + this.w = r; + } + i && "" === this.h && (this.h = i); + setFirstUnsplittable(this); + if (!checkDimensions(this, e)) { + this.w = t; + this.h = a; + this[Js](); + return HTMLResult.FAILURE; + } + unsetFirstUnsplittable(this); + const s = toStyle( + this, + "font", + "hAlign", + "dimensions", + "position", + "presence", + "rotate", + "anchorType", + "border", + "margin", + ); + setMinMaxDimensions(this, s); + if (s.margin) { + s.padding = s.margin; + delete s.margin; + } + const o = ["xfaDraw"]; + this.font && o.push("xfaFont"); + isPrintOnly(this) && o.push("xfaPrintOnly"); + const c = { style: s, id: this[uo], class: o }; + this.name && (c.xfaName = this.name); + const l = { name: "div", attributes: c, children: [] }; + applyAssist(this, c); + const h = computeBbox(this, l, e), + u = this.value ? this.value[co](e).html : null; + if (null === u) { + this.w = t; + this.h = a; + this[Js](); + return HTMLResult.success(createWrapper(this, l), h); + } + l.children.push(u); + setPara(this, s, u); + this.w = t; + this.h = a; + this[Js](); + return HTMLResult.success(createWrapper(this, l), h); + } +} +class Edge extends XFAObject { + constructor(e) { + super(Go, "edge", !0); + this.cap = getStringOption(e.cap, ["square", "butt", "round"]); + this.id = e.id || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.stroke = getStringOption(e.stroke, [ + "solid", + "dashDot", + "dashDotDot", + "dashed", + "dotted", + "embossed", + "etched", + "lowered", + "raised", + ]); + this.thickness = getMeasurement(e.thickness, "0.5pt"); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho]() { + const e = toStyle(this, "visibility"); + Object.assign(e, { + linecap: this.cap, + width: measureToString(this.thickness), + color: this.color ? this.color[ho]() : "#000000", + style: "", + }); + if ("visible" !== this.presence) e.style = "none"; + else + switch (this.stroke) { + case "solid": + e.style = "solid"; + break; + case "dashDot": + case "dashDotDot": + case "dashed": + e.style = "dashed"; + break; + case "dotted": + e.style = "dotted"; + break; + case "embossed": + e.style = "ridge"; + break; + case "etched": + e.style = "groove"; + break; + case "lowered": + e.style = "inset"; + break; + case "raised": + e.style = "outset"; + } + return e; + } +} +class Encoding extends OptionObject { + constructor(e) { + super(Go, "encoding", [ + "adbe.x509.rsa_sha1", + "adbe.pkcs7.detached", + "adbe.pkcs7.sha1", + ]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Encodings extends XFAObject { + constructor(e) { + super(Go, "encodings", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.encoding = new XFAObjectArray(); + } +} +class Encrypt extends XFAObject { + constructor(e) { + super(Go, "encrypt", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.certificate = null; + } +} +class EncryptData extends XFAObject { + constructor(e) { + super(Go, "encryptData", !0); + this.id = e.id || ""; + this.operation = getStringOption(e.operation, ["encrypt", "decrypt"]); + this.target = e.target || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.filter = null; + this.manifest = null; + } +} +class Encryption extends XFAObject { + constructor(e) { + super(Go, "encryption", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.certificate = new XFAObjectArray(); + } +} +class EncryptionMethod extends OptionObject { + constructor(e) { + super(Go, "encryptionMethod", [ + "", + "AES256-CBC", + "TRIPLEDES-CBC", + "AES128-CBC", + "AES192-CBC", + ]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class EncryptionMethods extends XFAObject { + constructor(e) { + super(Go, "encryptionMethods", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.encryptionMethod = new XFAObjectArray(); + } +} +class Event extends XFAObject { + constructor(e) { + super(Go, "event", !0); + this.activity = getStringOption(e.activity, [ + "click", + "change", + "docClose", + "docReady", + "enter", + "exit", + "full", + "indexChange", + "initialize", + "mouseDown", + "mouseEnter", + "mouseExit", + "mouseUp", + "postExecute", + "postOpen", + "postPrint", + "postSave", + "postSign", + "postSubmit", + "preExecute", + "preOpen", + "prePrint", + "preSave", + "preSign", + "preSubmit", + "ready", + "validationState", + ]); + this.id = e.id || ""; + this.listen = getStringOption(e.listen, ["refOnly", "refAndDescendents"]); + this.name = e.name || ""; + this.ref = e.ref || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.encryptData = null; + this.execute = null; + this.script = null; + this.signData = null; + this.submit = null; + } +} +class ExData extends ContentObject { + constructor(e) { + super(Go, "exData"); + this.contentType = e.contentType || ""; + this.href = e.href || ""; + this.id = e.id || ""; + this.maxLength = getInteger({ + data: e.maxLength, + defaultValue: -1, + validate: (e) => e >= -1, + }); + this.name = e.name || ""; + this.rid = e.rid || ""; + this.transferEncoding = getStringOption(e.transferEncoding, [ + "none", + "base64", + "package", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [Bs]() { + return "text/html" === this.contentType; + } + [$s](e) { + if ("text/html" === this.contentType && e[Hs] === go.xhtml.id) { + this[ss] = e; + return !0; + } + if ("text/xml" === this.contentType) { + this[ss] = e; + return !0; + } + return !1; + } + [co](e) { + return "text/html" === this.contentType && this[ss] + ? this[ss][co](e) + : HTMLResult.EMPTY; + } +} +class ExObject extends XFAObject { + constructor(e) { + super(Go, "exObject", !0); + this.archive = e.archive || ""; + this.classId = e.classId || ""; + this.codeBase = e.codeBase || ""; + this.codeType = e.codeType || ""; + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.boolean = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.exObject = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.time = new XFAObjectArray(); + } +} +class ExclGroup extends XFAObject { + constructor(e) { + super(Go, "exclGroup", !0); + this.access = getStringOption(e.access, [ + "open", + "nonInteractive", + "protected", + "readOnly", + ]); + this.accessKey = e.accessKey || ""; + this.anchorType = getStringOption(e.anchorType, [ + "topLeft", + "bottomCenter", + "bottomLeft", + "bottomRight", + "middleCenter", + "middleLeft", + "middleRight", + "topCenter", + "topRight", + ]); + this.colSpan = getInteger({ + data: e.colSpan, + defaultValue: 1, + validate: (e) => e >= 1 || -1 === e, + }); + this.h = e.h ? getMeasurement(e.h) : ""; + this.hAlign = getStringOption(e.hAlign, [ + "left", + "center", + "justify", + "justifyAll", + "radix", + "right", + ]); + this.id = e.id || ""; + this.layout = getStringOption(e.layout, [ + "position", + "lr-tb", + "rl-row", + "rl-tb", + "row", + "table", + "tb", + ]); + this.maxH = getMeasurement(e.maxH, "0pt"); + this.maxW = getMeasurement(e.maxW, "0pt"); + this.minH = getMeasurement(e.minH, "0pt"); + this.minW = getMeasurement(e.minW, "0pt"); + this.name = e.name || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.w = e.w ? getMeasurement(e.w) : ""; + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.assist = null; + this.bind = null; + this.border = null; + this.calculate = null; + this.caption = null; + this.desc = null; + this.extras = null; + this.margin = null; + this.para = null; + this.traversal = null; + this.validate = null; + this.connect = new XFAObjectArray(); + this.event = new XFAObjectArray(); + this.field = new XFAObjectArray(); + this.setProperty = new XFAObjectArray(); + } + [Rs]() { + return !0; + } + [Ts]() { + return !0; + } + [io](e) { + for (const t of this.field.children) { + if (!t.value) { + const e = new Value({}); + t[Qn](e); + t.value = e; + } + t.value[io](e); + } + } + [_s]() { + return ( + (this.layout.endsWith("-tb") && + 0 === this[ls].attempt && + this[ls].numberInLine > 0) || + this[vs]()[_s]() + ); + } + [js]() { + const e = this[Cs](); + if (!e[js]()) return !1; + if (void 0 !== this[ls]._isSplittable) return this[ls]._isSplittable; + if ("position" === this.layout || this.layout.includes("row")) { + this[ls]._isSplittable = !1; + return !1; + } + if (e.layout?.endsWith("-tb") && 0 !== e[ls].numberInLine) return !1; + this[ls]._isSplittable = !0; + return !0; + } + [us]() { + return flushHTML(this); + } + [Zn](e, t) { + addHTML(this, e, t); + } + [gs]() { + return getAvailableSpace(this); + } + [co](e) { + setTabIndex(this); + if ( + "hidden" === this.presence || + "inactive" === this.presence || + 0 === this.h || + 0 === this.w + ) + return HTMLResult.EMPTY; + fixDimensions(this); + const t = [], + a = { id: this[uo], class: [] }; + setAccess(this, a.class); + this[ls] ||= Object.create(null); + Object.assign(this[ls], { + children: t, + attributes: a, + attempt: 0, + line: null, + numberInLine: 0, + availableSpace: { + width: Math.min(this.w || 1 / 0, e.width), + height: Math.min(this.h || 1 / 0, e.height), + }, + width: 0, + height: 0, + prevHeight: 0, + currentWidth: 0, + }); + const r = this[js](); + r || setFirstUnsplittable(this); + if (!checkDimensions(this, e)) return HTMLResult.FAILURE; + const i = new Set(["field"]); + if (this.layout.includes("row")) { + const e = this[Cs]().columnWidths; + if (Array.isArray(e) && e.length > 0) { + this[ls].columnWidths = e; + this[ls].currentColumn = 0; + } + } + const n = toStyle( + this, + "anchorType", + "dimensions", + "position", + "presence", + "border", + "margin", + "hAlign", + ), + s = ["xfaExclgroup"], + o = layoutClass(this); + o && s.push(o); + isPrintOnly(this) && s.push("xfaPrintOnly"); + a.style = n; + a.class = s; + this.name && (a.xfaName = this.name); + this[Ys](); + const c = "lr-tb" === this.layout || "rl-tb" === this.layout, + l = c ? 2 : 1; + for (; this[ls].attempt < l; this[ls].attempt++) { + c && 1 === this[ls].attempt && (this[ls].numberInLine = 0); + const e = this[es]({ filter: i, include: !0 }); + if (e.success) break; + if (e.isBreak()) { + this[Js](); + return e; + } + if ( + c && + 0 === this[ls].attempt && + 0 === this[ls].numberInLine && + !this[Fs]()[ls].noLayoutFailure + ) { + this[ls].attempt = l; + break; + } + } + this[Js](); + r || unsetFirstUnsplittable(this); + if (this[ls].attempt === l) { + r || delete this[ls]; + return HTMLResult.FAILURE; + } + let h = 0, + u = 0; + if (this.margin) { + h = this.margin.leftInset + this.margin.rightInset; + u = this.margin.topInset + this.margin.bottomInset; + } + const d = Math.max(this[ls].width + h, this.w || 0), + f = Math.max(this[ls].height + u, this.h || 0), + g = [this.x, this.y, d, f]; + "" === this.w && (n.width = measureToString(d)); + "" === this.h && (n.height = measureToString(f)); + const p = { name: "div", attributes: a, children: t }; + applyAssist(this, a); + delete this[ls]; + return HTMLResult.success(createWrapper(this, p), g); + } +} +class Execute extends XFAObject { + constructor(e) { + super(Go, "execute"); + this.connection = e.connection || ""; + this.executeType = getStringOption(e.executeType, ["import", "remerge"]); + this.id = e.id || ""; + this.runAt = getStringOption(e.runAt, ["client", "both", "server"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Extras extends XFAObject { + constructor(e) { + super(Go, "extras", !0); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.boolean = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.extras = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.time = new XFAObjectArray(); + } +} +class Field extends XFAObject { + constructor(e) { + super(Go, "field", !0); + this.access = getStringOption(e.access, [ + "open", + "nonInteractive", + "protected", + "readOnly", + ]); + this.accessKey = e.accessKey || ""; + this.anchorType = getStringOption(e.anchorType, [ + "topLeft", + "bottomCenter", + "bottomLeft", + "bottomRight", + "middleCenter", + "middleLeft", + "middleRight", + "topCenter", + "topRight", + ]); + this.colSpan = getInteger({ + data: e.colSpan, + defaultValue: 1, + validate: (e) => e >= 1 || -1 === e, + }); + this.h = e.h ? getMeasurement(e.h) : ""; + this.hAlign = getStringOption(e.hAlign, [ + "left", + "center", + "justify", + "justifyAll", + "radix", + "right", + ]); + this.id = e.id || ""; + this.locale = e.locale || ""; + this.maxH = getMeasurement(e.maxH, "0pt"); + this.maxW = getMeasurement(e.maxW, "0pt"); + this.minH = getMeasurement(e.minH, "0pt"); + this.minW = getMeasurement(e.minW, "0pt"); + this.name = e.name || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.relevant = getRelevant(e.relevant); + this.rotate = getInteger({ + data: e.rotate, + defaultValue: 0, + validate: (e) => e % 90 == 0, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.w = e.w ? getMeasurement(e.w) : ""; + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.assist = null; + this.bind = null; + this.border = null; + this.calculate = null; + this.caption = null; + this.desc = null; + this.extras = null; + this.font = null; + this.format = null; + this.items = new XFAObjectArray(2); + this.keep = null; + this.margin = null; + this.para = null; + this.traversal = null; + this.ui = null; + this.validate = null; + this.value = null; + this.bindItems = new XFAObjectArray(); + this.connect = new XFAObjectArray(); + this.event = new XFAObjectArray(); + this.setProperty = new XFAObjectArray(); + } + [Rs]() { + return !0; + } + [io](e) { + _setValue(this, e); + } + [co](e) { + setTabIndex(this); + if (!this.ui) { + this.ui = new Ui({}); + this.ui[Is] = this[Is]; + this[Qn](this.ui); + let e; + switch (this.items.children.length) { + case 0: + e = new TextEdit({}); + this.ui.textEdit = e; + break; + case 1: + e = new CheckButton({}); + this.ui.checkButton = e; + break; + case 2: + e = new ChoiceList({}); + this.ui.choiceList = e; + } + this.ui[Qn](e); + } + if ( + !this.ui || + "hidden" === this.presence || + "inactive" === this.presence || + 0 === this.h || + 0 === this.w + ) + return HTMLResult.EMPTY; + this.caption && delete this.caption[ls]; + this[Ys](); + const t = this.caption ? this.caption[co](e).html : null, + a = this.w, + r = this.h; + let i = 0, + n = 0; + if (this.margin) { + i = this.margin.leftInset + this.margin.rightInset; + n = this.margin.topInset + this.margin.bottomInset; + } + let s = null; + if ("" === this.w || "" === this.h) { + let t = null, + a = null, + r = 0, + o = 0; + if (this.ui.checkButton) r = o = this.ui.checkButton.size; + else { + const { w: t, h: a } = layoutNode(this, e); + if (null !== t) { + r = t; + o = a; + } else + o = (function fonts_getMetrics(e, t = !1) { + let a = null; + if (e) { + const t = stripQuotes(e.typeface), + r = e[Is].fontFinder.find(t); + a = selectFont(e, r); + } + if (!a) return { lineHeight: 12, lineGap: 2, lineNoGap: 10 }; + const r = e.size || 10, + i = a.lineHeight ? Math.max(t ? 0 : 1.2, a.lineHeight) : 1.2, + n = void 0 === a.lineGap ? 0.2 : a.lineGap; + return { + lineHeight: i * r, + lineGap: n * r, + lineNoGap: Math.max(1, i - n) * r, + }; + })(this.font, !0).lineNoGap; + } + s = getBorderDims(this.ui[ws]()); + r += s.w; + o += s.h; + if (this.caption) { + const { w: i, h: n, isBroken: s } = this.caption[ws](e); + if (s && this[Cs]()[_s]()) { + this[Js](); + return HTMLResult.FAILURE; + } + t = i; + a = n; + switch (this.caption.placement) { + case "left": + case "right": + case "inline": + t += r; + break; + case "top": + case "bottom": + a += o; + } + } else { + t = r; + a = o; + } + if (t && "" === this.w) { + t += i; + this.w = Math.min( + this.maxW <= 0 ? 1 / 0 : this.maxW, + this.minW + 1 < t ? t : this.minW, + ); + } + if (a && "" === this.h) { + a += n; + this.h = Math.min( + this.maxH <= 0 ? 1 / 0 : this.maxH, + this.minH + 1 < a ? a : this.minH, + ); + } + } + this[Js](); + fixDimensions(this); + setFirstUnsplittable(this); + if (!checkDimensions(this, e)) { + this.w = a; + this.h = r; + this[Js](); + return HTMLResult.FAILURE; + } + unsetFirstUnsplittable(this); + const o = toStyle( + this, + "font", + "dimensions", + "position", + "rotate", + "anchorType", + "presence", + "margin", + "hAlign", + ); + setMinMaxDimensions(this, o); + const c = ["xfaField"]; + this.font && c.push("xfaFont"); + isPrintOnly(this) && c.push("xfaPrintOnly"); + const l = { style: o, id: this[uo], class: c }; + if (o.margin) { + o.padding = o.margin; + delete o.margin; + } + setAccess(this, c); + this.name && (l.xfaName = this.name); + const h = [], + u = { name: "div", attributes: l, children: h }; + applyAssist(this, l); + const d = this.border ? this.border[ho]() : null, + f = computeBbox(this, u, e), + g = this.ui[co]().html; + if (!g) { + Object.assign(o, d); + return HTMLResult.success(createWrapper(this, u), f); + } + this[no] && + (g.children?.[0] + ? (g.children[0].attributes.tabindex = this[no]) + : (g.attributes.tabindex = this[no])); + g.attributes.style ||= Object.create(null); + let p = null; + if (this.ui.button) { + 1 === g.children.length && ([p] = g.children.splice(0, 1)); + Object.assign(g.attributes.style, d); + } else Object.assign(o, d); + h.push(g); + if (this.value) + if (this.ui.imageEdit) g.children.push(this.value[co]().html); + else if (!this.ui.button) { + let e = ""; + if (this.value.exData) e = this.value.exData[so](); + else if (this.value.text) e = this.value.text[ws](); + else { + const t = this.value[co]().html; + null !== t && (e = t.children[0].value); + } + this.ui.textEdit && + this.value.text?.maxChars && + (g.children[0].attributes.maxLength = this.value.text.maxChars); + if (e) { + if (this.ui.numericEdit) { + e = parseFloat(e); + e = isNaN(e) ? "" : e.toString(); + } + "textarea" === g.children[0].name + ? (g.children[0].attributes.textContent = e) + : (g.children[0].attributes.value = e); + } + } + if (!this.ui.imageEdit && g.children?.[0] && this.h) { + s = s || getBorderDims(this.ui[ws]()); + let t = 0; + if (this.caption && ["top", "bottom"].includes(this.caption.placement)) { + t = this.caption.reserve; + t <= 0 && (t = this.caption[ws](e).h); + const a = this.h - t - n - s.h; + g.children[0].attributes.style.height = measureToString(a); + } else g.children[0].attributes.style.height = "100%"; + } + p && g.children.push(p); + if (!t) { + g.attributes.class && g.attributes.class.push("xfaLeft"); + this.w = a; + this.h = r; + return HTMLResult.success(createWrapper(this, u), f); + } + if (this.ui.button) { + o.padding && delete o.padding; + "div" === t.name && (t.name = "span"); + g.children.push(t); + return HTMLResult.success(u, f); + } + this.ui.checkButton && (t.attributes.class[0] = "xfaCaptionForCheckButton"); + g.attributes.class ||= []; + g.children.splice(0, 0, t); + switch (this.caption.placement) { + case "left": + case "inline": + g.attributes.class.push("xfaLeft"); + break; + case "right": + g.attributes.class.push("xfaRight"); + break; + case "top": + g.attributes.class.push("xfaTop"); + break; + case "bottom": + g.attributes.class.push("xfaBottom"); + } + this.w = a; + this.h = r; + return HTMLResult.success(createWrapper(this, u), f); + } +} +class Fill extends XFAObject { + constructor(e) { + super(Go, "fill", !0); + this.id = e.id || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + this.linear = null; + this.pattern = null; + this.radial = null; + this.solid = null; + this.stipple = null; + } + [ho]() { + const e = this[vs](), + t = e[vs]()[vs](), + a = Object.create(null); + let r = "color", + i = r; + if (e instanceof Border) { + r = "background-color"; + i = "background"; + t instanceof Ui && (a.backgroundColor = "white"); + } + if (e instanceof Rectangle || e instanceof Arc) { + r = i = "fill"; + a.fill = "white"; + } + for (const e of Object.getOwnPropertyNames(this)) { + if ("extras" === e || "color" === e) continue; + const t = this[e]; + if (!(t instanceof XFAObject)) continue; + const n = t[ho](this.color); + n && (a[n.startsWith("#") ? r : i] = n); + return a; + } + if (this.color?.value) { + const e = this.color[ho](); + a[e.startsWith("#") ? r : i] = e; + } + return a; + } +} +class Filter extends XFAObject { + constructor(e) { + super(Go, "filter", !0); + this.addRevocationInfo = getStringOption(e.addRevocationInfo, [ + "", + "required", + "optional", + "none", + ]); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.version = getInteger({ + data: this.version, + defaultValue: 5, + validate: (e) => e >= 1 && e <= 5, + }); + this.appearanceFilter = null; + this.certificates = null; + this.digestMethods = null; + this.encodings = null; + this.encryptionMethods = null; + this.handler = null; + this.lockDocument = null; + this.mdp = null; + this.reasons = null; + this.timeStamp = null; + } +} +class Float extends ContentObject { + constructor(e) { + super(Go, "float"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = parseFloat(this[ss].trim()); + this[ss] = isNaN(e) ? null : e; + } + [co](e) { + return valueToHtml(null !== this[ss] ? this[ss].toString() : ""); + } +} +class template_Font extends XFAObject { + constructor(e) { + super(Go, "font", !0); + this.baselineShift = getMeasurement(e.baselineShift); + this.fontHorizontalScale = getFloat({ + data: e.fontHorizontalScale, + defaultValue: 100, + validate: (e) => e >= 0, + }); + this.fontVerticalScale = getFloat({ + data: e.fontVerticalScale, + defaultValue: 100, + validate: (e) => e >= 0, + }); + this.id = e.id || ""; + this.kerningMode = getStringOption(e.kerningMode, ["none", "pair"]); + this.letterSpacing = getMeasurement(e.letterSpacing, "0"); + this.lineThrough = getInteger({ + data: e.lineThrough, + defaultValue: 0, + validate: (e) => 1 === e || 2 === e, + }); + this.lineThroughPeriod = getStringOption(e.lineThroughPeriod, [ + "all", + "word", + ]); + this.overline = getInteger({ + data: e.overline, + defaultValue: 0, + validate: (e) => 1 === e || 2 === e, + }); + this.overlinePeriod = getStringOption(e.overlinePeriod, ["all", "word"]); + this.posture = getStringOption(e.posture, ["normal", "italic"]); + this.size = getMeasurement(e.size, "10pt"); + this.typeface = e.typeface || "Courier"; + this.underline = getInteger({ + data: e.underline, + defaultValue: 0, + validate: (e) => 1 === e || 2 === e, + }); + this.underlinePeriod = getStringOption(e.underlinePeriod, ["all", "word"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.weight = getStringOption(e.weight, ["normal", "bold"]); + this.extras = null; + this.fill = null; + } + [ts](e) { + super[ts](e); + this[Is].usedTypefaces.add(this.typeface); + } + [ho]() { + const e = toStyle(this, "fill"), + t = e.color; + if (t) + if ("#000000" === t) delete e.color; + else if (!t.startsWith("#")) { + e.background = t; + e.backgroundClip = "text"; + e.color = "transparent"; + } + this.baselineShift && + (e.verticalAlign = measureToString(this.baselineShift)); + e.fontKerning = "none" === this.kerningMode ? "none" : "normal"; + e.letterSpacing = measureToString(this.letterSpacing); + if (0 !== this.lineThrough) { + e.textDecoration = "line-through"; + 2 === this.lineThrough && (e.textDecorationStyle = "double"); + } + if (0 !== this.overline) { + e.textDecoration = "overline"; + 2 === this.overline && (e.textDecorationStyle = "double"); + } + e.fontStyle = this.posture; + e.fontSize = measureToString(0.99 * this.size); + setFontFamily(this, this, this[Is].fontFinder, e); + if (0 !== this.underline) { + e.textDecoration = "underline"; + 2 === this.underline && (e.textDecorationStyle = "double"); + } + e.fontWeight = this.weight; + return e; + } +} +class Format extends XFAObject { + constructor(e) { + super(Go, "format", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.picture = null; + } +} +class Handler extends StringObject { + constructor(e) { + super(Go, "handler"); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Hyphenation extends XFAObject { + constructor(e) { + super(Go, "hyphenation"); + this.excludeAllCaps = getInteger({ + data: e.excludeAllCaps, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.excludeInitialCap = getInteger({ + data: e.excludeInitialCap, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.hyphenate = getInteger({ + data: e.hyphenate, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.id = e.id || ""; + this.pushCharacterCount = getInteger({ + data: e.pushCharacterCount, + defaultValue: 3, + validate: (e) => e >= 0, + }); + this.remainCharacterCount = getInteger({ + data: e.remainCharacterCount, + defaultValue: 3, + validate: (e) => e >= 0, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.wordCharacterCount = getInteger({ + data: e.wordCharacterCount, + defaultValue: 7, + validate: (e) => e >= 0, + }); + } +} +class Image extends StringObject { + constructor(e) { + super(Go, "image"); + this.aspect = getStringOption(e.aspect, [ + "fit", + "actual", + "height", + "none", + "width", + ]); + this.contentType = e.contentType || ""; + this.href = e.href || ""; + this.id = e.id || ""; + this.name = e.name || ""; + this.transferEncoding = getStringOption(e.transferEncoding, [ + "base64", + "none", + "package", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [co]() { + if (this.contentType && !Jo.has(this.contentType.toLowerCase())) + return HTMLResult.EMPTY; + let e = this[Is].images?.get(this.href); + if (!e && (this.href || !this[ss])) return HTMLResult.EMPTY; + e || + "base64" !== this.transferEncoding || + (e = (function fromBase64Util(e) { + return Uint8Array.fromBase64 + ? Uint8Array.fromBase64(e) + : stringToBytes(atob(e)); + })(this[ss])); + if (!e) return HTMLResult.EMPTY; + if (!this.contentType) { + for (const [t, a] of Yo) + if (e.length > t.length && t.every((t, a) => t === e[a])) { + this.contentType = a; + break; + } + if (!this.contentType) return HTMLResult.EMPTY; + } + const t = new Blob([e], { type: this.contentType }); + let a; + switch (this.aspect) { + case "fit": + case "actual": + break; + case "height": + a = { height: "100%", objectFit: "fill" }; + break; + case "none": + a = { width: "100%", height: "100%", objectFit: "fill" }; + break; + case "width": + a = { width: "100%", objectFit: "fill" }; + } + const r = this[vs](); + return HTMLResult.success({ + name: "img", + attributes: { + class: ["xfaImage"], + style: a, + src: URL.createObjectURL(t), + alt: r ? ariaLabel(r[vs]()) : null, + }, + }); + } +} +class ImageEdit extends XFAObject { + constructor(e) { + super(Go, "imageEdit", !0); + this.data = getStringOption(e.data, ["link", "embed"]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.extras = null; + this.margin = null; + } + [co](e) { + return "embed" === this.data + ? HTMLResult.success({ name: "div", children: [], attributes: {} }) + : HTMLResult.EMPTY; + } +} +class Integer extends ContentObject { + constructor(e) { + super(Go, "integer"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = parseInt(this[ss].trim(), 10); + this[ss] = isNaN(e) ? null : e; + } + [co](e) { + return valueToHtml(null !== this[ss] ? this[ss].toString() : ""); + } +} +class Issuers extends XFAObject { + constructor(e) { + super(Go, "issuers", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.certificate = new XFAObjectArray(); + } +} +class Items extends XFAObject { + constructor(e) { + super(Go, "items", !0); + this.id = e.id || ""; + this.name = e.name || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.ref = e.ref || ""; + this.save = getInteger({ + data: e.save, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.boolean = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.time = new XFAObjectArray(); + } + [co]() { + const e = []; + for (const t of this[Ss]()) e.push(t[so]()); + return HTMLResult.success(e); + } +} +class Keep extends XFAObject { + constructor(e) { + super(Go, "keep", !0); + this.id = e.id || ""; + const t = ["none", "contentArea", "pageArea"]; + this.intact = getStringOption(e.intact, t); + this.next = getStringOption(e.next, t); + this.previous = getStringOption(e.previous, t); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } +} +class KeyUsage extends XFAObject { + constructor(e) { + super(Go, "keyUsage"); + const t = ["", "yes", "no"]; + this.crlSign = getStringOption(e.crlSign, t); + this.dataEncipherment = getStringOption(e.dataEncipherment, t); + this.decipherOnly = getStringOption(e.decipherOnly, t); + this.digitalSignature = getStringOption(e.digitalSignature, t); + this.encipherOnly = getStringOption(e.encipherOnly, t); + this.id = e.id || ""; + this.keyAgreement = getStringOption(e.keyAgreement, t); + this.keyCertSign = getStringOption(e.keyCertSign, t); + this.keyEncipherment = getStringOption(e.keyEncipherment, t); + this.nonRepudiation = getStringOption(e.nonRepudiation, t); + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Line extends XFAObject { + constructor(e) { + super(Go, "line", !0); + this.hand = getStringOption(e.hand, ["even", "left", "right"]); + this.id = e.id || ""; + this.slope = getStringOption(e.slope, ["\\", "/"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.edge = null; + } + [co]() { + const e = this[vs]()[vs](), + t = this.edge || new Edge({}), + a = t[ho](), + r = Object.create(null), + i = "visible" === t.presence ? t.thickness : 0; + r.strokeWidth = measureToString(i); + r.stroke = a.color; + let n, + s, + o, + c, + l = "100%", + h = "100%"; + if (e.w <= i) { + [n, s, o, c] = ["50%", 0, "50%", "100%"]; + l = r.strokeWidth; + } else if (e.h <= i) { + [n, s, o, c] = [0, "50%", "100%", "50%"]; + h = r.strokeWidth; + } else + "\\" === this.slope + ? ([n, s, o, c] = [0, 0, "100%", "100%"]) + : ([n, s, o, c] = [0, "100%", "100%", 0]); + const u = { + name: "svg", + children: [ + { + name: "line", + attributes: { xmlns: Vo, x1: n, y1: s, x2: o, y2: c, style: r }, + }, + ], + attributes: { + xmlns: Vo, + width: l, + height: h, + style: { overflow: "visible" }, + }, + }; + if (hasMargin(e)) + return HTMLResult.success({ + name: "div", + attributes: { + style: { display: "inline", width: "100%", height: "100%" }, + }, + children: [u], + }); + u.attributes.style.position = "absolute"; + return HTMLResult.success(u); + } +} +class Linear extends XFAObject { + constructor(e) { + super(Go, "linear", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, [ + "toRight", + "toBottom", + "toLeft", + "toTop", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho](e) { + e = e ? e[ho]() : "#FFFFFF"; + return `linear-gradient(${this.type.replace(/([RBLT])/, " $1").toLowerCase()}, ${e}, ${this.color ? this.color[ho]() : "#000000"})`; + } +} +class LockDocument extends ContentObject { + constructor(e) { + super(Go, "lockDocument"); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + this[ss] = getStringOption(this[ss], ["auto", "0", "1"]); + } +} +class Manifest extends XFAObject { + constructor(e) { + super(Go, "manifest", !0); + this.action = getStringOption(e.action, ["include", "all", "exclude"]); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.ref = new XFAObjectArray(); + } +} +class Margin extends XFAObject { + constructor(e) { + super(Go, "margin", !0); + this.bottomInset = getMeasurement(e.bottomInset, "0"); + this.id = e.id || ""; + this.leftInset = getMeasurement(e.leftInset, "0"); + this.rightInset = getMeasurement(e.rightInset, "0"); + this.topInset = getMeasurement(e.topInset, "0"); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } + [ho]() { + return { + margin: + measureToString(this.topInset) + + " " + + measureToString(this.rightInset) + + " " + + measureToString(this.bottomInset) + + " " + + measureToString(this.leftInset), + }; + } +} +class Mdp extends XFAObject { + constructor(e) { + super(Go, "mdp"); + this.id = e.id || ""; + this.permissions = getInteger({ + data: e.permissions, + defaultValue: 2, + validate: (e) => 1 === e || 3 === e, + }); + this.signatureType = getStringOption(e.signatureType, ["filler", "author"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Medium extends XFAObject { + constructor(e) { + super(Go, "medium"); + this.id = e.id || ""; + this.imagingBBox = (function getBBox(e) { + const t = -1; + if (!e) return { x: t, y: t, width: t, height: t }; + const a = e.split(",", 4).map((e) => getMeasurement(e.trim(), "-1")); + if (a.length < 4 || a[2] < 0 || a[3] < 0) + return { x: t, y: t, width: t, height: t }; + const [r, i, n, s] = a; + return { x: r, y: i, width: n, height: s }; + })(e.imagingBBox); + this.long = getMeasurement(e.long); + this.orientation = getStringOption(e.orientation, [ + "portrait", + "landscape", + ]); + this.short = getMeasurement(e.short); + this.stock = e.stock || ""; + this.trayIn = getStringOption(e.trayIn, ["auto", "delegate", "pageFront"]); + this.trayOut = getStringOption(e.trayOut, ["auto", "delegate"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Message extends XFAObject { + constructor(e) { + super(Go, "message", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.text = new XFAObjectArray(); + } +} +class NumericEdit extends XFAObject { + constructor(e) { + super(Go, "numericEdit", !0); + this.hScrollPolicy = getStringOption(e.hScrollPolicy, [ + "auto", + "off", + "on", + ]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.comb = null; + this.extras = null; + this.margin = null; + } + [co](e) { + const t = toStyle(this, "border", "font", "margin"), + a = this[vs]()[vs](), + r = { + name: "input", + attributes: { + type: "text", + fieldId: a[uo], + dataId: a[os]?.[uo] || a[uo], + class: ["xfaTextfield"], + style: t, + "aria-label": ariaLabel(a), + "aria-required": !1, + }, + }; + if (isRequired(a)) { + r.attributes["aria-required"] = !0; + r.attributes.required = !0; + } + return HTMLResult.success({ + name: "label", + attributes: { class: ["xfaLabel"] }, + children: [r], + }); + } +} +class Occur extends XFAObject { + constructor(e) { + super(Go, "occur", !0); + this.id = e.id || ""; + this.initial = + "" !== e.initial + ? getInteger({ data: e.initial, defaultValue: "", validate: (e) => !0 }) + : ""; + this.max = + "" !== e.max + ? getInteger({ data: e.max, defaultValue: 1, validate: (e) => !0 }) + : ""; + this.min = + "" !== e.min + ? getInteger({ data: e.min, defaultValue: 1, validate: (e) => !0 }) + : ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } + [ts]() { + const e = this[vs](), + t = this.min; + "" === this.min && + (this.min = e instanceof PageArea || e instanceof PageSet ? 0 : 1); + "" === this.max && + (this.max = + "" === t + ? e instanceof PageArea || e instanceof PageSet + ? -1 + : 1 + : this.min); + -1 !== this.max && this.max < this.min && (this.max = this.min); + "" === this.initial && + (this.initial = e instanceof Template ? 1 : this.min); + } +} +class Oid extends StringObject { + constructor(e) { + super(Go, "oid"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Oids extends XFAObject { + constructor(e) { + super(Go, "oids", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.oid = new XFAObjectArray(); + } +} +class Overflow extends XFAObject { + constructor(e) { + super(Go, "overflow"); + this.id = e.id || ""; + this.leader = e.leader || ""; + this.target = e.target || ""; + this.trailer = e.trailer || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [ws]() { + if (!this[ls]) { + const e = this[vs](), + t = this[Fs](), + a = t[to](this.target, e), + r = t[to](this.leader, e), + i = t[to](this.trailer, e); + this[ls] = { + target: a?.[0] || null, + leader: r?.[0] || null, + trailer: i?.[0] || null, + addLeader: !1, + addTrailer: !1, + }; + } + return this[ls]; + } +} +class PageArea extends XFAObject { + constructor(e) { + super(Go, "pageArea", !0); + this.blankOrNotBlank = getStringOption(e.blankOrNotBlank, [ + "any", + "blank", + "notBlank", + ]); + this.id = e.id || ""; + this.initialNumber = getInteger({ + data: e.initialNumber, + defaultValue: 1, + validate: (e) => !0, + }); + this.name = e.name || ""; + this.numbered = getInteger({ + data: e.numbered, + defaultValue: 1, + validate: (e) => !0, + }); + this.oddOrEven = getStringOption(e.oddOrEven, ["any", "even", "odd"]); + this.pagePosition = getStringOption(e.pagePosition, [ + "any", + "first", + "last", + "only", + "rest", + ]); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.desc = null; + this.extras = null; + this.medium = null; + this.occur = null; + this.area = new XFAObjectArray(); + this.contentArea = new XFAObjectArray(); + this.draw = new XFAObjectArray(); + this.exclGroup = new XFAObjectArray(); + this.field = new XFAObjectArray(); + this.subform = new XFAObjectArray(); + } + [Xs]() { + if (!this[ls]) { + this[ls] = { numberOfUse: 0 }; + return !0; + } + return ( + !this.occur || + -1 === this.occur.max || + this[ls].numberOfUse < this.occur.max + ); + } + [as]() { + delete this[ls]; + } + [As]() { + this[ls] ||= { numberOfUse: 0 }; + const e = this[vs](); + if ("orderedOccurrence" === e.relation && this[Xs]()) { + this[ls].numberOfUse += 1; + return this; + } + return e[As](); + } + [gs]() { + return this[ls].space || { width: 0, height: 0 }; + } + [co]() { + this[ls] ||= { numberOfUse: 1 }; + const e = []; + this[ls].children = e; + const t = Object.create(null); + if (this.medium && this.medium.short && this.medium.long) { + t.width = measureToString(this.medium.short); + t.height = measureToString(this.medium.long); + this[ls].space = { width: this.medium.short, height: this.medium.long }; + if ("landscape" === this.medium.orientation) { + const e = t.width; + t.width = t.height; + t.height = e; + this[ls].space = { width: this.medium.long, height: this.medium.short }; + } + } else warn("XFA - No medium specified in pageArea: please file a bug."); + this[es]({ + filter: new Set(["area", "draw", "field", "subform"]), + include: !0, + }); + this[es]({ filter: new Set(["contentArea"]), include: !0 }); + return HTMLResult.success({ + name: "div", + children: e, + attributes: { + class: ["xfaPage"], + id: this[uo], + style: t, + xfaName: this.name, + }, + }); + } +} +class PageSet extends XFAObject { + constructor(e) { + super(Go, "pageSet", !0); + this.duplexImposition = getStringOption(e.duplexImposition, [ + "longEdge", + "shortEdge", + ]); + this.id = e.id || ""; + this.name = e.name || ""; + this.relation = getStringOption(e.relation, [ + "orderedOccurrence", + "duplexPaginated", + "simplexPaginated", + ]); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.occur = null; + this.pageArea = new XFAObjectArray(); + this.pageSet = new XFAObjectArray(); + } + [as]() { + for (const e of this.pageArea.children) e[as](); + for (const e of this.pageSet.children) e[as](); + } + [Xs]() { + return ( + !this.occur || + -1 === this.occur.max || + this[ls].numberOfUse < this.occur.max + ); + } + [As]() { + this[ls] ||= { numberOfUse: 1, pageIndex: -1, pageSetIndex: -1 }; + if ("orderedOccurrence" === this.relation) { + if (this[ls].pageIndex + 1 < this.pageArea.children.length) { + this[ls].pageIndex += 1; + return this.pageArea.children[this[ls].pageIndex][As](); + } + if (this[ls].pageSetIndex + 1 < this.pageSet.children.length) { + this[ls].pageSetIndex += 1; + return this.pageSet.children[this[ls].pageSetIndex][As](); + } + if (this[Xs]()) { + this[ls].numberOfUse += 1; + this[ls].pageIndex = -1; + this[ls].pageSetIndex = -1; + return this[As](); + } + const e = this[vs](); + if (e instanceof PageSet) return e[As](); + this[as](); + return this[As](); + } + const e = this[Fs]()[ls].pageNumber, + t = e % 2 == 0 ? "even" : "odd", + a = 0 === e ? "first" : "rest"; + let r = this.pageArea.children.find( + (e) => e.oddOrEven === t && e.pagePosition === a, + ); + if (r) return r; + r = this.pageArea.children.find( + (e) => "any" === e.oddOrEven && e.pagePosition === a, + ); + if (r) return r; + r = this.pageArea.children.find( + (e) => "any" === e.oddOrEven && "any" === e.pagePosition, + ); + return r || this.pageArea.children[0]; + } +} +class Para extends XFAObject { + constructor(e) { + super(Go, "para", !0); + this.hAlign = getStringOption(e.hAlign, [ + "left", + "center", + "justify", + "justifyAll", + "radix", + "right", + ]); + this.id = e.id || ""; + this.lineHeight = e.lineHeight ? getMeasurement(e.lineHeight, "0pt") : ""; + this.marginLeft = e.marginLeft ? getMeasurement(e.marginLeft, "0pt") : ""; + this.marginRight = e.marginRight + ? getMeasurement(e.marginRight, "0pt") + : ""; + this.orphans = getInteger({ + data: e.orphans, + defaultValue: 0, + validate: (e) => e >= 0, + }); + this.preserve = e.preserve || ""; + this.radixOffset = e.radixOffset + ? getMeasurement(e.radixOffset, "0pt") + : ""; + this.spaceAbove = e.spaceAbove ? getMeasurement(e.spaceAbove, "0pt") : ""; + this.spaceBelow = e.spaceBelow ? getMeasurement(e.spaceBelow, "0pt") : ""; + this.tabDefault = e.tabDefault ? getMeasurement(this.tabDefault) : ""; + this.tabStops = (e.tabStops || "") + .trim() + .split(/\s+/) + .map((e, t) => (t % 2 == 1 ? getMeasurement(e) : e)); + this.textIndent = e.textIndent ? getMeasurement(e.textIndent, "0pt") : ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.vAlign = getStringOption(e.vAlign, ["top", "bottom", "middle"]); + this.widows = getInteger({ + data: e.widows, + defaultValue: 0, + validate: (e) => e >= 0, + }); + this.hyphenation = null; + } + [ho]() { + const e = toStyle(this, "hAlign"); + "" !== this.marginLeft && + (e.paddingLeft = measureToString(this.marginLeft)); + "" !== this.marginRight && + (e.paddingRight = measureToString(this.marginRight)); + "" !== this.spaceAbove && (e.paddingTop = measureToString(this.spaceAbove)); + "" !== this.spaceBelow && + (e.paddingBottom = measureToString(this.spaceBelow)); + if ("" !== this.textIndent) { + e.textIndent = measureToString(this.textIndent); + fixTextIndent(e); + } + this.lineHeight > 0 && (e.lineHeight = measureToString(this.lineHeight)); + "" !== this.tabDefault && (e.tabSize = measureToString(this.tabDefault)); + this.tabStops.length; + this.hyphenatation && Object.assign(e, this.hyphenatation[ho]()); + return e; + } +} +class PasswordEdit extends XFAObject { + constructor(e) { + super(Go, "passwordEdit", !0); + this.hScrollPolicy = getStringOption(e.hScrollPolicy, [ + "auto", + "off", + "on", + ]); + this.id = e.id || ""; + this.passwordChar = e.passwordChar || "*"; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.extras = null; + this.margin = null; + } +} +class template_Pattern extends XFAObject { + constructor(e) { + super(Go, "pattern", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, [ + "crossHatch", + "crossDiagonal", + "diagonalLeft", + "diagonalRight", + "horizontal", + "vertical", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho](e) { + e = e ? e[ho]() : "#FFFFFF"; + const t = this.color ? this.color[ho]() : "#000000", + a = "repeating-linear-gradient", + r = `${e},${e} 5px,${t} 5px,${t} 10px`; + switch (this.type) { + case "crossHatch": + return `${a}(to top,${r}) ${a}(to right,${r})`; + case "crossDiagonal": + return `${a}(45deg,${r}) ${a}(-45deg,${r})`; + case "diagonalLeft": + return `${a}(45deg,${r})`; + case "diagonalRight": + return `${a}(-45deg,${r})`; + case "horizontal": + return `${a}(to top,${r})`; + case "vertical": + return `${a}(to right,${r})`; + } + return ""; + } +} +class Picture extends StringObject { + constructor(e) { + super(Go, "picture"); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Proto extends XFAObject { + constructor(e) { + super(Go, "proto", !0); + this.appearanceFilter = new XFAObjectArray(); + this.arc = new XFAObjectArray(); + this.area = new XFAObjectArray(); + this.assist = new XFAObjectArray(); + this.barcode = new XFAObjectArray(); + this.bindItems = new XFAObjectArray(); + this.bookend = new XFAObjectArray(); + this.boolean = new XFAObjectArray(); + this.border = new XFAObjectArray(); + this.break = new XFAObjectArray(); + this.breakAfter = new XFAObjectArray(); + this.breakBefore = new XFAObjectArray(); + this.button = new XFAObjectArray(); + this.calculate = new XFAObjectArray(); + this.caption = new XFAObjectArray(); + this.certificate = new XFAObjectArray(); + this.certificates = new XFAObjectArray(); + this.checkButton = new XFAObjectArray(); + this.choiceList = new XFAObjectArray(); + this.color = new XFAObjectArray(); + this.comb = new XFAObjectArray(); + this.connect = new XFAObjectArray(); + this.contentArea = new XFAObjectArray(); + this.corner = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.dateTimeEdit = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.defaultUi = new XFAObjectArray(); + this.desc = new XFAObjectArray(); + this.digestMethod = new XFAObjectArray(); + this.digestMethods = new XFAObjectArray(); + this.draw = new XFAObjectArray(); + this.edge = new XFAObjectArray(); + this.encoding = new XFAObjectArray(); + this.encodings = new XFAObjectArray(); + this.encrypt = new XFAObjectArray(); + this.encryptData = new XFAObjectArray(); + this.encryption = new XFAObjectArray(); + this.encryptionMethod = new XFAObjectArray(); + this.encryptionMethods = new XFAObjectArray(); + this.event = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.exObject = new XFAObjectArray(); + this.exclGroup = new XFAObjectArray(); + this.execute = new XFAObjectArray(); + this.extras = new XFAObjectArray(); + this.field = new XFAObjectArray(); + this.fill = new XFAObjectArray(); + this.filter = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.font = new XFAObjectArray(); + this.format = new XFAObjectArray(); + this.handler = new XFAObjectArray(); + this.hyphenation = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.imageEdit = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.issuers = new XFAObjectArray(); + this.items = new XFAObjectArray(); + this.keep = new XFAObjectArray(); + this.keyUsage = new XFAObjectArray(); + this.line = new XFAObjectArray(); + this.linear = new XFAObjectArray(); + this.lockDocument = new XFAObjectArray(); + this.manifest = new XFAObjectArray(); + this.margin = new XFAObjectArray(); + this.mdp = new XFAObjectArray(); + this.medium = new XFAObjectArray(); + this.message = new XFAObjectArray(); + this.numericEdit = new XFAObjectArray(); + this.occur = new XFAObjectArray(); + this.oid = new XFAObjectArray(); + this.oids = new XFAObjectArray(); + this.overflow = new XFAObjectArray(); + this.pageArea = new XFAObjectArray(); + this.pageSet = new XFAObjectArray(); + this.para = new XFAObjectArray(); + this.passwordEdit = new XFAObjectArray(); + this.pattern = new XFAObjectArray(); + this.picture = new XFAObjectArray(); + this.radial = new XFAObjectArray(); + this.reason = new XFAObjectArray(); + this.reasons = new XFAObjectArray(); + this.rectangle = new XFAObjectArray(); + this.ref = new XFAObjectArray(); + this.script = new XFAObjectArray(); + this.setProperty = new XFAObjectArray(); + this.signData = new XFAObjectArray(); + this.signature = new XFAObjectArray(); + this.signing = new XFAObjectArray(); + this.solid = new XFAObjectArray(); + this.speak = new XFAObjectArray(); + this.stipple = new XFAObjectArray(); + this.subform = new XFAObjectArray(); + this.subformSet = new XFAObjectArray(); + this.subjectDN = new XFAObjectArray(); + this.subjectDNs = new XFAObjectArray(); + this.submit = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.textEdit = new XFAObjectArray(); + this.time = new XFAObjectArray(); + this.timeStamp = new XFAObjectArray(); + this.toolTip = new XFAObjectArray(); + this.traversal = new XFAObjectArray(); + this.traverse = new XFAObjectArray(); + this.ui = new XFAObjectArray(); + this.validate = new XFAObjectArray(); + this.value = new XFAObjectArray(); + this.variables = new XFAObjectArray(); + } +} +class Radial extends XFAObject { + constructor(e) { + super(Go, "radial", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["toEdge", "toCenter"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho](e) { + e = e ? e[ho]() : "#FFFFFF"; + const t = this.color ? this.color[ho]() : "#000000"; + return `radial-gradient(circle at center, ${"toEdge" === this.type ? `${e},${t}` : `${t},${e}`})`; + } +} +class Reason extends StringObject { + constructor(e) { + super(Go, "reason"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Reasons extends XFAObject { + constructor(e) { + super(Go, "reasons", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.reason = new XFAObjectArray(); + } +} +class Rectangle extends XFAObject { + constructor(e) { + super(Go, "rectangle", !0); + this.hand = getStringOption(e.hand, ["even", "left", "right"]); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.corner = new XFAObjectArray(4); + this.edge = new XFAObjectArray(4); + this.fill = null; + } + [co]() { + const e = this.edge.children.length ? this.edge.children[0] : new Edge({}), + t = e[ho](), + a = Object.create(null); + "visible" === this.fill?.presence + ? Object.assign(a, this.fill[ho]()) + : (a.fill = "transparent"); + a.strokeWidth = measureToString("visible" === e.presence ? e.thickness : 0); + a.stroke = t.color; + const r = ( + this.corner.children.length ? this.corner.children[0] : new Corner({}) + )[ho](), + i = { + name: "svg", + children: [ + { + name: "rect", + attributes: { + xmlns: Vo, + width: "100%", + height: "100%", + x: 0, + y: 0, + rx: r.radius, + ry: r.radius, + style: a, + }, + }, + ], + attributes: { + xmlns: Vo, + style: { overflow: "visible" }, + width: "100%", + height: "100%", + }, + }; + if (hasMargin(this[vs]()[vs]())) + return HTMLResult.success({ + name: "div", + attributes: { + style: { display: "inline", width: "100%", height: "100%" }, + }, + children: [i], + }); + i.attributes.style.position = "absolute"; + return HTMLResult.success(i); + } +} +class RefElement extends StringObject { + constructor(e) { + super(Go, "ref"); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Script extends StringObject { + constructor(e) { + super(Go, "script"); + this.binding = e.binding || ""; + this.contentType = e.contentType || ""; + this.id = e.id || ""; + this.name = e.name || ""; + this.runAt = getStringOption(e.runAt, ["client", "both", "server"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class SetProperty extends XFAObject { + constructor(e) { + super(Go, "setProperty"); + this.connection = e.connection || ""; + this.ref = e.ref || ""; + this.target = e.target || ""; + } +} +class SignData extends XFAObject { + constructor(e) { + super(Go, "signData", !0); + this.id = e.id || ""; + this.operation = getStringOption(e.operation, ["sign", "clear", "verify"]); + this.ref = e.ref || ""; + this.target = e.target || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.filter = null; + this.manifest = null; + } +} +class Signature extends XFAObject { + constructor(e) { + super(Go, "signature", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["PDF1.3", "PDF1.6"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.border = null; + this.extras = null; + this.filter = null; + this.manifest = null; + this.margin = null; + } +} +class Signing extends XFAObject { + constructor(e) { + super(Go, "signing", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.certificate = new XFAObjectArray(); + } +} +class Solid extends XFAObject { + constructor(e) { + super(Go, "solid", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + } + [ho](e) { + return e ? e[ho]() : "#FFFFFF"; + } +} +class Speak extends StringObject { + constructor(e) { + super(Go, "speak"); + this.disable = getInteger({ + data: e.disable, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.id = e.id || ""; + this.priority = getStringOption(e.priority, [ + "custom", + "caption", + "name", + "toolTip", + ]); + this.rid = e.rid || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Stipple extends XFAObject { + constructor(e) { + super(Go, "stipple", !0); + this.id = e.id || ""; + this.rate = getInteger({ + data: e.rate, + defaultValue: 50, + validate: (e) => e >= 0 && e <= 100, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.color = null; + this.extras = null; + } + [ho](e) { + const t = this.rate / 100; + return Util.makeHexColor( + Math.round(e.value.r * (1 - t) + this.value.r * t), + Math.round(e.value.g * (1 - t) + this.value.g * t), + Math.round(e.value.b * (1 - t) + this.value.b * t), + ); + } +} +class Subform extends XFAObject { + constructor(e) { + super(Go, "subform", !0); + this.access = getStringOption(e.access, [ + "open", + "nonInteractive", + "protected", + "readOnly", + ]); + this.allowMacro = getInteger({ + data: e.allowMacro, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.anchorType = getStringOption(e.anchorType, [ + "topLeft", + "bottomCenter", + "bottomLeft", + "bottomRight", + "middleCenter", + "middleLeft", + "middleRight", + "topCenter", + "topRight", + ]); + this.colSpan = getInteger({ + data: e.colSpan, + defaultValue: 1, + validate: (e) => e >= 1 || -1 === e, + }); + this.columnWidths = (e.columnWidths || "") + .trim() + .split(/\s+/) + .map((e) => ("-1" === e ? -1 : getMeasurement(e))); + this.h = e.h ? getMeasurement(e.h) : ""; + this.hAlign = getStringOption(e.hAlign, [ + "left", + "center", + "justify", + "justifyAll", + "radix", + "right", + ]); + this.id = e.id || ""; + this.layout = getStringOption(e.layout, [ + "position", + "lr-tb", + "rl-row", + "rl-tb", + "row", + "table", + "tb", + ]); + this.locale = e.locale || ""; + this.maxH = getMeasurement(e.maxH, "0pt"); + this.maxW = getMeasurement(e.maxW, "0pt"); + this.mergeMode = getStringOption(e.mergeMode, [ + "consumeData", + "matchTemplate", + ]); + this.minH = getMeasurement(e.minH, "0pt"); + this.minW = getMeasurement(e.minW, "0pt"); + this.name = e.name || ""; + this.presence = getStringOption(e.presence, [ + "visible", + "hidden", + "inactive", + "invisible", + ]); + this.relevant = getRelevant(e.relevant); + this.restoreState = getStringOption(e.restoreState, ["manual", "auto"]); + this.scope = getStringOption(e.scope, ["name", "none"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.w = e.w ? getMeasurement(e.w) : ""; + this.x = getMeasurement(e.x, "0pt"); + this.y = getMeasurement(e.y, "0pt"); + this.assist = null; + this.bind = null; + this.bookend = null; + this.border = null; + this.break = null; + this.calculate = null; + this.desc = null; + this.extras = null; + this.keep = null; + this.margin = null; + this.occur = null; + this.overflow = null; + this.pageSet = null; + this.para = null; + this.traversal = null; + this.validate = null; + this.variables = null; + this.area = new XFAObjectArray(); + this.breakAfter = new XFAObjectArray(); + this.breakBefore = new XFAObjectArray(); + this.connect = new XFAObjectArray(); + this.draw = new XFAObjectArray(); + this.event = new XFAObjectArray(); + this.exObject = new XFAObjectArray(); + this.exclGroup = new XFAObjectArray(); + this.field = new XFAObjectArray(); + this.proto = new XFAObjectArray(); + this.setProperty = new XFAObjectArray(); + this.subform = new XFAObjectArray(); + this.subformSet = new XFAObjectArray(); + } + [Cs]() { + const e = this[vs](); + return e instanceof SubformSet ? e[Cs]() : e; + } + [Rs]() { + return !0; + } + [_s]() { + return ( + (this.layout.endsWith("-tb") && + 0 === this[ls].attempt && + this[ls].numberInLine > 0) || + this[vs]()[_s]() + ); + } + *[ks]() { + yield* getContainedChildren(this); + } + [us]() { + return flushHTML(this); + } + [Zn](e, t) { + addHTML(this, e, t); + } + [gs]() { + return getAvailableSpace(this); + } + [js]() { + const e = this[Cs](); + if (!e[js]()) return !1; + if (void 0 !== this[ls]._isSplittable) return this[ls]._isSplittable; + if ("position" === this.layout || this.layout.includes("row")) { + this[ls]._isSplittable = !1; + return !1; + } + if (this.keep && "none" !== this.keep.intact) { + this[ls]._isSplittable = !1; + return !1; + } + if (e.layout?.endsWith("-tb") && 0 !== e[ls].numberInLine) return !1; + this[ls]._isSplittable = !0; + return !0; + } + [co](e) { + setTabIndex(this); + if (this.break) { + if ("auto" !== this.break.after || "" !== this.break.afterTarget) { + const e = new BreakAfter({ + targetType: this.break.after, + target: this.break.afterTarget, + startNew: this.break.startNew.toString(), + }); + e[Is] = this[Is]; + this[Qn](e); + this.breakAfter.push(e); + } + if ("auto" !== this.break.before || "" !== this.break.beforeTarget) { + const e = new BreakBefore({ + targetType: this.break.before, + target: this.break.beforeTarget, + startNew: this.break.startNew.toString(), + }); + e[Is] = this[Is]; + this[Qn](e); + this.breakBefore.push(e); + } + if ("" !== this.break.overflowTarget) { + const e = new Overflow({ + target: this.break.overflowTarget, + leader: this.break.overflowLeader, + trailer: this.break.overflowTrailer, + }); + e[Is] = this[Is]; + this[Qn](e); + this.overflow.push(e); + } + this[Zs](this.break); + this.break = null; + } + if ("hidden" === this.presence || "inactive" === this.presence) + return HTMLResult.EMPTY; + (this.breakBefore.children.length > 1 || + this.breakAfter.children.length > 1) && + warn( + "XFA - Several breakBefore or breakAfter in subforms: please file a bug.", + ); + if (this.breakBefore.children.length >= 1) { + const e = this.breakBefore.children[0]; + if (handleBreak(e)) return HTMLResult.breakNode(e); + } + if (this[ls]?.afterBreakAfter) return HTMLResult.EMPTY; + fixDimensions(this); + const t = [], + a = { id: this[uo], class: [] }; + setAccess(this, a.class); + this[ls] ||= Object.create(null); + Object.assign(this[ls], { + children: t, + line: null, + attributes: a, + attempt: 0, + numberInLine: 0, + availableSpace: { + width: Math.min(this.w || 1 / 0, e.width), + height: Math.min(this.h || 1 / 0, e.height), + }, + width: 0, + height: 0, + prevHeight: 0, + currentWidth: 0, + }); + const r = this[Fs](), + i = r[ls].noLayoutFailure, + n = this[js](); + n || setFirstUnsplittable(this); + if (!checkDimensions(this, e)) return HTMLResult.FAILURE; + const s = new Set([ + "area", + "draw", + "exclGroup", + "field", + "subform", + "subformSet", + ]); + if (this.layout.includes("row")) { + const e = this[Cs]().columnWidths; + if (Array.isArray(e) && e.length > 0) { + this[ls].columnWidths = e; + this[ls].currentColumn = 0; + } + } + const o = toStyle( + this, + "anchorType", + "dimensions", + "position", + "presence", + "border", + "margin", + "hAlign", + ), + c = ["xfaSubform"], + l = layoutClass(this); + l && c.push(l); + a.style = o; + a.class = c; + this.name && (a.xfaName = this.name); + if (this.overflow) { + const t = this.overflow[ws](); + if (t.addLeader) { + t.addLeader = !1; + handleOverflow(this, t.leader, e); + } + } + this[Ys](); + const h = "lr-tb" === this.layout || "rl-tb" === this.layout, + u = h ? 2 : 1; + for (; this[ls].attempt < u; this[ls].attempt++) { + h && 1 === this[ls].attempt && (this[ls].numberInLine = 0); + const e = this[es]({ filter: s, include: !0 }); + if (e.success) break; + if (e.isBreak()) { + this[Js](); + return e; + } + if ( + h && + 0 === this[ls].attempt && + 0 === this[ls].numberInLine && + !r[ls].noLayoutFailure + ) { + this[ls].attempt = u; + break; + } + } + this[Js](); + n || unsetFirstUnsplittable(this); + r[ls].noLayoutFailure = i; + if (this[ls].attempt === u) { + this.overflow && (this[Fs]()[ls].overflowNode = this.overflow); + n || delete this[ls]; + return HTMLResult.FAILURE; + } + if (this.overflow) { + const t = this.overflow[ws](); + if (t.addTrailer) { + t.addTrailer = !1; + handleOverflow(this, t.trailer, e); + } + } + let d = 0, + f = 0; + if (this.margin) { + d = this.margin.leftInset + this.margin.rightInset; + f = this.margin.topInset + this.margin.bottomInset; + } + const g = Math.max(this[ls].width + d, this.w || 0), + p = Math.max(this[ls].height + f, this.h || 0), + m = [this.x, this.y, g, p]; + "" === this.w && (o.width = measureToString(g)); + "" === this.h && (o.height = measureToString(p)); + if (("0px" === o.width || "0px" === o.height) && 0 === t.length) + return HTMLResult.EMPTY; + const b = { name: "div", attributes: a, children: t }; + applyAssist(this, a); + const y = HTMLResult.success(createWrapper(this, b), m); + if (this.breakAfter.children.length >= 1) { + const e = this.breakAfter.children[0]; + if (handleBreak(e)) { + this[ls].afterBreakAfter = y; + return HTMLResult.breakNode(e); + } + } + delete this[ls]; + return y; + } +} +class SubformSet extends XFAObject { + constructor(e) { + super(Go, "subformSet", !0); + this.id = e.id || ""; + this.name = e.name || ""; + this.relation = getStringOption(e.relation, [ + "ordered", + "choice", + "unordered", + ]); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.bookend = null; + this.break = null; + this.desc = null; + this.extras = null; + this.occur = null; + this.overflow = null; + this.breakAfter = new XFAObjectArray(); + this.breakBefore = new XFAObjectArray(); + this.subform = new XFAObjectArray(); + this.subformSet = new XFAObjectArray(); + } + *[ks]() { + yield* getContainedChildren(this); + } + [Cs]() { + let e = this[vs](); + for (; !(e instanceof Subform); ) e = e[vs](); + return e; + } + [Rs]() { + return !0; + } +} +class SubjectDN extends ContentObject { + constructor(e) { + super(Go, "subjectDN"); + this.delimiter = e.delimiter || ","; + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + this[ss] = new Map( + this[ss].split(this.delimiter).map((e) => { + (e = e.split("=", 2))[0] = e[0].trim(); + return e; + }), + ); + } +} +class SubjectDNs extends XFAObject { + constructor(e) { + super(Go, "subjectDNs", !0); + this.id = e.id || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.subjectDN = new XFAObjectArray(); + } +} +class Submit extends XFAObject { + constructor(e) { + super(Go, "submit", !0); + this.embedPDF = getInteger({ + data: e.embedPDF, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.format = getStringOption(e.format, [ + "xdp", + "formdata", + "pdf", + "urlencoded", + "xfd", + "xml", + ]); + this.id = e.id || ""; + this.target = e.target || ""; + this.textEncoding = getKeyword({ + data: e.textEncoding ? e.textEncoding.toLowerCase() : "", + defaultValue: "", + validate: (e) => + [ + "utf-8", + "big-five", + "fontspecific", + "gbk", + "gb-18030", + "gb-2312", + "ksc-5601", + "none", + "shift-jis", + "ucs-2", + "utf-16", + ].includes(e) || e.match(/iso-8859-\d{2}/), + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.xdpContent = e.xdpContent || ""; + this.encrypt = null; + this.encryptData = new XFAObjectArray(); + this.signData = new XFAObjectArray(); + } +} +class Template extends XFAObject { + constructor(e) { + super(Go, "template", !0); + this.baseProfile = getStringOption(e.baseProfile, [ + "full", + "interactiveForms", + ]); + this.extras = null; + this.subform = new XFAObjectArray(); + } + [hs]() { + 0 === this.subform.children.length && + warn("XFA - No subforms in template node."); + this.subform.children.length >= 2 && + warn("XFA - Several subforms in template node: please file a bug."); + this[no] = 5e3; + } + [js]() { + return !0; + } + [to](e, t) { + return e.startsWith("#") + ? [this[Os].get(e.slice(1))] + : searchNode(this, t, e, !0, !0); + } + *[oo]() { + if (!this.subform.children.length) + return HTMLResult.success({ name: "div", children: [] }); + this[ls] = { + overflowNode: null, + firstUnsplittable: null, + currentContentArea: null, + currentPageArea: null, + noLayoutFailure: !1, + pageNumber: 1, + pagePosition: "first", + oddOrEven: "odd", + blankOrNotBlank: "nonBlank", + paraStack: [], + }; + const e = this.subform.children[0]; + e.pageSet[as](); + const t = e.pageSet.pageArea.children, + a = { name: "div", children: [] }; + let r = null, + i = null, + n = null; + if (e.breakBefore.children.length >= 1) { + i = e.breakBefore.children[0]; + n = i.target; + } else if ( + e.subform.children.length >= 1 && + e.subform.children[0].breakBefore.children.length >= 1 + ) { + i = e.subform.children[0].breakBefore.children[0]; + n = i.target; + } else if (e.break?.beforeTarget) { + i = e.break; + n = i.beforeTarget; + } else if ( + e.subform.children.length >= 1 && + e.subform.children[0].break?.beforeTarget + ) { + i = e.subform.children[0].break; + n = i.beforeTarget; + } + if (i) { + const e = this[to](n, i[vs]()); + if (e instanceof PageArea) { + r = e; + i[ls] = {}; + } + } + r ||= t[0]; + r[ls] = { numberOfUse: 1 }; + const s = r[vs](); + s[ls] = { + numberOfUse: 1, + pageIndex: s.pageArea.children.indexOf(r), + pageSetIndex: 0, + }; + let o, + c = null, + l = null, + h = !0, + u = 0, + d = 0; + for (;;) { + if (h) u = 0; + else { + a.children.pop(); + if (3 == ++u) { + warn("XFA - Something goes wrong: please file a bug."); + return a; + } + } + o = null; + this[ls].currentPageArea = r; + const t = r[co]().html; + a.children.push(t); + if (c) { + this[ls].noLayoutFailure = !0; + t.children.push(c[co](r[ls].space).html); + c = null; + } + if (l) { + this[ls].noLayoutFailure = !0; + t.children.push(l[co](r[ls].space).html); + l = null; + } + const i = r.contentArea.children, + n = t.children.filter((e) => + e.attributes.class.includes("xfaContentarea"), + ); + h = !1; + this[ls].firstUnsplittable = null; + this[ls].noLayoutFailure = !1; + const flush = (t) => { + const a = e[us](); + if (a) { + h ||= a.children?.length > 0; + n[t].children.push(a); + } + }; + for (let t = d, r = i.length; t < r; t++) { + const r = (this[ls].currentContentArea = i[t]), + s = { width: r.w, height: r.h }; + d = 0; + if (c) { + n[t].children.push(c[co](s).html); + c = null; + } + if (l) { + n[t].children.push(l[co](s).html); + l = null; + } + const u = e[co](s); + if (u.success) { + if (u.html) { + h ||= u.html.children?.length > 0; + n[t].children.push(u.html); + } else !h && a.children.length > 1 && a.children.pop(); + return a; + } + if (u.isBreak()) { + const e = u.breakNode; + flush(t); + if ("auto" === e.targetType) continue; + if (e.leader) { + c = this[to](e.leader, e[vs]()); + c = c ? c[0] : null; + } + if (e.trailer) { + l = this[to](e.trailer, e[vs]()); + l = l ? l[0] : null; + } + if ("pageArea" === e.targetType) { + o = e[ls].target; + t = 1 / 0; + } else if (e[ls].target) { + o = e[ls].target; + d = e[ls].index + 1; + t = 1 / 0; + } else t = e[ls].index; + } else if (this[ls].overflowNode) { + const e = this[ls].overflowNode; + this[ls].overflowNode = null; + const a = e[ws](), + r = a.target; + a.addLeader = null !== a.leader; + a.addTrailer = null !== a.trailer; + flush(t); + const n = t; + t = 1 / 0; + if (r instanceof PageArea) o = r; + else if (r instanceof ContentArea) { + const e = i.indexOf(r); + if (-1 !== e) e > n ? (t = e - 1) : (d = e); + else { + o = r[vs](); + d = o.contentArea.children.indexOf(r); + } + } + } else flush(t); + } + this[ls].pageNumber += 1; + o && (o[Xs]() ? (o[ls].numberOfUse += 1) : (o = null)); + r = o || r[As](); + yield null; + } + } +} +class Text extends ContentObject { + constructor(e) { + super(Go, "text"); + this.id = e.id || ""; + this.maxChars = getInteger({ + data: e.maxChars, + defaultValue: 0, + validate: (e) => e >= 0, + }); + this.name = e.name || ""; + this.rid = e.rid || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [Yn]() { + return !0; + } + [$s](e) { + if (e[Hs] === go.xhtml.id) { + this[ss] = e; + return !0; + } + warn(`XFA - Invalid content in Text: ${e[Ws]}.`); + return !1; + } + [Vs](e) { + this[ss] instanceof XFAObject || super[Vs](e); + } + [hs]() { + "string" == typeof this[ss] && + (this[ss] = this[ss].replaceAll("\r\n", "\n")); + } + [ws]() { + return "string" == typeof this[ss] + ? this[ss] + .split(/[\u2029\u2028\n]/) + .filter((e) => !!e) + .join("\n") + : this[ss][so](); + } + [co](e) { + if ("string" == typeof this[ss]) { + const e = valueToHtml(this[ss]).html; + if (this[ss].includes("\u2029")) { + e.name = "div"; + e.children = []; + this[ss] + .split("\u2029") + .map((e) => + e + .split(/[\u2028\n]/) + .flatMap((e) => [{ name: "span", value: e }, { name: "br" }]), + ) + .forEach((t) => { + e.children.push({ name: "p", children: t }); + }); + } else if (/[\u2028\n]/.test(this[ss])) { + e.name = "div"; + e.children = []; + this[ss].split(/[\u2028\n]/).forEach((t) => { + e.children.push({ name: "span", value: t }, { name: "br" }); + }); + } + return HTMLResult.success(e); + } + return this[ss][co](e); + } +} +class TextEdit extends XFAObject { + constructor(e) { + super(Go, "textEdit", !0); + this.allowRichText = getInteger({ + data: e.allowRichText, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.hScrollPolicy = getStringOption(e.hScrollPolicy, [ + "auto", + "off", + "on", + ]); + this.id = e.id || ""; + this.multiLine = getInteger({ + data: e.multiLine, + defaultValue: "", + validate: (e) => 0 === e || 1 === e, + }); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.vScrollPolicy = getStringOption(e.vScrollPolicy, [ + "auto", + "off", + "on", + ]); + this.border = null; + this.comb = null; + this.extras = null; + this.margin = null; + } + [co](e) { + const t = toStyle(this, "border", "font", "margin"); + let a; + const r = this[vs]()[vs](); + "" === this.multiLine && (this.multiLine = r instanceof Draw ? 1 : 0); + a = + 1 === this.multiLine + ? { + name: "textarea", + attributes: { + dataId: r[os]?.[uo] || r[uo], + fieldId: r[uo], + class: ["xfaTextfield"], + style: t, + "aria-label": ariaLabel(r), + "aria-required": !1, + }, + } + : { + name: "input", + attributes: { + type: "text", + dataId: r[os]?.[uo] || r[uo], + fieldId: r[uo], + class: ["xfaTextfield"], + style: t, + "aria-label": ariaLabel(r), + "aria-required": !1, + }, + }; + if (isRequired(r)) { + a.attributes["aria-required"] = !0; + a.attributes.required = !0; + } + return HTMLResult.success({ + name: "label", + attributes: { class: ["xfaLabel"] }, + children: [a], + }); + } +} +class Time extends StringObject { + constructor(e) { + super(Go, "time"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } + [hs]() { + const e = this[ss].trim(); + this[ss] = e ? new Date(e) : null; + } + [co](e) { + return valueToHtml(this[ss] ? this[ss].toString() : ""); + } +} +class TimeStamp extends XFAObject { + constructor(e) { + super(Go, "timeStamp"); + this.id = e.id || ""; + this.server = e.server || ""; + this.type = getStringOption(e.type, ["optional", "required"]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class ToolTip extends StringObject { + constructor(e) { + super(Go, "toolTip"); + this.id = e.id || ""; + this.rid = e.rid || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Traversal extends XFAObject { + constructor(e) { + super(Go, "traversal", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.traverse = new XFAObjectArray(); + } +} +class Traverse extends XFAObject { + constructor(e) { + super(Go, "traverse", !0); + this.id = e.id || ""; + this.operation = getStringOption(e.operation, [ + "next", + "back", + "down", + "first", + "left", + "right", + "up", + ]); + this.ref = e.ref || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.script = null; + } + get name() { + return this.operation; + } + [Us]() { + return !1; + } +} +class Ui extends XFAObject { + constructor(e) { + super(Go, "ui", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.picture = null; + this.barcode = null; + this.button = null; + this.checkButton = null; + this.choiceList = null; + this.dateTimeEdit = null; + this.defaultUi = null; + this.imageEdit = null; + this.numericEdit = null; + this.passwordEdit = null; + this.signature = null; + this.textEdit = null; + } + [ws]() { + if (void 0 === this[ls]) { + for (const e of Object.getOwnPropertyNames(this)) { + if ("extras" === e || "picture" === e) continue; + const t = this[e]; + if (t instanceof XFAObject) { + this[ls] = t; + return t; + } + } + this[ls] = null; + } + return this[ls]; + } + [co](e) { + const t = this[ws](); + return t ? t[co](e) : HTMLResult.EMPTY; + } +} +class Validate extends XFAObject { + constructor(e) { + super(Go, "validate", !0); + this.formatTest = getStringOption(e.formatTest, [ + "warning", + "disabled", + "error", + ]); + this.id = e.id || ""; + this.nullTest = getStringOption(e.nullTest, [ + "disabled", + "error", + "warning", + ]); + this.scriptTest = getStringOption(e.scriptTest, [ + "error", + "disabled", + "warning", + ]); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.extras = null; + this.message = null; + this.picture = null; + this.script = null; + } +} +class Value extends XFAObject { + constructor(e) { + super(Go, "value", !0); + this.id = e.id || ""; + this.override = getInteger({ + data: e.override, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.relevant = getRelevant(e.relevant); + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.arc = null; + this.boolean = null; + this.date = null; + this.dateTime = null; + this.decimal = null; + this.exData = null; + this.float = null; + this.image = null; + this.integer = null; + this.line = null; + this.rectangle = null; + this.text = null; + this.time = null; + } + [io](e) { + const t = this[vs](); + if (t instanceof Field && t.ui?.imageEdit) { + if (!this.image) { + this.image = new Image({}); + this[Qn](this.image); + } + this.image[ss] = e[ss]; + return; + } + const a = e[Ws]; + if (null === this[a]) { + for (const e of Object.getOwnPropertyNames(this)) { + const t = this[e]; + if (t instanceof XFAObject) { + this[e] = null; + this[Zs](t); + } + } + this[e[Ws]] = e; + this[Qn](e); + } else this[a][ss] = e[ss]; + } + [so]() { + if (this.exData) + return "string" == typeof this.exData[ss] + ? this.exData[ss].trim() + : this.exData[ss][so]().trim(); + for (const e of Object.getOwnPropertyNames(this)) { + if ("image" === e) continue; + const t = this[e]; + if (t instanceof XFAObject) return (t[ss] || "").toString().trim(); + } + return null; + } + [co](e) { + for (const t of Object.getOwnPropertyNames(this)) { + const a = this[t]; + if (a instanceof XFAObject) return a[co](e); + } + return HTMLResult.EMPTY; + } +} +class Variables extends XFAObject { + constructor(e) { + super(Go, "variables", !0); + this.id = e.id || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + this.boolean = new XFAObjectArray(); + this.date = new XFAObjectArray(); + this.dateTime = new XFAObjectArray(); + this.decimal = new XFAObjectArray(); + this.exData = new XFAObjectArray(); + this.float = new XFAObjectArray(); + this.image = new XFAObjectArray(); + this.integer = new XFAObjectArray(); + this.manifest = new XFAObjectArray(); + this.script = new XFAObjectArray(); + this.text = new XFAObjectArray(); + this.time = new XFAObjectArray(); + } + [Us]() { + return !0; + } +} +class TemplateNamespace { + static [fo](e, t) { + if (TemplateNamespace.hasOwnProperty(e)) { + const a = TemplateNamespace[e](t); + a[ro](t); + return a; + } + } + static appearanceFilter(e) { + return new AppearanceFilter(e); + } + static arc(e) { + return new Arc(e); + } + static area(e) { + return new Area(e); + } + static assist(e) { + return new Assist(e); + } + static barcode(e) { + return new Barcode(e); + } + static bind(e) { + return new Bind(e); + } + static bindItems(e) { + return new BindItems(e); + } + static bookend(e) { + return new Bookend(e); + } + static boolean(e) { + return new BooleanElement(e); + } + static border(e) { + return new Border(e); + } + static break(e) { + return new Break(e); + } + static breakAfter(e) { + return new BreakAfter(e); + } + static breakBefore(e) { + return new BreakBefore(e); + } + static button(e) { + return new Button(e); + } + static calculate(e) { + return new Calculate(e); + } + static caption(e) { + return new Caption(e); + } + static certificate(e) { + return new Certificate(e); + } + static certificates(e) { + return new Certificates(e); + } + static checkButton(e) { + return new CheckButton(e); + } + static choiceList(e) { + return new ChoiceList(e); + } + static color(e) { + return new Color(e); + } + static comb(e) { + return new Comb(e); + } + static connect(e) { + return new Connect(e); + } + static contentArea(e) { + return new ContentArea(e); + } + static corner(e) { + return new Corner(e); + } + static date(e) { + return new DateElement(e); + } + static dateTime(e) { + return new DateTime(e); + } + static dateTimeEdit(e) { + return new DateTimeEdit(e); + } + static decimal(e) { + return new Decimal(e); + } + static defaultUi(e) { + return new DefaultUi(e); + } + static desc(e) { + return new Desc(e); + } + static digestMethod(e) { + return new DigestMethod(e); + } + static digestMethods(e) { + return new DigestMethods(e); + } + static draw(e) { + return new Draw(e); + } + static edge(e) { + return new Edge(e); + } + static encoding(e) { + return new Encoding(e); + } + static encodings(e) { + return new Encodings(e); + } + static encrypt(e) { + return new Encrypt(e); + } + static encryptData(e) { + return new EncryptData(e); + } + static encryption(e) { + return new Encryption(e); + } + static encryptionMethod(e) { + return new EncryptionMethod(e); + } + static encryptionMethods(e) { + return new EncryptionMethods(e); + } + static event(e) { + return new Event(e); + } + static exData(e) { + return new ExData(e); + } + static exObject(e) { + return new ExObject(e); + } + static exclGroup(e) { + return new ExclGroup(e); + } + static execute(e) { + return new Execute(e); + } + static extras(e) { + return new Extras(e); + } + static field(e) { + return new Field(e); + } + static fill(e) { + return new Fill(e); + } + static filter(e) { + return new Filter(e); + } + static float(e) { + return new Float(e); + } + static font(e) { + return new template_Font(e); + } + static format(e) { + return new Format(e); + } + static handler(e) { + return new Handler(e); + } + static hyphenation(e) { + return new Hyphenation(e); + } + static image(e) { + return new Image(e); + } + static imageEdit(e) { + return new ImageEdit(e); + } + static integer(e) { + return new Integer(e); + } + static issuers(e) { + return new Issuers(e); + } + static items(e) { + return new Items(e); + } + static keep(e) { + return new Keep(e); + } + static keyUsage(e) { + return new KeyUsage(e); + } + static line(e) { + return new Line(e); + } + static linear(e) { + return new Linear(e); + } + static lockDocument(e) { + return new LockDocument(e); + } + static manifest(e) { + return new Manifest(e); + } + static margin(e) { + return new Margin(e); + } + static mdp(e) { + return new Mdp(e); + } + static medium(e) { + return new Medium(e); + } + static message(e) { + return new Message(e); + } + static numericEdit(e) { + return new NumericEdit(e); + } + static occur(e) { + return new Occur(e); + } + static oid(e) { + return new Oid(e); + } + static oids(e) { + return new Oids(e); + } + static overflow(e) { + return new Overflow(e); + } + static pageArea(e) { + return new PageArea(e); + } + static pageSet(e) { + return new PageSet(e); + } + static para(e) { + return new Para(e); + } + static passwordEdit(e) { + return new PasswordEdit(e); + } + static pattern(e) { + return new template_Pattern(e); + } + static picture(e) { + return new Picture(e); + } + static proto(e) { + return new Proto(e); + } + static radial(e) { + return new Radial(e); + } + static reason(e) { + return new Reason(e); + } + static reasons(e) { + return new Reasons(e); + } + static rectangle(e) { + return new Rectangle(e); + } + static ref(e) { + return new RefElement(e); + } + static script(e) { + return new Script(e); + } + static setProperty(e) { + return new SetProperty(e); + } + static signData(e) { + return new SignData(e); + } + static signature(e) { + return new Signature(e); + } + static signing(e) { + return new Signing(e); + } + static solid(e) { + return new Solid(e); + } + static speak(e) { + return new Speak(e); + } + static stipple(e) { + return new Stipple(e); + } + static subform(e) { + return new Subform(e); + } + static subformSet(e) { + return new SubformSet(e); + } + static subjectDN(e) { + return new SubjectDN(e); + } + static subjectDNs(e) { + return new SubjectDNs(e); + } + static submit(e) { + return new Submit(e); + } + static template(e) { + return new Template(e); + } + static text(e) { + return new Text(e); + } + static textEdit(e) { + return new TextEdit(e); + } + static time(e) { + return new Time(e); + } + static timeStamp(e) { + return new TimeStamp(e); + } + static toolTip(e) { + return new ToolTip(e); + } + static traversal(e) { + return new Traversal(e); + } + static traverse(e) { + return new Traverse(e); + } + static ui(e) { + return new Ui(e); + } + static validate(e) { + return new Validate(e); + } + static value(e) { + return new Value(e); + } + static variables(e) { + return new Variables(e); + } +} +const Zo = go.datasets.id; +function createText(e) { + const t = new Text({}); + t[ss] = e; + return t; +} +class Binder { + constructor(e) { + this.root = e; + this.datasets = e.datasets; + this.data = e.datasets?.data || new XmlObject(go.datasets.id, "data"); + this.emptyMerge = 0 === this.data[Ss]().length; + this.root.form = this.form = e.template[is](); + } + _isConsumeData() { + return !this.emptyMerge && this._mergeMode; + } + _isMatchTemplate() { + return !this._isConsumeData(); + } + bind() { + this._bindElement(this.form, this.data); + return this.form; + } + getData() { + return this.data; + } + _bindValue(e, t, a) { + e[os] = t; + if (e[Ts]()) + if (t[Ns]()) { + const a = t[ys](); + e[io](createText(a)); + } else if ( + e instanceof Field && + "multiSelect" === e.ui?.choiceList?.open + ) { + const a = t[Ss]() + .map((e) => e[ss].trim()) + .join("\n"); + e[io](createText(a)); + } else + this._isConsumeData() && warn("XFA - Nodes haven't the same type."); + else + !t[Ns]() || this._isMatchTemplate() + ? this._bindElement(e, t) + : warn("XFA - Nodes haven't the same type."); + } + _findDataByNameToConsume(e, t, a, r) { + if (!e) return null; + let i, n; + for (let r = 0; r < 3; r++) { + i = a[xs](e, !1, !0); + for (;;) { + n = i.next().value; + if (!n) break; + if (t === n[Ns]()) return n; + } + if (a[Hs] === go.datasets.id && "data" === a[Ws]) break; + a = a[vs](); + } + if (!r) return null; + i = this.data[xs](e, !0, !1); + n = i.next().value; + if (n) return n; + i = this.data[ds](e, !0); + n = i.next().value; + return n?.[Ns]() ? n : null; + } + _setProperties(e, t) { + if (e.hasOwnProperty("setProperty")) + for (const { ref: a, target: r, connection: i } of e.setProperty + .children) { + if (i) continue; + if (!a) continue; + const n = searchNode(this.root, t, a, !1, !1); + if (!n) { + warn(`XFA - Invalid reference: ${a}.`); + continue; + } + const [s] = n; + if (!s[Es](this.data)) { + warn("XFA - Invalid node: must be a data node."); + continue; + } + const o = searchNode(this.root, e, r, !1, !1); + if (!o) { + warn(`XFA - Invalid target: ${r}.`); + continue; + } + const [c] = o; + if (!c[Es](e)) { + warn("XFA - Invalid target: must be a property or subproperty."); + continue; + } + const l = c[vs](); + if (c instanceof SetProperty || l instanceof SetProperty) { + warn( + "XFA - Invalid target: cannot be a setProperty or one of its properties.", + ); + continue; + } + if (c instanceof BindItems || l instanceof BindItems) { + warn( + "XFA - Invalid target: cannot be a bindItems or one of its properties.", + ); + continue; + } + const h = s[so](), + u = c[Ws]; + if (c instanceof XFAAttribute) { + const e = Object.create(null); + e[u] = h; + const t = Reflect.construct(Object.getPrototypeOf(l).constructor, [ + e, + ]); + l[u] = t[u]; + } else if (c.hasOwnProperty(ss)) { + c[os] = s; + c[ss] = h; + c[hs](); + } else warn("XFA - Invalid node to use in setProperty"); + } + } + _bindItems(e, t) { + if ( + !e.hasOwnProperty("items") || + !e.hasOwnProperty("bindItems") || + e.bindItems.isEmpty() + ) + return; + for (const t of e.items.children) e[Zs](t); + e.items.clear(); + const a = new Items({}), + r = new Items({}); + e[Qn](a); + e.items.push(a); + e[Qn](r); + e.items.push(r); + for (const { ref: i, labelRef: n, valueRef: s, connection: o } of e + .bindItems.children) { + if (o) continue; + if (!i) continue; + const e = searchNode(this.root, t, i, !1, !1); + if (e) + for (const t of e) { + if (!t[Es](this.datasets)) { + warn(`XFA - Invalid ref (${i}): must be a datasets child.`); + continue; + } + const e = searchNode(this.root, t, n, !0, !1); + if (!e) { + warn(`XFA - Invalid label: ${n}.`); + continue; + } + const [o] = e; + if (!o[Es](this.datasets)) { + warn("XFA - Invalid label: must be a datasets child."); + continue; + } + const c = searchNode(this.root, t, s, !0, !1); + if (!c) { + warn(`XFA - Invalid value: ${s}.`); + continue; + } + const [l] = c; + if (!l[Es](this.datasets)) { + warn("XFA - Invalid value: must be a datasets child."); + continue; + } + const h = createText(o[so]()), + u = createText(l[so]()); + a[Qn](h); + a.text.push(h); + r[Qn](u); + r.text.push(u); + } + else warn(`XFA - Invalid reference: ${i}.`); + } + } + _bindOccurrences(e, t, a) { + let r; + if (t.length > 1) { + r = e[is](); + r[Zs](r.occur); + r.occur = null; + } + this._bindValue(e, t[0], a); + this._setProperties(e, t[0]); + this._bindItems(e, t[0]); + if (1 === t.length) return; + const i = e[vs](), + n = e[Ws], + s = i[Ms](e); + for (let e = 1, o = t.length; e < o; e++) { + const o = t[e], + c = r[is](); + i[n].push(c); + i[Ds](s + e, c); + this._bindValue(c, o, a); + this._setProperties(c, o); + this._bindItems(c, o); + } + } + _createOccurrences(e) { + if (!this.emptyMerge) return; + const { occur: t } = e; + if (!t || t.initial <= 1) return; + const a = e[vs](), + r = e[Ws]; + if (!(a[r] instanceof XFAObjectArray)) return; + let i; + i = e.name + ? a[r].children.filter((t) => t.name === e.name).length + : a[r].children.length; + const n = a[Ms](e) + 1, + s = t.initial - i; + if (s) { + const t = e[is](); + t[Zs](t.occur); + t.occur = null; + a[r].push(t); + a[Ds](n, t); + for (let e = 1; e < s; e++) { + const i = t[is](); + a[r].push(i); + a[Ds](n + e, i); + } + } + } + _getOccurInfo(e) { + const { name: t, occur: a } = e; + if (!a || !t) return [1, 1]; + const r = -1 === a.max ? 1 / 0 : a.max; + return [a.min, r]; + } + _setAndBind(e, t) { + this._setProperties(e, t); + this._bindItems(e, t); + this._bindElement(e, t); + } + _bindElement(e, t) { + const a = []; + this._createOccurrences(e); + for (const r of e[Ss]()) { + if (r[os]) continue; + if (void 0 === this._mergeMode && "subform" === r[Ws]) { + this._mergeMode = "consumeData" === r.mergeMode; + const e = t[Ss](); + if (e.length > 0) this._bindOccurrences(r, [e[0]], null); + else if (this.emptyMerge) { + const e = t[Hs] === Zo ? -1 : t[Hs], + a = (r[os] = new XmlObject(e, r.name || "root")); + t[Qn](a); + this._bindElement(r, a); + } + continue; + } + if (!r[Rs]()) continue; + let e = !1, + i = null, + n = null, + s = null; + if (r.bind) { + switch (r.bind.match) { + case "none": + this._setAndBind(r, t); + continue; + case "global": + e = !0; + break; + case "dataRef": + if (!r.bind.ref) { + warn(`XFA - ref is empty in node ${r[Ws]}.`); + this._setAndBind(r, t); + continue; + } + n = r.bind.ref; + } + r.bind.picture && (i = r.bind.picture[ss]); + } + const [o, c] = this._getOccurInfo(r); + if (n) { + s = searchNode(this.root, t, n, !0, !1); + if (null === s) { + s = createDataNode(this.data, t, n); + if (!s) continue; + this._isConsumeData() && (s[ns] = !0); + this._setAndBind(r, s); + continue; + } + this._isConsumeData() && (s = s.filter((e) => !e[ns])); + s.length > c ? (s = s.slice(0, c)) : 0 === s.length && (s = null); + s && + this._isConsumeData() && + s.forEach((e) => { + e[ns] = !0; + }); + } else { + if (!r.name) { + this._setAndBind(r, t); + continue; + } + if (this._isConsumeData()) { + const a = []; + for (; a.length < c; ) { + const i = this._findDataByNameToConsume(r.name, r[Ts](), t, e); + if (!i) break; + i[ns] = !0; + a.push(i); + } + s = a.length > 0 ? a : null; + } else { + s = t[xs](r.name, !1, this.emptyMerge).next().value; + if (!s) { + if (0 === o) { + a.push(r); + continue; + } + const e = t[Hs] === Zo ? -1 : t[Hs]; + s = r[os] = new XmlObject(e, r.name); + this.emptyMerge && (s[ns] = !0); + t[Qn](s); + this._setAndBind(r, s); + continue; + } + this.emptyMerge && (s[ns] = !0); + s = [s]; + } + } + s + ? this._bindOccurrences(r, s, i) + : o > 0 + ? this._setAndBind(r, t) + : a.push(r); + } + a.forEach((e) => e[vs]()[Zs](e)); + } +} +class DataHandler { + constructor(e, t) { + this.data = t; + this.dataset = e.datasets || null; + } + serialize(e) { + const t = [[-1, this.data[Ss]()]]; + for (; t.length > 0; ) { + const a = t.at(-1), + [r, i] = a; + if (r + 1 === i.length) { + t.pop(); + continue; + } + const n = i[++a[0]], + s = e.get(n[uo]); + if (s) n[io](s); + else { + const t = n[fs](); + for (const a of t.values()) { + const t = e.get(a[uo]); + if (t) { + a[io](t); + break; + } + } + } + const o = n[Ss](); + o.length > 0 && t.push([-1, o]); + } + const a = [ + '', + ]; + if (this.dataset) + for (const e of this.dataset[Ss]()) "data" !== e[Ws] && e[lo](a); + this.data[lo](a); + a.push(""); + return a.join(""); + } +} +const Qo = go.config.id; +class Acrobat extends XFAObject { + constructor(e) { + super(Qo, "acrobat", !0); + this.acrobat7 = null; + this.autoSave = null; + this.common = null; + this.validate = null; + this.validateApprovalSignatures = null; + this.submitUrl = new XFAObjectArray(); + } +} +class Acrobat7 extends XFAObject { + constructor(e) { + super(Qo, "acrobat7", !0); + this.dynamicRender = null; + } +} +class ADBE_JSConsole extends OptionObject { + constructor(e) { + super(Qo, "ADBE_JSConsole", ["delegate", "Enable", "Disable"]); + } +} +class ADBE_JSDebugger extends OptionObject { + constructor(e) { + super(Qo, "ADBE_JSDebugger", ["delegate", "Enable", "Disable"]); + } +} +class AddSilentPrint extends Option01 { + constructor(e) { + super(Qo, "addSilentPrint"); + } +} +class AddViewerPreferences extends Option01 { + constructor(e) { + super(Qo, "addViewerPreferences"); + } +} +class AdjustData extends Option10 { + constructor(e) { + super(Qo, "adjustData"); + } +} +class AdobeExtensionLevel extends IntegerObject { + constructor(e) { + super(Qo, "adobeExtensionLevel", 0, (e) => e >= 1 && e <= 8); + } +} +class Agent extends XFAObject { + constructor(e) { + super(Qo, "agent", !0); + this.name = e.name ? e.name.trim() : ""; + this.common = new XFAObjectArray(); + } +} +class AlwaysEmbed extends ContentObject { + constructor(e) { + super(Qo, "alwaysEmbed"); + } +} +class Amd extends StringObject { + constructor(e) { + super(Qo, "amd"); + } +} +class config_Area extends XFAObject { + constructor(e) { + super(Qo, "area"); + this.level = getInteger({ + data: e.level, + defaultValue: 0, + validate: (e) => e >= 1 && e <= 3, + }); + this.name = getStringOption(e.name, [ + "", + "barcode", + "coreinit", + "deviceDriver", + "font", + "general", + "layout", + "merge", + "script", + "signature", + "sourceSet", + "templateCache", + ]); + } +} +class Attributes extends OptionObject { + constructor(e) { + super(Qo, "attributes", ["preserve", "delegate", "ignore"]); + } +} +class AutoSave extends OptionObject { + constructor(e) { + super(Qo, "autoSave", ["disabled", "enabled"]); + } +} +class Base extends StringObject { + constructor(e) { + super(Qo, "base"); + } +} +class BatchOutput extends XFAObject { + constructor(e) { + super(Qo, "batchOutput"); + this.format = getStringOption(e.format, [ + "none", + "concat", + "zip", + "zipCompress", + ]); + } +} +class BehaviorOverride extends ContentObject { + constructor(e) { + super(Qo, "behaviorOverride"); + } + [hs]() { + this[ss] = new Map( + this[ss] + .trim() + .split(/\s+/) + .filter((e) => e.includes(":")) + .map((e) => e.split(":", 2)), + ); + } +} +class Cache extends XFAObject { + constructor(e) { + super(Qo, "cache", !0); + this.templateCache = null; + } +} +class Change extends Option01 { + constructor(e) { + super(Qo, "change"); + } +} +class Common extends XFAObject { + constructor(e) { + super(Qo, "common", !0); + this.data = null; + this.locale = null; + this.localeSet = null; + this.messaging = null; + this.suppressBanner = null; + this.template = null; + this.validationMessaging = null; + this.versionControl = null; + this.log = new XFAObjectArray(); + } +} +class Compress extends XFAObject { + constructor(e) { + super(Qo, "compress"); + this.scope = getStringOption(e.scope, ["imageOnly", "document"]); + } +} +class CompressLogicalStructure extends Option01 { + constructor(e) { + super(Qo, "compressLogicalStructure"); + } +} +class CompressObjectStream extends Option10 { + constructor(e) { + super(Qo, "compressObjectStream"); + } +} +class Compression extends XFAObject { + constructor(e) { + super(Qo, "compression", !0); + this.compressLogicalStructure = null; + this.compressObjectStream = null; + this.level = null; + this.type = null; + } +} +class Config extends XFAObject { + constructor(e) { + super(Qo, "config", !0); + this.acrobat = null; + this.present = null; + this.trace = null; + this.agent = new XFAObjectArray(); + } +} +class Conformance extends OptionObject { + constructor(e) { + super(Qo, "conformance", ["A", "B"]); + } +} +class ContentCopy extends Option01 { + constructor(e) { + super(Qo, "contentCopy"); + } +} +class Copies extends IntegerObject { + constructor(e) { + super(Qo, "copies", 1, (e) => e >= 1); + } +} +class Creator extends StringObject { + constructor(e) { + super(Qo, "creator"); + } +} +class CurrentPage extends IntegerObject { + constructor(e) { + super(Qo, "currentPage", 0, (e) => e >= 0); + } +} +class Data extends XFAObject { + constructor(e) { + super(Qo, "data", !0); + this.adjustData = null; + this.attributes = null; + this.incrementalLoad = null; + this.outputXSL = null; + this.range = null; + this.record = null; + this.startNode = null; + this.uri = null; + this.window = null; + this.xsl = null; + this.excludeNS = new XFAObjectArray(); + this.transform = new XFAObjectArray(); + } +} +class Debug extends XFAObject { + constructor(e) { + super(Qo, "debug", !0); + this.uri = null; + } +} +class DefaultTypeface extends ContentObject { + constructor(e) { + super(Qo, "defaultTypeface"); + this.writingScript = getStringOption(e.writingScript, [ + "*", + "Arabic", + "Cyrillic", + "EastEuropeanRoman", + "Greek", + "Hebrew", + "Japanese", + "Korean", + "Roman", + "SimplifiedChinese", + "Thai", + "TraditionalChinese", + "Vietnamese", + ]); + } +} +class Destination extends OptionObject { + constructor(e) { + super(Qo, "destination", ["pdf", "pcl", "ps", "webClient", "zpl"]); + } +} +class DocumentAssembly extends Option01 { + constructor(e) { + super(Qo, "documentAssembly"); + } +} +class Driver extends XFAObject { + constructor(e) { + super(Qo, "driver", !0); + this.name = e.name ? e.name.trim() : ""; + this.fontInfo = null; + this.xdc = null; + } +} +class DuplexOption extends OptionObject { + constructor(e) { + super(Qo, "duplexOption", [ + "simplex", + "duplexFlipLongEdge", + "duplexFlipShortEdge", + ]); + } +} +class DynamicRender extends OptionObject { + constructor(e) { + super(Qo, "dynamicRender", ["forbidden", "required"]); + } +} +class Embed extends Option01 { + constructor(e) { + super(Qo, "embed"); + } +} +class config_Encrypt extends Option01 { + constructor(e) { + super(Qo, "encrypt"); + } +} +class config_Encryption extends XFAObject { + constructor(e) { + super(Qo, "encryption", !0); + this.encrypt = null; + this.encryptionLevel = null; + this.permissions = null; + } +} +class EncryptionLevel extends OptionObject { + constructor(e) { + super(Qo, "encryptionLevel", ["40bit", "128bit"]); + } +} +class Enforce extends StringObject { + constructor(e) { + super(Qo, "enforce"); + } +} +class Equate extends XFAObject { + constructor(e) { + super(Qo, "equate"); + this.force = getInteger({ + data: e.force, + defaultValue: 1, + validate: (e) => 0 === e, + }); + this.from = e.from || ""; + this.to = e.to || ""; + } +} +class EquateRange extends XFAObject { + constructor(e) { + super(Qo, "equateRange"); + this.from = e.from || ""; + this.to = e.to || ""; + this._unicodeRange = e.unicodeRange || ""; + } + get unicodeRange() { + const e = [], + t = /U\+([0-9a-fA-F]+)/, + a = this._unicodeRange; + for (let r of a + .split(",") + .map((e) => e.trim()) + .filter((e) => !!e)) { + r = r.split("-", 2).map((e) => { + const a = e.match(t); + return a ? parseInt(a[1], 16) : 0; + }); + 1 === r.length && r.push(r[0]); + e.push(r); + } + return shadow(this, "unicodeRange", e); + } +} +class Exclude extends ContentObject { + constructor(e) { + super(Qo, "exclude"); + } + [hs]() { + this[ss] = this[ss] + .trim() + .split(/\s+/) + .filter( + (e) => + e && + [ + "calculate", + "close", + "enter", + "exit", + "initialize", + "ready", + "validate", + ].includes(e), + ); + } +} +class ExcludeNS extends StringObject { + constructor(e) { + super(Qo, "excludeNS"); + } +} +class FlipLabel extends OptionObject { + constructor(e) { + super(Qo, "flipLabel", ["usePrinterSetting", "on", "off"]); + } +} +class config_FontInfo extends XFAObject { + constructor(e) { + super(Qo, "fontInfo", !0); + this.embed = null; + this.map = null; + this.subsetBelow = null; + this.alwaysEmbed = new XFAObjectArray(); + this.defaultTypeface = new XFAObjectArray(); + this.neverEmbed = new XFAObjectArray(); + } +} +class FormFieldFilling extends Option01 { + constructor(e) { + super(Qo, "formFieldFilling"); + } +} +class GroupParent extends StringObject { + constructor(e) { + super(Qo, "groupParent"); + } +} +class IfEmpty extends OptionObject { + constructor(e) { + super(Qo, "ifEmpty", ["dataValue", "dataGroup", "ignore", "remove"]); + } +} +class IncludeXDPContent extends StringObject { + constructor(e) { + super(Qo, "includeXDPContent"); + } +} +class IncrementalLoad extends OptionObject { + constructor(e) { + super(Qo, "incrementalLoad", ["none", "forwardOnly"]); + } +} +class IncrementalMerge extends Option01 { + constructor(e) { + super(Qo, "incrementalMerge"); + } +} +class Interactive extends Option01 { + constructor(e) { + super(Qo, "interactive"); + } +} +class Jog extends OptionObject { + constructor(e) { + super(Qo, "jog", ["usePrinterSetting", "none", "pageSet"]); + } +} +class LabelPrinter extends XFAObject { + constructor(e) { + super(Qo, "labelPrinter", !0); + this.name = getStringOption(e.name, ["zpl", "dpl", "ipl", "tcpl"]); + this.batchOutput = null; + this.flipLabel = null; + this.fontInfo = null; + this.xdc = null; + } +} +class Layout extends OptionObject { + constructor(e) { + super(Qo, "layout", ["paginate", "panel"]); + } +} +class Level extends IntegerObject { + constructor(e) { + super(Qo, "level", 0, (e) => e > 0); + } +} +class Linearized extends Option01 { + constructor(e) { + super(Qo, "linearized"); + } +} +class Locale extends StringObject { + constructor(e) { + super(Qo, "locale"); + } +} +class LocaleSet extends StringObject { + constructor(e) { + super(Qo, "localeSet"); + } +} +class Log extends XFAObject { + constructor(e) { + super(Qo, "log", !0); + this.mode = null; + this.threshold = null; + this.to = null; + this.uri = null; + } +} +class MapElement extends XFAObject { + constructor(e) { + super(Qo, "map", !0); + this.equate = new XFAObjectArray(); + this.equateRange = new XFAObjectArray(); + } +} +class MediumInfo extends XFAObject { + constructor(e) { + super(Qo, "mediumInfo", !0); + this.map = null; + } +} +class config_Message extends XFAObject { + constructor(e) { + super(Qo, "message", !0); + this.msgId = null; + this.severity = null; + } +} +class Messaging extends XFAObject { + constructor(e) { + super(Qo, "messaging", !0); + this.message = new XFAObjectArray(); + } +} +class Mode extends OptionObject { + constructor(e) { + super(Qo, "mode", ["append", "overwrite"]); + } +} +class ModifyAnnots extends Option01 { + constructor(e) { + super(Qo, "modifyAnnots"); + } +} +class MsgId extends IntegerObject { + constructor(e) { + super(Qo, "msgId", 1, (e) => e >= 1); + } +} +class NameAttr extends StringObject { + constructor(e) { + super(Qo, "nameAttr"); + } +} +class NeverEmbed extends ContentObject { + constructor(e) { + super(Qo, "neverEmbed"); + } +} +class NumberOfCopies extends IntegerObject { + constructor(e) { + super(Qo, "numberOfCopies", null, (e) => e >= 2 && e <= 5); + } +} +class OpenAction extends XFAObject { + constructor(e) { + super(Qo, "openAction", !0); + this.destination = null; + } +} +class Output extends XFAObject { + constructor(e) { + super(Qo, "output", !0); + this.to = null; + this.type = null; + this.uri = null; + } +} +class OutputBin extends StringObject { + constructor(e) { + super(Qo, "outputBin"); + } +} +class OutputXSL extends XFAObject { + constructor(e) { + super(Qo, "outputXSL", !0); + this.uri = null; + } +} +class Overprint extends OptionObject { + constructor(e) { + super(Qo, "overprint", ["none", "both", "draw", "field"]); + } +} +class Packets extends StringObject { + constructor(e) { + super(Qo, "packets"); + } + [hs]() { + "*" !== this[ss] && + (this[ss] = this[ss] + .trim() + .split(/\s+/) + .filter((e) => + ["config", "datasets", "template", "xfdf", "xslt"].includes(e), + )); + } +} +class PageOffset extends XFAObject { + constructor(e) { + super(Qo, "pageOffset"); + this.x = getInteger({ + data: e.x, + defaultValue: "useXDCSetting", + validate: (e) => !0, + }); + this.y = getInteger({ + data: e.y, + defaultValue: "useXDCSetting", + validate: (e) => !0, + }); + } +} +class PageRange extends StringObject { + constructor(e) { + super(Qo, "pageRange"); + } + [hs]() { + const e = this[ss] + .trim() + .split(/\s+/) + .map((e) => parseInt(e, 10)), + t = []; + for (let a = 0, r = e.length; a < r; a += 2) t.push(e.slice(a, a + 2)); + this[ss] = t; + } +} +class Pagination extends OptionObject { + constructor(e) { + super(Qo, "pagination", ["simplex", "duplexShortEdge", "duplexLongEdge"]); + } +} +class PaginationOverride extends OptionObject { + constructor(e) { + super(Qo, "paginationOverride", [ + "none", + "forceDuplex", + "forceDuplexLongEdge", + "forceDuplexShortEdge", + "forceSimplex", + ]); + } +} +class Part extends IntegerObject { + constructor(e) { + super(Qo, "part", 1, (e) => !1); + } +} +class Pcl extends XFAObject { + constructor(e) { + super(Qo, "pcl", !0); + this.name = e.name || ""; + this.batchOutput = null; + this.fontInfo = null; + this.jog = null; + this.mediumInfo = null; + this.outputBin = null; + this.pageOffset = null; + this.staple = null; + this.xdc = null; + } +} +class Pdf extends XFAObject { + constructor(e) { + super(Qo, "pdf", !0); + this.name = e.name || ""; + this.adobeExtensionLevel = null; + this.batchOutput = null; + this.compression = null; + this.creator = null; + this.encryption = null; + this.fontInfo = null; + this.interactive = null; + this.linearized = null; + this.openAction = null; + this.pdfa = null; + this.producer = null; + this.renderPolicy = null; + this.scriptModel = null; + this.silentPrint = null; + this.submitFormat = null; + this.tagged = null; + this.version = null; + this.viewerPreferences = null; + this.xdc = null; + } +} +class Pdfa extends XFAObject { + constructor(e) { + super(Qo, "pdfa", !0); + this.amd = null; + this.conformance = null; + this.includeXDPContent = null; + this.part = null; + } +} +class Permissions extends XFAObject { + constructor(e) { + super(Qo, "permissions", !0); + this.accessibleContent = null; + this.change = null; + this.contentCopy = null; + this.documentAssembly = null; + this.formFieldFilling = null; + this.modifyAnnots = null; + this.plaintextMetadata = null; + this.print = null; + this.printHighQuality = null; + } +} +class PickTrayByPDFSize extends Option01 { + constructor(e) { + super(Qo, "pickTrayByPDFSize"); + } +} +class config_Picture extends StringObject { + constructor(e) { + super(Qo, "picture"); + } +} +class PlaintextMetadata extends Option01 { + constructor(e) { + super(Qo, "plaintextMetadata"); + } +} +class Presence extends OptionObject { + constructor(e) { + super(Qo, "presence", [ + "preserve", + "dissolve", + "dissolveStructure", + "ignore", + "remove", + ]); + } +} +class Present extends XFAObject { + constructor(e) { + super(Qo, "present", !0); + this.behaviorOverride = null; + this.cache = null; + this.common = null; + this.copies = null; + this.destination = null; + this.incrementalMerge = null; + this.layout = null; + this.output = null; + this.overprint = null; + this.pagination = null; + this.paginationOverride = null; + this.script = null; + this.validate = null; + this.xdp = null; + this.driver = new XFAObjectArray(); + this.labelPrinter = new XFAObjectArray(); + this.pcl = new XFAObjectArray(); + this.pdf = new XFAObjectArray(); + this.ps = new XFAObjectArray(); + this.submitUrl = new XFAObjectArray(); + this.webClient = new XFAObjectArray(); + this.zpl = new XFAObjectArray(); + } +} +class Print extends Option01 { + constructor(e) { + super(Qo, "print"); + } +} +class PrintHighQuality extends Option01 { + constructor(e) { + super(Qo, "printHighQuality"); + } +} +class PrintScaling extends OptionObject { + constructor(e) { + super(Qo, "printScaling", ["appdefault", "noScaling"]); + } +} +class PrinterName extends StringObject { + constructor(e) { + super(Qo, "printerName"); + } +} +class Producer extends StringObject { + constructor(e) { + super(Qo, "producer"); + } +} +class Ps extends XFAObject { + constructor(e) { + super(Qo, "ps", !0); + this.name = e.name || ""; + this.batchOutput = null; + this.fontInfo = null; + this.jog = null; + this.mediumInfo = null; + this.outputBin = null; + this.staple = null; + this.xdc = null; + } +} +class Range extends ContentObject { + constructor(e) { + super(Qo, "range"); + } + [hs]() { + this[ss] = this[ss] + .split(",", 2) + .map((e) => e.split("-").map((e) => parseInt(e.trim(), 10))) + .filter((e) => e.every((e) => !isNaN(e))) + .map((e) => { + 1 === e.length && e.push(e[0]); + return e; + }); + } +} +class Record extends ContentObject { + constructor(e) { + super(Qo, "record"); + } + [hs]() { + this[ss] = this[ss].trim(); + const e = parseInt(this[ss], 10); + !isNaN(e) && e >= 0 && (this[ss] = e); + } +} +class Relevant extends ContentObject { + constructor(e) { + super(Qo, "relevant"); + } + [hs]() { + this[ss] = this[ss].trim().split(/\s+/); + } +} +class Rename extends ContentObject { + constructor(e) { + super(Qo, "rename"); + } + [hs]() { + this[ss] = this[ss].trim(); + (this[ss].toLowerCase().startsWith("xml") || + new RegExp("[\\p{L}_][\\p{L}\\d._\\p{M}-]*", "u").test(this[ss])) && + warn("XFA - Rename: invalid XFA name"); + } +} +class RenderPolicy extends OptionObject { + constructor(e) { + super(Qo, "renderPolicy", ["server", "client"]); + } +} +class RunScripts extends OptionObject { + constructor(e) { + super(Qo, "runScripts", ["both", "client", "none", "server"]); + } +} +class config_Script extends XFAObject { + constructor(e) { + super(Qo, "script", !0); + this.currentPage = null; + this.exclude = null; + this.runScripts = null; + } +} +class ScriptModel extends OptionObject { + constructor(e) { + super(Qo, "scriptModel", ["XFA", "none"]); + } +} +class Severity extends OptionObject { + constructor(e) { + super(Qo, "severity", [ + "ignore", + "error", + "information", + "trace", + "warning", + ]); + } +} +class SilentPrint extends XFAObject { + constructor(e) { + super(Qo, "silentPrint", !0); + this.addSilentPrint = null; + this.printerName = null; + } +} +class Staple extends XFAObject { + constructor(e) { + super(Qo, "staple"); + this.mode = getStringOption(e.mode, ["usePrinterSetting", "on", "off"]); + } +} +class StartNode extends StringObject { + constructor(e) { + super(Qo, "startNode"); + } +} +class StartPage extends IntegerObject { + constructor(e) { + super(Qo, "startPage", 0, (e) => !0); + } +} +class SubmitFormat extends OptionObject { + constructor(e) { + super(Qo, "submitFormat", ["html", "delegate", "fdf", "xml", "pdf"]); + } +} +class SubmitUrl extends StringObject { + constructor(e) { + super(Qo, "submitUrl"); + } +} +class SubsetBelow extends IntegerObject { + constructor(e) { + super(Qo, "subsetBelow", 100, (e) => e >= 0 && e <= 100); + } +} +class SuppressBanner extends Option01 { + constructor(e) { + super(Qo, "suppressBanner"); + } +} +class Tagged extends Option01 { + constructor(e) { + super(Qo, "tagged"); + } +} +class config_Template extends XFAObject { + constructor(e) { + super(Qo, "template", !0); + this.base = null; + this.relevant = null; + this.startPage = null; + this.uri = null; + this.xsl = null; + } +} +class Threshold extends OptionObject { + constructor(e) { + super(Qo, "threshold", ["trace", "error", "information", "warning"]); + } +} +class To extends OptionObject { + constructor(e) { + super(Qo, "to", ["null", "memory", "stderr", "stdout", "system", "uri"]); + } +} +class TemplateCache extends XFAObject { + constructor(e) { + super(Qo, "templateCache"); + this.maxEntries = getInteger({ + data: e.maxEntries, + defaultValue: 5, + validate: (e) => e >= 0, + }); + } +} +class Trace extends XFAObject { + constructor(e) { + super(Qo, "trace", !0); + this.area = new XFAObjectArray(); + } +} +class Transform extends XFAObject { + constructor(e) { + super(Qo, "transform", !0); + this.groupParent = null; + this.ifEmpty = null; + this.nameAttr = null; + this.picture = null; + this.presence = null; + this.rename = null; + this.whitespace = null; + } +} +class Type extends OptionObject { + constructor(e) { + super(Qo, "type", [ + "none", + "ascii85", + "asciiHex", + "ccittfax", + "flate", + "lzw", + "runLength", + "native", + "xdp", + "mergedXDP", + ]); + } +} +class Uri extends StringObject { + constructor(e) { + super(Qo, "uri"); + } +} +class config_Validate extends OptionObject { + constructor(e) { + super(Qo, "validate", ["preSubmit", "prePrint", "preExecute", "preSave"]); + } +} +class ValidateApprovalSignatures extends ContentObject { + constructor(e) { + super(Qo, "validateApprovalSignatures"); + } + [hs]() { + this[ss] = this[ss] + .trim() + .split(/\s+/) + .filter((e) => ["docReady", "postSign"].includes(e)); + } +} +class ValidationMessaging extends OptionObject { + constructor(e) { + super(Qo, "validationMessaging", [ + "allMessagesIndividually", + "allMessagesTogether", + "firstMessageOnly", + "noMessages", + ]); + } +} +class Version extends OptionObject { + constructor(e) { + super(Qo, "version", ["1.7", "1.6", "1.5", "1.4", "1.3", "1.2"]); + } +} +class VersionControl extends XFAObject { + constructor(e) { + super(Qo, "VersionControl"); + this.outputBelow = getStringOption(e.outputBelow, [ + "warn", + "error", + "update", + ]); + this.sourceAbove = getStringOption(e.sourceAbove, ["warn", "error"]); + this.sourceBelow = getStringOption(e.sourceBelow, ["update", "maintain"]); + } +} +class ViewerPreferences extends XFAObject { + constructor(e) { + super(Qo, "viewerPreferences", !0); + this.ADBE_JSConsole = null; + this.ADBE_JSDebugger = null; + this.addViewerPreferences = null; + this.duplexOption = null; + this.enforce = null; + this.numberOfCopies = null; + this.pageRange = null; + this.pickTrayByPDFSize = null; + this.printScaling = null; + } +} +class WebClient extends XFAObject { + constructor(e) { + super(Qo, "webClient", !0); + this.name = e.name ? e.name.trim() : ""; + this.fontInfo = null; + this.xdc = null; + } +} +class Whitespace extends OptionObject { + constructor(e) { + super(Qo, "whitespace", [ + "preserve", + "ltrim", + "normalize", + "rtrim", + "trim", + ]); + } +} +class Window extends ContentObject { + constructor(e) { + super(Qo, "window"); + } + [hs]() { + const e = this[ss].split(",", 2).map((e) => parseInt(e.trim(), 10)); + if (e.some((e) => isNaN(e))) this[ss] = [0, 0]; + else { + 1 === e.length && e.push(e[0]); + this[ss] = e; + } + } +} +class Xdc extends XFAObject { + constructor(e) { + super(Qo, "xdc", !0); + this.uri = new XFAObjectArray(); + this.xsl = new XFAObjectArray(); + } +} +class Xdp extends XFAObject { + constructor(e) { + super(Qo, "xdp", !0); + this.packets = null; + } +} +class Xsl extends XFAObject { + constructor(e) { + super(Qo, "xsl", !0); + this.debug = null; + this.uri = null; + } +} +class Zpl extends XFAObject { + constructor(e) { + super(Qo, "zpl", !0); + this.name = e.name ? e.name.trim() : ""; + this.batchOutput = null; + this.flipLabel = null; + this.fontInfo = null; + this.xdc = null; + } +} +class ConfigNamespace { + static [fo](e, t) { + if (ConfigNamespace.hasOwnProperty(e)) return ConfigNamespace[e](t); + } + static acrobat(e) { + return new Acrobat(e); + } + static acrobat7(e) { + return new Acrobat7(e); + } + static ADBE_JSConsole(e) { + return new ADBE_JSConsole(e); + } + static ADBE_JSDebugger(e) { + return new ADBE_JSDebugger(e); + } + static addSilentPrint(e) { + return new AddSilentPrint(e); + } + static addViewerPreferences(e) { + return new AddViewerPreferences(e); + } + static adjustData(e) { + return new AdjustData(e); + } + static adobeExtensionLevel(e) { + return new AdobeExtensionLevel(e); + } + static agent(e) { + return new Agent(e); + } + static alwaysEmbed(e) { + return new AlwaysEmbed(e); + } + static amd(e) { + return new Amd(e); + } + static area(e) { + return new config_Area(e); + } + static attributes(e) { + return new Attributes(e); + } + static autoSave(e) { + return new AutoSave(e); + } + static base(e) { + return new Base(e); + } + static batchOutput(e) { + return new BatchOutput(e); + } + static behaviorOverride(e) { + return new BehaviorOverride(e); + } + static cache(e) { + return new Cache(e); + } + static change(e) { + return new Change(e); + } + static common(e) { + return new Common(e); + } + static compress(e) { + return new Compress(e); + } + static compressLogicalStructure(e) { + return new CompressLogicalStructure(e); + } + static compressObjectStream(e) { + return new CompressObjectStream(e); + } + static compression(e) { + return new Compression(e); + } + static config(e) { + return new Config(e); + } + static conformance(e) { + return new Conformance(e); + } + static contentCopy(e) { + return new ContentCopy(e); + } + static copies(e) { + return new Copies(e); + } + static creator(e) { + return new Creator(e); + } + static currentPage(e) { + return new CurrentPage(e); + } + static data(e) { + return new Data(e); + } + static debug(e) { + return new Debug(e); + } + static defaultTypeface(e) { + return new DefaultTypeface(e); + } + static destination(e) { + return new Destination(e); + } + static documentAssembly(e) { + return new DocumentAssembly(e); + } + static driver(e) { + return new Driver(e); + } + static duplexOption(e) { + return new DuplexOption(e); + } + static dynamicRender(e) { + return new DynamicRender(e); + } + static embed(e) { + return new Embed(e); + } + static encrypt(e) { + return new config_Encrypt(e); + } + static encryption(e) { + return new config_Encryption(e); + } + static encryptionLevel(e) { + return new EncryptionLevel(e); + } + static enforce(e) { + return new Enforce(e); + } + static equate(e) { + return new Equate(e); + } + static equateRange(e) { + return new EquateRange(e); + } + static exclude(e) { + return new Exclude(e); + } + static excludeNS(e) { + return new ExcludeNS(e); + } + static flipLabel(e) { + return new FlipLabel(e); + } + static fontInfo(e) { + return new config_FontInfo(e); + } + static formFieldFilling(e) { + return new FormFieldFilling(e); + } + static groupParent(e) { + return new GroupParent(e); + } + static ifEmpty(e) { + return new IfEmpty(e); + } + static includeXDPContent(e) { + return new IncludeXDPContent(e); + } + static incrementalLoad(e) { + return new IncrementalLoad(e); + } + static incrementalMerge(e) { + return new IncrementalMerge(e); + } + static interactive(e) { + return new Interactive(e); + } + static jog(e) { + return new Jog(e); + } + static labelPrinter(e) { + return new LabelPrinter(e); + } + static layout(e) { + return new Layout(e); + } + static level(e) { + return new Level(e); + } + static linearized(e) { + return new Linearized(e); + } + static locale(e) { + return new Locale(e); + } + static localeSet(e) { + return new LocaleSet(e); + } + static log(e) { + return new Log(e); + } + static map(e) { + return new MapElement(e); + } + static mediumInfo(e) { + return new MediumInfo(e); + } + static message(e) { + return new config_Message(e); + } + static messaging(e) { + return new Messaging(e); + } + static mode(e) { + return new Mode(e); + } + static modifyAnnots(e) { + return new ModifyAnnots(e); + } + static msgId(e) { + return new MsgId(e); + } + static nameAttr(e) { + return new NameAttr(e); + } + static neverEmbed(e) { + return new NeverEmbed(e); + } + static numberOfCopies(e) { + return new NumberOfCopies(e); + } + static openAction(e) { + return new OpenAction(e); + } + static output(e) { + return new Output(e); + } + static outputBin(e) { + return new OutputBin(e); + } + static outputXSL(e) { + return new OutputXSL(e); + } + static overprint(e) { + return new Overprint(e); + } + static packets(e) { + return new Packets(e); + } + static pageOffset(e) { + return new PageOffset(e); + } + static pageRange(e) { + return new PageRange(e); + } + static pagination(e) { + return new Pagination(e); + } + static paginationOverride(e) { + return new PaginationOverride(e); + } + static part(e) { + return new Part(e); + } + static pcl(e) { + return new Pcl(e); + } + static pdf(e) { + return new Pdf(e); + } + static pdfa(e) { + return new Pdfa(e); + } + static permissions(e) { + return new Permissions(e); + } + static pickTrayByPDFSize(e) { + return new PickTrayByPDFSize(e); + } + static picture(e) { + return new config_Picture(e); + } + static plaintextMetadata(e) { + return new PlaintextMetadata(e); + } + static presence(e) { + return new Presence(e); + } + static present(e) { + return new Present(e); + } + static print(e) { + return new Print(e); + } + static printHighQuality(e) { + return new PrintHighQuality(e); + } + static printScaling(e) { + return new PrintScaling(e); + } + static printerName(e) { + return new PrinterName(e); + } + static producer(e) { + return new Producer(e); + } + static ps(e) { + return new Ps(e); + } + static range(e) { + return new Range(e); + } + static record(e) { + return new Record(e); + } + static relevant(e) { + return new Relevant(e); + } + static rename(e) { + return new Rename(e); + } + static renderPolicy(e) { + return new RenderPolicy(e); + } + static runScripts(e) { + return new RunScripts(e); + } + static script(e) { + return new config_Script(e); + } + static scriptModel(e) { + return new ScriptModel(e); + } + static severity(e) { + return new Severity(e); + } + static silentPrint(e) { + return new SilentPrint(e); + } + static staple(e) { + return new Staple(e); + } + static startNode(e) { + return new StartNode(e); + } + static startPage(e) { + return new StartPage(e); + } + static submitFormat(e) { + return new SubmitFormat(e); + } + static submitUrl(e) { + return new SubmitUrl(e); + } + static subsetBelow(e) { + return new SubsetBelow(e); + } + static suppressBanner(e) { + return new SuppressBanner(e); + } + static tagged(e) { + return new Tagged(e); + } + static template(e) { + return new config_Template(e); + } + static templateCache(e) { + return new TemplateCache(e); + } + static threshold(e) { + return new Threshold(e); + } + static to(e) { + return new To(e); + } + static trace(e) { + return new Trace(e); + } + static transform(e) { + return new Transform(e); + } + static type(e) { + return new Type(e); + } + static uri(e) { + return new Uri(e); + } + static validate(e) { + return new config_Validate(e); + } + static validateApprovalSignatures(e) { + return new ValidateApprovalSignatures(e); + } + static validationMessaging(e) { + return new ValidationMessaging(e); + } + static version(e) { + return new Version(e); + } + static versionControl(e) { + return new VersionControl(e); + } + static viewerPreferences(e) { + return new ViewerPreferences(e); + } + static webClient(e) { + return new WebClient(e); + } + static whitespace(e) { + return new Whitespace(e); + } + static window(e) { + return new Window(e); + } + static xdc(e) { + return new Xdc(e); + } + static xdp(e) { + return new Xdp(e); + } + static xsl(e) { + return new Xsl(e); + } + static zpl(e) { + return new Zpl(e); + } +} +const ec = go.connectionSet.id; +class ConnectionSet extends XFAObject { + constructor(e) { + super(ec, "connectionSet", !0); + this.wsdlConnection = new XFAObjectArray(); + this.xmlConnection = new XFAObjectArray(); + this.xsdConnection = new XFAObjectArray(); + } +} +class EffectiveInputPolicy extends XFAObject { + constructor(e) { + super(ec, "effectiveInputPolicy"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class EffectiveOutputPolicy extends XFAObject { + constructor(e) { + super(ec, "effectiveOutputPolicy"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class Operation extends StringObject { + constructor(e) { + super(ec, "operation"); + this.id = e.id || ""; + this.input = e.input || ""; + this.name = e.name || ""; + this.output = e.output || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class RootElement extends StringObject { + constructor(e) { + super(ec, "rootElement"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class SoapAction extends StringObject { + constructor(e) { + super(ec, "soapAction"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class SoapAddress extends StringObject { + constructor(e) { + super(ec, "soapAddress"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class connection_set_Uri extends StringObject { + constructor(e) { + super(ec, "uri"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class WsdlAddress extends StringObject { + constructor(e) { + super(ec, "wsdlAddress"); + this.id = e.id || ""; + this.name = e.name || ""; + this.use = e.use || ""; + this.usehref = e.usehref || ""; + } +} +class WsdlConnection extends XFAObject { + constructor(e) { + super(ec, "wsdlConnection", !0); + this.dataDescription = e.dataDescription || ""; + this.name = e.name || ""; + this.effectiveInputPolicy = null; + this.effectiveOutputPolicy = null; + this.operation = null; + this.soapAction = null; + this.soapAddress = null; + this.wsdlAddress = null; + } +} +class XmlConnection extends XFAObject { + constructor(e) { + super(ec, "xmlConnection", !0); + this.dataDescription = e.dataDescription || ""; + this.name = e.name || ""; + this.uri = null; + } +} +class XsdConnection extends XFAObject { + constructor(e) { + super(ec, "xsdConnection", !0); + this.dataDescription = e.dataDescription || ""; + this.name = e.name || ""; + this.rootElement = null; + this.uri = null; + } +} +class ConnectionSetNamespace { + static [fo](e, t) { + if (ConnectionSetNamespace.hasOwnProperty(e)) + return ConnectionSetNamespace[e](t); + } + static connectionSet(e) { + return new ConnectionSet(e); + } + static effectiveInputPolicy(e) { + return new EffectiveInputPolicy(e); + } + static effectiveOutputPolicy(e) { + return new EffectiveOutputPolicy(e); + } + static operation(e) { + return new Operation(e); + } + static rootElement(e) { + return new RootElement(e); + } + static soapAction(e) { + return new SoapAction(e); + } + static soapAddress(e) { + return new SoapAddress(e); + } + static uri(e) { + return new connection_set_Uri(e); + } + static wsdlAddress(e) { + return new WsdlAddress(e); + } + static wsdlConnection(e) { + return new WsdlConnection(e); + } + static xmlConnection(e) { + return new XmlConnection(e); + } + static xsdConnection(e) { + return new XsdConnection(e); + } +} +const tc = go.datasets.id; +class datasets_Data extends XmlObject { + constructor(e) { + super(tc, "data", e); + } + [Ls]() { + return !0; + } +} +class Datasets extends XFAObject { + constructor(e) { + super(tc, "datasets", !0); + this.data = null; + this.Signature = null; + } + [$s](e) { + const t = e[Ws]; + (("data" === t && e[Hs] === tc) || + ("Signature" === t && e[Hs] === go.signature.id)) && + (this[t] = e); + this[Qn](e); + } +} +class DatasetsNamespace { + static [fo](e, t) { + if (DatasetsNamespace.hasOwnProperty(e)) return DatasetsNamespace[e](t); + } + static datasets(e) { + return new Datasets(e); + } + static data(e) { + return new datasets_Data(e); + } +} +const ac = go.localeSet.id; +class CalendarSymbols extends XFAObject { + constructor(e) { + super(ac, "calendarSymbols", !0); + this.name = "gregorian"; + this.dayNames = new XFAObjectArray(2); + this.eraNames = null; + this.meridiemNames = null; + this.monthNames = new XFAObjectArray(2); + } +} +class CurrencySymbol extends StringObject { + constructor(e) { + super(ac, "currencySymbol"); + this.name = getStringOption(e.name, ["symbol", "isoname", "decimal"]); + } +} +class CurrencySymbols extends XFAObject { + constructor(e) { + super(ac, "currencySymbols", !0); + this.currencySymbol = new XFAObjectArray(3); + } +} +class DatePattern extends StringObject { + constructor(e) { + super(ac, "datePattern"); + this.name = getStringOption(e.name, ["full", "long", "med", "short"]); + } +} +class DatePatterns extends XFAObject { + constructor(e) { + super(ac, "datePatterns", !0); + this.datePattern = new XFAObjectArray(4); + } +} +class DateTimeSymbols extends ContentObject { + constructor(e) { + super(ac, "dateTimeSymbols"); + } +} +class Day extends StringObject { + constructor(e) { + super(ac, "day"); + } +} +class DayNames extends XFAObject { + constructor(e) { + super(ac, "dayNames", !0); + this.abbr = getInteger({ + data: e.abbr, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.day = new XFAObjectArray(7); + } +} +class Era extends StringObject { + constructor(e) { + super(ac, "era"); + } +} +class EraNames extends XFAObject { + constructor(e) { + super(ac, "eraNames", !0); + this.era = new XFAObjectArray(2); + } +} +class locale_set_Locale extends XFAObject { + constructor(e) { + super(ac, "locale", !0); + this.desc = e.desc || ""; + this.name = "isoname"; + this.calendarSymbols = null; + this.currencySymbols = null; + this.datePatterns = null; + this.dateTimeSymbols = null; + this.numberPatterns = null; + this.numberSymbols = null; + this.timePatterns = null; + this.typeFaces = null; + } +} +class locale_set_LocaleSet extends XFAObject { + constructor(e) { + super(ac, "localeSet", !0); + this.locale = new XFAObjectArray(); + } +} +class Meridiem extends StringObject { + constructor(e) { + super(ac, "meridiem"); + } +} +class MeridiemNames extends XFAObject { + constructor(e) { + super(ac, "meridiemNames", !0); + this.meridiem = new XFAObjectArray(2); + } +} +class Month extends StringObject { + constructor(e) { + super(ac, "month"); + } +} +class MonthNames extends XFAObject { + constructor(e) { + super(ac, "monthNames", !0); + this.abbr = getInteger({ + data: e.abbr, + defaultValue: 0, + validate: (e) => 1 === e, + }); + this.month = new XFAObjectArray(12); + } +} +class NumberPattern extends StringObject { + constructor(e) { + super(ac, "numberPattern"); + this.name = getStringOption(e.name, ["full", "long", "med", "short"]); + } +} +class NumberPatterns extends XFAObject { + constructor(e) { + super(ac, "numberPatterns", !0); + this.numberPattern = new XFAObjectArray(4); + } +} +class NumberSymbol extends StringObject { + constructor(e) { + super(ac, "numberSymbol"); + this.name = getStringOption(e.name, [ + "decimal", + "grouping", + "percent", + "minus", + "zero", + ]); + } +} +class NumberSymbols extends XFAObject { + constructor(e) { + super(ac, "numberSymbols", !0); + this.numberSymbol = new XFAObjectArray(5); + } +} +class TimePattern extends StringObject { + constructor(e) { + super(ac, "timePattern"); + this.name = getStringOption(e.name, ["full", "long", "med", "short"]); + } +} +class TimePatterns extends XFAObject { + constructor(e) { + super(ac, "timePatterns", !0); + this.timePattern = new XFAObjectArray(4); + } +} +class TypeFace extends XFAObject { + constructor(e) { + super(ac, "typeFace", !0); + this.name = "" | e.name; + } +} +class TypeFaces extends XFAObject { + constructor(e) { + super(ac, "typeFaces", !0); + this.typeFace = new XFAObjectArray(); + } +} +class LocaleSetNamespace { + static [fo](e, t) { + if (LocaleSetNamespace.hasOwnProperty(e)) return LocaleSetNamespace[e](t); + } + static calendarSymbols(e) { + return new CalendarSymbols(e); + } + static currencySymbol(e) { + return new CurrencySymbol(e); + } + static currencySymbols(e) { + return new CurrencySymbols(e); + } + static datePattern(e) { + return new DatePattern(e); + } + static datePatterns(e) { + return new DatePatterns(e); + } + static dateTimeSymbols(e) { + return new DateTimeSymbols(e); + } + static day(e) { + return new Day(e); + } + static dayNames(e) { + return new DayNames(e); + } + static era(e) { + return new Era(e); + } + static eraNames(e) { + return new EraNames(e); + } + static locale(e) { + return new locale_set_Locale(e); + } + static localeSet(e) { + return new locale_set_LocaleSet(e); + } + static meridiem(e) { + return new Meridiem(e); + } + static meridiemNames(e) { + return new MeridiemNames(e); + } + static month(e) { + return new Month(e); + } + static monthNames(e) { + return new MonthNames(e); + } + static numberPattern(e) { + return new NumberPattern(e); + } + static numberPatterns(e) { + return new NumberPatterns(e); + } + static numberSymbol(e) { + return new NumberSymbol(e); + } + static numberSymbols(e) { + return new NumberSymbols(e); + } + static timePattern(e) { + return new TimePattern(e); + } + static timePatterns(e) { + return new TimePatterns(e); + } + static typeFace(e) { + return new TypeFace(e); + } + static typeFaces(e) { + return new TypeFaces(e); + } +} +const rc = go.signature.id; +class signature_Signature extends XFAObject { + constructor(e) { + super(rc, "signature", !0); + } +} +class SignatureNamespace { + static [fo](e, t) { + if (SignatureNamespace.hasOwnProperty(e)) return SignatureNamespace[e](t); + } + static signature(e) { + return new signature_Signature(e); + } +} +const ic = go.stylesheet.id; +class Stylesheet extends XFAObject { + constructor(e) { + super(ic, "stylesheet", !0); + } +} +class StylesheetNamespace { + static [fo](e, t) { + if (StylesheetNamespace.hasOwnProperty(e)) return StylesheetNamespace[e](t); + } + static stylesheet(e) { + return new Stylesheet(e); + } +} +const nc = go.xdp.id; +class xdp_Xdp extends XFAObject { + constructor(e) { + super(nc, "xdp", !0); + this.uuid = e.uuid || ""; + this.timeStamp = e.timeStamp || ""; + this.config = null; + this.connectionSet = null; + this.datasets = null; + this.localeSet = null; + this.stylesheet = new XFAObjectArray(); + this.template = null; + } + [Gs](e) { + const t = go[e[Ws]]; + return t && e[Hs] === t.id; + } +} +class XdpNamespace { + static [fo](e, t) { + if (XdpNamespace.hasOwnProperty(e)) return XdpNamespace[e](t); + } + static xdp(e) { + return new xdp_Xdp(e); + } +} +const sc = go.xhtml.id, + oc = Symbol(), + cc = new Set([ + "color", + "font", + "font-family", + "font-size", + "font-stretch", + "font-style", + "font-weight", + "margin", + "margin-bottom", + "margin-left", + "margin-right", + "margin-top", + "letter-spacing", + "line-height", + "orphans", + "page-break-after", + "page-break-before", + "page-break-inside", + "tab-interval", + "tab-stop", + "text-align", + "text-decoration", + "text-indent", + "vertical-align", + "widows", + "kerning-mode", + "xfa-font-horizontal-scale", + "xfa-font-vertical-scale", + "xfa-spacerun", + "xfa-tab-stops", + ]), + lc = new Map([ + ["page-break-after", "breakAfter"], + ["page-break-before", "breakBefore"], + ["page-break-inside", "breakInside"], + ["kerning-mode", (e) => ("none" === e ? "none" : "normal")], + [ + "xfa-font-horizontal-scale", + (e) => `scaleX(${Math.max(0, parseInt(e) / 100).toFixed(2)})`, + ], + [ + "xfa-font-vertical-scale", + (e) => `scaleY(${Math.max(0, parseInt(e) / 100).toFixed(2)})`, + ], + ["xfa-spacerun", ""], + ["xfa-tab-stops", ""], + [ + "font-size", + (e, t) => + measureToString(0.99 * (e = t.fontSize = Math.abs(getMeasurement(e)))), + ], + ["letter-spacing", (e) => measureToString(getMeasurement(e))], + ["line-height", (e) => measureToString(getMeasurement(e))], + ["margin", (e) => measureToString(getMeasurement(e))], + ["margin-bottom", (e) => measureToString(getMeasurement(e))], + ["margin-left", (e) => measureToString(getMeasurement(e))], + ["margin-right", (e) => measureToString(getMeasurement(e))], + ["margin-top", (e) => measureToString(getMeasurement(e))], + ["text-indent", (e) => measureToString(getMeasurement(e))], + ["font-family", (e) => e], + ["vertical-align", (e) => measureToString(getMeasurement(e))], + ]), + hc = /\s+/g, + uc = /[\r\n]+/g, + dc = /\r\n?/g; +function mapStyle(e, t, a) { + const r = Object.create(null); + if (!e) return r; + const i = Object.create(null); + for (const [t, a] of e.split(";").map((e) => e.split(":", 2))) { + const e = lc.get(t); + if ("" === e) continue; + let n = a; + e && (n = "string" == typeof e ? e : e(a, i)); + t.endsWith("scale") + ? (r.transform = r.transform ? `${r[t]} ${n}` : n) + : (r[t.replaceAll(/-([a-zA-Z])/g, (e, t) => t.toUpperCase())] = n); + } + r.fontFamily && + setFontFamily( + { + typeface: r.fontFamily, + weight: r.fontWeight || "normal", + posture: r.fontStyle || "normal", + size: i.fontSize || 0, + }, + t, + t[Is].fontFinder, + r, + ); + if (a && r.verticalAlign && "0px" !== r.verticalAlign && r.fontSize) { + const e = 0.583, + t = 0.333, + a = getMeasurement(r.fontSize); + r.fontSize = measureToString(a * e); + r.verticalAlign = measureToString( + Math.sign(getMeasurement(r.verticalAlign)) * a * t, + ); + } + a && + r.fontSize && + (r.fontSize = `calc(${r.fontSize} * var(--total-scale-factor))`); + fixTextIndent(r); + return r; +} +const fc = new Set(["body", "html"]); +class XhtmlObject extends XmlObject { + constructor(e, t) { + super(sc, t); + this[oc] = !1; + this.style = e.style || ""; + } + [ts](e) { + super[ts](e); + this.style = (function checkStyle(e) { + return e.style + ? e.style + .split(";") + .filter((e) => !!e.trim()) + .map((e) => e.split(":", 2).map((e) => e.trim())) + .filter(([t, a]) => { + "font-family" === t && e[Is].usedTypefaces.add(a); + return cc.has(t); + }) + .map((e) => e.join(":")) + .join(";") + : ""; + })(this); + } + [Yn]() { + return !fc.has(this[Ws]); + } + [Vs](e, t = !1) { + if (t) this[oc] = !0; + else { + e = e.replaceAll(uc, ""); + this.style.includes("xfa-spacerun:yes") || (e = e.replaceAll(hc, " ")); + } + e && (this[ss] += e); + } + [Ks](e, t = !0) { + const a = Object.create(null), + r = { top: NaN, bottom: NaN, left: NaN, right: NaN }; + let i = null; + for (const [e, t] of this.style.split(";").map((e) => e.split(":", 2))) + switch (e) { + case "font-family": + a.typeface = stripQuotes(t); + break; + case "font-size": + a.size = getMeasurement(t); + break; + case "font-weight": + a.weight = t; + break; + case "font-style": + a.posture = t; + break; + case "letter-spacing": + a.letterSpacing = getMeasurement(t); + break; + case "margin": + const e = t.split(/ \t/).map((e) => getMeasurement(e)); + switch (e.length) { + case 1: + r.top = r.bottom = r.left = r.right = e[0]; + break; + case 2: + r.top = r.bottom = e[0]; + r.left = r.right = e[1]; + break; + case 3: + r.top = e[0]; + r.bottom = e[2]; + r.left = r.right = e[1]; + break; + case 4: + r.top = e[0]; + r.left = e[1]; + r.bottom = e[2]; + r.right = e[3]; + } + break; + case "margin-top": + r.top = getMeasurement(t); + break; + case "margin-bottom": + r.bottom = getMeasurement(t); + break; + case "margin-left": + r.left = getMeasurement(t); + break; + case "margin-right": + r.right = getMeasurement(t); + break; + case "line-height": + i = getMeasurement(t); + } + e.pushData(a, r, i); + if (this[ss]) e.addString(this[ss]); + else + for (const t of this[Ss]()) + "#text" !== t[Ws] ? t[Ks](e) : e.addString(t[ss]); + t && e.popFont(); + } + [co](e) { + const t = []; + this[ls] = { children: t }; + this[es]({}); + if (0 === t.length && !this[ss]) return HTMLResult.EMPTY; + let a; + a = this[oc] + ? this[ss] + ? this[ss].replaceAll(dc, "\n") + : void 0 + : this[ss] || void 0; + return HTMLResult.success({ + name: this[Ws], + attributes: { + href: this.href, + style: mapStyle(this.style, this, this[oc]), + }, + children: t, + value: a, + }); + } +} +class A extends XhtmlObject { + constructor(e) { + super(e, "a"); + this.href = fixURL(e.href) || ""; + } +} +class B extends XhtmlObject { + constructor(e) { + super(e, "b"); + } + [Ks](e) { + e.pushFont({ weight: "bold" }); + super[Ks](e); + e.popFont(); + } +} +class Body extends XhtmlObject { + constructor(e) { + super(e, "body"); + } + [co](e) { + const t = super[co](e), + { html: a } = t; + if (!a) return HTMLResult.EMPTY; + a.name = "div"; + a.attributes.class = ["xfaRich"]; + return t; + } +} +class Br extends XhtmlObject { + constructor(e) { + super(e, "br"); + } + [so]() { + return "\n"; + } + [Ks](e) { + e.addString("\n"); + } + [co](e) { + return HTMLResult.success({ name: "br" }); + } +} +class Html extends XhtmlObject { + constructor(e) { + super(e, "html"); + } + [co](e) { + const t = []; + this[ls] = { children: t }; + this[es]({}); + if (0 === t.length) + return HTMLResult.success({ + name: "div", + attributes: { class: ["xfaRich"], style: {} }, + value: this[ss] || "", + }); + if (1 === t.length) { + const e = t[0]; + if (e.attributes?.class.includes("xfaRich")) return HTMLResult.success(e); + } + return HTMLResult.success({ + name: "div", + attributes: { class: ["xfaRich"], style: {} }, + children: t, + }); + } +} +class I extends XhtmlObject { + constructor(e) { + super(e, "i"); + } + [Ks](e) { + e.pushFont({ posture: "italic" }); + super[Ks](e); + e.popFont(); + } +} +class Li extends XhtmlObject { + constructor(e) { + super(e, "li"); + } +} +class Ol extends XhtmlObject { + constructor(e) { + super(e, "ol"); + } +} +class P extends XhtmlObject { + constructor(e) { + super(e, "p"); + } + [Ks](e) { + super[Ks](e, !1); + e.addString("\n"); + e.addPara(); + e.popFont(); + } + [so]() { + return this[vs]()[Ss]().at(-1) === this ? super[so]() : super[so]() + "\n"; + } +} +class Span extends XhtmlObject { + constructor(e) { + super(e, "span"); + } +} +class Sub extends XhtmlObject { + constructor(e) { + super(e, "sub"); + } +} +class Sup extends XhtmlObject { + constructor(e) { + super(e, "sup"); + } +} +class Ul extends XhtmlObject { + constructor(e) { + super(e, "ul"); + } +} +class XhtmlNamespace { + static [fo](e, t) { + if (XhtmlNamespace.hasOwnProperty(e)) return XhtmlNamespace[e](t); + } + static a(e) { + return new A(e); + } + static b(e) { + return new B(e); + } + static body(e) { + return new Body(e); + } + static br(e) { + return new Br(e); + } + static html(e) { + return new Html(e); + } + static i(e) { + return new I(e); + } + static li(e) { + return new Li(e); + } + static ol(e) { + return new Ol(e); + } + static p(e) { + return new P(e); + } + static span(e) { + return new Span(e); + } + static sub(e) { + return new Sub(e); + } + static sup(e) { + return new Sup(e); + } + static ul(e) { + return new Ul(e); + } +} +const gc = { + config: ConfigNamespace, + connection: ConnectionSetNamespace, + datasets: DatasetsNamespace, + localeSet: LocaleSetNamespace, + signature: SignatureNamespace, + stylesheet: StylesheetNamespace, + template: TemplateNamespace, + xdp: XdpNamespace, + xhtml: XhtmlNamespace, +}; +class UnknownNamespace { + constructor(e) { + this.namespaceId = e; + } + [fo](e, t) { + return new XmlObject(this.namespaceId, e, t); + } +} +class Root extends XFAObject { + constructor(e) { + super(-1, "root", Object.create(null)); + this.element = null; + this[Os] = e; + } + [$s](e) { + this.element = e; + return !0; + } + [hs]() { + super[hs](); + if (this.element.template instanceof Template) { + this[Os].set(Qs, this.element); + this.element.template[eo](this[Os]); + this.element.template[Os] = this[Os]; + } + } +} +class Empty extends XFAObject { + constructor() { + super(-1, "", Object.create(null)); + } + [$s](e) { + return !1; + } +} +class Builder { + constructor(e = null) { + this._namespaceStack = []; + this._nsAgnosticLevel = 0; + this._namespacePrefixes = new Map(); + this._namespaces = new Map(); + this._nextNsId = Math.max(...Object.values(go).map(({ id: e }) => e)); + this._currentNamespace = e || new UnknownNamespace(++this._nextNsId); + } + buildRoot(e) { + return new Root(e); + } + build({ nsPrefix: e, name: t, attributes: a, namespace: r, prefixes: i }) { + const n = null !== r; + if (n) { + this._namespaceStack.push(this._currentNamespace); + this._currentNamespace = this._searchNamespace(r); + } + i && this._addNamespacePrefix(i); + if (a.hasOwnProperty(zs)) { + const e = gc.datasets, + t = a[zs]; + let r = null; + for (const [a, i] of Object.entries(t)) { + if (this._getNamespaceToUse(a) === e) { + r = { xfa: i }; + break; + } + } + r ? (a[zs] = r) : delete a[zs]; + } + const s = this._getNamespaceToUse(e), + o = s?.[fo](t, a) || new Empty(); + o[Ls]() && this._nsAgnosticLevel++; + (n || i || o[Ls]()) && + (o[rs] = { hasNamespace: n, prefixes: i, nsAgnostic: o[Ls]() }); + return o; + } + isNsAgnostic() { + return this._nsAgnosticLevel > 0; + } + _searchNamespace(e) { + let t = this._namespaces.get(e); + if (t) return t; + for (const [a, { check: r }] of Object.entries(go)) + if (r(e)) { + t = gc[a]; + if (t) { + this._namespaces.set(e, t); + return t; + } + break; + } + t = new UnknownNamespace(++this._nextNsId); + this._namespaces.set(e, t); + return t; + } + _addNamespacePrefix(e) { + for (const { prefix: t, value: a } of e) { + const e = this._searchNamespace(a); + let r = this._namespacePrefixes.get(t); + if (!r) { + r = []; + this._namespacePrefixes.set(t, r); + } + r.push(e); + } + } + _getNamespaceToUse(e) { + if (!e) return this._currentNamespace; + const t = this._namespacePrefixes.get(e); + if (t?.length > 0) return t.at(-1); + warn(`Unknown namespace prefix: ${e}.`); + return null; + } + clean(e) { + const { hasNamespace: t, prefixes: a, nsAgnostic: r } = e; + t && (this._currentNamespace = this._namespaceStack.pop()); + a && + a.forEach(({ prefix: e }) => { + this._namespacePrefixes.get(e).pop(); + }); + r && this._nsAgnosticLevel--; + } +} +class XFAParser extends XMLParserBase { + constructor(e = null, t = !1) { + super(); + this._builder = new Builder(e); + this._stack = []; + this._globalData = { usedTypefaces: new Set() }; + this._ids = new Map(); + this._current = this._builder.buildRoot(this._ids); + this._errorCode = jn; + this._whiteRegex = /^\s+$/; + this._nbsps = /\xa0+/g; + this._richText = t; + } + parse(e) { + this.parseXml(e); + if (this._errorCode === jn) { + this._current[hs](); + return this._current.element; + } + } + onText(e) { + e = e.replace(this._nbsps, (e) => e.slice(1) + " "); + this._richText || this._current[Yn]() + ? this._current[Vs](e, this._richText) + : this._whiteRegex.test(e) || this._current[Vs](e.trim()); + } + onCdata(e) { + this._current[Vs](e); + } + _mkAttributes(e, t) { + let a = null, + r = null; + const i = Object.create({}); + for (const { name: n, value: s } of e) + if ("xmlns" === n) + a ? warn(`XFA - multiple namespace definition in <${t}>`) : (a = s); + else if (n.startsWith("xmlns:")) { + const e = n.substring(6); + r ??= []; + r.push({ prefix: e, value: s }); + } else { + const e = n.indexOf(":"); + if (-1 === e) i[n] = s; + else { + const t = (i[zs] ??= Object.create(null)), + [a, r] = [n.slice(0, e), n.slice(e + 1)]; + (t[a] ||= Object.create(null))[r] = s; + } + } + return [a, r, i]; + } + _getNameAndPrefix(e, t) { + const a = e.indexOf(":"); + return -1 === a + ? [e, null] + : [e.substring(a + 1), t ? "" : e.substring(0, a)]; + } + onBeginElement(e, t, a) { + const [r, i, n] = this._mkAttributes(t, e), + [s, o] = this._getNameAndPrefix(e, this._builder.isNsAgnostic()), + c = this._builder.build({ + nsPrefix: o, + name: s, + attributes: n, + namespace: r, + prefixes: i, + }); + c[Is] = this._globalData; + if (a) { + c[hs](); + this._current[$s](c) && c[ao](this._ids); + c[ts](this._builder); + } else { + this._stack.push(this._current); + this._current = c; + } + } + onEndElement(e) { + const t = this._current; + if (t[Bs]() && "string" == typeof t[ss]) { + const e = new XFAParser(); + e._globalData = this._globalData; + const a = e.parse(t[ss]); + t[ss] = null; + t[$s](a); + } + t[hs](); + this._current = this._stack.pop(); + this._current[$s](t) && t[ao](this._ids); + t[ts](this._builder); + } + onError(e) { + this._errorCode = e; + } +} +class XFAFactory { + constructor(e) { + try { + this.root = new XFAParser().parse(XFAFactory._createDocument(e)); + const t = new Binder(this.root); + this.form = t.bind(); + this.dataHandler = new DataHandler(this.root, t.getData()); + this.form[Is].template = this.form; + } catch (e) { + warn(`XFA - an error occurred during parsing and binding: ${e}`); + } + } + isValid() { + return !(!this.root || !this.form); + } + _createPagesHelper() { + const e = this.form[oo](); + return new Promise((t, a) => { + const nextIteration = () => { + try { + const a = e.next(); + a.done ? t(a.value) : setTimeout(nextIteration, 0); + } catch (e) { + a(e); + } + }; + setTimeout(nextIteration, 0); + }); + } + async _createPages() { + try { + this.pages = await this._createPagesHelper(); + this.dims = this.pages.children.map((e) => { + const { width: t, height: a } = e.attributes.style; + return [0, 0, parseInt(t), parseInt(a)]; + }); + } catch (e) { + warn(`XFA - an error occurred during layout: ${e}`); + } + } + getBoundingBox(e) { + return this.dims[e]; + } + async getNumPages() { + this.pages || (await this._createPages()); + return this.dims.length; + } + setImages(e) { + this.form[Is].images = e; + } + setFonts(e) { + this.form[Is].fontFinder = new FontFinder(e); + const t = []; + for (let e of this.form[Is].usedTypefaces) { + e = stripQuotes(e); + this.form[Is].fontFinder.find(e) || t.push(e); + } + return t.length > 0 ? t : null; + } + appendFonts(e, t) { + this.form[Is].fontFinder.add(e, t); + } + async getPages() { + this.pages || (await this._createPages()); + const e = this.pages; + this.pages = null; + return e; + } + serializeData(e) { + return this.dataHandler.serialize(e); + } + static _createDocument(e) { + return e["/xdp:xdp"] ? Object.values(e).join("") : e["xdp:xdp"]; + } + static getRichTextAsHtml(e) { + if (!e || "string" != typeof e) return null; + try { + let t = new XFAParser(XhtmlNamespace, !0).parse(e); + if (!["body", "xhtml"].includes(t[Ws])) { + const e = XhtmlNamespace.body({}); + e[Qn](t); + t = e; + } + const a = t[co](); + if (!a.success) return null; + const { html: r } = a, + { attributes: i } = r; + if (i) { + i.class && (i.class = i.class.filter((e) => !e.startsWith("xfa"))); + i.dir = "auto"; + } + return { html: r, str: t[so]() }; + } catch (e) { + warn(`XFA - an error occurred during parsing of rich text: ${e}`); + } + return null; + } +} +class AnnotationFactory { + static createGlobals(e) { + return Promise.all([ + e.ensureCatalog("acroForm"), + e.ensureDoc("xfaDatasets"), + e.ensureCatalog("structTreeRoot"), + e.ensureCatalog("baseUrl"), + e.ensureCatalog("attachments"), + e.ensureCatalog("globalColorSpaceCache"), + ]).then( + ([t, a, r, i, n, s]) => ({ + pdfManager: e, + acroForm: t instanceof Dict ? t : Dict.empty, + xfaDatasets: a, + structTreeRoot: r, + baseUrl: i, + attachments: n, + globalColorSpaceCache: s, + }), + (e) => { + warn(`createGlobals: "${e}".`); + return null; + }, + ); + } + static async create(e, t, a, r, i, n, s) { + const o = i ? await this._getPageIndex(e, t, a.pdfManager) : null; + return a.pdfManager.ensure(this, "_create", [e, t, a, r, i, n, o, s]); + } + static _create(e, t, a, r, i = !1, n = null, s = null, o = null) { + const c = e.fetchIfRef(t); + if (!(c instanceof Dict)) return; + const { acroForm: l, pdfManager: h } = a, + u = t instanceof Ref ? t.toString() : `annot_${r.createObjId()}`; + let d = c.get("Subtype"); + d = d instanceof Name ? d.name : null; + const f = { + xref: e, + ref: t, + dict: c, + subtype: d, + id: u, + annotationGlobals: a, + collectFields: i, + orphanFields: n, + needAppearances: !i && !0 === l.get("NeedAppearances"), + pageIndex: s, + evaluatorOptions: h.evaluatorOptions, + pageRef: o, + }; + switch (d) { + case "Link": + return new LinkAnnotation(f); + case "Text": + return new TextAnnotation(f); + case "Widget": + let e = getInheritableProperty({ dict: c, key: "FT" }); + e = e instanceof Name ? e.name : null; + switch (e) { + case "Tx": + return new TextWidgetAnnotation(f); + case "Btn": + return new ButtonWidgetAnnotation(f); + case "Ch": + return new ChoiceWidgetAnnotation(f); + case "Sig": + return new SignatureWidgetAnnotation(f); + } + warn( + `Unimplemented widget field type "${e}", falling back to base field type.`, + ); + return new WidgetAnnotation(f); + case "Popup": + return new PopupAnnotation(f); + case "FreeText": + return new FreeTextAnnotation(f); + case "Line": + return new LineAnnotation(f); + case "Square": + return new SquareAnnotation(f); + case "Circle": + return new CircleAnnotation(f); + case "PolyLine": + return new PolylineAnnotation(f); + case "Polygon": + return new PolygonAnnotation(f); + case "Caret": + return new CaretAnnotation(f); + case "Ink": + return new InkAnnotation(f); + case "Highlight": + return new HighlightAnnotation(f); + case "Underline": + return new UnderlineAnnotation(f); + case "Squiggly": + return new SquigglyAnnotation(f); + case "StrikeOut": + return new StrikeOutAnnotation(f); + case "Stamp": + return new StampAnnotation(f); + case "FileAttachment": + return new FileAttachmentAnnotation(f); + default: + i || + warn( + d + ? `Unimplemented annotation type "${d}", falling back to base annotation.` + : "Annotation is missing the required /Subtype.", + ); + return new Annotation(f); + } + } + static async _getPageIndex(e, t, a) { + try { + const r = await e.fetchIfRefAsync(t); + if (!(r instanceof Dict)) return -1; + const i = r.getRaw("P"); + if (i instanceof Ref) + try { + return await a.ensureCatalog("getPageIndex", [i]); + } catch (e) { + info(`_getPageIndex -- not a valid page reference: "${e}".`); + } + if (r.has("Kids")) return -1; + const n = await a.ensureDoc("numPages"); + for (let e = 0; e < n; e++) { + const r = await a.getPage(e), + i = await a.ensure(r, "annotations"); + for (const a of i) if (a instanceof Ref && isRefsEqual(a, t)) return e; + } + } catch (e) { + warn(`_getPageIndex: "${e}".`); + } + return -1; + } + static generateImages(e, t, a) { + if (!a) { + warn( + "generateImages: OffscreenCanvas is not supported, cannot save or print some annotations with images.", + ); + return null; + } + let r; + for (const { bitmapId: a, bitmap: i } of e) + if (i) { + r ||= new Map(); + r.set(a, StampAnnotation.createImage(i, t)); + } + return r; + } + static async saveNewAnnotations(e, t, a, r, i) { + const n = e.xref; + let s; + const o = [], + { isOffscreenCanvasSupported: c } = e.options; + for (const l of a) + if (!l.deleted) + switch (l.annotationType) { + case g: + if (!s) { + const e = new Dict(n); + e.set("BaseFont", Name.get("Helvetica")); + e.set("Type", Name.get("Font")); + e.set("Subtype", Name.get("Type1")); + e.set("Encoding", Name.get("WinAnsiEncoding")); + s = n.getNewTemporaryRef(); + i.put(s, { data: e }); + } + o.push( + FreeTextAnnotation.createNewAnnotation(n, l, i, { + evaluator: e, + task: t, + baseFontRef: s, + }), + ); + break; + case p: + l.quadPoints + ? o.push(HighlightAnnotation.createNewAnnotation(n, l, i)) + : o.push(InkAnnotation.createNewAnnotation(n, l, i)); + break; + case b: + o.push(InkAnnotation.createNewAnnotation(n, l, i)); + break; + case m: + const a = c ? await r?.get(l.bitmapId) : null; + if (a?.imageStream) { + const { imageStream: e, smaskStream: t } = a; + if (t) { + const a = n.getNewTemporaryRef(); + i.put(a, { data: t }); + e.dict.set("SMask", a); + } + const r = (a.imageRef = n.getNewTemporaryRef()); + i.put(r, { data: e }); + a.imageStream = a.smaskStream = null; + } + o.push(StampAnnotation.createNewAnnotation(n, l, i, { image: a })); + break; + case y: + o.push(StampAnnotation.createNewAnnotation(n, l, i, {})); + } + return { annotations: await Promise.all(o) }; + } + static async printNewAnnotations(e, t, a, r, i) { + if (!r) return null; + const { options: n, xref: s } = t, + o = []; + for (const c of r) + if (!c.deleted) + switch (c.annotationType) { + case g: + o.push( + FreeTextAnnotation.createNewPrintAnnotation(e, s, c, { + evaluator: t, + task: a, + evaluatorOptions: n, + }), + ); + break; + case p: + c.quadPoints + ? o.push( + HighlightAnnotation.createNewPrintAnnotation(e, s, c, { + evaluatorOptions: n, + }), + ) + : o.push( + InkAnnotation.createNewPrintAnnotation(e, s, c, { + evaluatorOptions: n, + }), + ); + break; + case b: + o.push( + InkAnnotation.createNewPrintAnnotation(e, s, c, { + evaluatorOptions: n, + }), + ); + break; + case m: + const r = n.isOffscreenCanvasSupported + ? await i?.get(c.bitmapId) + : null; + if (r?.imageStream) { + const { imageStream: e, smaskStream: t } = r; + t && e.dict.set("SMask", t); + r.imageRef = new JpegStream(e, e.length); + r.imageStream = r.smaskStream = null; + } + o.push( + StampAnnotation.createNewPrintAnnotation(e, s, c, { + image: r, + evaluatorOptions: n, + }), + ); + break; + case y: + o.push( + StampAnnotation.createNewPrintAnnotation(e, s, c, { + evaluatorOptions: n, + }), + ); + } + return Promise.all(o); + } +} +function getRgbColor(e, t = new Uint8ClampedArray(3)) { + if (!Array.isArray(e)) return t; + const a = t || new Uint8ClampedArray(3); + switch (e.length) { + case 0: + return null; + case 1: + ColorSpaceUtils.gray.getRgbItem(e, 0, a, 0); + return a; + case 3: + ColorSpaceUtils.rgb.getRgbItem(e, 0, a, 0); + return a; + case 4: + ColorSpaceUtils.cmyk.getRgbItem(e, 0, a, 0); + return a; + default: + return t; + } +} +function getPdfColorArray(e) { + return Array.from(e, (e) => e / 255); +} +function getQuadPoints(e, t) { + const a = e.getArray("QuadPoints"); + if (!isNumberArray(a, null) || 0 === a.length || a.length % 8 > 0) + return null; + const r = new Float32Array(a.length); + for (let e = 0, i = a.length; e < i; e += 8) { + const [i, n, s, o, c, l, h, u] = a.slice(e, e + 8), + d = Math.min(i, s, c, h), + f = Math.max(i, s, c, h), + g = Math.min(n, o, l, u), + p = Math.max(n, o, l, u); + if (null !== t && (d < t[0] || f > t[2] || g < t[1] || p > t[3])) + return null; + r.set([d, p, f, p, d, g, f, g], e); + } + return r; +} +function getTransformMatrix(e, t, a) { + const r = new Float32Array([1 / 0, 1 / 0, -1 / 0, -1 / 0]); + Util.axialAlignedBoundingBox(t, a, r); + const [i, n, s, o] = r; + if (i === s || n === o) return [1, 0, 0, 1, e[0], e[1]]; + const c = (e[2] - e[0]) / (s - i), + l = (e[3] - e[1]) / (o - n); + return [c, 0, 0, l, e[0] - i * c, e[1] - n * l]; +} +class Annotation { + constructor(e) { + const { + dict: t, + xref: a, + annotationGlobals: r, + ref: i, + orphanFields: n, + } = e, + s = n?.get(i); + s && t.set("Parent", s); + this.setTitle(t.get("T")); + this.setContents(t.get("Contents")); + this.setModificationDate(t.get("M")); + this.setFlags(t.get("F")); + this.setRectangle(t.getArray("Rect")); + this.setColor(t.getArray("C")); + this.setBorderStyle(t); + this.setAppearance(t); + this.setOptionalContent(t); + const o = t.get("MK"); + this.setBorderAndBackgroundColors(o); + this.setRotation(o, t); + this.ref = e.ref instanceof Ref ? e.ref : null; + this._streams = []; + this.appearance && this._streams.push(this.appearance); + const c = !!(this.flags & ee), + l = !!(this.flags & te); + this.data = { + annotationFlags: this.flags, + borderStyle: this.borderStyle, + color: this.color, + backgroundColor: this.backgroundColor, + borderColor: this.borderColor, + rotation: this.rotation, + contentsObj: this._contents, + hasAppearance: !!this.appearance, + id: e.id, + modificationDate: this.modificationDate, + rect: this.rectangle, + subtype: e.subtype, + hasOwnCanvas: !1, + noRotate: !!(this.flags & Z), + noHTML: c && l, + isEditable: !1, + structParent: -1, + }; + if (r.structTreeRoot) { + let a = t.get("StructParent"); + this.data.structParent = a = Number.isInteger(a) && a >= 0 ? a : -1; + r.structTreeRoot.addAnnotationIdToPage(e.pageRef, a); + } + if (e.collectFields) { + const r = t.get("Kids"); + if (Array.isArray(r)) { + const e = []; + for (const t of r) t instanceof Ref && e.push(t.toString()); + 0 !== e.length && (this.data.kidIds = e); + } + this.data.actions = collectActions(a, t, ye); + this.data.fieldName = this._constructFieldName(t); + this.data.pageIndex = e.pageIndex; + } + const h = t.get("IT"); + h instanceof Name && (this.data.it = h.name); + this._isOffscreenCanvasSupported = + e.evaluatorOptions.isOffscreenCanvasSupported; + this._fallbackFontDict = null; + this._needAppearances = !1; + } + _hasFlag(e, t) { + return !!(e & t); + } + _buildFlags(e, t) { + let { flags: a } = this; + if (void 0 === e) { + if (void 0 === t) return; + return t ? a & ~Y : (a & ~J) | Y; + } + if (e) { + a |= Y; + return t ? (a & ~Q) | J : (a & ~J) | Q; + } + a &= ~(J | Q); + return t ? a & ~Y : a | Y; + } + _isViewable(e) { + return !this._hasFlag(e, K) && !this._hasFlag(e, Q); + } + _isPrintable(e) { + return this._hasFlag(e, Y) && !this._hasFlag(e, J) && !this._hasFlag(e, K); + } + mustBeViewed(e, t) { + const a = e?.get(this.data.id)?.noView; + return void 0 !== a ? !a : this.viewable && !this._hasFlag(this.flags, J); + } + mustBePrinted(e) { + const t = e?.get(this.data.id)?.noPrint; + return void 0 !== t ? !t : this.printable; + } + mustBeViewedWhenEditing(e, t = null) { + return e ? !this.data.isEditable : !t?.has(this.data.id); + } + get viewable() { + return ( + null !== this.data.quadPoints && + (0 === this.flags || this._isViewable(this.flags)) + ); + } + get printable() { + return ( + null !== this.data.quadPoints && + 0 !== this.flags && + this._isPrintable(this.flags) + ); + } + _parseStringHelper(e) { + const t = "string" == typeof e ? stringToPDFString(e) : ""; + return { str: t, dir: t && "rtl" === bidi(t).dir ? "rtl" : "ltr" }; + } + setDefaultAppearance(e) { + const { dict: t, annotationGlobals: a } = e, + r = + getInheritableProperty({ dict: t, key: "DA" }) || a.acroForm.get("DA"); + this._defaultAppearance = "string" == typeof r ? r : ""; + this.data.defaultAppearanceData = parseDefaultAppearance( + this._defaultAppearance, + ); + } + setTitle(e) { + this._title = this._parseStringHelper(e); + } + setContents(e) { + this._contents = this._parseStringHelper(e); + } + setModificationDate(e) { + this.modificationDate = "string" == typeof e ? e : null; + } + setFlags(e) { + this.flags = Number.isInteger(e) && e > 0 ? e : 0; + this.flags & K && + "Annotation" !== this.constructor.name && + (this.flags ^= K); + } + hasFlag(e) { + return this._hasFlag(this.flags, e); + } + setRectangle(e) { + this.rectangle = lookupNormalRect(e, [0, 0, 0, 0]); + } + setColor(e) { + this.color = getRgbColor(e); + } + setLineEndings(e) { + this.lineEndings = ["None", "None"]; + if (Array.isArray(e) && 2 === e.length) + for (let t = 0; t < 2; t++) { + const a = e[t]; + if (a instanceof Name) + switch (a.name) { + case "None": + continue; + case "Square": + case "Circle": + case "Diamond": + case "OpenArrow": + case "ClosedArrow": + case "Butt": + case "ROpenArrow": + case "RClosedArrow": + case "Slash": + this.lineEndings[t] = a.name; + continue; + } + warn(`Ignoring invalid lineEnding: ${a}`); + } + } + setRotation(e, t) { + this.rotation = 0; + let a = e instanceof Dict ? e.get("R") || 0 : t.get("Rotate") || 0; + if (Number.isInteger(a) && 0 !== a) { + a %= 360; + a < 0 && (a += 360); + a % 90 == 0 && (this.rotation = a); + } + } + setBorderAndBackgroundColors(e) { + if (e instanceof Dict) { + this.borderColor = getRgbColor(e.getArray("BC"), null); + this.backgroundColor = getRgbColor(e.getArray("BG"), null); + } else this.borderColor = this.backgroundColor = null; + } + setBorderStyle(e) { + this.borderStyle = new AnnotationBorderStyle(); + if (e instanceof Dict) + if (e.has("BS")) { + const t = e.get("BS"); + if (t instanceof Dict) { + const e = t.get("Type"); + if (!e || isName(e, "Border")) { + this.borderStyle.setWidth(t.get("W"), this.rectangle); + this.borderStyle.setStyle(t.get("S")); + this.borderStyle.setDashArray(t.getArray("D")); + } + } + } else if (e.has("Border")) { + const t = e.getArray("Border"); + if (Array.isArray(t) && t.length >= 3) { + this.borderStyle.setHorizontalCornerRadius(t[0]); + this.borderStyle.setVerticalCornerRadius(t[1]); + this.borderStyle.setWidth(t[2], this.rectangle); + 4 === t.length && this.borderStyle.setDashArray(t[3], !0); + } + } else this.borderStyle.setWidth(0); + } + setAppearance(e) { + this.appearance = null; + const t = e.get("AP"); + if (!(t instanceof Dict)) return; + const a = t.get("N"); + if (a instanceof BaseStream) { + this.appearance = a; + return; + } + if (!(a instanceof Dict)) return; + const r = e.get("AS"); + if (!(r instanceof Name && a.has(r.name))) return; + const i = a.get(r.name); + i instanceof BaseStream && (this.appearance = i); + } + setOptionalContent(e) { + this.oc = null; + const t = e.get("OC"); + t instanceof Name + ? warn("setOptionalContent: Support for /Name-entry is not implemented.") + : t instanceof Dict && (this.oc = t); + } + async loadResources(e, t) { + const a = await t.dict.getAsync("Resources"); + a && (await ObjectLoader.load(a, e, a.xref)); + return a; + } + async getOperatorList(e, t, a, r) { + const { hasOwnCanvas: i, id: n, rect: o } = this.data; + let c = this.appearance; + const l = !!(i && a & s); + if (l && (0 === this.width || 0 === this.height)) { + this.data.hasOwnCanvas = !1; + return { + opList: new OperatorList(), + separateForm: !1, + separateCanvas: !1, + }; + } + if (!c) { + if (!l) + return { + opList: new OperatorList(), + separateForm: !1, + separateCanvas: !1, + }; + c = new StringStream(""); + c.dict = new Dict(); + } + const h = c.dict, + u = await this.loadResources(Ia, c), + d = lookupRect(h.getArray("BBox"), [0, 0, 1, 1]), + f = lookupMatrix(h.getArray("Matrix"), Fa), + g = getTransformMatrix(o, d, f), + p = new OperatorList(); + let m; + this.oc && (m = await e.parseMarkedContentProps(this.oc, null)); + void 0 !== m && p.addOp(jt, ["OC", m]); + p.addOp($t, [n, o, g, f, l]); + await e.getOperatorList({ + stream: c, + task: t, + resources: u, + operatorList: p, + fallbackFontDict: this._fallbackFontDict, + }); + p.addOp(Gt, []); + void 0 !== m && p.addOp(_t, []); + this.reset(); + return { opList: p, separateForm: !1, separateCanvas: l }; + } + async save(e, t, a, r) { + return null; + } + get overlaysTextContent() { + return !1; + } + get hasTextContent() { + return !1; + } + async extractTextContent(e, t, a) { + if (!this.appearance) return; + const r = await this.loadResources(Ta, this.appearance), + i = [], + n = []; + let s = null; + const o = { + desiredSize: Math.Infinity, + ready: !0, + enqueue(e, t) { + for (const t of e.items) + if (void 0 !== t.str) { + s ||= t.transform.slice(-2); + n.push(t.str); + if (t.hasEOL) { + i.push(n.join("").trimEnd()); + n.length = 0; + } + } + }, + }; + await e.getTextContent({ + stream: this.appearance, + task: t, + resources: r, + includeMarkedContent: !0, + keepWhiteSpace: !0, + sink: o, + viewBox: a, + }); + this.reset(); + n.length && i.push(n.join("").trimEnd()); + if (i.length > 1 || i[0]) { + const e = this.appearance.dict, + t = lookupRect(e.getArray("BBox"), null), + a = lookupMatrix(e.getArray("Matrix"), null); + this.data.textPosition = this._transformPoint(s, t, a); + this.data.textContent = i; + } + } + _transformPoint(e, t, a) { + const { rect: r } = this.data; + t ||= [0, 0, 1, 1]; + a ||= [1, 0, 0, 1, 0, 0]; + const i = getTransformMatrix(r, t, a); + i[4] -= r[0]; + i[5] -= r[1]; + const n = e.slice(); + Util.applyTransform(n, i); + Util.applyTransform(n, a); + return n; + } + getFieldObject() { + return this.data.kidIds + ? { + id: this.data.id, + actions: this.data.actions, + name: this.data.fieldName, + strokeColor: this.data.borderColor, + fillColor: this.data.backgroundColor, + type: "", + kidIds: this.data.kidIds, + page: this.data.pageIndex, + rotation: this.rotation, + } + : null; + } + reset() { + for (const e of this._streams) e.reset(); + } + _constructFieldName(e) { + if (!e.has("T") && !e.has("Parent")) { + warn("Unknown field name, falling back to empty field name."); + return ""; + } + if (!e.has("Parent")) return stringToPDFString(e.get("T")); + const t = []; + e.has("T") && t.unshift(stringToPDFString(e.get("T"))); + let a = e; + const r = new RefSet(); + e.objId && r.put(e.objId); + for (; a.has("Parent"); ) { + a = a.get("Parent"); + if (!(a instanceof Dict) || (a.objId && r.has(a.objId))) break; + a.objId && r.put(a.objId); + a.has("T") && t.unshift(stringToPDFString(a.get("T"))); + } + return t.join("."); + } + get width() { + return this.data.rect[2] - this.data.rect[0]; + } + get height() { + return this.data.rect[3] - this.data.rect[1]; + } +} +class AnnotationBorderStyle { + constructor() { + this.width = 1; + this.rawWidth = 1; + this.style = fe; + this.dashArray = [3]; + this.horizontalCornerRadius = 0; + this.verticalCornerRadius = 0; + } + setWidth(e, t = [0, 0, 0, 0]) { + if (e instanceof Name) this.width = 0; + else if ("number" == typeof e) { + if (e > 0) { + this.rawWidth = e; + const a = (t[2] - t[0]) / 2, + r = (t[3] - t[1]) / 2; + if (a > 0 && r > 0 && (e > a || e > r)) { + warn(`AnnotationBorderStyle.setWidth - ignoring width: ${e}`); + e = 1; + } + } + this.width = e; + } + } + setStyle(e) { + if (e instanceof Name) + switch (e.name) { + case "S": + this.style = fe; + break; + case "D": + this.style = ge; + break; + case "B": + this.style = pe; + break; + case "I": + this.style = me; + break; + case "U": + this.style = be; + } + } + setDashArray(e, t = !1) { + if (Array.isArray(e)) { + let a = !0, + r = !0; + for (const t of e) { + if (!(+t >= 0)) { + a = !1; + break; + } + t > 0 && (r = !1); + } + if (0 === e.length || (a && !r)) { + this.dashArray = e; + t && this.setStyle(Name.get("D")); + } else this.width = 0; + } else e && (this.width = 0); + } + setHorizontalCornerRadius(e) { + Number.isInteger(e) && (this.horizontalCornerRadius = e); + } + setVerticalCornerRadius(e) { + Number.isInteger(e) && (this.verticalCornerRadius = e); + } +} +class MarkupAnnotation extends Annotation { + constructor(e) { + super(e); + const { dict: t } = e; + if (t.has("IRT")) { + const e = t.getRaw("IRT"); + this.data.inReplyTo = e instanceof Ref ? e.toString() : null; + const a = t.get("RT"); + this.data.replyType = a instanceof Name ? a.name : V; + } + let a = null; + if (this.data.replyType === G) { + const e = t.get("IRT"); + this.setTitle(e.get("T")); + this.data.titleObj = this._title; + this.setContents(e.get("Contents")); + this.data.contentsObj = this._contents; + if (e.has("CreationDate")) { + this.setCreationDate(e.get("CreationDate")); + this.data.creationDate = this.creationDate; + } else this.data.creationDate = null; + if (e.has("M")) { + this.setModificationDate(e.get("M")); + this.data.modificationDate = this.modificationDate; + } else this.data.modificationDate = null; + a = e.getRaw("Popup"); + if (e.has("C")) { + this.setColor(e.getArray("C")); + this.data.color = this.color; + } else this.data.color = null; + } else { + this.data.titleObj = this._title; + this.setCreationDate(t.get("CreationDate")); + this.data.creationDate = this.creationDate; + a = t.getRaw("Popup"); + t.has("C") || (this.data.color = null); + } + this.data.popupRef = a instanceof Ref ? a.toString() : null; + t.has("RC") && + (this.data.richText = XFAFactory.getRichTextAsHtml(t.get("RC"))); + } + setCreationDate(e) { + this.creationDate = "string" == typeof e ? e : null; + } + _setDefaultAppearance({ + xref: e, + extra: t, + strokeColor: a, + fillColor: r, + blendMode: i, + strokeAlpha: n, + fillAlpha: s, + pointsCallback: o, + }) { + const c = (this.data.rect = [1 / 0, 1 / 0, -1 / 0, -1 / 0]), + l = ["q"]; + t && l.push(t); + a && l.push(`${a[0]} ${a[1]} ${a[2]} RG`); + r && l.push(`${r[0]} ${r[1]} ${r[2]} rg`); + const h = + this.data.quadPoints || + Float32Array.from([ + this.rectangle[0], + this.rectangle[3], + this.rectangle[2], + this.rectangle[3], + this.rectangle[0], + this.rectangle[1], + this.rectangle[2], + this.rectangle[1], + ]); + for (let e = 0, t = h.length; e < t; e += 8) { + const t = o(l, h.subarray(e, e + 8)); + Util.rectBoundingBox(...t, c); + } + l.push("Q"); + const u = new Dict(e), + d = new Dict(e); + d.set("Subtype", Name.get("Form")); + const f = new StringStream(l.join(" ")); + f.dict = d; + u.set("Fm0", f); + const g = new Dict(e); + i && g.set("BM", Name.get(i)); + "number" == typeof n && g.set("CA", n); + "number" == typeof s && g.set("ca", s); + const p = new Dict(e); + p.set("GS0", g); + const m = new Dict(e); + m.set("ExtGState", p); + m.set("XObject", u); + const b = new Dict(e); + b.set("Resources", m); + b.set("BBox", c); + this.appearance = new StringStream("/GS0 gs /Fm0 Do"); + this.appearance.dict = b; + this._streams.push(this.appearance, f); + } + static async createNewAnnotation(e, t, a, r) { + const i = (t.ref ||= e.getNewTemporaryRef()), + n = await this.createNewAppearanceStream(t, e, r); + let s; + if (n) { + const r = e.getNewTemporaryRef(); + s = this.createNewDict(t, e, { apRef: r }); + a.put(r, { data: n }); + } else s = this.createNewDict(t, e, {}); + Number.isInteger(t.parentTreeId) && s.set("StructParent", t.parentTreeId); + a.put(i, { data: s }); + return { ref: i }; + } + static async createNewPrintAnnotation(e, t, a, r) { + const i = await this.createNewAppearanceStream(a, t, r), + n = this.createNewDict(a, t, i ? { ap: i } : {}), + s = new this.prototype.constructor({ + dict: n, + xref: t, + annotationGlobals: e, + evaluatorOptions: r.evaluatorOptions, + }); + a.ref && (s.ref = s.refToReplace = a.ref); + return s; + } +} +class WidgetAnnotation extends Annotation { + constructor(e) { + super(e); + const { dict: t, xref: a, annotationGlobals: r } = e, + i = this.data; + this._needAppearances = e.needAppearances; + i.annotationType = $; + void 0 === i.fieldName && (i.fieldName = this._constructFieldName(t)); + void 0 === i.actions && (i.actions = collectActions(a, t, ye)); + let n = getInheritableProperty({ dict: t, key: "V", getArray: !0 }); + i.fieldValue = this._decodeFormValue(n); + const s = getInheritableProperty({ dict: t, key: "DV", getArray: !0 }); + i.defaultFieldValue = this._decodeFormValue(s); + if (void 0 === n && r.xfaDatasets) { + const e = this._title.str; + if (e) { + this._hasValueFromXFA = !0; + i.fieldValue = n = r.xfaDatasets.getValue(e); + } + } + void 0 === n && + null !== i.defaultFieldValue && + (i.fieldValue = i.defaultFieldValue); + i.alternativeText = stringToPDFString(t.get("TU") || ""); + this.setDefaultAppearance(e); + i.hasAppearance ||= + this._needAppearances && void 0 !== i.fieldValue && null !== i.fieldValue; + const o = getInheritableProperty({ dict: t, key: "FT" }); + i.fieldType = o instanceof Name ? o.name : null; + const c = getInheritableProperty({ dict: t, key: "DR" }), + l = r.acroForm.get("DR"), + h = this.appearance?.dict.get("Resources"); + this._fieldResources = { + localResources: c, + acroFormResources: l, + appearanceResources: h, + mergedResources: Dict.merge({ + xref: a, + dictArray: [c, h, l], + mergeSubDicts: !0, + }), + }; + i.fieldFlags = getInheritableProperty({ dict: t, key: "Ff" }); + (!Number.isInteger(i.fieldFlags) || i.fieldFlags < 0) && (i.fieldFlags = 0); + i.password = this.hasFieldFlag(ne); + i.readOnly = this.hasFieldFlag(ae); + i.required = this.hasFieldFlag(re); + i.hidden = + this._hasFlag(i.annotationFlags, J) || + this._hasFlag(i.annotationFlags, Q); + } + _decodeFormValue(e) { + return Array.isArray(e) + ? e.filter((e) => "string" == typeof e).map((e) => stringToPDFString(e)) + : e instanceof Name + ? stringToPDFString(e.name) + : "string" == typeof e + ? stringToPDFString(e) + : null; + } + hasFieldFlag(e) { + return !!(this.data.fieldFlags & e); + } + _isViewable(e) { + return !0; + } + mustBeViewed(e, t) { + return t + ? this.viewable + : super.mustBeViewed(e, t) && !this._hasFlag(this.flags, Q); + } + getRotationMatrix(e) { + let t = e?.get(this.data.id)?.rotation; + void 0 === t && (t = this.rotation); + return 0 === t ? Fa : getRotationMatrix(t, this.width, this.height); + } + getBorderAndBackgroundAppearances(e) { + let t = e?.get(this.data.id)?.rotation; + void 0 === t && (t = this.rotation); + if (!this.backgroundColor && !this.borderColor) return ""; + const a = + 0 === t || 180 === t + ? `0 0 ${this.width} ${this.height} re` + : `0 0 ${this.height} ${this.width} re`; + let r = ""; + this.backgroundColor && + (r = `${getPdfColor(this.backgroundColor, !0)} ${a} f `); + if (this.borderColor) { + r += `${this.borderStyle.width || 1} w ${getPdfColor(this.borderColor, !1)} ${a} S `; + } + return r; + } + async getOperatorList(e, t, a, r) { + if ( + a & l && + !(this instanceof SignatureWidgetAnnotation) && + !this.data.noHTML && + !this.data.hasOwnCanvas + ) + return { + opList: new OperatorList(), + separateForm: !0, + separateCanvas: !1, + }; + if (!this._hasText) return super.getOperatorList(e, t, a, r); + const i = await this._getAppearance(e, t, a, r); + if (this.appearance && null === i) return super.getOperatorList(e, t, a, r); + const n = new OperatorList(); + if (!this._defaultAppearance || null === i) + return { opList: n, separateForm: !1, separateCanvas: !1 }; + const o = !!(this.data.hasOwnCanvas && a & s), + c = [0, 0, this.width, this.height], + h = getTransformMatrix(this.data.rect, c, [1, 0, 0, 1, 0, 0]); + let u; + this.oc && (u = await e.parseMarkedContentProps(this.oc, null)); + void 0 !== u && n.addOp(jt, ["OC", u]); + n.addOp($t, [ + this.data.id, + this.data.rect, + h, + this.getRotationMatrix(r), + o, + ]); + const d = new StringStream(i); + await e.getOperatorList({ + stream: d, + task: t, + resources: this._fieldResources.mergedResources, + operatorList: n, + }); + n.addOp(Gt, []); + void 0 !== u && n.addOp(_t, []); + return { opList: n, separateForm: !1, separateCanvas: o }; + } + _getMKDict(e) { + const t = new Dict(null); + e && t.set("R", e); + this.borderColor && t.set("BC", getPdfColorArray(this.borderColor)); + this.backgroundColor && t.set("BG", getPdfColorArray(this.backgroundColor)); + return t.size > 0 ? t : null; + } + amendSavedDict(e, t) {} + setValue(e, t, a, r) { + const { dict: i, ref: n } = (function getParentToUpdate(e, t, a) { + const r = new RefSet(), + i = e, + n = { dict: null, ref: null }; + for (; e instanceof Dict && !r.has(t); ) { + r.put(t); + if (e.has("T")) break; + if (!((t = e.getRaw("Parent")) instanceof Ref)) return n; + e = a.fetch(t); + } + if (e instanceof Dict && e !== i) { + n.dict = e; + n.ref = t; + } + return n; + })(e, this.ref, a); + if (i) { + if (!r.has(n)) { + const e = i.clone(); + e.set("V", t); + r.put(n, { data: e }); + return e; + } + } else e.set("V", t); + return null; + } + async save(e, t, a, r) { + const i = a?.get(this.data.id), + n = this._buildFlags(i?.noView, i?.noPrint); + let s = i?.value, + o = i?.rotation; + if (s === this.data.fieldValue || void 0 === s) { + if (!this._hasValueFromXFA && void 0 === o && void 0 === n) return; + s ||= this.data.fieldValue; + } + if ( + void 0 === o && + !this._hasValueFromXFA && + Array.isArray(s) && + Array.isArray(this.data.fieldValue) && + isArrayEqual(s, this.data.fieldValue) && + void 0 === n + ) + return; + void 0 === o && (o = this.rotation); + let l = null; + if (!this._needAppearances) { + l = await this._getAppearance(e, t, c, a); + if (null === l && void 0 === n) return; + } + let h = !1; + if (l?.needAppearances) { + h = !0; + l = null; + } + const { xref: u } = e, + d = u.fetchIfRef(this.ref); + if (!(d instanceof Dict)) return; + const f = new Dict(u); + for (const e of d.getKeys()) "AP" !== e && f.set(e, d.getRaw(e)); + if (void 0 !== n) { + f.set("F", n); + if (null === l && !h) { + const e = d.getRaw("AP"); + e && f.set("AP", e); + } + } + const g = { path: this.data.fieldName, value: s }, + p = this.setValue( + f, + Array.isArray(s) + ? s.map(stringToAsciiOrUTF16BE) + : stringToAsciiOrUTF16BE(s), + u, + r, + ); + this.amendSavedDict(a, p || f); + const m = this._getMKDict(o); + m && f.set("MK", m); + r.put(this.ref, { data: f, xfa: g, needAppearances: h }); + if (null !== l) { + const e = u.getNewTemporaryRef(), + t = new Dict(u); + f.set("AP", t); + t.set("N", e); + const i = this._getSaveFieldResources(u), + n = new StringStream(l), + s = (n.dict = new Dict(u)); + s.set("Subtype", Name.get("Form")); + s.set("Resources", i); + const c = + o % 180 == 0 + ? [0, 0, this.width, this.height] + : [0, 0, this.height, this.width]; + s.set("BBox", c); + const h = this.getRotationMatrix(a); + h !== Fa && s.set("Matrix", h); + r.put(e, { data: n, xfa: null, needAppearances: !1 }); + } + f.set("M", `D:${getModificationDate()}`); + } + async _getAppearance(e, t, a, r) { + if (this.data.password) return null; + const n = r?.get(this.data.id); + let s, o; + if (n) { + s = n.formattedValue || n.value; + o = n.rotation; + } + if ( + void 0 === o && + void 0 === s && + !this._needAppearances && + (!this._hasValueFromXFA || this.appearance) + ) + return null; + const l = this.getBorderAndBackgroundAppearances(r); + if (void 0 === s) { + s = this.data.fieldValue; + if (!s) return `/Tx BMC q ${l}Q EMC`; + } + Array.isArray(s) && 1 === s.length && (s = s[0]); + assert("string" == typeof s, "Expected `value` to be a string."); + s = s.trimEnd(); + if (this.data.combo) { + const e = this.data.options.find(({ exportValue: e }) => s === e); + s = e?.displayValue || s; + } + if ("" === s) return `/Tx BMC q ${l}Q EMC`; + void 0 === o && (o = this.rotation); + let h, + u = -1; + if (this.data.multiLine) { + h = s.split(/\r\n?|\n/).map((e) => e.normalize("NFC")); + u = h.length; + } else h = [s.replace(/\r\n?|\n/, "").normalize("NFC")]; + let { width: d, height: f } = this; + (90 !== o && 270 !== o) || ([d, f] = [f, d]); + this._defaultAppearance || + (this.data.defaultAppearanceData = parseDefaultAppearance( + (this._defaultAppearance = "/Helvetica 0 Tf 0 g"), + )); + let g, + p, + m, + b = await WidgetAnnotation._getFontData( + e, + t, + this.data.defaultAppearanceData, + this._fieldResources.mergedResources, + ); + const y = []; + let w = !1; + for (const e of h) { + const t = b.encodeString(e); + t.length > 1 && (w = !0); + y.push(t.join("")); + } + if (w && a & c) return { needAppearances: !0 }; + if (w && this._isOffscreenCanvasSupported) { + const a = this.data.comb ? "monospace" : "sans-serif", + r = new FakeUnicodeFont(e.xref, a), + i = r.createFontResources(h.join("")), + n = i.getRaw("Font"); + if (this._fieldResources.mergedResources.has("Font")) { + const e = this._fieldResources.mergedResources.get("Font"); + for (const t of n.getKeys()) e.set(t, n.getRaw(t)); + } else this._fieldResources.mergedResources.set("Font", n); + const o = r.fontName.name; + b = await WidgetAnnotation._getFontData( + e, + t, + { fontName: o, fontSize: 0 }, + i, + ); + for (let e = 0, t = y.length; e < t; e++) + y[e] = stringToUTF16String(h[e]); + const c = Object.assign( + Object.create(null), + this.data.defaultAppearanceData, + ); + this.data.defaultAppearanceData.fontSize = 0; + this.data.defaultAppearanceData.fontName = o; + [g, p, m] = this._computeFontSize(f - 2, d - 4, s, b, u); + this.data.defaultAppearanceData = c; + } else { + this._isOffscreenCanvasSupported || + warn( + "_getAppearance: OffscreenCanvas is not supported, annotation may not render correctly.", + ); + [g, p, m] = this._computeFontSize(f - 2, d - 4, s, b, u); + } + let x = b.descent; + x = isNaN(x) ? i * m : Math.max(i * m, Math.abs(x) * p); + const S = Math.min(Math.floor((f - p) / 2), 1), + k = this.data.textAlignment; + if (this.data.multiLine) + return this._getMultilineAppearance(g, y, b, p, d, f, k, 2, S, x, m, r); + if (this.data.comb) + return this._getCombAppearance(g, b, y[0], p, d, f, 2, S, x, m, r); + const C = S + x; + if (0 === k || k > 2) + return ( + `/Tx BMC q ${l}BT ` + + g + + ` 1 0 0 1 ${numberToString(2)} ${numberToString(C)} Tm (${escapeString(y[0])}) Tj ET Q EMC` + ); + return ( + `/Tx BMC q ${l}BT ` + + g + + ` 1 0 0 1 0 0 Tm ${this._renderText(y[0], b, p, d, k, { shift: 0 }, 2, C)} ET Q EMC` + ); + } + static async _getFontData(e, t, a, r) { + const i = new OperatorList(), + n = { + font: null, + clone() { + return this; + }, + }, + { fontName: s, fontSize: o } = a; + await e.handleSetFont(r, [s && Name.get(s), o], null, i, t, n, null); + return n.font; + } + _getTextWidth(e, t) { + return Math.sumPrecise(t.charsToGlyphs(e).map((e) => e.width)) / 1e3; + } + _computeFontSize(e, t, r, i, n) { + let { fontSize: s } = this.data.defaultAppearanceData, + o = (s || 12) * a, + c = Math.round(e / o); + if (!s) { + const roundWithTwoDigits = (e) => Math.floor(100 * e) / 100; + if (-1 === n) { + const n = this._getTextWidth(r, i); + s = roundWithTwoDigits(Math.min(e / a, t / n)); + c = 1; + } else { + const l = r.split(/\r\n?|\n/), + h = []; + for (const e of l) { + const t = i.encodeString(e).join(""), + a = i.charsToGlyphs(t), + r = i.getCharPositions(t); + h.push({ line: t, glyphs: a, positions: r }); + } + const isTooBig = (a) => { + let r = 0; + for (const n of h) { + r += this._splitLine(null, i, a, t, n).length * a; + if (r > e) return !0; + } + return !1; + }; + c = Math.max(c, n); + for (;;) { + o = e / c; + s = roundWithTwoDigits(o / a); + if (!isTooBig(s)) break; + c++; + } + } + const { fontName: l, fontColor: h } = this.data.defaultAppearanceData; + this._defaultAppearance = (function createDefaultAppearance({ + fontSize: e, + fontName: t, + fontColor: a, + }) { + return `/${escapePDFName(t)} ${e} Tf ${getPdfColor(a, !0)}`; + })({ fontSize: s, fontName: l, fontColor: h }); + } + return [this._defaultAppearance, s, e / c]; + } + _renderText(e, t, a, r, i, n, s, o) { + let c; + if (1 === i) { + c = (r - this._getTextWidth(e, t) * a) / 2; + } else if (2 === i) { + c = r - this._getTextWidth(e, t) * a - s; + } else c = s; + const l = numberToString(c - n.shift); + n.shift = c; + return `${l} ${(o = numberToString(o))} Td (${escapeString(e)}) Tj`; + } + _getSaveFieldResources(e) { + const { + localResources: t, + appearanceResources: a, + acroFormResources: r, + } = this._fieldResources, + i = this.data.defaultAppearanceData?.fontName; + if (!i) return t || Dict.empty; + for (const e of [t, a]) + if (e instanceof Dict) { + const t = e.get("Font"); + if (t instanceof Dict && t.has(i)) return e; + } + if (r instanceof Dict) { + const a = r.get("Font"); + if (a instanceof Dict && a.has(i)) { + const r = new Dict(e); + r.set(i, a.getRaw(i)); + const n = new Dict(e); + n.set("Font", r); + return Dict.merge({ xref: e, dictArray: [n, t], mergeSubDicts: !0 }); + } + } + return t || Dict.empty; + } + getFieldObject() { + return null; + } +} +class TextWidgetAnnotation extends WidgetAnnotation { + constructor(e) { + super(e); + const { dict: t } = e; + if (t.has("PMD")) { + this.flags |= J; + this.data.hidden = !0; + warn("Barcodes are not supported"); + } + this.data.hasOwnCanvas = this.data.readOnly && !this.data.noHTML; + this._hasText = !0; + "string" != typeof this.data.fieldValue && (this.data.fieldValue = ""); + let a = getInheritableProperty({ dict: t, key: "Q" }); + (!Number.isInteger(a) || a < 0 || a > 2) && (a = null); + this.data.textAlignment = a; + let r = getInheritableProperty({ dict: t, key: "MaxLen" }); + (!Number.isInteger(r) || r < 0) && (r = 0); + this.data.maxLen = r; + this.data.multiLine = this.hasFieldFlag(ie); + this.data.comb = + this.hasFieldFlag(de) && + !this.data.multiLine && + !this.data.password && + !this.hasFieldFlag(le) && + 0 !== this.data.maxLen; + this.data.doNotScroll = this.hasFieldFlag(ue); + const { + data: { actions: i }, + } = this; + for (const e of i?.Keystroke || []) { + const t = e + .trim() + .match(/^AF(Date|Time)_Keystroke(?:Ex)?\(['"]?([^'"]+)['"]?\);$/); + if (t) { + let e = t[2]; + const a = parseInt(e, 10); + isNaN(a) || + Math.floor(Math.log10(a)) + 1 !== t[2].length || + (e = ("Date" === t[1] ? Pn : Ln)[a] ?? e); + this.data["Date" === t[1] ? "dateFormat" : "timeFormat"] = e; + break; + } + } + } + get hasTextContent() { + return !!this.appearance && !this._needAppearances; + } + _getCombAppearance(e, t, a, r, i, n, s, o, c, l, h) { + const u = i / this.data.maxLen, + d = this.getBorderAndBackgroundAppearances(h), + f = [], + g = t.getCharPositions(a); + for (const [e, t] of g) f.push(`(${escapeString(a.substring(e, t))}) Tj`); + const p = f.join(` ${numberToString(u)} 0 Td `); + return ( + `/Tx BMC q ${d}BT ` + + e + + ` 1 0 0 1 ${numberToString(s)} ${numberToString(o + c)} Tm ${p} ET Q EMC` + ); + } + _getMultilineAppearance(e, t, a, r, i, n, s, o, c, l, h, u) { + const d = [], + f = i - 2 * o, + g = { shift: 0 }; + for (let e = 0, n = t.length; e < n; e++) { + const n = t[e], + u = this._splitLine(n, a, r, f); + for (let t = 0, n = u.length; t < n; t++) { + const n = u[t], + f = 0 === e && 0 === t ? -c - (h - l) : -h; + d.push(this._renderText(n, a, r, i, s, g, o, f)); + } + } + const p = this.getBorderAndBackgroundAppearances(u), + m = d.join("\n"); + return ( + `/Tx BMC q ${p}BT ` + + e + + ` 1 0 0 1 0 ${numberToString(n)} Tm ${m} ET Q EMC` + ); + } + _splitLine(e, t, a, r, i = {}) { + e = i.line || e; + const n = i.glyphs || t.charsToGlyphs(e); + if (n.length <= 1) return [e]; + const s = i.positions || t.getCharPositions(e), + o = a / 1e3, + c = []; + let l = -1, + h = -1, + u = -1, + d = 0, + f = 0; + for (let t = 0, a = n.length; t < a; t++) { + const [a, i] = s[t], + g = n[t], + p = g.width * o; + if (" " === g.unicode) + if (f + p > r) { + c.push(e.substring(d, a)); + d = a; + f = p; + l = -1; + u = -1; + } else { + f += p; + l = a; + h = i; + u = t; + } + else if (f + p > r) + if (-1 !== l) { + c.push(e.substring(d, h)); + d = h; + t = u + 1; + l = -1; + f = 0; + } else { + c.push(e.substring(d, a)); + d = a; + f = p; + } + else f += p; + } + d < e.length && c.push(e.substring(d, e.length)); + return c; + } + async extractTextContent(e, t, a) { + await super.extractTextContent(e, t, a); + const r = this.data.textContent; + if (!r) return; + const i = r.join("\n"); + if (i === this.data.fieldValue) return; + const n = i.replaceAll(/([.*+?^${}()|[\]\\])|(\s+)/g, (e, t) => + t ? `\\${t}` : "\\s+", + ); + new RegExp(`^\\s*${n}\\s*$`).test(this.data.fieldValue) && + (this.data.textContent = this.data.fieldValue.split("\n")); + } + getFieldObject() { + return { + id: this.data.id, + value: this.data.fieldValue, + defaultValue: this.data.defaultFieldValue || "", + multiline: this.data.multiLine, + password: this.data.password, + charLimit: this.data.maxLen, + comb: this.data.comb, + editable: !this.data.readOnly, + hidden: this.data.hidden, + name: this.data.fieldName, + rect: this.data.rect, + actions: this.data.actions, + page: this.data.pageIndex, + strokeColor: this.data.borderColor, + fillColor: this.data.backgroundColor, + rotation: this.rotation, + type: "text", + }; + } +} +class ButtonWidgetAnnotation extends WidgetAnnotation { + constructor(e) { + super(e); + this.checkedAppearance = null; + this.uncheckedAppearance = null; + const t = this.hasFieldFlag(se), + a = this.hasFieldFlag(oe); + this.data.checkBox = !t && !a; + this.data.radioButton = t && !a; + this.data.pushButton = a; + this.data.isTooltipOnly = !1; + if (this.data.checkBox) this._processCheckBox(e); + else if (this.data.radioButton) this._processRadioButton(e); + else if (this.data.pushButton) { + this.data.hasOwnCanvas = !0; + this.data.noHTML = !1; + this._processPushButton(e); + } else warn("Invalid field flags for button widget annotation"); + } + async getOperatorList(e, t, a, r) { + if (this.data.pushButton) return super.getOperatorList(e, t, a, !1, r); + let i = null, + n = null; + if (r) { + const e = r.get(this.data.id); + i = e ? e.value : null; + n = e ? e.rotation : null; + } + if (null === i && this.appearance) return super.getOperatorList(e, t, a, r); + null == i && + (i = this.data.checkBox + ? this.data.fieldValue === this.data.exportValue + : this.data.fieldValue === this.data.buttonValue); + const s = i ? this.checkedAppearance : this.uncheckedAppearance; + if (s) { + const i = this.appearance, + o = lookupMatrix(s.dict.getArray("Matrix"), Fa); + n && s.dict.set("Matrix", this.getRotationMatrix(r)); + this.appearance = s; + const c = super.getOperatorList(e, t, a, r); + this.appearance = i; + s.dict.set("Matrix", o); + return c; + } + return { opList: new OperatorList(), separateForm: !1, separateCanvas: !1 }; + } + async save(e, t, a, r) { + this.data.checkBox + ? this._saveCheckbox(e, t, a, r) + : this.data.radioButton && this._saveRadioButton(e, t, a, r); + } + async _saveCheckbox(e, t, a, r) { + if (!a) return; + const i = a.get(this.data.id), + n = this._buildFlags(i?.noView, i?.noPrint); + let s = i?.rotation, + o = i?.value; + if (void 0 === s && void 0 === n) { + if (void 0 === o) return; + if ((this.data.fieldValue === this.data.exportValue) === o) return; + } + let c = e.xref.fetchIfRef(this.ref); + if (!(c instanceof Dict)) return; + c = c.clone(); + void 0 === s && (s = this.rotation); + void 0 === o && (o = this.data.fieldValue === this.data.exportValue); + const l = { + path: this.data.fieldName, + value: o ? this.data.exportValue : "", + }, + h = Name.get(o ? this.data.exportValue : "Off"); + this.setValue(c, h, e.xref, r); + c.set("AS", h); + c.set("M", `D:${getModificationDate()}`); + void 0 !== n && c.set("F", n); + const u = this._getMKDict(s); + u && c.set("MK", u); + r.put(this.ref, { data: c, xfa: l, needAppearances: !1 }); + } + async _saveRadioButton(e, t, a, r) { + if (!a) return; + const i = a.get(this.data.id), + n = this._buildFlags(i?.noView, i?.noPrint); + let s = i?.rotation, + o = i?.value; + if (void 0 === s && void 0 === n) { + if (void 0 === o) return; + if ((this.data.fieldValue === this.data.buttonValue) === o) return; + } + let c = e.xref.fetchIfRef(this.ref); + if (!(c instanceof Dict)) return; + c = c.clone(); + void 0 === o && (o = this.data.fieldValue === this.data.buttonValue); + void 0 === s && (s = this.rotation); + const l = { + path: this.data.fieldName, + value: o ? this.data.buttonValue : "", + }, + h = Name.get(o ? this.data.buttonValue : "Off"); + o && this.setValue(c, h, e.xref, r); + c.set("AS", h); + c.set("M", `D:${getModificationDate()}`); + void 0 !== n && c.set("F", n); + const u = this._getMKDict(s); + u && c.set("MK", u); + r.put(this.ref, { data: c, xfa: l, needAppearances: !1 }); + } + _getDefaultCheckedAppearance(e, t) { + const { width: a, height: r } = this, + i = [0, 0, a, r], + n = 0.8 * Math.min(a, r); + let s, o; + if ("check" === t) { + s = { width: 0.755 * n, height: 0.705 * n }; + o = "3"; + } else if ("disc" === t) { + s = { width: 0.791 * n, height: 0.705 * n }; + o = "l"; + } else unreachable(`_getDefaultCheckedAppearance - unsupported type: ${t}`); + const c = `q BT /PdfJsZaDb ${n} Tf 0 g ${numberToString((a - s.width) / 2)} ${numberToString((r - s.height) / 2)} Td (${o}) Tj ET Q`, + l = new Dict(e.xref); + l.set("FormType", 1); + l.set("Subtype", Name.get("Form")); + l.set("Type", Name.get("XObject")); + l.set("BBox", i); + l.set("Matrix", [1, 0, 0, 1, 0, 0]); + l.set("Length", c.length); + const h = new Dict(e.xref), + u = new Dict(e.xref); + u.set("PdfJsZaDb", this.fallbackFontDict); + h.set("Font", u); + l.set("Resources", h); + this.checkedAppearance = new StringStream(c); + this.checkedAppearance.dict = l; + this._streams.push(this.checkedAppearance); + } + _processCheckBox(e) { + const t = e.dict.get("AP"); + if (!(t instanceof Dict)) return; + const a = t.get("N"); + if (!(a instanceof Dict)) return; + const r = this._decodeFormValue(e.dict.get("AS")); + "string" == typeof r && (this.data.fieldValue = r); + const i = + null !== this.data.fieldValue && "Off" !== this.data.fieldValue + ? this.data.fieldValue + : "Yes", + n = this._decodeFormValue(a.getKeys()); + if (0 === n.length) n.push("Off", i); + else if (1 === n.length) "Off" === n[0] ? n.push(i) : n.unshift("Off"); + else if (n.includes(i)) { + n.length = 0; + n.push("Off", i); + } else { + const e = n.find((e) => "Off" !== e); + n.length = 0; + n.push("Off", e); + } + n.includes(this.data.fieldValue) || (this.data.fieldValue = "Off"); + this.data.exportValue = n[1]; + const s = a.get(this.data.exportValue); + this.checkedAppearance = s instanceof BaseStream ? s : null; + const o = a.get("Off"); + this.uncheckedAppearance = o instanceof BaseStream ? o : null; + this.checkedAppearance + ? this._streams.push(this.checkedAppearance) + : this._getDefaultCheckedAppearance(e, "check"); + this.uncheckedAppearance && this._streams.push(this.uncheckedAppearance); + this._fallbackFontDict = this.fallbackFontDict; + null === this.data.defaultFieldValue && + (this.data.defaultFieldValue = "Off"); + } + _processRadioButton(e) { + this.data.buttonValue = null; + const t = e.dict.get("Parent"); + if (t instanceof Dict) { + this.parent = e.dict.getRaw("Parent"); + const a = t.get("V"); + a instanceof Name && (this.data.fieldValue = this._decodeFormValue(a)); + } + const a = e.dict.get("AP"); + if (!(a instanceof Dict)) return; + const r = a.get("N"); + if (!(r instanceof Dict)) return; + for (const e of r.getKeys()) + if ("Off" !== e) { + this.data.buttonValue = this._decodeFormValue(e); + break; + } + const i = r.get(this.data.buttonValue); + this.checkedAppearance = i instanceof BaseStream ? i : null; + const n = r.get("Off"); + this.uncheckedAppearance = n instanceof BaseStream ? n : null; + this.checkedAppearance + ? this._streams.push(this.checkedAppearance) + : this._getDefaultCheckedAppearance(e, "disc"); + this.uncheckedAppearance && this._streams.push(this.uncheckedAppearance); + this._fallbackFontDict = this.fallbackFontDict; + null === this.data.defaultFieldValue && + (this.data.defaultFieldValue = "Off"); + } + _processPushButton(e) { + const { dict: t, annotationGlobals: a } = e; + if (t.has("A") || t.has("AA") || this.data.alternativeText) { + this.data.isTooltipOnly = !t.has("A") && !t.has("AA"); + Catalog.parseDestDictionary({ + destDict: t, + resultObj: this.data, + docBaseUrl: a.baseUrl, + docAttachments: a.attachments, + }); + } else warn("Push buttons without action dictionaries are not supported"); + } + getFieldObject() { + let e, + t = "button"; + if (this.data.checkBox) { + t = "checkbox"; + e = this.data.exportValue; + } else if (this.data.radioButton) { + t = "radiobutton"; + e = this.data.buttonValue; + } + return { + id: this.data.id, + value: this.data.fieldValue || "Off", + defaultValue: this.data.defaultFieldValue, + exportValues: e, + editable: !this.data.readOnly, + name: this.data.fieldName, + rect: this.data.rect, + hidden: this.data.hidden, + actions: this.data.actions, + page: this.data.pageIndex, + strokeColor: this.data.borderColor, + fillColor: this.data.backgroundColor, + rotation: this.rotation, + type: t, + }; + } + get fallbackFontDict() { + const e = new Dict(); + e.set("BaseFont", Name.get("ZapfDingbats")); + e.set("Type", Name.get("FallbackType")); + e.set("Subtype", Name.get("FallbackType")); + e.set("Encoding", Name.get("ZapfDingbatsEncoding")); + return shadow(this, "fallbackFontDict", e); + } +} +class ChoiceWidgetAnnotation extends WidgetAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.indices = t.getArray("I"); + this.hasIndices = Array.isArray(this.indices) && this.indices.length > 0; + this.data.options = []; + const r = getInheritableProperty({ dict: t, key: "Opt" }); + if (Array.isArray(r)) + for (let e = 0, t = r.length; e < t; e++) { + const t = a.fetchIfRef(r[e]), + i = Array.isArray(t); + this.data.options[e] = { + exportValue: this._decodeFormValue(i ? a.fetchIfRef(t[0]) : t), + displayValue: this._decodeFormValue(i ? a.fetchIfRef(t[1]) : t), + }; + } + if (this.hasIndices) { + this.data.fieldValue = []; + const e = this.data.options.length; + for (const t of this.indices) + Number.isInteger(t) && + t >= 0 && + t < e && + this.data.fieldValue.push(this.data.options[t].exportValue); + } else + "string" == typeof this.data.fieldValue + ? (this.data.fieldValue = [this.data.fieldValue]) + : (this.data.fieldValue ||= []); + 0 === this.data.options.length && + this.data.fieldValue.length > 0 && + (this.data.options = this.data.fieldValue.map((e) => ({ + exportValue: e, + displayValue: e, + }))); + this.data.combo = this.hasFieldFlag(ce); + this.data.multiSelect = this.hasFieldFlag(he); + this._hasText = !0; + } + getFieldObject() { + const e = this.data.combo ? "combobox" : "listbox", + t = this.data.fieldValue.length > 0 ? this.data.fieldValue[0] : null; + return { + id: this.data.id, + value: t, + defaultValue: this.data.defaultFieldValue, + editable: !this.data.readOnly, + name: this.data.fieldName, + rect: this.data.rect, + numItems: this.data.fieldValue.length, + multipleSelection: this.data.multiSelect, + hidden: this.data.hidden, + actions: this.data.actions, + items: this.data.options, + page: this.data.pageIndex, + strokeColor: this.data.borderColor, + fillColor: this.data.backgroundColor, + rotation: this.rotation, + type: e, + }; + } + amendSavedDict(e, t) { + if (!this.hasIndices) return; + let a = e?.get(this.data.id)?.value; + Array.isArray(a) || (a = [a]); + const r = [], + { options: i } = this.data; + for (let e = 0, t = 0, n = i.length; e < n; e++) + if (i[e].exportValue === a[t]) { + r.push(e); + t += 1; + } + t.set("I", r); + } + async _getAppearance(e, t, r, i) { + if (this.data.combo) return super._getAppearance(e, t, r, i); + let n, s; + const o = i?.get(this.data.id); + if (o) { + s = o.rotation; + n = o.value; + } + if (void 0 === s && void 0 === n && !this._needAppearances) return null; + void 0 === n ? (n = this.data.fieldValue) : Array.isArray(n) || (n = [n]); + let { width: c, height: l } = this; + (90 !== s && 270 !== s) || ([c, l] = [l, c]); + const h = this.data.options.length, + u = []; + for (let e = 0; e < h; e++) { + const { exportValue: t } = this.data.options[e]; + n.includes(t) && u.push(e); + } + this._defaultAppearance || + (this.data.defaultAppearanceData = parseDefaultAppearance( + (this._defaultAppearance = "/Helvetica 0 Tf 0 g"), + )); + const d = await WidgetAnnotation._getFontData( + e, + t, + this.data.defaultAppearanceData, + this._fieldResources.mergedResources, + ); + let f, + { fontSize: g } = this.data.defaultAppearanceData; + if (g) f = this._defaultAppearance; + else { + const e = (l - 1) / h; + let t, + a = -1; + for (const { displayValue: e } of this.data.options) { + const r = this._getTextWidth(e, d); + if (r > a) { + a = r; + t = e; + } + } + [f, g] = this._computeFontSize(e, c - 4, t, d, -1); + } + const p = g * a, + m = (p - g) / 2, + b = Math.floor(l / p); + let y = 0; + if (u.length > 0) { + const e = Math.min(...u), + t = Math.max(...u); + y = Math.max(0, t - b + 1); + y > e && (y = e); + } + const w = Math.min(y + b + 1, h), + x = ["/Tx BMC q", `1 1 ${c} ${l} re W n`]; + if (u.length) { + x.push("0.600006 0.756866 0.854904 rg"); + for (const e of u) + y <= e && e < w && x.push(`1 ${l - (e - y + 1) * p} ${c} ${p} re f`); + } + x.push("BT", f, `1 0 0 1 0 ${l} Tm`); + const S = { shift: 0 }; + for (let e = y; e < w; e++) { + const { displayValue: t } = this.data.options[e], + a = e === y ? m : 0; + x.push(this._renderText(t, d, g, c, 0, S, 2, -p + a)); + } + x.push("ET Q EMC"); + return x.join("\n"); + } +} +class SignatureWidgetAnnotation extends WidgetAnnotation { + constructor(e) { + super(e); + this.data.fieldValue = null; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !this.data.hasOwnCanvas; + } + getFieldObject() { + return { + id: this.data.id, + value: null, + page: this.data.pageIndex, + type: "signature", + }; + } +} +class TextAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + this.data.noRotate = !0; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + const { dict: t } = e; + this.data.annotationType = F; + if (this.data.hasAppearance) this.data.name = "NoIcon"; + else { + this.data.rect[1] = this.data.rect[3] - 22; + this.data.rect[2] = this.data.rect[0] + 22; + this.data.name = t.has("Name") ? t.get("Name").name : "Note"; + } + if (t.has("State")) { + this.data.state = t.get("State") || null; + this.data.stateModel = t.get("StateModel") || null; + } else { + this.data.state = null; + this.data.stateModel = null; + } + } +} +class LinkAnnotation extends Annotation { + constructor(e) { + super(e); + const { dict: t, annotationGlobals: a } = e; + this.data.annotationType = T; + this.data.noHTML = !1; + const r = getQuadPoints(t, this.rectangle); + r && (this.data.quadPoints = r); + this.data.borderColor ||= this.data.color; + Catalog.parseDestDictionary({ + destDict: t, + resultObj: this.data, + docBaseUrl: a.baseUrl, + docAttachments: a.attachments, + }); + } +} +class PopupAnnotation extends Annotation { + constructor(e) { + super(e); + const { dict: t } = e; + this.data.annotationType = W; + this.data.noHTML = !1; + (0 !== this.width && 0 !== this.height) || (this.data.rect = null); + let a = t.get("Parent"); + if (!a) { + warn("Popup annotation has a missing or invalid parent annotation."); + return; + } + this.data.parentRect = lookupNormalRect(a.getArray("Rect"), null); + isName(a.get("RT"), G) && (a = a.get("IRT")); + if (a.has("M")) { + this.setModificationDate(a.get("M")); + this.data.modificationDate = this.modificationDate; + } else this.data.modificationDate = null; + if (a.has("C")) { + this.setColor(a.getArray("C")); + this.data.color = this.color; + } else this.data.color = null; + if (!this.viewable) { + const e = a.get("F"); + this._isViewable(e) && this.setFlags(e); + } + this.setTitle(a.get("T")); + this.data.titleObj = this._title; + this.setContents(a.get("Contents")); + this.data.contentsObj = this._contents; + a.has("RC") && + (this.data.richText = XFAFactory.getRichTextAsHtml(a.get("RC"))); + this.data.open = !!t.get("Open"); + } +} +class FreeTextAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + this.data.hasOwnCanvas = this.data.noRotate; + this.data.isEditable = !this.data.noHTML; + this.data.noHTML = !1; + const { annotationGlobals: t, evaluatorOptions: a, xref: r } = e; + this.data.annotationType = O; + this.setDefaultAppearance(e); + this._hasAppearance = !!this.appearance; + if (this._hasAppearance) { + const { fontColor: e, fontSize: i } = (function parseAppearanceStream( + e, + t, + a, + r, + ) { + return new AppearanceStreamEvaluator(e, t, a, r).parse(); + })(this.appearance, a, r, t.globalColorSpaceCache); + this.data.defaultAppearanceData.fontColor = e; + this.data.defaultAppearanceData.fontSize = i || 10; + } else { + this.data.defaultAppearanceData.fontSize ||= 10; + const { fontColor: t, fontSize: a } = this.data.defaultAppearanceData; + if (this._contents.str) { + this.data.textContent = this._contents.str + .split(/\r\n?|\n/) + .map((e) => e.trimEnd()); + const { + coords: e, + bbox: t, + matrix: r, + } = FakeUnicodeFont.getFirstPositionInfo( + this.rectangle, + this.rotation, + a, + ); + this.data.textPosition = this._transformPoint(e, t, r); + } + if (this._isOffscreenCanvasSupported) { + const i = e.dict.get("CA"), + n = new FakeUnicodeFont(r, "sans-serif"); + this.appearance = n.createAppearance( + this._contents.str, + this.rectangle, + this.rotation, + a, + t, + i, + ); + this._streams.push(this.appearance); + } else + warn( + "FreeTextAnnotation: OffscreenCanvas is not supported, annotation may not render correctly.", + ); + } + } + get hasTextContent() { + return this._hasAppearance; + } + static createNewDict(e, t, { apRef: a, ap: r }) { + const { + color: i, + fontSize: n, + oldAnnotation: s, + rect: o, + rotation: c, + user: l, + value: h, + } = e, + u = s || new Dict(t); + u.set("Type", Name.get("Annot")); + u.set("Subtype", Name.get("FreeText")); + if (s) { + u.set("M", `D:${getModificationDate()}`); + u.delete("RC"); + } else u.set("CreationDate", `D:${getModificationDate()}`); + u.set("Rect", o); + const d = `/Helv ${n} Tf ${getPdfColor(i, !0)}`; + u.set("DA", d); + u.set("Contents", stringToAsciiOrUTF16BE(h)); + u.set("F", 4); + u.set("Border", [0, 0, 0]); + u.set("Rotate", c); + l && u.set("T", stringToAsciiOrUTF16BE(l)); + if (a || r) { + const e = new Dict(t); + u.set("AP", e); + a ? e.set("N", a) : e.set("N", r); + } + return u; + } + static async createNewAppearanceStream(e, t, r) { + const { baseFontRef: i, evaluator: n, task: s } = r, + { color: o, fontSize: c, rect: l, rotation: h, value: u } = e, + d = new Dict(t), + f = new Dict(t); + if (i) f.set("Helv", i); + else { + const e = new Dict(t); + e.set("BaseFont", Name.get("Helvetica")); + e.set("Type", Name.get("Font")); + e.set("Subtype", Name.get("Type1")); + e.set("Encoding", Name.get("WinAnsiEncoding")); + f.set("Helv", e); + } + d.set("Font", f); + const g = await WidgetAnnotation._getFontData( + n, + s, + { fontName: "Helv", fontSize: c }, + d, + ), + [p, m, b, y] = l; + let w = b - p, + x = y - m; + h % 180 != 0 && ([w, x] = [x, w]); + const S = u.split("\n"), + k = c / 1e3; + let C = -1 / 0; + const v = []; + for (let e of S) { + const t = g.encodeString(e); + if (t.length > 1) return null; + e = t.join(""); + v.push(e); + let a = 0; + const r = g.charsToGlyphs(e); + for (const e of r) a += e.width * k; + C = Math.max(C, a); + } + let F = 1; + C > w && (F = w / C); + let T = 1; + const O = a * c, + M = 1 * c, + D = O * S.length; + D > x && (T = x / D); + const R = c * Math.min(F, T); + let N, E, L; + switch (h) { + case 0: + L = [1, 0, 0, 1]; + E = [l[0], l[1], w, x]; + N = [l[0], l[3] - M]; + break; + case 90: + L = [0, 1, -1, 0]; + E = [l[1], -l[2], w, x]; + N = [l[1], -l[0] - M]; + break; + case 180: + L = [-1, 0, 0, -1]; + E = [-l[2], -l[3], w, x]; + N = [-l[2], -l[1] - M]; + break; + case 270: + L = [0, -1, 1, 0]; + E = [-l[3], l[0], w, x]; + N = [-l[3], l[2] - M]; + } + const j = [ + "q", + `${L.join(" ")} 0 0 cm`, + `${E.join(" ")} re W n`, + "BT", + `${getPdfColor(o, !0)}`, + `0 Tc /Helv ${numberToString(R)} Tf`, + ]; + j.push(`${N.join(" ")} Td (${escapeString(v[0])}) Tj`); + const _ = numberToString(O); + for (let e = 1, t = v.length; e < t; e++) { + const t = v[e]; + j.push(`0 -${_} Td (${escapeString(t)}) Tj`); + } + j.push("ET", "Q"); + const U = j.join("\n"), + X = new Dict(t); + X.set("FormType", 1); + X.set("Subtype", Name.get("Form")); + X.set("Type", Name.get("XObject")); + X.set("BBox", l); + X.set("Resources", d); + X.set("Matrix", [1, 0, 0, 1, -l[0], -l[1]]); + const q = new StringStream(U); + q.dict = X; + return q; + } +} +class LineAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = M; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + const r = lookupRect(t.getArray("L"), [0, 0, 0, 0]); + this.data.lineCoordinates = Util.normalizeRect(r); + this.setLineEndings(t.getArray("LE")); + this.data.lineEndings = this.lineEndings; + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + i = t.get("CA"), + n = getRgbColor(t.getArray("IC"), null), + s = n ? getPdfColorArray(n) : null, + o = s ? i : null, + c = this.borderStyle.width || 1, + l = 2 * c, + h = [ + this.data.lineCoordinates[0] - l, + this.data.lineCoordinates[1] - l, + this.data.lineCoordinates[2] + l, + this.data.lineCoordinates[3] + l, + ]; + Util.intersect(this.rectangle, h) || (this.rectangle = h); + this._setDefaultAppearance({ + xref: a, + extra: `${c} w`, + strokeColor: e, + fillColor: s, + strokeAlpha: i, + fillAlpha: o, + pointsCallback: (e, t) => { + e.push(`${r[0]} ${r[1]} m`, `${r[2]} ${r[3]} l`, "S"); + return [t[0] - c, t[7] - c, t[2] + c, t[3] + c]; + }, + }); + } + } +} +class SquareAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = D; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"), + i = getRgbColor(t.getArray("IC"), null), + n = i ? getPdfColorArray(i) : null, + s = n ? r : null; + if (0 === this.borderStyle.width && !n) return; + this._setDefaultAppearance({ + xref: a, + extra: `${this.borderStyle.width} w`, + strokeColor: e, + fillColor: n, + strokeAlpha: r, + fillAlpha: s, + pointsCallback: (e, t) => { + const a = t[4] + this.borderStyle.width / 2, + r = t[5] + this.borderStyle.width / 2, + i = t[6] - t[4] - this.borderStyle.width, + s = t[3] - t[7] - this.borderStyle.width; + e.push(`${a} ${r} ${i} ${s} re`); + n ? e.push("B") : e.push("S"); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } +} +class CircleAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = R; + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"), + i = getRgbColor(t.getArray("IC"), null), + n = i ? getPdfColorArray(i) : null, + s = n ? r : null; + if (0 === this.borderStyle.width && !n) return; + const o = (4 / 3) * Math.tan(Math.PI / 8); + this._setDefaultAppearance({ + xref: a, + extra: `${this.borderStyle.width} w`, + strokeColor: e, + fillColor: n, + strokeAlpha: r, + fillAlpha: s, + pointsCallback: (e, t) => { + const a = t[0] + this.borderStyle.width / 2, + r = t[1] - this.borderStyle.width / 2, + i = t[6] - this.borderStyle.width / 2, + s = t[7] + this.borderStyle.width / 2, + c = a + (i - a) / 2, + l = r + (s - r) / 2, + h = ((i - a) / 2) * o, + u = ((s - r) / 2) * o; + e.push( + `${c} ${s} m`, + `${c + h} ${s} ${i} ${l + u} ${i} ${l} c`, + `${i} ${l - u} ${c + h} ${r} ${c} ${r} c`, + `${c - h} ${r} ${a} ${l - u} ${a} ${l} c`, + `${a} ${l + u} ${c - h} ${s} ${c} ${s} c`, + "h", + ); + n ? e.push("B") : e.push("S"); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } +} +class PolylineAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = E; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + this.data.vertices = null; + if (!(this instanceof PolygonAnnotation)) { + this.setLineEndings(t.getArray("LE")); + this.data.lineEndings = this.lineEndings; + } + const r = t.getArray("Vertices"); + if (!isNumberArray(r, null)) return; + const i = (this.data.vertices = Float32Array.from(r)); + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"), + n = this.borderStyle.width || 1, + s = 2 * n, + o = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; + for (let e = 0, t = i.length; e < t; e += 2) + Util.rectBoundingBox(i[e] - s, i[e + 1] - s, i[e] + s, i[e + 1] + s, o); + Util.intersect(this.rectangle, o) || (this.rectangle = o); + this._setDefaultAppearance({ + xref: a, + extra: `${n} w`, + strokeColor: e, + strokeAlpha: r, + pointsCallback: (e, t) => { + for (let t = 0, a = i.length; t < a; t += 2) + e.push(`${i[t]} ${i[t + 1]} ${0 === t ? "m" : "l"}`); + e.push("S"); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } +} +class PolygonAnnotation extends PolylineAnnotation { + constructor(e) { + super(e); + this.data.annotationType = N; + } +} +class CaretAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + this.data.annotationType = q; + } +} +class InkAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + const { dict: t, xref: a } = e; + this.data.annotationType = H; + this.data.inkLists = []; + this.data.isEditable = !this.data.noHTML; + this.data.noHTML = !1; + this.data.opacity = t.get("CA") || 1; + const r = t.getArray("InkList"); + if (Array.isArray(r)) { + for (let e = 0, t = r.length; e < t; ++e) { + if (!Array.isArray(r[e])) continue; + const t = new Float32Array(r[e].length); + this.data.inkLists.push(t); + for (let i = 0, n = r[e].length; i < n; i += 2) { + const n = a.fetchIfRef(r[e][i]), + s = a.fetchIfRef(r[e][i + 1]); + if ("number" == typeof n && "number" == typeof s) { + t[i] = n; + t[i + 1] = s; + } + } + } + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"), + i = this.borderStyle.width || 1, + n = 2 * i, + s = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; + for (const e of this.data.inkLists) + for (let t = 0, a = e.length; t < a; t += 2) + Util.rectBoundingBox( + e[t] - n, + e[t + 1] - n, + e[t] + n, + e[t + 1] + n, + s, + ); + Util.intersect(this.rectangle, s) || (this.rectangle = s); + this._setDefaultAppearance({ + xref: a, + extra: `${i} w`, + strokeColor: e, + strokeAlpha: r, + pointsCallback: (e, t) => { + for (const t of this.data.inkLists) { + for (let a = 0, r = t.length; a < r; a += 2) + e.push(`${t[a]} ${t[a + 1]} ${0 === a ? "m" : "l"}`); + e.push("S"); + } + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } + } + static createNewDict(e, t, { apRef: a, ap: r }) { + const { + oldAnnotation: i, + color: n, + opacity: s, + paths: o, + outlines: c, + rect: l, + rotation: h, + thickness: u, + user: d, + } = e, + f = i || new Dict(t); + f.set("Type", Name.get("Annot")); + f.set("Subtype", Name.get("Ink")); + f.set(i ? "M" : "CreationDate", `D:${getModificationDate()}`); + f.set("Rect", l); + f.set("InkList", c?.points || o.points); + f.set("F", 4); + f.set("Rotate", h); + d && f.set("T", stringToAsciiOrUTF16BE(d)); + c && f.set("IT", Name.get("InkHighlight")); + const g = new Dict(t); + f.set("BS", g); + g.set("W", u); + f.set("C", getPdfColorArray(n)); + f.set("CA", s); + const p = new Dict(t); + f.set("AP", p); + a ? p.set("N", a) : p.set("N", r); + return f; + } + static async createNewAppearanceStream(e, t, a) { + if (e.outlines) return this.createNewAppearanceStreamForHighlight(e, t, a); + const { color: r, rect: i, paths: n, thickness: s, opacity: o } = e, + c = [`${s} w 1 J 1 j`, `${getPdfColor(r, !1)}`]; + 1 !== o && c.push("/R0 gs"); + for (const e of n.lines) { + c.push(`${numberToString(e[4])} ${numberToString(e[5])} m`); + for (let t = 6, a = e.length; t < a; t += 6) + if (isNaN(e[t])) + c.push(`${numberToString(e[t + 4])} ${numberToString(e[t + 5])} l`); + else { + const [a, r, i, n, s, o] = e.slice(t, t + 6); + c.push([a, r, i, n, s, o].map(numberToString).join(" ") + " c"); + } + 6 === e.length && + c.push(`${numberToString(e[4])} ${numberToString(e[5])} l`); + } + c.push("S"); + const l = c.join("\n"), + h = new Dict(t); + h.set("FormType", 1); + h.set("Subtype", Name.get("Form")); + h.set("Type", Name.get("XObject")); + h.set("BBox", i); + h.set("Length", l.length); + if (1 !== o) { + const e = new Dict(t), + a = new Dict(t), + r = new Dict(t); + r.set("CA", o); + r.set("Type", Name.get("ExtGState")); + a.set("R0", r); + e.set("ExtGState", a); + h.set("Resources", e); + } + const u = new StringStream(l); + u.dict = h; + return u; + } + static async createNewAppearanceStreamForHighlight(e, t, a) { + const { + color: r, + rect: i, + outlines: { outline: n }, + opacity: s, + } = e, + o = [`${getPdfColor(r, !0)}`, "/R0 gs"]; + o.push(`${numberToString(n[4])} ${numberToString(n[5])} m`); + for (let e = 6, t = n.length; e < t; e += 6) + if (isNaN(n[e])) + o.push(`${numberToString(n[e + 4])} ${numberToString(n[e + 5])} l`); + else { + const [t, a, r, i, s, c] = n.slice(e, e + 6); + o.push([t, a, r, i, s, c].map(numberToString).join(" ") + " c"); + } + o.push("h f"); + const c = o.join("\n"), + l = new Dict(t); + l.set("FormType", 1); + l.set("Subtype", Name.get("Form")); + l.set("Type", Name.get("XObject")); + l.set("BBox", i); + l.set("Length", c.length); + const h = new Dict(t), + u = new Dict(t); + h.set("ExtGState", u); + l.set("Resources", h); + const d = new Dict(t); + u.set("R0", d); + d.set("BM", Name.get("Multiply")); + if (1 !== s) { + d.set("ca", s); + d.set("Type", Name.get("ExtGState")); + } + const f = new StringStream(c); + f.dict = l; + return f; + } +} +class HighlightAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = L; + this.data.isEditable = !this.data.noHTML; + this.data.noHTML = !1; + this.data.opacity = t.get("CA") || 1; + if ((this.data.quadPoints = getQuadPoints(t, null))) { + const e = this.appearance?.dict.get("Resources"); + if (!this.appearance || !e?.has("ExtGState")) { + this.appearance && + warn("HighlightAnnotation - ignoring built-in appearance stream."); + const e = this.color ? getPdfColorArray(this.color) : [1, 1, 0], + r = t.get("CA"); + this._setDefaultAppearance({ + xref: a, + fillColor: e, + blendMode: "Multiply", + fillAlpha: r, + pointsCallback: (e, t) => { + e.push( + `${t[0]} ${t[1]} m`, + `${t[2]} ${t[3]} l`, + `${t[6]} ${t[7]} l`, + `${t[4]} ${t[5]} l`, + "f", + ); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } else this.data.popupRef = null; + } + get overlaysTextContent() { + return !0; + } + static createNewDict(e, t, { apRef: a, ap: r }) { + const { + color: i, + oldAnnotation: n, + opacity: s, + rect: o, + rotation: c, + user: l, + quadPoints: h, + } = e, + u = n || new Dict(t); + u.set("Type", Name.get("Annot")); + u.set("Subtype", Name.get("Highlight")); + u.set(n ? "M" : "CreationDate", `D:${getModificationDate()}`); + u.set("CreationDate", `D:${getModificationDate()}`); + u.set("Rect", o); + u.set("F", 4); + u.set("Border", [0, 0, 0]); + u.set("Rotate", c); + u.set("QuadPoints", h); + u.set("C", getPdfColorArray(i)); + u.set("CA", s); + l && u.set("T", stringToAsciiOrUTF16BE(l)); + if (a || r) { + const e = new Dict(t); + u.set("AP", e); + e.set("N", a || r); + } + return u; + } + static async createNewAppearanceStream(e, t, a) { + const { color: r, rect: i, outlines: n, opacity: s } = e, + o = [`${getPdfColor(r, !0)}`, "/R0 gs"], + c = []; + for (const e of n) { + c.length = 0; + c.push(`${numberToString(e[0])} ${numberToString(e[1])} m`); + for (let t = 2, a = e.length; t < a; t += 2) + c.push(`${numberToString(e[t])} ${numberToString(e[t + 1])} l`); + c.push("h"); + o.push(c.join("\n")); + } + o.push("f*"); + const l = o.join("\n"), + h = new Dict(t); + h.set("FormType", 1); + h.set("Subtype", Name.get("Form")); + h.set("Type", Name.get("XObject")); + h.set("BBox", i); + h.set("Length", l.length); + const u = new Dict(t), + d = new Dict(t); + u.set("ExtGState", d); + h.set("Resources", u); + const f = new Dict(t); + d.set("R0", f); + f.set("BM", Name.get("Multiply")); + if (1 !== s) { + f.set("ca", s); + f.set("Type", Name.get("ExtGState")); + } + const g = new StringStream(l); + g.dict = h; + return g; + } +} +class UnderlineAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = j; + if ((this.data.quadPoints = getQuadPoints(t, null))) { + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"); + this._setDefaultAppearance({ + xref: a, + extra: "[] 0 d 0.571 w", + strokeColor: e, + strokeAlpha: r, + pointsCallback: (e, t) => { + e.push(`${t[4]} ${t[5] + 1.3} m`, `${t[6]} ${t[7] + 1.3} l`, "S"); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } else this.data.popupRef = null; + } + get overlaysTextContent() { + return !0; + } +} +class SquigglyAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = _; + if ((this.data.quadPoints = getQuadPoints(t, null))) { + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"); + this._setDefaultAppearance({ + xref: a, + extra: "[] 0 d 1 w", + strokeColor: e, + strokeAlpha: r, + pointsCallback: (e, t) => { + const a = (t[1] - t[5]) / 6; + let r = a, + i = t[4]; + const n = t[5], + s = t[6]; + e.push(`${i} ${n + r} m`); + do { + i += 2; + r = 0 === r ? a : 0; + e.push(`${i} ${n + r} l`); + } while (i < s); + e.push("S"); + return [t[4], n - 2 * a, s, n + 2 * a]; + }, + }); + } + } else this.data.popupRef = null; + } + get overlaysTextContent() { + return !0; + } +} +class StrikeOutAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e; + this.data.annotationType = U; + if ((this.data.quadPoints = getQuadPoints(t, null))) { + if (!this.appearance) { + const e = this.color ? getPdfColorArray(this.color) : [0, 0, 0], + r = t.get("CA"); + this._setDefaultAppearance({ + xref: a, + extra: "[] 0 d 1 w", + strokeColor: e, + strokeAlpha: r, + pointsCallback: (e, t) => { + e.push( + (t[0] + t[4]) / 2 + " " + (t[1] + t[5]) / 2 + " m", + (t[2] + t[6]) / 2 + " " + (t[3] + t[7]) / 2 + " l", + "S", + ); + return [t[0], t[7], t[2], t[3]]; + }, + }); + } + } else this.data.popupRef = null; + } + get overlaysTextContent() { + return !0; + } +} +class StampAnnotation extends MarkupAnnotation { + #pe = null; + constructor(e) { + super(e); + this.data.annotationType = X; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.isEditable = !this.data.noHTML; + this.data.noHTML = !1; + } + mustBeViewedWhenEditing(e, t = null) { + if (e) { + if (!this.data.isEditable) return !0; + this.#pe ??= this.data.hasOwnCanvas; + this.data.hasOwnCanvas = !0; + return !0; + } + if (null !== this.#pe) { + this.data.hasOwnCanvas = this.#pe; + this.#pe = null; + } + return !t?.has(this.data.id); + } + static async createImage(e, t) { + const { width: a, height: r } = e, + i = new OffscreenCanvas(a, r), + n = i.getContext("2d", { alpha: !0 }); + n.drawImage(e, 0, 0); + const s = n.getImageData(0, 0, a, r).data, + o = new Uint32Array(s.buffer), + c = o.some( + FeatureTest.isLittleEndian + ? (e) => e >>> 24 != 255 + : (e) => !!(255 & ~e), + ); + if (c) { + n.fillStyle = "white"; + n.fillRect(0, 0, a, r); + n.drawImage(e, 0, 0); + } + const l = i + .convertToBlob({ type: "image/jpeg", quality: 1 }) + .then((e) => e.arrayBuffer()), + h = Name.get("XObject"), + u = Name.get("Image"), + d = new Dict(t); + d.set("Type", h); + d.set("Subtype", u); + d.set("BitsPerComponent", 8); + d.set("ColorSpace", Name.get("DeviceRGB")); + d.set("Filter", Name.get("DCTDecode")); + d.set("BBox", [0, 0, a, r]); + d.set("Width", a); + d.set("Height", r); + let f = null; + if (c) { + const e = new Uint8Array(o.length); + if (FeatureTest.isLittleEndian) + for (let t = 0, a = o.length; t < a; t++) e[t] = o[t] >>> 24; + else for (let t = 0, a = o.length; t < a; t++) e[t] = 255 & o[t]; + const i = new Dict(t); + i.set("Type", h); + i.set("Subtype", u); + i.set("BitsPerComponent", 8); + i.set("ColorSpace", Name.get("DeviceGray")); + i.set("Width", a); + i.set("Height", r); + f = new Stream(e, 0, 0, i); + } + return { + imageStream: new Stream(await l, 0, 0, d), + smaskStream: f, + width: a, + height: r, + }; + } + static createNewDict(e, t, { apRef: a, ap: r }) { + const { oldAnnotation: i, rect: n, rotation: s, user: o } = e, + c = i || new Dict(t); + c.set("Type", Name.get("Annot")); + c.set("Subtype", Name.get("Stamp")); + c.set(i ? "M" : "CreationDate", `D:${getModificationDate()}`); + c.set("Rect", n); + c.set("F", 4); + c.set("Border", [0, 0, 0]); + c.set("Rotate", s); + o && c.set("T", stringToAsciiOrUTF16BE(o)); + if (a || r) { + const e = new Dict(t); + c.set("AP", e); + a ? e.set("N", a) : e.set("N", r); + } + return c; + } + static async #me(e, t) { + const { areContours: a, color: r, rect: i, lines: n, thickness: s } = e, + o = [`${s} w 1 J 1 j`, `${getPdfColor(r, a)}`]; + for (const e of n) { + o.push(`${numberToString(e[4])} ${numberToString(e[5])} m`); + for (let t = 6, a = e.length; t < a; t += 6) + if (isNaN(e[t])) + o.push(`${numberToString(e[t + 4])} ${numberToString(e[t + 5])} l`); + else { + const [a, r, i, n, s, c] = e.slice(t, t + 6); + o.push([a, r, i, n, s, c].map(numberToString).join(" ") + " c"); + } + 6 === e.length && + o.push(`${numberToString(e[4])} ${numberToString(e[5])} l`); + } + o.push(a ? "F" : "S"); + const c = o.join("\n"), + l = new Dict(t); + l.set("FormType", 1); + l.set("Subtype", Name.get("Form")); + l.set("Type", Name.get("XObject")); + l.set("BBox", i); + l.set("Length", c.length); + const h = new StringStream(c); + h.dict = l; + return h; + } + static async createNewAppearanceStream(e, t, a) { + if (e.oldAnnotation) return null; + if (e.isSignature) return this.#me(e, t); + const { rotation: r } = e, + { imageRef: i, width: n, height: s } = a.image, + o = new Dict(t), + c = new Dict(t); + o.set("XObject", c); + c.set("Im0", i); + const l = `q ${n} 0 0 ${s} 0 0 cm /Im0 Do Q`, + h = new Dict(t); + h.set("FormType", 1); + h.set("Subtype", Name.get("Form")); + h.set("Type", Name.get("XObject")); + h.set("BBox", [0, 0, n, s]); + h.set("Resources", o); + if (r) { + const e = getRotationMatrix(r, n, s); + h.set("Matrix", e); + } + const u = new StringStream(l); + u.dict = h; + return u; + } +} +class FileAttachmentAnnotation extends MarkupAnnotation { + constructor(e) { + super(e); + const { dict: t, xref: a } = e, + r = new FileSpec(t.get("FS"), a); + this.data.annotationType = z; + this.data.hasOwnCanvas = this.data.noRotate; + this.data.noHTML = !1; + this.data.file = r.serializable; + const i = t.get("Name"); + this.data.name = i instanceof Name ? stringToPDFString(i.name) : "PushPin"; + const n = t.get("ca"); + this.data.fillAlpha = "number" == typeof n && n >= 0 && n <= 1 ? n : null; + } +} +const pc = { + get r() { + return shadow( + this, + "r", + new Uint8Array([ + 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 5, 9, 14, + 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 4, 11, 16, 23, 4, 11, 16, + 23, 4, 11, 16, 23, 4, 11, 16, 23, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, + 15, 21, 6, 10, 15, 21, + ]), + ); + }, + get k() { + return shadow( + this, + "k", + new Int32Array([ + -680876936, -389564586, 606105819, -1044525330, -176418897, 1200080426, + -1473231341, -45705983, 1770035416, -1958414417, -42063, -1990404162, + 1804603682, -40341101, -1502002290, 1236535329, -165796510, -1069501632, + 643717713, -373897302, -701558691, 38016083, -660478335, -405537848, + 568446438, -1019803690, -187363961, 1163531501, -1444681467, -51403784, + 1735328473, -1926607734, -378558, -2022574463, 1839030562, -35309556, + -1530992060, 1272893353, -155497632, -1094730640, 681279174, -358537222, + -722521979, 76029189, -640364487, -421815835, 530742520, -995338651, + -198630844, 1126891415, -1416354905, -57434055, 1700485571, -1894986606, + -1051523, -2054922799, 1873313359, -30611744, -1560198380, 1309151649, + -145523070, -1120210379, 718787259, -343485551, + ]), + ); + }, +}; +function calculateMD5(e, t, a) { + let r = 1732584193, + i = -271733879, + n = -1732584194, + s = 271733878; + const o = (a + 72) & -64, + c = new Uint8Array(o); + let l, h; + for (l = 0; l < a; ++l) c[l] = e[t++]; + c[l++] = 128; + const u = o - 8; + l < u && (l = u); + c[l++] = (a << 3) & 255; + c[l++] = (a >> 5) & 255; + c[l++] = (a >> 13) & 255; + c[l++] = (a >> 21) & 255; + c[l++] = (a >>> 29) & 255; + l += 3; + const d = new Int32Array(16), + { k: f, r: g } = pc; + for (l = 0; l < o; ) { + for (h = 0; h < 16; ++h, l += 4) + d[h] = c[l] | (c[l + 1] << 8) | (c[l + 2] << 16) | (c[l + 3] << 24); + let e, + t, + a = r, + o = i, + u = n, + p = s; + for (h = 0; h < 64; ++h) { + if (h < 16) { + e = (o & u) | (~o & p); + t = h; + } else if (h < 32) { + e = (p & o) | (~p & u); + t = (5 * h + 1) & 15; + } else if (h < 48) { + e = o ^ u ^ p; + t = (3 * h + 5) & 15; + } else { + e = u ^ (o | ~p); + t = (7 * h) & 15; + } + const r = p, + i = (a + e + f[h] + d[t]) | 0, + n = g[h]; + p = u; + u = o; + o = (o + ((i << n) | (i >>> (32 - n)))) | 0; + a = r; + } + r = (r + a) | 0; + i = (i + o) | 0; + n = (n + u) | 0; + s = (s + p) | 0; + } + return new Uint8Array([ + 255 & r, + (r >> 8) & 255, + (r >> 16) & 255, + (r >>> 24) & 255, + 255 & i, + (i >> 8) & 255, + (i >> 16) & 255, + (i >>> 24) & 255, + 255 & n, + (n >> 8) & 255, + (n >> 16) & 255, + (n >>> 24) & 255, + 255 & s, + (s >> 8) & 255, + (s >> 16) & 255, + (s >>> 24) & 255, + ]); +} +function decodeString(e) { + try { + return stringToUTF8String(e); + } catch (t) { + warn(`UTF-8 decoding failed: "${t}".`); + return e; + } +} +class DatasetXMLParser extends SimpleXMLParser { + constructor(e) { + super(e); + this.node = null; + } + onEndElement(e) { + const t = super.onEndElement(e); + if (t && "xfa:datasets" === e) { + this.node = t; + throw new Error("Aborting DatasetXMLParser."); + } + } +} +class DatasetReader { + constructor(e) { + if (e.datasets) + this.node = new SimpleXMLParser({ hasAttributes: !0 }).parseFromString( + e.datasets, + ).documentElement; + else { + const t = new DatasetXMLParser({ hasAttributes: !0 }); + try { + t.parseFromString(e["xdp:xdp"]); + } catch {} + this.node = t.node; + } + } + getValue(e) { + if (!this.node || !e) return ""; + const t = this.node.searchNode(parseXFAPath(e), 0); + if (!t) return ""; + const a = t.firstChild; + return "value" === a?.nodeName + ? t.children.map((e) => decodeString(e.textContent)) + : decodeString(t.textContent); + } +} +class SingleIntersector { + #be; + #ye = 1 / 0; + #we = 1 / 0; + #xe = -1 / 0; + #Se = -1 / 0; + #ke; + #Ae = []; + #Ce = []; + #ve = -1; + #Fe = !1; + constructor(e) { + this.#be = e; + const t = (this.#ke = e.data.quadPoints); + for (let e = 0, a = t.length; e < a; e += 8) { + this.#ye = Math.min(this.#ye, t[e]); + this.#xe = Math.max(this.#xe, t[e + 2]); + this.#we = Math.min(this.#we, t[e + 5]); + this.#Se = Math.max(this.#Se, t[e + 1]); + } + } + overlaps(e) { + return !( + this.#ye >= e.#xe || + this.#xe <= e.#ye || + this.#we >= e.#Se || + this.#Se <= e.#we + ); + } + #Ie(e, t) { + if (this.#ye >= e || this.#xe <= e || this.#we >= t || this.#Se <= t) + return !1; + const a = this.#ke; + if (8 === a.length) return !0; + if (this.#ve >= 0) { + const r = this.#ve; + if (!(a[r] >= e || a[r + 2] <= e || a[r + 5] >= t || a[r + 1] <= t)) + return !0; + this.#ve = -1; + } + for (let r = 0, i = a.length; r < i; r += 8) + if (!(a[r] >= e || a[r + 2] <= e || a[r + 5] >= t || a[r + 1] <= t)) { + this.#ve = r; + return !0; + } + return !1; + } + addGlyph(e, t, a) { + if (!this.#Ie(e, t)) { + this.disableExtraChars(); + return !1; + } + if (this.#Ce.length > 0) { + this.#Ae.push(this.#Ce.join("")); + this.#Ce.length = 0; + } + this.#Ae.push(a); + this.#Fe = !0; + return !0; + } + addExtraChar(e) { + this.#Fe && this.#Ce.push(e); + } + disableExtraChars() { + if (this.#Fe) { + this.#Fe = !1; + this.#Ce.length = 0; + } + } + setText() { + this.#be.data.overlaidText = this.#Ae.join(""); + } +} +class Intersector { + #Te = new Map(); + constructor(e) { + for (const t of e) { + if (!t.data.quadPoints) continue; + const e = new SingleIntersector(t); + for (const [t, a] of this.#Te) + t.overlaps(e) && (a ? a.add(e) : this.#Te.set(t, new Set([e]))); + this.#Te.set(e, null); + } + } + addGlyph(e, t, a, r) { + const i = e[4] + t / 2, + n = e[5] + a / 2; + let s; + for (const [e, t] of this.#Te) + s + ? s.has(e) + ? e.addGlyph(i, n, r) + : e.disableExtraChars() + : e.addGlyph(i, n, r) && (s = t); + } + addExtraChar(e) { + for (const t of this.#Te.keys()) t.addExtraChar(e); + } + setText() { + for (const e of this.#Te.keys()) e.setText(); + } +} +class Word64 { + constructor(e, t) { + this.high = 0 | e; + this.low = 0 | t; + } + and(e) { + this.high &= e.high; + this.low &= e.low; + } + xor(e) { + this.high ^= e.high; + this.low ^= e.low; + } + shiftRight(e) { + if (e >= 32) { + this.low = (this.high >>> (e - 32)) | 0; + this.high = 0; + } else { + this.low = (this.low >>> e) | (this.high << (32 - e)); + this.high = (this.high >>> e) | 0; + } + } + rotateRight(e) { + let t, a; + if (32 & e) { + a = this.low; + t = this.high; + } else { + t = this.low; + a = this.high; + } + e &= 31; + this.low = (t >>> e) | (a << (32 - e)); + this.high = (a >>> e) | (t << (32 - e)); + } + not() { + this.high = ~this.high; + this.low = ~this.low; + } + add(e) { + const t = (this.low >>> 0) + (e.low >>> 0); + let a = (this.high >>> 0) + (e.high >>> 0); + t > 4294967295 && (a += 1); + this.low = 0 | t; + this.high = 0 | a; + } + copyTo(e, t) { + e[t] = (this.high >>> 24) & 255; + e[t + 1] = (this.high >> 16) & 255; + e[t + 2] = (this.high >> 8) & 255; + e[t + 3] = 255 & this.high; + e[t + 4] = (this.low >>> 24) & 255; + e[t + 5] = (this.low >> 16) & 255; + e[t + 6] = (this.low >> 8) & 255; + e[t + 7] = 255 & this.low; + } + assign(e) { + this.high = e.high; + this.low = e.low; + } +} +const mc = { + get k() { + return shadow(this, "k", [ + new Word64(1116352408, 3609767458), + new Word64(1899447441, 602891725), + new Word64(3049323471, 3964484399), + new Word64(3921009573, 2173295548), + new Word64(961987163, 4081628472), + new Word64(1508970993, 3053834265), + new Word64(2453635748, 2937671579), + new Word64(2870763221, 3664609560), + new Word64(3624381080, 2734883394), + new Word64(310598401, 1164996542), + new Word64(607225278, 1323610764), + new Word64(1426881987, 3590304994), + new Word64(1925078388, 4068182383), + new Word64(2162078206, 991336113), + new Word64(2614888103, 633803317), + new Word64(3248222580, 3479774868), + new Word64(3835390401, 2666613458), + new Word64(4022224774, 944711139), + new Word64(264347078, 2341262773), + new Word64(604807628, 2007800933), + new Word64(770255983, 1495990901), + new Word64(1249150122, 1856431235), + new Word64(1555081692, 3175218132), + new Word64(1996064986, 2198950837), + new Word64(2554220882, 3999719339), + new Word64(2821834349, 766784016), + new Word64(2952996808, 2566594879), + new Word64(3210313671, 3203337956), + new Word64(3336571891, 1034457026), + new Word64(3584528711, 2466948901), + new Word64(113926993, 3758326383), + new Word64(338241895, 168717936), + new Word64(666307205, 1188179964), + new Word64(773529912, 1546045734), + new Word64(1294757372, 1522805485), + new Word64(1396182291, 2643833823), + new Word64(1695183700, 2343527390), + new Word64(1986661051, 1014477480), + new Word64(2177026350, 1206759142), + new Word64(2456956037, 344077627), + new Word64(2730485921, 1290863460), + new Word64(2820302411, 3158454273), + new Word64(3259730800, 3505952657), + new Word64(3345764771, 106217008), + new Word64(3516065817, 3606008344), + new Word64(3600352804, 1432725776), + new Word64(4094571909, 1467031594), + new Word64(275423344, 851169720), + new Word64(430227734, 3100823752), + new Word64(506948616, 1363258195), + new Word64(659060556, 3750685593), + new Word64(883997877, 3785050280), + new Word64(958139571, 3318307427), + new Word64(1322822218, 3812723403), + new Word64(1537002063, 2003034995), + new Word64(1747873779, 3602036899), + new Word64(1955562222, 1575990012), + new Word64(2024104815, 1125592928), + new Word64(2227730452, 2716904306), + new Word64(2361852424, 442776044), + new Word64(2428436474, 593698344), + new Word64(2756734187, 3733110249), + new Word64(3204031479, 2999351573), + new Word64(3329325298, 3815920427), + new Word64(3391569614, 3928383900), + new Word64(3515267271, 566280711), + new Word64(3940187606, 3454069534), + new Word64(4118630271, 4000239992), + new Word64(116418474, 1914138554), + new Word64(174292421, 2731055270), + new Word64(289380356, 3203993006), + new Word64(460393269, 320620315), + new Word64(685471733, 587496836), + new Word64(852142971, 1086792851), + new Word64(1017036298, 365543100), + new Word64(1126000580, 2618297676), + new Word64(1288033470, 3409855158), + new Word64(1501505948, 4234509866), + new Word64(1607167915, 987167468), + new Word64(1816402316, 1246189591), + ]); + }, +}; +function ch(e, t, a, r, i) { + e.assign(t); + e.and(a); + i.assign(t); + i.not(); + i.and(r); + e.xor(i); +} +function maj(e, t, a, r, i) { + e.assign(t); + e.and(a); + i.assign(t); + i.and(r); + e.xor(i); + i.assign(a); + i.and(r); + e.xor(i); +} +function sigma(e, t, a) { + e.assign(t); + e.rotateRight(28); + a.assign(t); + a.rotateRight(34); + e.xor(a); + a.assign(t); + a.rotateRight(39); + e.xor(a); +} +function sigmaPrime(e, t, a) { + e.assign(t); + e.rotateRight(14); + a.assign(t); + a.rotateRight(18); + e.xor(a); + a.assign(t); + a.rotateRight(41); + e.xor(a); +} +function littleSigma(e, t, a) { + e.assign(t); + e.rotateRight(1); + a.assign(t); + a.rotateRight(8); + e.xor(a); + a.assign(t); + a.shiftRight(7); + e.xor(a); +} +function littleSigmaPrime(e, t, a) { + e.assign(t); + e.rotateRight(19); + a.assign(t); + a.rotateRight(61); + e.xor(a); + a.assign(t); + a.shiftRight(6); + e.xor(a); +} +function calculateSHA512(e, t, a, r = !1) { + let i, n, s, o, c, l, h, u; + if (r) { + i = new Word64(3418070365, 3238371032); + n = new Word64(1654270250, 914150663); + s = new Word64(2438529370, 812702999); + o = new Word64(355462360, 4144912697); + c = new Word64(1731405415, 4290775857); + l = new Word64(2394180231, 1750603025); + h = new Word64(3675008525, 1694076839); + u = new Word64(1203062813, 3204075428); + } else { + i = new Word64(1779033703, 4089235720); + n = new Word64(3144134277, 2227873595); + s = new Word64(1013904242, 4271175723); + o = new Word64(2773480762, 1595750129); + c = new Word64(1359893119, 2917565137); + l = new Word64(2600822924, 725511199); + h = new Word64(528734635, 4215389547); + u = new Word64(1541459225, 327033209); + } + const d = 128 * Math.ceil((a + 17) / 128), + f = new Uint8Array(d); + let g, p; + for (g = 0; g < a; ++g) f[g] = e[t++]; + f[g++] = 128; + const m = d - 16; + g < m && (g = m); + g += 11; + f[g++] = (a >>> 29) & 255; + f[g++] = (a >> 21) & 255; + f[g++] = (a >> 13) & 255; + f[g++] = (a >> 5) & 255; + f[g++] = (a << 3) & 255; + const b = new Array(80); + for (g = 0; g < 80; g++) b[g] = new Word64(0, 0); + const { k: y } = mc; + let w = new Word64(0, 0), + x = new Word64(0, 0), + S = new Word64(0, 0), + k = new Word64(0, 0), + C = new Word64(0, 0), + v = new Word64(0, 0), + F = new Word64(0, 0), + T = new Word64(0, 0); + const O = new Word64(0, 0), + M = new Word64(0, 0), + D = new Word64(0, 0), + R = new Word64(0, 0); + let N, E; + for (g = 0; g < d; ) { + for (p = 0; p < 16; ++p) { + b[p].high = (f[g] << 24) | (f[g + 1] << 16) | (f[g + 2] << 8) | f[g + 3]; + b[p].low = + (f[g + 4] << 24) | (f[g + 5] << 16) | (f[g + 6] << 8) | f[g + 7]; + g += 8; + } + for (p = 16; p < 80; ++p) { + N = b[p]; + littleSigmaPrime(N, b[p - 2], R); + N.add(b[p - 7]); + littleSigma(D, b[p - 15], R); + N.add(D); + N.add(b[p - 16]); + } + w.assign(i); + x.assign(n); + S.assign(s); + k.assign(o); + C.assign(c); + v.assign(l); + F.assign(h); + T.assign(u); + for (p = 0; p < 80; ++p) { + O.assign(T); + sigmaPrime(D, C, R); + O.add(D); + ch(D, C, v, F, R); + O.add(D); + O.add(y[p]); + O.add(b[p]); + sigma(M, w, R); + maj(D, w, x, S, R); + M.add(D); + N = T; + T = F; + F = v; + v = C; + k.add(O); + C = k; + k = S; + S = x; + x = w; + N.assign(O); + N.add(M); + w = N; + } + i.add(w); + n.add(x); + s.add(S); + o.add(k); + c.add(C); + l.add(v); + h.add(F); + u.add(T); + } + if (r) { + E = new Uint8Array(48); + i.copyTo(E, 0); + n.copyTo(E, 8); + s.copyTo(E, 16); + o.copyTo(E, 24); + c.copyTo(E, 32); + l.copyTo(E, 40); + } else { + E = new Uint8Array(64); + i.copyTo(E, 0); + n.copyTo(E, 8); + s.copyTo(E, 16); + o.copyTo(E, 24); + c.copyTo(E, 32); + l.copyTo(E, 40); + h.copyTo(E, 48); + u.copyTo(E, 56); + } + return E; +} +const bc = { + get k() { + return shadow( + this, + "k", + [ + 1116352408, 1899447441, 3049323471, 3921009573, 961987163, 1508970993, + 2453635748, 2870763221, 3624381080, 310598401, 607225278, 1426881987, + 1925078388, 2162078206, 2614888103, 3248222580, 3835390401, 4022224774, + 264347078, 604807628, 770255983, 1249150122, 1555081692, 1996064986, + 2554220882, 2821834349, 2952996808, 3210313671, 3336571891, 3584528711, + 113926993, 338241895, 666307205, 773529912, 1294757372, 1396182291, + 1695183700, 1986661051, 2177026350, 2456956037, 2730485921, 2820302411, + 3259730800, 3345764771, 3516065817, 3600352804, 4094571909, 275423344, + 430227734, 506948616, 659060556, 883997877, 958139571, 1322822218, + 1537002063, 1747873779, 1955562222, 2024104815, 2227730452, 2361852424, + 2428436474, 2756734187, 3204031479, 3329325298, + ], + ); + }, +}; +function rotr(e, t) { + return (e >>> t) | (e << (32 - t)); +} +function calculate_sha256_ch(e, t, a) { + return (e & t) ^ (~e & a); +} +function calculate_sha256_maj(e, t, a) { + return (e & t) ^ (e & a) ^ (t & a); +} +function calculate_sha256_sigma(e) { + return rotr(e, 2) ^ rotr(e, 13) ^ rotr(e, 22); +} +function calculate_sha256_sigmaPrime(e) { + return rotr(e, 6) ^ rotr(e, 11) ^ rotr(e, 25); +} +function calculate_sha256_littleSigma(e) { + return rotr(e, 7) ^ rotr(e, 18) ^ (e >>> 3); +} +function calculateSHA256(e, t, a) { + let r = 1779033703, + i = 3144134277, + n = 1013904242, + s = 2773480762, + o = 1359893119, + c = 2600822924, + l = 528734635, + h = 1541459225; + const u = 64 * Math.ceil((a + 9) / 64), + d = new Uint8Array(u); + let f, g; + for (f = 0; f < a; ++f) d[f] = e[t++]; + d[f++] = 128; + const p = u - 8; + f < p && (f = p); + f += 3; + d[f++] = (a >>> 29) & 255; + d[f++] = (a >> 21) & 255; + d[f++] = (a >> 13) & 255; + d[f++] = (a >> 5) & 255; + d[f++] = (a << 3) & 255; + const m = new Uint32Array(64), + { k: b } = bc; + for (f = 0; f < u; ) { + for (g = 0; g < 16; ++g) { + m[g] = (d[f] << 24) | (d[f + 1] << 16) | (d[f + 2] << 8) | d[f + 3]; + f += 4; + } + for (g = 16; g < 64; ++g) + m[g] = + ((rotr((y = m[g - 2]), 17) ^ rotr(y, 19) ^ (y >>> 10)) + + m[g - 7] + + calculate_sha256_littleSigma(m[g - 15]) + + m[g - 16]) | + 0; + let e, + t, + a = r, + u = i, + p = n, + w = s, + x = o, + S = c, + k = l, + C = h; + for (g = 0; g < 64; ++g) { + e = + C + + calculate_sha256_sigmaPrime(x) + + calculate_sha256_ch(x, S, k) + + b[g] + + m[g]; + t = calculate_sha256_sigma(a) + calculate_sha256_maj(a, u, p); + C = k; + k = S; + S = x; + x = (w + e) | 0; + w = p; + p = u; + u = a; + a = (e + t) | 0; + } + r = (r + a) | 0; + i = (i + u) | 0; + n = (n + p) | 0; + s = (s + w) | 0; + o = (o + x) | 0; + c = (c + S) | 0; + l = (l + k) | 0; + h = (h + C) | 0; + } + var y; + return new Uint8Array([ + (r >> 24) & 255, + (r >> 16) & 255, + (r >> 8) & 255, + 255 & r, + (i >> 24) & 255, + (i >> 16) & 255, + (i >> 8) & 255, + 255 & i, + (n >> 24) & 255, + (n >> 16) & 255, + (n >> 8) & 255, + 255 & n, + (s >> 24) & 255, + (s >> 16) & 255, + (s >> 8) & 255, + 255 & s, + (o >> 24) & 255, + (o >> 16) & 255, + (o >> 8) & 255, + 255 & o, + (c >> 24) & 255, + (c >> 16) & 255, + (c >> 8) & 255, + 255 & c, + (l >> 24) & 255, + (l >> 16) & 255, + (l >> 8) & 255, + 255 & l, + (h >> 24) & 255, + (h >> 16) & 255, + (h >> 8) & 255, + 255 & h, + ]); +} +class DecryptStream extends DecodeStream { + constructor(e, t, a) { + super(t); + this.str = e; + this.dict = e.dict; + this.decrypt = a; + this.nextChunk = null; + this.initialized = !1; + } + readBlock() { + let e; + if (this.initialized) e = this.nextChunk; + else { + e = this.str.getBytes(512); + this.initialized = !0; + } + if (!e?.length) { + this.eof = !0; + return; + } + this.nextChunk = this.str.getBytes(512); + const t = this.nextChunk?.length > 0; + e = (0, this.decrypt)(e, !t); + const a = this.bufferLength, + r = a + e.length; + this.ensureBuffer(r).set(e, a); + this.bufferLength = r; + } +} +class ARCFourCipher { + constructor(e) { + this.a = 0; + this.b = 0; + const t = new Uint8Array(256), + a = e.length; + for (let e = 0; e < 256; ++e) t[e] = e; + for (let r = 0, i = 0; r < 256; ++r) { + const n = t[r]; + i = (i + n + e[r % a]) & 255; + t[r] = t[i]; + t[i] = n; + } + this.s = t; + } + encryptBlock(e) { + let t = this.a, + a = this.b; + const r = this.s, + i = e.length, + n = new Uint8Array(i); + for (let s = 0; s < i; ++s) { + t = (t + 1) & 255; + const i = r[t]; + a = (a + i) & 255; + const o = r[a]; + r[t] = o; + r[a] = i; + n[s] = e[s] ^ r[(i + o) & 255]; + } + this.a = t; + this.b = a; + return n; + } + decryptBlock(e) { + return this.encryptBlock(e); + } + encrypt(e) { + return this.encryptBlock(e); + } +} +class NullCipher { + decryptBlock(e) { + return e; + } + encrypt(e) { + return e; + } +} +class AESBaseCipher { + _s = new Uint8Array([ + 99, 124, 119, 123, 242, 107, 111, 197, 48, 1, 103, 43, 254, 215, 171, 118, + 202, 130, 201, 125, 250, 89, 71, 240, 173, 212, 162, 175, 156, 164, 114, + 192, 183, 253, 147, 38, 54, 63, 247, 204, 52, 165, 229, 241, 113, 216, 49, + 21, 4, 199, 35, 195, 24, 150, 5, 154, 7, 18, 128, 226, 235, 39, 178, 117, 9, + 131, 44, 26, 27, 110, 90, 160, 82, 59, 214, 179, 41, 227, 47, 132, 83, 209, + 0, 237, 32, 252, 177, 91, 106, 203, 190, 57, 74, 76, 88, 207, 208, 239, 170, + 251, 67, 77, 51, 133, 69, 249, 2, 127, 80, 60, 159, 168, 81, 163, 64, 143, + 146, 157, 56, 245, 188, 182, 218, 33, 16, 255, 243, 210, 205, 12, 19, 236, + 95, 151, 68, 23, 196, 167, 126, 61, 100, 93, 25, 115, 96, 129, 79, 220, 34, + 42, 144, 136, 70, 238, 184, 20, 222, 94, 11, 219, 224, 50, 58, 10, 73, 6, + 36, 92, 194, 211, 172, 98, 145, 149, 228, 121, 231, 200, 55, 109, 141, 213, + 78, 169, 108, 86, 244, 234, 101, 122, 174, 8, 186, 120, 37, 46, 28, 166, + 180, 198, 232, 221, 116, 31, 75, 189, 139, 138, 112, 62, 181, 102, 72, 3, + 246, 14, 97, 53, 87, 185, 134, 193, 29, 158, 225, 248, 152, 17, 105, 217, + 142, 148, 155, 30, 135, 233, 206, 85, 40, 223, 140, 161, 137, 13, 191, 230, + 66, 104, 65, 153, 45, 15, 176, 84, 187, 22, + ]); + _inv_s = new Uint8Array([ + 82, 9, 106, 213, 48, 54, 165, 56, 191, 64, 163, 158, 129, 243, 215, 251, + 124, 227, 57, 130, 155, 47, 255, 135, 52, 142, 67, 68, 196, 222, 233, 203, + 84, 123, 148, 50, 166, 194, 35, 61, 238, 76, 149, 11, 66, 250, 195, 78, 8, + 46, 161, 102, 40, 217, 36, 178, 118, 91, 162, 73, 109, 139, 209, 37, 114, + 248, 246, 100, 134, 104, 152, 22, 212, 164, 92, 204, 93, 101, 182, 146, 108, + 112, 72, 80, 253, 237, 185, 218, 94, 21, 70, 87, 167, 141, 157, 132, 144, + 216, 171, 0, 140, 188, 211, 10, 247, 228, 88, 5, 184, 179, 69, 6, 208, 44, + 30, 143, 202, 63, 15, 2, 193, 175, 189, 3, 1, 19, 138, 107, 58, 145, 17, 65, + 79, 103, 220, 234, 151, 242, 207, 206, 240, 180, 230, 115, 150, 172, 116, + 34, 231, 173, 53, 133, 226, 249, 55, 232, 28, 117, 223, 110, 71, 241, 26, + 113, 29, 41, 197, 137, 111, 183, 98, 14, 170, 24, 190, 27, 252, 86, 62, 75, + 198, 210, 121, 32, 154, 219, 192, 254, 120, 205, 90, 244, 31, 221, 168, 51, + 136, 7, 199, 49, 177, 18, 16, 89, 39, 128, 236, 95, 96, 81, 127, 169, 25, + 181, 74, 13, 45, 229, 122, 159, 147, 201, 156, 239, 160, 224, 59, 77, 174, + 42, 245, 176, 200, 235, 187, 60, 131, 83, 153, 97, 23, 43, 4, 126, 186, 119, + 214, 38, 225, 105, 20, 99, 85, 33, 12, 125, + ]); + _mix = new Uint32Array([ + 0, 235474187, 470948374, 303765277, 941896748, 908933415, 607530554, + 708780849, 1883793496, 2118214995, 1817866830, 1649639237, 1215061108, + 1181045119, 1417561698, 1517767529, 3767586992, 4003061179, 4236429990, + 4069246893, 3635733660, 3602770327, 3299278474, 3400528769, 2430122216, + 2664543715, 2362090238, 2193862645, 2835123396, 2801107407, 3035535058, + 3135740889, 3678124923, 3576870512, 3341394285, 3374361702, 3810496343, + 3977675356, 4279080257, 4043610186, 2876494627, 2776292904, 3076639029, + 3110650942, 2472011535, 2640243204, 2403728665, 2169303058, 1001089995, + 899835584, 666464733, 699432150, 59727847, 226906860, 530400753, 294930682, + 1273168787, 1172967064, 1475418501, 1509430414, 1942435775, 2110667444, + 1876241833, 1641816226, 2910219766, 2743034109, 2976151520, 3211623147, + 2505202138, 2606453969, 2302690252, 2269728455, 3711829422, 3543599269, + 3240894392, 3475313331, 3843699074, 3943906441, 4178062228, 4144047775, + 1306967366, 1139781709, 1374988112, 1610459739, 1975683434, 2076935265, + 1775276924, 1742315127, 1034867998, 866637845, 566021896, 800440835, + 92987698, 193195065, 429456164, 395441711, 1984812685, 2017778566, + 1784663195, 1683407248, 1315562145, 1080094634, 1383856311, 1551037884, + 101039829, 135050206, 437757123, 337553864, 1042385657, 807962610, + 573804783, 742039012, 2531067453, 2564033334, 2328828971, 2227573024, + 2935566865, 2700099354, 3001755655, 3168937228, 3868552805, 3902563182, + 4203181171, 4102977912, 3736164937, 3501741890, 3265478751, 3433712980, + 1106041591, 1340463100, 1576976609, 1408749034, 2043211483, 2009195472, + 1708848333, 1809054150, 832877231, 1068351396, 766945465, 599762354, + 159417987, 126454664, 361929877, 463180190, 2709260871, 2943682380, + 3178106961, 3009879386, 2572697195, 2538681184, 2236228733, 2336434550, + 3509871135, 3745345300, 3441850377, 3274667266, 3910161971, 3877198648, + 4110568485, 4211818798, 2597806476, 2497604743, 2261089178, 2295101073, + 2733856160, 2902087851, 3202437046, 2968011453, 3936291284, 3835036895, + 4136440770, 4169408201, 3535486456, 3702665459, 3467192302, 3231722213, + 2051518780, 1951317047, 1716890410, 1750902305, 1113818384, 1282050075, + 1584504582, 1350078989, 168810852, 67556463, 371049330, 404016761, + 841739592, 1008918595, 775550814, 540080725, 3969562369, 3801332234, + 4035489047, 4269907996, 3569255213, 3669462566, 3366754619, 3332740144, + 2631065433, 2463879762, 2160117071, 2395588676, 2767645557, 2868897406, + 3102011747, 3069049960, 202008497, 33778362, 270040487, 504459436, + 875451293, 975658646, 675039627, 641025152, 2084704233, 1917518562, + 1615861247, 1851332852, 1147550661, 1248802510, 1484005843, 1451044056, + 933301370, 967311729, 733156972, 632953703, 260388950, 25965917, 328671808, + 496906059, 1206477858, 1239443753, 1543208500, 1441952575, 2144161806, + 1908694277, 1675577880, 1842759443, 3610369226, 3644379585, 3408119516, + 3307916247, 4011190502, 3776767469, 4077384432, 4245618683, 2809771154, + 2842737049, 3144396420, 3043140495, 2673705150, 2438237621, 2203032232, + 2370213795, + ]); + _mixCol = new Uint8Array(256).map((e, t) => + t < 128 ? t << 1 : (t << 1) ^ 27, + ); + constructor() { + this.buffer = new Uint8Array(16); + this.bufferPosition = 0; + } + _expandKey(e) { + unreachable("Cannot call `_expandKey` on the base class"); + } + _decrypt(e, t) { + let a, r, i; + const n = new Uint8Array(16); + n.set(e); + for (let e = 0, a = this._keySize; e < 16; ++e, ++a) n[e] ^= t[a]; + for (let e = this._cyclesOfRepetition - 1; e >= 1; --e) { + a = n[13]; + n[13] = n[9]; + n[9] = n[5]; + n[5] = n[1]; + n[1] = a; + a = n[14]; + r = n[10]; + n[14] = n[6]; + n[10] = n[2]; + n[6] = a; + n[2] = r; + a = n[15]; + r = n[11]; + i = n[7]; + n[15] = n[3]; + n[11] = a; + n[7] = r; + n[3] = i; + for (let e = 0; e < 16; ++e) n[e] = this._inv_s[n[e]]; + for (let a = 0, r = 16 * e; a < 16; ++a, ++r) n[a] ^= t[r]; + for (let e = 0; e < 16; e += 4) { + const t = this._mix[n[e]], + r = this._mix[n[e + 1]], + i = this._mix[n[e + 2]], + s = this._mix[n[e + 3]]; + a = + t ^ + (r >>> 8) ^ + (r << 24) ^ + (i >>> 16) ^ + (i << 16) ^ + (s >>> 24) ^ + (s << 8); + n[e] = (a >>> 24) & 255; + n[e + 1] = (a >> 16) & 255; + n[e + 2] = (a >> 8) & 255; + n[e + 3] = 255 & a; + } + } + a = n[13]; + n[13] = n[9]; + n[9] = n[5]; + n[5] = n[1]; + n[1] = a; + a = n[14]; + r = n[10]; + n[14] = n[6]; + n[10] = n[2]; + n[6] = a; + n[2] = r; + a = n[15]; + r = n[11]; + i = n[7]; + n[15] = n[3]; + n[11] = a; + n[7] = r; + n[3] = i; + for (let e = 0; e < 16; ++e) { + n[e] = this._inv_s[n[e]]; + n[e] ^= t[e]; + } + return n; + } + _encrypt(e, t) { + const a = this._s; + let r, i, n; + const s = new Uint8Array(16); + s.set(e); + for (let e = 0; e < 16; ++e) s[e] ^= t[e]; + for (let e = 1; e < this._cyclesOfRepetition; e++) { + for (let e = 0; e < 16; ++e) s[e] = a[s[e]]; + n = s[1]; + s[1] = s[5]; + s[5] = s[9]; + s[9] = s[13]; + s[13] = n; + n = s[2]; + i = s[6]; + s[2] = s[10]; + s[6] = s[14]; + s[10] = n; + s[14] = i; + n = s[3]; + i = s[7]; + r = s[11]; + s[3] = s[15]; + s[7] = n; + s[11] = i; + s[15] = r; + for (let e = 0; e < 16; e += 4) { + const t = s[e], + a = s[e + 1], + i = s[e + 2], + n = s[e + 3]; + r = t ^ a ^ i ^ n; + s[e] ^= r ^ this._mixCol[t ^ a]; + s[e + 1] ^= r ^ this._mixCol[a ^ i]; + s[e + 2] ^= r ^ this._mixCol[i ^ n]; + s[e + 3] ^= r ^ this._mixCol[n ^ t]; + } + for (let a = 0, r = 16 * e; a < 16; ++a, ++r) s[a] ^= t[r]; + } + for (let e = 0; e < 16; ++e) s[e] = a[s[e]]; + n = s[1]; + s[1] = s[5]; + s[5] = s[9]; + s[9] = s[13]; + s[13] = n; + n = s[2]; + i = s[6]; + s[2] = s[10]; + s[6] = s[14]; + s[10] = n; + s[14] = i; + n = s[3]; + i = s[7]; + r = s[11]; + s[3] = s[15]; + s[7] = n; + s[11] = i; + s[15] = r; + for (let e = 0, a = this._keySize; e < 16; ++e, ++a) s[e] ^= t[a]; + return s; + } + _decryptBlock2(e, t) { + const a = e.length; + let r = this.buffer, + i = this.bufferPosition; + const n = []; + let s = this.iv; + for (let t = 0; t < a; ++t) { + r[i] = e[t]; + ++i; + if (i < 16) continue; + const a = this._decrypt(r, this._key); + for (let e = 0; e < 16; ++e) a[e] ^= s[e]; + s = r; + n.push(a); + r = new Uint8Array(16); + i = 0; + } + this.buffer = r; + this.bufferLength = i; + this.iv = s; + if (0 === n.length) return new Uint8Array(0); + let o = 16 * n.length; + if (t) { + const e = n.at(-1); + let t = e[15]; + if (t <= 16) { + for (let a = 15, r = 16 - t; a >= r; --a) + if (e[a] !== t) { + t = 0; + break; + } + o -= t; + n[n.length - 1] = e.subarray(0, 16 - t); + } + } + const c = new Uint8Array(o); + for (let e = 0, t = 0, a = n.length; e < a; ++e, t += 16) c.set(n[e], t); + return c; + } + decryptBlock(e, t, a = null) { + const r = e.length, + i = this.buffer; + let n = this.bufferPosition; + if (a) this.iv = a; + else { + for (let t = 0; n < 16 && t < r; ++t, ++n) i[n] = e[t]; + if (n < 16) { + this.bufferLength = n; + return new Uint8Array(0); + } + this.iv = i; + e = e.subarray(16); + } + this.buffer = new Uint8Array(16); + this.bufferLength = 0; + this.decryptBlock = this._decryptBlock2; + return this.decryptBlock(e, t); + } + encrypt(e, t) { + const a = e.length; + let r = this.buffer, + i = this.bufferPosition; + const n = []; + t ||= new Uint8Array(16); + for (let s = 0; s < a; ++s) { + r[i] = e[s]; + ++i; + if (i < 16) continue; + for (let e = 0; e < 16; ++e) r[e] ^= t[e]; + const a = this._encrypt(r, this._key); + t = a; + n.push(a); + r = new Uint8Array(16); + i = 0; + } + this.buffer = r; + this.bufferLength = i; + this.iv = t; + if (0 === n.length) return new Uint8Array(0); + const s = 16 * n.length, + o = new Uint8Array(s); + for (let e = 0, t = 0, a = n.length; e < a; ++e, t += 16) o.set(n[e], t); + return o; + } +} +class AES128Cipher extends AESBaseCipher { + _rcon = new Uint8Array([ + 141, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, 77, 154, 47, 94, + 188, 99, 198, 151, 53, 106, 212, 179, 125, 250, 239, 197, 145, 57, 114, 228, + 211, 189, 97, 194, 159, 37, 74, 148, 51, 102, 204, 131, 29, 58, 116, 232, + 203, 141, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, 77, 154, 47, + 94, 188, 99, 198, 151, 53, 106, 212, 179, 125, 250, 239, 197, 145, 57, 114, + 228, 211, 189, 97, 194, 159, 37, 74, 148, 51, 102, 204, 131, 29, 58, 116, + 232, 203, 141, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, 77, 154, + 47, 94, 188, 99, 198, 151, 53, 106, 212, 179, 125, 250, 239, 197, 145, 57, + 114, 228, 211, 189, 97, 194, 159, 37, 74, 148, 51, 102, 204, 131, 29, 58, + 116, 232, 203, 141, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, 77, + 154, 47, 94, 188, 99, 198, 151, 53, 106, 212, 179, 125, 250, 239, 197, 145, + 57, 114, 228, 211, 189, 97, 194, 159, 37, 74, 148, 51, 102, 204, 131, 29, + 58, 116, 232, 203, 141, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54, 108, 216, 171, + 77, 154, 47, 94, 188, 99, 198, 151, 53, 106, 212, 179, 125, 250, 239, 197, + 145, 57, 114, 228, 211, 189, 97, 194, 159, 37, 74, 148, 51, 102, 204, 131, + 29, 58, 116, 232, 203, 141, + ]); + constructor(e) { + super(); + this._cyclesOfRepetition = 10; + this._keySize = 160; + this._key = this._expandKey(e); + } + _expandKey(e) { + const t = this._s, + a = this._rcon, + r = new Uint8Array(176); + r.set(e); + for (let e = 16, i = 1; e < 176; ++i) { + let n = r[e - 3], + s = r[e - 2], + o = r[e - 1], + c = r[e - 4]; + n = t[n]; + s = t[s]; + o = t[o]; + c = t[c]; + n ^= a[i]; + for (let t = 0; t < 4; ++t) { + r[e] = n ^= r[e - 16]; + e++; + r[e] = s ^= r[e - 16]; + e++; + r[e] = o ^= r[e - 16]; + e++; + r[e] = c ^= r[e - 16]; + e++; + } + } + return r; + } +} +class AES256Cipher extends AESBaseCipher { + constructor(e) { + super(); + this._cyclesOfRepetition = 14; + this._keySize = 224; + this._key = this._expandKey(e); + } + _expandKey(e) { + const t = this._s, + a = new Uint8Array(240); + a.set(e); + let r, + i, + n, + s, + o = 1; + for (let e = 32, c = 1; e < 240; ++c) { + if (e % 32 == 16) { + r = t[r]; + i = t[i]; + n = t[n]; + s = t[s]; + } else if (e % 32 == 0) { + r = a[e - 3]; + i = a[e - 2]; + n = a[e - 1]; + s = a[e - 4]; + r = t[r]; + i = t[i]; + n = t[n]; + s = t[s]; + r ^= o; + (o <<= 1) >= 256 && (o = 255 & (27 ^ o)); + } + for (let t = 0; t < 4; ++t) { + a[e] = r ^= a[e - 32]; + e++; + a[e] = i ^= a[e - 32]; + e++; + a[e] = n ^= a[e - 32]; + e++; + a[e] = s ^= a[e - 32]; + e++; + } + } + return a; + } +} +class PDFBase { + _hash(e, t, a) { + unreachable("Abstract method `_hash` called"); + } + checkOwnerPassword(e, t, a, r) { + const i = new Uint8Array(e.length + 56); + i.set(e, 0); + i.set(t, e.length); + i.set(a, e.length + t.length); + return isArrayEqual(this._hash(e, i, a), r); + } + checkUserPassword(e, t, a) { + const r = new Uint8Array(e.length + 8); + r.set(e, 0); + r.set(t, e.length); + return isArrayEqual(this._hash(e, r, []), a); + } + getOwnerKey(e, t, a, r) { + const i = new Uint8Array(e.length + 56); + i.set(e, 0); + i.set(t, e.length); + i.set(a, e.length + t.length); + const n = this._hash(e, i, a); + return new AES256Cipher(n).decryptBlock(r, !1, new Uint8Array(16)); + } + getUserKey(e, t, a) { + const r = new Uint8Array(e.length + 8); + r.set(e, 0); + r.set(t, e.length); + const i = this._hash(e, r, []); + return new AES256Cipher(i).decryptBlock(a, !1, new Uint8Array(16)); + } +} +class PDF17 extends PDFBase { + _hash(e, t, a) { + return calculateSHA256(t, 0, t.length); + } +} +class PDF20 extends PDFBase { + _hash(e, t, a) { + let r = calculateSHA256(t, 0, t.length).subarray(0, 32), + i = [0], + n = 0; + for (; n < 64 || i.at(-1) > n - 32; ) { + const t = e.length + r.length + a.length, + l = new Uint8Array(t); + let h = 0; + l.set(e, h); + h += e.length; + l.set(r, h); + h += r.length; + l.set(a, h); + const u = new Uint8Array(64 * t); + for (let e = 0, a = 0; e < 64; e++, a += t) u.set(l, a); + i = new AES128Cipher(r.subarray(0, 16)).encrypt(u, r.subarray(16, 32)); + const d = Math.sumPrecise(i.slice(0, 16)) % 3; + 0 === d + ? (r = calculateSHA256(i, 0, i.length)) + : 1 === d + ? (r = + ((s = i), (o = 0), (c = i.length), calculateSHA512(s, o, c, !0))) + : 2 === d && (r = calculateSHA512(i, 0, i.length)); + n++; + } + var s, o, c; + return r.subarray(0, 32); + } +} +class CipherTransform { + constructor(e, t) { + this.StringCipherConstructor = e; + this.StreamCipherConstructor = t; + } + createStream(e, t) { + const a = new this.StreamCipherConstructor(); + return new DecryptStream(e, t, function cipherTransformDecryptStream(e, t) { + return a.decryptBlock(e, t); + }); + } + decryptString(e) { + const t = new this.StringCipherConstructor(); + let a = stringToBytes(e); + a = t.decryptBlock(a, !0); + return bytesToString(a); + } + encryptString(e) { + const t = new this.StringCipherConstructor(); + if (t instanceof AESBaseCipher) { + const a = 16 - (e.length % 16); + e += String.fromCharCode(a).repeat(a); + const r = new Uint8Array(16); + crypto.getRandomValues(r); + let i = stringToBytes(e); + i = t.encrypt(i, r); + const n = new Uint8Array(16 + i.length); + n.set(r); + n.set(i, 16); + return bytesToString(n); + } + let a = stringToBytes(e); + a = t.encrypt(a); + return bytesToString(a); + } +} +class CipherTransformFactory { + static get _defaultPasswordBytes() { + return shadow( + this, + "_defaultPasswordBytes", + new Uint8Array([ + 40, 191, 78, 94, 78, 117, 138, 65, 100, 0, 78, 86, 255, 250, 1, 8, 46, + 46, 0, 182, 208, 104, 62, 128, 47, 12, 169, 254, 100, 83, 105, 122, + ]), + ); + } + #Oe(e, t, a, r, i, n, s, o, c, l, h, u) { + if (t) { + const e = Math.min(127, t.length); + t = t.subarray(0, e); + } else t = []; + const d = 6 === e ? new PDF20() : new PDF17(); + return d.checkUserPassword(t, o, s) + ? d.getUserKey(t, c, h) + : t.length && d.checkOwnerPassword(t, r, n, a) + ? d.getOwnerKey(t, i, n, l) + : null; + } + #Me(e, t, a, r, i, n, s, o) { + const c = 40 + a.length + e.length, + l = new Uint8Array(c); + let h, + u, + d = 0; + if (t) { + u = Math.min(32, t.length); + for (; d < u; ++d) l[d] = t[d]; + } + h = 0; + for (; d < 32; ) l[d++] = CipherTransformFactory._defaultPasswordBytes[h++]; + l.set(a, d); + d += a.length; + l[d++] = 255 & i; + l[d++] = (i >> 8) & 255; + l[d++] = (i >> 16) & 255; + l[d++] = (i >>> 24) & 255; + l.set(e, d); + d += e.length; + if (n >= 4 && !o) { + l.fill(255, d, d + 4); + d += 4; + } + let f = calculateMD5(l, 0, d); + const g = s >> 3; + if (n >= 3) for (h = 0; h < 50; ++h) f = calculateMD5(f, 0, g); + const p = f.subarray(0, g); + let m, b; + if (n >= 3) { + d = 0; + l.set(CipherTransformFactory._defaultPasswordBytes, d); + d += 32; + l.set(e, d); + d += e.length; + m = new ARCFourCipher(p); + b = m.encryptBlock(calculateMD5(l, 0, d)); + u = p.length; + const t = new Uint8Array(u); + for (h = 1; h <= 19; ++h) { + for (let e = 0; e < u; ++e) t[e] = p[e] ^ h; + m = new ARCFourCipher(t); + b = m.encryptBlock(b); + } + } else { + m = new ARCFourCipher(p); + b = m.encryptBlock(CipherTransformFactory._defaultPasswordBytes); + } + return b.every((e, t) => r[t] === e) ? p : null; + } + #De(e, t, a, r) { + const i = new Uint8Array(32); + let n = 0; + const s = Math.min(32, e.length); + for (; n < s; ++n) i[n] = e[n]; + let o = 0; + for (; n < 32; ) i[n++] = CipherTransformFactory._defaultPasswordBytes[o++]; + let c = calculateMD5(i, 0, n); + const l = r >> 3; + if (a >= 3) for (o = 0; o < 50; ++o) c = calculateMD5(c, 0, c.length); + let h, u; + if (a >= 3) { + u = t; + const e = new Uint8Array(l); + for (o = 19; o >= 0; o--) { + for (let t = 0; t < l; ++t) e[t] = c[t] ^ o; + h = new ARCFourCipher(e); + u = h.encryptBlock(u); + } + } else { + h = new ARCFourCipher(c.subarray(0, l)); + u = h.encryptBlock(t); + } + return u; + } + #Be(e, t, a, r = !1) { + const i = a.length, + n = new Uint8Array(i + 9); + n.set(a); + let s = i; + n[s++] = 255 & e; + n[s++] = (e >> 8) & 255; + n[s++] = (e >> 16) & 255; + n[s++] = 255 & t; + n[s++] = (t >> 8) & 255; + if (r) { + n[s++] = 115; + n[s++] = 65; + n[s++] = 108; + n[s++] = 84; + } + return calculateMD5(n, 0, s).subarray(0, Math.min(i + 5, 16)); + } + #Re(e, t, a, r, i) { + if (!(t instanceof Name)) + throw new FormatError("Invalid crypt filter name."); + const n = this, + s = e.get(t.name), + o = s?.get("CFM"); + if (!o || "None" === o.name) + return function () { + return new NullCipher(); + }; + if ("V2" === o.name) + return function () { + return new ARCFourCipher(n.#Be(a, r, i, !1)); + }; + if ("AESV2" === o.name) + return function () { + return new AES128Cipher(n.#Be(a, r, i, !0)); + }; + if ("AESV3" === o.name) + return function () { + return new AES256Cipher(i); + }; + throw new FormatError("Unknown crypto method"); + } + constructor(e, t, a) { + const r = e.get("Filter"); + if (!isName(r, "Standard")) + throw new FormatError("unknown encryption method"); + this.filterName = r.name; + this.dict = e; + const i = e.get("V"); + if (!Number.isInteger(i) || (1 !== i && 2 !== i && 4 !== i && 5 !== i)) + throw new FormatError("unsupported encryption algorithm"); + this.algorithm = i; + let n = e.get("Length"); + if (!n) + if (i <= 3) n = 40; + else { + const t = e.get("CF"), + a = e.get("StmF"); + if (t instanceof Dict && a instanceof Name) { + t.suppressEncryption = !0; + const e = t.get(a.name); + n = e?.get("Length") || 128; + n < 40 && (n <<= 3); + } + } + if (!Number.isInteger(n) || n < 40 || n % 8 != 0) + throw new FormatError("invalid key length"); + const s = stringToBytes(e.get("O")), + o = stringToBytes(e.get("U")), + c = s.subarray(0, 32), + l = o.subarray(0, 32), + h = e.get("P"), + u = e.get("R"), + d = (4 === i || 5 === i) && !1 !== e.get("EncryptMetadata"); + this.encryptMetadata = d; + const f = stringToBytes(t); + let g, p; + if (a) { + if (6 === u) + try { + a = utf8StringToString(a); + } catch { + warn( + "CipherTransformFactory: Unable to convert UTF8 encoded password.", + ); + } + g = stringToBytes(a); + } + if (5 !== i) p = this.#Me(f, g, c, l, h, u, n, d); + else { + const t = s.subarray(32, 40), + a = s.subarray(40, 48), + r = o.subarray(0, 48), + i = o.subarray(32, 40), + n = o.subarray(40, 48), + h = stringToBytes(e.get("OE")), + d = stringToBytes(e.get("UE")), + f = stringToBytes(e.get("Perms")); + p = this.#Oe(u, g, c, t, a, r, l, i, n, h, d, f); + } + if (!p) { + if (!a) throw new PasswordException("No password given", ha); + const e = this.#De(g, c, u, n); + p = this.#Me(f, e, c, l, h, u, n, d); + } + if (!p) throw new PasswordException("Incorrect Password", ua); + if (4 === i && p.length < 16) { + this.encryptionKey = new Uint8Array(16); + this.encryptionKey.set(p); + } else this.encryptionKey = p; + if (i >= 4) { + const t = e.get("CF"); + t instanceof Dict && (t.suppressEncryption = !0); + this.cf = t; + this.stmf = e.get("StmF") || Name.get("Identity"); + this.strf = e.get("StrF") || Name.get("Identity"); + this.eff = e.get("EFF") || this.stmf; + } + } + createCipherTransform(e, t) { + if (4 === this.algorithm || 5 === this.algorithm) + return new CipherTransform( + this.#Re(this.cf, this.strf, e, t, this.encryptionKey), + this.#Re(this.cf, this.stmf, e, t, this.encryptionKey), + ); + const a = this.#Be(e, t, this.encryptionKey, !1), + cipherConstructor = function () { + return new ARCFourCipher(a); + }; + return new CipherTransform(cipherConstructor, cipherConstructor); + } +} +class XRef { + #Ne = null; + constructor(e, t) { + this.stream = e; + this.pdfManager = t; + this.entries = []; + this._xrefStms = new Set(); + this._cacheMap = new Map(); + this._pendingRefs = new RefSet(); + this._newPersistentRefNum = null; + this._newTemporaryRefNum = null; + this._persistentRefsCache = null; + } + getNewPersistentRef(e) { + null === this._newPersistentRefNum && + (this._newPersistentRefNum = this.entries.length || 1); + const t = this._newPersistentRefNum++; + this._cacheMap.set(t, e); + return Ref.get(t, 0); + } + getNewTemporaryRef() { + if (null === this._newTemporaryRefNum) { + this._newTemporaryRefNum = this.entries.length || 1; + if (this._newPersistentRefNum) { + this._persistentRefsCache = new Map(); + for ( + let e = this._newTemporaryRefNum; + e < this._newPersistentRefNum; + e++ + ) { + this._persistentRefsCache.set(e, this._cacheMap.get(e)); + this._cacheMap.delete(e); + } + } + } + return Ref.get(this._newTemporaryRefNum++, 0); + } + resetNewTemporaryRef() { + this._newTemporaryRefNum = null; + if (this._persistentRefsCache) + for (const [e, t] of this._persistentRefsCache) this._cacheMap.set(e, t); + this._persistentRefsCache = null; + } + setStartXRef(e) { + this.startXRefQueue = [e]; + } + parse(e = !1) { + let t, a, r; + if (e) { + warn("Indexing all PDF objects"); + t = this.indexObjects(); + } else t = this.readXRef(); + t.assignXref(this); + this.trailer = t; + try { + a = t.get("Encrypt"); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`XRef.parse - Invalid "Encrypt" reference: "${e}".`); + } + if (a instanceof Dict) { + const e = t.get("ID"), + r = e?.length ? e[0] : ""; + a.suppressEncryption = !0; + this.encrypt = new CipherTransformFactory(a, r, this.pdfManager.password); + } + try { + r = t.get("Root"); + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`XRef.parse - Invalid "Root" reference: "${e}".`); + } + if (r instanceof Dict) + try { + if (r.get("Pages") instanceof Dict) { + this.root = r; + return; + } + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`XRef.parse - Invalid "Pages" reference: "${e}".`); + } + if (!e) throw new XRefParseException(); + throw new InvalidPDFException("Invalid Root reference."); + } + processXRefTable(e) { + "tableState" in this || + (this.tableState = { + entryNum: 0, + streamPos: e.lexer.stream.pos, + parserBuf1: e.buf1, + parserBuf2: e.buf2, + }); + if (!isCmd(this.readXRefTable(e), "trailer")) + throw new FormatError( + "Invalid XRef table: could not find trailer dictionary", + ); + let t = e.getObj(); + t instanceof Dict || !t.dict || (t = t.dict); + if (!(t instanceof Dict)) + throw new FormatError( + "Invalid XRef table: could not parse trailer dictionary", + ); + delete this.tableState; + return t; + } + readXRefTable(e) { + const t = e.lexer.stream, + a = this.tableState; + t.pos = a.streamPos; + e.buf1 = a.parserBuf1; + e.buf2 = a.parserBuf2; + let r; + for (;;) { + if (!("firstEntryNum" in a) || !("entryCount" in a)) { + if (isCmd((r = e.getObj()), "trailer")) break; + a.firstEntryNum = r; + a.entryCount = e.getObj(); + } + let i = a.firstEntryNum; + const n = a.entryCount; + if (!Number.isInteger(i) || !Number.isInteger(n)) + throw new FormatError( + "Invalid XRef table: wrong types in subsection header", + ); + for (let r = a.entryNum; r < n; r++) { + a.streamPos = t.pos; + a.entryNum = r; + a.parserBuf1 = e.buf1; + a.parserBuf2 = e.buf2; + const s = {}; + s.offset = e.getObj(); + s.gen = e.getObj(); + const o = e.getObj(); + if (o instanceof Cmd) + switch (o.cmd) { + case "f": + s.free = !0; + break; + case "n": + s.uncompressed = !0; + } + if ( + !Number.isInteger(s.offset) || + !Number.isInteger(s.gen) || + (!s.free && !s.uncompressed) + ) + throw new FormatError(`Invalid entry in XRef subsection: ${i}, ${n}`); + 0 === r && s.free && 1 === i && (i = 0); + this.entries[r + i] || (this.entries[r + i] = s); + } + a.entryNum = 0; + a.streamPos = t.pos; + a.parserBuf1 = e.buf1; + a.parserBuf2 = e.buf2; + delete a.firstEntryNum; + delete a.entryCount; + } + if (this.entries[0] && !this.entries[0].free) + throw new FormatError("Invalid XRef table: unexpected first object"); + return r; + } + processXRefStream(e) { + if (!("streamState" in this)) { + const { dict: t, pos: a } = e, + r = t.get("W"), + i = t.get("Index") || [0, t.get("Size")]; + this.streamState = { + entryRanges: i, + byteWidths: r, + entryNum: 0, + streamPos: a, + }; + } + this.readXRefStream(e); + delete this.streamState; + return e.dict; + } + readXRefStream(e) { + const t = this.streamState; + e.pos = t.streamPos; + const [a, r, i] = t.byteWidths, + n = t.entryRanges; + for (; n.length > 0; ) { + const [s, o] = n; + if (!Number.isInteger(s) || !Number.isInteger(o)) + throw new FormatError(`Invalid XRef range fields: ${s}, ${o}`); + if (!Number.isInteger(a) || !Number.isInteger(r) || !Number.isInteger(i)) + throw new FormatError(`Invalid XRef entry fields length: ${s}, ${o}`); + for (let n = t.entryNum; n < o; ++n) { + t.entryNum = n; + t.streamPos = e.pos; + let o = 0, + c = 0, + l = 0; + for (let t = 0; t < a; ++t) { + const t = e.getByte(); + if (-1 === t) + throw new FormatError("Invalid XRef byteWidths 'type'."); + o = (o << 8) | t; + } + 0 === a && (o = 1); + for (let t = 0; t < r; ++t) { + const t = e.getByte(); + if (-1 === t) + throw new FormatError("Invalid XRef byteWidths 'offset'."); + c = (c << 8) | t; + } + for (let t = 0; t < i; ++t) { + const t = e.getByte(); + if (-1 === t) + throw new FormatError("Invalid XRef byteWidths 'generation'."); + l = (l << 8) | t; + } + const h = {}; + h.offset = c; + h.gen = l; + switch (o) { + case 0: + h.free = !0; + break; + case 1: + h.uncompressed = !0; + break; + case 2: + break; + default: + throw new FormatError(`Invalid XRef entry type: ${o}`); + } + this.entries[s + n] || (this.entries[s + n] = h); + } + t.entryNum = 0; + t.streamPos = e.pos; + n.splice(0, 2); + } + } + indexObjects() { + function readToken(e, t) { + let a = "", + r = e[t]; + for (; 10 !== r && 13 !== r && 60 !== r && !(++t >= e.length); ) { + a += String.fromCharCode(r); + r = e[t]; + } + return a; + } + function skipUntil(e, t, a) { + const r = a.length, + i = e.length; + let n = 0; + for (; t < i; ) { + let i = 0; + for (; i < r && e[t + i] === a[i]; ) ++i; + if (i >= r) break; + t++; + n++; + } + return n; + } + const e = /\b(endobj|\d+\s+\d+\s+obj|xref|trailer\s*<<)\b/g, + t = /\b(startxref|\d+\s+\d+\s+obj)\b/g, + a = /^(\d+)\s+(\d+)\s+obj\b/, + r = new Uint8Array([116, 114, 97, 105, 108, 101, 114]), + i = new Uint8Array([115, 116, 97, 114, 116, 120, 114, 101, 102]), + n = new Uint8Array([47, 88, 82, 101, 102]); + this.entries.length = 0; + this._cacheMap.clear(); + const s = this.stream; + s.pos = 0; + const o = s.getBytes(), + c = bytesToString(o), + l = o.length; + let h = s.start; + const u = [], + d = []; + for (; h < l; ) { + let f = o[h]; + if (9 === f || 10 === f || 13 === f || 32 === f) { + ++h; + continue; + } + if (37 === f) { + do { + ++h; + if (h >= l) break; + f = o[h]; + } while (10 !== f && 13 !== f); + continue; + } + const g = readToken(o, h); + let p; + if (g.startsWith("xref") && (4 === g.length || /\s/.test(g[4]))) { + h += skipUntil(o, h, r); + u.push(h); + h += skipUntil(o, h, i); + } else if ((p = a.exec(g))) { + const t = 0 | p[1], + a = 0 | p[2], + r = h + g.length; + let i, + u = !1; + if (this.entries[t]) { + if (this.entries[t].gen === a) + try { + new Parser({ lexer: new Lexer(s.makeSubStream(r)) }).getObj(); + u = !0; + } catch (e) { + e instanceof ParserEOFException + ? warn(`indexObjects -- checking object (${g}): "${e}".`) + : (u = !0); + } + } else u = !0; + u && + (this.entries[t] = { offset: h - s.start, gen: a, uncompressed: !0 }); + e.lastIndex = r; + const f = e.exec(c); + if (f) { + i = e.lastIndex + 1 - h; + if ("endobj" !== f[1]) { + warn( + `indexObjects: Found "${f[1]}" inside of another "obj", caused by missing "endobj" -- trying to recover.`, + ); + i -= f[1].length + 1; + } + } else i = l - h; + const m = o.subarray(h, h + i), + b = skipUntil(m, 0, n); + if (b < i && m[b + 5] < 64) { + d.push(h - s.start); + this._xrefStms.add(h - s.start); + } + h += i; + } else if ( + g.startsWith("trailer") && + (7 === g.length || /\s/.test(g[7])) + ) { + u.push(h); + const e = h + g.length; + let a; + t.lastIndex = e; + const r = t.exec(c); + if (r) { + a = t.lastIndex + 1 - h; + if ("startxref" !== r[1]) { + warn( + `indexObjects: Found "${r[1]}" after "trailer", caused by missing "startxref" -- trying to recover.`, + ); + a -= r[1].length + 1; + } + } else a = l - h; + h += a; + } else h += g.length + 1; + } + for (const e of d) { + this.startXRefQueue.push(e); + this.readXRef(!0); + } + const f = []; + let g, + p, + m = !1; + for (const e of u) { + s.pos = e; + const t = new Parser({ + lexer: new Lexer(s), + xref: this, + allowStreams: !0, + recoveryMode: !0, + }); + if (!isCmd(t.getObj(), "trailer")) continue; + const a = t.getObj(); + if (a instanceof Dict) { + f.push(a); + a.has("Encrypt") && (m = !0); + } + } + for (const e of [...f, "genFallback", ...f]) { + if ("genFallback" === e) { + if (!p) break; + this._generationFallback = !0; + continue; + } + let t = !1; + try { + const a = e.get("Root"); + if (!(a instanceof Dict)) continue; + const r = a.get("Pages"); + if (!(r instanceof Dict)) continue; + const i = r.get("Count"); + Number.isInteger(i) && (t = !0); + } catch (e) { + p = e; + continue; + } + if (t && (!m || e.has("Encrypt")) && e.has("ID")) return e; + g = e; + } + if (g) return g; + if (this.topDict) return this.topDict; + if (!f.length) + for (const [e, t] of this.entries.entries()) { + if (!t) continue; + const a = Ref.get(e, t.gen); + let r; + try { + r = this.fetch(a); + } catch { + continue; + } + r instanceof BaseStream && (r = r.dict); + if (r instanceof Dict && r.has("Root")) return r; + } + throw new InvalidPDFException("Invalid PDF structure."); + } + readXRef(e = !1) { + const t = this.stream, + a = new Set(); + for (; this.startXRefQueue.length; ) { + try { + const e = this.startXRefQueue[0]; + if (a.has(e)) { + warn("readXRef - skipping XRef table since it was already parsed."); + this.startXRefQueue.shift(); + continue; + } + a.add(e); + t.pos = e + t.start; + const r = new Parser({ + lexer: new Lexer(t), + xref: this, + allowStreams: !0, + }); + let i, + n = r.getObj(); + if (isCmd(n, "xref")) { + i = this.processXRefTable(r); + this.topDict || (this.topDict = i); + n = i.get("XRefStm"); + if (Number.isInteger(n) && !this._xrefStms.has(n)) { + this._xrefStms.add(n); + this.startXRefQueue.push(n); + this.#Ne ??= n; + } + } else { + if (!Number.isInteger(n)) + throw new FormatError("Invalid XRef stream header"); + if ( + !( + Number.isInteger(r.getObj()) && + isCmd(r.getObj(), "obj") && + (n = r.getObj()) instanceof BaseStream + ) + ) + throw new FormatError("Invalid XRef stream"); + i = this.processXRefStream(n); + this.topDict || (this.topDict = i); + if (!i) throw new FormatError("Failed to read XRef stream"); + } + n = i.get("Prev"); + Number.isInteger(n) + ? this.startXRefQueue.push(n) + : n instanceof Ref && this.startXRefQueue.push(n.num); + } catch (e) { + if (e instanceof MissingDataException) throw e; + info("(while reading XRef): " + e); + } + this.startXRefQueue.shift(); + } + if (this.topDict) return this.topDict; + if (!e) throw new XRefParseException(); + } + get lastXRefStreamPos() { + return ( + this.#Ne ?? (this._xrefStms.size > 0 ? Math.max(...this._xrefStms) : null) + ); + } + getEntry(e) { + const t = this.entries[e]; + return t && !t.free && t.offset ? t : null; + } + fetchIfRef(e, t = !1) { + return e instanceof Ref ? this.fetch(e, t) : e; + } + fetch(e, t = !1) { + if (!(e instanceof Ref)) throw new Error("ref object is not a reference"); + const a = e.num, + r = this._cacheMap.get(a); + if (void 0 !== r) { + r instanceof Dict && !r.objId && (r.objId = e.toString()); + return r; + } + let i = this.getEntry(a); + if (null === i) return i; + if (this._pendingRefs.has(e)) { + this._pendingRefs.remove(e); + warn(`Ignoring circular reference: ${e}.`); + return ya; + } + this._pendingRefs.put(e); + try { + i = i.uncompressed + ? this.fetchUncompressed(e, i, t) + : this.fetchCompressed(e, i, t); + this._pendingRefs.remove(e); + } catch (t) { + this._pendingRefs.remove(e); + throw t; + } + i instanceof Dict + ? (i.objId = e.toString()) + : i instanceof BaseStream && (i.dict.objId = e.toString()); + return i; + } + fetchUncompressed(e, t, a = !1) { + const r = e.gen; + let i = e.num; + if (t.gen !== r) { + const n = `Inconsistent generation in XRef: ${e}`; + if (this._generationFallback && t.gen < r) { + warn(n); + return this.fetchUncompressed(Ref.get(i, t.gen), t, a); + } + throw new XRefEntryException(n); + } + const n = this.stream.makeSubStream(t.offset + this.stream.start), + s = new Parser({ lexer: new Lexer(n), xref: this, allowStreams: !0 }), + o = s.getObj(), + c = s.getObj(), + l = s.getObj(); + if (o !== i || c !== r || !(l instanceof Cmd)) + throw new XRefEntryException(`Bad (uncompressed) XRef entry: ${e}`); + if ("obj" !== l.cmd) { + if (l.cmd.startsWith("obj")) { + i = parseInt(l.cmd.substring(3), 10); + if (!Number.isNaN(i)) return i; + } + throw new XRefEntryException(`Bad (uncompressed) XRef entry: ${e}`); + } + (t = + this.encrypt && !a + ? s.getObj(this.encrypt.createCipherTransform(i, r)) + : s.getObj()) instanceof BaseStream || this._cacheMap.set(i, t); + return t; + } + fetchCompressed(e, t, a = !1) { + const r = t.offset, + i = this.fetch(Ref.get(r, 0)); + if (!(i instanceof BaseStream)) throw new FormatError("bad ObjStm stream"); + const n = i.dict.get("First"), + s = i.dict.get("N"); + if (!Number.isInteger(n) || !Number.isInteger(s)) + throw new FormatError("invalid first and n parameters for ObjStm stream"); + let o = new Parser({ lexer: new Lexer(i), xref: this, allowStreams: !0 }); + const c = new Array(s), + l = new Array(s); + for (let e = 0; e < s; ++e) { + const t = o.getObj(); + if (!Number.isInteger(t)) + throw new FormatError( + `invalid object number in the ObjStm stream: ${t}`, + ); + const a = o.getObj(); + if (!Number.isInteger(a)) + throw new FormatError( + `invalid object offset in the ObjStm stream: ${a}`, + ); + c[e] = t; + l[e] = a; + } + const h = (i.start || 0) + n, + u = new Array(s); + for (let e = 0; e < s; ++e) { + const t = e < s - 1 ? l[e + 1] - l[e] : void 0; + if (t < 0) throw new FormatError("Invalid offset in the ObjStm stream."); + o = new Parser({ + lexer: new Lexer(i.makeSubStream(h + l[e], t, i.dict)), + xref: this, + allowStreams: !0, + }); + const a = o.getObj(); + u[e] = a; + if (a instanceof BaseStream) continue; + const n = c[e], + d = this.entries[n]; + d && d.offset === r && d.gen === e && this._cacheMap.set(n, a); + } + if (void 0 === (t = u[t.gen])) + throw new XRefEntryException(`Bad (compressed) XRef entry: ${e}`); + return t; + } + async fetchIfRefAsync(e, t) { + return e instanceof Ref ? this.fetchAsync(e, t) : e; + } + async fetchAsync(e, t) { + try { + return this.fetch(e, t); + } catch (a) { + if (!(a instanceof MissingDataException)) throw a; + await this.pdfManager.requestRange(a.begin, a.end); + return this.fetchAsync(e, t); + } + } + getCatalogObj() { + return this.root; + } +} +const yc = [0, 0, 612, 792]; +class Page { + #Ee = null; + constructor({ + pdfManager: e, + xref: t, + pageIndex: a, + pageDict: r, + ref: i, + globalIdFactory: n, + fontCache: s, + builtInCMapCache: o, + standardFontDataCache: c, + globalColorSpaceCache: l, + globalImageCache: h, + systemFontCache: u, + nonBlendModesSet: d, + xfaFactory: f, + }) { + this.pdfManager = e; + this.pageIndex = a; + this.pageDict = r; + this.xref = t; + this.ref = i; + this.fontCache = s; + this.builtInCMapCache = o; + this.standardFontDataCache = c; + this.globalColorSpaceCache = l; + this.globalImageCache = h; + this.systemFontCache = u; + this.nonBlendModesSet = d; + this.evaluatorOptions = e.evaluatorOptions; + this.xfaFactory = f; + const g = { obj: 0 }; + this._localIdFactory = class extends n { + static createObjId() { + return `p${a}_${++g.obj}`; + } + static getPageObjId() { + return `p${i.toString()}`; + } + }; + } + #Pe(e) { + return new PartialEvaluator({ + xref: this.xref, + handler: e, + pageIndex: this.pageIndex, + idFactory: this._localIdFactory, + fontCache: this.fontCache, + builtInCMapCache: this.builtInCMapCache, + standardFontDataCache: this.standardFontDataCache, + globalColorSpaceCache: this.globalColorSpaceCache, + globalImageCache: this.globalImageCache, + systemFontCache: this.systemFontCache, + options: this.evaluatorOptions, + }); + } + #Le(e, t = !1) { + const a = getInheritableProperty({ + dict: this.pageDict, + key: e, + getArray: t, + stopWhenFound: !1, + }); + return Array.isArray(a) + ? 1 !== a.length && a[0] instanceof Dict + ? Dict.merge({ xref: this.xref, dictArray: a }) + : a[0] + : a; + } + get content() { + return this.pageDict.getArray("Contents"); + } + get resources() { + const e = this.#Le("Resources"); + return shadow(this, "resources", e instanceof Dict ? e : Dict.empty); + } + #je(e) { + if (this.xfaData) return this.xfaData.bbox; + const t = lookupNormalRect(this.#Le(e, !0), null); + if (t) { + if (t[2] - t[0] > 0 && t[3] - t[1] > 0) return t; + warn(`Empty, or invalid, /${e} entry.`); + } + return null; + } + get mediaBox() { + return shadow(this, "mediaBox", this.#je("MediaBox") || yc); + } + get cropBox() { + return shadow(this, "cropBox", this.#je("CropBox") || this.mediaBox); + } + get userUnit() { + const e = this.pageDict.get("UserUnit"); + return shadow(this, "userUnit", "number" == typeof e && e > 0 ? e : 1); + } + get view() { + const { cropBox: e, mediaBox: t } = this; + if (e !== t && !isArrayEqual(e, t)) { + const a = Util.intersect(e, t); + if (a && a[2] - a[0] > 0 && a[3] - a[1] > 0) + return shadow(this, "view", a); + warn("Empty /CropBox and /MediaBox intersection."); + } + return shadow(this, "view", t); + } + get rotate() { + let e = this.#Le("Rotate") || 0; + e % 90 != 0 + ? (e = 0) + : e >= 360 + ? (e %= 360) + : e < 0 && (e = ((e % 360) + 360) % 360); + return shadow(this, "rotate", e); + } + #_e(e, t) { + if (!this.evaluatorOptions.ignoreErrors) throw e; + warn(`getContentStream - ignoring sub-stream (${t}): "${e}".`); + } + async getContentStream() { + const e = await this.pdfManager.ensure(this, "content"); + return e instanceof BaseStream + ? e + : Array.isArray(e) + ? new StreamsSequenceStream(e, this.#_e.bind(this)) + : new NullStream(); + } + get xfaData() { + return shadow( + this, + "xfaData", + this.xfaFactory + ? { bbox: this.xfaFactory.getBoundingBox(this.pageIndex) } + : null, + ); + } + async #Ue(e, t, a) { + const r = []; + for (const i of e) + if (i.id) { + const e = Ref.fromString(i.id); + if (!e) { + warn(`A non-linked annotation cannot be modified: ${i.id}`); + continue; + } + if (i.deleted) { + t.put(e, e); + if (i.popupRef) { + const e = Ref.fromString(i.popupRef); + e && t.put(e, e); + } + continue; + } + a?.put(e); + i.ref = e; + r.push( + this.xref.fetchAsync(e).then( + (e) => { + e instanceof Dict && (i.oldAnnotation = e.clone()); + }, + () => { + warn(`Cannot fetch \`oldAnnotation\` for: ${e}.`); + }, + ), + ); + delete i.id; + } + await Promise.all(r); + } + async saveNewAnnotations(e, t, a, r, i) { + if (this.xfaFactory) throw new Error("XFA: Cannot save new annotations."); + const n = this.#Pe(e), + s = new RefSetCache(), + o = new RefSet(); + await this.#Ue(a, s, o); + const c = this.pageDict, + l = this.annotations.filter((e) => !(e instanceof Ref && s.has(e))), + h = await AnnotationFactory.saveNewAnnotations(n, t, a, r, i); + for (const { ref: e } of h.annotations) + e instanceof Ref && !o.has(e) && l.push(e); + const u = c.clone(); + u.set("Annots", l); + i.put(this.ref, { data: u }); + for (const e of s) i.put(e, { data: null }); + } + async save(e, t, a, r) { + const i = this.#Pe(e), + n = await this._parsedAnnotations, + s = []; + for (const e of n) + s.push( + e.save(i, t, a, r).catch(function (e) { + warn( + `save - ignoring annotation data during "${t.name}" task: "${e}".`, + ); + return null; + }), + ); + return Promise.all(s); + } + async loadResources(e) { + await (this.#Ee ??= this.pdfManager.ensure(this, "resources")); + await ObjectLoader.load(this.resources, e, this.xref); + } + async #Xe(e, t) { + const a = e?.get("Resources"); + if (!(a instanceof Dict && a.size)) return this.resources; + await ObjectLoader.load(a, t, this.xref); + return Dict.merge({ + xref: this.xref, + dictArray: [a, this.resources], + mergeSubDicts: !0, + }); + } + async getOperatorList({ + handler: e, + sink: t, + task: a, + intent: r, + cacheKey: i, + annotationStorage: c = null, + modifiedIds: d = null, + }) { + const g = this.getContentStream(), + p = this.loadResources(Ia), + m = this.#Pe(e), + b = this.xfaFactory ? null : getNewAnnotationsMap(c), + y = b?.get(this.pageIndex); + let w = Promise.resolve(null), + x = null; + if (y) { + const e = this.pdfManager.ensureDoc("annotationGlobals"); + let t; + const r = new Set(); + for (const { bitmapId: e, bitmap: t } of y) + !e || t || r.has(e) || r.add(e); + const { isOffscreenCanvasSupported: i } = this.evaluatorOptions; + if (r.size > 0) { + const e = y.slice(); + for (const [t, a] of c) + t.startsWith(f) && a.bitmap && r.has(a.bitmapId) && e.push(a); + t = AnnotationFactory.generateImages(e, this.xref, i); + } else t = AnnotationFactory.generateImages(y, this.xref, i); + x = new RefSet(); + w = Promise.all([e, this.#Ue(y, x, null)]).then(([e]) => + e ? AnnotationFactory.printNewAnnotations(e, m, a, y, t) : null, + ); + } + const S = Promise.all([g, p]).then(async ([n]) => { + const s = await this.#Xe(n.dict, Ia), + o = new OperatorList(r, t); + e.send("StartRenderPage", { + transparency: m.hasBlendModes(s, this.nonBlendModesSet), + pageIndex: this.pageIndex, + cacheKey: i, + }); + await m.getOperatorList({ + stream: n, + task: a, + resources: s, + operatorList: o, + }); + return o; + }); + let [k, C, v] = await Promise.all([S, this._parsedAnnotations, w]); + if (v) { + C = C.filter((e) => !(e.ref && x.has(e.ref))); + for (let e = 0, t = v.length; e < t; e++) { + const a = v[e]; + if (a.refToReplace) { + const r = C.findIndex( + (e) => e.ref && isRefsEqual(e.ref, a.refToReplace), + ); + if (r >= 0) { + C.splice(r, 1, a); + v.splice(e--, 1); + t--; + } + } + } + C = C.concat(v); + } + if (0 === C.length || r & h) { + k.flush(!0); + return { length: k.totalLength }; + } + const F = !!(r & l), + T = !!(r & u), + O = !!(r & n), + M = !!(r & s), + D = !!(r & o), + R = []; + for (const e of C) + (O || + (M && e.mustBeViewed(c, F) && e.mustBeViewedWhenEditing(T, d)) || + (D && e.mustBePrinted(c))) && + R.push( + e.getOperatorList(m, a, r, c).catch(function (e) { + warn( + `getOperatorList - ignoring annotation data during "${a.name}" task: "${e}".`, + ); + return { opList: null, separateForm: !1, separateCanvas: !1 }; + }), + ); + const N = await Promise.all(R); + let E = !1, + L = !1; + for (const { opList: e, separateForm: t, separateCanvas: a } of N) { + k.addOpList(e); + E ||= t; + L ||= a; + } + k.flush(!0, { form: E, canvas: L }); + return { length: k.totalLength }; + } + async extractTextContent({ + handler: e, + task: t, + includeMarkedContent: a, + disableNormalization: r, + sink: i, + intersector: n = null, + }) { + const s = this.getContentStream(), + o = this.loadResources(Ta), + c = this.pdfManager.ensureCatalog("lang"), + [l, , h] = await Promise.all([s, o, c]), + u = await this.#Xe(l.dict, Ta); + return this.#Pe(e).getTextContent({ + stream: l, + task: t, + resources: u, + includeMarkedContent: a, + disableNormalization: r, + sink: i, + viewBox: this.view, + lang: h, + intersector: n, + }); + } + async getStructTree() { + const e = await this.pdfManager.ensureCatalog("structTreeRoot"); + if (!e) return null; + await this._parsedAnnotations; + try { + const t = await this.pdfManager.ensure(this, "_parseStructTree", [e]); + return await this.pdfManager.ensure(t, "serializable"); + } catch (e) { + warn(`getStructTree: "${e}".`); + return null; + } + } + _parseStructTree(e) { + const t = new StructTreePage(e, this.pageDict); + t.parse(this.ref); + return t; + } + async getAnnotationsData(e, t, a) { + const r = await this._parsedAnnotations; + if (0 === r.length) return r; + const i = [], + c = []; + let l; + const h = !!(a & n), + u = !!(a & s), + d = !!(a & o), + f = []; + for (const a of r) { + const r = h || (u && a.viewable); + (r || (d && a.printable)) && i.push(a.data); + if (a.hasTextContent && r) { + l ??= this.#Pe(e); + c.push( + a + .extractTextContent(l, t, [-1 / 0, -1 / 0, 1 / 0, 1 / 0]) + .catch(function (e) { + warn( + `getAnnotationsData - ignoring textContent during "${t.name}" task: "${e}".`, + ); + }), + ); + } else a.overlaysTextContent && r && f.push(a); + } + if (f.length > 0) { + const a = new Intersector(f); + c.push( + this.extractTextContent({ + handler: e, + task: t, + includeMarkedContent: !1, + disableNormalization: !1, + sink: null, + viewBox: this.view, + lang: null, + intersector: a, + }).then(() => { + a.setText(); + }), + ); + } + await Promise.all(c); + return i; + } + get annotations() { + const e = this.#Le("Annots"); + return shadow(this, "annotations", Array.isArray(e) ? e : []); + } + get _parsedAnnotations() { + return shadow( + this, + "_parsedAnnotations", + this.pdfManager.ensure(this, "annotations").then(async (e) => { + if (0 === e.length) return e; + const [t, a] = await Promise.all([ + this.pdfManager.ensureDoc("annotationGlobals"), + this.pdfManager.ensureDoc("fieldObjects"), + ]); + if (!t) return []; + const r = a?.orphanFields, + i = []; + for (const a of e) + i.push( + AnnotationFactory.create( + this.xref, + a, + t, + this._localIdFactory, + !1, + r, + this.ref, + ).catch(function (e) { + warn(`_parsedAnnotations: "${e}".`); + return null; + }), + ); + const n = []; + let s, o; + for (const e of await Promise.all(i)) + e && + (e instanceof WidgetAnnotation + ? (o ||= []).push(e) + : e instanceof PopupAnnotation + ? (s ||= []).push(e) + : n.push(e)); + o && n.push(...o); + s && n.push(...s); + return n; + }), + ); + } + get jsActions() { + return shadow( + this, + "jsActions", + collectActions(this.xref, this.pageDict, xe), + ); + } +} +const wc = new Uint8Array([37, 80, 68, 70, 45]), + xc = new Uint8Array([115, 116, 97, 114, 116, 120, 114, 101, 102]), + Sc = new Uint8Array([101, 110, 100, 111, 98, 106]); +function find(e, t, a = 1024, r = !1) { + const i = t.length, + n = e.peekBytes(a), + s = n.length - i; + if (s <= 0) return !1; + if (r) { + const a = i - 1; + let r = n.length - 1; + for (; r >= a; ) { + let s = 0; + for (; s < i && n[r - s] === t[a - s]; ) s++; + if (s >= i) { + e.pos += r - a; + return !0; + } + r--; + } + } else { + let a = 0; + for (; a <= s; ) { + let r = 0; + for (; r < i && n[a + r] === t[r]; ) r++; + if (r >= i) { + e.pos += a; + return !0; + } + a++; + } + } + return !1; +} +class PDFDocument { + #qe = new Map(); + #He = null; + constructor(e, t) { + if (t.length <= 0) + throw new InvalidPDFException( + "The PDF file is empty, i.e. its size is zero bytes.", + ); + this.pdfManager = e; + this.stream = t; + this.xref = new XRef(t, e); + const a = { font: 0 }; + this._globalIdFactory = class { + static getDocId() { + return `g_${e.docId}`; + } + static createFontId() { + return "f" + ++a.font; + } + static createObjId() { + unreachable("Abstract method `createObjId` called."); + } + static getPageObjId() { + unreachable("Abstract method `getPageObjId` called."); + } + }; + } + parse(e) { + this.xref.parse(e); + this.catalog = new Catalog(this.pdfManager, this.xref); + } + get linearization() { + let e = null; + try { + e = Linearization.create(this.stream); + } catch (e) { + if (e instanceof MissingDataException) throw e; + info(e); + } + return shadow(this, "linearization", e); + } + get startXRef() { + const e = this.stream; + let t = 0; + if (this.linearization) { + e.reset(); + if (find(e, Sc)) { + e.skip(6); + let a = e.peekByte(); + for (; isWhiteSpace(a); ) { + e.pos++; + a = e.peekByte(); + } + t = e.pos - e.start; + } + } else { + const a = 1024, + r = xc.length; + let i = !1, + n = e.end; + for (; !i && n > 0; ) { + n -= a - r; + n < 0 && (n = 0); + e.pos = n; + i = find(e, xc, a, !0); + } + if (i) { + e.skip(9); + let a; + do { + a = e.getByte(); + } while (isWhiteSpace(a)); + let r = ""; + for (; a >= 32 && a <= 57; ) { + r += String.fromCharCode(a); + a = e.getByte(); + } + t = parseInt(r, 10); + isNaN(t) && (t = 0); + } + } + return shadow(this, "startXRef", t); + } + checkHeader() { + const e = this.stream; + e.reset(); + if (!find(e, wc)) return; + e.moveStart(); + e.skip(wc.length); + let t, + a = ""; + for (; (t = e.getByte()) > 32 && a.length < 7; ) + a += String.fromCharCode(t); + Ca.test(a) ? (this.#He = a) : warn(`Invalid PDF header version: ${a}`); + } + parseStartXRef() { + this.xref.setStartXRef(this.startXRef); + } + get numPages() { + let e = 0; + e = this.catalog.hasActualNumPages + ? this.catalog.numPages + : this.xfaFactory + ? this.xfaFactory.getNumPages() + : this.linearization + ? this.linearization.numPages + : this.catalog.numPages; + return shadow(this, "numPages", e); + } + #We(e, t = 0) { + return ( + !!Array.isArray(e) && + e.every((e) => { + if (!((e = this.xref.fetchIfRef(e)) instanceof Dict)) return !1; + if (e.has("Kids")) { + if (++t > 10) { + warn("#hasOnlyDocumentSignatures: maximum recursion depth reached"); + return !1; + } + return this.#We(e.get("Kids"), t); + } + const a = isName(e.get("FT"), "Sig"), + r = e.get("Rect"), + i = Array.isArray(r) && r.every((e) => 0 === e); + return a && i; + }) + ); + } + #ze(e, t, a = new RefSet()) { + if (Array.isArray(e)) + for (let r of e) { + if (r instanceof Ref) { + if (a.has(r)) continue; + a.put(r); + } + r = this.xref.fetchIfRef(r); + if (!(r instanceof Dict)) continue; + if (r.has("Kids")) { + this.#ze(r.get("Kids"), t, a); + continue; + } + if (!isName(r.get("FT"), "Sig")) continue; + const e = r.get("V"); + if (!(e instanceof Dict)) continue; + const i = e.get("SubFilter"); + i instanceof Name && t.add(i.name); + } + } + get _xfaStreams() { + const { acroForm: e } = this.catalog; + if (!e) return null; + const t = e.get("XFA"), + a = new Map( + [ + "xdp:xdp", + "template", + "datasets", + "config", + "connectionSet", + "localeSet", + "stylesheet", + "/xdp:xdp", + ].map((e) => [e, null]), + ); + if (t instanceof BaseStream && !t.isEmpty) { + a.set("xdp:xdp", t); + return a; + } + if (!Array.isArray(t) || 0 === t.length) return null; + for (let e = 0, r = t.length; e < r; e += 2) { + let i; + i = 0 === e ? "xdp:xdp" : e === r - 2 ? "/xdp:xdp" : t[e]; + if (!a.has(i)) continue; + const n = this.xref.fetchIfRef(t[e + 1]); + n instanceof BaseStream && !n.isEmpty && a.set(i, n); + } + return a; + } + get xfaDatasets() { + const e = this._xfaStreams; + if (!e) return shadow(this, "xfaDatasets", null); + for (const t of ["datasets", "xdp:xdp"]) { + const a = e.get(t); + if (a) + try { + const e = stringToUTF8String(a.getString()); + return shadow(this, "xfaDatasets", new DatasetReader({ [t]: e })); + } catch { + warn("XFA - Invalid utf-8 string."); + break; + } + } + return shadow(this, "xfaDatasets", null); + } + get xfaData() { + const e = this._xfaStreams; + if (!e) return null; + const t = Object.create(null); + for (const [a, r] of e) + if (r) + try { + t[a] = stringToUTF8String(r.getString()); + } catch { + warn("XFA - Invalid utf-8 string."); + return null; + } + return t; + } + get xfaFactory() { + let e; + this.pdfManager.enableXfa && + this.catalog.needsRendering && + this.formInfo.hasXfa && + !this.formInfo.hasAcroForm && + (e = this.xfaData); + return shadow(this, "xfaFactory", e ? new XFAFactory(e) : null); + } + get isPureXfa() { + return !!this.xfaFactory && this.xfaFactory.isValid(); + } + get htmlForXfa() { + return this.xfaFactory ? this.xfaFactory.getPages() : null; + } + async #$e() { + const e = await this.pdfManager.ensureCatalog("xfaImages"); + e && this.xfaFactory.setImages(e); + } + async #Ge(e, t) { + const a = await this.pdfManager.ensureCatalog("acroForm"); + if (!a) return; + const r = await a.getAsync("DR"); + if (!(r instanceof Dict)) return; + await ObjectLoader.load(r, ["Font"], this.xref); + const i = r.get("Font"); + if (!(i instanceof Dict)) return; + const n = Object.assign( + Object.create(null), + this.pdfManager.evaluatorOptions, + { useSystemFonts: !1 }, + ), + { + builtInCMapCache: s, + fontCache: o, + standardFontDataCache: c, + } = this.catalog, + l = new PartialEvaluator({ + xref: this.xref, + handler: e, + pageIndex: -1, + idFactory: this._globalIdFactory, + fontCache: o, + builtInCMapCache: s, + standardFontDataCache: c, + options: n, + }), + h = new OperatorList(), + u = [], + d = { + get font() { + return u.at(-1); + }, + set font(e) { + u.push(e); + }, + clone() { + return this; + }, + }, + parseFont = (e, a, i) => + l.handleSetFont(r, [Name.get(e), 1], null, h, t, d, a, i).catch((e) => { + warn(`loadXfaFonts: "${e}".`); + return null; + }), + f = []; + for (const [e, t] of i) { + const a = t.get("FontDescriptor"); + if (!(a instanceof Dict)) continue; + let r = a.get("FontFamily"); + r = r.replaceAll(/[ ]+(\d)/g, "$1"); + const i = { + fontFamily: r, + fontWeight: a.get("FontWeight"), + italicAngle: -a.get("ItalicAngle"), + }; + validateCSSFont(i) && f.push(parseFont(e, null, i)); + } + await Promise.all(f); + const g = this.xfaFactory.setFonts(u); + if (!g) return; + n.ignoreErrors = !0; + f.length = 0; + u.length = 0; + const p = new Set(); + for (const e of g) getXfaFontName(`${e}-Regular`) || p.add(e); + p.size && g.push("PdfJS-Fallback"); + for (const e of g) + if (!p.has(e)) + for (const t of [ + { name: "Regular", fontWeight: 400, italicAngle: 0 }, + { name: "Bold", fontWeight: 700, italicAngle: 0 }, + { name: "Italic", fontWeight: 400, italicAngle: 12 }, + { name: "BoldItalic", fontWeight: 700, italicAngle: 12 }, + ]) { + const a = `${e}-${t.name}`; + f.push( + parseFont(a, getXfaFontDict(a), { + fontFamily: e, + fontWeight: t.fontWeight, + italicAngle: t.italicAngle, + }), + ); + } + await Promise.all(f); + this.xfaFactory.appendFonts(u, p); + } + loadXfaResources(e, t) { + return Promise.all([this.#Ge(e, t).catch(() => {}), this.#$e()]); + } + serializeXfaData(e) { + return this.xfaFactory ? this.xfaFactory.serializeData(e) : null; + } + get version() { + return this.catalog.version || this.#He; + } + get formInfo() { + const e = { hasFields: !1, hasAcroForm: !1, hasXfa: !1, hasSignatures: !1 }, + { acroForm: t } = this.catalog; + if (!t) return shadow(this, "formInfo", e); + try { + const a = t.get("Fields"), + r = Array.isArray(a) && a.length > 0; + e.hasFields = r; + const i = t.get("XFA"); + e.hasXfa = + (Array.isArray(i) && i.length > 0) || + (i instanceof BaseStream && !i.isEmpty); + const n = !!(1 & t.get("SigFlags")), + s = n && this.#We(a); + e.hasAcroForm = r && !s; + e.hasSignatures = n; + } catch (e) { + if (e instanceof MissingDataException) throw e; + warn(`Cannot fetch form information: "${e}".`); + } + return shadow(this, "formInfo", e); + } + get documentInfo() { + const { catalog: e, formInfo: t, xref: a } = this, + r = { + PDFFormatVersion: this.version, + Language: e.lang, + EncryptFilterName: a.encrypt?.filterName ?? null, + IsLinearized: !!this.linearization, + IsAcroFormPresent: t.hasAcroForm, + IsXFAPresent: t.hasXfa, + IsCollectionPresent: !!e.collection, + IsSignaturesPresent: t.hasSignatures, + }; + let i; + try { + i = a.trailer.get("Info"); + } catch (e) { + if (e instanceof MissingDataException) throw e; + info("The document information dictionary is invalid."); + } + if (!(i instanceof Dict)) return shadow(this, "documentInfo", r); + for (const [e, t] of i) { + switch (e) { + case "Title": + case "Author": + case "Subject": + case "Keywords": + case "Creator": + case "Producer": + case "CreationDate": + case "ModDate": + if ("string" == typeof t) { + r[e] = stringToPDFString(t); + continue; + } + break; + case "Trapped": + if (t instanceof Name) { + r[e] = t; + continue; + } + break; + default: + let a; + switch (typeof t) { + case "string": + a = stringToPDFString(t); + break; + case "number": + case "boolean": + a = t; + break; + default: + t instanceof Name && (a = t); + } + if (void 0 === a) { + warn(`Bad value, for custom key "${e}", in Info: ${t}.`); + continue; + } + r.Custom ??= Object.create(null); + r.Custom[e] = a; + continue; + } + warn(`Bad value, for key "${e}", in Info: ${t}.`); + } + return shadow(this, "documentInfo", r); + } + get fingerprints() { + const e = "\0".repeat(16); + function validate(t) { + return "string" == typeof t && 16 === t.length && t !== e; + } + const t = this.xref.trailer.get("ID"); + let a, r; + if (Array.isArray(t) && validate(t[0])) { + a = stringToBytes(t[0]); + t[1] !== t[0] && validate(t[1]) && (r = stringToBytes(t[1])); + } else a = calculateMD5(this.stream.getByteRange(0, 1024), 0, 1024); + return shadow(this, "fingerprints", [ + toHexUtil(a), + r ? toHexUtil(r) : null, + ]); + } + async #Ve(e) { + const { catalog: t, linearization: a, xref: r } = this, + i = Ref.get(a.objectNumberFirst, 0); + try { + const e = await r.fetchAsync(i); + if (e instanceof Dict) { + let a = e.getRaw("Type"); + a instanceof Ref && (a = await r.fetchAsync(a)); + if ( + isName(a, "Page") || + (!e.has("Type") && !e.has("Kids") && e.has("Contents")) + ) { + t.pageKidsCountCache.has(i) || t.pageKidsCountCache.put(i, 1); + t.pageIndexCache.has(i) || t.pageIndexCache.put(i, 0); + return [e, i]; + } + } + throw new FormatError( + "The Linearization dictionary doesn't point to a valid Page dictionary.", + ); + } catch (a) { + warn(`_getLinearizationPage: "${a.message}".`); + return t.getPageDict(e); + } + } + getPage(e) { + const t = this.#qe.get(e); + if (t) return t; + const { catalog: a, linearization: r, xfaFactory: i } = this; + let n; + n = i + ? Promise.resolve([Dict.empty, null]) + : r?.pageFirst === e + ? this.#Ve(e) + : a.getPageDict(e); + n = n.then( + ([t, r]) => + new Page({ + pdfManager: this.pdfManager, + xref: this.xref, + pageIndex: e, + pageDict: t, + ref: r, + globalIdFactory: this._globalIdFactory, + fontCache: a.fontCache, + builtInCMapCache: a.builtInCMapCache, + standardFontDataCache: a.standardFontDataCache, + globalColorSpaceCache: a.globalColorSpaceCache, + globalImageCache: a.globalImageCache, + systemFontCache: a.systemFontCache, + nonBlendModesSet: a.nonBlendModesSet, + xfaFactory: i, + }), + ); + this.#qe.set(e, n); + return n; + } + async checkFirstPage(e = !1) { + if (!e) + try { + await this.getPage(0); + } catch (e) { + if (e instanceof XRefEntryException) { + this.#qe.delete(0); + await this.cleanup(); + throw new XRefParseException(); + } + } + } + async checkLastPage(e = !1) { + const { catalog: t, pdfManager: a } = this; + t.setActualNumPages(); + let r; + try { + await Promise.all([ + a.ensureDoc("xfaFactory"), + a.ensureDoc("linearization"), + a.ensureCatalog("numPages"), + ]); + if (this.xfaFactory) return; + r = this.linearization ? this.linearization.numPages : t.numPages; + if (!Number.isInteger(r)) + throw new FormatError("Page count is not an integer."); + if (r <= 1) return; + await this.getPage(r - 1); + } catch (i) { + this.#qe.delete(r - 1); + await this.cleanup(); + if (i instanceof XRefEntryException && !e) throw new XRefParseException(); + warn(`checkLastPage - invalid /Pages tree /Count: ${r}.`); + let n; + try { + n = await t.getAllPageDicts(e); + } catch (a) { + if (a instanceof XRefEntryException && !e) + throw new XRefParseException(); + t.setActualNumPages(1); + return; + } + for (const [e, [r, i]] of n) { + let n; + if (r instanceof Error) { + n = Promise.reject(r); + n.catch(() => {}); + } else + n = Promise.resolve( + new Page({ + pdfManager: a, + xref: this.xref, + pageIndex: e, + pageDict: r, + ref: i, + globalIdFactory: this._globalIdFactory, + fontCache: t.fontCache, + builtInCMapCache: t.builtInCMapCache, + standardFontDataCache: t.standardFontDataCache, + globalColorSpaceCache: this.globalColorSpaceCache, + globalImageCache: t.globalImageCache, + systemFontCache: t.systemFontCache, + nonBlendModesSet: t.nonBlendModesSet, + xfaFactory: null, + }), + ); + this.#qe.set(e, n); + } + t.setActualNumPages(n.size); + } + } + async fontFallback(e, t) { + const { catalog: a, pdfManager: r } = this; + for (const i of await Promise.all(a.fontCache)) + if (i.loadedName === e) { + i.fallback(t, r.evaluatorOptions); + return; + } + } + async cleanup(e = !1) { + return this.catalog ? this.catalog.cleanup(e) : clearGlobalCaches(); + } + async #Ke(e, t, a, r, i, n, s) { + const { xref: o } = this; + if (!(a instanceof Ref) || n.has(a)) return; + n.put(a); + const c = await o.fetchAsync(a); + if (!(c instanceof Dict)) return; + let l = await c.getAsync("Subtype"); + l = l instanceof Name ? l.name : null; + if ("Link" === l) return; + if (c.has("T")) { + const t = stringToPDFString(await c.getAsync("T")); + e = "" === e ? t : `${e}.${t}`; + } else { + let a = c; + for (;;) { + a = a.getRaw("Parent") || t; + if (a instanceof Ref) { + if (n.has(a)) break; + a = await o.fetchAsync(a); + } + if (!(a instanceof Dict)) break; + if (a.has("T")) { + const t = stringToPDFString(await a.getAsync("T")); + e = "" === e ? t : `${e}.${t}`; + break; + } + } + } + t && !c.has("Parent") && isName(c.get("Subtype"), "Widget") && s.put(a, t); + r.has(e) || r.set(e, []); + r.get(e).push( + AnnotationFactory.create(o, a, i, null, !0, s, null) + .then((e) => e?.getFieldObject()) + .catch(function (e) { + warn(`#collectFieldObjects: "${e}".`); + return null; + }), + ); + if (!c.has("Kids")) return; + const h = await c.getAsync("Kids"); + if (Array.isArray(h)) + for (const t of h) await this.#Ke(e, a, t, r, i, n, s); + } + get fieldObjects() { + return shadow( + this, + "fieldObjects", + this.pdfManager.ensureDoc("formInfo").then(async (e) => { + if (!e.hasFields) return null; + const t = await this.annotationGlobals; + if (!t) return null; + const { acroForm: a } = t, + r = new RefSet(), + i = Object.create(null), + n = new Map(), + s = new RefSetCache(); + for (const e of a.get("Fields")) + await this.#Ke("", null, e, n, t, r, s); + const o = []; + for (const [e, t] of n) + o.push( + Promise.all(t).then((t) => { + (t = t.filter((e) => !!e)).length > 0 && (i[e] = t); + }), + ); + await Promise.all(o); + return { allFields: objectSize(i) > 0 ? i : null, orphanFields: s }; + }), + ); + } + get hasJSActions() { + return shadow( + this, + "hasJSActions", + this.pdfManager.ensureDoc("_parseHasJSActions"), + ); + } + async _parseHasJSActions() { + const [e, t] = await Promise.all([ + this.pdfManager.ensureCatalog("jsActions"), + this.pdfManager.ensureDoc("fieldObjects"), + ]); + return ( + !!e || + (!!t?.allFields && + Object.values(t.allFields).some((e) => + e.some((e) => null !== e.actions), + )) + ); + } + get calculationOrderIds() { + const e = this.catalog.acroForm?.get("CO"); + if (!Array.isArray(e) || 0 === e.length) + return shadow(this, "calculationOrderIds", null); + const t = []; + for (const a of e) a instanceof Ref && t.push(a.toString()); + return shadow(this, "calculationOrderIds", t.length ? t : null); + } + get annotationGlobals() { + return shadow( + this, + "annotationGlobals", + AnnotationFactory.createGlobals(this.pdfManager), + ); + } +} +class BasePdfManager { + constructor({ + docBaseUrl: e, + docId: t, + enableXfa: a, + evaluatorOptions: r, + handler: i, + password: n, + }) { + this._docBaseUrl = (function parseDocBaseUrl(e) { + if (e) { + const t = createValidAbsoluteUrl(e); + if (t) return t.href; + warn(`Invalid absolute docBaseUrl: "${e}".`); + } + return null; + })(e); + this._docId = t; + this._password = n; + this.enableXfa = a; + r.isOffscreenCanvasSupported &&= FeatureTest.isOffscreenCanvasSupported; + r.isImageDecoderSupported &&= FeatureTest.isImageDecoderSupported; + this.evaluatorOptions = Object.freeze(r); + ImageResizer.setOptions(r); + JpegStream.setOptions(r); + OperatorList.setOptions(r); + const s = { ...r, handler: i }; + JpxImage.setOptions(s); + IccColorSpace.setOptions(s); + CmykICCBasedCS.setOptions(s); + } + get docId() { + return this._docId; + } + get password() { + return this._password; + } + get docBaseUrl() { + return this._docBaseUrl; + } + ensureDoc(e, t) { + return this.ensure(this.pdfDocument, e, t); + } + ensureXRef(e, t) { + return this.ensure(this.pdfDocument.xref, e, t); + } + ensureCatalog(e, t) { + return this.ensure(this.pdfDocument.catalog, e, t); + } + getPage(e) { + return this.pdfDocument.getPage(e); + } + fontFallback(e, t) { + return this.pdfDocument.fontFallback(e, t); + } + cleanup(e = !1) { + return this.pdfDocument.cleanup(e); + } + async ensure(e, t, a) { + unreachable("Abstract method `ensure` called"); + } + requestRange(e, t) { + unreachable("Abstract method `requestRange` called"); + } + requestLoadedStream(e = !1) { + unreachable("Abstract method `requestLoadedStream` called"); + } + sendProgressiveData(e) { + unreachable("Abstract method `sendProgressiveData` called"); + } + updatePassword(e) { + this._password = e; + } + terminate(e) { + unreachable("Abstract method `terminate` called"); + } +} +class LocalPdfManager extends BasePdfManager { + constructor(e) { + super(e); + const t = new Stream(e.source); + this.pdfDocument = new PDFDocument(this, t); + this._loadedStreamPromise = Promise.resolve(t); + } + async ensure(e, t, a) { + const r = e[t]; + return "function" == typeof r ? r.apply(e, a) : r; + } + requestRange(e, t) { + return Promise.resolve(); + } + requestLoadedStream(e = !1) { + return this._loadedStreamPromise; + } + terminate(e) {} +} +class NetworkPdfManager extends BasePdfManager { + constructor(e) { + super(e); + this.streamManager = new ChunkedStreamManager(e.source, { + msgHandler: e.handler, + length: e.length, + disableAutoFetch: e.disableAutoFetch, + rangeChunkSize: e.rangeChunkSize, + }); + this.pdfDocument = new PDFDocument(this, this.streamManager.getStream()); + } + async ensure(e, t, a) { + try { + const r = e[t]; + return "function" == typeof r ? r.apply(e, a) : r; + } catch (r) { + if (!(r instanceof MissingDataException)) throw r; + await this.requestRange(r.begin, r.end); + return this.ensure(e, t, a); + } + } + requestRange(e, t) { + return this.streamManager.requestRange(e, t); + } + requestLoadedStream(e = !1) { + return this.streamManager.requestAllChunks(e); + } + sendProgressiveData(e) { + this.streamManager.onReceiveData({ chunk: e }); + } + terminate(e) { + this.streamManager.abort(e); + } +} +const kc = 1, + Ac = 2, + Cc = 1, + vc = 2, + Fc = 3, + Ic = 4, + Tc = 5, + Oc = 6, + Mc = 7, + Dc = 8; +function onFn() {} +function wrapReason(e) { + if ( + e instanceof AbortException || + e instanceof InvalidPDFException || + e instanceof PasswordException || + e instanceof ResponseException || + e instanceof UnknownErrorException + ) + return e; + e instanceof Error || + ("object" == typeof e && null !== e) || + unreachable( + 'wrapReason: Expected "reason" to be a (possibly cloned) Error.', + ); + switch (e.name) { + case "AbortException": + return new AbortException(e.message); + case "InvalidPDFException": + return new InvalidPDFException(e.message); + case "PasswordException": + return new PasswordException(e.message, e.code); + case "ResponseException": + return new ResponseException(e.message, e.status, e.missing); + case "UnknownErrorException": + return new UnknownErrorException(e.message, e.details); + } + return new UnknownErrorException(e.message, e.toString()); +} +class MessageHandler { + #Je = new AbortController(); + constructor(e, t, a) { + this.sourceName = e; + this.targetName = t; + this.comObj = a; + this.callbackId = 1; + this.streamId = 1; + this.streamSinks = Object.create(null); + this.streamControllers = Object.create(null); + this.callbackCapabilities = Object.create(null); + this.actionHandler = Object.create(null); + a.addEventListener("message", this.#Ye.bind(this), { + signal: this.#Je.signal, + }); + } + #Ye({ data: e }) { + if (e.targetName !== this.sourceName) return; + if (e.stream) { + this.#Ze(e); + return; + } + if (e.callback) { + const t = e.callbackId, + a = this.callbackCapabilities[t]; + if (!a) throw new Error(`Cannot resolve callback ${t}`); + delete this.callbackCapabilities[t]; + if (e.callback === kc) a.resolve(e.data); + else { + if (e.callback !== Ac) throw new Error("Unexpected callback case"); + a.reject(wrapReason(e.reason)); + } + return; + } + const t = this.actionHandler[e.action]; + if (!t) throw new Error(`Unknown action from worker: ${e.action}`); + if (e.callbackId) { + const a = this.sourceName, + r = e.sourceName, + i = this.comObj; + Promise.try(t, e.data).then( + function (t) { + i.postMessage({ + sourceName: a, + targetName: r, + callback: kc, + callbackId: e.callbackId, + data: t, + }); + }, + function (t) { + i.postMessage({ + sourceName: a, + targetName: r, + callback: Ac, + callbackId: e.callbackId, + reason: wrapReason(t), + }); + }, + ); + } else e.streamId ? this.#Qe(e) : t(e.data); + } + on(e, t) { + const a = this.actionHandler; + if (a[e]) throw new Error(`There is already an actionName called "${e}"`); + a[e] = t; + } + send(e, t, a) { + this.comObj.postMessage( + { + sourceName: this.sourceName, + targetName: this.targetName, + action: e, + data: t, + }, + a, + ); + } + sendWithPromise(e, t, a) { + const r = this.callbackId++, + i = Promise.withResolvers(); + this.callbackCapabilities[r] = i; + try { + this.comObj.postMessage( + { + sourceName: this.sourceName, + targetName: this.targetName, + action: e, + callbackId: r, + data: t, + }, + a, + ); + } catch (e) { + i.reject(e); + } + return i.promise; + } + sendWithStream(e, t, a, r) { + const i = this.streamId++, + n = this.sourceName, + s = this.targetName, + o = this.comObj; + return new ReadableStream( + { + start: (a) => { + const c = Promise.withResolvers(); + this.streamControllers[i] = { + controller: a, + startCall: c, + pullCall: null, + cancelCall: null, + isClosed: !1, + }; + o.postMessage( + { + sourceName: n, + targetName: s, + action: e, + streamId: i, + data: t, + desiredSize: a.desiredSize, + }, + r, + ); + return c.promise; + }, + pull: (e) => { + const t = Promise.withResolvers(); + this.streamControllers[i].pullCall = t; + o.postMessage({ + sourceName: n, + targetName: s, + stream: Oc, + streamId: i, + desiredSize: e.desiredSize, + }); + return t.promise; + }, + cancel: (e) => { + assert(e instanceof Error, "cancel must have a valid reason"); + const t = Promise.withResolvers(); + this.streamControllers[i].cancelCall = t; + this.streamControllers[i].isClosed = !0; + o.postMessage({ + sourceName: n, + targetName: s, + stream: Cc, + streamId: i, + reason: wrapReason(e), + }); + return t.promise; + }, + }, + a, + ); + } + #Qe(e) { + const t = e.streamId, + a = this.sourceName, + r = e.sourceName, + i = this.comObj, + n = this, + s = this.actionHandler[e.action], + o = { + enqueue(e, n = 1, s) { + if (this.isCancelled) return; + const o = this.desiredSize; + this.desiredSize -= n; + if (o > 0 && this.desiredSize <= 0) { + this.sinkCapability = Promise.withResolvers(); + this.ready = this.sinkCapability.promise; + } + i.postMessage( + { sourceName: a, targetName: r, stream: Ic, streamId: t, chunk: e }, + s, + ); + }, + close() { + if (!this.isCancelled) { + this.isCancelled = !0; + i.postMessage({ + sourceName: a, + targetName: r, + stream: Fc, + streamId: t, + }); + delete n.streamSinks[t]; + } + }, + error(e) { + assert(e instanceof Error, "error must have a valid reason"); + if (!this.isCancelled) { + this.isCancelled = !0; + i.postMessage({ + sourceName: a, + targetName: r, + stream: Tc, + streamId: t, + reason: wrapReason(e), + }); + } + }, + sinkCapability: Promise.withResolvers(), + onPull: null, + onCancel: null, + isCancelled: !1, + desiredSize: e.desiredSize, + ready: null, + }; + o.sinkCapability.resolve(); + o.ready = o.sinkCapability.promise; + this.streamSinks[t] = o; + Promise.try(s, e.data, o).then( + function () { + i.postMessage({ + sourceName: a, + targetName: r, + stream: Dc, + streamId: t, + success: !0, + }); + }, + function (e) { + i.postMessage({ + sourceName: a, + targetName: r, + stream: Dc, + streamId: t, + reason: wrapReason(e), + }); + }, + ); + } + #Ze(e) { + const t = e.streamId, + a = this.sourceName, + r = e.sourceName, + i = this.comObj, + n = this.streamControllers[t], + s = this.streamSinks[t]; + switch (e.stream) { + case Dc: + e.success + ? n.startCall.resolve() + : n.startCall.reject(wrapReason(e.reason)); + break; + case Mc: + e.success + ? n.pullCall.resolve() + : n.pullCall.reject(wrapReason(e.reason)); + break; + case Oc: + if (!s) { + i.postMessage({ + sourceName: a, + targetName: r, + stream: Mc, + streamId: t, + success: !0, + }); + break; + } + s.desiredSize <= 0 && e.desiredSize > 0 && s.sinkCapability.resolve(); + s.desiredSize = e.desiredSize; + Promise.try(s.onPull || onFn).then( + function () { + i.postMessage({ + sourceName: a, + targetName: r, + stream: Mc, + streamId: t, + success: !0, + }); + }, + function (e) { + i.postMessage({ + sourceName: a, + targetName: r, + stream: Mc, + streamId: t, + reason: wrapReason(e), + }); + }, + ); + break; + case Ic: + assert(n, "enqueue should have stream controller"); + if (n.isClosed) break; + n.controller.enqueue(e.chunk); + break; + case Fc: + assert(n, "close should have stream controller"); + if (n.isClosed) break; + n.isClosed = !0; + n.controller.close(); + this.#et(n, t); + break; + case Tc: + assert(n, "error should have stream controller"); + n.controller.error(wrapReason(e.reason)); + this.#et(n, t); + break; + case vc: + e.success + ? n.cancelCall.resolve() + : n.cancelCall.reject(wrapReason(e.reason)); + this.#et(n, t); + break; + case Cc: + if (!s) break; + const o = wrapReason(e.reason); + Promise.try(s.onCancel || onFn, o).then( + function () { + i.postMessage({ + sourceName: a, + targetName: r, + stream: vc, + streamId: t, + success: !0, + }); + }, + function (e) { + i.postMessage({ + sourceName: a, + targetName: r, + stream: vc, + streamId: t, + reason: wrapReason(e), + }); + }, + ); + s.sinkCapability.reject(o); + s.isCancelled = !0; + delete this.streamSinks[t]; + break; + default: + throw new Error("Unexpected stream case"); + } + } + async #et(e, t) { + await Promise.allSettled([ + e.startCall?.promise, + e.pullCall?.promise, + e.cancelCall?.promise, + ]); + delete this.streamControllers[t]; + } + destroy() { + this.#Je?.abort(); + this.#Je = null; + } +} +async function writeObject(e, t, a, { encrypt: r = null }) { + const i = r?.createCipherTransform(e.num, e.gen); + a.push(`${e.num} ${e.gen} obj\n`); + t instanceof Dict + ? await writeDict(t, a, i) + : t instanceof BaseStream + ? await writeStream(t, a, i) + : (Array.isArray(t) || ArrayBuffer.isView(t)) && + (await writeArray(t, a, i)); + a.push("\nendobj\n"); +} +async function writeDict(e, t, a) { + t.push("<<"); + for (const r of e.getKeys()) { + t.push(` /${escapePDFName(r)} `); + await writeValue(e.getRaw(r), t, a); + } + t.push(">>"); +} +async function writeStream(e, t, a) { + let r = e.getBytes(); + const { dict: i } = e, + [n, s] = await Promise.all([ + i.getAsync("Filter"), + i.getAsync("DecodeParms"), + ]), + o = isName( + Array.isArray(n) ? await i.xref.fetchIfRefAsync(n[0]) : n, + "FlateDecode", + ); + if (r.length >= 256 || o) + try { + const e = new CompressionStream("deflate"), + t = e.writable.getWriter(); + await t.ready; + t.write(r) + .then(async () => { + await t.ready; + await t.close(); + }) + .catch(() => {}); + const a = await new Response(e.readable).arrayBuffer(); + r = new Uint8Array(a); + let c, l; + if (n) { + if (!o) { + c = Array.isArray(n) + ? [Name.get("FlateDecode"), ...n] + : [Name.get("FlateDecode"), n]; + s && (l = Array.isArray(s) ? [null, ...s] : [null, s]); + } + } else c = Name.get("FlateDecode"); + c && i.set("Filter", c); + l && i.set("DecodeParms", l); + } catch (e) { + info(`writeStream - cannot compress data: "${e}".`); + } + let c = bytesToString(r); + a && (c = a.encryptString(c)); + i.set("Length", c.length); + await writeDict(i, t, a); + t.push(" stream\n", c, "\nendstream"); +} +async function writeArray(e, t, a) { + t.push("["); + let r = !0; + for (const i of e) { + r ? (r = !1) : t.push(" "); + await writeValue(i, t, a); + } + t.push("]"); +} +async function writeValue(e, t, a) { + if (e instanceof Name) t.push(`/${escapePDFName(e.name)}`); + else if (e instanceof Ref) t.push(`${e.num} ${e.gen} R`); + else if (Array.isArray(e) || ArrayBuffer.isView(e)) await writeArray(e, t, a); + else if ("string" == typeof e) { + a && (e = a.encryptString(e)); + t.push(`(${escapeString(e)})`); + } else + "number" == typeof e + ? t.push(numberToString(e)) + : "boolean" == typeof e + ? t.push(e.toString()) + : e instanceof Dict + ? await writeDict(e, t, a) + : e instanceof BaseStream + ? await writeStream(e, t, a) + : null === e + ? t.push("null") + : warn( + `Unhandled value in writer: ${typeof e}, please file a bug.`, + ); +} +function writeInt(e, t, a, r) { + for (let i = t + a - 1; i > a - 1; i--) { + r[i] = 255 & e; + e >>= 8; + } + return a + t; +} +function writeString(e, t, a) { + const r = e.length; + for (let i = 0; i < r; i++) a[t + i] = 255 & e.charCodeAt(i); + return t + r; +} +function updateXFA({ xfaData: e, xfaDatasetsRef: t, changes: a, xref: r }) { + if (null === e) { + e = (function writeXFADataForAcroform(e, t) { + const a = new SimpleXMLParser({ hasAttributes: !0 }).parseFromString(e); + for (const { xfa: e } of t) { + if (!e) continue; + const { path: t, value: r } = e; + if (!t) continue; + const i = parseXFAPath(t); + let n = a.documentElement.searchNode(i, 0); + !n && i.length > 1 && (n = a.documentElement.searchNode([i.at(-1)], 0)); + n + ? (n.childNodes = Array.isArray(r) + ? r.map((e) => new SimpleDOMNode("value", e)) + : [new SimpleDOMNode("#text", r)]) + : warn(`Node not found for path: ${t}`); + } + const r = []; + a.documentElement.dump(r); + return r.join(""); + })(r.fetchIfRef(t).getString(), a); + } + const i = new StringStream(e); + i.dict = new Dict(r); + i.dict.set("Type", Name.get("EmbeddedFile")); + a.put(t, { data: i }); +} +function getIndexes(e) { + const t = []; + for (const { ref: a } of e) + a.num === t.at(-2) + t.at(-1) ? (t[t.length - 1] += 1) : t.push(a.num, 1); + return t; +} +function computeIDs(e, t, a) { + if (Array.isArray(t.fileIds) && t.fileIds.length > 0) { + const r = (function computeMD5(e, t) { + const a = Math.floor(Date.now() / 1e3), + r = t.filename || "", + i = [a.toString(), r, e.toString(), ...t.infoMap.values()], + n = Math.sumPrecise(i.map((e) => e.length)), + s = new Uint8Array(n); + let o = 0; + for (const e of i) o = writeString(e, o, s); + return bytesToString(calculateMD5(s, 0, s.length)); + })(e, t); + a.set("ID", [t.fileIds[0], r]); + } +} +async function incrementalUpdate({ + originalData: e, + xrefInfo: t, + changes: a, + xref: r = null, + hasXfa: i = !1, + xfaDatasetsRef: n = null, + hasXfaDatasetsEntry: s = !1, + needAppearances: o, + acroFormRef: c = null, + acroForm: l = null, + xfaData: h = null, + useXrefStream: u = !1, +}) { + await (async function updateAcroform({ + xref: e, + acroForm: t, + acroFormRef: a, + hasXfa: r, + hasXfaDatasetsEntry: i, + xfaDatasetsRef: n, + needAppearances: s, + changes: o, + }) { + !r || i || n || warn("XFA - Cannot save it"); + if (!s && (!r || !n || i)) return; + const c = t.clone(); + if (r && !i) { + const e = t.get("XFA").slice(); + e.splice(2, 0, "datasets"); + e.splice(3, 0, n); + c.set("XFA", e); + } + s && c.set("NeedAppearances", !0); + o.put(a, { data: c }); + })({ + xref: r, + acroForm: l, + acroFormRef: c, + hasXfa: i, + hasXfaDatasetsEntry: s, + xfaDatasetsRef: n, + needAppearances: o, + changes: a, + }); + i && updateXFA({ xfaData: h, xfaDatasetsRef: n, changes: a, xref: r }); + const d = (function getTrailerDict(e, t, a) { + const r = new Dict(null); + r.set("Prev", e.startXRef); + const i = e.newRef; + if (a) { + t.put(i, { data: "" }); + r.set("Size", i.num + 1); + r.set("Type", Name.get("XRef")); + } else r.set("Size", i.num); + null !== e.rootRef && r.set("Root", e.rootRef); + null !== e.infoRef && r.set("Info", e.infoRef); + null !== e.encryptRef && r.set("Encrypt", e.encryptRef); + return r; + })(t, a, u), + f = [], + g = await (async function writeChanges(e, t, a = []) { + const r = []; + for (const [i, { data: n }] of e.items()) + if (null !== n && "string" != typeof n) { + await writeObject(i, n, a, t); + r.push({ ref: i, data: a.join("") }); + a.length = 0; + } else r.push({ ref: i, data: n }); + return r.sort((e, t) => e.ref.num - t.ref.num); + })(a, r, f); + let p = e.length; + const m = e.at(-1); + if (10 !== m && 13 !== m) { + f.push("\n"); + p += 1; + } + for (const { data: e } of g) null !== e && f.push(e); + await (u + ? (async function getXRefStreamTable(e, t, a, r, i) { + const n = []; + let s = 0, + o = 0; + for (const { ref: e, data: r } of a) { + let a; + s = Math.max(s, t); + if (null !== r) { + a = Math.min(e.gen, 65535); + n.push([1, t, a]); + t += r.length; + } else { + a = Math.min(e.gen + 1, 65535); + n.push([0, 0, a]); + } + o = Math.max(o, a); + } + r.set("Index", getIndexes(a)); + const c = [1, getSizeInBytes(s), getSizeInBytes(o)]; + r.set("W", c); + computeIDs(t, e, r); + const l = Math.sumPrecise(c), + h = new Uint8Array(l * n.length), + u = new Stream(h); + u.dict = r; + let d = 0; + for (const [e, t, a] of n) { + d = writeInt(e, c[0], d, h); + d = writeInt(t, c[1], d, h); + d = writeInt(a, c[2], d, h); + } + await writeObject(e.newRef, u, i, {}); + i.push("startxref\n", t.toString(), "\n%%EOF\n"); + })(t, p, g, d, f) + : (async function getXRefTable(e, t, a, r, i) { + i.push("xref\n"); + const n = getIndexes(a); + let s = 0; + for (const { ref: e, data: r } of a) { + if (e.num === n[s]) { + i.push(`${n[s]} ${n[s + 1]}\n`); + s += 2; + } + if (null !== r) { + i.push( + `${t.toString().padStart(10, "0")} ${Math.min(e.gen, 65535).toString().padStart(5, "0")} n\r\n`, + ); + t += r.length; + } else + i.push( + `0000000000 ${Math.min(e.gen + 1, 65535) + .toString() + .padStart(5, "0")} f\r\n`, + ); + } + computeIDs(t, e, r); + i.push("trailer\n"); + await writeDict(r, i); + i.push("\nstartxref\n", t.toString(), "\n%%EOF\n"); + })(t, p, g, d, f)); + const b = e.length + Math.sumPrecise(f.map((e) => e.length)), + y = new Uint8Array(b); + y.set(e); + let w = e.length; + for (const e of f) w = writeString(e, w, y); + return y; +} +class PDFWorkerStream { + constructor(e) { + this._msgHandler = e; + this._contentLength = null; + this._fullRequestReader = null; + this._rangeRequestReaders = []; + } + getFullReader() { + assert( + !this._fullRequestReader, + "PDFWorkerStream.getFullReader can only be called once.", + ); + this._fullRequestReader = new PDFWorkerStreamReader(this._msgHandler); + return this._fullRequestReader; + } + getRangeReader(e, t) { + const a = new PDFWorkerStreamRangeReader(e, t, this._msgHandler); + this._rangeRequestReaders.push(a); + return a; + } + cancelAllRequests(e) { + this._fullRequestReader?.cancel(e); + for (const t of this._rangeRequestReaders.slice(0)) t.cancel(e); + } +} +class PDFWorkerStreamReader { + constructor(e) { + this._msgHandler = e; + this.onProgress = null; + this._contentLength = null; + this._isRangeSupported = !1; + this._isStreamingSupported = !1; + const t = this._msgHandler.sendWithStream("GetReader"); + this._reader = t.getReader(); + this._headersReady = this._msgHandler + .sendWithPromise("ReaderHeadersReady") + .then((e) => { + this._isStreamingSupported = e.isStreamingSupported; + this._isRangeSupported = e.isRangeSupported; + this._contentLength = e.contentLength; + }); + } + get headersReady() { + return this._headersReady; + } + get contentLength() { + return this._contentLength; + } + get isStreamingSupported() { + return this._isStreamingSupported; + } + get isRangeSupported() { + return this._isRangeSupported; + } + async read() { + const { value: e, done: t } = await this._reader.read(); + return t ? { value: void 0, done: !0 } : { value: e.buffer, done: !1 }; + } + cancel(e) { + this._reader.cancel(e); + } +} +class PDFWorkerStreamRangeReader { + constructor(e, t, a) { + this._msgHandler = a; + this.onProgress = null; + const r = this._msgHandler.sendWithStream("GetRangeReader", { + begin: e, + end: t, + }); + this._reader = r.getReader(); + } + get isStreamingSupported() { + return !1; + } + async read() { + const { value: e, done: t } = await this._reader.read(); + return t ? { value: void 0, done: !0 } : { value: e.buffer, done: !1 }; + } + cancel(e) { + this._reader.cancel(e); + } +} +class WorkerTask { + constructor(e) { + this.name = e; + this.terminated = !1; + this._capability = Promise.withResolvers(); + } + get finished() { + return this._capability.promise; + } + finish() { + this._capability.resolve(); + } + terminate() { + this.terminated = !0; + } + ensureNotTerminated() { + if (this.terminated) throw new Error("Worker task was terminated"); + } +} +class WorkerMessageHandler { + static { + "undefined" == typeof window && + !e && + "undefined" != typeof self && + "function" == typeof self.postMessage && + "onmessage" in self && + this.initializeFromPort(self); + } + static setup(e, t) { + let a = !1; + e.on("test", (t) => { + if (!a) { + a = !0; + e.send("test", t instanceof Uint8Array); + } + }); + e.on("configure", (e) => { + !(function setVerbosityLevel(e) { + Number.isInteger(e) && (da = e); + })(e.verbosity); + }); + e.on("GetDocRequest", (e) => this.createDocumentHandler(e, t)); + } + static createDocumentHandler(e, t) { + let a, + r = !1, + i = null; + const n = new Set(), + s = getVerbosityLevel(), + { docId: o, apiVersion: c } = e, + l = "5.3.93"; + if (c !== l) + throw new Error( + `The API version "${c}" does not match the Worker version "${l}".`, + ); + const buildMsg = (e, t) => + `The \`${e}.prototype\` contains unexpected enumerable property "${t}", thus breaking e.g. \`for...in\` iteration of ${e}s.`; + for (const e in {}) throw new Error(buildMsg("Object", e)); + for (const e in []) throw new Error(buildMsg("Array", e)); + const h = o + "_worker"; + let u = new MessageHandler(h, o, t); + function ensureNotTerminated() { + if (r) throw new Error("Worker was terminated"); + } + function startWorkerTask(e) { + n.add(e); + } + function finishWorkerTask(e) { + e.finish(); + n.delete(e); + } + async function loadDocument(e) { + await a.ensureDoc("checkHeader"); + await a.ensureDoc("parseStartXRef"); + await a.ensureDoc("parse", [e]); + await a.ensureDoc("checkFirstPage", [e]); + await a.ensureDoc("checkLastPage", [e]); + const t = await a.ensureDoc("isPureXfa"); + if (t) { + const e = new WorkerTask("loadXfaResources"); + startWorkerTask(e); + await a.ensureDoc("loadXfaResources", [u, e]); + finishWorkerTask(e); + } + const [r, i] = await Promise.all([ + a.ensureDoc("numPages"), + a.ensureDoc("fingerprints"), + ]); + return { + numPages: r, + fingerprints: i, + htmlForXfa: t ? await a.ensureDoc("htmlForXfa") : null, + }; + } + function setupDoc(e) { + function onSuccess(e) { + ensureNotTerminated(); + u.send("GetDoc", { pdfInfo: e }); + } + function onFailure(e) { + ensureNotTerminated(); + if (e instanceof PasswordException) { + const t = new WorkerTask(`PasswordException: response ${e.code}`); + startWorkerTask(t); + u.sendWithPromise("PasswordRequest", e) + .then(function ({ password: e }) { + finishWorkerTask(t); + a.updatePassword(e); + pdfManagerReady(); + }) + .catch(function () { + finishWorkerTask(t); + u.send("DocException", e); + }); + } else u.send("DocException", wrapReason(e)); + } + function pdfManagerReady() { + ensureNotTerminated(); + loadDocument(!1).then(onSuccess, function (e) { + ensureNotTerminated(); + e instanceof XRefParseException + ? a.requestLoadedStream().then(function () { + ensureNotTerminated(); + loadDocument(!0).then(onSuccess, onFailure); + }) + : onFailure(e); + }); + } + ensureNotTerminated(); + (async function getPdfManager({ + data: e, + password: t, + disableAutoFetch: a, + rangeChunkSize: r, + length: n, + docBaseUrl: s, + enableXfa: c, + evaluatorOptions: l, + }) { + const h = { + source: null, + disableAutoFetch: a, + docBaseUrl: s, + docId: o, + enableXfa: c, + evaluatorOptions: l, + handler: u, + length: n, + password: t, + rangeChunkSize: r, + }; + if (e) { + h.source = e; + return new LocalPdfManager(h); + } + const d = new PDFWorkerStream(u), + f = d.getFullReader(), + g = Promise.withResolvers(); + let p, + m = [], + b = 0; + f.headersReady + .then(function () { + if (f.isRangeSupported) { + h.source = d; + h.length = f.contentLength; + h.disableAutoFetch ||= f.isStreamingSupported; + p = new NetworkPdfManager(h); + for (const e of m) p.sendProgressiveData(e); + m = []; + g.resolve(p); + i = null; + } + }) + .catch(function (e) { + g.reject(e); + i = null; + }); + new Promise(function (e, t) { + const readChunk = function ({ value: e, done: a }) { + try { + ensureNotTerminated(); + if (a) { + if (!p) { + const e = arrayBuffersToBytes(m); + m = []; + n && + e.length !== n && + warn("reported HTTP length is different from actual"); + h.source = e; + p = new LocalPdfManager(h); + g.resolve(p); + } + i = null; + return; + } + b += e.byteLength; + f.isStreamingSupported || + u.send("DocProgress", { + loaded: b, + total: Math.max(b, f.contentLength || 0), + }); + p ? p.sendProgressiveData(e) : m.push(e); + f.read().then(readChunk, t); + } catch (e) { + t(e); + } + }; + f.read().then(readChunk, t); + }).catch(function (e) { + g.reject(e); + i = null; + }); + i = (e) => { + d.cancelAllRequests(e); + }; + return g.promise; + })(e) + .then(function (e) { + if (r) { + e.terminate(new AbortException("Worker was terminated.")); + throw new Error("Worker was terminated"); + } + a = e; + a.requestLoadedStream(!0).then((e) => { + u.send("DataLoaded", { length: e.bytes.byteLength }); + }); + }) + .then(pdfManagerReady, onFailure); + } + u.on("GetPage", function (e) { + return a.getPage(e.pageIndex).then(function (e) { + return Promise.all([ + a.ensure(e, "rotate"), + a.ensure(e, "ref"), + a.ensure(e, "userUnit"), + a.ensure(e, "view"), + ]).then(function ([e, t, a, r]) { + return { + rotate: e, + ref: t, + refStr: t?.toString() ?? null, + userUnit: a, + view: r, + }; + }); + }); + }); + u.on("GetPageIndex", function (e) { + const t = Ref.get(e.num, e.gen); + return a.ensureCatalog("getPageIndex", [t]); + }); + u.on("GetDestinations", function (e) { + return a.ensureCatalog("destinations"); + }); + u.on("GetDestination", function (e) { + return a.ensureCatalog("getDestination", [e.id]); + }); + u.on("GetPageLabels", function (e) { + return a.ensureCatalog("pageLabels"); + }); + u.on("GetPageLayout", function (e) { + return a.ensureCatalog("pageLayout"); + }); + u.on("GetPageMode", function (e) { + return a.ensureCatalog("pageMode"); + }); + u.on("GetViewerPreferences", function (e) { + return a.ensureCatalog("viewerPreferences"); + }); + u.on("GetOpenAction", function (e) { + return a.ensureCatalog("openAction"); + }); + u.on("GetAttachments", function (e) { + return a.ensureCatalog("attachments"); + }); + u.on("GetDocJSActions", function (e) { + return a.ensureCatalog("jsActions"); + }); + u.on("GetPageJSActions", function ({ pageIndex: e }) { + return a.getPage(e).then((e) => a.ensure(e, "jsActions")); + }); + u.on("GetOutline", function (e) { + return a.ensureCatalog("documentOutline"); + }); + u.on("GetOptionalContentConfig", function (e) { + return a.ensureCatalog("optionalContentConfig"); + }); + u.on("GetPermissions", function (e) { + return a.ensureCatalog("permissions"); + }); + u.on("GetMetadata", function (e) { + return Promise.all([ + a.ensureDoc("documentInfo"), + a.ensureCatalog("metadata"), + ]); + }); + u.on("GetMarkInfo", function (e) { + return a.ensureCatalog("markInfo"); + }); + u.on("GetData", function (e) { + return a.requestLoadedStream().then((e) => e.bytes); + }); + u.on("GetAnnotations", function ({ pageIndex: e, intent: t }) { + return a.getPage(e).then(function (a) { + const r = new WorkerTask(`GetAnnotations: page ${e}`); + startWorkerTask(r); + return a.getAnnotationsData(u, r, t).then( + (e) => { + finishWorkerTask(r); + return e; + }, + (e) => { + finishWorkerTask(r); + throw e; + }, + ); + }); + }); + u.on("GetFieldObjects", function (e) { + return a.ensureDoc("fieldObjects").then((e) => e?.allFields || null); + }); + u.on("HasJSActions", function (e) { + return a.ensureDoc("hasJSActions"); + }); + u.on("GetCalculationOrderIds", function (e) { + return a.ensureDoc("calculationOrderIds"); + }); + u.on( + "SaveDocument", + async function ({ + isPureXfa: e, + numPages: t, + annotationStorage: r, + filename: i, + }) { + const n = [ + a.requestLoadedStream(), + a.ensureCatalog("acroForm"), + a.ensureCatalog("acroFormRef"), + a.ensureDoc("startXRef"), + a.ensureDoc("xref"), + a.ensureDoc("linearization"), + a.ensureCatalog("structTreeRoot"), + ], + s = new RefSetCache(), + o = [], + c = e ? null : getNewAnnotationsMap(r), + [l, h, d, f, g, p, m] = await Promise.all(n), + b = g.trailer.getRaw("Root") || null; + let y; + if (c) { + m + ? (await m.canUpdateStructTree({ + pdfManager: a, + newAnnotationsByPage: c, + })) && (y = m) + : (await StructTreeRoot.canCreateStructureTree({ + catalogRef: b, + pdfManager: a, + newAnnotationsByPage: c, + })) && (y = null); + const e = AnnotationFactory.generateImages( + r.values(), + g, + a.evaluatorOptions.isOffscreenCanvasSupported, + ), + t = void 0 === y ? o : []; + for (const [r, i] of c) + t.push( + a.getPage(r).then((t) => { + const a = new WorkerTask(`Save (editor): page ${r}`); + startWorkerTask(a); + return t.saveNewAnnotations(u, a, i, e, s).finally(function () { + finishWorkerTask(a); + }); + }), + ); + null === y + ? o.push( + Promise.all(t).then(async () => { + await StructTreeRoot.createStructureTree({ + newAnnotationsByPage: c, + xref: g, + catalogRef: b, + pdfManager: a, + changes: s, + }); + }), + ) + : y && + o.push( + Promise.all(t).then(async () => { + await y.updateStructureTree({ + newAnnotationsByPage: c, + pdfManager: a, + changes: s, + }); + }), + ); + } + if (e) o.push(a.ensureDoc("serializeXfaData", [r])); + else + for (let e = 0; e < t; e++) + o.push( + a.getPage(e).then(function (t) { + const a = new WorkerTask(`Save: page ${e}`); + startWorkerTask(a); + return t.save(u, a, r, s).finally(function () { + finishWorkerTask(a); + }); + }), + ); + const w = await Promise.all(o); + let x = null; + if (e) { + x = w[0]; + if (!x) return l.bytes; + } else if (0 === s.size) return l.bytes; + const S = + d && h instanceof Dict && s.values().some((e) => e.needAppearances), + k = (h instanceof Dict && h.get("XFA")) || null; + let C = null, + v = !1; + if (Array.isArray(k)) { + for (let e = 0, t = k.length; e < t; e += 2) + if ("datasets" === k[e]) { + C = k[e + 1]; + v = !0; + } + null === C && (C = g.getNewTemporaryRef()); + } else k && warn("Unsupported XFA type."); + let F = Object.create(null); + if (g.trailer) { + const e = new Map(), + t = g.trailer.get("Info") || null; + if (t instanceof Dict) + for (const [a, r] of t) + "string" == typeof r && e.set(a, stringToPDFString(r)); + F = { + rootRef: b, + encryptRef: g.trailer.getRaw("Encrypt") || null, + newRef: g.getNewTemporaryRef(), + infoRef: g.trailer.getRaw("Info") || null, + infoMap: e, + fileIds: g.trailer.get("ID") || null, + startXRef: p ? f : (g.lastXRefStreamPos ?? f), + filename: i, + }; + } + return incrementalUpdate({ + originalData: l.bytes, + xrefInfo: F, + changes: s, + xref: g, + hasXfa: !!k, + xfaDatasetsRef: C, + hasXfaDatasetsEntry: v, + needAppearances: S, + acroFormRef: d, + acroForm: h, + xfaData: x, + useXrefStream: isDict(g.topDict, "XRef"), + }).finally(() => { + g.resetNewTemporaryRef(); + }); + }, + ); + u.on("GetOperatorList", function (e, t) { + const r = e.pageIndex; + a.getPage(r).then(function (a) { + const i = new WorkerTask(`GetOperatorList: page ${r}`); + startWorkerTask(i); + const n = s >= ke ? Date.now() : 0; + a.getOperatorList({ + handler: u, + sink: t, + task: i, + intent: e.intent, + cacheKey: e.cacheKey, + annotationStorage: e.annotationStorage, + modifiedIds: e.modifiedIds, + }).then( + function (e) { + finishWorkerTask(i); + n && + info( + `page=${r + 1} - getOperatorList: time=${Date.now() - n}ms, len=${e.length}`, + ); + t.close(); + }, + function (e) { + finishWorkerTask(i); + i.terminated || t.error(e); + }, + ); + }); + }); + u.on("GetTextContent", function (e, t) { + const { + pageIndex: r, + includeMarkedContent: i, + disableNormalization: n, + } = e; + a.getPage(r).then(function (e) { + const a = new WorkerTask("GetTextContent: page " + r); + startWorkerTask(a); + const o = s >= ke ? Date.now() : 0; + e.extractTextContent({ + handler: u, + task: a, + sink: t, + includeMarkedContent: i, + disableNormalization: n, + }).then( + function () { + finishWorkerTask(a); + o && + info( + `page=${r + 1} - getTextContent: time=` + + (Date.now() - o) + + "ms", + ); + t.close(); + }, + function (e) { + finishWorkerTask(a); + a.terminated || t.error(e); + }, + ); + }); + }); + u.on("GetStructTree", function (e) { + return a.getPage(e.pageIndex).then((e) => a.ensure(e, "getStructTree")); + }); + u.on("FontFallback", function (e) { + return a.fontFallback(e.id, u); + }); + u.on("Cleanup", function (e) { + return a.cleanup(!0); + }); + u.on("Terminate", function (e) { + r = !0; + const t = []; + if (a) { + a.terminate(new AbortException("Worker was terminated.")); + const e = a.cleanup(); + t.push(e); + a = null; + } else clearGlobalCaches(); + i?.(new AbortException("Worker was terminated.")); + for (const e of n) { + t.push(e.finished); + e.terminate(); + } + return Promise.all(t).then(function () { + u.destroy(); + u = null; + }); + }); + u.on("Ready", function (t) { + setupDoc(e); + e = null; + }); + return h; + } + static initializeFromPort(e) { + const t = new MessageHandler("worker", "main", e); + this.setup(t, e); + t.send("ready", null); + } +} +globalThis.pdfjsWorker = { WorkerMessageHandler }; +export { WorkerMessageHandler }; diff --git a/repo-images/Image 1.png b/repo-images/Image 1.png index a79728e8..7a398fb4 100644 Binary files a/repo-images/Image 1.png and b/repo-images/Image 1.png differ diff --git a/repo-images/Image 2.png b/repo-images/Image 2.png index 8caa89d5..e7a1f6b8 100644 Binary files a/repo-images/Image 2.png and b/repo-images/Image 2.png differ diff --git a/repo-images/Image 3.png b/repo-images/Image 3.png index 495187fb..70077cdf 100644 Binary files a/repo-images/Image 3.png and b/repo-images/Image 3.png differ diff --git a/repo-images/Image 4.png b/repo-images/Image 4.png index c30f6577..5cb16b6c 100644 Binary files a/repo-images/Image 4.png and b/repo-images/Image 4.png differ diff --git a/repo-images/Image 5.png b/repo-images/Image 5.png index 65c199af..868e5c27 100644 Binary files a/repo-images/Image 5.png and b/repo-images/Image 5.png differ diff --git a/repo-images/Image 6.png b/repo-images/Image 6.png new file mode 100644 index 00000000..9d87ba0f Binary files /dev/null and b/repo-images/Image 6.png differ diff --git a/scripts/enable-ssl.sh b/scripts/enable-ssl.sh new file mode 100644 index 00000000..9fd76e1e --- /dev/null +++ b/scripts/enable-ssl.sh @@ -0,0 +1,103 @@ +#!/bin/bash + +set -e + +RED='\033[0;31m' +GREEN='\033[0;32m' +YELLOW='\033[1;33m' +BLUE='\033[0;34m' +CYAN='\033[0;36m' +NC='\033[0m' + +SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" +PROJECT_ROOT="$(dirname "$SCRIPT_DIR")" +ENV_FILE="$PROJECT_ROOT/.env" + +log_info() { + echo -e "${BLUE}[SSL Setup]${NC} $1" +} + +log_success() { + echo -e "${GREEN}[SSL Setup]${NC} $1" +} + +log_warn() { + echo -e "${YELLOW}[SSL Setup]${NC} $1" +} + +log_error() { + echo -e "${RED}[SSL Setup]${NC} $1" +} + +log_header() { + echo -e "${CYAN}$1${NC}" +} + +generate_keys() { + log_info "Generating security keys..." + + JWT_SECRET=$(openssl rand -hex 32) + log_success "Generated JWT secret" + + DATABASE_KEY=$(openssl rand -hex 32) + log_success "Generated database encryption key" + + echo "JWT_SECRET=$JWT_SECRET" >> "$ENV_FILE" + echo "DATABASE_KEY=$DATABASE_KEY" >> "$ENV_FILE" + + log_success "Security keys added to .env file" +} + +setup_env_file() { + log_info "Setting up environment configuration..." + + if [[ -f "$ENV_FILE" ]]; then + log_warn ".env file already exists, creating backup..." + cp "$ENV_FILE" "$ENV_FILE.backup.$(date +%s)" + fi + + cat > "$ENV_FILE" << EOF +# Termix SSL Configuration - Auto-generated $(date) + +# SSL/TLS Configuration +ENABLE_SSL=true +SSL_PORT=8443 +SSL_DOMAIN=localhost +PORT=8080 + +# Node environment +NODE_ENV=production + +# CORS configuration +ALLOWED_ORIGINS=* + +EOF + + generate_keys + + log_success "Environment configuration created at $ENV_FILE" +} + +setup_ssl_certificates() { + log_info "Setting up SSL certificates..." + + if [[ -f "$SCRIPT_DIR/setup-ssl.sh" ]]; then + bash "$SCRIPT_DIR/setup-ssl.sh" + else + log_error "SSL setup script not found at $SCRIPT_DIR/setup-ssl.sh" + exit 1 + fi +} + +main() { + if ! command -v openssl &> /dev/null; then + log_error "OpenSSL is not installed. Please install OpenSSL first." + exit 1 + fi + + setup_env_file + setup_ssl_certificates +} + +# Run main function +main "$@" \ No newline at end of file diff --git a/scripts/setup-ssl.sh b/scripts/setup-ssl.sh new file mode 100644 index 00000000..8ad7c12f --- /dev/null +++ b/scripts/setup-ssl.sh @@ -0,0 +1,121 @@ +#!/bin/bash + +set -e + +SSL_DIR="$(dirname "$0")/../ssl" +CERT_FILE="$SSL_DIR/termix.crt" +KEY_FILE="$SSL_DIR/termix.key" +DAYS_VALID=365 + +DOMAIN=${SSL_DOMAIN:-"localhost"} +ALT_NAMES=${SSL_ALT_NAMES:-"DNS:localhost,DNS:127.0.0.1,DNS:*.localhost,IP:127.0.0.1"} + +RED='\033[0;31m' +GREEN='\033[0;32m' +YELLOW='\033[1;33m' +BLUE='\033[0;34m' +NC='\033[0m' + +log_info() { + echo -e "${BLUE}[SSL Setup]${NC} $1" +} + +log_success() { + echo -e "${GREEN}[SSL Setup]${NC} $1" +} + +log_warn() { + echo -e "${YELLOW}[SSL Setup]${NC} $1" +} + +log_error() { + echo -e "${RED}[SSL Setup]${NC} $1" +} + +check_existing_cert() { + if [[ -f "$CERT_FILE" && -f "$KEY_FILE" ]]; then + if openssl x509 -in "$CERT_FILE" -checkend 2592000 -noout 2>/dev/null; then + log_success "Valid SSL certificate already exists" + + local expiry=$(openssl x509 -in "$CERT_FILE" -noout -enddate 2>/dev/null | cut -d= -f2) + log_info "Expires: $expiry" + return 0 + else + log_warn "Existing certificate is expired or expiring soon" + fi + fi + return 1 +} + +generate_certificate() { + log_info "Generating new SSL certificate for domain: $DOMAIN" + + mkdir -p "$SSL_DIR" + + local config_file="$SSL_DIR/openssl.conf" + cat > "$config_file" << EOF +[req] +default_bits = 2048 +prompt = no +default_md = sha256 +distinguished_name = dn +req_extensions = v3_req + +[dn] +C=US +ST=State +L=City +O=Termix +OU=IT Department +CN=$DOMAIN + +[v3_req] +basicConstraints = CA:FALSE +keyUsage = nonRepudiation, digitalSignature, keyEncipherment +subjectAltName = @alt_names + +[alt_names] +DNS.1 = localhost +DNS.2 = 127.0.0.1 +DNS.3 = *.localhost +IP.1 = 127.0.0.1 +EOF + + if [[ -n "$SSL_ALT_NAMES" ]]; then + local counter=2 + IFS=',' read -ra NAMES <<< "$SSL_ALT_NAMES" + for name in "${NAMES[@]}"; do + name=$(echo "$name" | xargs) + if [[ "$name" == DNS:* ]]; then + echo "DNS.$((counter++)) = ${name#DNS:}" >> "$config_file" + elif [[ "$name" == IP:* ]]; then + echo "IP.$((counter++)) = ${name#IP:}" >> "$config_file" + fi + done + fi + + log_info "Generating private key..." + openssl genrsa -out "$KEY_FILE" 2048 + + log_info "Generating certificate..." + openssl req -new -x509 -key "$KEY_FILE" -out "$CERT_FILE" -days $DAYS_VALID -config "$config_file" -extensions v3_req + + chmod 600 "$KEY_FILE" + chmod 644 "$CERT_FILE" + + rm -f "$config_file" + + log_success "SSL certificate generated successfully" + log_info "Valid for: $DAYS_VALID days" +} + +main() { + if ! command -v openssl &> /dev/null; then + log_error "OpenSSL is not installed. Please install OpenSSL first." + exit 1 + fi + + generate_certificate +} + +main "$@" \ No newline at end of file diff --git a/src/backend/database/database.ts b/src/backend/database/database.ts index 50f169db..55f955e9 100644 --- a/src/backend/database/database.ts +++ b/src/backend/database/database.ts @@ -1,5 +1,7 @@ import express from "express"; import bodyParser from "body-parser"; +import multer from "multer"; +import cookieParser from "cookie-parser"; import userRoutes from "./routes/users.js"; import sshRoutes from "./routes/ssh.js"; import alertRoutes from "./routes/alerts.js"; @@ -8,13 +10,64 @@ import cors from "cors"; import fetch from "node-fetch"; import fs from "fs"; import path from "path"; +import os from "os"; import "dotenv/config"; import { databaseLogger, apiLogger } from "../utils/logger.js"; +import { AuthManager } from "../utils/auth-manager.js"; +import { DataCrypto } from "../utils/data-crypto.js"; +import { DatabaseFileEncryption } from "../utils/database-file-encryption.js"; +import { DatabaseMigration } from "../utils/database-migration.js"; +import { UserDataExport } from "../utils/user-data-export.js"; +import { AutoSSLSetup } from "../utils/auto-ssl-setup.js"; +import { eq, and } from "drizzle-orm"; +import { + users, + sshData, + sshCredentials, + fileManagerRecent, + fileManagerPinned, + fileManagerShortcuts, + dismissedAlerts, + sshCredentialUsage, + settings, +} from "./db/schema.js"; +import { getDb } from "./db/index.js"; +import Database from "better-sqlite3"; const app = express(); + +app.set("trust proxy", true); + +const authManager = AuthManager.getInstance(); +const authenticateJWT = authManager.createAuthMiddleware(); +const requireAdmin = authManager.createAdminMiddleware(); app.use( cors({ - origin: "*", + origin: (origin, callback) => { + if (!origin) return callback(null, true); + + const allowedOrigins = [ + "http://localhost:5173", + "http://localhost:3000", + "http://127.0.0.1:5173", + "http://127.0.0.1:3000", + ]; + + if (origin.startsWith("https://")) { + return callback(null, true); + } + + if (origin.startsWith("http://")) { + return callback(null, true); + } + + if (allowedOrigins.includes(origin)) { + return callback(null, true); + } + + callback(new Error("Not allowed by CORS")); + }, + credentials: true, methods: ["GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"], allowedHeaders: [ "Content-Type", @@ -25,6 +78,33 @@ app.use( }), ); +const storage = multer.diskStorage({ + destination: (req, file, cb) => { + cb(null, "uploads/"); + }, + filename: (req, file, cb) => { + const timestamp = Date.now(); + cb(null, `${timestamp}-${file.originalname}`); + }, +}); + +const upload = multer({ + storage: storage, + limits: { + fileSize: 1024 * 1024 * 1024, + }, + fileFilter: (req, file, cb) => { + if ( + file.originalname.endsWith(".termix-export.sqlite") || + file.originalname.endsWith(".sqlite") + ) { + cb(null, true); + } else { + cb(new Error("Only .termix-export.sqlite files are allowed")); + } + }, +}); + interface CacheEntry { data: any; timestamp: number; @@ -127,24 +207,59 @@ async function fetchGitHubAPI( } } -app.use(bodyParser.json()); +app.use(bodyParser.json({ limit: "1gb" })); +app.use(bodyParser.urlencoded({ limit: "1gb", extended: true })); +app.use(bodyParser.raw({ limit: "5gb", type: "application/octet-stream" })); +app.use(cookieParser()); app.get("/health", (req, res) => { res.json({ status: "ok" }); }); -app.get("/version", async (req, res) => { +app.get("/version", authenticateJWT, async (req, res) => { let localVersion = process.env.VERSION; if (!localVersion) { - try { - const packagePath = path.resolve(process.cwd(), "package.json"); - const packageJson = JSON.parse(fs.readFileSync(packagePath, "utf8")); - localVersion = packageJson.version; - } catch (error) { - databaseLogger.error("Failed to read version from package.json", error, { - operation: "version_check", - }); + const versionSources = [ + () => { + try { + const packagePath = path.resolve(process.cwd(), "package.json"); + const packageJson = JSON.parse(fs.readFileSync(packagePath, "utf8")); + return packageJson.version; + } catch { + return null; + } + }, + () => { + try { + const packagePath = path.resolve("/app", "package.json"); + const packageJson = JSON.parse(fs.readFileSync(packagePath, "utf8")); + return packageJson.version; + } catch { + return null; + } + }, + () => { + try { + const packagePath = path.resolve(__dirname, "../../../package.json"); + const packageJson = JSON.parse(fs.readFileSync(packagePath, "utf8")); + return packageJson.version; + } catch { + return null; + } + }, + ]; + + for (const getVersion of versionSources) { + try { + const foundVersion = getVersion(); + if (foundVersion && foundVersion !== "unknown") { + localVersion = foundVersion; + break; + } + } catch (error) { + continue; + } } } @@ -199,7 +314,7 @@ app.get("/version", async (req, res) => { } }); -app.get("/releases/rss", async (req, res) => { +app.get("/releases/rss", authenticateJWT, async (req, res) => { try { const page = parseInt(req.query.page as string) || 1; const per_page = Math.min( @@ -255,6 +370,1043 @@ app.get("/releases/rss", async (req, res) => { } }); +app.get("/encryption/status", requireAdmin, async (req, res) => { + try { + const authManager = AuthManager.getInstance(); + const securityStatus = { + initialized: true, + system: { hasSecret: true, isValid: true }, + activeSessions: {}, + activeSessionCount: 0, + }; + + res.json({ + security: securityStatus, + version: "v2-kek-dek", + }); + } catch (error) { + apiLogger.error("Failed to get security status", error, { + operation: "security_status", + }); + res.status(500).json({ error: "Failed to get security status" }); + } +}); + +app.post("/encryption/initialize", requireAdmin, async (req, res) => { + try { + const authManager = AuthManager.getInstance(); + + const isValid = true; + if (!isValid) { + await authManager.initialize(); + } + + res.json({ + success: true, + message: "Security system initialized successfully", + version: "v2-kek-dek", + note: "User data encryption will be set up when users log in", + }); + } catch (error) { + apiLogger.error("Failed to initialize security system", error, { + operation: "security_init_api_failed", + }); + res.status(500).json({ error: "Failed to initialize security system" }); + } +}); + +app.post("/encryption/regenerate", requireAdmin, async (req, res) => { + try { + const authManager = AuthManager.getInstance(); + + apiLogger.warn("System JWT secret regenerated via API", { + operation: "jwt_regenerate_api", + }); + + res.json({ + success: true, + message: "System JWT secret regenerated", + warning: + "All existing JWT tokens are now invalid - users must re-authenticate", + note: "User data encryption keys are protected by passwords and cannot be regenerated", + }); + } catch (error) { + apiLogger.error("Failed to regenerate JWT secret", error, { + operation: "jwt_regenerate_failed", + }); + res.status(500).json({ error: "Failed to regenerate JWT secret" }); + } +}); + +app.post("/encryption/regenerate-jwt", requireAdmin, async (req, res) => { + try { + const authManager = AuthManager.getInstance(); + + apiLogger.warn("JWT secret regenerated via API", { + operation: "jwt_secret_regenerate_api", + }); + + res.json({ + success: true, + message: "New JWT secret generated", + warning: + "All existing JWT tokens are now invalid - users must re-authenticate", + }); + } catch (error) { + apiLogger.error("Failed to regenerate JWT secret", error, { + operation: "jwt_secret_regenerate_failed", + }); + res.status(500).json({ error: "Failed to regenerate JWT secret" }); + } +}); + +app.post("/database/export", authenticateJWT, async (req, res) => { + try { + const userId = (req as any).userId; + const { password } = req.body; + + if (!password) { + return res.status(400).json({ + error: "Password required for export", + code: "PASSWORD_REQUIRED", + }); + } + + const unlocked = await authManager.authenticateUser(userId, password); + if (!unlocked) { + return res.status(401).json({ error: "Invalid password" }); + } + + apiLogger.info("Exporting user data as SQLite", { + operation: "user_data_sqlite_export_api", + userId, + }); + + const userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + throw new Error("User data not unlocked"); + } + + const user = await getDb().select().from(users).where(eq(users.id, userId)); + if (!user || user.length === 0) { + throw new Error(`User not found: ${userId}`); + } + + const tempDir = + process.env.NODE_ENV === "production" + ? path.join(process.env.DATA_DIR || "./db/data", ".temp", "exports") + : path.join(os.tmpdir(), "termix-exports"); + + try { + if (!fs.existsSync(tempDir)) { + fs.mkdirSync(tempDir, { recursive: true }); + } + } catch (dirError) { + apiLogger.error("Failed to create temp directory", dirError, { + operation: "export_temp_dir_error", + tempDir, + }); + throw new Error(`Failed to create temp directory: ${dirError.message}`); + } + + const timestamp = new Date().toISOString().replace(/[:.]/g, "-"); + const filename = `termix-export-${user[0].username}-${timestamp}.sqlite`; + const tempPath = path.join(tempDir, filename); + + apiLogger.info("Creating export database", { + operation: "export_db_creation", + userId, + tempPath, + }); + + const exportDb = new Database(tempPath); + + try { + exportDb.exec(` + CREATE TABLE users ( + id TEXT PRIMARY KEY, + username TEXT NOT NULL, + password_hash TEXT NOT NULL, + is_admin INTEGER NOT NULL DEFAULT 0, + is_oidc INTEGER NOT NULL DEFAULT 0, + oidc_identifier TEXT, + client_id TEXT, + client_secret TEXT, + issuer_url TEXT, + authorization_url TEXT, + token_url TEXT, + identifier_path TEXT, + name_path TEXT, + scopes TEXT DEFAULT 'openid email profile', + totp_secret TEXT, + totp_enabled INTEGER NOT NULL DEFAULT 0, + totp_backup_codes TEXT + ); + + CREATE TABLE settings ( + key TEXT PRIMARY KEY, + value TEXT NOT NULL + ); + + CREATE TABLE ssh_data ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + name TEXT, + ip TEXT NOT NULL, + port INTEGER NOT NULL, + username TEXT NOT NULL, + folder TEXT, + tags TEXT, + pin INTEGER NOT NULL DEFAULT 0, + auth_type TEXT NOT NULL, + password TEXT, + key TEXT, + key_password TEXT, + key_type TEXT, + autostart_password TEXT, + autostart_key TEXT, + autostart_key_password TEXT, + credential_id INTEGER, + enable_terminal INTEGER NOT NULL DEFAULT 1, + enable_tunnel INTEGER NOT NULL DEFAULT 1, + tunnel_connections TEXT, + enable_file_manager INTEGER NOT NULL DEFAULT 1, + default_path TEXT, + created_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP, + updated_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE ssh_credentials ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + name TEXT NOT NULL, + description TEXT, + folder TEXT, + tags TEXT, + auth_type TEXT NOT NULL, + username TEXT NOT NULL, + password TEXT, + key TEXT, + private_key TEXT, + public_key TEXT, + key_password TEXT, + key_type TEXT, + detected_key_type TEXT, + usage_count INTEGER NOT NULL DEFAULT 0, + last_used TEXT, + created_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP, + updated_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE file_manager_recent ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + host_id INTEGER NOT NULL, + name TEXT NOT NULL, + path TEXT NOT NULL, + last_opened TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE file_manager_pinned ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + host_id INTEGER NOT NULL, + name TEXT NOT NULL, + path TEXT NOT NULL, + pinned_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE file_manager_shortcuts ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + host_id INTEGER NOT NULL, + name TEXT NOT NULL, + path TEXT NOT NULL, + created_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE dismissed_alerts ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + user_id TEXT NOT NULL, + alert_id TEXT NOT NULL, + dismissed_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + + CREATE TABLE ssh_credential_usage ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + credential_id INTEGER NOT NULL, + host_id INTEGER NOT NULL, + user_id TEXT NOT NULL, + used_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP + ); + `); + + const userRecord = user[0]; + const insertUser = exportDb.prepare(` + INSERT INTO users (id, username, password_hash, is_admin, is_oidc, oidc_identifier, client_id, client_secret, issuer_url, authorization_url, token_url, identifier_path, name_path, scopes, totp_secret, totp_enabled, totp_backup_codes) + VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) + `); + insertUser.run( + userRecord.id, + userRecord.username, + "[EXPORTED_USER_NO_PASSWORD]", + userRecord.is_admin ? 1 : 0, + userRecord.is_oidc ? 1 : 0, + userRecord.oidc_identifier || null, + userRecord.client_id || null, + userRecord.client_secret || null, + userRecord.issuer_url || null, + userRecord.authorization_url || null, + userRecord.token_url || null, + userRecord.identifier_path || null, + userRecord.name_path || null, + userRecord.scopes || null, + userRecord.totp_secret || null, + userRecord.totp_enabled ? 1 : 0, + userRecord.totp_backup_codes || null, + ); + + const sshHosts = await getDb() + .select() + .from(sshData) + .where(eq(sshData.userId, userId)); + const insertHost = exportDb.prepare(` + INSERT INTO ssh_data (id, user_id, name, ip, port, username, folder, tags, pin, auth_type, password, key, key_password, key_type, autostart_password, autostart_key, autostart_key_password, credential_id, enable_terminal, enable_tunnel, tunnel_connections, enable_file_manager, default_path, created_at, updated_at) + VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) + `); + + for (const host of sshHosts) { + const decrypted = DataCrypto.decryptRecord( + "ssh_data", + host, + userId, + userDataKey, + ); + insertHost.run( + decrypted.id, + decrypted.userId, + decrypted.name || null, + decrypted.ip, + decrypted.port, + decrypted.username, + decrypted.folder || null, + decrypted.tags || null, + decrypted.pin ? 1 : 0, + decrypted.authType, + decrypted.password || null, + decrypted.key || null, + decrypted.keyPassword || null, + decrypted.keyType || null, + decrypted.autostartPassword || null, + decrypted.autostartKey || null, + decrypted.autostartKeyPassword || null, + decrypted.credentialId || null, + decrypted.enableTerminal ? 1 : 0, + decrypted.enableTunnel ? 1 : 0, + decrypted.tunnelConnections || null, + decrypted.enableFileManager ? 1 : 0, + decrypted.defaultPath || null, + decrypted.createdAt, + decrypted.updatedAt, + ); + } + + const credentials = await getDb() + .select() + .from(sshCredentials) + .where(eq(sshCredentials.userId, userId)); + const insertCred = exportDb.prepare(` + INSERT INTO ssh_credentials (id, user_id, name, description, folder, tags, auth_type, username, password, key, private_key, public_key, key_password, key_type, detected_key_type, usage_count, last_used, created_at, updated_at) + VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) + `); + + for (const cred of credentials) { + const decrypted = DataCrypto.decryptRecord( + "ssh_credentials", + cred, + userId, + userDataKey, + ); + insertCred.run( + decrypted.id, + decrypted.userId, + decrypted.name, + decrypted.description || null, + decrypted.folder || null, + decrypted.tags || null, + decrypted.authType, + decrypted.username, + decrypted.password || null, + decrypted.key || null, + decrypted.privateKey || null, + decrypted.publicKey || null, + decrypted.keyPassword || null, + decrypted.keyType || null, + decrypted.detectedKeyType || null, + decrypted.usageCount || 0, + decrypted.lastUsed || null, + decrypted.createdAt, + decrypted.updatedAt, + ); + } + + const [recentFiles, pinnedFiles, shortcuts] = await Promise.all([ + getDb() + .select() + .from(fileManagerRecent) + .where(eq(fileManagerRecent.userId, userId)), + getDb() + .select() + .from(fileManagerPinned) + .where(eq(fileManagerPinned.userId, userId)), + getDb() + .select() + .from(fileManagerShortcuts) + .where(eq(fileManagerShortcuts.userId, userId)), + ]); + + const insertRecent = exportDb.prepare(` + INSERT INTO file_manager_recent (id, user_id, host_id, name, path, last_opened) + VALUES (?, ?, ?, ?, ?, ?) + `); + for (const item of recentFiles) { + insertRecent.run( + item.id, + item.userId, + item.hostId, + item.name, + item.path, + item.lastOpened, + ); + } + + const insertPinned = exportDb.prepare(` + INSERT INTO file_manager_pinned (id, user_id, host_id, name, path, pinned_at) + VALUES (?, ?, ?, ?, ?, ?) + `); + for (const item of pinnedFiles) { + insertPinned.run( + item.id, + item.userId, + item.hostId, + item.name, + item.path, + item.pinnedAt, + ); + } + + const insertShortcut = exportDb.prepare(` + INSERT INTO file_manager_shortcuts (id, user_id, host_id, name, path, created_at) + VALUES (?, ?, ?, ?, ?, ?) + `); + for (const item of shortcuts) { + insertShortcut.run( + item.id, + item.userId, + item.hostId, + item.name, + item.path, + item.createdAt, + ); + } + + const alerts = await getDb() + .select() + .from(dismissedAlerts) + .where(eq(dismissedAlerts.userId, userId)); + const insertAlert = exportDb.prepare(` + INSERT INTO dismissed_alerts (id, user_id, alert_id, dismissed_at) + VALUES (?, ?, ?, ?) + `); + for (const alert of alerts) { + insertAlert.run( + alert.id, + alert.userId, + alert.alertId, + alert.dismissedAt, + ); + } + + const usage = await getDb() + .select() + .from(sshCredentialUsage) + .where(eq(sshCredentialUsage.userId, userId)); + const insertUsage = exportDb.prepare(` + INSERT INTO ssh_credential_usage (id, credential_id, host_id, user_id, used_at) + VALUES (?, ?, ?, ?, ?) + `); + for (const item of usage) { + insertUsage.run( + item.id, + item.credentialId, + item.hostId, + item.userId, + item.usedAt, + ); + } + + const settingsData = await getDb().select().from(settings); + const insertSetting = exportDb.prepare(` + INSERT INTO settings (key, value) + VALUES (?, ?) + `); + for (const setting of settingsData) { + insertSetting.run(setting.key, setting.value); + } + } finally { + exportDb.close(); + } + + res.setHeader("Content-Type", "application/x-sqlite3"); + res.setHeader("Content-Disposition", `attachment; filename="${filename}"`); + + const fileStream = fs.createReadStream(tempPath); + + fileStream.on("error", (streamError) => { + apiLogger.error("File stream error during export", streamError, { + operation: "export_file_stream_error", + userId, + tempPath, + }); + if (!res.headersSent) { + res.status(500).json({ + error: "Failed to stream export file", + details: streamError.message, + }); + } + }); + + fileStream.on("end", () => { + apiLogger.success("User data exported as SQLite successfully", { + operation: "user_data_sqlite_export_success", + userId, + filename, + }); + + fs.unlink(tempPath, (err) => { + if (err) { + apiLogger.warn("Failed to clean up export file", { + operation: "export_cleanup_failed", + path: tempPath, + error: err.message, + }); + } + }); + }); + + fileStream.pipe(res); + } catch (error) { + apiLogger.error("User data SQLite export failed", error, { + operation: "user_data_sqlite_export_failed", + }); + res.status(500).json({ + error: "Failed to export user data", + details: error instanceof Error ? error.message : "Unknown error", + }); + } +}); + +app.post( + "/database/import", + authenticateJWT, + upload.single("file"), + async (req, res) => { + try { + if (!req.file) { + return res.status(400).json({ error: "No file uploaded" }); + } + + const userId = (req as any).userId; + const { password } = req.body; + + if (!password) { + return res.status(400).json({ + error: "Password required for import", + code: "PASSWORD_REQUIRED", + }); + } + + const unlocked = await authManager.authenticateUser(userId, password); + if (!unlocked) { + return res.status(401).json({ error: "Invalid password" }); + } + + apiLogger.info("Importing SQLite data", { + operation: "sqlite_import_api", + userId, + filename: req.file.originalname, + fileSize: req.file.size, + mimetype: req.file.mimetype, + }); + + const userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + throw new Error("User data not unlocked"); + } + + if (!fs.existsSync(req.file.path)) { + return res.status(400).json({ + error: "Uploaded file not found", + details: "File was not properly uploaded", + }); + } + + const fileHeader = Buffer.alloc(16); + const fd = fs.openSync(req.file.path, "r"); + fs.readSync(fd, fileHeader, 0, 16, 0); + fs.closeSync(fd); + + const sqliteHeader = "SQLite format 3"; + if (fileHeader.toString("utf8", 0, 15) !== sqliteHeader) { + return res.status(400).json({ + error: "Invalid file format - not a SQLite database", + details: `Expected SQLite file, got file starting with: ${fileHeader.toString("utf8", 0, 15)}`, + }); + } + + let importDb; + try { + importDb = new Database(req.file.path, { readonly: true }); + + const tables = importDb + .prepare("SELECT name FROM sqlite_master WHERE type='table'") + .all(); + } catch (sqliteError) { + return res.status(400).json({ + error: "Failed to open SQLite database", + details: sqliteError.message, + }); + } + + const result = { + success: false, + summary: { + sshHostsImported: 0, + sshCredentialsImported: 0, + fileManagerItemsImported: 0, + dismissedAlertsImported: 0, + credentialUsageImported: 0, + settingsImported: 0, + skippedItems: 0, + errors: [], + }, + }; + + try { + const mainDb = getDb(); + + try { + const importedHosts = importDb + .prepare("SELECT * FROM ssh_data") + .all(); + for (const host of importedHosts) { + try { + const existing = await mainDb + .select() + .from(sshData) + .where( + and( + eq(sshData.userId, userId), + eq(sshData.ip, host.ip), + eq(sshData.port, host.port), + eq(sshData.username, host.username), + ), + ); + + if (existing.length > 0) { + result.summary.skippedItems++; + continue; + } + + const hostData = { + userId: userId, + name: host.name, + ip: host.ip, + port: host.port, + username: host.username, + folder: host.folder, + tags: host.tags, + pin: Boolean(host.pin), + authType: host.auth_type, + password: host.password, + key: host.key, + keyPassword: host.key_password, + keyType: host.key_type, + autostartPassword: host.autostart_password, + autostartKey: host.autostart_key, + autostartKeyPassword: host.autostart_key_password, + credentialId: null, + enableTerminal: Boolean(host.enable_terminal), + enableTunnel: Boolean(host.enable_tunnel), + tunnelConnections: host.tunnel_connections, + enableFileManager: Boolean(host.enable_file_manager), + defaultPath: host.default_path, + createdAt: host.created_at || new Date().toISOString(), + updatedAt: new Date().toISOString(), + }; + + const encrypted = DataCrypto.encryptRecord( + "ssh_data", + hostData, + userId, + userDataKey, + ); + await mainDb.insert(sshData).values(encrypted); + result.summary.sshHostsImported++; + } catch (hostError) { + result.summary.errors.push( + `SSH host import error: ${hostError.message}`, + ); + } + } + } catch (tableError) { + apiLogger.info("ssh_data table not found in import file, skipping"); + } + + try { + const importedCreds = importDb + .prepare("SELECT * FROM ssh_credentials") + .all(); + for (const cred of importedCreds) { + try { + const existing = await mainDb + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.userId, userId), + eq(sshCredentials.name, cred.name), + eq(sshCredentials.username, cred.username), + ), + ); + + if (existing.length > 0) { + result.summary.skippedItems++; + continue; + } + + const credData = { + userId: userId, + name: cred.name, + description: cred.description, + folder: cred.folder, + tags: cred.tags, + authType: cred.auth_type, + username: cred.username, + password: cred.password, + key: cred.key, + privateKey: cred.private_key, + publicKey: cred.public_key, + keyPassword: cred.key_password, + keyType: cred.key_type, + detectedKeyType: cred.detected_key_type, + usageCount: cred.usage_count || 0, + lastUsed: cred.last_used, + createdAt: cred.created_at || new Date().toISOString(), + updatedAt: new Date().toISOString(), + }; + + const encrypted = DataCrypto.encryptRecord( + "ssh_credentials", + credData, + userId, + userDataKey, + ); + await mainDb.insert(sshCredentials).values(encrypted); + result.summary.sshCredentialsImported++; + } catch (credError) { + result.summary.errors.push( + `SSH credential import error: ${credError.message}`, + ); + } + } + } catch (tableError) { + apiLogger.info( + "ssh_credentials table not found in import file, skipping", + ); + } + + const fileManagerTables = [ + { + table: "file_manager_recent", + schema: fileManagerRecent, + key: "fileManagerItemsImported", + }, + { + table: "file_manager_pinned", + schema: fileManagerPinned, + key: "fileManagerItemsImported", + }, + { + table: "file_manager_shortcuts", + schema: fileManagerShortcuts, + key: "fileManagerItemsImported", + }, + ]; + + for (const { table, schema, key } of fileManagerTables) { + try { + const importedItems = importDb + .prepare(`SELECT * FROM ${table}`) + .all(); + for (const item of importedItems) { + try { + const existing = await mainDb + .select() + .from(schema) + .where( + and( + eq(schema.userId, userId), + eq(schema.path, item.path), + eq(schema.name, item.name), + ), + ); + + if (existing.length > 0) { + result.summary.skippedItems++; + continue; + } + + const itemData = { + userId: userId, + hostId: item.host_id, + name: item.name, + path: item.path, + ...(table === "file_manager_recent" && { + lastOpened: item.last_opened, + }), + ...(table === "file_manager_pinned" && { + pinnedAt: item.pinned_at, + }), + ...(table === "file_manager_shortcuts" && { + createdAt: item.created_at, + }), + }; + + await mainDb.insert(schema).values(itemData); + result.summary[key]++; + } catch (itemError) { + result.summary.errors.push( + `${table} import error: ${itemError.message}`, + ); + } + } + } catch (tableError) { + apiLogger.info(`${table} table not found in import file, skipping`); + } + } + + try { + const importedAlerts = importDb + .prepare("SELECT * FROM dismissed_alerts") + .all(); + for (const alert of importedAlerts) { + try { + const existing = await mainDb + .select() + .from(dismissedAlerts) + .where( + and( + eq(dismissedAlerts.userId, userId), + eq(dismissedAlerts.alertId, alert.alert_id), + ), + ); + + if (existing.length > 0) { + result.summary.skippedItems++; + continue; + } + + await mainDb.insert(dismissedAlerts).values({ + userId: userId, + alertId: alert.alert_id, + dismissedAt: alert.dismissed_at || new Date().toISOString(), + }); + result.summary.dismissedAlertsImported++; + } catch (alertError) { + result.summary.errors.push( + `Dismissed alert import error: ${alertError.message}`, + ); + } + } + } catch (tableError) { + apiLogger.info( + "dismissed_alerts table not found in import file, skipping", + ); + } + + const targetUser = await mainDb + .select() + .from(users) + .where(eq(users.id, userId)); + if (targetUser.length > 0 && targetUser[0].is_admin) { + try { + const importedSettings = importDb + .prepare("SELECT * FROM settings") + .all(); + for (const setting of importedSettings) { + try { + const existing = await mainDb + .select() + .from(settings) + .where(eq(settings.key, setting.key)); + + if (existing.length > 0) { + await mainDb + .update(settings) + .set({ value: setting.value }) + .where(eq(settings.key, setting.key)); + result.summary.settingsImported++; + } else { + await mainDb.insert(settings).values({ + key: setting.key, + value: setting.value, + }); + result.summary.settingsImported++; + } + } catch (settingError) { + result.summary.errors.push( + `Setting import error (${setting.key}): ${settingError.message}`, + ); + } + } + } catch (tableError) { + apiLogger.info("settings table not found in import file, skipping"); + } + } else { + apiLogger.info( + "Settings import skipped - only admin users can import settings", + ); + } + + result.success = true; + } finally { + if (importDb) { + importDb.close(); + } + } + + try { + fs.unlinkSync(req.file.path); + } catch (cleanupError) { + apiLogger.warn("Failed to clean up uploaded file", { + operation: "file_cleanup_warning", + filePath: req.file.path, + }); + } + + res.json({ + success: result.success, + message: result.success + ? "Incremental import completed successfully" + : "Import failed", + summary: result.summary, + }); + + if (result.success) { + apiLogger.success("SQLite data imported successfully", { + operation: "sqlite_import_api_success", + userId, + summary: result.summary, + }); + } + } catch (error) { + if (req.file?.path && fs.existsSync(req.file.path)) { + try { + fs.unlinkSync(req.file.path); + } catch (cleanupError) { + apiLogger.warn("Failed to clean up uploaded file after error", { + operation: "file_cleanup_error", + filePath: req.file.path, + }); + } + } + + apiLogger.error("SQLite import failed", error, { + operation: "sqlite_import_api_failed", + userId: (req as any).userId, + }); + res.status(500).json({ + error: "Failed to import SQLite data", + details: error instanceof Error ? error.message : "Unknown error", + }); + } + }, +); + +app.post("/database/export/preview", authenticateJWT, async (req, res) => { + try { + const userId = (req as any).userId; + const { + format = "encrypted", + scope = "user_data", + includeCredentials = true, + } = req.body; + + const exportData = await UserDataExport.exportUserData(userId, { + format: "encrypted", + scope, + includeCredentials, + }); + + const stats = UserDataExport.getExportStats(exportData); + + res.json({ + preview: true, + stats, + estimatedSize: JSON.stringify(exportData).length, + }); + + apiLogger.success("Export preview generated", { + operation: "export_preview_api_success", + userId, + totalRecords: stats.totalRecords, + }); + } catch (error) { + apiLogger.error("Export preview failed", error, { + operation: "export_preview_api_failed", + }); + res.status(500).json({ + error: "Failed to generate export preview", + details: error instanceof Error ? error.message : "Unknown error", + }); + } +}); + +app.post("/database/restore", requireAdmin, async (req, res) => { + try { + const { backupPath, targetPath } = req.body; + + if (!backupPath) { + return res.status(400).json({ error: "Backup path is required" }); + } + + if (!DatabaseFileEncryption.isEncryptedDatabaseFile(backupPath)) { + return res.status(400).json({ error: "Invalid encrypted backup file" }); + } + + const restoredPath = + await DatabaseFileEncryption.restoreFromEncryptedBackup( + backupPath, + targetPath, + ); + + res.json({ + success: true, + message: "Database restored successfully", + restoredPath, + }); + } catch (error) { + apiLogger.error("Database restore failed", error, { + operation: "database_restore_api_failed", + }); + res.status(500).json({ + error: "Database restore failed", + details: error instanceof Error ? error.message : "Unknown error", + }); + } +}); + app.use("/users", userRoutes); app.use("/ssh", sshRoutes); app.use("/alerts", alertRoutes); @@ -277,19 +1429,166 @@ app.use( }, ); -const PORT = 8081; -app.listen(PORT, () => { - databaseLogger.success(`Database API server started on port ${PORT}`, { - operation: "server_start", - port: PORT, - routes: [ - "/users", - "/ssh", - "/alerts", - "/credentials", - "/health", - "/version", - "/releases/rss", - ], - }); +const HTTP_PORT = 30001; +const HTTPS_PORT = process.env.SSL_PORT || 8443; + +async function initializeSecurity() { + try { + const authManager = AuthManager.getInstance(); + await authManager.initialize(); + + DataCrypto.initialize(); + + const isValid = true; + if (!isValid) { + throw new Error("Security system validation failed"); + } + + const securityStatus = { + initialized: true, + system: { hasSecret: true, isValid: true }, + activeSessions: {}, + activeSessionCount: 0, + }; + } catch (error) { + databaseLogger.error("Failed to initialize security system", error, { + operation: "security_init_error", + }); + throw error; + } +} + +app.get( + "/database/migration/status", + authenticateJWT, + requireAdmin, + async (req, res) => { + try { + const dataDir = process.env.DATA_DIR || "./db/data"; + const migration = new DatabaseMigration(dataDir); + const status = migration.checkMigrationStatus(); + + const dbPath = path.join(dataDir, "db.sqlite"); + const encryptedDbPath = `${dbPath}.encrypted`; + + const files = fs.readdirSync(dataDir); + const backupFiles = files.filter((f) => f.includes(".migration-backup-")); + const migratedFiles = files.filter((f) => f.includes(".migrated-")); + + let unencryptedSize = 0; + let encryptedSize = 0; + + if (status.hasUnencryptedDb) { + try { + unencryptedSize = fs.statSync(dbPath).size; + } catch (error) {} + } + + if (status.hasEncryptedDb) { + try { + encryptedSize = fs.statSync(encryptedDbPath).size; + } catch (error) {} + } + + res.json({ + migrationStatus: status, + files: { + unencryptedDbSize: unencryptedSize, + encryptedDbSize: encryptedSize, + backupFiles: backupFiles.length, + migratedFiles: migratedFiles.length, + }, + }); + } catch (error) { + apiLogger.error("Failed to get migration status", error, { + operation: "migration_status_api_failed", + }); + res.status(500).json({ + error: "Failed to get migration status", + details: error instanceof Error ? error.message : "Unknown error", + }); + } + }, +); + +app.get( + "/database/migration/history", + authenticateJWT, + requireAdmin, + async (req, res) => { + try { + const dataDir = process.env.DATA_DIR || "./db/data"; + + const files = fs.readdirSync(dataDir); + + const backupFiles = files + .filter((f) => f.includes(".migration-backup-")) + .map((f) => { + const filePath = path.join(dataDir, f); + const stats = fs.statSync(filePath); + return { + name: f, + size: stats.size, + created: stats.birthtime, + modified: stats.mtime, + type: "backup", + }; + }) + .sort((a, b) => b.modified.getTime() - a.modified.getTime()); + + const migratedFiles = files + .filter((f) => f.includes(".migrated-")) + .map((f) => { + const filePath = path.join(dataDir, f); + const stats = fs.statSync(filePath); + return { + name: f, + size: stats.size, + created: stats.birthtime, + modified: stats.mtime, + type: "migrated", + }; + }) + .sort((a, b) => b.modified.getTime() - a.modified.getTime()); + + res.json({ + files: [...backupFiles, ...migratedFiles], + summary: { + totalBackups: backupFiles.length, + totalMigrated: migratedFiles.length, + oldestBackup: + backupFiles.length > 0 + ? backupFiles[backupFiles.length - 1].created + : null, + newestBackup: backupFiles.length > 0 ? backupFiles[0].created : null, + }, + }); + } catch (error) { + apiLogger.error("Failed to get migration history", error, { + operation: "migration_history_api_failed", + }); + res.status(500).json({ + error: "Failed to get migration history", + details: error instanceof Error ? error.message : "Unknown error", + }); + } + }, +); + +app.listen(HTTP_PORT, async () => { + const uploadsDir = path.join(process.cwd(), "uploads"); + if (!fs.existsSync(uploadsDir)) { + fs.mkdirSync(uploadsDir, { recursive: true }); + } + + await initializeSecurity(); }); + +const sslConfig = AutoSSLSetup.getSSLConfig(); +if (sslConfig.enabled) { + databaseLogger.info(`SSL is enabled`, { + operation: "ssl_info", + nginx_https_port: sslConfig.port, + backend_http_port: HTTP_PORT, + }); +} diff --git a/src/backend/database/db/index.ts b/src/backend/database/db/index.ts index 1dd17218..88cca125 100644 --- a/src/backend/database/db/index.ts +++ b/src/backend/database/db/index.ts @@ -4,6 +4,10 @@ import * as schema from "./schema.js"; import fs from "fs"; import path from "path"; import { databaseLogger } from "../../utils/logger.js"; +import { DatabaseFileEncryption } from "../../utils/database-file-encryption.js"; +import { SystemCrypto } from "../../utils/system-crypto.js"; +import { DatabaseMigration } from "../../utils/database-migration.js"; +import { DatabaseSaveTrigger } from "../../utils/database-save-trigger.js"; const dataDir = process.env.DATA_DIR || "./db/data"; const dbDir = path.resolve(dataDir); @@ -15,29 +19,125 @@ if (!fs.existsSync(dbDir)) { fs.mkdirSync(dbDir, { recursive: true }); } +const enableFileEncryption = process.env.DB_FILE_ENCRYPTION !== "false"; const dbPath = path.join(dataDir, "db.sqlite"); -databaseLogger.info(`Initializing SQLite database`, { - operation: "db_init", - path: dbPath, -}); -const sqlite = new Database(dbPath); +const encryptedDbPath = `${dbPath}.encrypted`; -sqlite.exec(` +let actualDbPath = ":memory:"; +let memoryDatabase: Database.Database; +let isNewDatabase = false; +let sqlite: Database.Database; + +async function initializeDatabaseAsync(): Promise { + const systemCrypto = SystemCrypto.getInstance(); + + const dbKey = await systemCrypto.getDatabaseKey(); + if (enableFileEncryption) { + try { + if (DatabaseFileEncryption.isEncryptedDatabaseFile(encryptedDbPath)) { + const decryptedBuffer = + await DatabaseFileEncryption.decryptDatabaseToBuffer(encryptedDbPath); + + memoryDatabase = new Database(decryptedBuffer); + } else { + const migration = new DatabaseMigration(dataDir); + const migrationStatus = migration.checkMigrationStatus(); + + if (migrationStatus.needsMigration) { + const migrationResult = await migration.migrateDatabase(); + + if (migrationResult.success) { + migration.cleanupOldBackups(); + + if ( + DatabaseFileEncryption.isEncryptedDatabaseFile(encryptedDbPath) + ) { + const decryptedBuffer = + await DatabaseFileEncryption.decryptDatabaseToBuffer( + encryptedDbPath, + ); + memoryDatabase = new Database(decryptedBuffer); + isNewDatabase = false; + } else { + throw new Error( + "Migration completed but encrypted database file not found", + ); + } + } else { + databaseLogger.error("Automatic database migration failed", null, { + operation: "auto_migration_failed", + error: migrationResult.error, + migratedTables: migrationResult.migratedTables, + migratedRows: migrationResult.migratedRows, + duration: migrationResult.duration, + backupPath: migrationResult.backupPath, + }); + throw new Error( + `Database migration failed: ${migrationResult.error}. Backup available at: ${migrationResult.backupPath}`, + ); + } + } else { + memoryDatabase = new Database(":memory:"); + isNewDatabase = true; + } + } + } catch (error) { + databaseLogger.error("Failed to initialize memory database", error, { + operation: "db_memory_init_failed", + errorMessage: error instanceof Error ? error.message : "Unknown error", + errorStack: error instanceof Error ? error.stack : undefined, + encryptedDbExists: + DatabaseFileEncryption.isEncryptedDatabaseFile(encryptedDbPath), + databaseKeyAvailable: !!process.env.DATABASE_KEY, + databaseKeyLength: process.env.DATABASE_KEY?.length || 0, + }); + + throw new Error( + `Database decryption failed: ${error instanceof Error ? error.message : "Unknown error"}. This prevents data loss.`, + ); + } + } else { + memoryDatabase = new Database(":memory:"); + isNewDatabase = true; + } +} + +async function initializeCompleteDatabase(): Promise { + await initializeDatabaseAsync(); + + databaseLogger.info(`Initializing SQLite database`, { + operation: "db_init", + path: actualDbPath, + encrypted: + enableFileEncryption && + DatabaseFileEncryption.isEncryptedDatabaseFile(encryptedDbPath), + inMemory: true, + isNewDatabase, + }); + + sqlite = memoryDatabase; + + db = drizzle(sqlite, { schema }); + + sqlite.exec(` CREATE TABLE IF NOT EXISTS users ( id TEXT PRIMARY KEY, username TEXT NOT NULL, password_hash TEXT NOT NULL, is_admin INTEGER NOT NULL DEFAULT 0, is_oidc INTEGER NOT NULL DEFAULT 0, - client_id TEXT NOT NULL, - client_secret TEXT NOT NULL, - issuer_url TEXT NOT NULL, - authorization_url TEXT NOT NULL, - token_url TEXT NOT NULL, - redirect_uri TEXT, - identifier_path TEXT NOT NULL, - name_path TEXT NOT NULL, - scopes TEXT NOT NULL + oidc_identifier TEXT, + client_id TEXT, + client_secret TEXT, + issuer_url TEXT, + authorization_url TEXT, + token_url TEXT, + identifier_path TEXT, + name_path TEXT, + scopes TEXT DEFAULT 'openid email profile', + totp_secret TEXT, + totp_enabled INTEGER NOT NULL DEFAULT 0, + totp_backup_codes TEXT ); CREATE TABLE IF NOT EXISTS settings ( @@ -141,8 +241,30 @@ sqlite.exec(` FOREIGN KEY (host_id) REFERENCES ssh_data (id), FOREIGN KEY (user_id) REFERENCES users (id) ); + `); + migrateSchema(); + + try { + const row = sqlite + .prepare("SELECT value FROM settings WHERE key = 'allow_registration'") + .get(); + if (!row) { + sqlite + .prepare( + "INSERT INTO settings (key, value) VALUES ('allow_registration', 'true')", + ) + .run(); + } + } catch (e) { + databaseLogger.warn("Could not initialize default settings", { + operation: "db_init", + error: e, + }); + } +} + const addColumnIfNotExists = ( table: string, column: string, @@ -157,18 +279,8 @@ const addColumnIfNotExists = ( .get(); } catch (e) { try { - databaseLogger.debug(`Adding column ${column} to ${table}`, { - operation: "schema_migration", - table, - column, - }); sqlite.exec(`ALTER TABLE ${table} ADD COLUMN ${column} ${definition};`); - databaseLogger.success(`Column ${column} added to ${table}`, { - operation: "schema_migration", - table, - column, - }); } catch (alterError) { databaseLogger.warn(`Failed to add column ${column} to ${table}`, { operation: "schema_migration", @@ -181,10 +293,6 @@ const addColumnIfNotExists = ( }; const migrateSchema = () => { - databaseLogger.info("Checking for schema updates...", { - operation: "schema_migration", - }); - addColumnIfNotExists("users", "is_admin", "INTEGER NOT NULL DEFAULT 0"); addColumnIfNotExists("users", "is_oidc", "INTEGER NOT NULL DEFAULT 0"); @@ -250,6 +358,14 @@ const migrateSchema = () => { "INTEGER REFERENCES ssh_credentials(id)", ); + addColumnIfNotExists("ssh_data", "autostart_password", "TEXT"); + addColumnIfNotExists("ssh_data", "autostart_key", "TEXT"); + addColumnIfNotExists("ssh_data", "autostart_key_password", "TEXT"); + + addColumnIfNotExists("ssh_credentials", "private_key", "TEXT"); + addColumnIfNotExists("ssh_credentials", "public_key", "TEXT"); + addColumnIfNotExists("ssh_credentials", "detected_key_type", "TEXT"); + addColumnIfNotExists("file_manager_recent", "host_id", "INTEGER NOT NULL"); addColumnIfNotExists("file_manager_pinned", "host_id", "INTEGER NOT NULL"); addColumnIfNotExists("file_manager_shortcuts", "host_id", "INTEGER NOT NULL"); @@ -259,48 +375,170 @@ const migrateSchema = () => { }); }; -const initializeDatabase = async () => { - migrateSchema(); +async function saveMemoryDatabaseToFile() { + if (!memoryDatabase) return; try { - const row = sqlite - .prepare("SELECT value FROM settings WHERE key = 'allow_registration'") - .get(); - if (!row) { - databaseLogger.info("Initializing default settings", { - operation: "db_init", - setting: "allow_registration", - }); - sqlite - .prepare( - "INSERT INTO settings (key, value) VALUES ('allow_registration', 'true')", - ) - .run(); - databaseLogger.success("Default settings initialized", { - operation: "db_init", - }); - } else { - databaseLogger.debug("Default settings already exist", { - operation: "db_init", - }); + const buffer = memoryDatabase.serialize(); + + if (!fs.existsSync(dataDir)) { + fs.mkdirSync(dataDir, { recursive: true }); } - } catch (e) { - databaseLogger.warn("Could not initialize default settings", { - operation: "db_init", - error: e, + + if (enableFileEncryption) { + await DatabaseFileEncryption.encryptDatabaseFromBuffer( + buffer, + encryptedDbPath, + ); + } else { + fs.writeFileSync(dbPath, buffer); + } + } catch (error) { + databaseLogger.error("Failed to save in-memory database", error, { + operation: "memory_db_save_failed", + enableFileEncryption, }); } +} + +async function handlePostInitFileEncryption() { + if (!enableFileEncryption) return; + + try { + if (memoryDatabase) { + await saveMemoryDatabaseToFile(); + + setInterval(saveMemoryDatabaseToFile, 15 * 1000); + + DatabaseSaveTrigger.initialize(saveMemoryDatabaseToFile); + } + + try { + const migration = new DatabaseMigration(dataDir); + migration.cleanupOldBackups(); + } catch (cleanupError) { + databaseLogger.warn("Failed to cleanup old migration files", { + operation: "migration_cleanup_startup_failed", + error: + cleanupError instanceof Error + ? cleanupError.message + : "Unknown error", + }); + } + } catch (error) { + databaseLogger.error( + "Failed to handle database file encryption setup", + error, + { + operation: "db_encrypt_setup_failed", + }, + ); + } +} + +async function initializeDatabase(): Promise { + await initializeCompleteDatabase(); + await handlePostInitFileEncryption(); +} + +export { initializeDatabase }; + +async function cleanupDatabase() { + if (memoryDatabase) { + try { + await saveMemoryDatabaseToFile(); + } catch (error) { + databaseLogger.error( + "Failed to save in-memory database before shutdown", + error, + { + operation: "shutdown_save_failed", + }, + ); + } + } + + try { + if (sqlite) { + sqlite.close(); + } + } catch (error) { + databaseLogger.warn("Error closing database connection", { + operation: "db_close_error", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + + try { + const tempDir = path.join(dataDir, ".temp"); + if (fs.existsSync(tempDir)) { + const files = fs.readdirSync(tempDir); + for (const file of files) { + try { + fs.unlinkSync(path.join(tempDir, file)); + } catch {} + } + + try { + fs.rmdirSync(tempDir); + } catch {} + } + } catch (error) {} +} + +process.on("exit", () => { + if (sqlite) { + try { + sqlite.close(); + } catch {} + } +}); + +process.on("SIGINT", async () => { + databaseLogger.info("Received SIGINT, cleaning up...", { + operation: "shutdown", + }); + await cleanupDatabase(); + process.exit(0); +}); + +process.on("SIGTERM", async () => { + databaseLogger.info("Received SIGTERM, cleaning up...", { + operation: "shutdown", + }); + await cleanupDatabase(); + process.exit(0); +}); + +let db: ReturnType>; + +export function getDb(): ReturnType> { + if (!db) { + throw new Error( + "Database not initialized. Ensure initializeDatabase() is called before accessing db.", + ); + } + return db; +} + +export function getSqlite(): Database.Database { + if (!sqlite) { + throw new Error( + "SQLite not initialized. Ensure initializeDatabase() is called before accessing sqlite.", + ); + } + return sqlite; +} + +export { db }; +export { DatabaseFileEncryption }; +export const databasePaths = { + main: actualDbPath, + encrypted: encryptedDbPath, + directory: dbDir, + inMemory: true, }; -initializeDatabase().catch((error) => { - databaseLogger.error("Failed to initialize database", error, { - operation: "db_init", - }); - process.exit(1); -}); +export { saveMemoryDatabaseToFile }; -databaseLogger.success("Database connection established", { - operation: "db_init", - path: dbPath, -}); -export const db = drizzle(sqlite, { schema }); +export { DatabaseSaveTrigger }; diff --git a/src/backend/database/db/schema.ts b/src/backend/database/db/schema.ts index 9e46d73a..bc2bb4d8 100644 --- a/src/backend/database/db/schema.ts +++ b/src/backend/database/db/schema.ts @@ -49,6 +49,10 @@ export const sshData = sqliteTable("ssh_data", { keyPassword: text("key_password"), keyType: text("key_type"), + autostartPassword: text("autostart_password"), + autostartKey: text("autostart_key", { length: 8192 }), + autostartKeyPassword: text("autostart_key_password"), + credentialId: integer("credential_id").references(() => sshCredentials.id), enableTerminal: integer("enable_terminal", { mode: "boolean" }) .notNull() @@ -138,8 +142,11 @@ export const sshCredentials = sqliteTable("ssh_credentials", { username: text("username").notNull(), password: text("password"), key: text("key", { length: 16384 }), + privateKey: text("private_key", { length: 16384 }), + publicKey: text("public_key", { length: 4096 }), keyPassword: text("key_password"), keyType: text("key_type"), + detectedKeyType: text("detected_key_type"), usageCount: integer("usage_count").notNull().default(0), lastUsed: text("last_used"), createdAt: text("created_at") diff --git a/src/backend/database/routes/alerts.ts b/src/backend/database/routes/alerts.ts index ddfc44c5..4f836894 100644 --- a/src/backend/database/routes/alerts.ts +++ b/src/backend/database/routes/alerts.ts @@ -4,6 +4,7 @@ import { dismissedAlerts } from "../db/schema.js"; import { eq, and } from "drizzle-orm"; import fetch from "node-fetch"; import { authLogger } from "../../utils/logger.js"; +import { AuthManager } from "../../utils/auth-manager.js"; interface CacheEntry { data: any; @@ -107,31 +108,14 @@ async function fetchAlertsFromGitHub(): Promise { const router = express.Router(); -// Route: Get all active alerts +const authManager = AuthManager.getInstance(); +const authenticateJWT = authManager.createAuthMiddleware(); + +// Route: Get alerts for the authenticated user (excluding dismissed ones) // GET /alerts -router.get("/", async (req, res) => { +router.get("/", authenticateJWT, async (req, res) => { try { - const alerts = await fetchAlertsFromGitHub(); - res.json({ - alerts, - cached: alertCache.get("termix_alerts") !== null, - total_count: alerts.length, - }); - } catch (error) { - authLogger.error("Failed to get alerts", error); - res.status(500).json({ error: "Failed to fetch alerts" }); - } -}); - -// Route: Get alerts for a specific user (excluding dismissed ones) -// GET /alerts/user/:userId -router.get("/user/:userId", async (req, res) => { - try { - const { userId } = req.params; - - if (!userId) { - return res.status(400).json({ error: "User ID is required" }); - } + const userId = (req as any).userId; const allAlerts = await fetchAlertsFromGitHub(); @@ -144,32 +128,31 @@ router.get("/user/:userId", async (req, res) => { dismissedAlertRecords.map((record) => record.alertId), ); - const userAlerts = allAlerts.filter( + const activeAlertsForUser = allAlerts.filter( (alert) => !dismissedAlertIds.has(alert.id), ); res.json({ - alerts: userAlerts, - total_count: userAlerts.length, - dismissed_count: dismissedAlertIds.size, + alerts: activeAlertsForUser, + cached: alertCache.get("termix_alerts") !== null, + total_count: activeAlertsForUser.length, }); } catch (error) { authLogger.error("Failed to get user alerts", error); - res.status(500).json({ error: "Failed to fetch user alerts" }); + res.status(500).json({ error: "Failed to fetch alerts" }); } }); -// Route: Dismiss an alert for a user +// Route: Dismiss an alert for the authenticated user // POST /alerts/dismiss -router.post("/dismiss", async (req, res) => { +router.post("/dismiss", authenticateJWT, async (req, res) => { try { - const { userId, alertId } = req.body; + const { alertId } = req.body; + const userId = (req as any).userId; - if (!userId || !alertId) { - authLogger.warn("Missing userId or alertId in dismiss request"); - return res - .status(400) - .json({ error: "User ID and Alert ID are required" }); + if (!alertId) { + authLogger.warn("Missing alertId in dismiss request", { userId }); + return res.status(400).json({ error: "Alert ID is required" }); } const existingDismissal = await db @@ -201,13 +184,9 @@ router.post("/dismiss", async (req, res) => { // Route: Get dismissed alerts for a user // GET /alerts/dismissed/:userId -router.get("/dismissed/:userId", async (req, res) => { +router.get("/dismissed", authenticateJWT, async (req, res) => { try { - const { userId } = req.params; - - if (!userId) { - return res.status(400).json({ error: "User ID is required" }); - } + const userId = (req as any).userId; const dismissedAlertRecords = await db .select({ @@ -227,16 +206,15 @@ router.get("/dismissed/:userId", async (req, res) => { } }); -// Route: Undismiss an alert for a user (remove from dismissed list) +// Route: Undismiss an alert for the authenticated user (remove from dismissed list) // DELETE /alerts/dismiss -router.delete("/dismiss", async (req, res) => { +router.delete("/dismiss", authenticateJWT, async (req, res) => { try { - const { userId, alertId } = req.body; + const { alertId } = req.body; + const userId = (req as any).userId; - if (!userId || !alertId) { - return res - .status(400) - .json({ error: "User ID and Alert ID are required" }); + if (!alertId) { + return res.status(400).json({ error: "Alert ID is required" }); } const result = await db diff --git a/src/backend/database/routes/credentials.ts b/src/backend/database/routes/credentials.ts index b6dbb62c..ac022f87 100644 --- a/src/backend/database/routes/credentials.ts +++ b/src/backend/database/routes/credentials.ts @@ -5,85 +5,110 @@ import { eq, and, desc, sql } from "drizzle-orm"; import type { Request, Response, NextFunction } from "express"; import jwt from "jsonwebtoken"; import { authLogger } from "../../utils/logger.js"; +import { SimpleDBOps } from "../../utils/simple-db-ops.js"; +import { AuthManager } from "../../utils/auth-manager.js"; +import { + parseSSHKey, + parsePublicKey, + detectKeyType, + validateKeyPair, +} from "../../utils/ssh-key-utils.js"; +import crypto from "crypto"; +import ssh2Pkg from "ssh2"; +const { utils: ssh2Utils, Client } = ssh2Pkg; + +function generateSSHKeyPair( + keyType: string, + keySize?: number, + passphrase?: string, +): { + success: boolean; + privateKey?: string; + publicKey?: string; + error?: string; +} { + try { + let ssh2Type = keyType; + const options: any = {}; + + if (keyType === "ssh-rsa") { + ssh2Type = "rsa"; + options.bits = keySize || 2048; + } else if (keyType === "ssh-ed25519") { + ssh2Type = "ed25519"; + } else if (keyType === "ecdsa-sha2-nistp256") { + ssh2Type = "ecdsa"; + options.bits = 256; + } + + if (passphrase && passphrase.trim()) { + options.passphrase = passphrase; + options.cipher = "aes128-cbc"; + } + + const keyPair = ssh2Utils.generateKeyPairSync(ssh2Type as any, options); + + return { + success: true, + privateKey: keyPair.private, + publicKey: keyPair.public, + }; + } catch (error) { + return { + success: false, + error: + error instanceof Error ? error.message : "SSH key generation failed", + }; + } +} const router = express.Router(); -interface JWTPayload { - userId: string; - iat?: number; - exp?: number; -} - function isNonEmptyString(val: any): val is string { return typeof val === "string" && val.trim().length > 0; } -function authenticateJWT(req: Request, res: Response, next: NextFunction) { - const authHeader = req.headers["authorization"]; - if (!authHeader || !authHeader.startsWith("Bearer ")) { - authLogger.warn("Missing or invalid Authorization header"); - return res - .status(401) - .json({ error: "Missing or invalid Authorization header" }); - } - const token = authHeader.split(" ")[1]; - const jwtSecret = process.env.JWT_SECRET || "secret"; - try { - const payload = jwt.verify(token, jwtSecret) as JWTPayload; - (req as any).userId = payload.userId; - next(); - } catch (err) { - authLogger.warn("Invalid or expired token"); - return res.status(401).json({ error: "Invalid or expired token" }); - } -} +const authManager = AuthManager.getInstance(); +const authenticateJWT = authManager.createAuthMiddleware(); +const requireDataAccess = authManager.createDataAccessMiddleware(); // Create a new credential // POST /credentials -router.post("/", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; - const { - name, - description, - folder, - tags, - authType, - username, - password, - key, - keyPassword, - keyType, - } = req.body; - - if ( - !isNonEmptyString(userId) || - !isNonEmptyString(name) || - !isNonEmptyString(username) - ) { - authLogger.warn("Invalid credential creation data validation failed", { - operation: "credential_create", - userId, - hasName: !!name, - hasUsername: !!username, - }); - return res.status(400).json({ error: "Name and username are required" }); - } - - if (!["password", "key"].includes(authType)) { - authLogger.warn("Invalid auth type provided", { - operation: "credential_create", - userId, +router.post( + "/", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { name, + description, + folder, + tags, authType, - }); - return res - .status(400) - .json({ error: 'Auth type must be "password" or "key"' }); - } + username, + password, + key, + keyPassword, + keyType, + } = req.body; - try { - if (authType === "password" && !password) { - authLogger.warn("Password required for password authentication", { + if ( + !isNonEmptyString(userId) || + !isNonEmptyString(name) || + !isNonEmptyString(username) + ) { + authLogger.warn("Invalid credential creation data validation failed", { + operation: "credential_create", + userId, + hasName: !!name, + hasUsername: !!username, + }); + return res.status(400).json({ error: "Name and username are required" }); + } + + if (!["password", "key"].includes(authType)) { + authLogger.warn("Invalid auth type provided", { operation: "credential_create", userId, name, @@ -91,371 +116,479 @@ router.post("/", authenticateJWT, async (req: Request, res: Response) => { }); return res .status(400) - .json({ error: "Password is required for password authentication" }); + .json({ error: 'Auth type must be "password" or "key"' }); } - if (authType === "key" && !key) { - authLogger.warn("SSH key required for key authentication", { + + try { + if (authType === "password" && !password) { + authLogger.warn("Password required for password authentication", { + operation: "credential_create", + userId, + name, + authType, + }); + return res + .status(400) + .json({ error: "Password is required for password authentication" }); + } + if (authType === "key" && !key) { + authLogger.warn("SSH key required for key authentication", { + operation: "credential_create", + userId, + name, + authType, + }); + return res + .status(400) + .json({ error: "SSH key is required for key authentication" }); + } + const plainPassword = + authType === "password" && password ? password : null; + const plainKey = authType === "key" && key ? key : null; + const plainKeyPassword = + authType === "key" && keyPassword ? keyPassword : null; + + let keyInfo = null; + if (authType === "key" && plainKey) { + keyInfo = parseSSHKey(plainKey, plainKeyPassword); + if (!keyInfo.success) { + authLogger.warn("SSH key parsing failed", { + operation: "credential_create", + userId, + name, + error: keyInfo.error, + }); + return res.status(400).json({ + error: `Invalid SSH key: ${keyInfo.error}`, + }); + } + } + + const credentialData = { + userId, + name: name.trim(), + description: description?.trim() || null, + folder: folder?.trim() || null, + tags: Array.isArray(tags) ? tags.join(",") : tags || "", + authType, + username: username.trim(), + password: plainPassword, + key: plainKey, + privateKey: keyInfo?.privateKey || plainKey, + publicKey: keyInfo?.publicKey || null, + keyPassword: plainKeyPassword, + keyType: keyType || null, + detectedKeyType: keyInfo?.keyType || null, + usageCount: 0, + lastUsed: null, + }; + + const created = (await SimpleDBOps.insert( + sshCredentials, + "ssh_credentials", + credentialData, + userId, + )) as typeof credentialData & { id: number }; + + authLogger.success( + `SSH credential created: ${name} (${authType}) by user ${userId}`, + { + operation: "credential_create_success", + userId, + credentialId: created.id, + name, + authType, + username, + }, + ); + + res.status(201).json(formatCredentialOutput(created)); + } catch (err) { + authLogger.error("Failed to create credential in database", err, { operation: "credential_create", userId, name, authType, - }); - return res - .status(400) - .json({ error: "SSH key is required for key authentication" }); - } - const plainPassword = authType === "password" && password ? password : null; - const plainKey = authType === "key" && key ? key : null; - const plainKeyPassword = - authType === "key" && keyPassword ? keyPassword : null; - - const credentialData = { - userId, - name: name.trim(), - description: description?.trim() || null, - folder: folder?.trim() || null, - tags: Array.isArray(tags) ? tags.join(",") : tags || "", - authType, - username: username.trim(), - password: plainPassword, - key: plainKey, - keyPassword: plainKeyPassword, - keyType: keyType || null, - usageCount: 0, - lastUsed: null, - }; - - const result = await db - .insert(sshCredentials) - .values(credentialData) - .returning(); - const created = result[0]; - - authLogger.success( - `SSH credential created: ${name} (${authType}) by user ${userId}`, - { - operation: "credential_create_success", - userId, - credentialId: created.id, - name, - authType, username, - }, - ); - - res.status(201).json(formatCredentialOutput(created)); - } catch (err) { - authLogger.error("Failed to create credential in database", err, { - operation: "credential_create", - userId, - name, - authType, - username, - }); - res.status(500).json({ - error: err instanceof Error ? err.message : "Failed to create credential", - }); - } -}); + }); + res.status(500).json({ + error: + err instanceof Error ? err.message : "Failed to create credential", + }); + } + }, +); // Get all credentials for the authenticated user // GET /credentials -router.get("/", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; +router.get( + "/", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; - if (!isNonEmptyString(userId)) { - authLogger.warn("Invalid userId for credential fetch"); - return res.status(400).json({ error: "Invalid userId" }); - } + if (!isNonEmptyString(userId)) { + authLogger.warn("Invalid userId for credential fetch"); + return res.status(400).json({ error: "Invalid userId" }); + } - try { - const credentials = await db - .select() - .from(sshCredentials) - .where(eq(sshCredentials.userId, userId)) - .orderBy(desc(sshCredentials.updatedAt)); + try { + const credentials = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where(eq(sshCredentials.userId, userId)) + .orderBy(desc(sshCredentials.updatedAt)), + "ssh_credentials", + userId, + ); - res.json(credentials.map((cred) => formatCredentialOutput(cred))); - } catch (err) { - authLogger.error("Failed to fetch credentials", err); - res.status(500).json({ error: "Failed to fetch credentials" }); - } -}); + res.json(credentials.map((cred) => formatCredentialOutput(cred))); + } catch (err) { + authLogger.error("Failed to fetch credentials", err); + res.status(500).json({ error: "Failed to fetch credentials" }); + } + }, +); // Get all unique credential folders for the authenticated user // GET /credentials/folders -router.get("/folders", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; +router.get( + "/folders", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; - if (!isNonEmptyString(userId)) { - authLogger.warn("Invalid userId for credential folder fetch"); - return res.status(400).json({ error: "Invalid userId" }); - } + if (!isNonEmptyString(userId)) { + authLogger.warn("Invalid userId for credential folder fetch"); + return res.status(400).json({ error: "Invalid userId" }); + } - try { - const result = await db - .select({ folder: sshCredentials.folder }) - .from(sshCredentials) - .where(eq(sshCredentials.userId, userId)); + try { + const result = await db + .select({ folder: sshCredentials.folder }) + .from(sshCredentials) + .where(eq(sshCredentials.userId, userId)); - const folderCounts: Record = {}; - result.forEach((r) => { - if (r.folder && r.folder.trim() !== "") { - folderCounts[r.folder] = (folderCounts[r.folder] || 0) + 1; - } - }); + const folderCounts: Record = {}; + result.forEach((r) => { + if (r.folder && r.folder.trim() !== "") { + folderCounts[r.folder] = (folderCounts[r.folder] || 0) + 1; + } + }); - const folders = Object.keys(folderCounts).filter( - (folder) => folderCounts[folder] > 0, - ); - res.json(folders); - } catch (err) { - authLogger.error("Failed to fetch credential folders", err); - res.status(500).json({ error: "Failed to fetch credential folders" }); - } -}); + const folders = Object.keys(folderCounts).filter( + (folder) => folderCounts[folder] > 0, + ); + res.json(folders); + } catch (err) { + authLogger.error("Failed to fetch credential folders", err); + res.status(500).json({ error: "Failed to fetch credential folders" }); + } + }, +); // Get a specific credential by ID (with plain text secrets) // GET /credentials/:id -router.get("/:id", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; - const { id } = req.params; +router.get( + "/:id", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { id } = req.params; - if (!isNonEmptyString(userId) || !id) { - authLogger.warn("Invalid request for credential fetch"); - return res.status(400).json({ error: "Invalid request" }); - } + if (!isNonEmptyString(userId) || !id) { + authLogger.warn("Invalid request for credential fetch"); + return res.status(400).json({ error: "Invalid request" }); + } - try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, parseInt(id)), - eq(sshCredentials.userId, userId), - ), + try { + const credentials = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, parseInt(id)), + eq(sshCredentials.userId, userId), + ), + ), + "ssh_credentials", + userId, ); - if (credentials.length === 0) { - return res.status(404).json({ error: "Credential not found" }); - } + if (credentials.length === 0) { + return res.status(404).json({ error: "Credential not found" }); + } - const credential = credentials[0]; - const output = formatCredentialOutput(credential); + const credential = credentials[0]; + const output = formatCredentialOutput(credential); - if (credential.password) { - (output as any).password = credential.password; - } - if (credential.key) { - (output as any).key = credential.key; - } - if (credential.keyPassword) { - (output as any).keyPassword = credential.keyPassword; - } + if (credential.password) { + (output as any).password = credential.password; + } + if (credential.key) { + (output as any).key = credential.key; + } + if (credential.privateKey) { + (output as any).privateKey = credential.privateKey; + } + if (credential.publicKey) { + (output as any).publicKey = credential.publicKey; + } + if (credential.keyPassword) { + (output as any).keyPassword = credential.keyPassword; + } - res.json(output); - } catch (err) { - authLogger.error("Failed to fetch credential", err); - res.status(500).json({ - error: err instanceof Error ? err.message : "Failed to fetch credential", - }); - } -}); + res.json(output); + } catch (err) { + authLogger.error("Failed to fetch credential", err); + res.status(500).json({ + error: + err instanceof Error ? err.message : "Failed to fetch credential", + }); + } + }, +); // Update a credential // PUT /credentials/:id -router.put("/:id", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; - const { id } = req.params; - const updateData = req.body; +router.put( + "/:id", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { id } = req.params; + const updateData = req.body; - if (!isNonEmptyString(userId) || !id) { - authLogger.warn("Invalid request for credential update"); - return res.status(400).json({ error: "Invalid request" }); - } - - try { - const existing = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, parseInt(id)), - eq(sshCredentials.userId, userId), - ), - ); - - if (existing.length === 0) { - return res.status(404).json({ error: "Credential not found" }); + if (!isNonEmptyString(userId) || !id) { + authLogger.warn("Invalid request for credential update"); + return res.status(400).json({ error: "Invalid request" }); } - const updateFields: any = {}; - - if (updateData.name !== undefined) - updateFields.name = updateData.name.trim(); - if (updateData.description !== undefined) - updateFields.description = updateData.description?.trim() || null; - if (updateData.folder !== undefined) - updateFields.folder = updateData.folder?.trim() || null; - if (updateData.tags !== undefined) { - updateFields.tags = Array.isArray(updateData.tags) - ? updateData.tags.join(",") - : updateData.tags || ""; - } - if (updateData.username !== undefined) - updateFields.username = updateData.username.trim(); - if (updateData.authType !== undefined) - updateFields.authType = updateData.authType; - if (updateData.keyType !== undefined) - updateFields.keyType = updateData.keyType; - - if (updateData.password !== undefined) { - updateFields.password = updateData.password || null; - } - if (updateData.key !== undefined) { - updateFields.key = updateData.key || null; - } - if (updateData.keyPassword !== undefined) { - updateFields.keyPassword = updateData.keyPassword || null; - } - - if (Object.keys(updateFields).length === 0) { + try { const existing = await db .select() .from(sshCredentials) - .where(eq(sshCredentials.id, parseInt(id))); + .where( + and( + eq(sshCredentials.id, parseInt(id)), + eq(sshCredentials.userId, userId), + ), + ); - return res.json(formatCredentialOutput(existing[0])); - } + if (existing.length === 0) { + return res.status(404).json({ error: "Credential not found" }); + } - await db - .update(sshCredentials) - .set(updateFields) - .where( + const updateFields: any = {}; + + if (updateData.name !== undefined) + updateFields.name = updateData.name.trim(); + if (updateData.description !== undefined) + updateFields.description = updateData.description?.trim() || null; + if (updateData.folder !== undefined) + updateFields.folder = updateData.folder?.trim() || null; + if (updateData.tags !== undefined) { + updateFields.tags = Array.isArray(updateData.tags) + ? updateData.tags.join(",") + : updateData.tags || ""; + } + if (updateData.username !== undefined) + updateFields.username = updateData.username.trim(); + if (updateData.authType !== undefined) + updateFields.authType = updateData.authType; + if (updateData.keyType !== undefined) + updateFields.keyType = updateData.keyType; + + if (updateData.password !== undefined) { + updateFields.password = updateData.password || null; + } + if (updateData.key !== undefined) { + updateFields.key = updateData.key || null; + + if (updateData.key && existing[0].authType === "key") { + const keyInfo = parseSSHKey(updateData.key, updateData.keyPassword); + if (!keyInfo.success) { + authLogger.warn("SSH key parsing failed during update", { + operation: "credential_update", + userId, + credentialId: parseInt(id), + error: keyInfo.error, + }); + return res.status(400).json({ + error: `Invalid SSH key: ${keyInfo.error}`, + }); + } + updateFields.privateKey = keyInfo.privateKey; + updateFields.publicKey = keyInfo.publicKey; + updateFields.detectedKeyType = keyInfo.keyType; + } + } + if (updateData.keyPassword !== undefined) { + updateFields.keyPassword = updateData.keyPassword || null; + } + + if (Object.keys(updateFields).length === 0) { + const existing = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where(eq(sshCredentials.id, parseInt(id))), + "ssh_credentials", + userId, + ); + + return res.json(formatCredentialOutput(existing[0])); + } + + await SimpleDBOps.update( + sshCredentials, + "ssh_credentials", and( eq(sshCredentials.id, parseInt(id)), eq(sshCredentials.userId, userId), ), + updateFields, + userId, ); - const updated = await db - .select() - .from(sshCredentials) - .where(eq(sshCredentials.id, parseInt(id))); - - const credential = updated[0]; - authLogger.success( - `SSH credential updated: ${credential.name} (${credential.authType}) by user ${userId}`, - { - operation: "credential_update_success", + const updated = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where(eq(sshCredentials.id, parseInt(id))), + "ssh_credentials", userId, - credentialId: parseInt(id), - name: credential.name, - authType: credential.authType, - username: credential.username, - }, - ); + ); - res.json(formatCredentialOutput(updated[0])); - } catch (err) { - authLogger.error("Failed to update credential", err); - res.status(500).json({ - error: err instanceof Error ? err.message : "Failed to update credential", - }); - } -}); + const credential = updated[0]; + authLogger.success( + `SSH credential updated: ${credential.name} (${credential.authType}) by user ${userId}`, + { + operation: "credential_update_success", + userId, + credentialId: parseInt(id), + name: credential.name, + authType: credential.authType, + username: credential.username, + }, + ); + + res.json(formatCredentialOutput(updated[0])); + } catch (err) { + authLogger.error("Failed to update credential", err); + res.status(500).json({ + error: + err instanceof Error ? err.message : "Failed to update credential", + }); + } + }, +); // Delete a credential // DELETE /credentials/:id -router.delete("/:id", authenticateJWT, async (req: Request, res: Response) => { - const userId = (req as any).userId; - const { id } = req.params; +router.delete( + "/:id", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { id } = req.params; - if (!isNonEmptyString(userId) || !id) { - authLogger.warn("Invalid request for credential deletion"); - return res.status(400).json({ error: "Invalid request" }); - } - - try { - const credentialToDelete = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, parseInt(id)), - eq(sshCredentials.userId, userId), - ), - ); - - if (credentialToDelete.length === 0) { - return res.status(404).json({ error: "Credential not found" }); + if (!isNonEmptyString(userId) || !id) { + authLogger.warn("Invalid request for credential deletion"); + return res.status(400).json({ error: "Invalid request" }); } - const hostsUsingCredential = await db - .select() - .from(sshData) - .where( - and(eq(sshData.credentialId, parseInt(id)), eq(sshData.userId, userId)), - ); + try { + const credentialToDelete = await db + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, parseInt(id)), + eq(sshCredentials.userId, userId), + ), + ); - if (hostsUsingCredential.length > 0) { - await db - .update(sshData) - .set({ - credentialId: null, - password: null, - key: null, - keyPassword: null, - authType: "password", - }) + if (credentialToDelete.length === 0) { + return res.status(404).json({ error: "Credential not found" }); + } + + const hostsUsingCredential = await db + .select() + .from(sshData) .where( and( eq(sshData.credentialId, parseInt(id)), eq(sshData.userId, userId), ), ); + + if (hostsUsingCredential.length > 0) { + await db + .update(sshData) + .set({ + credentialId: null, + password: null, + key: null, + keyPassword: null, + authType: "password", + }) + .where( + and( + eq(sshData.credentialId, parseInt(id)), + eq(sshData.userId, userId), + ), + ); + } + + await db + .delete(sshCredentialUsage) + .where( + and( + eq(sshCredentialUsage.credentialId, parseInt(id)), + eq(sshCredentialUsage.userId, userId), + ), + ); + + await db + .delete(sshCredentials) + .where( + and( + eq(sshCredentials.id, parseInt(id)), + eq(sshCredentials.userId, userId), + ), + ); + + const credential = credentialToDelete[0]; + authLogger.success( + `SSH credential deleted: ${credential.name} (${credential.authType}) by user ${userId}`, + { + operation: "credential_delete_success", + userId, + credentialId: parseInt(id), + name: credential.name, + authType: credential.authType, + username: credential.username, + }, + ); + + res.json({ message: "Credential deleted successfully" }); + } catch (err) { + authLogger.error("Failed to delete credential", err); + res.status(500).json({ + error: + err instanceof Error ? err.message : "Failed to delete credential", + }); } - - await db - .delete(sshCredentialUsage) - .where( - and( - eq(sshCredentialUsage.credentialId, parseInt(id)), - eq(sshCredentialUsage.userId, userId), - ), - ); - - await db - .delete(sshCredentials) - .where( - and( - eq(sshCredentials.id, parseInt(id)), - eq(sshCredentials.userId, userId), - ), - ); - - const credential = credentialToDelete[0]; - authLogger.success( - `SSH credential deleted: ${credential.name} (${credential.authType}) by user ${userId}`, - { - operation: "credential_delete_success", - userId, - credentialId: parseInt(id), - name: credential.name, - authType: credential.authType, - username: credential.username, - }, - ); - - res.json({ message: "Credential deleted successfully" }); - } catch (err) { - authLogger.error("Failed to delete credential", err); - res.status(500).json({ - error: err instanceof Error ? err.message : "Failed to delete credential", - }); - } -}); + }, +); // Apply a credential to an SSH host (for quick application) // POST /credentials/:id/apply-to-host/:hostId @@ -584,7 +717,9 @@ function formatCredentialOutput(credential: any): any { : [], authType: credential.authType, username: credential.username, + publicKey: credential.publicKey, keyType: credential.keyType, + detectedKeyType: credential.detectedKeyType, usageCount: credential.usageCount || 0, lastUsed: credential.lastUsed, createdAt: credential.createdAt, @@ -661,4 +796,809 @@ router.put( }, ); +// Detect SSH key type endpoint +// POST /credentials/detect-key-type +router.post( + "/detect-key-type", + authenticateJWT, + async (req: Request, res: Response) => { + const { privateKey, keyPassword } = req.body; + + if (!privateKey || typeof privateKey !== "string") { + return res.status(400).json({ error: "Private key is required" }); + } + + try { + const keyInfo = parseSSHKey(privateKey, keyPassword); + + const response = { + success: keyInfo.success, + keyType: keyInfo.keyType, + detectedKeyType: keyInfo.keyType, + hasPublicKey: !!keyInfo.publicKey, + error: keyInfo.error || null, + }; + + res.json(response); + } catch (error) { + authLogger.error("Failed to detect key type", error); + res.status(500).json({ + error: + error instanceof Error ? error.message : "Failed to detect key type", + }); + } + }, +); + +// Detect SSH public key type endpoint +// POST /credentials/detect-public-key-type +router.post( + "/detect-public-key-type", + authenticateJWT, + async (req: Request, res: Response) => { + const { publicKey } = req.body; + + if (!publicKey || typeof publicKey !== "string") { + return res.status(400).json({ error: "Public key is required" }); + } + + try { + const keyInfo = parsePublicKey(publicKey); + + const response = { + success: keyInfo.success, + keyType: keyInfo.keyType, + detectedKeyType: keyInfo.keyType, + error: keyInfo.error || null, + }; + + res.json(response); + } catch (error) { + authLogger.error("Failed to detect public key type", error); + res.status(500).json({ + error: + error instanceof Error + ? error.message + : "Failed to detect public key type", + }); + } + }, +); + +// Validate SSH key pair endpoint +// POST /credentials/validate-key-pair +router.post( + "/validate-key-pair", + authenticateJWT, + async (req: Request, res: Response) => { + const { privateKey, publicKey, keyPassword } = req.body; + + if (!privateKey || typeof privateKey !== "string") { + return res.status(400).json({ error: "Private key is required" }); + } + + if (!publicKey || typeof publicKey !== "string") { + return res.status(400).json({ error: "Public key is required" }); + } + + try { + const validationResult = validateKeyPair( + privateKey, + publicKey, + keyPassword, + ); + + const response = { + isValid: validationResult.isValid, + privateKeyType: validationResult.privateKeyType, + publicKeyType: validationResult.publicKeyType, + generatedPublicKey: validationResult.generatedPublicKey, + error: validationResult.error || null, + }; + + res.json(response); + } catch (error) { + authLogger.error("Failed to validate key pair", error); + res.status(500).json({ + error: + error instanceof Error + ? error.message + : "Failed to validate key pair", + }); + } + }, +); + +// Generate new SSH key pair endpoint +// POST /credentials/generate-key-pair +router.post( + "/generate-key-pair", + authenticateJWT, + async (req: Request, res: Response) => { + const { keyType = "ssh-ed25519", keySize = 2048, passphrase } = req.body; + + try { + const result = generateSSHKeyPair(keyType, keySize, passphrase); + + if (result.success && result.privateKey && result.publicKey) { + const response = { + success: true, + privateKey: result.privateKey, + publicKey: result.publicKey, + keyType: keyType, + format: "ssh", + algorithm: keyType, + keySize: keyType === "ssh-rsa" ? keySize : undefined, + curve: keyType === "ecdsa-sha2-nistp256" ? "nistp256" : undefined, + }; + + res.json(response); + } else { + res.status(500).json({ + success: false, + error: result.error || "Failed to generate SSH key pair", + }); + } + } catch (error) { + authLogger.error("Failed to generate key pair", error); + res.status(500).json({ + success: false, + error: + error instanceof Error + ? error.message + : "Failed to generate key pair", + }); + } + }, +); + +// Generate public key from private key endpoint +// POST /credentials/generate-public-key +router.post( + "/generate-public-key", + authenticateJWT, + async (req: Request, res: Response) => { + const { privateKey, keyPassword } = req.body; + + if (!privateKey || typeof privateKey !== "string") { + return res.status(400).json({ error: "Private key is required" }); + } + + try { + let privateKeyObj; + let parseAttempts = []; + + try { + privateKeyObj = crypto.createPrivateKey({ + key: privateKey, + passphrase: keyPassword, + }); + } catch (error) { + parseAttempts.push(`Method 1 (with passphrase): ${error.message}`); + } + + if (!privateKeyObj) { + try { + privateKeyObj = crypto.createPrivateKey(privateKey); + } catch (error) { + parseAttempts.push(`Method 2 (without passphrase): ${error.message}`); + } + } + + if (!privateKeyObj) { + try { + privateKeyObj = crypto.createPrivateKey({ + key: privateKey, + format: "pem", + type: "pkcs8", + }); + } catch (error) { + parseAttempts.push(`Method 3 (PKCS#8): ${error.message}`); + } + } + + if ( + !privateKeyObj && + privateKey.includes("-----BEGIN RSA PRIVATE KEY-----") + ) { + try { + privateKeyObj = crypto.createPrivateKey({ + key: privateKey, + format: "pem", + type: "pkcs1", + }); + } catch (error) { + parseAttempts.push(`Method 4 (PKCS#1): ${error.message}`); + } + } + + if ( + !privateKeyObj && + privateKey.includes("-----BEGIN EC PRIVATE KEY-----") + ) { + try { + privateKeyObj = crypto.createPrivateKey({ + key: privateKey, + format: "pem", + type: "sec1", + }); + } catch (error) { + parseAttempts.push(`Method 5 (SEC1): ${error.message}`); + } + } + + if (!privateKeyObj) { + try { + const keyInfo = parseSSHKey(privateKey, keyPassword); + + if (keyInfo.success && keyInfo.publicKey) { + const publicKeyString = String(keyInfo.publicKey); + return res.json({ + success: true, + publicKey: publicKeyString, + keyType: keyInfo.keyType, + }); + } else { + parseAttempts.push( + `SSH2 fallback: ${keyInfo.error || "No public key generated"}`, + ); + } + } catch (error) { + parseAttempts.push(`SSH2 fallback exception: ${error.message}`); + } + } + + if (!privateKeyObj) { + return res.status(400).json({ + success: false, + error: "Unable to parse private key. Tried multiple formats.", + details: parseAttempts, + }); + } + + const publicKeyObj = crypto.createPublicKey(privateKeyObj); + const publicKeyPem = publicKeyObj.export({ + type: "spki", + format: "pem", + }); + + const publicKeyString = + typeof publicKeyPem === "string" + ? publicKeyPem + : publicKeyPem.toString("utf8"); + + let keyType = "unknown"; + const asymmetricKeyType = privateKeyObj.asymmetricKeyType; + + if (asymmetricKeyType === "rsa") { + keyType = "ssh-rsa"; + } else if (asymmetricKeyType === "ed25519") { + keyType = "ssh-ed25519"; + } else if (asymmetricKeyType === "ec") { + keyType = "ecdsa-sha2-nistp256"; + } + + let finalPublicKey = publicKeyString; + let formatType = "pem"; + + try { + const ssh2PrivateKey = ssh2Utils.parseKey(privateKey, keyPassword); + if (!(ssh2PrivateKey instanceof Error)) { + const publicKeyBuffer = ssh2PrivateKey.getPublicSSH(); + const base64Data = publicKeyBuffer.toString("base64"); + finalPublicKey = `${keyType} ${base64Data}`; + formatType = "ssh"; + } + } catch (sshError) {} + + const response = { + success: true, + publicKey: finalPublicKey, + keyType: keyType, + format: formatType, + }; + + res.json(response); + } catch (error) { + authLogger.error("Failed to generate public key", error); + res.status(500).json({ + success: false, + error: + error instanceof Error + ? error.message + : "Failed to generate public key", + }); + } + }, +); + +async function deploySSHKeyToHost( + hostConfig: any, + publicKey: string, + credentialData: any, +): Promise<{ success: boolean; message?: string; error?: string }> { + return new Promise((resolve) => { + const conn = new Client(); + let connectionTimeout: NodeJS.Timeout; + + connectionTimeout = setTimeout(() => { + conn.destroy(); + resolve({ success: false, error: "Connection timeout" }); + }, 120000); + + conn.on("ready", async () => { + clearTimeout(connectionTimeout); + + try { + await new Promise((resolveCmd, rejectCmd) => { + const cmdTimeout = setTimeout(() => { + rejectCmd(new Error("mkdir command timeout")); + }, 10000); + + conn.exec( + "test -d ~/.ssh || mkdir -p ~/.ssh; chmod 700 ~/.ssh", + (err, stream) => { + if (err) { + clearTimeout(cmdTimeout); + return rejectCmd(err); + } + + stream.on("close", (code) => { + clearTimeout(cmdTimeout); + if (code === 0) { + resolveCmd(); + } else { + rejectCmd( + new Error(`mkdir command failed with code ${code}`), + ); + } + }); + + stream.on("data", (data) => {}); + }, + ); + }); + + const keyExists = await new Promise( + (resolveCheck, rejectCheck) => { + const checkTimeout = setTimeout(() => { + rejectCheck(new Error("Key check timeout")); + }, 5000); + + let actualPublicKey = publicKey; + try { + const parsed = JSON.parse(publicKey); + if (parsed.data) { + actualPublicKey = parsed.data; + } + } catch (e) {} + + const keyParts = actualPublicKey.trim().split(" "); + if (keyParts.length < 2) { + clearTimeout(checkTimeout); + return rejectCheck( + new Error( + "Invalid public key format - must contain at least 2 parts", + ), + ); + } + + const keyPattern = keyParts[1]; + + conn.exec( + `if [ -f ~/.ssh/authorized_keys ]; then grep -F "${keyPattern}" ~/.ssh/authorized_keys >/dev/null 2>&1; echo $?; else echo 1; fi`, + (err, stream) => { + if (err) { + clearTimeout(checkTimeout); + return rejectCheck(err); + } + + let output = ""; + stream.on("data", (data) => { + output += data.toString(); + }); + + stream.on("close", (code) => { + clearTimeout(checkTimeout); + const exists = output.trim() === "0"; + resolveCheck(exists); + }); + }, + ); + }, + ); + + if (keyExists) { + conn.end(); + resolve({ success: true, message: "SSH key already deployed" }); + return; + } + + await new Promise((resolveAdd, rejectAdd) => { + const addTimeout = setTimeout(() => { + rejectAdd(new Error("Key add timeout")); + }, 30000); + + let actualPublicKey = publicKey; + try { + const parsed = JSON.parse(publicKey); + if (parsed.data) { + actualPublicKey = parsed.data; + } + } catch (e) {} + + const escapedKey = actualPublicKey + .replace(/\\/g, "\\\\") + .replace(/'/g, "'\\''"); + + conn.exec( + `printf '%s\\n' '${escapedKey}' >> ~/.ssh/authorized_keys && chmod 600 ~/.ssh/authorized_keys`, + (err, stream) => { + if (err) { + clearTimeout(addTimeout); + return rejectAdd(err); + } + + stream.on("close", (code) => { + clearTimeout(addTimeout); + if (code === 0) { + resolveAdd(); + } else { + rejectAdd( + new Error(`Key deployment failed with code ${code}`), + ); + } + }); + }, + ); + }); + + const verifySuccess = await new Promise( + (resolveVerify, rejectVerify) => { + const verifyTimeout = setTimeout(() => { + rejectVerify(new Error("Key verification timeout")); + }, 5000); + + let actualPublicKey = publicKey; + try { + const parsed = JSON.parse(publicKey); + if (parsed.data) { + actualPublicKey = parsed.data; + } + } catch (e) {} + + const keyParts = actualPublicKey.trim().split(" "); + if (keyParts.length < 2) { + clearTimeout(verifyTimeout); + return rejectVerify( + new Error( + "Invalid public key format - must contain at least 2 parts", + ), + ); + } + + const keyPattern = keyParts[1]; + conn.exec( + `grep -F "${keyPattern}" ~/.ssh/authorized_keys >/dev/null 2>&1; echo $?`, + (err, stream) => { + if (err) { + clearTimeout(verifyTimeout); + return rejectVerify(err); + } + + let output = ""; + stream.on("data", (data) => { + output += data.toString(); + }); + + stream.on("close", (code) => { + clearTimeout(verifyTimeout); + const verified = output.trim() === "0"; + resolveVerify(verified); + }); + }, + ); + }, + ); + + conn.end(); + + if (verifySuccess) { + resolve({ success: true, message: "SSH key deployed successfully" }); + } else { + resolve({ + success: false, + error: "Key deployment verification failed", + }); + } + } catch (error) { + conn.end(); + resolve({ + success: false, + error: error instanceof Error ? error.message : "Deployment failed", + }); + } + }); + + conn.on("error", (err) => { + clearTimeout(connectionTimeout); + let errorMessage = err.message; + + if ( + err.message.includes("All configured authentication methods failed") + ) { + errorMessage = + "Authentication failed. Please check your credentials and ensure the SSH service is running."; + } else if ( + err.message.includes("ENOTFOUND") || + err.message.includes("ENOENT") + ) { + errorMessage = "Could not resolve hostname or connect to server."; + } else if (err.message.includes("ECONNREFUSED")) { + errorMessage = + "Connection refused. The server may not be running or the port may be incorrect."; + } else if (err.message.includes("ETIMEDOUT")) { + errorMessage = + "Connection timed out. Check your network connection and server availability."; + } else if ( + err.message.includes("authentication failed") || + err.message.includes("Permission denied") + ) { + errorMessage = + "Authentication failed. Please check your username and password/key."; + } + + resolve({ success: false, error: errorMessage }); + }); + + try { + const connectionConfig: any = { + host: hostConfig.ip, + port: hostConfig.port || 22, + username: hostConfig.username, + readyTimeout: 60000, + keepaliveInterval: 30000, + keepaliveCountMax: 3, + tcpKeepAlive: true, + tcpKeepAliveInitialDelay: 30000, + algorithms: { + kex: [ + "diffie-hellman-group14-sha256", + "diffie-hellman-group14-sha1", + "diffie-hellman-group1-sha1", + "diffie-hellman-group-exchange-sha256", + "diffie-hellman-group-exchange-sha1", + "ecdh-sha2-nistp256", + "ecdh-sha2-nistp384", + "ecdh-sha2-nistp521", + ], + cipher: [ + "aes128-ctr", + "aes192-ctr", + "aes256-ctr", + "aes128-gcm@openssh.com", + "aes256-gcm@openssh.com", + "aes128-cbc", + "aes192-cbc", + "aes256-cbc", + "3des-cbc", + ], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], + compress: ["none", "zlib@openssh.com", "zlib"], + }, + }; + + if (hostConfig.authType === "password" && hostConfig.password) { + connectionConfig.password = hostConfig.password; + } else if (hostConfig.authType === "key" && hostConfig.privateKey) { + try { + if ( + !hostConfig.privateKey.includes("-----BEGIN") || + !hostConfig.privateKey.includes("-----END") + ) { + throw new Error("Invalid private key format"); + } + + const cleanKey = hostConfig.privateKey + .trim() + .replace(/\r\n/g, "\n") + .replace(/\r/g, "\n"); + + connectionConfig.privateKey = Buffer.from(cleanKey, "utf8"); + + if (hostConfig.keyPassword) { + connectionConfig.passphrase = hostConfig.keyPassword; + } + } catch (keyError) { + clearTimeout(connectionTimeout); + resolve({ + success: false, + error: `Invalid SSH key format: ${keyError instanceof Error ? keyError.message : "Unknown error"}`, + }); + return; + } + } else { + clearTimeout(connectionTimeout); + resolve({ + success: false, + error: `Invalid authentication configuration. Auth type: ${hostConfig.authType}, has password: ${!!hostConfig.password}, has key: ${!!hostConfig.privateKey}`, + }); + return; + } + + conn.connect(connectionConfig); + } catch (error) { + clearTimeout(connectionTimeout); + resolve({ + success: false, + error: error instanceof Error ? error.message : "Connection failed", + }); + } + }); +} + +// Deploy SSH Key to Host endpoint +// POST /credentials/:id/deploy-to-host +router.post( + "/:id/deploy-to-host", + authenticateJWT, + async (req: Request, res: Response) => { + const credentialId = parseInt(req.params.id); + const { targetHostId } = req.body; + + if (!credentialId || !targetHostId) { + return res.status(400).json({ + success: false, + error: "Credential ID and target host ID are required", + }); + } + + try { + const userId = (req as any).userId; + if (!userId) { + return res.status(401).json({ + success: false, + error: "Authentication required", + }); + } + + const { SimpleDBOps } = await import("../../utils/simple-db-ops.js"); + const credential = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where(eq(sshCredentials.id, credentialId)) + .limit(1), + "ssh_credentials", + userId, + ); + + if (!credential || credential.length === 0) { + return res.status(404).json({ + success: false, + error: "Credential not found", + }); + } + + const credData = credential[0]; + + if (credData.authType !== "key") { + return res.status(400).json({ + success: false, + error: "Only SSH key-based credentials can be deployed", + }); + } + + if (!credData.publicKey) { + return res.status(400).json({ + success: false, + error: "Public key is required for deployment", + }); + } + const targetHost = await SimpleDBOps.select( + db.select().from(sshData).where(eq(sshData.id, targetHostId)).limit(1), + "ssh_data", + userId, + ); + + if (!targetHost || targetHost.length === 0) { + return res.status(404).json({ + success: false, + error: "Target host not found", + }); + } + + const hostData = targetHost[0]; + + let hostConfig = { + ip: hostData.ip, + port: hostData.port, + username: hostData.username, + authType: hostData.authType, + password: hostData.password, + privateKey: hostData.key, + keyPassword: hostData.keyPassword, + }; + + if (hostData.authType === "credential" && hostData.credentialId) { + const userId = (req as any).userId; + if (!userId) { + return res.status(400).json({ + success: false, + error: "Authentication required for credential resolution", + }); + } + + try { + const { SimpleDBOps } = await import("../../utils/simple-db-ops.js"); + const hostCredential = await SimpleDBOps.select( + db + .select() + .from(sshCredentials) + .where(eq(sshCredentials.id, hostData.credentialId)) + .limit(1), + "ssh_credentials", + userId, + ); + + if (hostCredential && hostCredential.length > 0) { + const cred = hostCredential[0]; + + hostConfig.authType = cred.authType; + hostConfig.username = cred.username; + + if (cred.authType === "password") { + hostConfig.password = cred.password; + } else if (cred.authType === "key") { + hostConfig.privateKey = cred.privateKey || cred.key; + hostConfig.keyPassword = cred.keyPassword; + } + } else { + return res.status(400).json({ + success: false, + error: "Host credential not found", + }); + } + } catch (error) { + return res.status(500).json({ + success: false, + error: "Failed to resolve host credentials", + }); + } + } + + const deployResult = await deploySSHKeyToHost( + hostConfig, + credData.publicKey, + credData, + ); + + if (deployResult.success) { + res.json({ + success: true, + message: deployResult.message || "SSH key deployed successfully", + }); + } else { + res.status(500).json({ + success: false, + error: deployResult.error || "Deployment failed", + }); + } + } catch (error) { + res.status(500).json({ + success: false, + error: + error instanceof Error ? error.message : "Failed to deploy SSH key", + }); + } + }, +); + export default router; diff --git a/src/backend/database/routes/ssh.ts b/src/backend/database/routes/ssh.ts index b08d39dd..6420aa74 100644 --- a/src/backend/database/routes/ssh.ts +++ b/src/backend/database/routes/ssh.ts @@ -8,20 +8,21 @@ import { fileManagerPinned, fileManagerShortcuts, } from "../db/schema.js"; -import { eq, and, desc } from "drizzle-orm"; +import { eq, and, desc, isNotNull, or } from "drizzle-orm"; import type { Request, Response, NextFunction } from "express"; import jwt from "jsonwebtoken"; import multer from "multer"; import { sshLogger } from "../../utils/logger.js"; +import { SimpleDBOps } from "../../utils/simple-db-ops.js"; +import { AuthManager } from "../../utils/auth-manager.js"; +import { DataCrypto } from "../../utils/data-crypto.js"; +import { SystemCrypto } from "../../utils/system-crypto.js"; +import { DatabaseSaveTrigger } from "../db/index.js"; const router = express.Router(); const upload = multer({ storage: multer.memoryStorage() }); -interface JWTPayload { - userId: string; -} - function isNonEmptyString(value: any): value is string { return typeof value === "string" && value.trim().length > 0; } @@ -30,61 +31,148 @@ function isValidPort(port: any): port is number { return typeof port === "number" && port > 0 && port <= 65535; } -function authenticateJWT(req: Request, res: Response, next: NextFunction) { - const authHeader = req.headers.authorization; - if (!authHeader || !authHeader.startsWith("Bearer ")) { - sshLogger.warn("Missing or invalid Authorization header"); - return res - .status(401) - .json({ error: "Missing or invalid Authorization header" }); - } - const token = authHeader.split(" ")[1]; - const jwtSecret = process.env.JWT_SECRET || "secret"; - try { - const payload = jwt.verify(token, jwtSecret) as JWTPayload; - (req as any).userId = payload.userId; - next(); - } catch (err) { - sshLogger.warn("Invalid or expired token"); - return res.status(401).json({ error: "Invalid or expired token" }); - } -} +const authManager = AuthManager.getInstance(); +const authenticateJWT = authManager.createAuthMiddleware(); +const requireDataAccess = authManager.createDataAccessMiddleware(); -function isLocalhost(req: Request) { - const ip = req.ip || req.connection?.remoteAddress; - return ip === "127.0.0.1" || ip === "::1" || ip === "::ffff:127.0.0.1"; -} - -// Internal-only endpoint for autostart (no JWT) router.get("/db/host/internal", async (req: Request, res: Response) => { - if (!isLocalhost(req) && req.headers["x-internal-request"] !== "1") { - sshLogger.warn("Unauthorized attempt to access internal SSH host endpoint"); - return res.status(403).json({ error: "Forbidden" }); - } try { - const data = await db.select().from(sshData); - const result = data.map((row: any) => { - return { - ...row, - tags: - typeof row.tags === "string" - ? row.tags - ? row.tags.split(",").filter(Boolean) - : [] - : [], - pin: !!row.pin, - enableTerminal: !!row.enableTerminal, - enableTunnel: !!row.enableTunnel, - tunnelConnections: row.tunnelConnections - ? JSON.parse(row.tunnelConnections) - : [], - enableFileManager: !!row.enableFileManager, - }; - }); + const internalToken = req.headers["x-internal-auth-token"]; + const systemCrypto = SystemCrypto.getInstance(); + const expectedToken = await systemCrypto.getInternalAuthToken(); + + if (internalToken !== expectedToken) { + sshLogger.warn( + "Unauthorized attempt to access internal SSH host endpoint", + { + source: req.ip, + userAgent: req.headers["user-agent"], + providedToken: internalToken ? "present" : "missing", + }, + ); + return res.status(403).json({ error: "Forbidden" }); + } + } catch (error) { + sshLogger.error("Failed to validate internal auth token", error); + return res.status(500).json({ error: "Internal server error" }); + } + + try { + const autostartHosts = await db + .select() + .from(sshData) + .where( + and( + eq(sshData.enableTunnel, true), + isNotNull(sshData.tunnelConnections), + ), + ); + + const result = autostartHosts + .map((host) => { + const tunnelConnections = host.tunnelConnections + ? JSON.parse(host.tunnelConnections) + : []; + + const hasAutoStartTunnels = tunnelConnections.some( + (tunnel: any) => tunnel.autoStart, + ); + + if (!hasAutoStartTunnels) { + return null; + } + + return { + id: host.id, + userId: host.userId, + name: host.name || `autostart-${host.id}`, + ip: host.ip, + port: host.port, + username: host.username, + password: host.autostartPassword, + key: host.autostartKey, + keyPassword: host.autostartKeyPassword, + autostartPassword: host.autostartPassword, + autostartKey: host.autostartKey, + autostartKeyPassword: host.autostartKeyPassword, + authType: host.authType, + keyType: host.keyType, + credentialId: host.credentialId, + enableTunnel: true, + tunnelConnections: tunnelConnections.filter( + (tunnel: any) => tunnel.autoStart, + ), + pin: !!host.pin, + enableTerminal: !!host.enableTerminal, + enableFileManager: !!host.enableFileManager, + tags: ["autostart"], + }; + }) + .filter(Boolean); + res.json(result); } catch (err) { - sshLogger.error("Failed to fetch SSH data (internal)", err); - res.status(500).json({ error: "Failed to fetch SSH data" }); + sshLogger.error("Failed to fetch autostart SSH data", err); + res.status(500).json({ error: "Failed to fetch autostart SSH data" }); + } +}); + +router.get("/db/host/internal/all", async (req: Request, res: Response) => { + try { + const internalToken = req.headers["x-internal-auth-token"]; + if (!internalToken) { + return res + .status(401) + .json({ error: "Internal authentication token required" }); + } + + const systemCrypto = SystemCrypto.getInstance(); + const expectedToken = await systemCrypto.getInternalAuthToken(); + + if (internalToken !== expectedToken) { + return res + .status(401) + .json({ error: "Invalid internal authentication token" }); + } + + const allHosts = await db.select().from(sshData); + + const result = allHosts.map((host) => { + const tunnelConnections = host.tunnelConnections + ? JSON.parse(host.tunnelConnections) + : []; + + return { + id: host.id, + userId: host.userId, + name: host.name || `${host.username}@${host.ip}`, + ip: host.ip, + port: host.port, + username: host.username, + password: host.autostartPassword || host.password, + key: host.autostartKey || host.key, + keyPassword: host.autostartKeyPassword || host.keyPassword, + autostartPassword: host.autostartPassword, + autostartKey: host.autostartKey, + autostartKeyPassword: host.autostartKeyPassword, + authType: host.authType, + keyType: host.keyType, + credentialId: host.credentialId, + enableTunnel: !!host.enableTunnel, + tunnelConnections: tunnelConnections, + pin: !!host.pin, + enableTerminal: !!host.enableTerminal, + enableFileManager: !!host.enableFileManager, + defaultPath: host.defaultPath, + createdAt: host.createdAt, + updatedAt: host.updatedAt, + }; + }); + + res.json(result); + } catch (err) { + sshLogger.error("Failed to fetch all hosts for internal use", err); + res.status(500).json({ error: "Failed to fetch all hosts" }); } }); @@ -93,6 +181,7 @@ router.get("/db/host/internal", async (req: Request, res: Response) => { router.post( "/db/host", authenticateJWT, + requireDataAccess, upload.single("key"), async (req: Request, res: Response) => { const userId = (req as any).userId; @@ -192,12 +281,22 @@ router.post( sshDataObj.keyPassword = keyPassword || null; sshDataObj.keyType = keyType; sshDataObj.password = null; + } else { + sshDataObj.password = null; + sshDataObj.key = null; + sshDataObj.keyPassword = null; + sshDataObj.keyType = null; } try { - const result = await db.insert(sshData).values(sshDataObj).returning(); + const result = await SimpleDBOps.insert( + sshData, + "ssh_data", + sshDataObj, + userId, + ); - if (result.length === 0) { + if (!result) { sshLogger.warn("No host returned after creation", { operation: "host_create", userId, @@ -208,7 +307,7 @@ router.post( return res.status(500).json({ error: "Failed to create host" }); } - const createdHost = result[0]; + const createdHost = result; const baseHost = { ...createdHost, tags: @@ -372,18 +471,33 @@ router.put( sshDataObj.keyType = keyType; } sshDataObj.password = null; + } else { + // For credential auth + sshDataObj.password = null; + sshDataObj.key = null; + sshDataObj.keyPassword = null; + sshDataObj.keyType = null; } try { - await db - .update(sshData) - .set(sshDataObj) - .where(and(eq(sshData.id, Number(hostId)), eq(sshData.userId, userId))); + await SimpleDBOps.update( + sshData, + "ssh_data", + and(eq(sshData.id, Number(hostId)), eq(sshData.userId, userId)), + sshDataObj, + userId, + ); - const updatedHosts = await db - .select() - .from(sshData) - .where(and(eq(sshData.id, Number(hostId)), eq(sshData.userId, userId))); + const updatedHosts = await SimpleDBOps.select( + db + .select() + .from(sshData) + .where( + and(eq(sshData.id, Number(hostId)), eq(sshData.userId, userId)), + ), + "ssh_data", + userId, + ); if (updatedHosts.length === 0) { sshLogger.warn("Updated host not found after update", { @@ -455,10 +569,11 @@ router.get("/db/host", authenticateJWT, async (req: Request, res: Response) => { return res.status(400).json({ error: "Invalid userId" }); } try { - const data = await db - .select() - .from(sshData) - .where(eq(sshData.userId, userId)); + const data = await SimpleDBOps.select( + db.select().from(sshData).where(eq(sshData.userId, userId)), + "ssh_data", + userId, + ); const result = await Promise.all( data.map(async (row: any) => { @@ -1074,14 +1189,16 @@ router.put( } try { - const updatedHosts = await db - .update(sshData) - .set({ + const updatedHosts = await SimpleDBOps.update( + sshData, + "ssh_data", + and(eq(sshData.userId, userId), eq(sshData.folder, oldName)), + { folder: newName, updatedAt: new Date().toISOString(), - }) - .where(and(eq(sshData.userId, userId), eq(sshData.folder, oldName))) - .returning(); + }, + userId, + ); const updatedCredentials = await db .update(sshCredentials) @@ -1097,6 +1214,9 @@ router.put( ) .returning(); + // Trigger database save after folder rename + DatabaseSaveTrigger.triggerSave("folder_rename"); + res.json({ message: "Folder renamed successfully", updatedHosts: updatedHosts.length, @@ -1221,7 +1341,7 @@ router.post( updatedAt: new Date().toISOString(), }; - await db.insert(sshData).values(sshDataObj); + await SimpleDBOps.insert(sshData, "ssh_data", sshDataObj, userId); results.success++; } catch (error) { results.failed++; @@ -1240,4 +1360,248 @@ router.post( }, ); +// Route: Enable autostart for SSH configuration (requires JWT) +// POST /ssh/autostart/enable +router.post( + "/autostart/enable", + authenticateJWT, + requireDataAccess, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { sshConfigId } = req.body; + + if (!sshConfigId || typeof sshConfigId !== "number") { + sshLogger.warn( + "Missing or invalid sshConfigId in autostart enable request", + { + operation: "autostart_enable", + userId, + sshConfigId, + }, + ); + return res.status(400).json({ error: "Valid sshConfigId is required" }); + } + + try { + const userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + sshLogger.warn( + "User attempted to enable autostart without unlocked data", + { + operation: "autostart_enable_failed", + userId, + sshConfigId, + reason: "data_locked", + }, + ); + return res.status(400).json({ + error: "Failed to enable autostart. Ensure user data is unlocked.", + }); + } + + const sshConfig = await db + .select() + .from(sshData) + .where(and(eq(sshData.id, sshConfigId), eq(sshData.userId, userId))); + + if (sshConfig.length === 0) { + sshLogger.warn("SSH config not found for autostart enable", { + operation: "autostart_enable_failed", + userId, + sshConfigId, + reason: "config_not_found", + }); + return res.status(404).json({ + error: "SSH configuration not found", + }); + } + + const config = sshConfig[0]; + + const decryptedConfig = DataCrypto.decryptRecord( + "ssh_data", + config, + userId, + userDataKey, + ); + + let updatedTunnelConnections = config.tunnelConnections; + if (config.tunnelConnections) { + try { + const tunnelConnections = JSON.parse(config.tunnelConnections); + + const resolvedConnections = await Promise.all( + tunnelConnections.map(async (tunnel: any) => { + if ( + tunnel.autoStart && + tunnel.endpointHost && + !tunnel.endpointPassword && + !tunnel.endpointKey + ) { + const endpointHosts = await db + .select() + .from(sshData) + .where(eq(sshData.userId, userId)); + + const endpointHost = endpointHosts.find( + (h) => + h.name === tunnel.endpointHost || + `${h.username}@${h.ip}` === tunnel.endpointHost, + ); + + if (endpointHost) { + const decryptedEndpoint = DataCrypto.decryptRecord( + "ssh_data", + endpointHost, + userId, + userDataKey, + ); + + return { + ...tunnel, + endpointPassword: decryptedEndpoint.password || null, + endpointKey: decryptedEndpoint.key || null, + endpointKeyPassword: decryptedEndpoint.keyPassword || null, + endpointAuthType: endpointHost.authType, + }; + } + } + return tunnel; + }), + ); + + updatedTunnelConnections = JSON.stringify(resolvedConnections); + } catch (error) { + sshLogger.warn("Failed to update tunnel connections", { + operation: "tunnel_connections_update_failed", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + + const updateResult = await db + .update(sshData) + .set({ + autostartPassword: decryptedConfig.password || null, + autostartKey: decryptedConfig.key || null, + autostartKeyPassword: decryptedConfig.keyPassword || null, + tunnelConnections: updatedTunnelConnections, + }) + .where(eq(sshData.id, sshConfigId)); + + try { + await DatabaseSaveTrigger.triggerSave(); + } catch (saveError) { + sshLogger.warn("Database save failed after autostart", { + operation: "autostart_db_save_failed", + error: + saveError instanceof Error ? saveError.message : "Unknown error", + }); + } + + res.json({ + message: "AutoStart enabled successfully", + sshConfigId, + }); + } catch (error) { + sshLogger.error("Error enabling autostart", error, { + operation: "autostart_enable_error", + userId, + sshConfigId, + }); + res.status(500).json({ error: "Internal server error" }); + } + }, +); + +// Route: Disable autostart for SSH configuration (requires JWT) +// DELETE /ssh/autostart/disable +router.delete( + "/autostart/disable", + authenticateJWT, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + const { sshConfigId } = req.body; + + if (!sshConfigId || typeof sshConfigId !== "number") { + sshLogger.warn( + "Missing or invalid sshConfigId in autostart disable request", + { + operation: "autostart_disable", + userId, + sshConfigId, + }, + ); + return res.status(400).json({ error: "Valid sshConfigId is required" }); + } + + try { + const result = await db + .update(sshData) + .set({ + autostartPassword: null, + autostartKey: null, + autostartKeyPassword: null, + }) + .where(and(eq(sshData.id, sshConfigId), eq(sshData.userId, userId))); + + res.json({ + message: "AutoStart disabled successfully", + sshConfigId, + }); + } catch (error) { + sshLogger.error("Error disabling autostart", error, { + operation: "autostart_disable_error", + userId, + sshConfigId, + }); + res.status(500).json({ error: "Internal server error" }); + } + }, +); + +// Route: Get autostart status for user's SSH configurations (requires JWT) +// GET /ssh/autostart/status +router.get( + "/autostart/status", + authenticateJWT, + async (req: Request, res: Response) => { + const userId = (req as any).userId; + + try { + const autostartConfigs = await db + .select() + .from(sshData) + .where( + and( + eq(sshData.userId, userId), + or( + isNotNull(sshData.autostartPassword), + isNotNull(sshData.autostartKey), + ), + ), + ); + + const statusList = autostartConfigs.map((config) => ({ + sshConfigId: config.id, + host: config.ip, + port: config.port, + username: config.username, + authType: config.authType, + })); + + res.json({ + autostart_configs: statusList, + total_count: statusList.length, + }); + } catch (error) { + sshLogger.error("Error getting autostart status", error, { + operation: "autostart_status_error", + userId, + }); + res.status(500).json({ error: "Internal server error" }); + } + }, +); + export default router; diff --git a/src/backend/database/routes/users.ts b/src/backend/database/routes/users.ts index fe4a7a10..78f6578d 100644 --- a/src/backend/database/routes/users.ts +++ b/src/backend/database/routes/users.ts @@ -1,4 +1,5 @@ import express from "express"; +import crypto from "crypto"; import { db } from "../db/index.js"; import { users, @@ -7,15 +8,21 @@ import { fileManagerPinned, fileManagerShortcuts, dismissedAlerts, + settings, } from "../db/schema.js"; import { eq, and } from "drizzle-orm"; import bcrypt from "bcryptjs"; import { nanoid } from "nanoid"; -import jwt from "jsonwebtoken"; import speakeasy from "speakeasy"; import QRCode from "qrcode"; -import type { Request, Response, NextFunction } from "express"; -import { authLogger, apiLogger } from "../../utils/logger.js"; +import type { Request, Response } from "express"; +import { authLogger } from "../../utils/logger.js"; +import { AuthManager } from "../../utils/auth-manager.js"; +import { UserCrypto } from "../../utils/user-crypto.js"; +import { DataCrypto } from "../../utils/data-crypto.js"; +import { LazyFieldEncryption } from "../../utils/lazy-field-encryption.js"; + +const authManager = AuthManager.getInstance(); async function verifyOIDCToken( idToken: string, @@ -70,12 +77,8 @@ async function verifyOIDCToken( ); } } else { - authLogger.error( - `JWKS fetch failed from ${url}: ${response.status} ${response.statusText}`, - ); } } catch (error) { - authLogger.error(`JWKS fetch error from ${url}:`, error); continue; } } @@ -112,7 +115,6 @@ async function verifyOIDCToken( return payload; } catch (error) { - authLogger.error("OIDC token verification failed:", error); throw error; } } @@ -129,35 +131,9 @@ interface JWTPayload { exp?: number; } -// JWT authentication middleware -function authenticateJWT(req: Request, res: Response, next: NextFunction) { - const authHeader = req.headers["authorization"]; - if (!authHeader || !authHeader.startsWith("Bearer ")) { - authLogger.warn("Missing or invalid Authorization header", { - operation: "auth", - method: req.method, - url: req.url, - }); - return res - .status(401) - .json({ error: "Missing or invalid Authorization header" }); - } - const token = authHeader.split(" ")[1]; - const jwtSecret = process.env.JWT_SECRET || "secret"; - try { - const payload = jwt.verify(token, jwtSecret) as JWTPayload; - (req as any).userId = payload.userId; - next(); - } catch (err) { - authLogger.warn("Invalid or expired token", { - operation: "auth", - method: req.method, - url: req.url, - error: err, - }); - return res.status(401).json({ error: "Invalid or expired token" }); - } -} +const authenticateJWT = authManager.createAuthMiddleware(); +const requireAdmin = authManager.createAdminMiddleware(); +const requireDataAccess = authManager.createDataAccessMiddleware(); // Route: Create traditional user (username/password) // POST /users/create @@ -208,19 +184,10 @@ router.post("/create", async (req, res) => { } let isFirstUser = false; - try { - const countResult = db.$client - .prepare("SELECT COUNT(*) as count FROM users") - .get(); - isFirstUser = ((countResult as any)?.count || 0) === 0; - } catch (e) { - isFirstUser = true; - authLogger.warn("Failed to check user count, assuming first user", { - operation: "user_create", - username, - error: e, - }); - } + const countResult = db.$client + .prepare("SELECT COUNT(*) as count FROM users") + .get(); + isFirstUser = ((countResult as any)?.count || 0) === 0; const saltRounds = parseInt(process.env.SALT || "10", 10); const password_hash = await bcrypt.hash(password, saltRounds); @@ -244,6 +211,23 @@ router.post("/create", async (req, res) => { totp_backup_codes: null, }); + try { + await authManager.registerUser(id, password); + } catch (encryptionError) { + await db.delete(users).where(eq(users.id, id)); + authLogger.error( + "Failed to setup user encryption, user creation rolled back", + encryptionError, + { + operation: "user_create_encryption_failed", + userId: id, + }, + ); + return res.status(500).json({ + error: "Failed to setup user security - user creation cancelled", + }); + } + authLogger.success( `Traditional user created: ${username} (is_admin: ${isFirstUser})`, { @@ -343,11 +327,54 @@ router.post("/oidc-config", authenticateJWT, async (req, res) => { scopes: scopes || "openid email profile", }; + let encryptedConfig; + try { + const adminDataKey = DataCrypto.getUserDataKey(userId); + if (adminDataKey) { + const configWithId = { ...config, id: `oidc-config-${userId}` }; + encryptedConfig = DataCrypto.encryptRecord( + "settings", + configWithId, + userId, + adminDataKey, + ); + authLogger.info("OIDC configuration encrypted with admin data key", { + operation: "oidc_config_encrypt", + userId, + }); + } else { + encryptedConfig = { + ...config, + client_secret: `encrypted:${Buffer.from(client_secret).toString("base64")}`, // Simple base64 encoding + }; + authLogger.warn( + "OIDC configuration stored with basic encoding - admin should re-save with password", + { + operation: "oidc_config_basic_encoding", + userId, + }, + ); + } + } catch (encryptError) { + authLogger.error( + "Failed to encrypt OIDC configuration, storing with basic encoding", + encryptError, + { + operation: "oidc_config_encrypt_failed", + userId, + }, + ); + encryptedConfig = { + ...config, + client_secret: `encoded:${Buffer.from(client_secret).toString("base64")}`, + }; + } + db.$client .prepare( "INSERT OR REPLACE INTO settings (key, value) VALUES ('oidc_config', ?)", ) - .run(JSON.stringify(config)); + .run(JSON.stringify(encryptedConfig)); authLogger.info("OIDC configuration updated", { operation: "oidc_update", userId, @@ -383,7 +410,7 @@ router.delete("/oidc-config", authenticateJWT, async (req, res) => { } }); -// Route: Get OIDC configuration +// Route: Get OIDC configuration (public - needed for login page) // GET /users/oidc-config router.get("/oidc-config", async (req, res) => { try { @@ -393,7 +420,67 @@ router.get("/oidc-config", async (req, res) => { if (!row) { return res.json(null); } - res.json(JSON.parse((row as any).value)); + + let config = JSON.parse((row as any).value); + + if (config.client_secret) { + if (config.client_secret.startsWith("encrypted:")) { + const authHeader = req.headers["authorization"]; + if (authHeader?.startsWith("Bearer ")) { + const token = authHeader.split(" ")[1]; + const authManager = AuthManager.getInstance(); + const payload = await authManager.verifyJWTToken(token); + + if (payload) { + const userId = payload.userId; + const user = await db + .select() + .from(users) + .where(eq(users.id, userId)); + + if (user && user.length > 0 && user[0].is_admin) { + try { + const adminDataKey = DataCrypto.getUserDataKey(userId); + if (adminDataKey) { + config = DataCrypto.decryptRecord( + "settings", + config, + userId, + adminDataKey, + ); + } else { + config.client_secret = "[ENCRYPTED - PASSWORD REQUIRED]"; + } + } catch (decryptError) { + authLogger.warn("Failed to decrypt OIDC config for admin", { + operation: "oidc_config_decrypt_failed", + userId, + }); + config.client_secret = "[ENCRYPTED - DECRYPTION FAILED]"; + } + } else { + config.client_secret = "[ENCRYPTED - ADMIN ONLY]"; + } + } else { + config.client_secret = "[ENCRYPTED - AUTH REQUIRED]"; + } + } else { + config.client_secret = "[ENCRYPTED - AUTH REQUIRED]"; + } + } else if (config.client_secret.startsWith("encoded:")) { + try { + const decoded = Buffer.from( + config.client_secret.substring(8), + "base64", + ).toString("utf8"); + config.client_secret = decoded; + } catch { + config.client_secret = "[ENCODING ERROR]"; + } + } + } + + res.json(config); } catch (err) { authLogger.error("Failed to get OIDC config", err); res.status(500).json({ error: "Failed to get OIDC config" }); @@ -421,7 +508,7 @@ router.get("/oidc/authorize", async (req, res) => { "http://localhost:5173"; if (origin.includes("localhost")) { - origin = "http://localhost:8081"; + origin = "http://localhost:30001"; } const redirectUri = `${origin}/users/oidc/callback`; @@ -565,10 +652,6 @@ router.get("/oidc/callback", async (req, res) => { config.client_id, ); } catch (error) { - authLogger.error( - "OIDC token verification failed, trying userinfo endpoints", - error, - ); try { const parts = tokenData.id_token.split("."); if (parts.length === 3) { @@ -654,14 +737,10 @@ router.get("/oidc/callback", async (req, res) => { let isFirstUser = false; if (!user || user.length === 0) { - try { - const countResult = db.$client - .prepare("SELECT COUNT(*) as count FROM users") - .get(); - isFirstUser = ((countResult as any)?.count || 0) === 0; - } catch (e) { - isFirstUser = true; - } + const countResult = db.$client + .prepare("SELECT COUNT(*) as count FROM users") + .get(); + isFirstUser = ((countResult as any)?.count || 0) === 0; const id = nanoid(); await db.insert(users).values({ @@ -681,6 +760,23 @@ router.get("/oidc/callback", async (req, res) => { scopes: config.scopes, }); + try { + await authManager.registerOIDCUser(id); + } catch (encryptionError) { + await db.delete(users).where(eq(users.id, id)); + authLogger.error( + "Failed to setup OIDC user encryption, user creation rolled back", + encryptionError, + { + operation: "oidc_user_create_encryption_failed", + userId: id, + }, + ); + return res.status(500).json({ + error: "Failed to setup user security - user creation cancelled", + }); + } + user = await db.select().from(users).where(eq(users.id, id)); } else { await db @@ -693,8 +789,16 @@ router.get("/oidc/callback", async (req, res) => { const userRecord = user[0]; - const jwtSecret = process.env.JWT_SECRET || "secret"; - const token = jwt.sign({ userId: userRecord.id }, jwtSecret, { + try { + await authManager.authenticateOIDCUser(userRecord.id); + } catch (setupError) { + authLogger.error("Failed to setup OIDC user encryption", setupError, { + operation: "oidc_user_encryption_setup_failed", + userId: userRecord.id, + }); + } + + const token = await authManager.generateJWTToken(userRecord.id, { expiresIn: "50d", }); @@ -706,9 +810,14 @@ router.get("/oidc/callback", async (req, res) => { const redirectUrl = new URL(frontendUrl); redirectUrl.searchParams.set("success", "true"); - redirectUrl.searchParams.set("token", token); - res.redirect(redirectUrl.toString()); + return res + .cookie( + "jwt", + token, + authManager.getSecureCookieOptions(req, 50 * 24 * 60 * 60 * 1000), + ) + .redirect(redirectUrl.toString()); } catch (err) { authLogger.error("OIDC callback failed", err); @@ -775,33 +884,101 @@ router.post("/login", async (req, res) => { }); return res.status(401).json({ error: "Incorrect password" }); } - const jwtSecret = process.env.JWT_SECRET || "secret"; - const token = jwt.sign({ userId: userRecord.id }, jwtSecret, { - expiresIn: "50d", - }); + + try { + const kekSalt = await db + .select() + .from(settings) + .where(eq(settings.key, `user_kek_salt_${userRecord.id}`)); + + if (kekSalt.length === 0) { + await authManager.registerUser(userRecord.id, password); + } + } catch (setupError) { + // Continue if setup fails - authenticateUser will handle it + } + + const dataUnlocked = await authManager.authenticateUser( + userRecord.id, + password, + ); + if (!dataUnlocked) { + return res.status(401).json({ error: "Incorrect password" }); + } if (userRecord.totp_enabled) { - const tempToken = jwt.sign( - { userId: userRecord.id, pending_totp: true }, - jwtSecret, - { expiresIn: "10m" }, - ); + const tempToken = await authManager.generateJWTToken(userRecord.id, { + pendingTOTP: true, + expiresIn: "10m", + }); return res.json({ + success: true, requires_totp: true, temp_token: tempToken, }); } - return res.json({ - token, + + const token = await authManager.generateJWTToken(userRecord.id, { + expiresIn: "24h", + }); + + authLogger.success(`User logged in successfully: ${username}`, { + operation: "user_login_success", + username, + userId: userRecord.id, + dataUnlocked: true, + }); + + const response: any = { + success: true, is_admin: !!userRecord.is_admin, username: userRecord.username, - }); + }; + + const isElectron = + req.headers["x-electron-app"] === "true" || + req.headers["X-Electron-App"] === "true"; + + if (isElectron) { + response.token = token; + } + + return res + .cookie( + "jwt", + token, + authManager.getSecureCookieOptions(req, 24 * 60 * 60 * 1000), + ) + .json(response); } catch (err) { authLogger.error("Failed to log in user", err); return res.status(500).json({ error: "Login failed" }); } }); +// Route: Logout user +// POST /users/logout +router.post("/logout", async (req, res) => { + try { + const userId = (req as any).userId; + + if (userId) { + authManager.logoutUser(userId); + authLogger.info("User logged out", { + operation: "user_logout", + userId, + }); + } + + return res + .clearCookie("jwt", authManager.getSecureCookieOptions(req)) + .json({ success: true, message: "Logged out successfully" }); + } catch (err) { + authLogger.error("Logout failed", err); + return res.status(500).json({ error: "Logout failed" }); + } +}); + // Route: Get current user's info using JWT // GET /users/me router.get("/me", authenticateJWT, async (req: Request, res: Response) => { @@ -816,12 +993,16 @@ router.get("/me", authenticateJWT, async (req: Request, res: Response) => { authLogger.warn(`User not found for /users/me: ${userId}`); return res.status(401).json({ error: "User not found" }); } + + const isDataUnlocked = authManager.isUserUnlocked(userId); + res.json({ userId: user[0].id, username: user[0].username, is_admin: !!user[0].is_admin, is_oidc: !!user[0].is_oidc, totp_enabled: !!user[0].totp_enabled, + data_unlocked: isDataUnlocked, }); } catch (err) { authLogger.error("Failed to get username", err); @@ -829,10 +1010,34 @@ router.get("/me", authenticateJWT, async (req: Request, res: Response) => { } }); -// Route: Count users -// GET /users/count -router.get("/count", async (req, res) => { +// Route: Check if system requires initial setup (public - for first-time setup detection) +// GET /users/setup-required +router.get("/setup-required", async (req, res) => { try { + const countResult = db.$client + .prepare("SELECT COUNT(*) as count FROM users") + .get(); + const count = (countResult as any)?.count || 0; + + res.json({ + setup_required: count === 0, + }); + } catch (err) { + authLogger.error("Failed to check setup status", err); + res.status(500).json({ error: "Failed to check setup status" }); + } +}); + +// Route: Count users (admin only - for dashboard statistics) +// GET /users/count +router.get("/count", authenticateJWT, async (req, res) => { + const userId = (req as any).userId; + try { + const user = await db.select().from(users).where(eq(users.id, userId)); + if (!user[0] || !user[0].is_admin) { + return res.status(403).json({ error: "Admin access required" }); + } + const countResult = db.$client .prepare("SELECT COUNT(*) as count FROM users") .get(); @@ -846,7 +1051,7 @@ router.get("/count", async (req, res) => { // Route: DB health check (actually queries DB) // GET /users/db-health -router.get("/db-health", async (req, res) => { +router.get("/db-health", requireAdmin, async (req, res) => { try { db.$client.prepare("SELECT 1").get(); res.json({ status: "ok" }); @@ -856,7 +1061,7 @@ router.get("/db-health", async (req, res) => { } }); -// Route: Get registration allowed status +// Route: Get registration allowed status (public - needed for login page) // GET /users/registration-allowed router.get("/registration-allowed", async (req, res) => { try { @@ -977,7 +1182,7 @@ router.post("/initiate-reset", async (req, res) => { }); } - const resetCode = Math.floor(100000 + Math.random() * 900000).toString(); + const resetCode = crypto.randomInt(100000, 1000000).toString(); const expiresAt = new Date(Date.now() + 15 * 60 * 1000); db.$client @@ -1095,6 +1300,15 @@ router.post("/complete-reset", async (req, res) => { return res.status(400).json({ error: "Invalid temporary token" }); } + const user = await db + .select() + .from(users) + .where(eq(users.username, username)); + if (!user || user.length === 0) { + return res.status(404).json({ error: "User not found" }); + } + const userId = user[0].id; + const saltRounds = parseInt(process.env.SALT || "10", 10); const password_hash = await bcrypt.hash(newPassword, saltRounds); @@ -1103,6 +1317,8 @@ router.post("/complete-reset", async (req, res) => { .set({ password_hash }) .where(eq(users.username, username)); + authLogger.success(`Password successfully reset for user: ${username}`); + db.$client .prepare("DELETE FROM settings WHERE key = ?") .run(`reset_code_${username}`); @@ -1110,7 +1326,6 @@ router.post("/complete-reset", async (req, res) => { .prepare("DELETE FROM settings WHERE key = ?") .run(`temp_reset_token_${username}`); - authLogger.success(`Password successfully reset for user: ${username}`); res.json({ message: "Password has been successfully reset" }); } catch (err) { authLogger.error("Failed to complete password reset", err); @@ -1245,11 +1460,9 @@ router.post("/totp/verify-login", async (req, res) => { return res.status(400).json({ error: "Token and TOTP code are required" }); } - const jwtSecret = process.env.JWT_SECRET || "secret"; - try { - const decoded = jwt.verify(temp_token, jwtSecret) as any; - if (!decoded.pending_totp) { + const decoded = await authManager.verifyJWTToken(temp_token); + if (!decoded || !decoded.pendingTOTP) { return res.status(401).json({ error: "Invalid temporary token" }); } @@ -1267,17 +1480,42 @@ router.post("/totp/verify-login", async (req, res) => { return res.status(400).json({ error: "TOTP not enabled for this user" }); } + const userDataKey = authManager.getUserDataKey(userRecord.id); + if (!userDataKey) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } + + const totpSecret = LazyFieldEncryption.safeGetFieldValue( + userRecord.totp_secret, + userDataKey, + userRecord.id, + "totp_secret", + ); + const verified = speakeasy.totp.verify({ - secret: userRecord.totp_secret, + secret: totpSecret, encoding: "base32", token: totp_code, window: 2, }); if (!verified) { - const backupCodes = userRecord.totp_backup_codes - ? JSON.parse(userRecord.totp_backup_codes) - : []; + let backupCodes = []; + try { + backupCodes = userRecord.totp_backup_codes + ? JSON.parse(userRecord.totp_backup_codes) + : []; + } catch (parseError) { + backupCodes = []; + } + + if (!Array.isArray(backupCodes)) { + backupCodes = []; + } + const backupIndex = backupCodes.indexOf(totp_code); if (backupIndex === -1) { @@ -1291,15 +1529,44 @@ router.post("/totp/verify-login", async (req, res) => { .where(eq(users.id, userRecord.id)); } - const token = jwt.sign({ userId: userRecord.id }, jwtSecret, { + const token = await authManager.generateJWTToken(userRecord.id, { expiresIn: "50d", }); - return res.json({ - token, + const isElectron = + req.headers["x-electron-app"] === "true" || + req.headers["X-Electron-App"] === "true"; + + const isDataUnlocked = authManager.isUserUnlocked(userRecord.id); + + if (!isDataUnlocked) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } + + const response: any = { + success: true, is_admin: !!userRecord.is_admin, username: userRecord.username, - }); + userId: userRecord.id, + is_oidc: !!userRecord.is_oidc, + totp_enabled: !!userRecord.totp_enabled, + data_unlocked: isDataUnlocked, + }; + + if (isElectron) { + response.token = token; + } + + return res + .cookie( + "jwt", + token, + authManager.getSecureCookieOptions(req, 50 * 24 * 60 * 60 * 1000), + ) + .json(response); } catch (err) { authLogger.error("TOTP verification failed", err); return res.status(500).json({ error: "TOTP verification failed" }); @@ -1606,4 +1873,117 @@ router.delete("/delete-user", authenticateJWT, async (req, res) => { } }); +// Route: User data unlock - used when session expires +// POST /users/unlock-data +router.post("/unlock-data", authenticateJWT, async (req, res) => { + const userId = (req as any).userId; + const { password } = req.body; + + if (!password) { + return res.status(400).json({ error: "Password is required" }); + } + + try { + const unlocked = await authManager.authenticateUser(userId, password); + if (unlocked) { + res.json({ + success: true, + message: "Data unlocked successfully", + }); + } else { + authLogger.warn("Failed to unlock user data - invalid password", { + operation: "user_data_unlock_failed", + userId, + }); + res.status(401).json({ error: "Invalid password" }); + } + } catch (err) { + authLogger.error("Data unlock failed", err, { + operation: "user_data_unlock_error", + userId, + }); + res.status(500).json({ error: "Failed to unlock data" }); + } +}); + +// Route: Check user data unlock status +// GET /users/data-status +router.get("/data-status", authenticateJWT, async (req, res) => { + const userId = (req as any).userId; + + try { + const isUnlocked = authManager.isUserUnlocked(userId); + res.json({ + unlocked: isUnlocked, + message: isUnlocked + ? "Data is unlocked" + : "Data is locked - re-authenticate with password", + }); + } catch (err) { + authLogger.error("Failed to check data status", err, { + operation: "data_status_check_failed", + userId, + }); + res.status(500).json({ error: "Failed to check data status" }); + } +}); + +// Route: Change user password (re-encrypt data keys) +// POST /users/change-password +router.post("/change-password", authenticateJWT, async (req, res) => { + const userId = (req as any).userId; + const { currentPassword, newPassword } = req.body; + + if (!currentPassword || !newPassword) { + return res.status(400).json({ + error: "Current password and new password are required", + }); + } + + if (newPassword.length < 8) { + return res.status(400).json({ + error: "New password must be at least 8 characters long", + }); + } + + try { + const success = await authManager.changeUserPassword( + userId, + currentPassword, + newPassword, + ); + + if (success) { + const saltRounds = parseInt(process.env.SALT || "10", 10); + const newPasswordHash = await bcrypt.hash(newPassword, saltRounds); + await db + .update(users) + .set({ password_hash: newPasswordHash }) + .where(eq(users.id, userId)); + + authLogger.success("User password changed successfully", { + operation: "password_change_success", + userId, + }); + + res.json({ + success: true, + message: "Password changed successfully", + }); + } else { + authLogger.warn("Password change failed - invalid current password", { + operation: "password_change_failed", + userId, + }); + res.status(401).json({ error: "Current password is incorrect" }); + } + } catch (err) { + authLogger.error("Password change failed", err, { + operation: "password_change_error", + userId, + }); + res.status(500).json({ error: "Failed to change password" }); + } +}); + export default router; diff --git a/src/backend/ssh/file-manager.ts b/src/backend/ssh/file-manager.ts index 20c8f816..4453adb7 100644 --- a/src/backend/ssh/file-manager.ts +++ b/src/backend/ssh/file-manager.ts @@ -1,16 +1,75 @@ import express from "express"; import cors from "cors"; +import cookieParser from "cookie-parser"; import { Client as SSHClient } from "ssh2"; -import { db } from "../database/db/index.js"; +import { getDb } from "../database/db/index.js"; import { sshCredentials } from "../database/db/schema.js"; import { eq, and } from "drizzle-orm"; import { fileLogger } from "../utils/logger.js"; +import { SimpleDBOps } from "../utils/simple-db-ops.js"; +import { AuthManager } from "../utils/auth-manager.js"; + +function isExecutableFile(permissions: string, fileName: string): boolean { + const hasExecutePermission = + permissions[3] === "x" || permissions[6] === "x" || permissions[9] === "x"; + + const scriptExtensions = [ + ".sh", + ".py", + ".pl", + ".rb", + ".js", + ".php", + ".bash", + ".zsh", + ".fish", + ]; + const hasScriptExtension = scriptExtensions.some((ext) => + fileName.toLowerCase().endsWith(ext), + ); + + const executableExtensions = [".bin", ".exe", ".out"]; + const hasExecutableExtension = executableExtensions.some((ext) => + fileName.toLowerCase().endsWith(ext), + ); + + const hasNoExtension = !fileName.includes(".") && hasExecutePermission; + + return ( + hasExecutePermission && + (hasScriptExtension || hasExecutableExtension || hasNoExtension) + ); +} const app = express(); app.use( cors({ - origin: "*", + origin: (origin, callback) => { + if (!origin) return callback(null, true); + + const allowedOrigins = [ + "http://localhost:5173", + "http://localhost:3000", + "http://127.0.0.1:5173", + "http://127.0.0.1:3000", + ]; + + if (origin.startsWith("https://")) { + return callback(null, true); + } + + if (origin.startsWith("http://")) { + return callback(null, true); + } + + if (allowedOrigins.includes(origin)) { + return callback(null, true); + } + + callback(new Error("Not allowed by CORS")); + }, + credentials: true, methods: ["GET", "POST", "PUT", "DELETE", "OPTIONS"], allowedHeaders: [ "Content-Type", @@ -20,9 +79,13 @@ app.use( ], }), ); -app.use(express.json({ limit: "100mb" })); -app.use(express.urlencoded({ limit: "100mb", extended: true })); -app.use(express.raw({ limit: "200mb", type: "application/octet-stream" })); +app.use(cookieParser()); +app.use(express.json({ limit: "1gb" })); +app.use(express.urlencoded({ limit: "1gb", extended: true })); +app.use(express.raw({ limit: "5gb", type: "application/octet-stream" })); + +const authManager = AuthManager.getInstance(); +app.use(authManager.createAuthMiddleware()); interface SSHSession { client: SSHClient; @@ -48,9 +111,36 @@ function scheduleSessionCleanup(sessionId: string) { const session = sshSessions[sessionId]; if (session) { if (session.timeout) clearTimeout(session.timeout); + + session.timeout = setTimeout( + () => { + cleanupSession(sessionId); + }, + 30 * 60 * 1000, + ); } } +function getMimeType(fileName: string): string { + const ext = fileName.split(".").pop()?.toLowerCase(); + const mimeTypes: Record = { + txt: "text/plain", + json: "application/json", + js: "text/javascript", + html: "text/html", + css: "text/css", + png: "image/png", + jpg: "image/jpeg", + jpeg: "image/jpeg", + gif: "image/gif", + pdf: "application/pdf", + zip: "application/zip", + tar: "application/x-tar", + gz: "application/gzip", + }; + return mimeTypes[ext || ""] || "application/octet-stream"; +} + app.post("/ssh/file_manager/ssh/connect", async (req, res) => { const { sessionId, @@ -63,9 +153,18 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { keyPassword, authType, credentialId, - userId, } = req.body; + const userId = (req as any).userId; + + if (!userId) { + fileLogger.error("SSH connection rejected: no authenticated user", { + operation: "file_connect_auth", + sessionId, + }); + return res.status(401).json({ error: "Authentication required" }); + } + if (!sessionId || !ip || !username || !port) { fileLogger.warn("Missing SSH connection parameters for file manager", { operation: "file_connect", @@ -85,51 +184,49 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { let resolvedCredentials = { password, sshKey, keyPassword, authType }; if (credentialId && hostId && userId) { try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, credentialId), - eq(sshCredentials.userId, userId), + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, credentialId), + eq(sshCredentials.userId, userId), + ), ), - ); + "ssh_credentials", + userId, + ); if (credentials.length > 0) { const credential = credentials[0]; resolvedCredentials = { password: credential.password, - sshKey: credential.key, + sshKey: credential.privateKey || credential.key, keyPassword: credential.keyPassword, authType: credential.authType, }; } else { - fileLogger.warn("No credentials found in database for file manager", { - operation: "file_connect", - sessionId, + fileLogger.warn(`No credentials found for host ${hostId}`, { + operation: "ssh_credentials", hostId, credentialId, userId, }); } } catch (error) { - fileLogger.warn( - "Failed to resolve credentials from database for file manager", - { - operation: "file_connect", - sessionId, - hostId, - credentialId, - error: error instanceof Error ? error.message : "Unknown error", - }, - ); + fileLogger.warn(`Failed to resolve credentials for host ${hostId}`, { + operation: "ssh_credentials", + hostId, + credentialId, + error: error instanceof Error ? error.message : "Unknown error", + }); } } else if (credentialId && hostId) { fileLogger.warn( "Missing userId for credential resolution in file manager", { - operation: "file_connect", - sessionId, + operation: "ssh_credentials", hostId, credentialId, hasUserId: !!userId, @@ -141,9 +238,9 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { host: ip, port: port || 22, username, - readyTimeout: 0, + readyTimeout: 60000, keepaliveInterval: 30000, - keepaliveCountMax: 0, + keepaliveCountMax: 3, algorithms: { kex: [ "diffie-hellman-group14-sha256", @@ -166,12 +263,29 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { "aes256-cbc", "3des-cbc", ], - hmac: ["hmac-sha2-256", "hmac-sha2-512", "hmac-sha1", "hmac-md5"], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], compress: ["none", "zlib@openssh.com", "zlib"], }, }; - if (resolvedCredentials.sshKey && resolvedCredentials.sshKey.trim()) { + if ( + resolvedCredentials.authType === "password" && + resolvedCredentials.password && + resolvedCredentials.password.trim() + ) { + config.password = resolvedCredentials.password; + } else if ( + resolvedCredentials.authType === "key" && + resolvedCredentials.sshKey && + resolvedCredentials.sshKey.trim() + ) { try { if ( !resolvedCredentials.sshKey.includes("-----BEGIN") || @@ -198,17 +312,18 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { }); return res.status(400).json({ error: "Invalid SSH key format" }); } - } else if ( - resolvedCredentials.password && - resolvedCredentials.password.trim() - ) { - config.password = resolvedCredentials.password; } else { - fileLogger.warn("No authentication method provided for file manager", { - operation: "file_connect", - sessionId, - hostId, - }); + fileLogger.warn( + "No valid authentication method provided for file manager", + { + operation: "file_connect", + sessionId, + hostId, + authType: resolvedCredentials.authType, + hasPassword: !!resolvedCredentials.password, + hasKey: !!resolvedCredentials.sshKey, + }, + ); return res .status(400) .json({ error: "Either password or SSH key must be provided" }); @@ -224,6 +339,7 @@ app.post("/ssh/file_manager/ssh/connect", async (req, res) => { isConnected: true, lastActive: Date.now(), }; + scheduleSessionCleanup(sessionId); res.json({ status: "success", message: "SSH connection established" }); }); @@ -262,6 +378,33 @@ app.get("/ssh/file_manager/ssh/status", (req, res) => { res.json({ status: "success", connected: isConnected }); }); +app.post("/ssh/file_manager/ssh/keepalive", (req, res) => { + const { sessionId } = req.body; + + if (!sessionId) { + return res.status(400).json({ error: "Session ID is required" }); + } + + const session = sshSessions[sessionId]; + + if (!session || !session.isConnected) { + return res.status(400).json({ + error: "SSH session not found or not connected", + connected: false, + }); + } + + session.lastActive = Date.now(); + scheduleSessionCleanup(sessionId); + + res.json({ + status: "success", + connected: true, + message: "Session keepalive successful", + lastActive: session.lastActive, + }); +}); + app.get("/ssh/file_manager/ssh/listFiles", (req, res) => { const sessionId = req.query.sessionId as string; const sshConn = sshSessions[sessionId]; @@ -311,20 +454,118 @@ app.get("/ssh/file_manager/ssh/listFiles", (req, res) => { const parts = line.split(/\s+/); if (parts.length >= 9) { const permissions = parts[0]; - const name = parts.slice(8).join(" "); + const linkCount = parts[1]; + const owner = parts[2]; + const group = parts[3]; + const size = parseInt(parts[4], 10); + + let dateStr = ""; + let nameStartIndex = 8; + + if (parts[5] && parts[6] && parts[7]) { + dateStr = `${parts[5]} ${parts[6]} ${parts[7]}`; + } + + const name = parts.slice(nameStartIndex).join(" "); const isDirectory = permissions.startsWith("d"); const isLink = permissions.startsWith("l"); if (name === "." || name === "..") continue; + let actualName = name; + let linkTarget = undefined; + if (isLink && name.includes(" -> ")) { + const linkParts = name.split(" -> "); + actualName = linkParts[0]; + linkTarget = linkParts[1]; + } + files.push({ - name, + name: actualName, type: isDirectory ? "directory" : isLink ? "link" : "file", + size: isDirectory ? undefined : size, + modified: dateStr, + permissions, + owner, + group, + linkTarget, + path: `${sshPath.endsWith("/") ? sshPath : sshPath + "/"}${actualName}`, + executable: + !isDirectory && !isLink + ? isExecutableFile(permissions, actualName) + : false, }); } } - res.json(files); + res.json({ files, path: sshPath }); + }); + }); +}); + +app.get("/ssh/file_manager/ssh/identifySymlink", (req, res) => { + const sessionId = req.query.sessionId as string; + const sshConn = sshSessions[sessionId]; + const linkPath = decodeURIComponent(req.query.path as string); + + if (!sessionId) { + return res.status(400).json({ error: "Session ID is required" }); + } + + if (!sshConn?.isConnected) { + return res.status(400).json({ error: "SSH connection not established" }); + } + + if (!linkPath) { + return res.status(400).json({ error: "Link path is required" }); + } + + sshConn.lastActive = Date.now(); + + const escapedPath = linkPath.replace(/'/g, "'\"'\"'"); + const command = `stat -L -c "%F" '${escapedPath}' && readlink -f '${escapedPath}'`; + + sshConn.client.exec(command, (err, stream) => { + if (err) { + fileLogger.error("SSH identifySymlink error:", err); + return res.status(500).json({ error: err.message }); + } + + let data = ""; + let errorData = ""; + + stream.on("data", (chunk: Buffer) => { + data += chunk.toString(); + }); + + stream.stderr.on("data", (chunk: Buffer) => { + errorData += chunk.toString(); + }); + + stream.on("close", (code) => { + if (code !== 0) { + fileLogger.error( + `SSH identifySymlink command failed with code ${code}: ${errorData.replace(/\n/g, " ").trim()}`, + ); + return res.status(500).json({ error: `Command failed: ${errorData}` }); + } + + const [fileType, target] = data.trim().split("\n"); + + res.json({ + path: linkPath, + target: target, + type: fileType.toLowerCase().includes("directory") + ? "directory" + : "file", + }); + }); + + stream.on("error", (streamErr) => { + fileLogger.error("SSH identifySymlink stream error:", streamErr); + if (!res.headersSent) { + res.status(500).json({ error: `Stream error: ${streamErr.message}` }); + } }); }); }); @@ -348,35 +589,107 @@ app.get("/ssh/file_manager/ssh/readFile", (req, res) => { sshConn.lastActive = Date.now(); + const MAX_READ_SIZE = 500 * 1024 * 1024; const escapedPath = filePath.replace(/'/g, "'\"'\"'"); - sshConn.client.exec(`cat '${escapedPath}'`, (err, stream) => { - if (err) { - fileLogger.error("SSH readFile error:", err); - return res.status(500).json({ error: err.message }); - } - let data = ""; - let errorData = ""; - - stream.on("data", (chunk: Buffer) => { - data += chunk.toString(); - }); - - stream.stderr.on("data", (chunk: Buffer) => { - errorData += chunk.toString(); - }); - - stream.on("close", (code) => { - if (code !== 0) { - fileLogger.error( - `SSH readFile command failed with code ${code}: ${errorData.replace(/\n/g, " ").trim()}`, - ); - return res.status(500).json({ error: `Command failed: ${errorData}` }); + sshConn.client.exec( + `stat -c%s '${escapedPath}' 2>/dev/null || wc -c < '${escapedPath}'`, + (sizeErr, sizeStream) => { + if (sizeErr) { + fileLogger.error("SSH file size check error:", sizeErr); + return res.status(500).json({ error: sizeErr.message }); } - res.json({ content: data, path: filePath }); - }); - }); + let sizeData = ""; + let sizeErrorData = ""; + + sizeStream.on("data", (chunk: Buffer) => { + sizeData += chunk.toString(); + }); + + sizeStream.stderr.on("data", (chunk: Buffer) => { + sizeErrorData += chunk.toString(); + }); + + sizeStream.on("close", (sizeCode) => { + if (sizeCode !== 0) { + const errorLower = sizeErrorData.toLowerCase(); + const isFileNotFound = + errorLower.includes("no such file or directory") || + errorLower.includes("cannot access") || + errorLower.includes("not found") || + errorLower.includes("resource not found"); + + fileLogger.error(`File size check failed: ${sizeErrorData}`); + return res.status(isFileNotFound ? 404 : 500).json({ + error: `Cannot check file size: ${sizeErrorData}`, + fileNotFound: isFileNotFound, + }); + } + + const fileSize = parseInt(sizeData.trim(), 10); + + if (isNaN(fileSize)) { + fileLogger.error("Invalid file size response:", sizeData); + return res.status(500).json({ error: "Cannot determine file size" }); + } + + if (fileSize > MAX_READ_SIZE) { + fileLogger.warn("File too large for reading", { + operation: "file_read", + sessionId, + filePath, + fileSize, + maxSize: MAX_READ_SIZE, + }); + return res.status(400).json({ + error: `File too large to open in editor. Maximum size is ${MAX_READ_SIZE / 1024 / 1024}MB, file is ${(fileSize / 1024 / 1024).toFixed(2)}MB. Use download instead.`, + fileSize, + maxSize: MAX_READ_SIZE, + tooLarge: true, + }); + } + + sshConn.client.exec(`cat '${escapedPath}'`, (err, stream) => { + if (err) { + fileLogger.error("SSH readFile error:", err); + return res.status(500).json({ error: err.message }); + } + + let data = ""; + let errorData = ""; + + stream.on("data", (chunk: Buffer) => { + data += chunk.toString(); + }); + + stream.stderr.on("data", (chunk: Buffer) => { + errorData += chunk.toString(); + }); + + stream.on("close", (code) => { + if (code !== 0) { + fileLogger.error( + `SSH readFile command failed with code ${code}: ${errorData.replace(/\n/g, " ").trim()}`, + ); + + const isFileNotFound = + errorData.includes("No such file or directory") || + errorData.includes("cannot access") || + errorData.includes("not found"); + + return res.status(isFileNotFound ? 404 : 500).json({ + error: `Command failed: ${errorData}`, + fileNotFound: isFileNotFound, + }); + } + + res.json({ content: data, path: filePath }); + }); + }); + }); + }, + ); }); app.post("/ssh/file_manager/ssh/writeFile", async (req, res) => { @@ -593,6 +906,11 @@ app.post("/ssh/file_manager/ssh/uploadFile", async (req, res) => { sshConn.lastActive = Date.now(); + const contentSize = + typeof content === "string" + ? Buffer.byteLength(content, "utf8") + : content.length; + const fullPath = filePath.endsWith("/") ? filePath + fileName : filePath + "/" + fileName; @@ -637,6 +955,13 @@ app.post("/ssh/file_manager/ssh/uploadFile", async (req, res) => { hasError = true; fileLogger.warn( `SFTP write failed, trying fallback method: ${streamErr.message}`, + { + operation: "file_upload", + sessionId, + fileName, + fileSize: contentSize, + error: streamErr.message, + }, ); tryFallbackMethod(); }); @@ -1269,6 +1594,493 @@ app.put("/ssh/file_manager/ssh/renameItem", async (req, res) => { }); }); +app.put("/ssh/file_manager/ssh/moveItem", async (req, res) => { + const { sessionId, oldPath, newPath, hostId, userId } = req.body; + const sshConn = sshSessions[sessionId]; + + if (!sessionId) { + return res.status(400).json({ error: "Session ID is required" }); + } + + if (!sshConn?.isConnected) { + return res.status(400).json({ error: "SSH connection not established" }); + } + + if (!oldPath || !newPath) { + return res + .status(400) + .json({ error: "Old path and new path are required" }); + } + + sshConn.lastActive = Date.now(); + + const escapedOldPath = oldPath.replace(/'/g, "'\"'\"'"); + const escapedNewPath = newPath.replace(/'/g, "'\"'\"'"); + + const moveCommand = `mv '${escapedOldPath}' '${escapedNewPath}' && echo "SUCCESS" && exit 0`; + + const commandTimeout = setTimeout(() => { + if (!res.headersSent) { + res.status(408).json({ + error: "Move operation timed out. SSH connection may be unstable.", + toast: { + type: "error", + message: "Move operation timed out. SSH connection may be unstable.", + }, + }); + } + }, 60000); + + sshConn.client.exec(moveCommand, (err, stream) => { + if (err) { + clearTimeout(commandTimeout); + fileLogger.error("SSH moveItem error:", err); + if (!res.headersSent) { + return res.status(500).json({ error: err.message }); + } + return; + } + + let outputData = ""; + let errorData = ""; + + stream.on("data", (chunk: Buffer) => { + outputData += chunk.toString(); + }); + + stream.stderr.on("data", (chunk: Buffer) => { + errorData += chunk.toString(); + + if (chunk.toString().includes("Permission denied")) { + fileLogger.error(`Permission denied moving: ${oldPath}`); + if (!res.headersSent) { + return res.status(403).json({ + error: `Permission denied: Cannot move ${oldPath}. Check file permissions.`, + toast: { + type: "error", + message: `Permission denied: Cannot move ${oldPath}. Check file permissions.`, + }, + }); + } + return; + } + }); + + stream.on("close", (code) => { + clearTimeout(commandTimeout); + if (outputData.includes("SUCCESS")) { + if (!res.headersSent) { + res.json({ + message: "Item moved successfully", + oldPath, + newPath, + toast: { + type: "success", + message: `Item moved: ${oldPath} -> ${newPath}`, + }, + }); + } + return; + } + + if (code !== 0) { + fileLogger.error( + `SSH moveItem command failed with code ${code}: ${errorData.replace(/\n/g, " ").trim()}`, + ); + if (!res.headersSent) { + return res.status(500).json({ + error: `Command failed: ${errorData}`, + toast: { type: "error", message: `Move failed: ${errorData}` }, + }); + } + return; + } + + if (!res.headersSent) { + res.json({ + message: "Item moved successfully", + oldPath, + newPath, + toast: { + type: "success", + message: `Item moved: ${oldPath} -> ${newPath}`, + }, + }); + } + }); + + stream.on("error", (streamErr) => { + clearTimeout(commandTimeout); + fileLogger.error("SSH moveItem stream error:", streamErr); + if (!res.headersSent) { + res.status(500).json({ error: `Stream error: ${streamErr.message}` }); + } + }); + }); +}); + +app.post("/ssh/file_manager/ssh/downloadFile", async (req, res) => { + const { sessionId, path: filePath, hostId, userId } = req.body; + + if (!sessionId || !filePath) { + fileLogger.warn("Missing download parameters", { + operation: "file_download", + sessionId, + hasFilePath: !!filePath, + }); + return res.status(400).json({ error: "Missing download parameters" }); + } + + const sshConn = sshSessions[sessionId]; + if (!sshConn || !sshConn.isConnected) { + fileLogger.warn("SSH session not found or not connected for download", { + operation: "file_download", + sessionId, + isConnected: sshConn?.isConnected, + }); + return res + .status(400) + .json({ error: "SSH session not found or not connected" }); + } + + sshConn.lastActive = Date.now(); + scheduleSessionCleanup(sessionId); + + sshConn.client.sftp((err, sftp) => { + if (err) { + fileLogger.error("SFTP connection failed for download:", err); + return res.status(500).json({ error: "SFTP connection failed" }); + } + + sftp.stat(filePath, (statErr, stats) => { + if (statErr) { + fileLogger.error("File stat failed for download:", statErr); + return res + .status(500) + .json({ error: `Cannot access file: ${statErr.message}` }); + } + + if (!stats.isFile()) { + fileLogger.warn("Attempted to download non-file", { + operation: "file_download", + sessionId, + filePath, + isFile: stats.isFile(), + isDirectory: stats.isDirectory(), + }); + return res + .status(400) + .json({ error: "Cannot download directories or special files" }); + } + + const MAX_FILE_SIZE = 5 * 1024 * 1024 * 1024; + if (stats.size > MAX_FILE_SIZE) { + fileLogger.warn("File too large for download", { + operation: "file_download", + sessionId, + filePath, + fileSize: stats.size, + maxSize: MAX_FILE_SIZE, + }); + return res.status(400).json({ + error: `File too large. Maximum size is ${MAX_FILE_SIZE / 1024 / 1024}MB, file is ${(stats.size / 1024 / 1024).toFixed(2)}MB`, + }); + } + + sftp.readFile(filePath, (readErr, data) => { + if (readErr) { + fileLogger.error("File read failed for download:", readErr); + return res + .status(500) + .json({ error: `Failed to read file: ${readErr.message}` }); + } + + const base64Content = data.toString("base64"); + const fileName = filePath.split("/").pop() || "download"; + + fileLogger.success("File downloaded successfully", { + operation: "file_download", + sessionId, + filePath, + fileName, + fileSize: stats.size, + hostId, + userId, + }); + + res.json({ + content: base64Content, + fileName: fileName, + size: stats.size, + mimeType: getMimeType(fileName), + path: filePath, + }); + }); + }); + }); +}); + +app.post("/ssh/file_manager/ssh/copyItem", async (req, res) => { + const { sessionId, sourcePath, targetDir, hostId, userId } = req.body; + + if (!sessionId || !sourcePath || !targetDir) { + return res.status(400).json({ error: "Missing required parameters" }); + } + + const sshConn = sshSessions[sessionId]; + if (!sshConn || !sshConn.isConnected) { + return res + .status(400) + .json({ error: "SSH session not found or not connected" }); + } + + sshConn.lastActive = Date.now(); + scheduleSessionCleanup(sessionId); + + const sourceName = sourcePath.split("/").pop() || "copied_item"; + + const timestamp = Date.now().toString().slice(-8); + const uniqueName = `${sourceName}_copy_${timestamp}`; + const targetPath = `${targetDir}/${uniqueName}`; + + const escapedSource = sourcePath.replace(/'/g, "'\"'\"'"); + const escapedTarget = targetPath.replace(/'/g, "'\"'\"'"); + + const copyCommand = `cp '${escapedSource}' '${escapedTarget}' && echo "COPY_SUCCESS"`; + + const commandTimeout = setTimeout(() => { + fileLogger.error("Copy command timed out after 60 seconds", { + sourcePath, + targetPath, + command: copyCommand, + }); + if (!res.headersSent) { + res.status(500).json({ + error: "Copy operation timed out", + toast: { + type: "error", + message: "Copy operation timed out. SSH connection may be unstable.", + }, + }); + } + }, 60000); + + sshConn.client.exec(copyCommand, (err, stream) => { + if (err) { + clearTimeout(commandTimeout); + fileLogger.error("SSH copyItem error:", err); + if (!res.headersSent) { + return res.status(500).json({ error: err.message }); + } + return; + } + + let errorData = ""; + let stdoutData = ""; + + stream.on("data", (data: Buffer) => { + const output = data.toString(); + stdoutData += output; + stream.stderr.on("data", (data: Buffer) => { + const output = data.toString(); + errorData += output; + }); + + stream.on("close", (code) => { + clearTimeout(commandTimeout); + + if (code !== 0) { + const fullErrorInfo = + errorData || stdoutData || "No error message available"; + fileLogger.error(`SSH copyItem command failed with code ${code}`, { + operation: "file_copy_failed", + sessionId, + sourcePath, + targetPath, + command: copyCommand, + exitCode: code, + errorData, + stdoutData, + fullErrorInfo, + }); + if (!res.headersSent) { + return res.status(500).json({ + error: `Copy failed: ${fullErrorInfo}`, + toast: { + type: "error", + message: `Copy failed: ${fullErrorInfo}`, + }, + debug: { + sourcePath, + targetPath, + exitCode: code, + command: copyCommand, + }, + }); + } + return; + } + + const copySuccessful = + stdoutData.includes("COPY_SUCCESS") || code === 0; + + if (copySuccessful) { + fileLogger.success("Item copied successfully", { + operation: "file_copy", + sessionId, + sourcePath, + targetPath, + uniqueName, + hostId, + userId, + }); + + if (!res.headersSent) { + res.json({ + message: "Item copied successfully", + sourcePath, + targetPath, + uniqueName, + toast: { + type: "success", + message: `Successfully copied to: ${uniqueName}`, + }, + }); + } + } else { + fileLogger.warn("Copy completed but without success confirmation", { + operation: "file_copy_uncertain", + sessionId, + sourcePath, + targetPath, + code, + stdoutData: stdoutData.substring(0, 200), + }); + + if (!res.headersSent) { + res.json({ + message: "Copy may have completed", + sourcePath, + targetPath, + uniqueName, + toast: { + type: "warning", + message: `Copy completed but verification uncertain for: ${uniqueName}`, + }, + }); + } + } + }); + + stream.on("error", (streamErr) => { + clearTimeout(commandTimeout); + fileLogger.error("SSH copyItem stream error:", streamErr); + if (!res.headersSent) { + res.status(500).json({ error: `Stream error: ${streamErr.message}` }); + } + }); + }); + }); +}); + +app.post("/ssh/file_manager/ssh/executeFile", async (req, res) => { + const { sessionId, filePath, hostId, userId } = req.body; + const sshConn = sshSessions[sessionId]; + + if (!sshConn || !sshConn.isConnected) { + fileLogger.error( + "SSH connection not found or not connected for executeFile", + { + operation: "execute_file", + sessionId, + hasConnection: !!sshConn, + isConnected: sshConn?.isConnected, + }, + ); + return res.status(400).json({ error: "SSH connection not available" }); + } + + if (!filePath) { + return res.status(400).json({ error: "File path is required" }); + } + + const escapedPath = filePath.replace(/'/g, "'\"'\"'"); + + const checkCommand = `test -x '${escapedPath}' && echo "EXECUTABLE" || echo "NOT_EXECUTABLE"`; + + sshConn.client.exec(checkCommand, (checkErr, checkStream) => { + if (checkErr) { + fileLogger.error("SSH executeFile check error:", checkErr); + return res + .status(500) + .json({ error: "Failed to check file executability" }); + } + + let checkResult = ""; + checkStream.on("data", (data) => { + checkResult += data.toString(); + }); + + checkStream.on("close", (code) => { + if (!checkResult.includes("EXECUTABLE")) { + return res.status(400).json({ error: "File is not executable" }); + } + + const executeCommand = `cd "$(dirname '${escapedPath}')" && '${escapedPath}' 2>&1; echo "EXIT_CODE:$?"`; + + sshConn.client.exec(executeCommand, (err, stream) => { + if (err) { + fileLogger.error("SSH executeFile error:", err); + return res.status(500).json({ error: "Failed to execute file" }); + } + + let output = ""; + let errorOutput = ""; + + stream.on("data", (data) => { + output += data.toString(); + }); + + stream.stderr.on("data", (data) => { + errorOutput += data.toString(); + }); + + stream.on("close", (code) => { + const exitCodeMatch = output.match(/EXIT_CODE:(\d+)$/); + const actualExitCode = exitCodeMatch + ? parseInt(exitCodeMatch[1]) + : code; + const cleanOutput = output.replace(/EXIT_CODE:\d+$/, "").trim(); + + fileLogger.info("File execution completed", { + operation: "execute_file", + sessionId, + filePath, + exitCode: actualExitCode, + outputLength: cleanOutput.length, + errorLength: errorOutput.length, + }); + + res.json({ + success: true, + exitCode: actualExitCode, + output: cleanOutput, + error: errorOutput, + timestamp: new Date().toISOString(), + }); + }); + + stream.on("error", (streamErr) => { + fileLogger.error("SSH executeFile stream error:", streamErr); + if (!res.headersSent) { + res.status(500).json({ error: "Execution stream error" }); + } + }); + }); + }); + }); +}); + process.on("SIGINT", () => { Object.keys(sshSessions).forEach(cleanupSession); process.exit(0); @@ -1279,10 +2091,28 @@ process.on("SIGTERM", () => { process.exit(0); }); -const PORT = 8084; -app.listen(PORT, () => { - fileLogger.success("File Manager API server started", { - operation: "server_start", +const PORT = 30004; + +try { + const server = app.listen(PORT, async () => { + try { + await authManager.initialize(); + } catch (err) { + fileLogger.error("Failed to initialize AuthManager", err, { + operation: "auth_init_error", + }); + } + }); + + server.on("error", (err) => { + fileLogger.error("File Manager server error", err, { + operation: "file_manager_server_error", + port: PORT, + }); + }); +} catch (err) { + fileLogger.error("Failed to start File Manager server", err, { + operation: "file_manager_server_start_failed", port: PORT, }); -}); +} diff --git a/src/backend/ssh/server-stats.ts b/src/backend/ssh/server-stats.ts index bdc8ec50..c59c9ff9 100644 --- a/src/backend/ssh/server-stats.ts +++ b/src/backend/ssh/server-stats.ts @@ -1,11 +1,14 @@ import express from "express"; import net from "net"; import cors from "cors"; +import cookieParser from "cookie-parser"; import { Client, type ConnectConfig } from "ssh2"; -import { db } from "../database/db/index.js"; +import { getDb } from "../database/db/index.js"; import { sshData, sshCredentials } from "../database/db/schema.js"; import { eq, and } from "drizzle-orm"; import { statsLogger } from "../utils/logger.js"; +import { SimpleDBOps } from "../utils/simple-db-ops.js"; +import { AuthManager } from "../utils/auth-manager.js"; interface PooledConnection { client: Client; @@ -227,6 +230,7 @@ class MetricsCache { const connectionPool = new SSHConnectionPool(); const requestQueue = new RequestQueue(); const metricsCache = new MetricsCache(); +const authManager = AuthManager.getInstance(); type HostStatus = "online" | "offline"; @@ -275,7 +279,37 @@ function validateHostId( const app = express(); app.use( cors({ - origin: "*", + origin: (origin, callback) => { + // Allow requests with no origin (like mobile apps or curl requests) + if (!origin) return callback(null, true); + + // Allow localhost and 127.0.0.1 for development + const allowedOrigins = [ + "http://localhost:5173", + "http://localhost:3000", + "http://127.0.0.1:5173", + "http://127.0.0.1:3000", + ]; + + // Allow any HTTPS origin (production deployments) + if (origin.startsWith("https://")) { + return callback(null, true); + } + + // Allow any HTTP origin for self-hosted scenarios + if (origin.startsWith("http://")) { + return callback(null, true); + } + + // Check against allowed development origins + if (allowedOrigins.includes(origin)) { + return callback(null, true); + } + + // Reject other origins + callback(new Error("Not allowed by CORS")); + }, + credentials: true, methods: ["GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"], allowedHeaders: [ "Content-Type", @@ -285,33 +319,28 @@ app.use( ], }), ); -app.use((req, res, next) => { - res.header("Access-Control-Allow-Origin", "*"); - res.header( - "Access-Control-Allow-Headers", - "Content-Type, Authorization, User-Agent, X-Electron-App", - ); - res.header( - "Access-Control-Allow-Methods", - "GET, POST, PUT, PATCH, DELETE, OPTIONS", - ); - if (req.method === "OPTIONS") { - return res.sendStatus(204); - } - next(); -}); +app.use(cookieParser()); app.use(express.json({ limit: "1mb" })); +// Add authentication middleware - Linus principle: eliminate special cases +app.use(authManager.createAuthMiddleware()); + const hostStatuses: Map = new Map(); -async function fetchAllHosts(): Promise { +async function fetchAllHosts( + userId: string, +): Promise { try { - const hosts = await db.select().from(sshData); + const hosts = await SimpleDBOps.select( + getDb().select().from(sshData).where(eq(sshData.userId, userId)), + "ssh_data", + userId, + ); const hostsWithCredentials: SSHHostWithCredentials[] = []; for (const host of hosts) { try { - const hostWithCreds = await resolveHostCredentials(host); + const hostWithCreds = await resolveHostCredentials(host, userId); if (hostWithCreds) { hostsWithCredentials.push(hostWithCreds); } @@ -331,16 +360,34 @@ async function fetchAllHosts(): Promise { async function fetchHostById( id: number, + userId: string, ): Promise { try { - const hosts = await db.select().from(sshData).where(eq(sshData.id, id)); + // Check if user data is unlocked before attempting to fetch + if (!SimpleDBOps.isUserDataUnlocked(userId)) { + statsLogger.debug("User data locked - cannot fetch host", { + operation: "fetchHostById_data_locked", + userId, + hostId: id, + }); + return undefined; + } + + const hosts = await SimpleDBOps.select( + getDb() + .select() + .from(sshData) + .where(and(eq(sshData.id, id), eq(sshData.userId, userId))), + "ssh_data", + userId, + ); if (hosts.length === 0) { return undefined; } const host = hosts[0]; - return await resolveHostCredentials(host); + return await resolveHostCredentials(host, userId); } catch (err) { statsLogger.error(`Failed to fetch host ${id}`, err); return undefined; @@ -349,6 +396,7 @@ async function fetchHostById( async function resolveHostCredentials( host: any, + userId: string, ): Promise { try { const baseHost: any = { @@ -380,15 +428,19 @@ async function resolveHostCredentials( if (host.credentialId) { try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, host.credentialId), - eq(sshCredentials.userId, host.userId), + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, host.credentialId), + eq(sshCredentials.userId, userId), + ), ), - ); + "ssh_credentials", + userId, + ); if (credentials.length > 0) { const credential = credentials[0]; @@ -409,9 +461,6 @@ async function resolveHostCredentials( baseHost.keyType = credential.keyType; } } else { - statsLogger.warn( - `Credential ${host.credentialId} not found for host ${host.id}, using legacy data`, - ); addLegacyCredentials(baseHost, host); } } catch (error) { @@ -446,7 +495,38 @@ function buildSshConfig(host: SSHHostWithCredentials): ConnectConfig { port: host.port || 22, username: host.username || "root", readyTimeout: 10_000, - algorithms: {}, + algorithms: { + kex: [ + "diffie-hellman-group14-sha256", + "diffie-hellman-group14-sha1", + "diffie-hellman-group1-sha1", + "diffie-hellman-group-exchange-sha256", + "diffie-hellman-group-exchange-sha1", + "ecdh-sha2-nistp256", + "ecdh-sha2-nistp384", + "ecdh-sha2-nistp521", + ], + cipher: [ + "aes128-ctr", + "aes192-ctr", + "aes256-ctr", + "aes128-gcm@openssh.com", + "aes256-gcm@openssh.com", + "aes128-cbc", + "aes192-cbc", + "aes256-cbc", + "3des-cbc", + ], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], + compress: ["none", "zlib@openssh.com", "zlib"], + }, } as ConnectConfig; if (host.authType === "password") { @@ -761,11 +841,19 @@ function tcpPing( }); } -async function pollStatusesOnce(): Promise { - const hosts = await fetchAllHosts(); +async function pollStatusesOnce(userId?: string): Promise { + if (!userId) { + statsLogger.warn("Skipping status poll - no authenticated user", { + operation: "status_poll", + }); + return; + } + + const hosts = await fetchAllHosts(userId); if (hosts.length === 0) { statsLogger.warn("No hosts retrieved for status polling", { operation: "status_poll", + userId, }); return; } @@ -797,8 +885,18 @@ async function pollStatusesOnce(): Promise { } app.get("/status", async (req, res) => { + const userId = (req as any).userId; + + // Check if user data is unlocked + if (!SimpleDBOps.isUserDataUnlocked(userId)) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } + if (hostStatuses.size === 0) { - await pollStatusesOnce(); + await pollStatusesOnce(userId); } const result: Record = {}; for (const [id, entry] of hostStatuses.entries()) { @@ -809,9 +907,18 @@ app.get("/status", async (req, res) => { app.get("/status/:id", validateHostId, async (req, res) => { const id = Number(req.params.id); + const userId = (req as any).userId; + + // Check if user data is unlocked + if (!SimpleDBOps.isUserDataUnlocked(userId)) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } try { - const host = await fetchHostById(id); + const host = await fetchHostById(id, userId); if (!host) { return res.status(404).json({ error: "Host not found" }); } @@ -832,15 +939,34 @@ app.get("/status/:id", validateHostId, async (req, res) => { }); app.post("/refresh", async (req, res) => { - await pollStatusesOnce(); + const userId = (req as any).userId; + + // Check if user data is unlocked + if (!SimpleDBOps.isUserDataUnlocked(userId)) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } + + await pollStatusesOnce(userId); res.json({ message: "Refreshed" }); }); app.get("/metrics/:id", validateHostId, async (req, res) => { const id = Number(req.params.id); + const userId = (req as any).userId; + + // Check if user data is unlocked + if (!SimpleDBOps.isUserDataUnlocked(userId)) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } try { - const host = await fetchHostById(id); + const host = await fetchHostById(id, userId); if (!host) { return res.status(404).json({ error: "Host not found" }); } @@ -882,28 +1008,22 @@ app.get("/metrics/:id", validateHostId, async (req, res) => { }); process.on("SIGINT", () => { - statsLogger.info("Received SIGINT, shutting down gracefully"); connectionPool.destroy(); process.exit(0); }); process.on("SIGTERM", () => { - statsLogger.info("Received SIGTERM, shutting down gracefully"); connectionPool.destroy(); process.exit(0); }); -const PORT = 8085; +const PORT = 30005; app.listen(PORT, async () => { - statsLogger.success("Server Stats API server started", { - operation: "server_start", - port: PORT, - }); try { - await pollStatusesOnce(); + await authManager.initialize(); } catch (err) { - statsLogger.error("Initial poll failed", err, { - operation: "initial_poll", + statsLogger.error("Failed to initialize AuthManager", err, { + operation: "auth_init_error", }); } }); diff --git a/src/backend/ssh/terminal.ts b/src/backend/ssh/terminal.ts index cb1ec180..405afabb 100644 --- a/src/backend/ssh/terminal.ts +++ b/src/backend/ssh/terminal.ts @@ -1,33 +1,198 @@ import { WebSocketServer, WebSocket, type RawData } from "ws"; import { Client, type ClientChannel, type PseudoTtyOptions } from "ssh2"; -import { db } from "../database/db/index.js"; +import { parse as parseUrl } from "url"; +import { getDb } from "../database/db/index.js"; import { sshCredentials } from "../database/db/schema.js"; import { eq, and } from "drizzle-orm"; import { sshLogger } from "../utils/logger.js"; +import { SimpleDBOps } from "../utils/simple-db-ops.js"; +import { AuthManager } from "../utils/auth-manager.js"; +import { UserCrypto } from "../utils/user-crypto.js"; -const wss = new WebSocketServer({ port: 8082 }); +const authManager = AuthManager.getInstance(); +const userCrypto = UserCrypto.getInstance(); -sshLogger.success("SSH Terminal WebSocket server started", { - operation: "server_start", - port: 8082, +const userConnections = new Map>(); + +const wss = new WebSocketServer({ + port: 30002, + verifyClient: async (info) => { + try { + const url = parseUrl(info.req.url!, true); + const token = url.query.token as string; + + if (!token) { + sshLogger.warn("WebSocket connection rejected: missing token", { + operation: "websocket_auth_reject", + reason: "missing_token", + ip: info.req.socket.remoteAddress, + }); + return false; + } + + const payload = await authManager.verifyJWTToken(token); + + if (!payload) { + sshLogger.warn("WebSocket connection rejected: invalid token", { + operation: "websocket_auth_reject", + reason: "invalid_token", + ip: info.req.socket.remoteAddress, + }); + return false; + } + + if (payload.pendingTOTP) { + sshLogger.warn( + "WebSocket connection rejected: TOTP verification pending", + { + operation: "websocket_auth_reject", + reason: "totp_pending", + userId: payload.userId, + ip: info.req.socket.remoteAddress, + }, + ); + return false; + } + + const existingConnections = userConnections.get(payload.userId); + if (existingConnections && existingConnections.size >= 3) { + sshLogger.warn("WebSocket connection rejected: too many connections", { + operation: "websocket_auth_reject", + reason: "connection_limit", + userId: payload.userId, + currentConnections: existingConnections.size, + ip: info.req.socket.remoteAddress, + }); + return false; + } + + return true; + } catch (error) { + sshLogger.error("WebSocket authentication error", error, { + operation: "websocket_auth_error", + ip: info.req.socket.remoteAddress, + }); + return false; + } + }, }); -wss.on("connection", (ws: WebSocket) => { +wss.on("connection", async (ws: WebSocket, req) => { + let userId: string | undefined; + let userPayload: any; + + try { + const url = parseUrl(req.url!, true); + const token = url.query.token as string; + + if (!token) { + sshLogger.warn( + "WebSocket connection rejected: missing token in connection", + { + operation: "websocket_connection_reject", + reason: "missing_token", + ip: req.socket.remoteAddress, + }, + ); + ws.close(1008, "Authentication required"); + return; + } + + const payload = await authManager.verifyJWTToken(token); + if (!payload) { + sshLogger.warn( + "WebSocket connection rejected: invalid token in connection", + { + operation: "websocket_connection_reject", + reason: "invalid_token", + ip: req.socket.remoteAddress, + }, + ); + ws.close(1008, "Authentication required"); + return; + } + + userId = payload.userId; + userPayload = payload; + } catch (error) { + sshLogger.error( + "WebSocket JWT verification failed during connection", + error, + { + operation: "websocket_connection_auth_error", + ip: req.socket.remoteAddress, + }, + ); + ws.close(1008, "Authentication required"); + return; + } + + const dataKey = userCrypto.getUserDataKey(userId); + if (!dataKey) { + sshLogger.warn("WebSocket connection rejected: data locked", { + operation: "websocket_data_locked", + userId, + ip: req.socket.remoteAddress, + }); + ws.send( + JSON.stringify({ + type: "error", + message: "Data locked - re-authenticate with password", + code: "DATA_LOCKED", + }), + ); + ws.close(1008, "Data access required"); + return; + } + + if (!userConnections.has(userId)) { + userConnections.set(userId, new Set()); + } + const userWs = userConnections.get(userId)!; + userWs.add(ws); + let sshConn: Client | null = null; let sshStream: ClientChannel | null = null; let pingInterval: NodeJS.Timeout | null = null; ws.on("close", () => { + const userWs = userConnections.get(userId); + if (userWs) { + userWs.delete(ws); + if (userWs.size === 0) { + userConnections.delete(userId); + } + } + cleanupSSH(); }); ws.on("message", (msg: RawData) => { + const currentDataKey = userCrypto.getUserDataKey(userId); + if (!currentDataKey) { + sshLogger.warn("WebSocket message rejected: data access expired", { + operation: "websocket_message_rejected", + userId, + reason: "data_access_expired", + }); + ws.send( + JSON.stringify({ + type: "error", + message: "Data access expired - please re-authenticate", + code: "DATA_EXPIRED", + }), + ); + ws.close(1008, "Data access expired"); + return; + } + let parsed: any; try { parsed = JSON.parse(msg.toString()); } catch (e) { sshLogger.error("Invalid JSON received", e, { - operation: "websocket_message", + operation: "websocket_message_invalid_json", + userId, messageLength: msg.toString().length, }); ws.send(JSON.stringify({ type: "error", message: "Invalid JSON" })); @@ -38,9 +203,13 @@ wss.on("connection", (ws: WebSocket) => { switch (type) { case "connectToHost": + if (data.hostConfig) { + data.hostConfig.userId = userId; + } handleConnectToHost(data).catch((error) => { sshLogger.error("Failed to connect to host", error, { operation: "ssh_connect", + userId, hostId: data.hostConfig?.id, ip: data.hostConfig?.ip, }); @@ -81,7 +250,8 @@ wss.on("connection", (ws: WebSocket) => { default: sshLogger.warn("Unknown message type received", { - operation: "websocket_message", + operation: "websocket_message_unknown_type", + userId, messageType: type, }); } @@ -103,8 +273,10 @@ wss.on("connection", (ws: WebSocket) => { credentialId?: number; userId?: string; }; + initialPath?: string; + executeCommand?: string; }) { - const { cols, rows, hostConfig } = data; + const { cols, rows, hostConfig, initialPath, executeCommand } = data; const { id, ip, @@ -177,21 +349,25 @@ wss.on("connection", (ws: WebSocket) => { let resolvedCredentials = { password, key, keyPassword, keyType, authType }; if (credentialId && id && hostConfig.userId) { try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, credentialId), - eq(sshCredentials.userId, hostConfig.userId), + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, credentialId), + eq(sshCredentials.userId, hostConfig.userId), + ), ), - ); + "ssh_credentials", + hostConfig.userId, + ); if (credentials.length > 0) { const credential = credentials[0]; resolvedCredentials = { password: credential.password, - key: credential.key, + key: credential.privateKey || credential.key, keyPassword: credential.keyPassword, keyType: credential.keyType, authType: credential.authType, @@ -281,6 +457,18 @@ wss.on("connection", (ws: WebSocket) => { setupPingInterval(); + if (initialPath && initialPath.trim() !== "") { + const cdCommand = `cd "${initialPath.replace(/"/g, '\\"')}" && pwd\n`; + stream.write(cdCommand); + } + + if (executeCommand && executeCommand.trim() !== "") { + setTimeout(() => { + const command = `${executeCommand}\n`; + stream.write(command); + }, 500); + } + ws.send( JSON.stringify({ type: "connected", message: "SSH connected" }), ); @@ -389,11 +577,26 @@ wss.on("connection", (ws: WebSocket) => { "aes256-cbc", "3des-cbc", ], - hmac: ["hmac-sha2-256", "hmac-sha2-512", "hmac-sha1", "hmac-md5"], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], compress: ["none", "zlib@openssh.com", "zlib"], }, }; - if (resolvedCredentials.authType === "key" && resolvedCredentials.key) { + if ( + resolvedCredentials.authType === "password" && + resolvedCredentials.password + ) { + connectConfig.password = resolvedCredentials.password; + } else if ( + resolvedCredentials.authType === "key" && + resolvedCredentials.key + ) { try { if ( !resolvedCredentials.key.includes("-----BEGIN") || @@ -439,7 +642,14 @@ wss.on("connection", (ws: WebSocket) => { ); return; } else { - connectConfig.password = resolvedCredentials.password; + sshLogger.error("No valid authentication method provided"); + ws.send( + JSON.stringify({ + type: "error", + message: "No valid authentication method provided", + }), + ); + return; } sshConn.connect(connectConfig); diff --git a/src/backend/ssh/tunnel.ts b/src/backend/ssh/tunnel.ts index 5d37c753..f92dfccb 100644 --- a/src/backend/ssh/tunnel.ts +++ b/src/backend/ssh/tunnel.ts @@ -1,9 +1,10 @@ import express from "express"; import cors from "cors"; +import cookieParser from "cookie-parser"; import { Client } from "ssh2"; import { ChildProcess } from "child_process"; import axios from "axios"; -import { db } from "../database/db/index.js"; +import { getDb } from "../database/db/index.js"; import { sshCredentials } from "../database/db/schema.js"; import { eq, and } from "drizzle-orm"; import type { @@ -15,11 +16,38 @@ import type { } from "../../types/index.js"; import { CONNECTION_STATES } from "../../types/index.js"; import { tunnelLogger } from "../utils/logger.js"; +import { SystemCrypto } from "../utils/system-crypto.js"; +import { SimpleDBOps } from "../utils/simple-db-ops.js"; +import { DataCrypto } from "../utils/data-crypto.js"; const app = express(); app.use( cors({ - origin: "*", + origin: (origin, callback) => { + if (!origin) return callback(null, true); + + const allowedOrigins = [ + "http://localhost:5173", + "http://localhost:3000", + "http://127.0.0.1:5173", + "http://127.0.0.1:3000", + ]; + + if (origin.startsWith("https://")) { + return callback(null, true); + } + + if (origin.startsWith("http://")) { + return callback(null, true); + } + + if (allowedOrigins.includes(origin)) { + return callback(null, true); + } + + callback(new Error("Not allowed by CORS")); + }, + credentials: true, methods: ["GET", "POST", "PUT", "DELETE", "OPTIONS"], allowedHeaders: [ "Origin", @@ -32,6 +60,7 @@ app.use( ], }), ); +app.use(cookieParser()); app.use(express.json()); const activeTunnels = new Map(); @@ -43,6 +72,8 @@ const verificationTimers = new Map(); const activeRetryTimers = new Map(); const countdownIntervals = new Map(); const retryExhaustedTunnels = new Set(); +const cleanupInProgress = new Set(); +const tunnelConnecting = new Set(); const tunnelConfigs = new Map(); const activeTunnelProcesses = new Map(); @@ -123,16 +154,32 @@ function getTunnelMarker(tunnelName: string) { return `TUNNEL_MARKER_${tunnelName.replace(/[^a-zA-Z0-9]/g, "_")}`; } -function cleanupTunnelResources(tunnelName: string): void { +function cleanupTunnelResources( + tunnelName: string, + forceCleanup = false, +): void { + if (cleanupInProgress.has(tunnelName)) { + return; + } + + if (!forceCleanup && tunnelConnecting.has(tunnelName)) { + return; + } + + cleanupInProgress.add(tunnelName); + const tunnelConfig = tunnelConfigs.get(tunnelName); if (tunnelConfig) { killRemoteTunnelByMarker(tunnelConfig, tunnelName, (err) => { + cleanupInProgress.delete(tunnelName); if (err) { tunnelLogger.error( `Failed to kill remote tunnel for '${tunnelName}': ${err.message}`, ); } }); + } else { + cleanupInProgress.delete(tunnelName); } if (activeTunnelProcesses.has(tunnelName)) { @@ -203,6 +250,8 @@ function cleanupTunnelResources(tunnelName: string): void { function resetRetryState(tunnelName: string): void { retryCounters.delete(tunnelName); retryExhaustedTunnels.delete(tunnelName); + cleanupInProgress.delete(tunnelName); + tunnelConnecting.delete(tunnelName); if (activeRetryTimers.has(tunnelName)) { clearTimeout(activeRetryTimers.get(tunnelName)!); @@ -394,7 +443,9 @@ async function connectSSHTunnel( return; } - cleanupTunnelResources(tunnelName); + tunnelConnecting.add(tunnelName); + + cleanupTunnelResources(tunnelName, true); if (retryAttempt === 0) { retryExhaustedTunnels.delete(tunnelName); @@ -441,31 +492,34 @@ async function connectSSHTunnel( if (tunnelConfig.sourceCredentialId && tunnelConfig.sourceUserId) { try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, tunnelConfig.sourceCredentialId), - eq(sshCredentials.userId, tunnelConfig.sourceUserId), - ), + const userDataKey = DataCrypto.getUserDataKey(tunnelConfig.sourceUserId); + if (userDataKey) { + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, tunnelConfig.sourceCredentialId), + eq(sshCredentials.userId, tunnelConfig.sourceUserId), + ), + ), + "ssh_credentials", + tunnelConfig.sourceUserId, ); - if (credentials.length > 0) { - const credential = credentials[0]; - resolvedSourceCredentials = { - password: credential.password, - sshKey: credential.key, - keyPassword: credential.keyPassword, - keyType: credential.keyType, - authMethod: credential.authType, - }; + if (credentials.length > 0) { + const credential = credentials[0]; + resolvedSourceCredentials = { + password: credential.password, + sshKey: credential.privateKey || credential.key, + keyPassword: credential.keyPassword, + keyType: credential.keyType, + authMethod: credential.authType, + }; + } else { + } } else { - tunnelLogger.warn("No source credentials found in database", { - operation: "tunnel_connect", - tunnelName, - credentialId: tunnelConfig.sourceCredentialId, - }); } } catch (error) { tunnelLogger.warn("Failed to resolve source credentials from database", { @@ -485,33 +539,71 @@ async function connectSSHTunnel( authMethod: tunnelConfig.endpointAuthMethod, }; + if ( + resolvedEndpointCredentials.authMethod === "password" && + !resolvedEndpointCredentials.password + ) { + const errorMessage = `Cannot connect tunnel '${tunnelName}': endpoint host requires password authentication but no plaintext password available. Enable autostart for endpoint host or configure credentials in tunnel connection.`; + tunnelLogger.error(errorMessage); + broadcastTunnelStatus(tunnelName, { + connected: false, + status: CONNECTION_STATES.FAILED, + reason: errorMessage, + }); + return; + } + + if ( + resolvedEndpointCredentials.authMethod === "key" && + !resolvedEndpointCredentials.sshKey + ) { + const errorMessage = `Cannot connect tunnel '${tunnelName}': endpoint host requires key authentication but no plaintext key available. Enable autostart for endpoint host or configure credentials in tunnel connection.`; + tunnelLogger.error(errorMessage); + broadcastTunnelStatus(tunnelName, { + connected: false, + status: CONNECTION_STATES.FAILED, + reason: errorMessage, + }); + return; + } + if (tunnelConfig.endpointCredentialId && tunnelConfig.endpointUserId) { try { - const credentials = await db - .select() - .from(sshCredentials) - .where( - and( - eq(sshCredentials.id, tunnelConfig.endpointCredentialId), - eq(sshCredentials.userId, tunnelConfig.endpointUserId), - ), + const userDataKey = DataCrypto.getUserDataKey( + tunnelConfig.endpointUserId, + ); + if (userDataKey) { + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, tunnelConfig.endpointCredentialId), + eq(sshCredentials.userId, tunnelConfig.endpointUserId), + ), + ), + "ssh_credentials", + tunnelConfig.endpointUserId, ); - if (credentials.length > 0) { - const credential = credentials[0]; - resolvedEndpointCredentials = { - password: credential.password, - sshKey: credential.key, - keyPassword: credential.keyPassword, - keyType: credential.keyType, - authMethod: credential.authType, - }; + if (credentials.length > 0) { + const credential = credentials[0]; + resolvedEndpointCredentials = { + password: credential.password, + sshKey: credential.privateKey || credential.key, + keyPassword: credential.keyPassword, + keyType: credential.keyType, + authMethod: credential.authType, + }; + } else { + tunnelLogger.warn("No endpoint credentials found in database", { + operation: "tunnel_connect", + tunnelName, + credentialId: tunnelConfig.endpointCredentialId, + }); + } } else { - tunnelLogger.warn("No endpoint credentials found in database", { - operation: "tunnel_connect", - tunnelName, - credentialId: tunnelConfig.endpointCredentialId, - }); } } catch (error) { tunnelLogger.warn( @@ -555,6 +647,8 @@ async function connectSSHTunnel( clearTimeout(connectionTimeout); tunnelLogger.error(`SSH error for '${tunnelName}': ${err.message}`); + tunnelConnecting.delete(tunnelName); + if (activeRetryTimers.has(tunnelName)) { return; } @@ -583,6 +677,8 @@ async function connectSSHTunnel( conn.on("close", () => { clearTimeout(connectionTimeout); + tunnelConnecting.delete(tunnelName); + if (activeRetryTimers.has(tunnelName)) { return; } @@ -620,9 +716,9 @@ async function connectSSHTunnel( resolvedEndpointCredentials.sshKey ) { const keyFilePath = `/tmp/tunnel_key_${tunnelName.replace(/[^a-zA-Z0-9]/g, "_")}`; - tunnelCmd = `echo '${resolvedEndpointCredentials.sshKey}' > ${keyFilePath} && chmod 600 ${keyFilePath} && ssh -i ${keyFilePath} -N -o StrictHostKeyChecking=no -o ExitOnForwardFailure=yes -o ServerAliveInterval=30 -o ServerAliveCountMax=3 -R ${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort} ${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP} ${tunnelMarker} && rm -f ${keyFilePath}`; + tunnelCmd = `echo '${resolvedEndpointCredentials.sshKey}' > ${keyFilePath} && chmod 600 ${keyFilePath} && exec -a "${tunnelMarker}" ssh -i ${keyFilePath} -N -o StrictHostKeyChecking=no -o ExitOnForwardFailure=yes -o ServerAliveInterval=30 -o ServerAliveCountMax=3 -o GatewayPorts=yes -R ${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort} ${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP} && rm -f ${keyFilePath}`; } else { - tunnelCmd = `sshpass -p '${resolvedEndpointCredentials.password || ""}' ssh -N -o StrictHostKeyChecking=no -o ExitOnForwardFailure=yes -o ServerAliveInterval=30 -o ServerAliveCountMax=3 -R ${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort} ${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP} ${tunnelMarker}`; + tunnelCmd = `exec -a "${tunnelMarker}" sshpass -p '${resolvedEndpointCredentials.password || ""}' ssh -N -o StrictHostKeyChecking=no -o ExitOnForwardFailure=yes -o ServerAliveInterval=30 -o ServerAliveCountMax=3 -o GatewayPorts=yes -R ${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort} ${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP}`; } conn.exec(tunnelCmd, (err, stream) => { @@ -651,6 +747,8 @@ async function connectSSHTunnel( !manualDisconnects.has(tunnelName) && activeTunnels.has(tunnelName) ) { + tunnelConnecting.delete(tunnelName); + broadcastTunnelStatus(tunnelName, { connected: true, status: CONNECTION_STATES.CONNECTED, @@ -722,12 +820,68 @@ async function connectSSHTunnel( } }); - stream.stdout?.on("data", (data: Buffer) => {}); + stream.stdout?.on("data", (data: Buffer) => { + const output = data.toString().trim(); + if (output) { + } + }); stream.on("error", (err: Error) => {}); stream.stderr.on("data", (data) => { const errorMsg = data.toString().trim(); + if (errorMsg) { + const isDebugMessage = + errorMsg.startsWith("debug1:") || + errorMsg.startsWith("debug2:") || + errorMsg.startsWith("debug3:") || + errorMsg.includes("Reading configuration data") || + errorMsg.includes("include /etc/ssh/ssh_config.d") || + errorMsg.includes("matched no files") || + errorMsg.includes("Applying options for"); + + if (!isDebugMessage) { + tunnelLogger.error(`SSH stderr for '${tunnelName}': ${errorMsg}`); + } + + if ( + errorMsg.includes("sshpass: command not found") || + errorMsg.includes("sshpass not found") + ) { + broadcastTunnelStatus(tunnelName, { + connected: false, + status: CONNECTION_STATES.FAILED, + reason: + "sshpass tool not found on source host. Please install sshpass or use SSH key authentication.", + }); + } + + if ( + errorMsg.includes("remote port forwarding failed") || + errorMsg.includes("Error: remote port forwarding failed") + ) { + const portMatch = errorMsg.match(/listen port (\d+)/); + const port = portMatch ? portMatch[1] : tunnelConfig.endpointPort; + + tunnelLogger.error( + `Port forwarding failed for tunnel '${tunnelName}' on port ${port}. This prevents tunnel establishment.`, + ); + + if (activeTunnels.has(tunnelName)) { + const conn = activeTunnels.get(tunnelName); + if (conn) { + conn.end(); + } + activeTunnels.delete(tunnelName); + } + + broadcastTunnelStatus(tunnelName, { + connected: false, + status: CONNECTION_STATES.FAILED, + reason: `Remote port forwarding failed for port ${port}. Port may be in use, requires root privileges, or SSH server doesn't allow port forwarding. Try a different port.`, + }); + } + } }); }); }); @@ -763,7 +917,14 @@ async function connectSSHTunnel( "aes256-cbc", "3des-cbc", ], - hmac: ["hmac-sha2-256", "hmac-sha2-512", "hmac-sha1", "hmac-md5"], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], compress: ["none", "zlib@openssh.com", "zlib"], }, }; @@ -827,12 +988,60 @@ async function connectSSHTunnel( conn.connect(connOptions); } -function killRemoteTunnelByMarker( +async function killRemoteTunnelByMarker( tunnelConfig: TunnelConfig, tunnelName: string, callback: (err?: Error) => void, ) { const tunnelMarker = getTunnelMarker(tunnelName); + + let resolvedSourceCredentials = { + password: tunnelConfig.sourcePassword, + sshKey: tunnelConfig.sourceSSHKey, + keyPassword: tunnelConfig.sourceKeyPassword, + keyType: tunnelConfig.sourceKeyType, + authMethod: tunnelConfig.sourceAuthMethod, + }; + + if (tunnelConfig.sourceCredentialId && tunnelConfig.sourceUserId) { + try { + const userDataKey = DataCrypto.getUserDataKey(tunnelConfig.sourceUserId); + if (userDataKey) { + const credentials = await SimpleDBOps.select( + getDb() + .select() + .from(sshCredentials) + .where( + and( + eq(sshCredentials.id, tunnelConfig.sourceCredentialId), + eq(sshCredentials.userId, tunnelConfig.sourceUserId), + ), + ), + "ssh_credentials", + tunnelConfig.sourceUserId, + ); + + if (credentials.length > 0) { + const credential = credentials[0]; + resolvedSourceCredentials = { + password: credential.password, + sshKey: credential.privateKey || credential.key, + keyPassword: credential.keyPassword, + keyType: credential.keyType, + authMethod: credential.authType, + }; + } + } else { + } + } catch (error) { + tunnelLogger.warn("Failed to resolve source credentials for cleanup", { + tunnelName, + credentialId: tunnelConfig.sourceCredentialId, + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + const conn = new Client(); const connOptions: any = { host: tunnelConfig.sourceIP, @@ -865,52 +1074,149 @@ function killRemoteTunnelByMarker( "aes256-cbc", "3des-cbc", ], - hmac: ["hmac-sha2-256", "hmac-sha2-512", "hmac-sha1", "hmac-md5"], + hmac: [ + "hmac-sha2-256-etm@openssh.com", + "hmac-sha2-512-etm@openssh.com", + "hmac-sha2-256", + "hmac-sha2-512", + "hmac-sha1", + "hmac-md5", + ], compress: ["none", "zlib@openssh.com", "zlib"], }, }; - if (tunnelConfig.sourceAuthMethod === "key" && tunnelConfig.sourceSSHKey) { + + if ( + resolvedSourceCredentials.authMethod === "key" && + resolvedSourceCredentials.sshKey + ) { if ( - !tunnelConfig.sourceSSHKey.includes("-----BEGIN") || - !tunnelConfig.sourceSSHKey.includes("-----END") + !resolvedSourceCredentials.sshKey.includes("-----BEGIN") || + !resolvedSourceCredentials.sshKey.includes("-----END") ) { callback(new Error("Invalid SSH key format")); return; } - const cleanKey = tunnelConfig.sourceSSHKey + const cleanKey = resolvedSourceCredentials.sshKey .trim() .replace(/\r\n/g, "\n") .replace(/\r/g, "\n"); connOptions.privateKey = Buffer.from(cleanKey, "utf8"); - if (tunnelConfig.sourceKeyPassword) { - connOptions.passphrase = tunnelConfig.sourceKeyPassword; + if (resolvedSourceCredentials.keyPassword) { + connOptions.passphrase = resolvedSourceCredentials.keyPassword; } - if (tunnelConfig.sourceKeyType && tunnelConfig.sourceKeyType !== "auto") { - connOptions.privateKeyType = tunnelConfig.sourceKeyType; + if ( + resolvedSourceCredentials.keyType && + resolvedSourceCredentials.keyType !== "auto" + ) { + connOptions.privateKeyType = resolvedSourceCredentials.keyType; } } else { - connOptions.password = tunnelConfig.sourcePassword; + connOptions.password = resolvedSourceCredentials.password; } + conn.on("ready", () => { - const killCmd = `pkill -f '${tunnelMarker}'`; - conn.exec(killCmd, (err, stream) => { - if (err) { - conn.end(); - callback(err); - return; - } - stream.on("close", () => { - conn.end(); - callback(); + const checkCmd = `ps aux | grep -E '(${tunnelMarker}|ssh.*-R.*${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort}.*${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP}|sshpass.*ssh.*-R.*${tunnelConfig.endpointPort})' | grep -v grep`; + + conn.exec(checkCmd, (err, stream) => { + let foundProcesses = false; + + stream.on("data", (data) => { + const output = data.toString().trim(); + if (output) { + foundProcesses = true; + } + }); + + stream.on("close", () => { + if (!foundProcesses) { + conn.end(); + callback(); + return; + } + + const killCmds = [ + `pkill -TERM -f '${tunnelMarker}'`, + `sleep 1 && pkill -f 'ssh.*-R.*${tunnelConfig.endpointPort}:localhost:${tunnelConfig.sourcePort}.*${tunnelConfig.endpointUsername}@${tunnelConfig.endpointIP}'`, + `sleep 1 && pkill -f 'sshpass.*ssh.*-R.*${tunnelConfig.endpointPort}'`, + `sleep 2 && pkill -9 -f '${tunnelMarker}'`, + ]; + + let commandIndex = 0; + + function executeNextKillCommand() { + if (commandIndex >= killCmds.length) { + conn.exec(checkCmd, (err, verifyStream) => { + let stillRunning = false; + + verifyStream.on("data", (data) => { + const output = data.toString().trim(); + if (output) { + stillRunning = true; + tunnelLogger.warn( + `Processes still running after cleanup for '${tunnelName}': ${output}`, + ); + } + }); + + verifyStream.on("close", () => { + if (stillRunning) { + tunnelLogger.warn( + `Some tunnel processes may still be running for '${tunnelName}'`, + ); + } + conn.end(); + callback(); + }); + }); + return; + } + + const killCmd = killCmds[commandIndex]; + + conn.exec(killCmd, (err, stream) => { + if (err) { + tunnelLogger.warn( + `Kill command ${commandIndex + 1} failed for '${tunnelName}': ${err.message}`, + ); + } else { + } + + stream.on("close", (code) => { + commandIndex++; + executeNextKillCommand(); + }); + + stream.on("data", (data) => { + const output = data.toString().trim(); + if (output) { + } + }); + + stream.stderr.on("data", (data) => { + const output = data.toString().trim(); + if (output && !output.includes("debug1")) { + tunnelLogger.warn( + `Kill command ${commandIndex + 1} stderr for '${tunnelName}': ${output}`, + ); + } + }); + }); + } + + executeNextKillCommand(); }); - stream.on("data", () => {}); - stream.stderr.on("data", () => {}); }); }); + conn.on("error", (err) => { + tunnelLogger.error( + `Failed to connect to source host for killing tunnel '${tunnelName}': ${err.message}`, + ); callback(err); }); + conn.connect(connOptions); } @@ -938,6 +1244,8 @@ app.post("/ssh/tunnel/connect", (req, res) => { const tunnelName = tunnelConfig.name; + cleanupTunnelResources(tunnelName); + manualDisconnects.delete(tunnelName); retryCounters.delete(tunnelName); retryExhaustedTunnels.delete(tunnelName); @@ -969,6 +1277,8 @@ app.post("/ssh/tunnel/disconnect", (req, res) => { activeRetryTimers.delete(tunnelName); } + cleanupTunnelResources(tunnelName, true); + broadcastTunnelStatus(tunnelName, { connected: false, status: CONNECTION_STATES.DISCONNECTED, @@ -1005,6 +1315,8 @@ app.post("/ssh/tunnel/cancel", (req, res) => { countdownIntervals.delete(tunnelName); } + cleanupTunnelResources(tunnelName, true); + broadcastTunnelStatus(tunnelName, { connected: false, status: CONNECTION_STATES.DISCONNECTED, @@ -1023,24 +1335,42 @@ app.post("/ssh/tunnel/cancel", (req, res) => { async function initializeAutoStartTunnels(): Promise { try { - const response = await axios.get( - "http://localhost:8081/ssh/db/host/internal", + const systemCrypto = SystemCrypto.getInstance(); + const internalAuthToken = await systemCrypto.getInternalAuthToken(); + + const autostartResponse = await axios.get( + "http://localhost:30001/ssh/db/host/internal", { headers: { "Content-Type": "application/json", - "X-Internal-Request": "1", + "X-Internal-Auth-Token": internalAuthToken, }, }, ); - const hosts: SSHHost[] = response.data || []; + const allHostsResponse = await axios.get( + "http://localhost:30001/ssh/db/host/internal/all", + { + headers: { + "Content-Type": "application/json", + "X-Internal-Auth-Token": internalAuthToken, + }, + }, + ); + + const autostartHosts: SSHHost[] = autostartResponse.data || []; + const allHosts: SSHHost[] = allHostsResponse.data || []; const autoStartTunnels: TunnelConfig[] = []; - for (const host of hosts) { + tunnelLogger.info( + `Found ${autostartHosts.length} autostart hosts and ${allHosts.length} total hosts for endpointHost resolution`, + ); + + for (const host of autostartHosts) { if (host.enableTunnel && host.tunnelConnections) { for (const tunnelConnection of host.tunnelConnections) { if (tunnelConnection.autoStart) { - const endpointHost = hosts.find( + const endpointHost = allHosts.find( (h) => h.name === tunnelConnection.endpointHost || `${h.username}@${h.ip}` === tunnelConnection.endpointHost, @@ -1053,19 +1383,35 @@ async function initializeAutoStartTunnels(): Promise { sourceIP: host.ip, sourceSSHPort: host.port, sourceUsername: host.username, - sourcePassword: host.password, + sourcePassword: host.autostartPassword || host.password, sourceAuthMethod: host.authType, - sourceSSHKey: host.key, - sourceKeyPassword: host.keyPassword, + sourceSSHKey: host.autostartKey || host.key, + sourceKeyPassword: + host.autostartKeyPassword || host.keyPassword, sourceKeyType: host.keyType, + sourceCredentialId: host.credentialId, + sourceUserId: host.userId, endpointIP: endpointHost.ip, endpointSSHPort: endpointHost.port, endpointUsername: endpointHost.username, - endpointPassword: endpointHost.password, - endpointAuthMethod: endpointHost.authType, - endpointSSHKey: endpointHost.key, - endpointKeyPassword: endpointHost.keyPassword, - endpointKeyType: endpointHost.keyType, + endpointPassword: + tunnelConnection.endpointPassword || + endpointHost.autostartPassword || + endpointHost.password, + endpointAuthMethod: + tunnelConnection.endpointAuthType || endpointHost.authType, + endpointSSHKey: + tunnelConnection.endpointKey || + endpointHost.autostartKey || + endpointHost.key, + endpointKeyPassword: + tunnelConnection.endpointKeyPassword || + endpointHost.autostartKeyPassword || + endpointHost.keyPassword, + endpointKeyType: + tunnelConnection.endpointKeyType || endpointHost.keyType, + endpointCredentialId: endpointHost.credentialId, + endpointUserId: endpointHost.userId, sourcePort: tunnelConnection.sourcePort, endpointPort: tunnelConnection.endpointPort, maxRetries: tunnelConnection.maxRetries, @@ -1074,15 +1420,25 @@ async function initializeAutoStartTunnels(): Promise { isPinned: host.pin, }; + const hasSourcePassword = host.autostartPassword; + const hasSourceKey = host.autostartKey; + const hasEndpointPassword = + tunnelConnection.endpointPassword || + endpointHost.autostartPassword; + const hasEndpointKey = + tunnelConnection.endpointKey || endpointHost.autostartKey; + autoStartTunnels.push(tunnelConfig); + } else { + tunnelLogger.error( + `Failed to find endpointHost '${tunnelConnection.endpointHost}' for tunnel from ${host.name || `${host.username}@${host.ip}`}. Available hosts: ${allHosts.map((h) => h.name || `${h.username}@${h.ip}`).join(", ")}`, + ); } } } } } - tunnelLogger.info(`Found ${autoStartTunnels.length} auto-start tunnels`); - for (const tunnelConfig of autoStartTunnels) { tunnelConfigs.set(tunnelConfig.name, tunnelConfig); @@ -1102,12 +1458,8 @@ async function initializeAutoStartTunnels(): Promise { } } -const PORT = 8083; +const PORT = 30003; app.listen(PORT, () => { - tunnelLogger.success("SSH Tunnel API server started", { - operation: "server_start", - port: PORT, - }); setTimeout(() => { initializeAutoStartTunnels(); }, 2000); diff --git a/src/backend/starter.ts b/src/backend/starter.ts index 83caf7ed..fb0cfc89 100644 --- a/src/backend/starter.ts +++ b/src/backend/starter.ts @@ -1,31 +1,107 @@ -// npx tsc -p tsconfig.node.json -// node ./dist/backend/starter.js - -import "./database/database.js"; -import "./ssh/terminal.js"; -import "./ssh/tunnel.js"; -import "./ssh/file-manager.js"; -import "./ssh/server-stats.js"; +import dotenv from "dotenv"; +import { promises as fs } from "fs"; +import { readFileSync } from "fs"; +import path from "path"; +import { fileURLToPath } from "url"; +import { AutoSSLSetup } from "./utils/auto-ssl-setup.js"; +import { AuthManager } from "./utils/auth-manager.js"; +import { DataCrypto } from "./utils/data-crypto.js"; +import { SystemCrypto } from "./utils/system-crypto.js"; import { systemLogger, versionLogger } from "./utils/logger.js"; -import "dotenv/config"; (async () => { try { - const version = process.env.VERSION || "unknown"; + dotenv.config({ quiet: true }); + + const dataDir = process.env.DATA_DIR || "./db/data"; + const envPath = path.join(dataDir, ".env"); + try { + await fs.access(envPath); + const persistentConfig = dotenv.config({ path: envPath, quiet: true }); + if (persistentConfig.parsed) { + Object.assign(process.env, persistentConfig.parsed); + } + } catch {} + + let version = "unknown"; + + const versionSources = [ + () => process.env.VERSION, + () => { + try { + const packageJsonPath = path.join(process.cwd(), "package.json"); + const packageJson = JSON.parse( + readFileSync(packageJsonPath, "utf-8"), + ); + return packageJson.version; + } catch { + return null; + } + }, + () => { + try { + const __filename = fileURLToPath(import.meta.url); + const packageJsonPath = path.join( + path.dirname(__filename), + "../../../package.json", + ); + const packageJson = JSON.parse( + readFileSync(packageJsonPath, "utf-8"), + ); + return packageJson.version; + } catch { + return null; + } + }, + () => { + try { + const packageJsonPath = path.join("/app", "package.json"); + const packageJson = JSON.parse( + readFileSync(packageJsonPath, "utf-8"), + ); + return packageJson.version; + } catch { + return null; + } + }, + ]; + + for (const getVersion of versionSources) { + try { + const foundVersion = getVersion(); + if (foundVersion && foundVersion !== "unknown") { + version = foundVersion; + break; + } + } catch (error) { + continue; + } + } versionLogger.info(`Termix Backend starting - Version: ${version}`, { operation: "startup", version: version, }); - systemLogger.info("Initializing backend services...", { - operation: "startup", - }); + const systemCrypto = SystemCrypto.getInstance(); + await systemCrypto.initializeJWTSecret(); + await systemCrypto.initializeDatabaseKey(); + await systemCrypto.initializeInternalAuthToken(); - systemLogger.success("All backend services initialized successfully", { - operation: "startup_complete", - services: ["database", "terminal", "tunnel", "file_manager", "stats"], - version: version, - }); + await AutoSSLSetup.initialize(); + + const dbModule = await import("./database/db/index.js"); + await dbModule.initializeDatabase(); + + const authManager = AuthManager.getInstance(); + await authManager.initialize(); + DataCrypto.initialize(); + + await import("./database/database.js"); + + await import("./ssh/terminal.js"); + await import("./ssh/tunnel.js"); + await import("./ssh/file-manager.js"); + await import("./ssh/server-stats.js"); process.on("SIGINT", () => { systemLogger.info( diff --git a/src/backend/utils/auth-manager.ts b/src/backend/utils/auth-manager.ts new file mode 100644 index 00000000..541d889f --- /dev/null +++ b/src/backend/utils/auth-manager.ts @@ -0,0 +1,300 @@ +import jwt from "jsonwebtoken"; +import { UserCrypto } from "./user-crypto.js"; +import { SystemCrypto } from "./system-crypto.js"; +import { DataCrypto } from "./data-crypto.js"; +import { databaseLogger } from "./logger.js"; +import type { Request, Response, NextFunction } from "express"; + +interface AuthenticationResult { + success: boolean; + token?: string; + userId?: string; + isAdmin?: boolean; + username?: string; + requiresTOTP?: boolean; + tempToken?: string; + error?: string; +} + +interface JWTPayload { + userId: string; + pendingTOTP?: boolean; + iat?: number; + exp?: number; +} + +class AuthManager { + private static instance: AuthManager; + private systemCrypto: SystemCrypto; + private userCrypto: UserCrypto; + private invalidatedTokens: Set = new Set(); + + private constructor() { + this.systemCrypto = SystemCrypto.getInstance(); + this.userCrypto = UserCrypto.getInstance(); + + this.userCrypto.setSessionExpiredCallback((userId: string) => { + this.invalidateUserTokens(userId); + }); + } + + static getInstance(): AuthManager { + if (!this.instance) { + this.instance = new AuthManager(); + } + return this.instance; + } + + async initialize(): Promise { + await this.systemCrypto.initializeJWTSecret(); + } + + async registerUser(userId: string, password: string): Promise { + await this.userCrypto.setupUserEncryption(userId, password); + } + + async registerOIDCUser(userId: string): Promise { + await this.userCrypto.setupOIDCUserEncryption(userId); + } + + async authenticateOIDCUser(userId: string): Promise { + const authenticated = await this.userCrypto.authenticateOIDCUser(userId); + + if (authenticated) { + await this.performLazyEncryptionMigration(userId); + } + + return authenticated; + } + + async authenticateUser(userId: string, password: string): Promise { + const authenticated = await this.userCrypto.authenticateUser( + userId, + password, + ); + + if (authenticated) { + await this.performLazyEncryptionMigration(userId); + } + + return authenticated; + } + + private async performLazyEncryptionMigration(userId: string): Promise { + try { + const userDataKey = this.getUserDataKey(userId); + if (!userDataKey) { + databaseLogger.warn( + "Cannot perform lazy encryption migration - user data key not available", + { + operation: "lazy_encryption_migration_no_key", + userId, + }, + ); + return; + } + + const { getSqlite, saveMemoryDatabaseToFile } = await import( + "../database/db/index.js" + ); + + const sqlite = getSqlite(); + + const migrationResult = await DataCrypto.migrateUserSensitiveFields( + userId, + userDataKey, + sqlite, + ); + + if (migrationResult.migrated) { + await saveMemoryDatabaseToFile(); + } else { + } + } catch (error) { + databaseLogger.error("Lazy encryption migration failed", error, { + operation: "lazy_encryption_migration_error", + userId, + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + + async generateJWTToken( + userId: string, + options: { expiresIn?: string; pendingTOTP?: boolean } = {}, + ): Promise { + const jwtSecret = await this.systemCrypto.getJWTSecret(); + + const payload: JWTPayload = { userId }; + if (options.pendingTOTP) { + payload.pendingTOTP = true; + } + + return jwt.sign(payload, jwtSecret, { + expiresIn: options.expiresIn || "24h", + } as jwt.SignOptions); + } + + async verifyJWTToken(token: string): Promise { + try { + if (this.invalidatedTokens.has(token)) { + return null; + } + + const jwtSecret = await this.systemCrypto.getJWTSecret(); + const payload = jwt.verify(token, jwtSecret) as JWTPayload; + return payload; + } catch (error) { + databaseLogger.warn("JWT verification failed", { + operation: "jwt_verify_failed", + error: error instanceof Error ? error.message : "Unknown error", + }); + return null; + } + } + + invalidateJWTToken(token: string): void { + this.invalidatedTokens.add(token); + } + + invalidateUserTokens(userId: string): void { + databaseLogger.info("User tokens invalidated due to data lock", { + operation: "user_tokens_invalidate", + userId, + }); + } + + getSecureCookieOptions(req: any, maxAge: number = 24 * 60 * 60 * 1000) { + return { + httpOnly: false, + secure: req.secure || req.headers["x-forwarded-proto"] === "https", + sameSite: "strict" as const, + maxAge: maxAge, + path: "/", + }; + } + + createAuthMiddleware() { + return async (req: Request, res: Response, next: NextFunction) => { + let token = req.cookies?.jwt; + + if (!token) { + const authHeader = req.headers["authorization"]; + if (authHeader?.startsWith("Bearer ")) { + token = authHeader.split(" ")[1]; + } + } + + if (!token) { + return res.status(401).json({ error: "Missing authentication token" }); + } + + const payload = await this.verifyJWTToken(token); + + if (!payload) { + return res.status(401).json({ error: "Invalid token" }); + } + + (req as any).userId = payload.userId; + (req as any).pendingTOTP = payload.pendingTOTP; + next(); + }; + } + + createDataAccessMiddleware() { + return async (req: Request, res: Response, next: NextFunction) => { + const userId = (req as any).userId; + if (!userId) { + return res.status(401).json({ error: "Authentication required" }); + } + + const dataKey = this.userCrypto.getUserDataKey(userId); + if (!dataKey) { + return res.status(401).json({ + error: "Session expired - please log in again", + code: "SESSION_EXPIRED", + }); + } + + (req as any).dataKey = dataKey; + next(); + }; + } + + createAdminMiddleware() { + return async (req: Request, res: Response, next: NextFunction) => { + const authHeader = req.headers["authorization"]; + if (!authHeader?.startsWith("Bearer ")) { + return res.status(401).json({ error: "Missing Authorization header" }); + } + + const token = authHeader.split(" ")[1]; + const payload = await this.verifyJWTToken(token); + + if (!payload) { + return res.status(401).json({ error: "Invalid token" }); + } + + try { + const { db } = await import("../database/db/index.js"); + const { users } = await import("../database/db/schema.js"); + const { eq } = await import("drizzle-orm"); + + const user = await db + .select() + .from(users) + .where(eq(users.id, payload.userId)); + + if (!user || user.length === 0 || !user[0].is_admin) { + databaseLogger.warn( + "Non-admin user attempted to access admin endpoint", + { + operation: "admin_access_denied", + userId: payload.userId, + endpoint: req.path, + }, + ); + return res.status(403).json({ error: "Admin access required" }); + } + + (req as any).userId = payload.userId; + (req as any).pendingTOTP = payload.pendingTOTP; + next(); + } catch (error) { + databaseLogger.error("Failed to verify admin privileges", error, { + operation: "admin_check_failed", + userId: payload.userId, + }); + return res + .status(500) + .json({ error: "Failed to verify admin privileges" }); + } + }; + } + + logoutUser(userId: string): void { + this.userCrypto.logoutUser(userId); + } + + getUserDataKey(userId: string): Buffer | null { + return this.userCrypto.getUserDataKey(userId); + } + + isUserUnlocked(userId: string): boolean { + return this.userCrypto.isUserUnlocked(userId); + } + + async changeUserPassword( + userId: string, + oldPassword: string, + newPassword: string, + ): Promise { + return await this.userCrypto.changeUserPassword( + userId, + oldPassword, + newPassword, + ); + } +} + +export { AuthManager, type AuthenticationResult, type JWTPayload }; diff --git a/src/backend/utils/auto-ssl-setup.ts b/src/backend/utils/auto-ssl-setup.ts new file mode 100644 index 00000000..e2d1034a --- /dev/null +++ b/src/backend/utils/auto-ssl-setup.ts @@ -0,0 +1,280 @@ +import { execSync } from "child_process"; +import { promises as fs } from "fs"; +import path from "path"; +import crypto from "crypto"; +import { systemLogger } from "./logger.js"; + +export class AutoSSLSetup { + private static readonly DATA_DIR = process.env.DATA_DIR || "./db/data"; + private static readonly SSL_DIR = path.join(AutoSSLSetup.DATA_DIR, "ssl"); + private static readonly CERT_FILE = path.join( + AutoSSLSetup.SSL_DIR, + "termix.crt", + ); + private static readonly KEY_FILE = path.join( + AutoSSLSetup.SSL_DIR, + "termix.key", + ); + private static readonly ENV_FILE = path.join(AutoSSLSetup.DATA_DIR, ".env"); + + static async initialize(): Promise { + if (process.env.ENABLE_SSL !== "true") { + systemLogger.info("SSL not enabled - skipping certificate generation", { + operation: "ssl_disabled_default", + enable_ssl: process.env.ENABLE_SSL || "undefined", + note: "Set ENABLE_SSL=true to enable SSL certificate generation", + }); + return; + } + + try { + if (await this.isSSLConfigured()) { + await this.logCertificateInfo(); + await this.setupEnvironmentVariables(); + return; + } + + try { + await fs.access(this.CERT_FILE); + await fs.access(this.KEY_FILE); + + systemLogger.info("SSL certificates found from entrypoint script", { + operation: "ssl_cert_found_entrypoint", + cert_path: this.CERT_FILE, + key_path: this.KEY_FILE, + }); + + await this.logCertificateInfo(); + await this.setupEnvironmentVariables(); + return; + } catch { + await this.generateSSLCertificates(); + await this.setupEnvironmentVariables(); + } + } catch (error) { + systemLogger.error("Failed to initialize SSL configuration", error, { + operation: "ssl_auto_init_failed", + }); + + systemLogger.warn("Falling back to HTTP-only mode", { + operation: "ssl_fallback_http", + }); + } + } + + private static async isSSLConfigured(): Promise { + try { + await fs.access(this.CERT_FILE); + await fs.access(this.KEY_FILE); + + execSync( + `openssl x509 -in "${this.CERT_FILE}" -checkend 2592000 -noout`, + { + stdio: "pipe", + }, + ); + + return true; + } catch (error) { + if (error instanceof Error && error.message.includes("checkend")) { + systemLogger.warn( + "SSL certificate is expired or expiring soon, will regenerate", + { + operation: "ssl_cert_expired", + cert_path: this.CERT_FILE, + error: error.message, + }, + ); + } else { + systemLogger.info( + "SSL certificate not found or invalid, will generate new one", + { + operation: "ssl_cert_missing", + cert_path: this.CERT_FILE, + }, + ); + } + return false; + } + } + + private static async generateSSLCertificates(): Promise { + try { + try { + execSync("openssl version", { stdio: "pipe" }); + } catch (error) { + throw new Error( + "OpenSSL is not installed or not available in PATH. Please install OpenSSL to enable SSL certificate generation.", + ); + } + + await fs.mkdir(this.SSL_DIR, { recursive: true }); + + const configFile = path.join(this.SSL_DIR, "openssl.conf"); + const opensslConfig = ` +[req] +default_bits = 2048 +prompt = no +default_md = sha256 +distinguished_name = dn +req_extensions = v3_req + +[dn] +C=US +ST=State +L=City +O=Termix +OU=IT Department +CN=localhost + +[v3_req] +basicConstraints = CA:FALSE +keyUsage = nonRepudiation, digitalSignature, keyEncipherment +subjectAltName = @alt_names + +[alt_names] +DNS.1 = localhost +DNS.2 = 127.0.0.1 +DNS.3 = *.localhost +DNS.4 = termix.local +DNS.5 = *.termix.local +IP.1 = 127.0.0.1 +IP.2 = ::1 +IP.3 = 0.0.0.0 + `.trim(); + + await fs.writeFile(configFile, opensslConfig); + + execSync(`openssl genrsa -out "${this.KEY_FILE}" 2048`, { + stdio: "pipe", + }); + + execSync( + `openssl req -new -x509 -key "${this.KEY_FILE}" -out "${this.CERT_FILE}" -days 365 -config "${configFile}" -extensions v3_req`, + { + stdio: "pipe", + }, + ); + + await fs.chmod(this.KEY_FILE, 0o600); + await fs.chmod(this.CERT_FILE, 0o644); + + await fs.unlink(configFile); + + systemLogger.success("SSL certificates generated successfully", { + operation: "ssl_cert_generated", + cert_path: this.CERT_FILE, + key_path: this.KEY_FILE, + valid_days: 365, + }); + + await this.logCertificateInfo(); + } catch (error) { + throw new Error( + `SSL certificate generation failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + private static async logCertificateInfo(): Promise { + try { + const subject = execSync( + `openssl x509 -in "${this.CERT_FILE}" -noout -subject`, + { stdio: "pipe" }, + ) + .toString() + .trim(); + const issuer = execSync( + `openssl x509 -in "${this.CERT_FILE}" -noout -issuer`, + { stdio: "pipe" }, + ) + .toString() + .trim(); + const notAfter = execSync( + `openssl x509 -in "${this.CERT_FILE}" -noout -enddate`, + { stdio: "pipe" }, + ) + .toString() + .trim(); + const notBefore = execSync( + `openssl x509 -in "${this.CERT_FILE}" -noout -startdate`, + { stdio: "pipe" }, + ) + .toString() + .trim(); + + systemLogger.info("SSL Certificate Information:", { + operation: "ssl_cert_info", + subject: subject.replace("subject=", ""), + issuer: issuer.replace("issuer=", ""), + valid_from: notBefore.replace("notBefore=", ""), + valid_until: notAfter.replace("notAfter=", ""), + note: "Certificate will auto-renew 30 days before expiration", + }); + } catch (error) { + systemLogger.warn("Could not retrieve certificate information", { + operation: "ssl_cert_info_error", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + + private static async setupEnvironmentVariables(): Promise { + const certPath = this.CERT_FILE; + const keyPath = this.KEY_FILE; + + const sslEnvVars = { + ENABLE_SSL: "false", + SSL_PORT: process.env.SSL_PORT || "8443", + SSL_CERT_PATH: certPath, + SSL_KEY_PATH: keyPath, + SSL_DOMAIN: "localhost", + }; + + let envContent = ""; + try { + envContent = await fs.readFile(this.ENV_FILE, "utf8"); + } catch {} + + let updatedContent = envContent; + let hasChanges = false; + + for (const [key, value] of Object.entries(sslEnvVars)) { + const regex = new RegExp(`^${key}=.*$`, "m"); + + if (regex.test(updatedContent)) { + updatedContent = updatedContent.replace(regex, `${key}=${value}`); + } else { + if (!updatedContent.includes(`# SSL Configuration`)) { + updatedContent += `\n# SSL Configuration (Auto-generated)\n`; + } + updatedContent += `${key}=${value}\n`; + hasChanges = true; + } + } + + if (hasChanges || !envContent) { + await fs.writeFile(this.ENV_FILE, updatedContent.trim() + "\n"); + + systemLogger.info("SSL environment variables configured", { + operation: "ssl_env_configured", + file: this.ENV_FILE, + variables: Object.keys(sslEnvVars), + }); + } + + for (const [key, value] of Object.entries(sslEnvVars)) { + process.env[key] = value; + } + } + + static getSSLConfig() { + return { + enabled: process.env.ENABLE_SSL === "true", + port: parseInt(process.env.SSL_PORT || "8443"), + certPath: process.env.SSL_CERT_PATH || this.CERT_FILE, + keyPath: process.env.SSL_KEY_PATH || this.KEY_FILE, + domain: process.env.SSL_DOMAIN || "localhost", + }; + } +} diff --git a/src/backend/utils/data-crypto.ts b/src/backend/utils/data-crypto.ts new file mode 100644 index 00000000..37099a6a --- /dev/null +++ b/src/backend/utils/data-crypto.ts @@ -0,0 +1,284 @@ +import { FieldCrypto } from "./field-crypto.js"; +import { LazyFieldEncryption } from "./lazy-field-encryption.js"; +import { UserCrypto } from "./user-crypto.js"; +import { databaseLogger } from "./logger.js"; + +class DataCrypto { + private static userCrypto: UserCrypto; + + static initialize() { + this.userCrypto = UserCrypto.getInstance(); + } + + static encryptRecord( + tableName: string, + record: any, + userId: string, + userDataKey: Buffer, + ): any { + const encryptedRecord = { ...record }; + const recordId = record.id || "temp-" + Date.now(); + + for (const [fieldName, value] of Object.entries(record)) { + if (FieldCrypto.shouldEncryptField(tableName, fieldName) && value) { + encryptedRecord[fieldName] = FieldCrypto.encryptField( + value as string, + userDataKey, + recordId, + fieldName, + ); + } + } + + return encryptedRecord; + } + + static decryptRecord( + tableName: string, + record: any, + userId: string, + userDataKey: Buffer, + ): any { + if (!record) return record; + + const decryptedRecord = { ...record }; + const recordId = record.id; + + for (const [fieldName, value] of Object.entries(record)) { + if (FieldCrypto.shouldEncryptField(tableName, fieldName) && value) { + decryptedRecord[fieldName] = LazyFieldEncryption.safeGetFieldValue( + value as string, + userDataKey, + recordId, + fieldName, + ); + } + } + + return decryptedRecord; + } + + static decryptRecords( + tableName: string, + records: any[], + userId: string, + userDataKey: Buffer, + ): any[] { + if (!Array.isArray(records)) return records; + return records.map((record) => + this.decryptRecord(tableName, record, userId, userDataKey), + ); + } + + static async migrateUserSensitiveFields( + userId: string, + userDataKey: Buffer, + db: any, + ): Promise<{ + migrated: boolean; + migratedTables: string[]; + migratedFieldsCount: number; + }> { + let migrated = false; + const migratedTables: string[] = []; + let migratedFieldsCount = 0; + + try { + const { needsMigration, plaintextFields } = + await LazyFieldEncryption.checkUserNeedsMigration( + userId, + userDataKey, + db, + ); + + if (!needsMigration) { + return { migrated: false, migratedTables: [], migratedFieldsCount: 0 }; + } + + const sshDataRecords = db + .prepare("SELECT * FROM ssh_data WHERE user_id = ?") + .all(userId); + for (const record of sshDataRecords) { + const sensitiveFields = + LazyFieldEncryption.getSensitiveFieldsForTable("ssh_data"); + const { updatedRecord, migratedFields, needsUpdate } = + LazyFieldEncryption.migrateRecordSensitiveFields( + record, + sensitiveFields, + userDataKey, + record.id.toString(), + ); + + if (needsUpdate) { + const updateQuery = ` + UPDATE ssh_data + SET password = ?, key = ?, key_password = ?, updated_at = CURRENT_TIMESTAMP + WHERE id = ? + `; + db.prepare(updateQuery).run( + updatedRecord.password || null, + updatedRecord.key || null, + updatedRecord.key_password || null, + record.id, + ); + + migratedFieldsCount += migratedFields.length; + if (!migratedTables.includes("ssh_data")) { + migratedTables.push("ssh_data"); + } + migrated = true; + } + } + + const sshCredentialsRecords = db + .prepare("SELECT * FROM ssh_credentials WHERE user_id = ?") + .all(userId); + for (const record of sshCredentialsRecords) { + const sensitiveFields = + LazyFieldEncryption.getSensitiveFieldsForTable("ssh_credentials"); + const { updatedRecord, migratedFields, needsUpdate } = + LazyFieldEncryption.migrateRecordSensitiveFields( + record, + sensitiveFields, + userDataKey, + record.id.toString(), + ); + + if (needsUpdate) { + const updateQuery = ` + UPDATE ssh_credentials + SET password = ?, key = ?, key_password = ?, private_key = ?, updated_at = CURRENT_TIMESTAMP + WHERE id = ? + `; + db.prepare(updateQuery).run( + updatedRecord.password || null, + updatedRecord.key || null, + updatedRecord.key_password || null, + updatedRecord.private_key || null, + record.id, + ); + + migratedFieldsCount += migratedFields.length; + if (!migratedTables.includes("ssh_credentials")) { + migratedTables.push("ssh_credentials"); + } + migrated = true; + } + } + + const userRecord = db + .prepare("SELECT * FROM users WHERE id = ?") + .get(userId); + if (userRecord) { + const sensitiveFields = + LazyFieldEncryption.getSensitiveFieldsForTable("users"); + const { updatedRecord, migratedFields, needsUpdate } = + LazyFieldEncryption.migrateRecordSensitiveFields( + userRecord, + sensitiveFields, + userDataKey, + userId, + ); + + if (needsUpdate) { + const updateQuery = ` + UPDATE users + SET totp_secret = ?, totp_backup_codes = ? + WHERE id = ? + `; + db.prepare(updateQuery).run( + updatedRecord.totp_secret || null, + updatedRecord.totp_backup_codes || null, + userId, + ); + + migratedFieldsCount += migratedFields.length; + if (!migratedTables.includes("users")) { + migratedTables.push("users"); + } + migrated = true; + } + } + + return { migrated, migratedTables, migratedFieldsCount }; + } catch (error) { + databaseLogger.error("User sensitive fields migration failed", error, { + operation: "user_sensitive_migration_failed", + userId, + error: error instanceof Error ? error.message : "Unknown error", + }); + + return { migrated: false, migratedTables: [], migratedFieldsCount: 0 }; + } + } + + static getUserDataKey(userId: string): Buffer | null { + return this.userCrypto.getUserDataKey(userId); + } + + static validateUserAccess(userId: string): Buffer { + const userDataKey = this.getUserDataKey(userId); + if (!userDataKey) { + throw new Error(`User ${userId} data not unlocked`); + } + return userDataKey; + } + + static encryptRecordForUser( + tableName: string, + record: any, + userId: string, + ): any { + const userDataKey = this.validateUserAccess(userId); + return this.encryptRecord(tableName, record, userId, userDataKey); + } + + static decryptRecordForUser( + tableName: string, + record: any, + userId: string, + ): any { + const userDataKey = this.validateUserAccess(userId); + return this.decryptRecord(tableName, record, userId, userDataKey); + } + + static decryptRecordsForUser( + tableName: string, + records: any[], + userId: string, + ): any[] { + const userDataKey = this.validateUserAccess(userId); + return this.decryptRecords(tableName, records, userId, userDataKey); + } + + static canUserAccessData(userId: string): boolean { + return this.userCrypto.isUserUnlocked(userId); + } + + static testUserEncryption(userId: string): boolean { + try { + const userDataKey = this.getUserDataKey(userId); + if (!userDataKey) return false; + + const testData = "test-" + Date.now(); + const encrypted = FieldCrypto.encryptField( + testData, + userDataKey, + "test-record", + "test-field", + ); + const decrypted = FieldCrypto.decryptField( + encrypted, + userDataKey, + "test-record", + "test-field", + ); + + return decrypted === testData; + } catch (error) { + return false; + } + } +} + +export { DataCrypto }; diff --git a/src/backend/utils/database-file-encryption.ts b/src/backend/utils/database-file-encryption.ts new file mode 100644 index 00000000..db302d2e --- /dev/null +++ b/src/backend/utils/database-file-encryption.ts @@ -0,0 +1,400 @@ +import crypto from "crypto"; +import fs from "fs"; +import path from "path"; +import { databaseLogger } from "./logger.js"; +import { SystemCrypto } from "./system-crypto.js"; + +interface EncryptedFileMetadata { + iv: string; + tag: string; + version: string; + fingerprint: string; + algorithm: string; + keySource?: string; + salt?: string; +} + +class DatabaseFileEncryption { + private static readonly VERSION = "v2"; + private static readonly ALGORITHM = "aes-256-gcm"; + private static readonly ENCRYPTED_FILE_SUFFIX = ".encrypted"; + private static readonly METADATA_FILE_SUFFIX = ".meta"; + private static systemCrypto = SystemCrypto.getInstance(); + + static async encryptDatabaseFromBuffer( + buffer: Buffer, + targetPath: string, + ): Promise { + try { + const key = await this.systemCrypto.getDatabaseKey(); + + const iv = crypto.randomBytes(16); + + const cipher = crypto.createCipheriv(this.ALGORITHM, key, iv) as any; + const encrypted = Buffer.concat([cipher.update(buffer), cipher.final()]); + const tag = cipher.getAuthTag(); + + const metadata: EncryptedFileMetadata = { + iv: iv.toString("hex"), + tag: tag.toString("hex"), + version: this.VERSION, + fingerprint: "termix-v2-systemcrypto", + algorithm: this.ALGORITHM, + keySource: "SystemCrypto", + }; + + const metadataPath = `${targetPath}${this.METADATA_FILE_SUFFIX}`; + fs.writeFileSync(targetPath, encrypted); + fs.writeFileSync(metadataPath, JSON.stringify(metadata, null, 2)); + + return targetPath; + } catch (error) { + databaseLogger.error("Failed to encrypt database buffer", error, { + operation: "database_buffer_encryption_failed", + targetPath, + }); + throw new Error( + `Database buffer encryption failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + static async encryptDatabaseFile( + sourcePath: string, + targetPath?: string, + ): Promise { + if (!fs.existsSync(sourcePath)) { + throw new Error(`Source database file does not exist: ${sourcePath}`); + } + + const encryptedPath = + targetPath || `${sourcePath}${this.ENCRYPTED_FILE_SUFFIX}`; + const metadataPath = `${encryptedPath}${this.METADATA_FILE_SUFFIX}`; + + try { + const sourceData = fs.readFileSync(sourcePath); + + const key = await this.systemCrypto.getDatabaseKey(); + + const iv = crypto.randomBytes(16); + + const cipher = crypto.createCipheriv(this.ALGORITHM, key, iv) as any; + const encrypted = Buffer.concat([ + cipher.update(sourceData), + cipher.final(), + ]); + const tag = cipher.getAuthTag(); + + const metadata: EncryptedFileMetadata = { + iv: iv.toString("hex"), + tag: tag.toString("hex"), + version: this.VERSION, + fingerprint: "termix-v2-systemcrypto", + algorithm: this.ALGORITHM, + keySource: "SystemCrypto", + }; + + fs.writeFileSync(encryptedPath, encrypted); + fs.writeFileSync(metadataPath, JSON.stringify(metadata, null, 2)); + + databaseLogger.info("Database file encrypted successfully", { + operation: "database_file_encryption", + sourcePath, + encryptedPath, + fileSize: sourceData.length, + encryptedSize: encrypted.length, + fingerprintPrefix: metadata.fingerprint, + }); + + return encryptedPath; + } catch (error) { + databaseLogger.error("Failed to encrypt database file", error, { + operation: "database_file_encryption_failed", + sourcePath, + targetPath: encryptedPath, + }); + throw new Error( + `Database file encryption failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + static async decryptDatabaseToBuffer(encryptedPath: string): Promise { + if (!fs.existsSync(encryptedPath)) { + throw new Error( + `Encrypted database file does not exist: ${encryptedPath}`, + ); + } + + const metadataPath = `${encryptedPath}${this.METADATA_FILE_SUFFIX}`; + if (!fs.existsSync(metadataPath)) { + throw new Error(`Metadata file does not exist: ${metadataPath}`); + } + + try { + const metadataContent = fs.readFileSync(metadataPath, "utf8"); + const metadata: EncryptedFileMetadata = JSON.parse(metadataContent); + + const encryptedData = fs.readFileSync(encryptedPath); + + let key: Buffer; + if (metadata.version === "v2") { + key = await this.systemCrypto.getDatabaseKey(); + } else if (metadata.version === "v1") { + databaseLogger.warn( + "Decrypting legacy v1 encrypted database - consider upgrading", + { + operation: "decrypt_legacy_v1", + path: encryptedPath, + }, + ); + if (!metadata.salt) { + throw new Error("v1 encrypted file missing required salt field"); + } + const salt = Buffer.from(metadata.salt, "hex"); + const fixedSeed = + process.env.DB_FILE_KEY || "termix-database-file-encryption-seed-v1"; + key = crypto.pbkdf2Sync(fixedSeed, salt, 100000, 32, "sha256"); + } else { + throw new Error(`Unsupported encryption version: ${metadata.version}`); + } + + const decipher = crypto.createDecipheriv( + metadata.algorithm, + key, + Buffer.from(metadata.iv, "hex"), + ) as any; + decipher.setAuthTag(Buffer.from(metadata.tag, "hex")); + + const decryptedBuffer = Buffer.concat([ + decipher.update(encryptedData), + decipher.final(), + ]); + + return decryptedBuffer; + } catch (error) { + databaseLogger.error("Failed to decrypt database to buffer", error, { + operation: "database_buffer_decryption_failed", + encryptedPath, + }); + throw new Error( + `Database buffer decryption failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + static async decryptDatabaseFile( + encryptedPath: string, + targetPath?: string, + ): Promise { + if (!fs.existsSync(encryptedPath)) { + throw new Error( + `Encrypted database file does not exist: ${encryptedPath}`, + ); + } + + const metadataPath = `${encryptedPath}${this.METADATA_FILE_SUFFIX}`; + if (!fs.existsSync(metadataPath)) { + throw new Error(`Metadata file does not exist: ${metadataPath}`); + } + + const decryptedPath = + targetPath || encryptedPath.replace(this.ENCRYPTED_FILE_SUFFIX, ""); + + try { + const metadataContent = fs.readFileSync(metadataPath, "utf8"); + const metadata: EncryptedFileMetadata = JSON.parse(metadataContent); + + const encryptedData = fs.readFileSync(encryptedPath); + + let key: Buffer; + if (metadata.version === "v2") { + key = await this.systemCrypto.getDatabaseKey(); + } else if (metadata.version === "v1") { + databaseLogger.warn( + "Decrypting legacy v1 encrypted database - consider upgrading", + { + operation: "decrypt_legacy_v1", + path: encryptedPath, + }, + ); + if (!metadata.salt) { + throw new Error("v1 encrypted file missing required salt field"); + } + const salt = Buffer.from(metadata.salt, "hex"); + const fixedSeed = + process.env.DB_FILE_KEY || "termix-database-file-encryption-seed-v1"; + key = crypto.pbkdf2Sync(fixedSeed, salt, 100000, 32, "sha256"); + } else { + throw new Error(`Unsupported encryption version: ${metadata.version}`); + } + + const decipher = crypto.createDecipheriv( + metadata.algorithm, + key, + Buffer.from(metadata.iv, "hex"), + ) as any; + decipher.setAuthTag(Buffer.from(metadata.tag, "hex")); + + const decrypted = Buffer.concat([ + decipher.update(encryptedData), + decipher.final(), + ]); + + fs.writeFileSync(decryptedPath, decrypted); + + databaseLogger.info("Database file decrypted successfully", { + operation: "database_file_decryption", + encryptedPath, + decryptedPath, + encryptedSize: encryptedData.length, + decryptedSize: decrypted.length, + fingerprintPrefix: metadata.fingerprint, + }); + + return decryptedPath; + } catch (error) { + databaseLogger.error("Failed to decrypt database file", error, { + operation: "database_file_decryption_failed", + encryptedPath, + targetPath: decryptedPath, + }); + throw new Error( + `Database file decryption failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + static isEncryptedDatabaseFile(filePath: string): boolean { + const metadataPath = `${filePath}${this.METADATA_FILE_SUFFIX}`; + + if (!fs.existsSync(filePath) || !fs.existsSync(metadataPath)) { + return false; + } + + try { + const metadataContent = fs.readFileSync(metadataPath, "utf8"); + const metadata: EncryptedFileMetadata = JSON.parse(metadataContent); + return ( + metadata.version === this.VERSION && + metadata.algorithm === this.ALGORITHM + ); + } catch { + return false; + } + } + + static getEncryptedFileInfo(encryptedPath: string): { + version: string; + algorithm: string; + fingerprint: string; + isCurrentHardware: boolean; + fileSize: number; + } | null { + if (!this.isEncryptedDatabaseFile(encryptedPath)) { + return null; + } + + try { + const metadataPath = `${encryptedPath}${this.METADATA_FILE_SUFFIX}`; + const metadataContent = fs.readFileSync(metadataPath, "utf8"); + const metadata: EncryptedFileMetadata = JSON.parse(metadataContent); + + const fileStats = fs.statSync(encryptedPath); + const currentFingerprint = "termix-v1-file"; + + return { + version: metadata.version, + algorithm: metadata.algorithm, + fingerprint: metadata.fingerprint, + isCurrentHardware: true, + fileSize: fileStats.size, + }; + } catch { + return null; + } + } + + static async createEncryptedBackup( + databasePath: string, + backupDir: string, + ): Promise { + if (!fs.existsSync(databasePath)) { + throw new Error(`Database file does not exist: ${databasePath}`); + } + + if (!fs.existsSync(backupDir)) { + fs.mkdirSync(backupDir, { recursive: true }); + } + + const timestamp = new Date().toISOString().replace(/[:.]/g, "-"); + const backupFileName = `database-backup-${timestamp}.sqlite.encrypted`; + const backupPath = path.join(backupDir, backupFileName); + + try { + const encryptedPath = await this.encryptDatabaseFile( + databasePath, + backupPath, + ); + + return encryptedPath; + } catch (error) { + databaseLogger.error("Failed to create encrypted backup", error, { + operation: "database_backup_failed", + sourcePath: databasePath, + backupDir, + }); + throw error; + } + } + + static async restoreFromEncryptedBackup( + backupPath: string, + targetPath: string, + ): Promise { + if (!this.isEncryptedDatabaseFile(backupPath)) { + throw new Error("Invalid encrypted backup file"); + } + + try { + const restoredPath = await this.decryptDatabaseFile( + backupPath, + targetPath, + ); + + return restoredPath; + } catch (error) { + databaseLogger.error("Failed to restore from encrypted backup", error, { + operation: "database_restore_failed", + backupPath, + targetPath, + }); + throw error; + } + } + + static cleanupTempFiles(basePath: string): void { + try { + const tempFiles = [ + `${basePath}.tmp`, + `${basePath}${this.ENCRYPTED_FILE_SUFFIX}`, + `${basePath}${this.ENCRYPTED_FILE_SUFFIX}${this.METADATA_FILE_SUFFIX}`, + ]; + + for (const tempFile of tempFiles) { + if (fs.existsSync(tempFile)) { + fs.unlinkSync(tempFile); + } + } + } catch (error) { + databaseLogger.warn("Failed to clean up temporary files", { + operation: "temp_cleanup_failed", + basePath, + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } +} + +export { DatabaseFileEncryption }; +export type { EncryptedFileMetadata }; diff --git a/src/backend/utils/database-migration.ts b/src/backend/utils/database-migration.ts new file mode 100644 index 00000000..ebf3192b --- /dev/null +++ b/src/backend/utils/database-migration.ts @@ -0,0 +1,404 @@ +import Database from "better-sqlite3"; +import fs from "fs"; +import path from "path"; +import { databaseLogger } from "./logger.js"; +import { DatabaseFileEncryption } from "./database-file-encryption.js"; + +export interface MigrationResult { + success: boolean; + error?: string; + migratedTables: number; + migratedRows: number; + backupPath?: string; + duration: number; +} + +export interface MigrationStatus { + needsMigration: boolean; + hasUnencryptedDb: boolean; + hasEncryptedDb: boolean; + unencryptedDbSize: number; + reason: string; +} + +export class DatabaseMigration { + private dataDir: string; + private unencryptedDbPath: string; + private encryptedDbPath: string; + + constructor(dataDir: string) { + this.dataDir = dataDir; + this.unencryptedDbPath = path.join(dataDir, "db.sqlite"); + this.encryptedDbPath = `${this.unencryptedDbPath}.encrypted`; + } + + checkMigrationStatus(): MigrationStatus { + const hasUnencryptedDb = fs.existsSync(this.unencryptedDbPath); + const hasEncryptedDb = DatabaseFileEncryption.isEncryptedDatabaseFile( + this.encryptedDbPath, + ); + + let unencryptedDbSize = 0; + if (hasUnencryptedDb) { + try { + unencryptedDbSize = fs.statSync(this.unencryptedDbPath).size; + } catch (error) { + databaseLogger.warn("Could not get unencrypted database file size", { + operation: "migration_status_check", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + + let needsMigration = false; + let reason = ""; + + if (hasEncryptedDb && hasUnencryptedDb) { + const unencryptedSize = fs.statSync(this.unencryptedDbPath).size; + const encryptedSize = fs.statSync(this.encryptedDbPath).size; + + if (unencryptedSize === 0) { + needsMigration = false; + reason = + "Empty unencrypted database found alongside encrypted database. Removing empty file."; + try { + fs.unlinkSync(this.unencryptedDbPath); + databaseLogger.info("Removed empty unencrypted database file", { + operation: "migration_cleanup_empty", + path: this.unencryptedDbPath, + }); + } catch (error) { + databaseLogger.warn("Failed to remove empty unencrypted database", { + operation: "migration_cleanup_empty_failed", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } else { + needsMigration = false; + reason = + "Both encrypted and unencrypted databases exist. Skipping migration for safety. Manual intervention may be required."; + } + } else if (hasEncryptedDb && !hasUnencryptedDb) { + needsMigration = false; + reason = "Only encrypted database exists. No migration needed."; + } else if (!hasEncryptedDb && hasUnencryptedDb) { + needsMigration = true; + reason = + "Unencrypted database found. Migration to encrypted format required."; + } else { + needsMigration = false; + reason = "No existing database found. This is a fresh installation."; + } + + return { + needsMigration, + hasUnencryptedDb, + hasEncryptedDb, + unencryptedDbSize, + reason, + }; + } + + private createBackup(): string { + const timestamp = new Date().toISOString().replace(/[:.]/g, "-"); + const backupPath = `${this.unencryptedDbPath}.migration-backup-${timestamp}`; + + try { + fs.copyFileSync(this.unencryptedDbPath, backupPath); + + const originalSize = fs.statSync(this.unencryptedDbPath).size; + const backupSize = fs.statSync(backupPath).size; + + if (originalSize !== backupSize) { + throw new Error( + `Backup size mismatch: original=${originalSize}, backup=${backupSize}`, + ); + } + + return backupPath; + } catch (error) { + databaseLogger.error("Failed to create migration backup", error, { + operation: "migration_backup_failed", + source: this.unencryptedDbPath, + backup: backupPath, + }); + throw new Error( + `Backup creation failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + } + + private async verifyMigration( + originalDb: Database.Database, + memoryDb: Database.Database, + ): Promise { + try { + memoryDb.exec("PRAGMA foreign_keys = OFF"); + + const originalTables = originalDb + .prepare( + ` + SELECT name FROM sqlite_master + WHERE type='table' AND name NOT LIKE 'sqlite_%' + ORDER BY name + `, + ) + .all() as { name: string }[]; + + const memoryTables = memoryDb + .prepare( + ` + SELECT name FROM sqlite_master + WHERE type='table' AND name NOT LIKE 'sqlite_%' + ORDER BY name + `, + ) + .all() as { name: string }[]; + + if (originalTables.length !== memoryTables.length) { + databaseLogger.error( + "Table count mismatch during migration verification", + null, + { + operation: "migration_verify_failed", + originalCount: originalTables.length, + memoryCount: memoryTables.length, + }, + ); + return false; + } + + let totalOriginalRows = 0; + let totalMemoryRows = 0; + + for (const table of originalTables) { + const originalCount = originalDb + .prepare(`SELECT COUNT(*) as count FROM ${table.name}`) + .get() as { count: number }; + const memoryCount = memoryDb + .prepare(`SELECT COUNT(*) as count FROM ${table.name}`) + .get() as { count: number }; + + totalOriginalRows += originalCount.count; + totalMemoryRows += memoryCount.count; + + if (originalCount.count !== memoryCount.count) { + databaseLogger.error( + "Row count mismatch for table during migration verification", + null, + { + operation: "migration_verify_table_failed", + table: table.name, + originalRows: originalCount.count, + memoryRows: memoryCount.count, + }, + ); + return false; + } + } + + memoryDb.exec("PRAGMA foreign_keys = ON"); + + return true; + } catch (error) { + databaseLogger.error("Migration verification failed", error, { + operation: "migration_verify_error", + }); + return false; + } + } + + async migrateDatabase(): Promise { + const startTime = Date.now(); + let backupPath: string | undefined; + let migratedTables = 0; + let migratedRows = 0; + + try { + backupPath = this.createBackup(); + + const originalDb = new Database(this.unencryptedDbPath, { + readonly: true, + }); + + const memoryDb = new Database(":memory:"); + + try { + const tables = originalDb + .prepare( + ` + SELECT name, sql FROM sqlite_master + WHERE type='table' AND name NOT LIKE 'sqlite_%' + `, + ) + .all() as { name: string; sql: string }[]; + + for (const table of tables) { + memoryDb.exec(table.sql); + migratedTables++; + } + + memoryDb.exec("PRAGMA foreign_keys = OFF"); + + for (const table of tables) { + const rows = originalDb.prepare(`SELECT * FROM ${table.name}`).all(); + + if (rows.length > 0) { + const columns = Object.keys(rows[0]); + const placeholders = columns.map(() => "?").join(", "); + const insertStmt = memoryDb.prepare( + `INSERT INTO ${table.name} (${columns.join(", ")}) VALUES (${placeholders})`, + ); + + const insertTransaction = memoryDb.transaction( + (dataRows: any[]) => { + for (const row of dataRows) { + const values = columns.map((col) => row[col]); + insertStmt.run(values); + } + }, + ); + + insertTransaction(rows); + migratedRows += rows.length; + } + } + + memoryDb.exec("PRAGMA foreign_keys = ON"); + + const fkCheckResult = memoryDb + .prepare("PRAGMA foreign_key_check") + .all(); + if (fkCheckResult.length > 0) { + databaseLogger.error( + "Foreign key constraints violations detected after migration", + null, + { + operation: "migration_fk_check_failed", + violations: fkCheckResult, + }, + ); + throw new Error( + `Foreign key violations detected: ${JSON.stringify(fkCheckResult)}`, + ); + } + + const verificationPassed = await this.verifyMigration( + originalDb, + memoryDb, + ); + if (!verificationPassed) { + throw new Error("Migration integrity verification failed"); + } + + const buffer = memoryDb.serialize(); + + await DatabaseFileEncryption.encryptDatabaseFromBuffer( + buffer, + this.encryptedDbPath, + ); + + if ( + !DatabaseFileEncryption.isEncryptedDatabaseFile(this.encryptedDbPath) + ) { + throw new Error("Encrypted database file verification failed"); + } + + const timestamp = new Date().toISOString().replace(/[:.]/g, "-"); + const migratedPath = `${this.unencryptedDbPath}.migrated-${timestamp}`; + + fs.renameSync(this.unencryptedDbPath, migratedPath); + + databaseLogger.success("Database migration completed successfully", { + operation: "migration_complete", + migratedTables, + migratedRows, + duration: Date.now() - startTime, + backupPath, + migratedPath, + encryptedDbPath: this.encryptedDbPath, + }); + + return { + success: true, + migratedTables, + migratedRows, + backupPath, + duration: Date.now() - startTime, + }; + } finally { + originalDb.close(); + memoryDb.close(); + } + } catch (error) { + const errorMessage = + error instanceof Error ? error.message : "Unknown error"; + + databaseLogger.error("Database migration failed", error, { + operation: "migration_failed", + migratedTables, + migratedRows, + duration: Date.now() - startTime, + backupPath, + }); + + return { + success: false, + error: errorMessage, + migratedTables, + migratedRows, + backupPath, + duration: Date.now() - startTime, + }; + } + } + + cleanupOldBackups(): void { + try { + const backupPattern = + /\.migration-backup-\d{4}-\d{2}-\d{2}T\d{2}-\d{2}-\d{2}-\d{3}Z$/; + const migratedPattern = + /\.migrated-\d{4}-\d{2}-\d{2}T\d{2}-\d{2}-\d{2}-\d{3}Z$/; + + const files = fs.readdirSync(this.dataDir); + + const backupFiles = files + .filter((f) => backupPattern.test(f)) + .map((f) => ({ + name: f, + path: path.join(this.dataDir, f), + mtime: fs.statSync(path.join(this.dataDir, f)).mtime, + })) + .sort((a, b) => b.mtime.getTime() - a.mtime.getTime()); + + const migratedFiles = files + .filter((f) => migratedPattern.test(f)) + .map((f) => ({ + name: f, + path: path.join(this.dataDir, f), + mtime: fs.statSync(path.join(this.dataDir, f)).mtime, + })) + .sort((a, b) => b.mtime.getTime() - a.mtime.getTime()); + + const backupsToDelete = backupFiles.slice(3); + const migratedToDelete = migratedFiles.slice(3); + + for (const file of [...backupsToDelete, ...migratedToDelete]) { + try { + fs.unlinkSync(file.path); + } catch (error) { + databaseLogger.warn("Failed to cleanup old migration file", { + operation: "migration_cleanup_failed", + file: file.name, + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } + } catch (error) { + databaseLogger.warn("Migration cleanup failed", { + operation: "migration_cleanup_error", + error: error instanceof Error ? error.message : "Unknown error", + }); + } + } +} diff --git a/src/backend/utils/database-save-trigger.ts b/src/backend/utils/database-save-trigger.ts new file mode 100644 index 00000000..15bc05bc --- /dev/null +++ b/src/backend/utils/database-save-trigger.ts @@ -0,0 +1,118 @@ +import { databaseLogger } from "./logger.js"; + +export class DatabaseSaveTrigger { + private static saveFunction: (() => Promise) | null = null; + private static isInitialized = false; + private static pendingSave = false; + private static saveTimeout: NodeJS.Timeout | null = null; + + static initialize(saveFunction: () => Promise): void { + this.saveFunction = saveFunction; + this.isInitialized = true; + } + + static async triggerSave( + reason: string = "data_modification", + ): Promise { + if (!this.isInitialized || !this.saveFunction) { + databaseLogger.warn("Database save trigger not initialized", { + operation: "db_save_trigger_not_init", + reason, + }); + return; + } + + if (this.saveTimeout) { + clearTimeout(this.saveTimeout); + } + + this.saveTimeout = setTimeout(async () => { + if (this.pendingSave) { + return; + } + + this.pendingSave = true; + + try { + await this.saveFunction!(); + } catch (error) { + databaseLogger.error("Database save failed", error, { + operation: "db_save_trigger_failed", + reason, + error: error instanceof Error ? error.message : "Unknown error", + }); + } finally { + this.pendingSave = false; + } + }, 2000); + } + + static async forceSave(reason: string = "critical_operation"): Promise { + if (!this.isInitialized || !this.saveFunction) { + databaseLogger.warn( + "Database save trigger not initialized for force save", + { + operation: "db_save_trigger_force_not_init", + reason, + }, + ); + return; + } + + if (this.saveTimeout) { + clearTimeout(this.saveTimeout); + this.saveTimeout = null; + } + + if (this.pendingSave) { + return; + } + + this.pendingSave = true; + + try { + databaseLogger.info("Force saving database", { + operation: "db_save_trigger_force_start", + reason, + }); + + await this.saveFunction(); + } catch (error) { + databaseLogger.error("Database force save failed", error, { + operation: "db_save_trigger_force_failed", + reason, + error: error instanceof Error ? error.message : "Unknown error", + }); + throw error; + } finally { + this.pendingSave = false; + } + } + + static getStatus(): { + initialized: boolean; + pendingSave: boolean; + hasPendingTimeout: boolean; + } { + return { + initialized: this.isInitialized, + pendingSave: this.pendingSave, + hasPendingTimeout: this.saveTimeout !== null, + }; + } + + static cleanup(): void { + if (this.saveTimeout) { + clearTimeout(this.saveTimeout); + this.saveTimeout = null; + } + + this.pendingSave = false; + this.isInitialized = false; + this.saveFunction = null; + + databaseLogger.info("Database save trigger cleaned up", { + operation: "db_save_trigger_cleanup", + }); + } +} diff --git a/src/backend/utils/field-crypto.ts b/src/backend/utils/field-crypto.ts new file mode 100644 index 00000000..b225fa8b --- /dev/null +++ b/src/backend/utils/field-crypto.ts @@ -0,0 +1,108 @@ +import crypto from "crypto"; + +interface EncryptedData { + data: string; + iv: string; + tag: string; + salt: string; + recordId: string; +} + +class FieldCrypto { + private static readonly ALGORITHM = "aes-256-gcm"; + private static readonly KEY_LENGTH = 32; + private static readonly IV_LENGTH = 16; + private static readonly SALT_LENGTH = 32; + + private static readonly ENCRYPTED_FIELDS = { + users: new Set([ + "password_hash", + "client_secret", + "totp_secret", + "totp_backup_codes", + "oidc_identifier", + ]), + ssh_data: new Set(["password", "key", "keyPassword"]), + ssh_credentials: new Set([ + "password", + "privateKey", + "keyPassword", + "key", + "publicKey", + ]), + }; + + static encryptField( + plaintext: string, + masterKey: Buffer, + recordId: string, + fieldName: string, + ): string { + if (!plaintext) return ""; + + const salt = crypto.randomBytes(this.SALT_LENGTH); + const context = `${recordId}:${fieldName}`; + const fieldKey = Buffer.from( + crypto.hkdfSync("sha256", masterKey, salt, context, this.KEY_LENGTH), + ); + + const iv = crypto.randomBytes(this.IV_LENGTH); + const cipher = crypto.createCipheriv(this.ALGORITHM, fieldKey, iv) as any; + + let encrypted = cipher.update(plaintext, "utf8", "hex"); + encrypted += cipher.final("hex"); + const tag = cipher.getAuthTag(); + + const encryptedData: EncryptedData = { + data: encrypted, + iv: iv.toString("hex"), + tag: tag.toString("hex"), + salt: salt.toString("hex"), + recordId: recordId, + }; + + return JSON.stringify(encryptedData); + } + + static decryptField( + encryptedValue: string, + masterKey: Buffer, + recordId: string, + fieldName: string, + ): string { + if (!encryptedValue) return ""; + + const encrypted: EncryptedData = JSON.parse(encryptedValue); + const salt = Buffer.from(encrypted.salt, "hex"); + + if (!encrypted.recordId) { + throw new Error( + `Encrypted field missing recordId context - data corruption or legacy format not supported`, + ); + } + const context = `${encrypted.recordId}:${fieldName}`; + const fieldKey = Buffer.from( + crypto.hkdfSync("sha256", masterKey, salt, context, this.KEY_LENGTH), + ); + + const decipher = crypto.createDecipheriv( + this.ALGORITHM, + fieldKey, + Buffer.from(encrypted.iv, "hex"), + ) as any; + decipher.setAuthTag(Buffer.from(encrypted.tag, "hex")); + + let decrypted = decipher.update(encrypted.data, "hex", "utf8"); + decrypted += decipher.final("utf8"); + + return decrypted; + } + + static shouldEncryptField(tableName: string, fieldName: string): boolean { + const fields = + this.ENCRYPTED_FIELDS[tableName as keyof typeof this.ENCRYPTED_FIELDS]; + return fields ? fields.has(fieldName) : false; + } +} + +export { FieldCrypto, type EncryptedData }; diff --git a/src/backend/utils/lazy-field-encryption.ts b/src/backend/utils/lazy-field-encryption.ts new file mode 100644 index 00000000..685fa25a --- /dev/null +++ b/src/backend/utils/lazy-field-encryption.ts @@ -0,0 +1,243 @@ +import { FieldCrypto } from "./field-crypto.js"; +import { databaseLogger } from "./logger.js"; + +export class LazyFieldEncryption { + static isPlaintextField(value: string): boolean { + if (!value) return false; + + try { + const parsed = JSON.parse(value); + if ( + parsed && + typeof parsed === "object" && + parsed.data && + parsed.iv && + parsed.tag && + parsed.salt && + parsed.recordId + ) { + return false; + } + return true; + } catch (jsonError) { + return true; + } + } + + static safeGetFieldValue( + fieldValue: string, + userKEK: Buffer, + recordId: string, + fieldName: string, + ): string { + if (!fieldValue) return ""; + + if (this.isPlaintextField(fieldValue)) { + return fieldValue; + } else { + try { + const decrypted = FieldCrypto.decryptField( + fieldValue, + userKEK, + recordId, + fieldName, + ); + return decrypted; + } catch (error) { + databaseLogger.error("Failed to decrypt field", error, { + operation: "lazy_encryption_decrypt_failed", + recordId, + fieldName, + error: error instanceof Error ? error.message : "Unknown error", + }); + throw error; + } + } + } + + static migrateFieldToEncrypted( + fieldValue: string, + userKEK: Buffer, + recordId: string, + fieldName: string, + ): { encrypted: string; wasPlaintext: boolean } { + if (!fieldValue) { + return { encrypted: "", wasPlaintext: false }; + } + + if (this.isPlaintextField(fieldValue)) { + try { + const encrypted = FieldCrypto.encryptField( + fieldValue, + userKEK, + recordId, + fieldName, + ); + + return { encrypted, wasPlaintext: true }; + } catch (error) { + databaseLogger.error("Failed to encrypt plaintext field", error, { + operation: "lazy_encryption_migrate_failed", + recordId, + fieldName, + error: error instanceof Error ? error.message : "Unknown error", + }); + throw error; + } + } else { + return { encrypted: fieldValue, wasPlaintext: false }; + } + } + + static migrateRecordSensitiveFields( + record: any, + sensitiveFields: string[], + userKEK: Buffer, + recordId: string, + ): { + updatedRecord: any; + migratedFields: string[]; + needsUpdate: boolean; + } { + const updatedRecord = { ...record }; + const migratedFields: string[] = []; + let needsUpdate = false; + + for (const fieldName of sensitiveFields) { + const fieldValue = record[fieldName]; + + if (fieldValue && this.isPlaintextField(fieldValue)) { + try { + const { encrypted } = this.migrateFieldToEncrypted( + fieldValue, + userKEK, + recordId, + fieldName, + ); + + updatedRecord[fieldName] = encrypted; + migratedFields.push(fieldName); + needsUpdate = true; + } catch (error) { + databaseLogger.error("Failed to migrate record field", error, { + operation: "lazy_encryption_record_field_failed", + recordId, + fieldName, + }); + } + } + } + + return { updatedRecord, migratedFields, needsUpdate }; + } + + static getSensitiveFieldsForTable(tableName: string): string[] { + const sensitiveFieldsMap: Record = { + ssh_data: ["password", "key", "key_password"], + ssh_credentials: ["password", "key", "key_password", "private_key"], + users: ["totp_secret", "totp_backup_codes"], + }; + + return sensitiveFieldsMap[tableName] || []; + } + + static async checkUserNeedsMigration( + userId: string, + userKEK: Buffer, + db: any, + ): Promise<{ + needsMigration: boolean; + plaintextFields: Array<{ + table: string; + recordId: string; + fields: string[]; + }>; + }> { + const plaintextFields: Array<{ + table: string; + recordId: string; + fields: string[]; + }> = []; + let needsMigration = false; + + try { + const sshHosts = db + .prepare("SELECT * FROM ssh_data WHERE user_id = ?") + .all(userId); + for (const host of sshHosts) { + const sensitiveFields = this.getSensitiveFieldsForTable("ssh_data"); + const hostPlaintextFields: string[] = []; + + for (const field of sensitiveFields) { + if (host[field] && this.isPlaintextField(host[field])) { + hostPlaintextFields.push(field); + needsMigration = true; + } + } + + if (hostPlaintextFields.length > 0) { + plaintextFields.push({ + table: "ssh_data", + recordId: host.id.toString(), + fields: hostPlaintextFields, + }); + } + } + + const sshCredentials = db + .prepare("SELECT * FROM ssh_credentials WHERE user_id = ?") + .all(userId); + for (const credential of sshCredentials) { + const sensitiveFields = + this.getSensitiveFieldsForTable("ssh_credentials"); + const credentialPlaintextFields: string[] = []; + + for (const field of sensitiveFields) { + if (credential[field] && this.isPlaintextField(credential[field])) { + credentialPlaintextFields.push(field); + needsMigration = true; + } + } + + if (credentialPlaintextFields.length > 0) { + plaintextFields.push({ + table: "ssh_credentials", + recordId: credential.id.toString(), + fields: credentialPlaintextFields, + }); + } + } + + const user = db.prepare("SELECT * FROM users WHERE id = ?").get(userId); + if (user) { + const sensitiveFields = this.getSensitiveFieldsForTable("users"); + const userPlaintextFields: string[] = []; + + for (const field of sensitiveFields) { + if (user[field] && this.isPlaintextField(user[field])) { + userPlaintextFields.push(field); + needsMigration = true; + } + } + + if (userPlaintextFields.length > 0) { + plaintextFields.push({ + table: "users", + recordId: userId, + fields: userPlaintextFields, + }); + } + } + + return { needsMigration, plaintextFields }; + } catch (error) { + databaseLogger.error("Failed to check user migration needs", error, { + operation: "lazy_encryption_user_check_failed", + userId, + error: error instanceof Error ? error.message : "Unknown error", + }); + + return { needsMigration: false, plaintextFields: [] }; + } + } +} diff --git a/src/backend/utils/logger.ts b/src/backend/utils/logger.ts index 598e10a8..f020047a 100644 --- a/src/backend/utils/logger.ts +++ b/src/backend/utils/logger.ts @@ -14,10 +14,35 @@ export interface LogContext { [key: string]: any; } +const SENSITIVE_FIELDS = [ + "password", + "passphrase", + "key", + "privateKey", + "publicKey", + "token", + "secret", + "clientSecret", + "keyPassword", + "autostartPassword", + "autostartKey", + "autostartKeyPassword", + "credentialId", + "authToken", + "jwt", + "session", + "cookie", +]; + +const TRUNCATE_FIELDS = ["data", "content", "body", "response", "request"]; + class Logger { private serviceName: string; private serviceIcon: string; private serviceColor: string; + private logCounts = new Map(); + private readonly RATE_LIMIT_WINDOW = 60000; + private readonly RATE_LIMIT_MAX = 10; constructor(serviceName: string, serviceIcon: string, serviceColor: string) { this.serviceName = serviceName; @@ -29,6 +54,37 @@ class Logger { return chalk.gray(`[${new Date().toLocaleTimeString()}]`); } + private sanitizeContext(context: LogContext): LogContext { + const sanitized = { ...context }; + + for (const field of SENSITIVE_FIELDS) { + if (sanitized[field] !== undefined) { + if ( + typeof sanitized[field] === "string" && + sanitized[field].length > 0 + ) { + sanitized[field] = "[MASKED]"; + } else if (typeof sanitized[field] === "boolean") { + sanitized[field] = sanitized[field] ? "[PRESENT]" : "[ABSENT]"; + } else { + sanitized[field] = "[MASKED]"; + } + } + } + + for (const field of TRUNCATE_FIELDS) { + if ( + sanitized[field] && + typeof sanitized[field] === "string" && + sanitized[field].length > 100 + ) { + sanitized[field] = sanitized[field].substring(0, 100) + "..."; + } + } + + return sanitized; + } + private formatMessage( level: LogLevel, message: string, @@ -41,14 +97,22 @@ class Logger { let contextStr = ""; if (context) { + const sanitizedContext = this.sanitizeContext(context); const contextParts = []; - if (context.operation) contextParts.push(`op:${context.operation}`); - if (context.userId) contextParts.push(`user:${context.userId}`); - if (context.hostId) contextParts.push(`host:${context.hostId}`); - if (context.tunnelName) contextParts.push(`tunnel:${context.tunnelName}`); - if (context.sessionId) contextParts.push(`session:${context.sessionId}`); - if (context.requestId) contextParts.push(`req:${context.requestId}`); - if (context.duration) contextParts.push(`duration:${context.duration}ms`); + if (sanitizedContext.operation) + contextParts.push(`op:${sanitizedContext.operation}`); + if (sanitizedContext.userId) + contextParts.push(`user:${sanitizedContext.userId}`); + if (sanitizedContext.hostId) + contextParts.push(`host:${sanitizedContext.hostId}`); + if (sanitizedContext.tunnelName) + contextParts.push(`tunnel:${sanitizedContext.tunnelName}`); + if (sanitizedContext.sessionId) + contextParts.push(`session:${sanitizedContext.sessionId}`); + if (sanitizedContext.requestId) + contextParts.push(`req:${sanitizedContext.requestId}`); + if (sanitizedContext.duration) + contextParts.push(`duration:${sanitizedContext.duration}ms`); if (contextParts.length > 0) { contextStr = chalk.gray(` [${contextParts.join(",")}]`); @@ -75,30 +139,49 @@ class Logger { } } - private shouldLog(level: LogLevel): boolean { + private shouldLog(level: LogLevel, message: string): boolean { if (level === "debug" && process.env.NODE_ENV === "production") { return false; } + + const now = Date.now(); + const logKey = `${level}:${message}`; + const logInfo = this.logCounts.get(logKey); + + if (logInfo) { + if (now - logInfo.lastLog < this.RATE_LIMIT_WINDOW) { + logInfo.count++; + if (logInfo.count > this.RATE_LIMIT_MAX) { + return false; + } + } else { + logInfo.count = 1; + logInfo.lastLog = now; + } + } else { + this.logCounts.set(logKey, { count: 1, lastLog: now }); + } + return true; } debug(message: string, context?: LogContext): void { - if (!this.shouldLog("debug")) return; + if (!this.shouldLog("debug", message)) return; console.debug(this.formatMessage("debug", message, context)); } info(message: string, context?: LogContext): void { - if (!this.shouldLog("info")) return; + if (!this.shouldLog("info", message)) return; console.log(this.formatMessage("info", message, context)); } warn(message: string, context?: LogContext): void { - if (!this.shouldLog("warn")) return; + if (!this.shouldLog("warn", message)) return; console.warn(this.formatMessage("warn", message, context)); } error(message: string, error?: unknown, context?: LogContext): void { - if (!this.shouldLog("error")) return; + if (!this.shouldLog("error", message)) return; console.error(this.formatMessage("error", message, context)); if (error) { console.error(error); @@ -106,7 +189,7 @@ class Logger { } success(message: string, context?: LogContext): void { - if (!this.shouldLog("success")) return; + if (!this.shouldLog("success", message)) return; console.log(this.formatMessage("success", message, context)); } diff --git a/src/backend/utils/simple-db-ops.ts b/src/backend/utils/simple-db-ops.ts new file mode 100644 index 00000000..c324e0a2 --- /dev/null +++ b/src/backend/utils/simple-db-ops.ts @@ -0,0 +1,157 @@ +import { getDb, DatabaseSaveTrigger } from "../database/db/index.js"; +import { DataCrypto } from "./data-crypto.js"; +import type { SQLiteTable } from "drizzle-orm/sqlite-core"; + +type TableName = "users" | "ssh_data" | "ssh_credentials"; + +class SimpleDBOps { + static async insert>( + table: SQLiteTable, + tableName: TableName, + data: T, + userId: string, + ): Promise { + const userDataKey = DataCrypto.validateUserAccess(userId); + + const tempId = data.id || `temp-${userId}-${Date.now()}`; + const dataWithTempId = { ...data, id: tempId }; + + const encryptedData = DataCrypto.encryptRecord( + tableName, + dataWithTempId, + userId, + userDataKey, + ); + + if (!data.id) { + delete encryptedData.id; + } + + const result = await getDb() + .insert(table) + .values(encryptedData) + .returning(); + + DatabaseSaveTrigger.triggerSave(`insert_${tableName}`); + + const decryptedResult = DataCrypto.decryptRecord( + tableName, + result[0], + userId, + userDataKey, + ); + + return decryptedResult as T; + } + + static async select>( + query: any, + tableName: TableName, + userId: string, + ): Promise { + const userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + return []; + } + + const results = await query; + + const decryptedResults = DataCrypto.decryptRecords( + tableName, + results, + userId, + userDataKey, + ); + + return decryptedResults; + } + + static async selectOne>( + query: any, + tableName: TableName, + userId: string, + ): Promise { + const userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + return undefined; + } + + const result = await query; + if (!result) return undefined; + + const decryptedResult = DataCrypto.decryptRecord( + tableName, + result, + userId, + userDataKey, + ); + + return decryptedResult; + } + + static async update>( + table: SQLiteTable, + tableName: TableName, + where: any, + data: Partial, + userId: string, + ): Promise { + const userDataKey = DataCrypto.validateUserAccess(userId); + + const encryptedData = DataCrypto.encryptRecord( + tableName, + data, + userId, + userDataKey, + ); + + const result = await getDb() + .update(table) + .set(encryptedData) + .where(where) + .returning(); + + DatabaseSaveTrigger.triggerSave(`update_${tableName}`); + + const decryptedResults = DataCrypto.decryptRecords( + tableName, + result, + userId, + userDataKey, + ); + + return decryptedResults as T[]; + } + + static async delete( + table: SQLiteTable, + tableName: TableName, + where: any, + userId: string, + ): Promise { + const result = await getDb().delete(table).where(where).returning(); + + DatabaseSaveTrigger.triggerSave(`delete_${tableName}`); + + return result; + } + + static async healthCheck(userId: string): Promise { + return DataCrypto.canUserAccessData(userId); + } + + static isUserDataUnlocked(userId: string): boolean { + return DataCrypto.getUserDataKey(userId) !== null; + } + + static async selectEncrypted( + query: any, + tableName: TableName, + ): Promise { + const results = await query; + + return results; + } +} + +export { SimpleDBOps, type TableName }; diff --git a/src/backend/utils/ssh-key-utils.ts b/src/backend/utils/ssh-key-utils.ts new file mode 100644 index 00000000..b19f95c9 --- /dev/null +++ b/src/backend/utils/ssh-key-utils.ts @@ -0,0 +1,418 @@ +import ssh2Pkg from "ssh2"; +const ssh2Utils = ssh2Pkg.utils; + +function detectKeyTypeFromContent(keyContent: string): string { + const content = keyContent.trim(); + + if (content.includes("-----BEGIN OPENSSH PRIVATE KEY-----")) { + if ( + content.includes("ssh-ed25519") || + content.includes("AAAAC3NzaC1lZDI1NTE5") + ) { + return "ssh-ed25519"; + } + if (content.includes("ssh-rsa") || content.includes("AAAAB3NzaC1yc2E")) { + return "ssh-rsa"; + } + if (content.includes("ecdsa-sha2-nistp256")) { + return "ecdsa-sha2-nistp256"; + } + if (content.includes("ecdsa-sha2-nistp384")) { + return "ecdsa-sha2-nistp384"; + } + if (content.includes("ecdsa-sha2-nistp521")) { + return "ecdsa-sha2-nistp521"; + } + + try { + const base64Content = content + .replace("-----BEGIN OPENSSH PRIVATE KEY-----", "") + .replace("-----END OPENSSH PRIVATE KEY-----", "") + .replace(/\s/g, ""); + + const decoded = Buffer.from(base64Content, "base64").toString("binary"); + + if (decoded.includes("ssh-rsa")) { + return "ssh-rsa"; + } + if (decoded.includes("ssh-ed25519")) { + return "ssh-ed25519"; + } + if (decoded.includes("ecdsa-sha2-nistp256")) { + return "ecdsa-sha2-nistp256"; + } + if (decoded.includes("ecdsa-sha2-nistp384")) { + return "ecdsa-sha2-nistp384"; + } + if (decoded.includes("ecdsa-sha2-nistp521")) { + return "ecdsa-sha2-nistp521"; + } + + return "ssh-rsa"; + } catch (error) { + return "ssh-rsa"; + } + } + + if (content.includes("-----BEGIN RSA PRIVATE KEY-----")) { + return "ssh-rsa"; + } + if (content.includes("-----BEGIN DSA PRIVATE KEY-----")) { + return "ssh-dss"; + } + if (content.includes("-----BEGIN EC PRIVATE KEY-----")) { + return "ecdsa-sha2-nistp256"; + } + + if (content.includes("-----BEGIN PRIVATE KEY-----")) { + try { + const base64Content = content + .replace("-----BEGIN PRIVATE KEY-----", "") + .replace("-----END PRIVATE KEY-----", "") + .replace(/\s/g, ""); + + const decoded = Buffer.from(base64Content, "base64"); + const decodedString = decoded.toString("binary"); + + if (decodedString.includes("1.2.840.113549.1.1.1")) { + return "ssh-rsa"; + } else if (decodedString.includes("1.2.840.10045.2.1")) { + if (decodedString.includes("1.2.840.10045.3.1.7")) { + return "ecdsa-sha2-nistp256"; + } + return "ecdsa-sha2-nistp256"; + } else if (decodedString.includes("1.3.101.112")) { + return "ssh-ed25519"; + } + } catch (error) {} + + if (content.length < 800) { + return "ssh-ed25519"; + } else if (content.length > 1600) { + return "ssh-rsa"; + } else { + return "ecdsa-sha2-nistp256"; + } + } + + return "unknown"; +} + +function detectPublicKeyTypeFromContent(publicKeyContent: string): string { + const content = publicKeyContent.trim(); + + if (content.startsWith("ssh-rsa ")) { + return "ssh-rsa"; + } + if (content.startsWith("ssh-ed25519 ")) { + return "ssh-ed25519"; + } + if (content.startsWith("ecdsa-sha2-nistp256 ")) { + return "ecdsa-sha2-nistp256"; + } + if (content.startsWith("ecdsa-sha2-nistp384 ")) { + return "ecdsa-sha2-nistp384"; + } + if (content.startsWith("ecdsa-sha2-nistp521 ")) { + return "ecdsa-sha2-nistp521"; + } + if (content.startsWith("ssh-dss ")) { + return "ssh-dss"; + } + + if (content.includes("-----BEGIN PUBLIC KEY-----")) { + try { + const base64Content = content + .replace("-----BEGIN PUBLIC KEY-----", "") + .replace("-----END PUBLIC KEY-----", "") + .replace(/\s/g, ""); + + const decoded = Buffer.from(base64Content, "base64"); + const decodedString = decoded.toString("binary"); + + if (decodedString.includes("1.2.840.113549.1.1.1")) { + return "ssh-rsa"; + } else if (decodedString.includes("1.2.840.10045.2.1")) { + if (decodedString.includes("1.2.840.10045.3.1.7")) { + return "ecdsa-sha2-nistp256"; + } + return "ecdsa-sha2-nistp256"; + } else if (decodedString.includes("1.3.101.112")) { + return "ssh-ed25519"; + } + } catch (error) {} + + if (content.length < 400) { + return "ssh-ed25519"; + } else if (content.length > 600) { + return "ssh-rsa"; + } else { + return "ecdsa-sha2-nistp256"; + } + } + + if (content.includes("-----BEGIN RSA PUBLIC KEY-----")) { + return "ssh-rsa"; + } + + if (content.includes("AAAAB3NzaC1yc2E")) { + return "ssh-rsa"; + } + if (content.includes("AAAAC3NzaC1lZDI1NTE5")) { + return "ssh-ed25519"; + } + if (content.includes("AAAAE2VjZHNhLXNoYTItbmlzdHAyNTY")) { + return "ecdsa-sha2-nistp256"; + } + if (content.includes("AAAAE2VjZHNhLXNoYTItbmlzdHAzODQ")) { + return "ecdsa-sha2-nistp384"; + } + if (content.includes("AAAAE2VjZHNhLXNoYTItbmlzdHA1MjE")) { + return "ecdsa-sha2-nistp521"; + } + if (content.includes("AAAAB3NzaC1kc3M")) { + return "ssh-dss"; + } + + return "unknown"; +} + +export interface KeyInfo { + privateKey: string; + publicKey: string; + keyType: string; + success: boolean; + error?: string; +} + +export interface PublicKeyInfo { + publicKey: string; + keyType: string; + success: boolean; + error?: string; +} + +export interface KeyPairValidationResult { + isValid: boolean; + privateKeyType: string; + publicKeyType: string; + generatedPublicKey?: string; + error?: string; +} + +export function parseSSHKey( + privateKeyData: string, + passphrase?: string, +): KeyInfo { + try { + let keyType = "unknown"; + let publicKey = ""; + let useSSH2 = false; + + if (ssh2Utils && typeof ssh2Utils.parseKey === "function") { + try { + const parsedKey = ssh2Utils.parseKey(privateKeyData, passphrase); + + if (!(parsedKey instanceof Error)) { + if (parsedKey.type) { + keyType = parsedKey.type; + } + + try { + const publicKeyBuffer = parsedKey.getPublicSSH(); + + if (Buffer.isBuffer(publicKeyBuffer)) { + const base64Data = publicKeyBuffer.toString("base64"); + + if (keyType === "ssh-rsa") { + publicKey = `ssh-rsa ${base64Data}`; + } else if (keyType === "ssh-ed25519") { + publicKey = `ssh-ed25519 ${base64Data}`; + } else if (keyType.startsWith("ecdsa-")) { + publicKey = `${keyType} ${base64Data}`; + } else { + publicKey = `${keyType} ${base64Data}`; + } + } else { + publicKey = ""; + } + } catch (error) { + publicKey = ""; + } + + useSSH2 = true; + } + } catch (error) {} + } + + if (!useSSH2) { + keyType = detectKeyTypeFromContent(privateKeyData); + + publicKey = ""; + } + + return { + privateKey: privateKeyData, + publicKey, + keyType, + success: keyType !== "unknown", + }; + } catch (error) { + try { + const fallbackKeyType = detectKeyTypeFromContent(privateKeyData); + if (fallbackKeyType !== "unknown") { + return { + privateKey: privateKeyData, + publicKey: "", + keyType: fallbackKeyType, + success: true, + }; + } + } catch (fallbackError) {} + + return { + privateKey: privateKeyData, + publicKey: "", + keyType: "unknown", + success: false, + error: + error instanceof Error ? error.message : "Unknown error parsing key", + }; + } +} + +export function parsePublicKey(publicKeyData: string): PublicKeyInfo { + try { + const keyType = detectPublicKeyTypeFromContent(publicKeyData); + + return { + publicKey: publicKeyData, + keyType, + success: keyType !== "unknown", + }; + } catch (error) { + return { + publicKey: publicKeyData, + keyType: "unknown", + success: false, + error: + error instanceof Error + ? error.message + : "Unknown error parsing public key", + }; + } +} + +export function detectKeyType(privateKeyData: string): string { + try { + const parsedKey = ssh2Utils.parseKey(privateKeyData); + if (parsedKey instanceof Error) { + return "unknown"; + } + return parsedKey.type || "unknown"; + } catch (error) { + return "unknown"; + } +} + +export function getFriendlyKeyTypeName(keyType: string): string { + const keyTypeMap: Record = { + "ssh-rsa": "RSA", + "ssh-ed25519": "Ed25519", + "ecdsa-sha2-nistp256": "ECDSA P-256", + "ecdsa-sha2-nistp384": "ECDSA P-384", + "ecdsa-sha2-nistp521": "ECDSA P-521", + "ssh-dss": "DSA", + "rsa-sha2-256": "RSA-SHA2-256", + "rsa-sha2-512": "RSA-SHA2-512", + unknown: "Unknown", + }; + + return keyTypeMap[keyType] || keyType; +} + +export function validateKeyPair( + privateKeyData: string, + publicKeyData: string, + passphrase?: string, +): KeyPairValidationResult { + try { + const privateKeyInfo = parseSSHKey(privateKeyData, passphrase); + const publicKeyInfo = parsePublicKey(publicKeyData); + + if (!privateKeyInfo.success) { + return { + isValid: false, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + error: `Invalid private key: ${privateKeyInfo.error}`, + }; + } + + if (!publicKeyInfo.success) { + return { + isValid: false, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + error: `Invalid public key: ${publicKeyInfo.error}`, + }; + } + + if (privateKeyInfo.keyType !== publicKeyInfo.keyType) { + return { + isValid: false, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + error: `Key type mismatch: private key is ${privateKeyInfo.keyType}, public key is ${publicKeyInfo.keyType}`, + }; + } + + if (privateKeyInfo.publicKey && privateKeyInfo.publicKey.trim()) { + const generatedPublicKey = privateKeyInfo.publicKey.trim(); + const providedPublicKey = publicKeyData.trim(); + + const generatedKeyParts = generatedPublicKey.split(" "); + const providedKeyParts = providedPublicKey.split(" "); + + if (generatedKeyParts.length >= 2 && providedKeyParts.length >= 2) { + const generatedKeyData = + generatedKeyParts[0] + " " + generatedKeyParts[1]; + const providedKeyData = providedKeyParts[0] + " " + providedKeyParts[1]; + + if (generatedKeyData === providedKeyData) { + return { + isValid: true, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + generatedPublicKey: generatedPublicKey, + }; + } else { + return { + isValid: false, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + generatedPublicKey: generatedPublicKey, + error: "Public key does not match the private key", + }; + } + } + } + + return { + isValid: true, + privateKeyType: privateKeyInfo.keyType, + publicKeyType: publicKeyInfo.keyType, + error: "Unable to verify key pair match, but key types are compatible", + }; + } catch (error) { + return { + isValid: false, + privateKeyType: "unknown", + publicKeyType: "unknown", + error: + error instanceof Error + ? error.message + : "Unknown error during validation", + }; + } +} diff --git a/src/backend/utils/system-crypto.ts b/src/backend/utils/system-crypto.ts new file mode 100644 index 00000000..cd805bfc --- /dev/null +++ b/src/backend/utils/system-crypto.ts @@ -0,0 +1,263 @@ +import crypto from "crypto"; +import { promises as fs } from "fs"; +import path from "path"; +import { databaseLogger } from "./logger.js"; + +class SystemCrypto { + private static instance: SystemCrypto; + private jwtSecret: string | null = null; + private databaseKey: Buffer | null = null; + private internalAuthToken: string | null = null; + + private constructor() {} + + static getInstance(): SystemCrypto { + if (!this.instance) { + this.instance = new SystemCrypto(); + } + return this.instance; + } + + async initializeJWTSecret(): Promise { + try { + const envSecret = process.env.JWT_SECRET; + if (envSecret && envSecret.length >= 64) { + this.jwtSecret = envSecret; + return; + } + + const dataDir = process.env.DATA_DIR || "./db/data"; + const envPath = path.join(dataDir, ".env"); + + try { + const envContent = await fs.readFile(envPath, "utf8"); + const jwtMatch = envContent.match(/^JWT_SECRET=(.+)$/m); + if (jwtMatch && jwtMatch[1] && jwtMatch[1].length >= 64) { + this.jwtSecret = jwtMatch[1]; + process.env.JWT_SECRET = jwtMatch[1]; + return; + } + } catch {} + + await this.generateAndGuideUser(); + } catch (error) { + databaseLogger.error("Failed to initialize JWT secret", error, { + operation: "jwt_init_failed", + }); + throw new Error("JWT secret initialization failed"); + } + } + + async getJWTSecret(): Promise { + if (!this.jwtSecret) { + await this.initializeJWTSecret(); + } + return this.jwtSecret!; + } + + async initializeDatabaseKey(): Promise { + try { + const envKey = process.env.DATABASE_KEY; + if (envKey && envKey.length >= 64) { + this.databaseKey = Buffer.from(envKey, "hex"); + return; + } + + const dataDir = process.env.DATA_DIR || "./db/data"; + const envPath = path.join(dataDir, ".env"); + + try { + const envContent = await fs.readFile(envPath, "utf8"); + const dbKeyMatch = envContent.match(/^DATABASE_KEY=(.+)$/m); + if (dbKeyMatch && dbKeyMatch[1] && dbKeyMatch[1].length >= 64) { + this.databaseKey = Buffer.from(dbKeyMatch[1], "hex"); + process.env.DATABASE_KEY = dbKeyMatch[1]; + return; + } + } catch {} + + await this.generateAndGuideDatabaseKey(); + } catch (error) { + databaseLogger.error("Failed to initialize database key", error, { + operation: "db_key_init_failed", + }); + throw new Error("Database key initialization failed"); + } + } + + async getDatabaseKey(): Promise { + if (!this.databaseKey) { + await this.initializeDatabaseKey(); + } + return this.databaseKey!; + } + + async initializeInternalAuthToken(): Promise { + try { + const envToken = process.env.INTERNAL_AUTH_TOKEN; + if (envToken && envToken.length >= 32) { + this.internalAuthToken = envToken; + return; + } + + const dataDir = process.env.DATA_DIR || "./db/data"; + const envPath = path.join(dataDir, ".env"); + + try { + const envContent = await fs.readFile(envPath, "utf8"); + const tokenMatch = envContent.match(/^INTERNAL_AUTH_TOKEN=(.+)$/m); + if (tokenMatch && tokenMatch[1] && tokenMatch[1].length >= 32) { + this.internalAuthToken = tokenMatch[1]; + process.env.INTERNAL_AUTH_TOKEN = tokenMatch[1]; + return; + } + } catch {} + + await this.generateAndGuideInternalAuthToken(); + } catch (error) { + databaseLogger.error("Failed to initialize internal auth token", error, { + operation: "internal_auth_init_failed", + }); + throw new Error("Internal auth token initialization failed"); + } + } + + async getInternalAuthToken(): Promise { + if (!this.internalAuthToken) { + await this.initializeInternalAuthToken(); + } + return this.internalAuthToken!; + } + + private async generateAndGuideUser(): Promise { + const newSecret = crypto.randomBytes(32).toString("hex"); + const instanceId = crypto.randomBytes(8).toString("hex"); + + this.jwtSecret = newSecret; + + await this.updateEnvFile("JWT_SECRET", newSecret); + + databaseLogger.success("JWT secret auto-generated and saved to .env", { + operation: "jwt_auto_generated", + instanceId, + envVarName: "JWT_SECRET", + note: "Ready for use - no restart required", + }); + } + + private async generateAndGuideDatabaseKey(): Promise { + const newKey = crypto.randomBytes(32); + const newKeyHex = newKey.toString("hex"); + const instanceId = crypto.randomBytes(8).toString("hex"); + + this.databaseKey = newKey; + + await this.updateEnvFile("DATABASE_KEY", newKeyHex); + + databaseLogger.success("Database key auto-generated and saved to .env", { + operation: "db_key_auto_generated", + instanceId, + envVarName: "DATABASE_KEY", + note: "Ready for use - no restart required", + }); + } + + private async generateAndGuideInternalAuthToken(): Promise { + const newToken = crypto.randomBytes(32).toString("hex"); + const instanceId = crypto.randomBytes(8).toString("hex"); + + this.internalAuthToken = newToken; + + await this.updateEnvFile("INTERNAL_AUTH_TOKEN", newToken); + + databaseLogger.success( + "Internal auth token auto-generated and saved to .env", + { + operation: "internal_auth_auto_generated", + instanceId, + envVarName: "INTERNAL_AUTH_TOKEN", + note: "Ready for use - no restart required", + }, + ); + } + + async validateJWTSecret(): Promise { + try { + const secret = await this.getJWTSecret(); + if (!secret || secret.length < 32) { + return false; + } + + const jwt = await import("jsonwebtoken"); + const testPayload = { test: true, timestamp: Date.now() }; + const token = jwt.default.sign(testPayload, secret, { expiresIn: "1s" }); + const decoded = jwt.default.verify(token, secret); + + return !!decoded; + } catch (error) { + databaseLogger.error("JWT secret validation failed", error, { + operation: "jwt_validation_failed", + }); + return false; + } + } + + async getSystemKeyStatus() { + const isValid = await this.validateJWTSecret(); + const hasSecret = this.jwtSecret !== null; + + const hasEnvVar = !!( + process.env.JWT_SECRET && process.env.JWT_SECRET.length >= 64 + ); + + return { + hasSecret, + isValid, + storage: { + environment: hasEnvVar, + }, + algorithm: "HS256", + note: "Using simplified key management without encryption layers", + }; + } + + private async updateEnvFile(key: string, value: string): Promise { + const dataDir = process.env.DATA_DIR || "./db/data"; + const envPath = path.join(dataDir, ".env"); + + try { + await fs.mkdir(dataDir, { recursive: true }); + + let envContent = ""; + + try { + envContent = await fs.readFile(envPath, "utf8"); + } catch { + envContent = "# Termix Auto-generated Configuration\n\n"; + } + + const keyRegex = new RegExp(`^${key}=.*$`, "m"); + + if (keyRegex.test(envContent)) { + envContent = envContent.replace(keyRegex, `${key}=${value}`); + } else { + if (!envContent.includes("# Security Keys")) { + envContent += "\n# Security Keys (Auto-generated)\n"; + } + envContent += `${key}=${value}\n`; + } + + await fs.writeFile(envPath, envContent); + + process.env[key] = value; + } catch (error) { + databaseLogger.error(`Failed to update .env file with ${key}`, error, { + operation: "env_file_update_failed", + key, + }); + throw error; + } + } +} + +export { SystemCrypto }; diff --git a/src/backend/utils/user-crypto.ts b/src/backend/utils/user-crypto.ts new file mode 100644 index 00000000..4164ece4 --- /dev/null +++ b/src/backend/utils/user-crypto.ts @@ -0,0 +1,443 @@ +import crypto from "crypto"; +import { getDb } from "../database/db/index.js"; +import { settings, users } from "../database/db/schema.js"; +import { eq } from "drizzle-orm"; +import { databaseLogger } from "./logger.js"; + +interface KEKSalt { + salt: string; + iterations: number; + algorithm: string; + createdAt: string; +} + +interface EncryptedDEK { + data: string; + iv: string; + tag: string; + algorithm: string; + createdAt: string; +} + +interface UserSession { + dataKey: Buffer; + lastActivity: number; + expiresAt: number; +} + +class UserCrypto { + private static instance: UserCrypto; + private userSessions: Map = new Map(); + private sessionExpiredCallback?: (userId: string) => void; + + private static readonly PBKDF2_ITERATIONS = 100000; + private static readonly KEK_LENGTH = 32; + private static readonly DEK_LENGTH = 32; + private static readonly SESSION_DURATION = 24 * 60 * 60 * 1000; + private static readonly MAX_INACTIVITY = 6 * 60 * 60 * 1000; + + private constructor() { + setInterval( + () => { + this.cleanupExpiredSessions(); + }, + 5 * 60 * 1000, + ); + } + + static getInstance(): UserCrypto { + if (!this.instance) { + this.instance = new UserCrypto(); + } + return this.instance; + } + + setSessionExpiredCallback(callback: (userId: string) => void): void { + this.sessionExpiredCallback = callback; + } + + async setupUserEncryption(userId: string, password: string): Promise { + const kekSalt = await this.generateKEKSalt(); + await this.storeKEKSalt(userId, kekSalt); + + const KEK = this.deriveKEK(password, kekSalt); + const DEK = crypto.randomBytes(UserCrypto.DEK_LENGTH); + const encryptedDEK = this.encryptDEK(DEK, KEK); + await this.storeEncryptedDEK(userId, encryptedDEK); + + KEK.fill(0); + DEK.fill(0); + } + + async setupOIDCUserEncryption(userId: string): Promise { + const DEK = crypto.randomBytes(UserCrypto.DEK_LENGTH); + + const now = Date.now(); + this.userSessions.set(userId, { + dataKey: Buffer.from(DEK), + lastActivity: now, + expiresAt: now + UserCrypto.SESSION_DURATION, + }); + + DEK.fill(0); + } + + async authenticateUser(userId: string, password: string): Promise { + try { + const kekSalt = await this.getKEKSalt(userId); + if (!kekSalt) return false; + + const KEK = this.deriveKEK(password, kekSalt); + const encryptedDEK = await this.getEncryptedDEK(userId); + if (!encryptedDEK) { + KEK.fill(0); + return false; + } + + const DEK = this.decryptDEK(encryptedDEK, KEK); + KEK.fill(0); + + if (!DEK || DEK.length === 0) { + databaseLogger.error("DEK is empty or invalid after decryption", { + operation: "user_crypto_auth_debug", + userId, + dekLength: DEK ? DEK.length : 0, + }); + return false; + } + + const now = Date.now(); + + const oldSession = this.userSessions.get(userId); + if (oldSession) { + oldSession.dataKey.fill(0); + } + + this.userSessions.set(userId, { + dataKey: Buffer.from(DEK), + lastActivity: now, + expiresAt: now + UserCrypto.SESSION_DURATION, + }); + + DEK.fill(0); + + return true; + } catch (error) { + databaseLogger.warn("User authentication failed", { + operation: "user_crypto_auth_failed", + userId, + error: error instanceof Error ? error.message : "Unknown", + }); + return false; + } + } + + async authenticateOIDCUser(userId: string): Promise { + try { + const kekSalt = await this.getKEKSalt(userId); + if (!kekSalt) { + await this.setupOIDCUserEncryption(userId); + return true; + } + + const systemKey = this.deriveOIDCSystemKey(userId); + const encryptedDEK = await this.getEncryptedDEK(userId); + if (!encryptedDEK) { + systemKey.fill(0); + await this.setupOIDCUserEncryption(userId); + return true; + } + + const DEK = this.decryptDEK(encryptedDEK, systemKey); + systemKey.fill(0); + + if (!DEK || DEK.length === 0) { + await this.setupOIDCUserEncryption(userId); + return true; + } + + const now = Date.now(); + + const oldSession = this.userSessions.get(userId); + if (oldSession) { + oldSession.dataKey.fill(0); + } + + this.userSessions.set(userId, { + dataKey: Buffer.from(DEK), + lastActivity: now, + expiresAt: now + UserCrypto.SESSION_DURATION, + }); + + DEK.fill(0); + + return true; + } catch (error) { + await this.setupOIDCUserEncryption(userId); + return true; + } + } + + getUserDataKey(userId: string): Buffer | null { + const session = this.userSessions.get(userId); + if (!session) { + return null; + } + + const now = Date.now(); + + if (now > session.expiresAt) { + this.userSessions.delete(userId); + session.dataKey.fill(0); + if (this.sessionExpiredCallback) { + this.sessionExpiredCallback(userId); + } + return null; + } + + if (now - session.lastActivity > UserCrypto.MAX_INACTIVITY) { + this.userSessions.delete(userId); + session.dataKey.fill(0); + if (this.sessionExpiredCallback) { + this.sessionExpiredCallback(userId); + } + return null; + } + + session.lastActivity = now; + return session.dataKey; + } + + logoutUser(userId: string): void { + const session = this.userSessions.get(userId); + if (session) { + session.dataKey.fill(0); + this.userSessions.delete(userId); + } + } + + isUserUnlocked(userId: string): boolean { + return this.getUserDataKey(userId) !== null; + } + + async changeUserPassword( + userId: string, + oldPassword: string, + newPassword: string, + ): Promise { + try { + const isValid = await this.validatePassword(userId, oldPassword); + if (!isValid) return false; + + const kekSalt = await this.getKEKSalt(userId); + if (!kekSalt) return false; + + const oldKEK = this.deriveKEK(oldPassword, kekSalt); + const encryptedDEK = await this.getEncryptedDEK(userId); + if (!encryptedDEK) return false; + + const DEK = this.decryptDEK(encryptedDEK, oldKEK); + + const newKekSalt = await this.generateKEKSalt(); + const newKEK = this.deriveKEK(newPassword, newKekSalt); + const newEncryptedDEK = this.encryptDEK(DEK, newKEK); + + await this.storeKEKSalt(userId, newKekSalt); + await this.storeEncryptedDEK(userId, newEncryptedDEK); + + oldKEK.fill(0); + newKEK.fill(0); + DEK.fill(0); + + this.logoutUser(userId); + + return true; + } catch (error) { + return false; + } + } + + private async validatePassword( + userId: string, + password: string, + ): Promise { + try { + const kekSalt = await this.getKEKSalt(userId); + if (!kekSalt) return false; + + const KEK = this.deriveKEK(password, kekSalt); + const encryptedDEK = await this.getEncryptedDEK(userId); + if (!encryptedDEK) return false; + + const DEK = this.decryptDEK(encryptedDEK, KEK); + + KEK.fill(0); + DEK.fill(0); + + return true; + } catch (error) { + return false; + } + } + + private cleanupExpiredSessions(): void { + const now = Date.now(); + const expiredUsers: string[] = []; + + for (const [userId, session] of this.userSessions.entries()) { + if ( + now > session.expiresAt || + now - session.lastActivity > UserCrypto.MAX_INACTIVITY + ) { + session.dataKey.fill(0); + expiredUsers.push(userId); + } + } + + expiredUsers.forEach((userId) => { + this.userSessions.delete(userId); + }); + } + + private async generateKEKSalt(): Promise { + return { + salt: crypto.randomBytes(32).toString("hex"), + iterations: UserCrypto.PBKDF2_ITERATIONS, + algorithm: "pbkdf2-sha256", + createdAt: new Date().toISOString(), + }; + } + + private deriveKEK(password: string, kekSalt: KEKSalt): Buffer { + return crypto.pbkdf2Sync( + password, + Buffer.from(kekSalt.salt, "hex"), + kekSalt.iterations, + UserCrypto.KEK_LENGTH, + "sha256", + ); + } + + private deriveOIDCSystemKey(userId: string): Buffer { + const systemSecret = + process.env.OIDC_SYSTEM_SECRET || "termix-oidc-system-secret-default"; + const salt = Buffer.from(userId, "utf8"); + return crypto.pbkdf2Sync( + systemSecret, + salt, + 100000, + UserCrypto.KEK_LENGTH, + "sha256", + ); + } + + private encryptDEK(dek: Buffer, kek: Buffer): EncryptedDEK { + const iv = crypto.randomBytes(16); + const cipher = crypto.createCipheriv("aes-256-gcm", kek, iv); + + let encrypted = cipher.update(dek); + encrypted = Buffer.concat([encrypted, cipher.final()]); + const tag = cipher.getAuthTag(); + + return { + data: encrypted.toString("hex"), + iv: iv.toString("hex"), + tag: tag.toString("hex"), + algorithm: "aes-256-gcm", + createdAt: new Date().toISOString(), + }; + } + + private decryptDEK(encryptedDEK: EncryptedDEK, kek: Buffer): Buffer { + const decipher = crypto.createDecipheriv( + "aes-256-gcm", + kek, + Buffer.from(encryptedDEK.iv, "hex"), + ); + + decipher.setAuthTag(Buffer.from(encryptedDEK.tag, "hex")); + let decrypted = decipher.update(Buffer.from(encryptedDEK.data, "hex")); + decrypted = Buffer.concat([decrypted, decipher.final()]); + + return decrypted; + } + + private async storeKEKSalt(userId: string, kekSalt: KEKSalt): Promise { + const key = `user_kek_salt_${userId}`; + const value = JSON.stringify(kekSalt); + + const existing = await getDb() + .select() + .from(settings) + .where(eq(settings.key, key)); + + if (existing.length > 0) { + await getDb() + .update(settings) + .set({ value }) + .where(eq(settings.key, key)); + } else { + await getDb().insert(settings).values({ key, value }); + } + } + + private async getKEKSalt(userId: string): Promise { + try { + const key = `user_kek_salt_${userId}`; + const result = await getDb() + .select() + .from(settings) + .where(eq(settings.key, key)); + + if (result.length === 0) { + return null; + } + + return JSON.parse(result[0].value); + } catch (error) { + return null; + } + } + + private async storeEncryptedDEK( + userId: string, + encryptedDEK: EncryptedDEK, + ): Promise { + const key = `user_encrypted_dek_${userId}`; + const value = JSON.stringify(encryptedDEK); + + const existing = await getDb() + .select() + .from(settings) + .where(eq(settings.key, key)); + + if (existing.length > 0) { + await getDb() + .update(settings) + .set({ value }) + .where(eq(settings.key, key)); + } else { + await getDb().insert(settings).values({ key, value }); + } + } + + private async getEncryptedDEK(userId: string): Promise { + try { + const key = `user_encrypted_dek_${userId}`; + const result = await getDb() + .select() + .from(settings) + .where(eq(settings.key, key)); + + if (result.length === 0) { + return null; + } + + return JSON.parse(result[0].value); + } catch (error) { + return null; + } + } +} + +export { UserCrypto, type KEKSalt, type EncryptedDEK }; diff --git a/src/backend/utils/user-data-export.ts b/src/backend/utils/user-data-export.ts new file mode 100644 index 00000000..82d3fde3 --- /dev/null +++ b/src/backend/utils/user-data-export.ts @@ -0,0 +1,281 @@ +import { getDb } from "../database/db/index.js"; +import { + users, + sshData, + sshCredentials, + fileManagerRecent, + fileManagerPinned, + fileManagerShortcuts, + dismissedAlerts, +} from "../database/db/schema.js"; +import { eq } from "drizzle-orm"; +import { DataCrypto } from "./data-crypto.js"; +import { databaseLogger } from "./logger.js"; + +interface UserExportData { + version: string; + exportedAt: string; + userId: string; + username: string; + userData: { + sshHosts: any[]; + sshCredentials: any[]; + fileManagerData: { + recent: any[]; + pinned: any[]; + shortcuts: any[]; + }; + dismissedAlerts: any[]; + }; + metadata: { + totalRecords: number; + encrypted: boolean; + exportType: "user_data" | "system_config" | "all"; + }; +} + +class UserDataExport { + private static readonly EXPORT_VERSION = "v2.0"; + + static async exportUserData( + userId: string, + options: { + format?: "encrypted" | "plaintext"; + scope?: "user_data" | "all"; + includeCredentials?: boolean; + } = {}, + ): Promise { + const { + format = "encrypted", + scope = "user_data", + includeCredentials = true, + } = options; + + try { + const user = await getDb() + .select() + .from(users) + .where(eq(users.id, userId)); + if (!user || user.length === 0) { + throw new Error(`User not found: ${userId}`); + } + + const userRecord = user[0]; + + let userDataKey: Buffer | null = null; + if (format === "plaintext") { + userDataKey = DataCrypto.getUserDataKey(userId); + if (!userDataKey) { + throw new Error( + "User data not unlocked - password required for plaintext export", + ); + } + } + + const sshHosts = await getDb() + .select() + .from(sshData) + .where(eq(sshData.userId, userId)); + const processedSshHosts = + format === "plaintext" && userDataKey + ? sshHosts.map((host) => + DataCrypto.decryptRecord("ssh_data", host, userId, userDataKey!), + ) + : sshHosts; + + let sshCredentialsData: any[] = []; + if (includeCredentials) { + const credentials = await getDb() + .select() + .from(sshCredentials) + .where(eq(sshCredentials.userId, userId)); + sshCredentialsData = + format === "plaintext" && userDataKey + ? credentials.map((cred) => + DataCrypto.decryptRecord( + "ssh_credentials", + cred, + userId, + userDataKey!, + ), + ) + : credentials; + } + + const [recentFiles, pinnedFiles, shortcuts] = await Promise.all([ + getDb() + .select() + .from(fileManagerRecent) + .where(eq(fileManagerRecent.userId, userId)), + getDb() + .select() + .from(fileManagerPinned) + .where(eq(fileManagerPinned.userId, userId)), + getDb() + .select() + .from(fileManagerShortcuts) + .where(eq(fileManagerShortcuts.userId, userId)), + ]); + + const alerts = await getDb() + .select() + .from(dismissedAlerts) + .where(eq(dismissedAlerts.userId, userId)); + + const exportData: UserExportData = { + version: this.EXPORT_VERSION, + exportedAt: new Date().toISOString(), + userId: userRecord.id, + username: userRecord.username, + userData: { + sshHosts: processedSshHosts, + sshCredentials: sshCredentialsData, + fileManagerData: { + recent: recentFiles, + pinned: pinnedFiles, + shortcuts: shortcuts, + }, + dismissedAlerts: alerts, + }, + metadata: { + totalRecords: + processedSshHosts.length + + sshCredentialsData.length + + recentFiles.length + + pinnedFiles.length + + shortcuts.length + + alerts.length, + encrypted: format === "encrypted", + exportType: scope, + }, + }; + + databaseLogger.success("User data export completed", { + operation: "user_data_export_complete", + userId, + totalRecords: exportData.metadata.totalRecords, + format, + sshHosts: processedSshHosts.length, + sshCredentials: sshCredentialsData.length, + }); + + return exportData; + } catch (error) { + databaseLogger.error("User data export failed", error, { + operation: "user_data_export_failed", + userId, + format, + scope, + }); + throw error; + } + } + + static async exportUserDataToJSON( + userId: string, + options: { + format?: "encrypted" | "plaintext"; + scope?: "user_data" | "all"; + includeCredentials?: boolean; + pretty?: boolean; + } = {}, + ): Promise { + const { pretty = true } = options; + const exportData = await this.exportUserData(userId, options); + return JSON.stringify(exportData, null, pretty ? 2 : 0); + } + + static validateExportData(data: any): { valid: boolean; errors: string[] } { + const errors: string[] = []; + + if (!data || typeof data !== "object") { + errors.push("Export data must be an object"); + return { valid: false, errors }; + } + + if (!data.version) { + errors.push("Missing version field"); + } + + if (!data.userId) { + errors.push("Missing userId field"); + } + + if (!data.userData || typeof data.userData !== "object") { + errors.push("Missing or invalid userData field"); + } + + if (!data.metadata || typeof data.metadata !== "object") { + errors.push("Missing or invalid metadata field"); + } + + if (data.userData) { + const requiredFields = [ + "sshHosts", + "sshCredentials", + "fileManagerData", + "dismissedAlerts", + ]; + for (const field of requiredFields) { + if ( + !Array.isArray(data.userData[field]) && + !( + field === "fileManagerData" && + typeof data.userData[field] === "object" + ) + ) { + errors.push(`Missing or invalid userData.${field} field`); + } + } + + if ( + data.userData.fileManagerData && + typeof data.userData.fileManagerData === "object" + ) { + const fmFields = ["recent", "pinned", "shortcuts"]; + for (const field of fmFields) { + if (!Array.isArray(data.userData.fileManagerData[field])) { + errors.push( + `Missing or invalid userData.fileManagerData.${field} field`, + ); + } + } + } + } + + return { valid: errors.length === 0, errors }; + } + + static getExportStats(data: UserExportData): { + version: string; + exportedAt: string; + username: string; + totalRecords: number; + breakdown: { + sshHosts: number; + sshCredentials: number; + fileManagerItems: number; + dismissedAlerts: number; + }; + encrypted: boolean; + } { + return { + version: data.version, + exportedAt: data.exportedAt, + username: data.username, + totalRecords: data.metadata.totalRecords, + breakdown: { + sshHosts: data.userData.sshHosts.length, + sshCredentials: data.userData.sshCredentials.length, + fileManagerItems: + data.userData.fileManagerData.recent.length + + data.userData.fileManagerData.pinned.length + + data.userData.fileManagerData.shortcuts.length, + dismissedAlerts: data.userData.dismissedAlerts.length, + }, + encrypted: data.metadata.encrypted, + }; + } +} + +export { UserDataExport, type UserExportData }; diff --git a/src/backend/utils/user-data-import.ts b/src/backend/utils/user-data-import.ts new file mode 100644 index 00000000..448d3c00 --- /dev/null +++ b/src/backend/utils/user-data-import.ts @@ -0,0 +1,434 @@ +import { getDb } from "../database/db/index.js"; +import { + users, + sshData, + sshCredentials, + fileManagerRecent, + fileManagerPinned, + fileManagerShortcuts, + dismissedAlerts, +} from "../database/db/schema.js"; +import { eq, and } from "drizzle-orm"; +import { DataCrypto } from "./data-crypto.js"; +import { UserDataExport, type UserExportData } from "./user-data-export.js"; +import { databaseLogger } from "./logger.js"; +import { nanoid } from "nanoid"; + +interface ImportOptions { + replaceExisting?: boolean; + skipCredentials?: boolean; + skipFileManagerData?: boolean; + dryRun?: boolean; +} + +interface ImportResult { + success: boolean; + summary: { + sshHostsImported: number; + sshCredentialsImported: number; + fileManagerItemsImported: number; + dismissedAlertsImported: number; + skippedItems: number; + errors: string[]; + }; + dryRun: boolean; +} + +class UserDataImport { + static async importUserData( + targetUserId: string, + exportData: UserExportData, + options: ImportOptions = {}, + ): Promise { + const { + replaceExisting = false, + skipCredentials = false, + skipFileManagerData = false, + dryRun = false, + } = options; + + try { + const targetUser = await getDb() + .select() + .from(users) + .where(eq(users.id, targetUserId)); + if (!targetUser || targetUser.length === 0) { + throw new Error(`Target user not found: ${targetUserId}`); + } + + const validation = UserDataExport.validateExportData(exportData); + if (!validation.valid) { + throw new Error(`Invalid export data: ${validation.errors.join(", ")}`); + } + + let userDataKey: Buffer | null = null; + if (exportData.metadata.encrypted) { + userDataKey = DataCrypto.getUserDataKey(targetUserId); + if (!userDataKey) { + throw new Error( + "Target user data not unlocked - password required for encrypted import", + ); + } + } + + const result: ImportResult = { + success: false, + summary: { + sshHostsImported: 0, + sshCredentialsImported: 0, + fileManagerItemsImported: 0, + dismissedAlertsImported: 0, + skippedItems: 0, + errors: [], + }, + dryRun, + }; + + if ( + exportData.userData.sshHosts && + exportData.userData.sshHosts.length > 0 + ) { + const importStats = await this.importSshHosts( + targetUserId, + exportData.userData.sshHosts, + { replaceExisting, dryRun, userDataKey }, + ); + result.summary.sshHostsImported = importStats.imported; + result.summary.skippedItems += importStats.skipped; + result.summary.errors.push(...importStats.errors); + } + + if ( + !skipCredentials && + exportData.userData.sshCredentials && + exportData.userData.sshCredentials.length > 0 + ) { + const importStats = await this.importSshCredentials( + targetUserId, + exportData.userData.sshCredentials, + { replaceExisting, dryRun, userDataKey }, + ); + result.summary.sshCredentialsImported = importStats.imported; + result.summary.skippedItems += importStats.skipped; + result.summary.errors.push(...importStats.errors); + } + + if (!skipFileManagerData && exportData.userData.fileManagerData) { + const importStats = await this.importFileManagerData( + targetUserId, + exportData.userData.fileManagerData, + { replaceExisting, dryRun }, + ); + result.summary.fileManagerItemsImported = importStats.imported; + result.summary.skippedItems += importStats.skipped; + result.summary.errors.push(...importStats.errors); + } + + if ( + exportData.userData.dismissedAlerts && + exportData.userData.dismissedAlerts.length > 0 + ) { + const importStats = await this.importDismissedAlerts( + targetUserId, + exportData.userData.dismissedAlerts, + { replaceExisting, dryRun }, + ); + result.summary.dismissedAlertsImported = importStats.imported; + result.summary.skippedItems += importStats.skipped; + result.summary.errors.push(...importStats.errors); + } + + result.success = result.summary.errors.length === 0; + + databaseLogger.success("User data import completed", { + operation: "user_data_import_complete", + targetUserId, + dryRun, + ...result.summary, + }); + + return result; + } catch (error) { + databaseLogger.error("User data import failed", error, { + operation: "user_data_import_failed", + targetUserId, + dryRun, + }); + throw error; + } + } + + private static async importSshHosts( + targetUserId: string, + sshHosts: any[], + options: { + replaceExisting: boolean; + dryRun: boolean; + userDataKey: Buffer | null; + }, + ) { + let imported = 0; + let skipped = 0; + const errors: string[] = []; + + for (const host of sshHosts) { + try { + if (options.dryRun) { + imported++; + continue; + } + + const tempId = `import-ssh-${targetUserId}-${Date.now()}-${imported}`; + const newHostData = { + ...host, + id: tempId, + userId: targetUserId, + createdAt: new Date().toISOString(), + updatedAt: new Date().toISOString(), + }; + + let processedHostData = newHostData; + if (options.userDataKey) { + processedHostData = DataCrypto.encryptRecord( + "ssh_data", + newHostData, + targetUserId, + options.userDataKey, + ); + } + + delete processedHostData.id; + + await getDb().insert(sshData).values(processedHostData); + imported++; + } catch (error) { + errors.push( + `SSH host import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + + return { imported, skipped, errors }; + } + + private static async importSshCredentials( + targetUserId: string, + credentials: any[], + options: { + replaceExisting: boolean; + dryRun: boolean; + userDataKey: Buffer | null; + }, + ) { + let imported = 0; + let skipped = 0; + const errors: string[] = []; + + for (const credential of credentials) { + try { + if (options.dryRun) { + imported++; + continue; + } + + const tempCredId = `import-cred-${targetUserId}-${Date.now()}-${imported}`; + const newCredentialData = { + ...credential, + id: tempCredId, + userId: targetUserId, + usageCount: 0, + lastUsed: null, + createdAt: new Date().toISOString(), + updatedAt: new Date().toISOString(), + }; + + let processedCredentialData = newCredentialData; + if (options.userDataKey) { + processedCredentialData = DataCrypto.encryptRecord( + "ssh_credentials", + newCredentialData, + targetUserId, + options.userDataKey, + ); + } + + delete processedCredentialData.id; + + await getDb().insert(sshCredentials).values(processedCredentialData); + imported++; + } catch (error) { + errors.push( + `SSH credential import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + + return { imported, skipped, errors }; + } + + private static async importFileManagerData( + targetUserId: string, + fileManagerData: any, + options: { replaceExisting: boolean; dryRun: boolean }, + ) { + let imported = 0; + let skipped = 0; + const errors: string[] = []; + + try { + if (fileManagerData.recent && Array.isArray(fileManagerData.recent)) { + for (const item of fileManagerData.recent) { + try { + if (!options.dryRun) { + const newItem = { + ...item, + id: undefined, + userId: targetUserId, + lastOpened: new Date().toISOString(), + }; + await getDb().insert(fileManagerRecent).values(newItem); + } + imported++; + } catch (error) { + errors.push( + `Recent file import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + } + + if (fileManagerData.pinned && Array.isArray(fileManagerData.pinned)) { + for (const item of fileManagerData.pinned) { + try { + if (!options.dryRun) { + const newItem = { + ...item, + id: undefined, + userId: targetUserId, + pinnedAt: new Date().toISOString(), + }; + await getDb().insert(fileManagerPinned).values(newItem); + } + imported++; + } catch (error) { + errors.push( + `Pinned file import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + } + + if ( + fileManagerData.shortcuts && + Array.isArray(fileManagerData.shortcuts) + ) { + for (const item of fileManagerData.shortcuts) { + try { + if (!options.dryRun) { + const newItem = { + ...item, + id: undefined, + userId: targetUserId, + createdAt: new Date().toISOString(), + }; + await getDb().insert(fileManagerShortcuts).values(newItem); + } + imported++; + } catch (error) { + errors.push( + `Shortcut import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + } + } catch (error) { + errors.push( + `File manager data import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + } + + return { imported, skipped, errors }; + } + + private static async importDismissedAlerts( + targetUserId: string, + alerts: any[], + options: { replaceExisting: boolean; dryRun: boolean }, + ) { + let imported = 0; + let skipped = 0; + const errors: string[] = []; + + for (const alert of alerts) { + try { + if (options.dryRun) { + imported++; + continue; + } + + const existing = await getDb() + .select() + .from(dismissedAlerts) + .where( + and( + eq(dismissedAlerts.userId, targetUserId), + eq(dismissedAlerts.alertId, alert.alertId), + ), + ); + + if (existing.length > 0 && !options.replaceExisting) { + skipped++; + continue; + } + + const newAlert = { + ...alert, + id: undefined, + userId: targetUserId, + dismissedAt: new Date().toISOString(), + }; + + if (existing.length > 0 && options.replaceExisting) { + await getDb() + .update(dismissedAlerts) + .set(newAlert) + .where(eq(dismissedAlerts.id, existing[0].id)); + } else { + await getDb().insert(dismissedAlerts).values(newAlert); + } + + imported++; + } catch (error) { + errors.push( + `Dismissed alert import failed: ${error instanceof Error ? error.message : "Unknown error"}`, + ); + skipped++; + } + } + + return { imported, skipped, errors }; + } + + static async importUserDataFromJSON( + targetUserId: string, + jsonData: string, + options: ImportOptions = {}, + ): Promise { + try { + const exportData: UserExportData = JSON.parse(jsonData); + return await this.importUserData(targetUserId, exportData, options); + } catch (error) { + if (error instanceof SyntaxError) { + throw new Error("Invalid JSON format in import data"); + } + throw error; + } + } +} + +export { UserDataImport, type ImportOptions, type ImportResult }; diff --git a/src/components/ui/sonner.tsx b/src/components/ui/sonner.tsx index 7264637e..557077ac 100644 --- a/src/components/ui/sonner.tsx +++ b/src/components/ui/sonner.tsx @@ -1,8 +1,40 @@ import { useTheme } from "next-themes"; -import { Toaster as Sonner, type ToasterProps } from "sonner"; +import { Toaster as Sonner, type ToasterProps, toast } from "sonner"; +import { useRef } from "react"; const Toaster = ({ ...props }: ToasterProps) => { const { theme = "system" } = useTheme(); + const lastToastRef = useRef<{ text: string; timestamp: number } | null>(null); + + const originalToast = toast; + + const rateLimitedToast = (message: string, options?: any) => { + const now = Date.now(); + const lastToast = lastToastRef.current; + + if ( + lastToast && + lastToast.text === message && + now - lastToast.timestamp < 1000 + ) { + return; + } + + lastToastRef.current = { text: message, timestamp: now }; + return originalToast(message, options); + }; + + Object.assign(toast, { + success: (message: string, options?: any) => + rateLimitedToast(message, { ...options, type: "success" }), + error: (message: string, options?: any) => + rateLimitedToast(message, { ...options, type: "error" }), + warning: (message: string, options?: any) => + rateLimitedToast(message, { ...options, type: "warning" }), + info: (message: string, options?: any) => + rateLimitedToast(message, { ...options, type: "info" }), + message: rateLimitedToast, + }); return ( void; +} + +export function VersionAlert({ updateInfo, onDownload }: VersionAlertProps) { + const { t } = useTranslation(); + + if (!updateInfo.success) { + return ( + + + {t("versionCheck.error")} + + {updateInfo.error || t("versionCheck.checkFailed")} + + + ); + } + + if (updateInfo.status === "up_to_date") { + return ( + + + {t("versionCheck.upToDate")} + + {t("versionCheck.currentVersion", { + version: updateInfo.localVersion, + })} + + + ); + } + + if (updateInfo.status === "requires_update") { + return ( + + + {t("versionCheck.updateAvailable")} + +
+ {t("versionCheck.newVersionAvailable", { + current: updateInfo.localVersion, + latest: updateInfo.remoteVersion, + })} +
+ + {updateInfo.latest_release && ( +
+
+ {updateInfo.latest_release.name} +
+
+ {t("versionCheck.releasedOn", { + date: new Date( + updateInfo.latest_release.published_at, + ).toLocaleDateString(), + })} +
+
+ )} + +
+ {updateInfo.latest_release?.html_url && ( + + )} +
+
+
+ ); + } + + return null; +} diff --git a/src/components/ui/version-check-modal.tsx b/src/components/ui/version-check-modal.tsx new file mode 100644 index 00000000..29d20aa9 --- /dev/null +++ b/src/components/ui/version-check-modal.tsx @@ -0,0 +1,187 @@ +import React, { useState, useEffect } from "react"; +import { Button } from "@/components/ui/button.tsx"; +import { VersionAlert } from "@/components/ui/version-alert.tsx"; +import { RefreshCw, X } from "lucide-react"; +import { useTranslation } from "react-i18next"; +import { checkElectronUpdate, isElectron } from "@/ui/main-axios.ts"; + +interface VersionCheckModalProps { + onDismiss: () => void; + onContinue: () => void; + isAuthenticated?: boolean; +} + +export function VersionCheckModal({ + onDismiss, + onContinue, + isAuthenticated = false, +}: VersionCheckModalProps) { + const { t } = useTranslation(); + const [versionInfo, setVersionInfo] = useState(null); + const [versionChecking, setVersionChecking] = useState(false); + const [versionDismissed, setVersionDismissed] = useState(false); + + useEffect(() => { + if (isElectron()) { + checkForUpdates(); + } else { + onContinue(); + } + }, []); + + const checkForUpdates = async () => { + setVersionChecking(true); + try { + const updateInfo = await checkElectronUpdate(); + setVersionInfo(updateInfo); + + if (updateInfo?.status === "up_to_date") { + onContinue(); + return; + } + } catch (error) { + console.error("Failed to check for updates:", error); + setVersionInfo({ success: false, error: "Check failed" }); + } finally { + setVersionChecking(false); + } + }; + + const handleVersionDismiss = () => { + setVersionDismissed(true); + }; + + const handleDownloadUpdate = () => { + if (versionInfo?.latest_release?.html_url) { + window.open(versionInfo.latest_release.html_url, "_blank"); + } + }; + + const handleContinue = () => { + onContinue(); + }; + + if (!isElectron()) { + return null; + } + + if (versionChecking && !versionInfo) { + return ( +
+ {!isAuthenticated && ( +
+ )} +
+
+
+
+

+ {t("versionCheck.checkingUpdates")} +

+
+
+ ); + } + + if (!versionInfo || versionDismissed) { + return ( +
+ {!isAuthenticated && ( +
+ )} +
+
+

+ {t("versionCheck.checkUpdates")} +

+
+ + {versionInfo && !versionDismissed && ( +
+ +
+ )} + +
+ +
+
+
+ ); + } + + return ( +
+ {!isAuthenticated && ( +
+ )} +
+
+

+ {t("versionCheck.updateRequired")} +

+
+ +
+ +
+ +
+ +
+
+
+ ); +} diff --git a/src/index.css b/src/index.css index f463abb8..c833a548 100644 --- a/src/index.css +++ b/src/index.css @@ -1,5 +1,4 @@ @import "tailwindcss"; -@import "tw-animate-css"; @custom-variant dark (&:is(.dark *)); diff --git a/src/locales/en/translation.json b/src/locales/en/translation.json index f40340c4..262cec0a 100644 --- a/src/locales/en/translation.json +++ b/src/locales/en/translation.json @@ -87,7 +87,20 @@ "keyPassphraseOptional": "Optional: leave empty if your key has no passphrase", "leaveEmptyToKeepCurrent": "Leave empty to keep current value", "uploadKeyFile": "Upload Key File", + "generateKeyPairButton": "Generate Key Pair", "generateKeyPair": "Generate Key Pair", + "generateKeyPairDescription": "Generate a new SSH key pair. If you want to protect the key with a passphrase, enter it in the Key Password field below first.", + "deploySSHKey": "Deploy SSH Key", + "deploySSHKeyDescription": "Deploy public key to target server", + "sourceCredential": "Source Credential", + "targetHost": "Target Host", + "deploymentProcess": "Deployment Process", + "deploymentProcessDescription": "This will safely add the public key to the target host's ~/.ssh/authorized_keys file without overwriting existing keys. The operation is reversible.", + "chooseHostToDeploy": "Choose a host to deploy to...", + "deploying": "Deploying...", + "name": "Name", + "noHostsAvailable": "No hosts available", + "noHostsMatchSearch": "No hosts match your search", "sshKeyGenerationNotImplemented": "SSH key generation feature coming soon", "connectionTestingNotImplemented": "Connection testing feature coming soon", "testConnection": "Test Connection", @@ -123,14 +136,47 @@ "editCredentialDescription": "Update the credential information", "listView": "List", "folderView": "Folders", - "unknown": "Unknown", + "unknownCredential": "Unknown", "confirmRemoveFromFolder": "Are you sure you want to remove \"{{name}}\" from folder \"{{folder}}\"? The credential will be moved to \"Uncategorized\".", "removedFromFolder": "Credential \"{{name}}\" removed from folder successfully", "failedToRemoveFromFolder": "Failed to remove credential from folder", "folderRenamed": "Folder \"{{oldName}}\" renamed to \"{{newName}}\" successfully", "failedToRenameFolder": "Failed to rename folder", "movedToFolder": "Credential \"{{name}}\" moved to \"{{folder}}\" successfully", - "failedToMoveToFolder": "Failed to move credential to folder" + "failedToMoveToFolder": "Failed to move credential to folder", + "sshPublicKey": "SSH Public Key", + "publicKeyNote": "Public key is optional but recommended for key validation", + "publicKeyUploaded": "Public Key Uploaded", + "uploadPublicKey": "Upload Public Key", + "uploadPrivateKeyFile": "Upload Private Key File", + "uploadPublicKeyFile": "Upload Public Key File", + "privateKeyRequiredForGeneration": "Private key is required to generate public key", + "failedToGeneratePublicKey": "Failed to generate public key", + "generatePublicKey": "Generate from Private Key", + "publicKeyGeneratedSuccessfully": "Public key generated successfully", + "detectedKeyType": "Detected key type", + "detectingKeyType": "detecting...", + "optional": "Optional", + "generateKeyPairNew": "Generate New Key Pair", + "generateEd25519": "Generate Ed25519", + "generateECDSA": "Generate ECDSA", + "generateRSA": "Generate RSA", + "keyPairGeneratedSuccessfully": "{{keyType}} key pair generated successfully", + "failedToGenerateKeyPair": "Failed to generate key pair", + "generateKeyPairNote": "Generate a new SSH key pair directly. This will replace any existing keys in the form.", + "invalidKey": "Invalid Key", + "detectionError": "Detection Error", + "unknown": "Unknown" + }, + "dragIndicator": { + "error": "Error: {{error}}", + "dragging": "Dragging {{fileName}}", + "preparing": "Preparing {{fileName}}", + "readySingle": "Ready to download {{fileName}}", + "readyMultiple": "Ready to download {{count}} files", + "batchDrag": "Drag {{count}} files to desktop", + "dragToDesktop": "Drag to desktop", + "canDragAnywhere": "You can drag files anywhere on your desktop" }, "sshTools": { "title": "SSH Tools", @@ -167,12 +213,32 @@ "saveError": "Error saving configuration", "saving": "Saving...", "saveConfig": "Save Configuration", - "helpText": "Enter the URL where your Termix server is running (e.g., http://localhost:8081 or https://your-server.com)" + "helpText": "Enter the URL where your Termix server is running (e.g., http://localhost:30001 or https://your-server.com)" + }, + "versionCheck": { + "error": "Version Check Error", + "checkFailed": "Failed to check for updates", + "upToDate": "App is Up to Date", + "currentVersion": "You are running version {{version}}", + "updateAvailable": "Update Available", + "newVersionAvailable": "A new version is available! You are running {{current}}, but {{latest}} is available.", + "releasedOn": "Released on {{date}}", + "downloadUpdate": "Download Update", + "dismiss": "Dismiss", + "checking": "Checking for updates...", + "checkUpdates": "Check for Updates", + "checkingUpdates": "Checking for updates...", + "refresh": "Refresh", + "updateRequired": "Update Required", + "updateDismissed": "Update notification dismissed", + "noUpdatesFound": "No updates found" }, "common": { "close": "Close", + "minimize": "Minimize", "online": "Online", "offline": "Offline", + "continue": "Continue", "maintenance": "Maintenance", "degraded": "Degraded", "discord": "Discord", @@ -201,6 +267,7 @@ "newVersionAvailable": "A new version ({{version}}) is available.", "failedToFetchUpdateInfo": "Failed to fetch update information", "preRelease": "Pre-release", + "loginFailed": "Login failed", "noReleasesFound": "No releases found.", "yourBackupCodes": "Your Backup Codes", "sendResetCode": "Send Reset Code", @@ -219,6 +286,9 @@ "sshTools": "SSH Tools", "english": "English", "chinese": "Chinese", + "cancel": "Cancel", + "username": "Username", + "name": "Name", "login": "Login", "logout": "Logout", "register": "Register", @@ -270,7 +340,10 @@ "failedToInitiatePasswordReset": "Failed to initiate password reset", "failedToVerifyResetCode": "Failed to verify reset code", "failedToCompletePasswordReset": "Failed to complete password reset", - "documentation": "Documentation" + "documentation": "Documentation", + "retry": "Retry", + "checking": "Checking...", + "checkingDatabase": "Checking database connection..." }, "nav": { "home": "Home", @@ -353,7 +426,126 @@ "deleteUser": "Delete user {{username}}? This cannot be undone.", "userDeletedSuccessfully": "User {{username}} deleted successfully", "failedToDeleteUser": "Failed to delete user", - "overrideUserInfoUrl": "Override User Info URL (not required)" + "overrideUserInfoUrl": "Override User Info URL (not required)", + "databaseSecurity": "Database Security", + "encryptionStatus": "Encryption Status", + "encryptionEnabled": "Encryption Enabled", + "enabled": "Enabled", + "disabled": "Disabled", + "keyId": "Key ID", + "created": "Created", + "migrationStatus": "Migration Status", + "migrationCompleted": "Migration completed", + "migrationRequired": "Migration required", + "deviceProtectedMasterKey": "Environment-Protected Master Key", + "legacyKeyStorage": "Legacy Key Storage", + "masterKeyEncryptedWithDeviceFingerprint": "Master key encrypted with environment fingerprint (KEK protection active)", + "keyNotProtectedByDeviceBinding": "Key not protected by environment binding (upgrade recommended)", + "valid": "Valid", + "initializeDatabaseEncryption": "Initialize Database Encryption", + "enableAes256EncryptionWithDeviceBinding": "Enable AES-256 encryption with environment-bound master key protection. This creates enterprise-grade security for SSH keys, passwords, and authentication tokens.", + "featuresEnabled": "Features enabled:", + "aes256GcmAuthenticatedEncryption": "AES-256-GCM authenticated encryption", + "deviceFingerprintMasterKeyProtection": "Environment fingerprint master key protection (KEK)", + "pbkdf2KeyDerivation": "PBKDF2 key derivation with 100K iterations", + "automaticKeyManagement": "Automatic key management and rotation", + "initializing": "Initializing...", + "initializeEnterpriseEncryption": "Initialize Enterprise Encryption", + "migrateExistingData": "Migrate Existing Data", + "encryptExistingUnprotectedData": "Encrypt existing unprotected data in your database. This process is safe and creates automatic backups.", + "testMigrationDryRun": "Verify Encryption Compatibility", + "migrating": "Migrating...", + "migrateData": "Migrate Data", + "securityInformation": "Security Information", + "sshPrivateKeysEncryptedWithAes256": "SSH private keys and passwords are encrypted with AES-256-GCM", + "userAuthTokensProtected": "User authentication tokens and 2FA secrets are protected", + "masterKeysProtectedByDeviceFingerprint": "Master encryption keys are protected by device fingerprint (KEK)", + "keysBoundToServerInstance": "Keys are bound to current server environment (migratable via environment variables)", + "pbkdf2HkdfKeyDerivation": "PBKDF2 + HKDF key derivation with 100K iterations", + "backwardCompatibleMigration": "All data remains backward compatible during migration", + "enterpriseGradeSecurityActive": "Enterprise-Grade Security Active", + "masterKeysProtectedByDeviceBinding": "Your master encryption keys are protected by environment fingerprinting. This uses server hostname, paths, and other environment info to generate protection keys. To migrate servers, set the DB_ENCRYPTION_KEY environment variable on the new server.", + "important": "Important", + "keepEncryptionKeysSecure": "Ensure data security: regularly backup your database files and server configuration. To migrate to a new server, set the DB_ENCRYPTION_KEY environment variable on the new environment, or maintain the same hostname and directory structure.", + "loadingEncryptionStatus": "Loading encryption status...", + "testMigrationDescription": "Verify that existing data can be safely migrated to encrypted format without actually modifying any data", + "serverMigrationGuide": "Server Migration Guide", + "migrationInstructions": "To migrate encrypted data to a new server: 1) Backup database files, 2) Set environment variable DB_ENCRYPTION_KEY=\"your-key\" on new server, 3) Restore database files", + "environmentProtection": "Environment Protection", + "environmentProtectionDesc": "Protects encryption keys based on server environment info (hostname, paths, etc.), migratable via environment variables", + "verificationCompleted": "Compatibility verification completed - no data was changed", + "verificationInProgress": "Verification completed", + "dataMigrationCompleted": "Data migration completed successfully!", + "migrationCompleted": "Migration completed", + "verificationFailed": "Compatibility verification failed", + "migrationFailed": "Migration failed", + "runningVerification": "Running compatibility verification...", + "startingMigration": "Starting migration...", + "hardwareFingerprintSecurity": "Hardware Fingerprint Security", + "hardwareBoundEncryption": "Hardware-Bound Encryption Active", + "masterKeysNowProtectedByHardwareFingerprint": "Master keys are now protected by real hardware fingerprinting instead of environment variables", + "cpuSerialNumberDetection": "CPU serial number detection", + "motherboardUuidIdentification": "Motherboard UUID identification", + "diskSerialNumberVerification": "Disk serial number verification", + "biosSerialNumberCheck": "BIOS serial number check", + "stableMacAddressFiltering": "Stable MAC address filtering", + "databaseFileEncryption": "Database File Encryption", + "dualLayerProtection": "Dual-Layer Protection Active", + "bothFieldAndFileEncryptionActive": "Both field-level and file-level encryption are now active for maximum security", + "fieldLevelAes256Encryption": "Field-level AES-256 encryption for sensitive data", + "fileLevelDatabaseEncryption": "File-level database encryption with hardware binding", + "hardwareBoundFileKeys": "Hardware-bound file encryption keys", + "automaticEncryptedBackups": "Automatic encrypted backup creation", + "createEncryptedBackup": "Create Encrypted Backup", + "creatingBackup": "Creating Backup...", + "backupCreated": "Backup Created", + "encryptedBackupCreatedSuccessfully": "Encrypted backup created successfully", + "backupCreationFailed": "Backup creation failed", + "databaseMigration": "Database Migration", + "exportForMigration": "Export for Migration", + "exportDatabaseForHardwareMigration": "Export database as SQLite file with decrypted data for migration to new hardware", + "exportDatabase": "Export SQLite Database", + "exporting": "Exporting...", + "exportCreated": "SQLite Export Created", + "exportContainsDecryptedData": "SQLite export contains decrypted data - keep secure!", + "databaseExportedSuccessfully": "SQLite database exported successfully", + "databaseExportFailed": "SQLite database export failed", + "importFromMigration": "Import from Migration", + "importDatabaseFromAnotherSystem": "Import SQLite database from another system or hardware", + "importDatabase": "Import SQLite Database", + "importing": "Importing...", + "selectedFile": "Selected SQLite File", + "importWillReplaceExistingData": "SQLite import will replace existing data - backup recommended!", + "pleaseSelectImportFile": "Please select a SQLite import file", + "databaseImportedSuccessfully": "SQLite database imported successfully", + "databaseImportFailed": "SQLite database import failed", + "manageEncryptionAndBackups": "Manage encryption keys, database security, and backup operations", + "activeSecurityFeatures": "Currently active security measures and protections", + "deviceBindingTechnology": "Advanced hardware-based key protection technology", + "backupAndRecovery": "Secure backup creation and database recovery options", + "crossSystemDataTransfer": "Export and import databases across different systems", + "noMigrationNeeded": "No migration needed", + "encryptionKey": "Encryption Key", + "keyProtection": "Key Protection", + "active": "Active", + "legacy": "Legacy", + "dataStatus": "Data Status", + "encrypted": "Encrypted", + "needsMigration": "Needs Migration", + "ready": "Ready", + "initializeEncryption": "Initialize Encryption", + "initialize": "Initialize", + "test": "Test", + "migrate": "Migrate", + "backup": "Backup", + "createBackup": "Create Backup", + "exportImport": "Export/Import", + "export": "Export", + "import": "Import", + "passwordRequired": "Password required", + "confirmExport": "Confirm Export", + "exportDescription": "Export SSH hosts and credentials as SQLite file", + "importDescription": "Import SQLite file with incremental merge (skips duplicates)" }, "hosts": { "title": "Host Manager", @@ -398,6 +590,7 @@ "mustSelectValidSshConfig": "Must select a valid SSH configuration from the list", "addHost": "Add Host", "editHost": "Edit Host", + "cloneHost": "Clone Host", "updateHost": "Update Host", "hostUpdatedSuccessfully": "Host \"{{name}}\" updated successfully!", "hostAddedSuccessfully": "Host \"{{name}}\" added successfully!", @@ -429,6 +622,8 @@ "sshpassRequired": "Sshpass Required For Password Authentication", "sshpassRequiredDesc": "For password authentication in tunnels, sshpass must be installed on the system.", "otherInstallMethods": "Other installation methods:", + "debianUbuntuEquivalent": "(Debian/Ubuntu) or the equivalent for your OS.", + "or": "or", "centosRhelFedora": "CentOS/RHEL/Fedora", "macos": "macOS", "windows": "Windows", @@ -510,7 +705,10 @@ "reconnecting": "Reconnecting... ({{attempt}}/{{max}})", "reconnected": "Reconnected successfully", "maxReconnectAttemptsReached": "Maximum reconnection attempts reached", - "connectionTimeout": "Connection timeout" + "connectionTimeout": "Connection timeout", + "terminalTitle": "Terminal - {{host}}", + "terminalWithPath": "Terminal - {{host}}:{{path}}", + "runTitle": "Running {{command}} - {{host}}" }, "fileManager": { "title": "File Manager", @@ -518,6 +716,14 @@ "folder": "Folder", "connectToSsh": "Connect to SSH to use file operations", "uploadFile": "Upload File", + "downloadFile": "Download", + "edit": "Edit", + "preview": "Preview", + "previous": "Previous", + "next": "Next", + "pageXOfY": "Page {{current}} of {{total}}", + "zoomOut": "Zoom Out", + "zoomIn": "Zoom In", "newFile": "New File", "newFolder": "New Folder", "rename": "Rename", @@ -525,12 +731,15 @@ "deleteItem": "Delete Item", "currentPath": "Current Path", "uploadFileTitle": "Upload File", - "maxFileSize": "Max: 100MB (JSON) / 200MB (Binary)", + "maxFileSize": "Max: 1GB (JSON) / 5GB (Binary) - Large files supported", "removeFile": "Remove File", "clickToSelectFile": "Click to select a file", "chooseFile": "Choose File", "uploading": "Uploading...", + "downloading": "Downloading...", "uploadingFile": "Uploading {{name}}...", + "uploadingLargeFile": "Uploading large file {{name}} ({{size}})...", + "downloadingFile": "Downloading {{name}}...", "creatingFile": "Creating {{name}}...", "creatingFolder": "Creating {{name}}...", "deletingItem": "Deleting {{type}} {{name}}...", @@ -552,11 +761,46 @@ "renaming": "Renaming...", "fileUploadedSuccessfully": "File \"{{name}}\" uploaded successfully", "failedToUploadFile": "Failed to upload file", + "fileDownloadedSuccessfully": "File \"{{name}}\" downloaded successfully", + "failedToDownloadFile": "Failed to download file", + "noFileContent": "No file content received", + "filePath": "File Path", "fileCreatedSuccessfully": "File \"{{name}}\" created successfully", "failedToCreateFile": "Failed to create file", "folderCreatedSuccessfully": "Folder \"{{name}}\" created successfully", "failedToCreateFolder": "Failed to create folder", + "failedToCreateItem": "Failed to create item", + "operationFailed": "{{operation}} operation failed for {{name}}: {{error}}", + "failedToResolveSymlink": "Failed to resolve symlink", "itemDeletedSuccessfully": "{{type}} deleted successfully", + "itemsDeletedSuccessfully": "{{count}} items deleted successfully", + "failedToDeleteItems": "Failed to delete items", + "dragFilesToUpload": "Drop files here to upload", + "emptyFolder": "This folder is empty", + "itemCount": "{{count}} items", + "selectedCount": "{{count}} selected", + "searchFiles": "Search files...", + "upload": "Upload", + "selectHostToStart": "Select a host to start file management", + "failedToConnect": "Failed to connect to SSH", + "failedToLoadDirectory": "Failed to load directory", + "noSSHConnection": "No SSH connection available", + "enterFolderName": "Enter folder name:", + "enterFileName": "Enter file name:", + "copy": "Copy", + "cut": "Cut", + "paste": "Paste", + "delete": "Delete", + "properties": "Properties", + "preview": "Preview", + "refresh": "Refresh", + "downloadFiles": "Download {{count}} files to Browser", + "copyFiles": "Copy {{count}} items", + "cutFiles": "Cut {{count}} items", + "deleteFiles": "Delete {{count}} items", + "filesCopiedToClipboard": "{{count}} items copied to clipboard", + "filesCutToClipboard": "{{count}} items cut to clipboard", + "movedItems": "Moved {{count}} items", "failedToDeleteItem": "Failed to delete item", "itemRenamedSuccessfully": "{{type}} renamed successfully", "failedToRenameItem": "Failed to rename item", @@ -583,7 +827,7 @@ "serverError": "Server Error", "error": "Error", "requestFailed": "Request failed with status code", - "unknown": "unknown", + "unknownFileError": "unknown", "cannotReadFile": "Cannot read file", "noSshSessionId": "No SSH session ID available", "noFilePath": "No file path available", @@ -617,7 +861,124 @@ "sshStatusCheckTimeout": "SSH status check timed out", "sshReconnectionTimeout": "SSH reconnection timed out", "saveOperationTimeout": "Save operation timed out", - "cannotSaveFile": "Cannot save file" + "cannotSaveFile": "Cannot save file", + "dragSystemFilesToUpload": "Drag system files here to upload", + "dragFilesToWindowToDownload": "Drag files outside window to download", + "openTerminalHere": "Open Terminal Here", + "run": "Run", + "saveToSystem": "Save as...", + "selectLocationToSave": "Select Location to Save", + "openTerminalInFolder": "Open Terminal in This Folder", + "openTerminalInFileLocation": "Open Terminal at File Location", + "terminalWithPath": "Terminal - {{host}}:{{path}}", + "runningFile": "Running - {{file}}", + "onlyRunExecutableFiles": "Can only run executable files", + "noHostSelected": "No host selected", + "starred": "Starred", + "shortcuts": "Shortcuts", + "directories": "Directories", + "removedFromRecentFiles": "Removed \"{{name}}\" from recent files", + "removeFailed": "Remove failed", + "unpinnedSuccessfully": "Unpinned \"{{name}}\" successfully", + "unpinFailed": "Unpin failed", + "removedShortcut": "Removed shortcut \"{{name}}\"", + "removeShortcutFailed": "Remove shortcut failed", + "clearedAllRecentFiles": "Cleared all recent files", + "clearFailed": "Clear failed", + "removeFromRecentFiles": "Remove from recent files", + "clearAllRecentFiles": "Clear all recent files", + "unpinFile": "Unpin file", + "removeShortcut": "Remove shortcut", + "saveFilesToSystem": "Save {{count}} files as...", + "saveToSystem": "Save as...", + "pinFile": "Pin file", + "addToShortcuts": "Add to shortcuts", + "selectLocationToSave": "Select location to save", + "downloadToDefaultLocation": "Download to default location", + "pasteFailed": "Paste failed", + "noUndoableActions": "No undoable actions", + "undoCopySuccess": "Undid copy operation: Deleted {{count}} copied files", + "undoCopyFailedDelete": "Undo failed: Could not delete any copied files", + "undoCopyFailedNoInfo": "Undo failed: Could not find copied file information", + "undoMoveSuccess": "Undid move operation: Moved {{count}} files back to original location", + "undoMoveFailedMove": "Undo failed: Could not move any files back", + "undoMoveFailedNoInfo": "Undo failed: Could not find moved file information", + "undoDeleteNotSupported": "Delete operation cannot be undone: Files have been permanently deleted from server", + "undoTypeNotSupported": "Unsupported undo operation type", + "undoOperationFailed": "Undo operation failed", + "unknownError": "Unknown error", + "enterPath": "Enter path...", + "editPath": "Edit path", + "confirm": "Confirm", + "cancel": "Cancel", + "folderName": "Folder name", + "find": "Find...", + "replaceWith": "Replace with...", + "replace": "Replace", + "replaceAll": "Replace All", + "downloadInstead": "Download Instead", + "keyboardShortcuts": "Keyboard Shortcuts", + "searchAndReplace": "Search & Replace", + "editing": "Editing", + "navigation": "Navigation", + "code": "Code", + "search": "Search", + "findNext": "Find Next", + "findPrevious": "Find Previous", + "save": "Save", + "selectAll": "Select All", + "undo": "Undo", + "redo": "Redo", + "goToLine": "Go to Line", + "moveLineUp": "Move Line Up", + "moveLineDown": "Move Line Down", + "toggleComment": "Toggle Comment", + "indent": "Indent", + "outdent": "Outdent", + "autoComplete": "Auto Complete", + "imageLoadError": "Failed to load image", + "zoomIn": "Zoom In", + "zoomOut": "Zoom Out", + "rotate": "Rotate", + "originalSize": "Original Size", + "startTyping": "Start typing...", + "unknownSize": "Unknown size", + "fileIsEmpty": "File is empty", + "modified": "Modified", + "largeFileWarning": "Large File Warning", + "largeFileWarningDesc": "This file is {{size}} in size, which may cause performance issues when opened as text.", + "fileNotFoundAndRemoved": "File \"{{name}}\" not found and has been removed from recent/pinned files", + "failedToLoadFile": "Failed to load file: {{error}}", + "serverErrorOccurred": "Server error occurred. Please try again later.", + "fileSavedSuccessfully": "File saved successfully", + "autoSaveFailed": "Auto-save failed", + "fileAutoSaved": "File auto-saved", + "fileDownloadedSuccessfully": "File downloaded successfully", + "moveFileFailed": "Failed to move {{name}}", + "moveOperationFailed": "Move operation failed", + "canOnlyCompareFiles": "Can only compare two files", + "comparingFiles": "Comparing files: {{file1}} and {{file2}}", + "dragFailed": "Drag operation failed", + "filePinnedSuccessfully": "File \"{{name}}\" pinned successfully", + "pinFileFailed": "Failed to pin file", + "fileUnpinnedSuccessfully": "File \"{{name}}\" unpinned successfully", + "unpinFileFailed": "Failed to unpin file", + "shortcutAddedSuccessfully": "Folder shortcut \"{{name}}\" added successfully", + "addShortcutFailed": "Failed to add shortcut", + "operationCompletedSuccessfully": "{{operation}} {{count}} items successfully", + "operationCompleted": "{{operation}} {{count}} items", + "downloadFileSuccess": "File {{name}} downloaded successfully", + "downloadFileFailed": "Download failed", + "moveTo": "Move to {{name}}", + "diffCompareWith": "Diff compare with {{name}}", + "dragOutsideToDownload": "Drag outside window to download ({{count}} files)", + "newFolderDefault": "NewFolder", + "newFileDefault": "NewFile.txt", + "successfullyMovedItems": "Successfully moved {{count}} items to {{target}}", + "move": "Move", + "searchInFile": "Search in file (Ctrl+F)", + "showKeyboardShortcuts": "Show keyboard shortcuts", + "startWritingMarkdown": "Start writing your markdown content..." }, "tunnels": { "title": "SSH Tunnels", @@ -627,6 +988,7 @@ "disconnected": "Disconnected", "connecting": "Connecting...", "disconnecting": "Disconnecting...", + "unknownTunnelStatus": "Unknown", "unknown": "Unknown", "error": "Error", "failed": "Failed", @@ -664,7 +1026,7 @@ "dynamic": "Dynamic", "noSshTunnels": "No SSH Tunnels", "createFirstTunnelMessage": "Create your first SSH tunnel to get started. Use the SSH Manager to add hosts with tunnel connections.", - "unknown": "Unknown", + "unknownConnectionStatus": "Unknown", "connected": "Connected", "connecting": "Connecting...", "disconnecting": "Disconnecting...", @@ -673,7 +1035,10 @@ "disconnect": "Disconnect", "connect": "Connect", "canceling": "Canceling...", - "endpointHostNotFound": "Endpoint host not found" + "endpointHostNotFound": "Endpoint host not found", + "discord": "Discord", + "githubIssue": "GitHub issue", + "forHelp": "for help" }, "serverStats": { "title": "Server Statistics", @@ -782,7 +1147,7 @@ "enableTwoFactorButton": "Enable Two-Factor Authentication", "addExtraSecurityLayer": "Add an extra layer of security to your account", "firstUser": "First User", - "firstUserMessage": "You are the first user and will be made an admin. You can view admin settings in the sidebar user dropdown. If you think this is a mistake, check the docker logs, or create a", + "firstUserMessage": "You are the first user and will be made an admin. You can view admin settings in the sidebar user dropdown. If you think this is a mistake, check the docker logs, or create a GitHub issue.", "external": "External", "loginWithExternal": "Login with External Provider", "loginWithExternalDesc": "Login using your configured external identity provider", @@ -807,8 +1172,9 @@ "forbidden": "Access forbidden", "serverError": "Server error", "networkError": "Network error", - "databaseConnection": "Could not connect to the database. Please try again later.", + "databaseConnection": "Could not connect to the database.", "unknownError": "Unknown error", + "loginFailed": "Login failed", "failedPasswordReset": "Failed to initiate password reset", "failedVerifyCode": "Failed to verify reset code", "failedCompleteReset": "Failed to complete password reset", @@ -828,7 +1194,8 @@ "usernameExists": "Username already exists", "emailExists": "Email already exists", "loadFailed": "Failed to load data", - "saveError": "Failed to save" + "saveError": "Failed to save", + "sessionExpired": "Session expired - please log in again" }, "messages": { "saveSuccess": "Saved successfully", @@ -845,7 +1212,15 @@ "reconnecting": "Reconnecting...", "processing": "Processing...", "pleaseWait": "Please wait...", - "registrationDisabled": "New account registration is currently disabled by an admin. Please log in or contact an administrator." + "registrationDisabled": "New account registration is currently disabled by an admin. Please log in or contact an administrator.", + "databaseConnected": "Database connected successfully", + "databaseConnectionFailed": "Failed to connect to the database server", + "checkServerConnection": "Please check your server connection and try again", + "resetCodeSent": "Reset code sent to Docker logs", + "codeVerified": "Code verified successfully", + "passwordResetSuccess": "Password reset successfully", + "loginSuccess": "Login successful", + "registrationSuccess": "Registration successful" }, "profile": { "title": "User Profile", @@ -878,6 +1253,7 @@ "password": "password", "keyPassword": "key password", "pastePrivateKey": "Paste your private key here...", + "pastePublicKey": "Paste your public key here...", "credentialName": "My SSH Server", "description": "SSH credential description", "searchCredentials": "Search credentials by name, username, or tags...", @@ -1007,6 +1383,9 @@ "updateKey": "Update Key", "productionFolder": "Production", "databaseServer": "Database Server", + "developmentServer": "Development Server", + "developmentFolder": "Development", + "webServerProduction": "Web Server - Production", "unknownError": "Unknown error", "failedToInitiatePasswordReset": "Failed to initiate password reset", "failedToVerifyResetCode": "Failed to verify reset code", @@ -1030,6 +1409,10 @@ }, "mobile": { "selectHostToStart": "Select a host to start your terminal session", - "limitedSupportMessage": "Mobile support is currently limited. A dedicated mobile app is coming soon to enhance your experience." + "limitedSupportMessage": "Website mobile support is still in progress. Use the mobile app for a better experience.", + "mobileAppInProgress": "Mobile app is in progress", + "mobileAppInProgressDesc": "We're working on a dedicated mobile app to provide a better experience on mobile devices.", + "viewMobileAppDocs": "Install Mobile App", + "mobileAppDocumentation": "Mobile App Documentation" } } diff --git a/src/locales/zh/translation.json b/src/locales/zh/translation.json index 370d906f..5b7ba6b1 100644 --- a/src/locales/zh/translation.json +++ b/src/locales/zh/translation.json @@ -87,7 +87,20 @@ "keyPassphraseOptional": "可选:如果您的密钥没有密码,请留空", "leaveEmptyToKeepCurrent": "留空以保持当前值", "uploadKeyFile": "上传密钥文件", + "generateKeyPairButton": "生成密钥对", "generateKeyPair": "生成密钥对", + "generateKeyPairDescription": "生成新的SSH密钥对。如果您想用密码保护密钥,请先在下面的密钥密码字段中输入密码。", + "deploySSHKey": "部署SSH密钥", + "deploySSHKeyDescription": "将公钥部署到目标服务器", + "sourceCredential": "源凭据", + "targetHost": "目标主机", + "deploymentProcess": "部署过程", + "deploymentProcessDescription": "这将安全地将公钥添加到目标主机的~/.ssh/authorized_keys文件中,而不会覆盖现有密钥。此操作是可逆的。", + "chooseHostToDeploy": "选择要部署到的主机...", + "deploying": "部署中...", + "name": "名称", + "noHostsAvailable": "没有可用的主机", + "noHostsMatchSearch": "没有匹配搜索的主机", "sshKeyGenerationNotImplemented": "SSH密钥生成功能即将推出", "connectionTestingNotImplemented": "连接测试功能即将推出", "testConnection": "测试连接", @@ -122,14 +135,46 @@ "editCredentialDescription": "更新凭据信息", "listView": "列表", "folderView": "文件夹", - "unknown": "未知", + "unknownCredential": "未知", "confirmRemoveFromFolder": "确定要将\"{{name}}\"从文件夹\"{{folder}}\"中移除吗?凭据将被移动到\"未分类\"。", "removedFromFolder": "凭据\"{{name}}\"已成功从文件夹中移除", "failedToRemoveFromFolder": "从文件夹中移除凭据失败", "folderRenamed": "文件夹\"{{oldName}}\"已成功重命名为\"{{newName}}\"", "failedToRenameFolder": "重命名文件夹失败", "movedToFolder": "凭据\"{{name}}\"已成功移动到\"{{folder}}\"", - "failedToMoveToFolder": "移动凭据到文件夹失败" + "failedToMoveToFolder": "移动凭据到文件夹失败", + "sshPublicKey": "SSH公钥", + "publicKeyNote": "公钥是可选的,但建议提供以验证密钥对", + "publicKeyUploaded": "公钥已上传", + "uploadPublicKey": "上传公钥", + "uploadPrivateKeyFile": "上传私钥文件", + "uploadPublicKeyFile": "上传公钥文件", + "privateKeyRequiredForGeneration": "生成公钥需要先输入私钥", + "failedToGeneratePublicKey": "生成公钥失败", + "generatePublicKey": "从私钥生成", + "publicKeyGeneratedSuccessfully": "公钥生成成功", + "detectedKeyType": "检测到的密钥类型", + "detectingKeyType": "检测中...", + "optional": "可选", + "generateKeyPairNew": "生成新的密钥对", + "generateEd25519": "生成 Ed25519", + "generateECDSA": "生成 ECDSA", + "generateRSA": "生成 RSA", + "keyPairGeneratedSuccessfully": "{{keyType}} 密钥对生成成功", + "failedToGenerateKeyPair": "生成密钥对失败", + "generateKeyPairNote": "直接生成新的SSH密钥对。这将替换表单中的现有密钥。", + "invalidKey": "无效密钥", + "detectionError": "检测错误" + }, + "dragIndicator": { + "error": "错误:{{error}}", + "dragging": "正在拖拽 {{fileName}}", + "preparing": "正在准备 {{fileName}}", + "readySingle": "准备下载 {{fileName}}", + "readyMultiple": "准备下载 {{count}} 个文件", + "batchDrag": "拖拽 {{count}} 个文件到桌面", + "dragToDesktop": "拖拽到桌面", + "canDragAnywhere": "您可以将文件拖拽到桌面的任何位置" }, "sshTools": { "title": "SSH 工具", @@ -166,12 +211,32 @@ "saveError": "保存配置时出错", "saving": "保存中...", "saveConfig": "保存配置", - "helpText": "输入您的 Termix 服务器运行地址(例如:http://localhost:8081 或 https://your-server.com)" + "helpText": "输入您的 Termix 服务器运行地址(例如:http://localhost:30001 或 https://your-server.com)" + }, + "versionCheck": { + "error": "版本检查错误", + "checkFailed": "检查更新失败", + "upToDate": "应用已是最新版本", + "currentVersion": "您正在运行版本 {{version}}", + "updateAvailable": "有可用更新", + "newVersionAvailable": "有新版本可用!您正在运行 {{current}},但 {{latest}} 已可用。", + "releasedOn": "发布于 {{date}}", + "downloadUpdate": "下载更新", + "dismiss": "忽略", + "checking": "正在检查更新...", + "checkUpdates": "检查更新", + "checkingUpdates": "正在检查更新...", + "refresh": "刷新", + "updateRequired": "需要更新", + "updateDismissed": "更新通知已忽略", + "noUpdatesFound": "未找到更新" }, "common": { "close": "关闭", + "minimize": "最小化", "online": "在线", "offline": "离线", + "continue": "继续", "maintenance": "维护中", "degraded": "降级", "discord": "Discord", @@ -199,6 +264,7 @@ "newVersionAvailable": "有新版本 ({{version}}) 可用。", "failedToFetchUpdateInfo": "获取更新信息失败", "preRelease": "预发布版本", + "loginFailed": "登录失败", "noReleasesFound": "未找到发布版本。", "yourBackupCodes": "您的备份代码", "sendResetCode": "发送重置代码", @@ -214,6 +280,9 @@ "sshTools": "SSH 工具", "english": "英语", "chinese": "中文", + "cancel": "取消", + "username": "用户名", + "name": "名称", "login": "登录", "logout": "登出", "register": "注册", @@ -257,7 +326,10 @@ "failedToInitiatePasswordReset": "启动密码重置失败", "failedToVerifyResetCode": "验证重置代码失败", "failedToCompletePasswordReset": "完成密码重置失败", - "documentation": "文档" + "documentation": "文档", + "retry": "重试", + "checking": "检查中...", + "checkingDatabase": "正在检查数据库连接..." }, "nav": { "home": "首页", @@ -339,7 +411,125 @@ "failedToRemoveAdminStatus": "移除管理员权限失败", "userDeletedSuccessfully": "用户 {{username}} 删除成功", "failedToDeleteUser": "删除用户失败", - "overrideUserInfoUrl": "覆盖用户信息 URL(非必填)" + "overrideUserInfoUrl": "覆盖用户信息 URL(非必填)", + "databaseSecurity": "数据库安全", + "encryptionStatus": "加密状态", + "encryptionEnabled": "加密已启用", + "enabled": "已启用", + "disabled": "已禁用", + "keyId": "密钥 ID", + "created": "创建时间", + "migrationStatus": "迁移状态", + "migrationCompleted": "迁移完成", + "migrationRequired": "需要迁移", + "deviceProtectedMasterKey": "环境保护主密钥", + "legacyKeyStorage": "传统密钥存储", + "masterKeyEncryptedWithDeviceFingerprint": "主密钥已通过环境指纹加密(KEK 保护已激活)", + "keyNotProtectedByDeviceBinding": "密钥未受环境绑定保护(建议升级)", + "valid": "有效", + "initializeDatabaseEncryption": "初始化数据库加密", + "enableAes256EncryptionWithDeviceBinding": "启用具有环境绑定主密钥保护的 AES-256 加密。这为 SSH 密钥、密码和身份验证令牌创建企业级安全保护。", + "featuresEnabled": "启用的功能:", + "aes256GcmAuthenticatedEncryption": "AES-256-GCM 认证加密", + "deviceFingerprintMasterKeyProtection": "环境指纹主密钥保护 (KEK)", + "pbkdf2KeyDerivation": "PBKDF2 密钥推导(10万次迭代)", + "automaticKeyManagement": "自动密钥管理和轮换", + "initializing": "初始化中...", + "initializeEnterpriseEncryption": "初始化企业级加密", + "migrateExistingData": "迁移现有数据", + "encryptExistingUnprotectedData": "加密数据库中现有的未保护数据。此过程安全可靠,会自动创建备份。", + "testMigrationDryRun": "验证加密兼容性", + "migrating": "迁移中...", + "migrateData": "迁移数据", + "securityInformation": "安全信息", + "sshPrivateKeysEncryptedWithAes256": "SSH 私钥和密码使用 AES-256-GCM 加密", + "userAuthTokensProtected": "用户认证令牌和 2FA 密钥受到保护", + "masterKeysProtectedByDeviceFingerprint": "主加密密钥受设备指纹保护 (KEK)", + "keysBoundToServerInstance": "密钥绑定到当前服务器环境(可通过环境变量迁移)", + "pbkdf2HkdfKeyDerivation": "PBKDF2 + HKDF 密钥推导(10万次迭代)", + "backwardCompatibleMigration": "迁移过程中所有数据保持向后兼容", + "enterpriseGradeSecurityActive": "企业级安全已激活", + "masterKeysProtectedByDeviceBinding": "您的主加密密钥受环境指纹保护。这基于服务器的主机名、路径等环境信息生成保护密钥。如需迁移服务器,可通过设置 DB_ENCRYPTION_KEY 环境变量来实现数据迁移。", + "important": "重要提示", + "keepEncryptionKeysSecure": "确保数据安全:定期备份数据库文件和服务器配置。如需迁移到新服务器,请在新环境中设置 DB_ENCRYPTION_KEY 环境变量,或保持相同的主机名和目录结构。", + "loadingEncryptionStatus": "正在加载加密状态...", + "testMigrationDescription": "验证现有数据是否可以安全地迁移到加密格式,不会实际修改任何数据", + "serverMigrationGuide": "服务器迁移指南", + "migrationInstructions": "要将加密数据迁移到新服务器:1) 备份数据库文件,2) 在新服务器设置环境变量 DB_ENCRYPTION_KEY=\"你的密钥\",3) 恢复数据库文件", + "environmentProtection": "环境保护", + "environmentProtectionDesc": "基于服务器环境信息(主机名、路径等)保护加密密钥,可通过环境变量实现迁移", + "verificationCompleted": "兼容性验证完成 - 未修改任何数据", + "verificationInProgress": "验证完成", + "dataMigrationCompleted": "数据迁移完成!", + "verificationFailed": "兼容性验证失败", + "migrationFailed": "迁移失败", + "runningVerification": "正在进行兼容性验证...", + "startingMigration": "开始迁移...", + "hardwareFingerprintSecurity": "硬件指纹安全", + "hardwareBoundEncryption": "硬件绑定加密已激活", + "masterKeysNowProtectedByHardwareFingerprint": "主密钥现在受真实硬件指纹保护,而非环境变量", + "cpuSerialNumberDetection": "CPU 序列号检测", + "motherboardUuidIdentification": "主板 UUID 识别", + "diskSerialNumberVerification": "磁盘序列号验证", + "biosSerialNumberCheck": "BIOS 序列号检查", + "stableMacAddressFiltering": "稳定 MAC 地址过滤", + "databaseFileEncryption": "数据库文件加密", + "dualLayerProtection": "双层保护已激活", + "bothFieldAndFileEncryptionActive": "字段级和文件级加密现均已激活,提供最大安全保护", + "fieldLevelAes256Encryption": "敏感数据的字段级 AES-256 加密", + "fileLevelDatabaseEncryption": "硬件绑定的文件级数据库加密", + "hardwareBoundFileKeys": "硬件绑定的文件加密密钥", + "automaticEncryptedBackups": "自动加密备份创建", + "createEncryptedBackup": "创建加密备份", + "creatingBackup": "创建备份中...", + "backupCreated": "备份已创建", + "encryptedBackupCreatedSuccessfully": "加密备份创建成功", + "backupCreationFailed": "备份创建失败", + "databaseMigration": "数据库迁移", + "exportForMigration": "导出用于迁移", + "exportDatabaseForHardwareMigration": "导出 SQLite 格式的解密数据库以迁移到新硬件", + "exportDatabase": "导出 SQLite 数据库", + "exporting": "导出中...", + "exportCreated": "SQLite 导出已创建", + "exportContainsDecryptedData": "SQLite 导出包含解密数据 - 请保持安全!", + "databaseExportedSuccessfully": "SQLite 数据库导出成功", + "databaseExportFailed": "SQLite 数据库导出失败", + "importFromMigration": "从迁移导入", + "importDatabaseFromAnotherSystem": "从其他系统或硬件导入 SQLite 数据库", + "importDatabase": "导入 SQLite 数据库", + "importing": "导入中...", + "selectedFile": "选定 SQLite 文件", + "importWillReplaceExistingData": "SQLite 导入将替换现有数据 - 建议备份!", + "pleaseSelectImportFile": "请选择 SQLite 导入文件", + "databaseImportedSuccessfully": "SQLite 数据库导入成功", + "databaseImportFailed": "SQLite 数据库导入失败", + "manageEncryptionAndBackups": "管理加密密钥、数据库安全和备份操作", + "activeSecurityFeatures": "当前活跃的安全措施和保护功能", + "deviceBindingTechnology": "高级硬件密钥保护技术", + "backupAndRecovery": "安全备份创建和数据库恢复选项", + "crossSystemDataTransfer": "跨系统数据库导出和导入", + "noMigrationNeeded": "无需迁移", + "encryptionKey": "加密密钥", + "keyProtection": "密钥保护", + "active": "已激活", + "legacy": "旧版", + "dataStatus": "数据状态", + "encrypted": "已加密", + "needsMigration": "需要迁移", + "ready": "就绪", + "initializeEncryption": "初始化加密", + "initialize": "初始化", + "test": "测试", + "migrate": "迁移", + "backup": "备份", + "createBackup": "创建备份", + "exportImport": "导出/导入", + "export": "导出", + "import": "导入", + "passwordRequired": "密码为必填项", + "confirmExport": "确认导出", + "exportDescription": "将SSH主机和凭据导出为SQLite文件", + "importDescription": "导入SQLite文件并进行增量合并(跳过重复项)" }, "hosts": { "title": "主机管理", @@ -384,6 +574,7 @@ "mustSelectValidSshConfig": "必须从列表中选择有效的 SSH 配置", "addHost": "添加主机", "editHost": "编辑主机", + "cloneHost": "克隆主机", "deleteHost": "删除主机", "authType": "认证类型", "passwordAuth": "密码", @@ -451,11 +642,21 @@ "maxRetriesDescription": "隧道连接的最大重试次数。", "retryIntervalDescription": "重试尝试之间的等待时间。", "otherInstallMethods": "其他安装方法:", + "debianUbuntuEquivalent": "(Debian/Ubuntu) 或您的操作系统的等效命令。", + "or": "或", + "centosRhelFedora": "CentOS/RHEL/Fedora", + "macos": "macOS", + "windows": "Windows", "sshpassOSInstructions": { "centos": "CentOS/RHEL/Fedora: sudo yum install sshpass 或 sudo dnf install sshpass", "macos": "macOS: brew install hudochenkov/sshpass/sshpass", "windows": "Windows: 使用 WSL 或考虑使用 SSH 密钥认证" }, + "sshServerConfigRequired": "SSH 服务器配置要求", + "sshServerConfigDesc": "对于隧道连接,SSH 服务器必须配置允许端口转发:", + "gatewayPortsYes": "绑定远程端口到所有接口", + "allowTcpForwardingYes": "启用端口转发", + "permitRootLoginYes": "如果使用 root 用户进行隧道连接", "sshServerConfigReverse": "对于反向 SSH 隧道,端点 SSH 服务器必须允许:", "gatewayPorts": "GatewayPorts yes(绑定远程端口)", "allowTcpForwarding": "AllowTcpForwarding yes(端口转发)", @@ -498,6 +699,9 @@ }, "terminal": { "title": "终端", + "terminalTitle": "终端 - {{host}}", + "terminalWithPath": "终端 - {{host}}:{{path}}", + "runTitle": "运行 {{command}} - {{host}}", "connect": "连接主机", "disconnect": "断开连接", "clear": "清屏", @@ -533,6 +737,14 @@ "folder": "文件夹", "connectToSsh": "连接 SSH 以使用文件操作", "uploadFile": "上传文件", + "downloadFile": "下载", + "edit": "编辑", + "preview": "预览", + "previous": "上一页", + "next": "下一页", + "pageXOfY": "第 {{current}} 页,共 {{total}} 页", + "zoomOut": "缩小", + "zoomIn": "放大", "newFile": "新建文件", "newFolder": "新建文件夹", "rename": "重命名", @@ -540,12 +752,15 @@ "deleteItem": "删除项目", "currentPath": "当前路径", "uploadFileTitle": "上传文件", - "maxFileSize": "最大:100MB(JSON)/ 200MB(二进制)", + "maxFileSize": "最大:1GB(JSON)/ 5GB(二进制)- 支持大文件", "removeFile": "移除文件", "clickToSelectFile": "点击选择文件", "chooseFile": "选择文件", "uploading": "上传中...", + "downloading": "下载中...", "uploadingFile": "正在上传 {{name}}...", + "uploadingLargeFile": "正在上传大文件 {{name}} ({{size}})...", + "downloadingFile": "正在下载 {{name}}...", "creatingFile": "正在创建 {{name}}...", "creatingFolder": "正在创建 {{name}}...", "deletingItem": "正在删除 {{type}} {{name}}...", @@ -567,21 +782,52 @@ "renaming": "重命名中...", "fileUploadedSuccessfully": "文件 \"{{name}}\" 上传成功", "failedToUploadFile": "上传文件失败", + "failedToDownloadFile": "下载文件失败", + "noFileContent": "未收到文件内容", + "filePath": "文件路径", "fileCreatedSuccessfully": "文件 \"{{name}}\" 创建成功", "failedToCreateFile": "创建文件失败", "folderCreatedSuccessfully": "文件夹 \"{{name}}\" 创建成功", "failedToCreateFolder": "创建文件夹失败", + "failedToCreateItem": "创建项目失败", + "operationFailed": "{{operation}} 操作失败,文件 {{name}}:{{error}}", + "failedToResolveSymlink": "解析符号链接失败", "itemDeletedSuccessfully": "{{type}}删除成功", + "itemsDeletedSuccessfully": "{{count}} 个项目删除成功", + "failedToDeleteItems": "删除项目失败", + "dragFilesToUpload": "拖拽文件到这里上传", + "emptyFolder": "此文件夹为空", + "itemCount": "{{count}} 个项目", + "selectedCount": "已选择 {{count}} 个", + "searchFiles": "搜索文件...", + "upload": "上传", + "selectHostToStart": "选择主机开始文件管理", + "failedToConnect": "连接SSH失败", + "failedToLoadDirectory": "加载目录失败", + "noSSHConnection": "无SSH连接可用", + "enterFolderName": "输入文件夹名称:", + "enterFileName": "输入文件名称:", + "cut": "剪切", + "properties": "属性", + "refresh": "刷新", + "downloadFiles": "下载 {{count}} 个文件", + "copyFiles": "复制 {{count}} 个项目", + "cutFiles": "剪切 {{count}} 个项目", + "deleteFiles": "删除 {{count}} 个项目", + "filesCopiedToClipboard": "{{count}} 个项目已复制到剪贴板", + "filesCutToClipboard": "{{count}} 个项目已剪切到剪贴板", + "movedItems": "已移动 {{count}} 个项目", + "unknownSize": "未知大小", + "fileIsEmpty": "文件为空", + "modified": "修改时间", + "largeFileWarning": "大文件警告", + "largeFileWarningDesc": "此文件大小为 {{size}},以文本形式打开可能会导致性能问题。", + "fileNotFoundAndRemoved": "文件 \"{{name}}\" 未找到,已从最近访问/固定文件中移除", + "failedToLoadFile": "加载文件失败:{{error}}", + "serverErrorOccurred": "服务器错误,请稍后重试。", "failedToDeleteItem": "删除项目失败", "itemRenamedSuccessfully": "{{type}}重命名成功", "failedToRenameItem": "重命名项目失败", - "upload": "上传", - "download": "下载", - "delete": "删除", - "permissions": "权限", - "size": "大小", - "modified": "修改时间", - "path": "路径", "confirmDelete": "确定要删除 {{name}} 吗?", "uploadSuccess": "文件上传成功", "uploadFailed": "文件上传失败", @@ -593,12 +839,11 @@ "serverError": "服务器错误", "error": "错误", "requestFailed": "请求失败,状态码", - "unknown": "未知", + "unknownFileError": "未知", "cannotReadFile": "无法读取文件", "noSshSessionId": "没有可用的 SSH 会话 ID", "noFilePath": "没有可用的文件路径", "noCurrentHost": "没有可用的当前主机", - "fileSavedSuccessfully": "文件保存成功", "saveTimeout": "保存操作超时。文件可能已成功保存,但操作用时过长。请检查 Docker 日志以确认。", "failedToSaveFile": "保存文件失败", "deletedSuccessfully": "删除成功", @@ -608,6 +853,18 @@ "confirmDeleteMessage": "确定要删除 {{name}} 吗?", "deleteDirectoryWarning": "这将删除文件夹及其所有内容。", "actionCannotBeUndone": "此操作无法撤销。", + "dragSystemFilesToUpload": "拖拽系统文件到此处上传", + "dragFilesToWindowToDownload": "拖拽文件到窗口外下载", + "openTerminalHere": "在此处打开终端", + "run": "运行", + "saveToSystem": "另存为...", + "selectLocationToSave": "选择位置保存", + "openTerminalInFolder": "在此文件夹打开终端", + "openTerminalInFileLocation": "在文件位置打开终端", + "terminalWithPath": "终端 - {{host}}:{{path}}", + "runningFile": "运行 - {{file}}", + "onlyRunExecutableFiles": "只能运行可执行文件", + "noHostSelected": "没有选择主机", "recent": "最近的", "pinned": "固定的", "folderShortcuts": "文件夹快捷方式", @@ -624,7 +881,95 @@ "sshStatusCheckTimeout": "SSH 状态检查超时", "sshReconnectionTimeout": "SSH 重新连接超时", "saveOperationTimeout": "保存操作超时", - "cannotSaveFile": "无法保存文件" + "cannotSaveFile": "无法保存文件", + "starred": "收藏", + "shortcuts": "快捷方式", + "directories": "目录", + "removedFromRecentFiles": "已从最近访问中移除\"{{name}}\"", + "removeFailed": "移除失败", + "unpinnedSuccessfully": "已取消固定\"{{name}}\"", + "unpinFailed": "取消固定失败", + "removedShortcut": "已移除快捷方式\"{{name}}\"", + "removeShortcutFailed": "移除快捷方式失败", + "clearedAllRecentFiles": "已清除所有最近访问记录", + "clearFailed": "清除失败", + "removeFromRecentFiles": "从最近访问中移除", + "clearAllRecentFiles": "清除所有最近访问", + "unpinFile": "取消固定", + "removeShortcut": "移除快捷方式", + "saveFilesToSystem": "另存 {{count}} 个文件为...", + "pinFile": "固定文件", + "addToShortcuts": "添加到快捷方式", + "downloadToDefaultLocation": "下载到默认位置", + "pasteFailed": "粘贴失败", + "noUndoableActions": "没有可撤销的操作", + "undoCopySuccess": "已撤销复制操作:删除了 {{count}} 个复制的文件", + "undoCopyFailedDelete": "撤销失败:无法删除任何复制的文件", + "undoCopyFailedNoInfo": "撤销失败:找不到复制的文件信息", + "undoMoveSuccess": "已撤销移动操作:移回了 {{count}} 个文件到原位置", + "undoMoveFailedMove": "撤销失败:无法移回任何文件", + "undoMoveFailedNoInfo": "撤销失败:找不到移动的文件信息", + "undoDeleteNotSupported": "删除操作无法撤销:文件已从服务器永久删除", + "undoTypeNotSupported": "不支持撤销此类操作", + "undoOperationFailed": "撤销操作失败", + "unknownError": "未知错误", + "enterPath": "输入路径...", + "editPath": "编辑路径", + "confirm": "确认", + "cancel": "取消", + "find": "查找...", + "replaceWith": "替换为...", + "replace": "替换", + "replaceAll": "全部替换", + "downloadInstead": "下载文件", + "keyboardShortcuts": "键盘快捷键", + "searchAndReplace": "搜索和替换", + "editing": "编辑", + "navigation": "导航", + "code": "代码", + "search": "搜索", + "findNext": "查找下一个", + "findPrevious": "查找上一个", + "save": "保存", + "selectAll": "全选", + "undo": "撤销", + "redo": "重做", + "goToLine": "跳转到行", + "moveLineUp": "向上移动行", + "moveLineDown": "向下移动行", + "toggleComment": "切换注释", + "indent": "增加缩进", + "outdent": "减少缩进", + "autoComplete": "自动补全", + "imageLoadError": "图片加载失败", + "rotate": "旋转", + "originalSize": "原始大小", + "startTyping": "开始输入...", + "moveFileFailed": "移动 {{name}} 失败", + "moveOperationFailed": "移动操作失败", + "canOnlyCompareFiles": "只能对比两个文件", + "comparingFiles": "正在对比文件:{{file1}} 与 {{file2}}", + "dragFailed": "拖拽失败", + "filePinnedSuccessfully": "文件\"{{name}}\"已固定", + "pinFileFailed": "固定文件失败", + "fileUnpinnedSuccessfully": "文件\"{{name}}\"已取消固定", + "unpinFileFailed": "取消固定失败", + "shortcutAddedSuccessfully": "文件夹快捷方式\"{{name}}\"已添加", + "addShortcutFailed": "添加快捷方式失败", + "operationCompletedSuccessfully": "已{{operation}} {{count}} 个项目", + "operationCompleted": "已{{operation}} {{count}} 个项目", + "downloadFileSuccess": "文件 {{name}} 下载成功", + "downloadFileFailed": "下载失败", + "moveTo": "移动到 {{name}}", + "diffCompareWith": "与 {{name}} 对比", + "dragOutsideToDownload": "拖拽到窗口外下载 ({{count}} 个文件)", + "newFolderDefault": "新文件夹", + "newFileDefault": "新文件.txt", + "successfullyMovedItems": "成功移动 {{count}} 个项目到 {{target}}", + "move": "移动", + "searchInFile": "在文件中搜索 (Ctrl+F)", + "showKeyboardShortcuts": "显示键盘快捷键", + "startWritingMarkdown": "开始编写您的 markdown 内容..." }, "tunnels": { "title": "SSH 隧道", @@ -634,6 +979,7 @@ "disconnected": "已断开连接", "connecting": "连接中...", "disconnecting": "断开连接中...", + "unknownTunnelStatus": "未知", "unknown": "未知", "error": "错误", "failed": "失败", @@ -670,7 +1016,10 @@ "remote": "远程", "dynamic": "动态", "portMapping": "端口 {{sourcePort}} → {{endpointHost}}:{{endpointPort}}", - "endpointHostNotFound": "未找到端点主机" + "endpointHostNotFound": "未找到端点主机", + "discord": "Discord", + "githubIssue": "GitHub 问题", + "forHelp": "寻求帮助" }, "serverStats": { "title": "服务器统计", @@ -775,7 +1124,7 @@ "enableTwoFactorButton": "启用双因素认证", "addExtraSecurityLayer": "为您的账户添加额外的安全层", "firstUser": "首位用户", - "firstUserMessage": "您是第一个用户,将被设为管理员。您可以在侧边栏用户下拉菜单中查看管理员设置。如果您认为这是错误,请检查 docker 日志,或创建", + "firstUserMessage": "作为您的第一个用户,您将被设置为管理员。您可以在侧边栏用户下拉菜单中查看管理员设置。如果您认为这是一个错误,请检查 Docker 日志或创建 GitHub 问题", "external": "外部", "loginWithExternal": "使用外部提供商登录", "loginWithExternalDesc": "使用您配置的外部身份提供者登录", @@ -800,8 +1149,9 @@ "forbidden": "访问被禁止", "serverError": "服务器错误", "networkError": "网络错误", - "databaseConnection": "无法连接到数据库。请稍后再试。", + "databaseConnection": "无法连接到数据库。", "unknownError": "未知错误", + "loginFailed": "登录失败", "failedPasswordReset": "无法启动密码重置", "failedVerifyCode": "验证重置代码失败", "failedCompleteReset": "无法完成密码重置", @@ -821,7 +1171,8 @@ "usernameExists": "用户名已存在", "emailExists": "邮箱已存在", "loadFailed": "加载数据失败", - "saveError": "保存失败" + "saveError": "保存失败", + "sessionExpired": "会话已过期 - 请重新登录" }, "messages": { "saveSuccess": "保存成功", @@ -838,7 +1189,15 @@ "reconnecting": "重新连接中...", "processing": "处理中...", "pleaseWait": "请稍候...", - "registrationDisabled": "新用户注册已被管理员禁用。请登录或联系管理员。" + "registrationDisabled": "新用户注册已被管理员禁用。请登录或联系管理员。", + "databaseConnected": "数据库连接成功", + "databaseConnectionFailed": "无法连接到数据库服务器", + "checkServerConnection": "请检查您的服务器连接并重试", + "resetCodeSent": "重置代码已发送到 Docker 日志", + "codeVerified": "代码验证成功", + "passwordResetSuccess": "密码重置成功", + "loginSuccess": "登录成功", + "registrationSuccess": "注册成功" }, "profile": { "title": "用户资料", @@ -874,6 +1233,7 @@ "searchCredentials": "按名称、用户名或标签搜索凭据...", "keyPassword": "密钥密码", "pastePrivateKey": "在此粘贴您的私钥...", + "pastePublicKey": "在此粘贴您的公钥...", "sshConfig": "端点 SSH 配置", "homePath": "/home", "clientId": "您的客户端 ID", @@ -929,101 +1289,37 @@ "discord": "Discord", "connectToSshForOperations": "连接 SSH 以使用文件操作", "uploadFile": "上传文件", - "newFile": "新建文件", - "newFolder": "新建文件夹", "rename": "重命名", - "deleteItem": "删除项目", - "createNewFile": "创建新文件", - "createNewFolder": "创建新文件夹", - "renameItem": "重命名项目", - "clickToSelectFile": "点击选择文件", "noSshHosts": "没有 SSH 主机", - "sshHosts": "SSH 主机", "importSshHosts": "从 JSON 导入 SSH 主机", - "clientId": "客户端 ID", - "clientSecret": "客户端密钥", "error": "错误", - "warning": "警告", - "deleteAccount": "删除账户", - "closeDeleteAccount": "关闭删除账户", - "cannotDeleteAccount": "无法删除账户", - "confirmPassword": "确认密码", - "deleting": "删除中...", "externalAuth": "外部认证 (OIDC)", - "configureExternalProvider": "配置外部身份提供者", - "waitingForRetry": "等待重试", - "retryingConnection": "重试连接中", "resetSplitSizes": "重置分屏大小", "sshManagerAlreadyOpen": "SSH 管理器已打开", "disabledDuringSplitScreen": "分屏期间禁用", - "unknown": "未知", - "connected": "已连接", - "disconnected": "已断开连接", "maxRetriesExhausted": "已达到最大重试次数", - "endpointHostNotFound": "未找到端点主机", "administrator": "管理员", - "user": "用户", - "external": "外部", - "local": "本地", - "saving": "保存中...", - "saveConfiguration": "保存配置", - "loading": "加载中...", - "refresh": "刷新", - "adding": "添加中...", - "makeAdmin": "设为管理员", "verifying": "验证中...", - "verifyAndEnable": "验证并启用", "secretKey": "密钥", "totpQrCode": "TOTP 二维码", - "passwordRequired": "使用密码认证时需要密码", - "sshKeyRequired": "使用密钥认证时需要 SSH 私钥", - "keyTypeRequired": "使用密钥认证时需要密钥类型", "validSshConfigRequired": "必须从列表中选择有效的 SSH 配置", - "updateHost": "更新主机", - "addHost": "添加主机", - "editHost": "编辑主机", "pinConnection": "固定连接", - "authentication": "认证", - "password": "密码", - "key": "密钥", - "sshPrivateKey": "SSH 私钥", - "keyPassword": "密钥密码", - "keyType": "密钥类型", - "enableTerminal": "启用终端", - "enableTunnel": "启用隧道", - "enableFileManager": "启用文件管理器", - "defaultPath": "默认路径", - "tunnelConnections": "隧道连接", - "maxRetries": "最大重试次数", - "upload": "上传", - "updateKey": "更新密钥", - "sshpassRequired": "密码认证需要 Sshpass", - "sshServerConfigRequired": "需要 SSH 服务器配置", "productionFolder": "生产环境", "databaseServer": "数据库服务器", - "unknownError": "未知错误", - "failedToInitiatePasswordReset": "启动密码重置失败", - "failedToVerifyResetCode": "验证重置代码失败", - "failedToCompletePasswordReset": "完成密码重置失败", - "invalidTotpCode": "无效的 TOTP 代码", + "developmentServer": "开发服务器", + "developmentFolder": "开发环境", + "webServerProduction": "Web 服务器 - 生产环境", "failedToStartOidcLogin": "启动 OIDC 登录失败", "failedToGetUserInfoAfterOidc": "OIDC 登录后获取用户信息失败", "loginWithExternalProvider": "使用外部提供者登录", - "loginWithExternal": "使用外部提供者登录", - "sendResetCode": "发送重置代码", - "verifyCode": "验证代码", - "resetPassword": "重置密码", - "login": "登录", - "signUp": "注册", - "failedToUpdateOidcConfig": "更新 OIDC 配置失败", - "failedToMakeUserAdmin": "设为管理员失败", - "failedToStartTotpSetup": "启动 TOTP 设置失败", - "invalidVerificationCode": "无效的验证码", - "failedToDisableTotp": "禁用 TOTP 失败", - "failedToGenerateBackupCodes": "生成备用码失败" + "failedToStartTotpSetup": "启动 TOTP 设置失败" }, "mobile": { "selectHostToStart": "选择一个主机以开始您的终端会话", - "limitedSupportMessage": "移动端支持目前有限。我们即将推出专门的移动应用以提升您的体验。" + "limitedSupportMessage": "网站移动端支持仍在开发中。使用移动应用以获得更好的体验。", + "mobileAppInProgress": "移动应用开发中", + "mobileAppInProgressDesc": "我们正在开发专门的移动应用,为移动设备提供更好的体验。", + "viewMobileAppDocs": "安装移动应用", + "mobileAppDocumentation": "移动应用文档" } } diff --git a/src/types/electron.d.ts b/src/types/electron.d.ts new file mode 100644 index 00000000..6a544f20 --- /dev/null +++ b/src/types/electron.d.ts @@ -0,0 +1,65 @@ +export interface ElectronAPI { + getAppVersion: () => Promise; + getPlatform: () => Promise; + + getServerConfig: () => Promise; + saveServerConfig: (config: any) => Promise; + testServerConnection: (serverUrl: string) => Promise; + + showSaveDialog: (options: any) => Promise; + showOpenDialog: (options: any) => Promise; + + onUpdateAvailable: (callback: Function) => void; + onUpdateDownloaded: (callback: Function) => void; + + removeAllListeners: (channel: string) => void; + isElectron: boolean; + isDev: boolean; + + invoke: (channel: string, ...args: any[]) => Promise; + + createTempFile: (fileData: { + fileName: string; + content: string; + encoding?: "base64" | "utf8"; + }) => Promise<{ + success: boolean; + tempId?: string; + path?: string; + error?: string; + }>; + + createTempFolder: (folderData: { + folderName: string; + files: Array<{ + relativePath: string; + content: string; + encoding?: "base64" | "utf8"; + }>; + }) => Promise<{ + success: boolean; + tempId?: string; + path?: string; + error?: string; + }>; + + startDragToDesktop: (dragData: { + tempId: string; + fileName: string; + }) => Promise<{ + success: boolean; + error?: string; + }>; + + cleanupTempFile: (tempId: string) => Promise<{ + success: boolean; + error?: string; + }>; +} + +declare global { + interface Window { + electronAPI: ElectronAPI; + IS_ELECTRON: boolean; + } +} diff --git a/src/types/index.ts b/src/types/index.ts index 706c8828..ee7cedb2 100644 --- a/src/types/index.ts +++ b/src/types/index.ts @@ -2,7 +2,6 @@ // CENTRAL TYPE DEFINITIONS // ============================================================================ // This file contains all shared interfaces and types used across the application -// to avoid duplication and ensure consistency. import type { Client } from "ssh2"; @@ -24,6 +23,11 @@ export interface SSHHost { key?: string; keyPassword?: string; keyType?: string; + + autostartPassword?: string; + autostartKey?: string; + autostartKeyPassword?: string; + credentialId?: number; userId?: string; enableTerminal: boolean; @@ -70,6 +74,7 @@ export interface Credential { username: string; password?: string; key?: string; + publicKey?: string; keyPassword?: string; keyType?: string; usageCount: number; @@ -87,6 +92,7 @@ export interface CredentialData { username: string; password?: string; key?: string; + publicKey?: string; keyPassword?: string; keyType?: string; } @@ -99,6 +105,14 @@ export interface TunnelConnection { sourcePort: number; endpointPort: number; endpointHost: string; + + // Endpoint host credentials for tunnel authentication + endpointPassword?: string; + endpointKey?: string; + endpointKeyPassword?: string; + endpointAuthType?: string; + endpointKeyType?: string; + maxRetries: number; retryInterval: number; autoStart: boolean; @@ -180,8 +194,15 @@ export interface FileItem { name: string; path: string; isPinned?: boolean; - type: "file" | "directory"; + type: "file" | "directory" | "link"; sshSessionId?: string; + size?: number; + modified?: string; + permissions?: string; + owner?: string; + group?: string; + linkTarget?: string; + executable?: boolean; } export interface ShortcutItem { @@ -360,26 +381,6 @@ export interface FileManagerProps { initialHost?: SSHHost | null; } -export interface FileManagerLeftSidebarProps { - onSelectView?: (view: string) => void; - onOpenFile: (file: any) => void; - tabs: Tab[]; - host: SSHHost; - onOperationComplete?: () => void; - onError?: (error: string) => void; - onSuccess?: (message: string) => void; - onPathChange?: (path: string) => void; - onDeleteItem?: (item: any) => void; -} - -export interface FileManagerOperationsProps { - currentPath: string; - sshSessionId: string | null; - onOperationComplete?: () => void; - onError?: (error: string) => void; - onSuccess?: (message: string) => void; -} - export interface AlertCardProps { alert: TermixAlert; onDismiss: (alertId: string) => void; diff --git a/src/ui/Desktop/Admin/AdminSettings.tsx b/src/ui/Desktop/Admin/AdminSettings.tsx index 8b2f8cc9..e176e234 100644 --- a/src/ui/Desktop/Admin/AdminSettings.tsx +++ b/src/ui/Desktop/Admin/AdminSettings.tsx @@ -21,7 +21,16 @@ import { TableHeader, TableRow, } from "@/components/ui/table.tsx"; -import { Shield, Trash2, Users } from "lucide-react"; +import { + Shield, + Trash2, + Users, + Database, + Key, + Lock, + Download, + Upload, +} from "lucide-react"; import { toast } from "sonner"; import { useTranslation } from "react-i18next"; import { useConfirmation } from "@/hooks/use-confirmation.ts"; @@ -82,10 +91,16 @@ export function AdminSettings({ null, ); - React.useEffect(() => { - const jwt = getCookie("jwt"); - if (!jwt) return; + const [securityInitialized, setSecurityInitialized] = React.useState(true); + const [exportLoading, setExportLoading] = React.useState(false); + const [importLoading, setImportLoading] = React.useState(false); + const [importFile, setImportFile] = React.useState(null); + const [exportPassword, setExportPassword] = React.useState(""); + const [showPasswordInput, setShowPasswordInput] = React.useState(false); + const [importPassword, setImportPassword] = React.useState(""); + + React.useEffect(() => { if (isElectron()) { const serverUrl = (window as any).configuredServerUrl; if (!serverUrl) { @@ -127,9 +142,6 @@ export function AdminSettings({ }, []); const fetchUsers = async () => { - const jwt = getCookie("jwt"); - if (!jwt) return; - if (isElectron()) { const serverUrl = (window as any).configuredServerUrl; if (!serverUrl) { @@ -152,7 +164,6 @@ export function AdminSettings({ const handleToggleRegistration = async (checked: boolean) => { setRegLoading(true); - const jwt = getCookie("jwt"); try { await updateRegistrationAllowed(checked); setAllowRegistration(checked); @@ -184,7 +195,6 @@ export function AdminSettings({ return; } - const jwt = getCookie("jwt"); try { await updateOIDCConfig(oidcConfig); toast.success(t("admin.oidcConfigurationUpdated")); @@ -206,7 +216,6 @@ export function AdminSettings({ if (!newAdminUsername.trim()) return; setMakeAdminLoading(true); setMakeAdminError(null); - const jwt = getCookie("jwt"); try { await makeUserAdmin(newAdminUsername.trim()); toast.success(t("admin.userIsNowAdmin", { username: newAdminUsername })); @@ -223,7 +232,6 @@ export function AdminSettings({ const handleRemoveAdminStatus = async (username: string) => { confirmWithToast(t("admin.removeAdminStatus", { username }), async () => { - const jwt = getCookie("jwt"); try { await removeAdminStatus(username); toast.success(t("admin.adminStatusRemoved", { username })); @@ -238,7 +246,6 @@ export function AdminSettings({ confirmWithToast( t("admin.deleteUser", { username }), async () => { - const jwt = getCookie("jwt"); try { await deleteUser(username); toast.success(t("admin.userDeletedSuccessfully", { username })); @@ -251,6 +258,168 @@ export function AdminSettings({ ); }; + const handleExportDatabase = async () => { + if (!showPasswordInput) { + setShowPasswordInput(true); + return; + } + + if (!exportPassword.trim()) { + toast.error(t("admin.passwordRequired")); + return; + } + + setExportLoading(true); + try { + const isDev = + process.env.NODE_ENV === "development" && + (window.location.port === "3000" || + window.location.port === "5173" || + window.location.port === "" || + window.location.hostname === "localhost" || + window.location.hostname === "127.0.0.1"); + + const apiUrl = isElectron() + ? `${(window as any).configuredServerUrl}/database/export` + : isDev + ? `http://localhost:30001/database/export` + : `${window.location.protocol}//${window.location.host}/database/export`; + + const response = await fetch(apiUrl, { + method: "POST", + headers: { + "Content-Type": "application/json", + }, + credentials: "include", + body: JSON.stringify({ password: exportPassword }), + }); + + if (response.ok) { + const blob = await response.blob(); + const contentDisposition = response.headers.get("content-disposition"); + const filename = + contentDisposition?.match(/filename="([^"]+)"/)?.[1] || + "termix-export.sqlite"; + + const url = window.URL.createObjectURL(blob); + const a = document.createElement("a"); + a.href = url; + a.download = filename; + document.body.appendChild(a); + a.click(); + window.URL.revokeObjectURL(url); + document.body.removeChild(a); + + toast.success(t("admin.databaseExportedSuccessfully")); + setExportPassword(""); + setShowPasswordInput(false); + } else { + const error = await response.json(); + if (error.code === "PASSWORD_REQUIRED") { + toast.error(t("admin.passwordRequired")); + } else { + toast.error(error.error || t("admin.databaseExportFailed")); + } + } + } catch (err) { + toast.error(t("admin.databaseExportFailed")); + } finally { + setExportLoading(false); + } + }; + + const handleImportDatabase = async () => { + if (!importFile) { + toast.error(t("admin.pleaseSelectImportFile")); + return; + } + + if (!importPassword.trim()) { + toast.error(t("admin.passwordRequired")); + return; + } + + setImportLoading(true); + try { + const isDev = + process.env.NODE_ENV === "development" && + (window.location.port === "3000" || + window.location.port === "5173" || + window.location.port === "" || + window.location.hostname === "localhost" || + window.location.hostname === "127.0.0.1"); + + const apiUrl = isElectron() + ? `${(window as any).configuredServerUrl}/database/import` + : isDev + ? `http://localhost:30001/database/import` + : `${window.location.protocol}//${window.location.host}/database/import`; + + const formData = new FormData(); + formData.append("file", importFile); + formData.append("password", importPassword); + + const response = await fetch(apiUrl, { + method: "POST", + credentials: "include", + body: formData, + }); + + if (response.ok) { + const result = await response.json(); + if (result.success) { + const summary = result.summary; + const imported = + summary.sshHostsImported + + summary.sshCredentialsImported + + summary.fileManagerItemsImported + + summary.dismissedAlertsImported + + (summary.settingsImported || 0); + const skipped = summary.skippedItems; + + const details = []; + if (summary.sshHostsImported > 0) + details.push(`${summary.sshHostsImported} SSH hosts`); + if (summary.sshCredentialsImported > 0) + details.push(`${summary.sshCredentialsImported} credentials`); + if (summary.fileManagerItemsImported > 0) + details.push( + `${summary.fileManagerItemsImported} file manager items`, + ); + if (summary.dismissedAlertsImported > 0) + details.push(`${summary.dismissedAlertsImported} alerts`); + if (summary.settingsImported > 0) + details.push(`${summary.settingsImported} settings`); + + toast.success( + `Import completed: ${imported} items imported${details.length > 0 ? ` (${details.join(", ")})` : ""}, ${skipped} items skipped`, + ); + setImportFile(null); + setImportPassword(""); + + setTimeout(() => { + window.location.reload(); + }, 1500); + } else { + toast.error( + `${t("admin.databaseImportFailed")}: ${result.summary?.errors?.join(", ") || "Unknown error"}`, + ); + } + } else { + const error = await response.json(); + if (error.code === "PASSWORD_REQUIRED") { + toast.error(t("admin.passwordRequired")); + } else { + toast.error(error.error || t("admin.databaseImportFailed")); + } + } + } catch (err) { + toast.error(t("admin.databaseImportFailed")); + } finally { + setImportLoading(false); + } + }; + const topMarginPx = isTopbarOpen ? 74 : 26; const leftMarginPx = sidebarState === "collapsed" ? 26 : 8; const bottomMarginPx = 8; @@ -295,6 +464,10 @@ export function AdminSettings({ {t("admin.adminManagement")} + + + {t("admin.databaseSecurity")} + @@ -680,6 +853,151 @@ export function AdminSettings({
+ + +
+
+ +

+ {t("admin.databaseSecurity")} +

+
+ +
+
+ +
+
+ {t("admin.encryptionStatus")} +
+
+ {t("admin.encryptionEnabled")} +
+
+
+
+ +
+
+
+
+ +

{t("admin.export")}

+
+

+ {t("admin.exportDescription")} +

+ {showPasswordInput && ( +
+ + setExportPassword(e.target.value)} + placeholder="Enter your password" + onKeyDown={(e) => { + if (e.key === "Enter") { + handleExportDatabase(); + } + }} + /> +
+ )} + + {showPasswordInput && ( + + )} +
+
+ +
+
+
+ +

{t("admin.import")}

+
+

+ {t("admin.importDescription")} +

+
+ + setImportFile(e.target.files?.[0] || null) + } + className="absolute inset-0 w-full h-full opacity-0 cursor-pointer" + /> + +
+ {importFile && ( +
+ + setImportPassword(e.target.value)} + placeholder="Enter your password" + onKeyDown={(e) => { + if (e.key === "Enter") { + handleImportDatabase(); + } + }} + /> +
+ )} + +
+
+
+
+
diff --git a/src/ui/Desktop/Apps/Credentials/CredentialEditor.tsx b/src/ui/Desktop/Apps/Credentials/CredentialEditor.tsx index f0401878..9303c0b8 100644 --- a/src/ui/Desktop/Apps/Credentials/CredentialEditor.tsx +++ b/src/ui/Desktop/Apps/Credentials/CredentialEditor.tsx @@ -22,8 +22,15 @@ import { updateCredential, getCredentials, getCredentialDetails, + detectKeyType, + detectPublicKeyType, + generatePublicKeyFromPrivate, + generateKeyPair, } from "@/ui/main-axios"; import { useTranslation } from "react-i18next"; +import CodeMirror from "@uiw/react-codemirror"; +import { oneDark } from "@codemirror/theme-one-dark"; +import { EditorView } from "@codemirror/view"; import type { Credential, CredentialEditorProps, @@ -42,9 +49,16 @@ export function CredentialEditor({ useState(null); const [authTab, setAuthTab] = useState<"password" | "key">("password"); - const [keyInputMethod, setKeyInputMethod] = useState<"upload" | "paste">( - "upload", - ); + const [detectedKeyType, setDetectedKeyType] = useState(null); + const [keyDetectionLoading, setKeyDetectionLoading] = useState(false); + const keyDetectionTimeoutRef = useRef(null); + + const [detectedPublicKeyType, setDetectedPublicKeyType] = useState< + string | null + >(null); + const [publicKeyDetectionLoading, setPublicKeyDetectionLoading] = + useState(false); + const publicKeyDetectionTimeoutRef = useRef(null); useEffect(() => { const fetchData = async () => { @@ -101,6 +115,7 @@ export function CredentialEditor({ username: z.string().min(1), password: z.string().optional(), key: z.any().optional().nullable(), + publicKey: z.string().optional(), keyPassword: z.string().optional(), keyType: z .enum([ @@ -149,6 +164,7 @@ export function CredentialEditor({ username: "", password: "", key: null, + publicKey: "", keyPassword: "", keyType: "auto", }, @@ -169,6 +185,7 @@ export function CredentialEditor({ username: fullCredentialDetails.username || "", password: "", key: null, + publicKey: "", keyPassword: "", keyType: "auto" as const, }; @@ -176,7 +193,8 @@ export function CredentialEditor({ if (defaultAuthType === "password") { formData.password = fullCredentialDetails.password || ""; } else if (defaultAuthType === "key") { - formData.key = "existing_key"; + formData.key = fullCredentialDetails.key || ""; + formData.publicKey = fullCredentialDetails.publicKey || ""; formData.keyPassword = fullCredentialDetails.keyPassword || ""; formData.keyType = (fullCredentialDetails.keyType as any) || ("auto" as const); @@ -196,6 +214,7 @@ export function CredentialEditor({ username: "", password: "", key: null, + publicKey: "", keyPassword: "", keyType: "auto", }); @@ -203,6 +222,100 @@ export function CredentialEditor({ } }, [editingCredential?.id, fullCredentialDetails, form]); + useEffect(() => { + return () => { + if (keyDetectionTimeoutRef.current) { + clearTimeout(keyDetectionTimeoutRef.current); + } + if (publicKeyDetectionTimeoutRef.current) { + clearTimeout(publicKeyDetectionTimeoutRef.current); + } + }; + }, []); + + const handleKeyTypeDetection = async ( + keyValue: string, + keyPassword?: string, + ) => { + if (!keyValue || keyValue.trim() === "") { + setDetectedKeyType(null); + return; + } + + setKeyDetectionLoading(true); + try { + const result = await detectKeyType(keyValue, keyPassword); + if (result.success) { + setDetectedKeyType(result.keyType); + } else { + setDetectedKeyType("invalid"); + } + } catch (error) { + setDetectedKeyType("error"); + console.error("Key type detection error:", error); + } finally { + setKeyDetectionLoading(false); + } + }; + + const debouncedKeyDetection = (keyValue: string, keyPassword?: string) => { + if (keyDetectionTimeoutRef.current) { + clearTimeout(keyDetectionTimeoutRef.current); + } + keyDetectionTimeoutRef.current = setTimeout(() => { + handleKeyTypeDetection(keyValue, keyPassword); + }, 1000); + }; + + const handlePublicKeyTypeDetection = async (publicKeyValue: string) => { + if (!publicKeyValue || publicKeyValue.trim() === "") { + setDetectedPublicKeyType(null); + return; + } + + setPublicKeyDetectionLoading(true); + try { + const result = await detectPublicKeyType(publicKeyValue); + if (result.success) { + setDetectedPublicKeyType(result.keyType); + } else { + setDetectedPublicKeyType("invalid"); + console.warn("Public key detection failed:", result.error); + } + } catch (error) { + setDetectedPublicKeyType("error"); + console.error("Public key type detection error:", error); + } finally { + setPublicKeyDetectionLoading(false); + } + }; + + const debouncedPublicKeyDetection = (publicKeyValue: string) => { + if (publicKeyDetectionTimeoutRef.current) { + clearTimeout(publicKeyDetectionTimeoutRef.current); + } + publicKeyDetectionTimeoutRef.current = setTimeout(() => { + handlePublicKeyTypeDetection(publicKeyValue); + }, 1000); + }; + + const getFriendlyKeyTypeName = (keyType: string): string => { + const keyTypeMap: Record = { + "ssh-rsa": "RSA (SSH)", + "ssh-ed25519": "Ed25519 (SSH)", + "ecdsa-sha2-nistp256": "ECDSA P-256 (SSH)", + "ecdsa-sha2-nistp384": "ECDSA P-384 (SSH)", + "ecdsa-sha2-nistp521": "ECDSA P-521 (SSH)", + "ssh-dss": "DSA (SSH)", + "rsa-sha2-256": "RSA-SHA2-256", + "rsa-sha2-512": "RSA-SHA2-512", + invalid: t("credentials.invalidKey"), + error: t("credentials.detectionError"), + unknown: t("credentials.unknown"), + }; + return keyTypeMap[keyType] || keyType; + }; + const onSubmit = async (data: FormData) => { try { if (!data.name || data.name.trim() === "") { @@ -221,20 +334,15 @@ export function CredentialEditor({ submitData.password = null; submitData.key = null; + submitData.publicKey = null; submitData.keyPassword = null; submitData.keyType = null; if (data.authType === "password") { submitData.password = data.password; } else if (data.authType === "key") { - if (data.key instanceof File) { - const keyContent = await data.key.text(); - submitData.key = keyContent; - } else if (data.key === "existing_key") { - delete submitData.key; - } else { - submitData.key = data.key; - } + submitData.key = data.key; + submitData.publicKey = data.publicKey; submitData.keyPassword = data.keyPassword; submitData.keyType = data.keyType; } @@ -259,7 +367,12 @@ export function CredentialEditor({ form.reset(); } catch (error) { - toast.error(t("credentials.failedToSaveCredential")); + console.error("Credential save error:", error); + if (error instanceof Error) { + toast.error(error.message); + } else { + toast.error(t("credentials.failedToSaveCredential")); + } } }; @@ -305,39 +418,6 @@ export function CredentialEditor({ }; }, [folderDropdownOpen]); - const keyTypeOptions = [ - { value: "auto", label: t("hosts.autoDetect") }, - { value: "ssh-rsa", label: t("hosts.rsa") }, - { value: "ssh-ed25519", label: t("hosts.ed25519") }, - { value: "ecdsa-sha2-nistp256", label: t("hosts.ecdsaNistP256") }, - { value: "ecdsa-sha2-nistp384", label: t("hosts.ecdsaNistP384") }, - { value: "ecdsa-sha2-nistp521", label: t("hosts.ecdsaNistP521") }, - { value: "ssh-dss", label: t("hosts.dsa") }, - { value: "ssh-rsa-sha2-256", label: t("hosts.rsaSha2256") }, - { value: "ssh-rsa-sha2-512", label: t("hosts.rsaSha2512") }, - ]; - - const [keyTypeDropdownOpen, setKeyTypeDropdownOpen] = useState(false); - const keyTypeButtonRef = useRef(null); - const keyTypeDropdownRef = useRef(null); - - useEffect(() => { - function onClickOutside(event: MouseEvent) { - if ( - keyTypeDropdownOpen && - keyTypeDropdownRef.current && - !keyTypeDropdownRef.current.contains(event.target as Node) && - keyTypeButtonRef.current && - !keyTypeButtonRef.current.contains(event.target as Node) - ) { - setKeyTypeDropdownOpen(false); - } - } - - document.addEventListener("mousedown", onClickOutside); - return () => document.removeEventListener("mousedown", onClickOutside); - }, [keyTypeDropdownOpen]); - return (
- + {t("credentials.basicInformation")} -
+
- + {t("credentials.organization")} -
+
- + {t("credentials.authentication")} - { - setKeyInputMethod(value as "upload" | "paste"); - if (value === "upload") { - form.setValue("key", null); - } else { - form.setValue("key", ""); - } - }} - className="w-full" - > - - - {t("hosts.uploadFile")} - - - {t("hosts.pasteKey")} - - - +
+
+ + {t("credentials.generateKeyPair")} + + +
+
+ {t("credentials.generateKeyPairDescription")} +
+
+ +
+ + + +
+
+
( - - + + {t("credentials.sshPrivateKey")} - -
+
+
{ + accept="*,.pem,.key,.txt,.ppk" + onChange={async (e) => { const file = e.target.files?.[0]; - field.onChange(file || null); + if (file) { + try { + const fileContent = await file.text(); + field.onChange(fileContent); + debouncedKeyDetection( + fileContent, + form.watch("keyPassword"), + ); + } catch (error) { + console.error( + "Failed to read uploaded file:", + error, + ); + } + } }} className="absolute inset-0 w-full h-full opacity-0 cursor-pointer" />
- - - )} - /> -
- ( - - - {t("credentials.keyPassword")} - - - - - - )} - /> - ( - - - {t("credentials.keyType")} - - -
- - {keyTypeDropdownOpen && ( -
-
- {keyTypeOptions.map((opt) => ( - - ))} -
-
- )} -
-
-
- )} - /> -
- - - ( - - - {t("credentials.sshPrivateKey")} - +
-