Tutorial

Nuevas actualizaciones y mejoras para Macfleet.

Aviso importante

Los ejemplos de código y scripts proporcionados en estos tutoriales son solo para propósitos educativos. Macfleet no es responsable de ningún problema, daño o vulnerabilidad de seguridad que pueda surgir del uso, modificación o implementación de estos ejemplos. Siempre revisa y prueba el código en un entorno seguro antes de usarlo en sistemas de producción.

Safari Browser Management on macOS

Manage Safari browser configurations and policies across your MacFleet devices with enterprise-grade settings deployment. This tutorial covers homepage configuration, security settings, user management, and comprehensive browser policy enforcement.

Understanding Safari Browser Management

Safari browser management on macOS involves configuring browser settings, security policies, and user preferences across enterprise devices:

Core Components

  • Homepage Configuration - Set default landing pages for users
  • Security Settings - Manage privacy, security, and content policies
  • User Preferences - Control browser behavior and features
  • Policy Enforcement - Deploy and maintain consistent browser settings
  • Fleet Management - Mass configuration across multiple devices

Enterprise Benefits

  • Standardized Browsing - Consistent user experience across devices
  • Security Compliance - Enforce security policies and restrictions
  • Productivity Control - Manage access to sites and features
  • Policy Deployment - Centralized browser configuration management
  • Audit Capabilities - Track and monitor browser usage patterns

Basic Safari Homepage Configuration

Simple Homepage Setup

#!/bin/bash

# Enhanced Safari homepage configuration
configure_safari_homepage() {
    local homepage_url="${1:-https://macfleet.io}"
    local apply_to_all_users="${2:-true}"
    
    echo "🌐 Safari Homepage Configuration"
    echo "==============================="
    echo "Homepage URL: $homepage_url"
    echo "Apply to all users: $apply_to_all_users"
    echo ""
    
    # Validate URL format
    if ! [[ "$homepage_url" =~ ^https?:// ]]; then
        echo "⚠️ Adding https:// to URL: $homepage_url"
        homepage_url="https://$homepage_url"
    fi
    
    echo "Final homepage URL: $homepage_url"
    echo ""
    
    # Kill Safari processes to ensure settings take effect
    echo "Terminating Safari processes..."
    sudo killall -9 Safari 2>/dev/null || echo "No Safari processes running"
    sleep 2
    
    if [[ "$apply_to_all_users" == "true" ]]; then
        configure_all_users_safari "$homepage_url"
    else
        configure_current_user_safari "$homepage_url"
    fi
}

# Configure Safari for all users
configure_all_users_safari() {
    local homepage="$1"
    local users_configured=0
    local users_failed=0
    
    echo "Configuring Safari for all users..."
    echo ""
    
    # Loop through each user to set homepage preferences
    for user in $(ls /Users | grep -v Shared | grep -v npsparcc | grep -v ".localized" | grep -v "Guest"); do
        echo "Processing user: $user"
        
        # Check if user home directory exists
        if [[ ! -d "/Users/$user" ]]; then
            echo "⚠️ User directory not found, skipping: $user"
            continue
        fi
        
        # Configure Safari settings
        if configure_user_safari_settings "$user" "$homepage"; then
            echo "✅ Safari configured successfully for user: $user"
            ((users_configured++))
        else
            echo "❌ Failed to configure Safari for user: $user"
            ((users_failed++))
        fi
        echo ""
    done
    
    echo "=== Configuration Summary ==="
    echo "Users configured: $users_configured"
    echo "Users failed: $users_failed"
    echo "Total processed: $((users_configured + users_failed))"
}

# Configure Safari settings for specific user
configure_user_safari_settings() {
    local user="$1"
    local homepage="$2"
    
    # Set Safari homepage
    if su - "$user" -c "defaults write com.apple.Safari HomePage '$homepage'" 2>/dev/null; then
        # Set new window behavior (0 = homepage)
        su - "$user" -c "defaults write com.apple.Safari NewWindowBehavior -int 0" 2>/dev/null
        
        # Set new tab behavior (0 = homepage)
        su - "$user" -c "defaults write com.apple.Safari NewTabBehavior -int 0" 2>/dev/null
        
        # Verify settings
        local current_homepage
        current_homepage=$(su - "$user" -c "defaults read com.apple.Safari HomePage" 2>/dev/null)
        
        if [[ "$current_homepage" == "$homepage" ]]; then
            echo "  Homepage set: $current_homepage"
            echo "  New window behavior: Homepage"
            echo "  New tab behavior: Homepage"
            return 0
        else
            echo "  ⚠️ Verification failed"
            return 1
        fi
    else
        echo "  ❌ Failed to write Safari preferences"
        return 1
    fi
}

# Configure current user only
configure_current_user_safari() {
    local homepage="$1"
    local current_user=$(whoami)
    
    echo "Configuring Safari for current user: $current_user"
    
    if configure_user_safari_settings "$current_user" "$homepage"; then
        echo "✅ Safari configured successfully for current user"
    else
        echo "❌ Failed to configure Safari for current user"
        return 1
    fi
}

# Execute basic homepage configuration
echo "Basic Safari Homepage Configuration:"
echo "===================================="
configure_safari_homepage "https://macfleet.io" true

Enterprise Safari Management System

Comprehensive Browser Configuration Manager

#!/bin/bash

# Enterprise Safari management system
enterprise_safari_manager() {
    local operation="${1:-configure}"
    local config_profile="${2:-standard}"
    local target_users="${3:-all}"
    
    echo "🏢 MacFleet Safari Enterprise Manager"
    echo "===================================="
    echo "Operation: $operation"
    echo "Profile: $config_profile"
    echo "Target users: $target_users"
    echo ""
    
    # Configuration profiles
    declare -A config_profiles
    config_profiles[standard]="https://macfleet.io:true:true:false"
    config_profiles[secure]="https://macfleet.io:true:true:true"
    config_profiles[education]="https://education.macfleet.io:true:false:true"
    config_profiles[kiosk]="https://kiosk.macfleet.io:false:false:true"
    
    case "$operation" in
        "configure")
            deploy_safari_configuration "$config_profile" "$target_users"
            ;;
        "security")
            apply_security_settings "$config_profile" "$target_users"
            ;;
        "audit")
            audit_safari_settings "$target_users"
            ;;
        "backup")
            backup_safari_settings "$target_users"
            ;;
        "restore")
            restore_safari_settings "$target_users"
            ;;
        *)
            echo "❌ Unknown operation: $operation"
            echo "Available operations: configure, security, audit, backup, restore"
            return 1
            ;;
    esac
}

# Deploy comprehensive Safari configuration
deploy_safari_configuration() {
    local profile="$1"
    local target_users="$2"
    
    echo "📋 Deploying Safari Configuration"
    echo "================================="
    
    # Parse configuration profile
    local config_string="${config_profiles[$profile]:-${config_profiles[standard]}}"
    IFS=':' read -r homepage block_popups auto_fill restrict_sites <<< "$config_string"
    
    echo "Configuration Profile: $profile"
    echo "Homepage: $homepage"
    echo "Block popups: $block_popups"
    echo "Auto-fill: $auto_fill" 
    echo "Restrict sites: $restrict_sites"
    echo ""
    
    # Get target user list
    local users_list=()
    if [[ "$target_users" == "all" ]]; then
        readarray -t users_list < <(ls /Users | grep -v Shared | grep -v npsparcc | grep -v ".localized" | grep -v "Guest")
    else
        IFS=',' read -ra users_list <<< "$target_users"
    fi
    
    local configured=0
    local failed=0
    
    # Kill Safari processes first
    echo "Terminating all Safari processes..."
    sudo killall -9 Safari 2>/dev/null || echo "No Safari processes running"
    sleep 3
    
    # Configure each user
    for user in "${users_list[@]}"; do
        if [[ -n "$user" && -d "/Users/$user" ]]; then
            echo "Configuring user: $user"
            
            if apply_user_safari_config "$user" "$homepage" "$block_popups" "$auto_fill" "$restrict_sites"; then
                echo "✅ Configuration applied successfully"
                ((configured++))
            else
                echo "❌ Configuration failed"
                ((failed++))
            fi
            echo ""
        fi
    done
    
    # Generate deployment report
    cat > "/tmp/safari_deployment_$(date +%Y%m%d_%H%M%S).log" << EOF
Safari Configuration Deployment Report
=====================================
Date: $(date)
Profile: $profile
Target: $target_users

Configuration Details:
- Homepage: $homepage
- Block popups: $block_popups
- Auto-fill: $auto_fill
- Restrict sites: $restrict_sites

Results:
- Successfully configured: $configured users
- Failed configurations: $failed users
- Total processed: $((configured + failed)) users

Deployment Status: $([[ "$failed" -eq 0 ]] && echo "SUCCESS" || echo "PARTIAL")
EOF
    
    echo "=== Deployment Summary ==="
    echo "Successfully configured: $configured users"
    echo "Failed configurations: $failed users"
    echo "Total processed: $((configured + failed)) users"
    
    if [[ "$failed" -eq 0 ]]; then
        echo "🎉 Deployment completed successfully!"
    else
        echo "⚠️ Deployment completed with some failures"
    fi
}

# Apply comprehensive Safari settings for user
apply_user_safari_config() {
    local user="$1"
    local homepage="$2"
    local block_popups="$3"
    local auto_fill="$4"
    local restrict_sites="$5"
    
    local settings_applied=0
    
    # Set homepage and window/tab behavior
    if su - "$user" -c "defaults write com.apple.Safari HomePage '$homepage'" 2>/dev/null; then
        su - "$user" -c "defaults write com.apple.Safari NewWindowBehavior -int 0" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari NewTabBehavior -int 0" 2>/dev/null
        ((settings_applied++))
    fi
    
    # Configure popup blocking
    if [[ "$block_popups" == "true" ]]; then
        su - "$user" -c "defaults write com.apple.Safari WebKitJavaScriptCanOpenWindowsAutomatically -bool false" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari com.apple.Safari.ContentPageGroupIdentifier.WebKit2JavaScriptCanOpenWindowsAutomatically -bool false" 2>/dev/null
        ((settings_applied++))
    fi
    
    # Configure auto-fill settings
    if [[ "$auto_fill" == "true" ]]; then
        su - "$user" -c "defaults write com.apple.Safari AutoFillFormData -bool true" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari AutoFillPasswords -bool true" 2>/dev/null
    else
        su - "$user" -c "defaults write com.apple.Safari AutoFillFormData -bool false" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari AutoFillPasswords -bool false" 2>/dev/null
    fi
    ((settings_applied++))
    
    # Configure security settings
    if [[ "$restrict_sites" == "true" ]]; then
        # Enable parental controls and restrictions
        su - "$user" -c "defaults write com.apple.Safari WebKitDeveloperExtrasEnabled -bool false" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari IncludeDevelopMenu -bool false" 2>/dev/null
        su - "$user" -c "defaults write com.apple.Safari WebKitJavaEnabled -bool false" 2>/dev/null
        ((settings_applied++))
    fi
    
    # Additional security settings
    su - "$user" -c "defaults write com.apple.Safari SendDoNotTrackHTTPHeader -bool true" 2>/dev/null
    su - "$user" -c "defaults write com.apple.Safari InstallExtensionUpdatesAutomatically -bool true" 2>/dev/null
    
    return $([[ "$settings_applied" -ge 3 ]] && echo 0 || echo 1)
}

# Security-focused Safari configuration
apply_security_settings() {
    local profile="$1"
    local target_users="$2"
    
    echo "🔒 Applying Security Settings"
    echo "============================"
    echo ""
    
    # Get user list
    local users_list=()
    if [[ "$target_users" == "all" ]]; then
        readarray -t users_list < <(ls /Users | grep -v Shared | grep -v npsparcc | grep -v ".localized" | grep -v "Guest")
    else
        IFS=',' read -ra users_list <<< "$target_users"
    fi
    
    for user in "${users_list[@]}"; do
        if [[ -n "$user" && -d "/Users/$user" ]]; then
            echo "Applying security settings for user: $user"
            
            # Enhanced security settings
            su - "$user" -c "defaults write com.apple.Safari WebKitJavaScriptEnabled -bool false" 2>/dev/null
            su - "$user" -c "defaults write com.apple.Safari WebKitJavaEnabled -bool false" 2>/dev/null
            su - "$user" -c "defaults write com.apple.Safari WebKitPluginsEnabled -bool false" 2>/dev/null
            su - "$user" -c "defaults write com.apple.Safari SendDoNotTrackHTTPHeader -bool true" 2>/dev/null
            su - "$user" -c "defaults write com.apple.Safari WarnAboutFraudulentWebsites -bool true" 2>/dev/null
            su - "$user" -c "defaults write com.apple.Safari BlockStoragePolicy -int 2" 2>/dev/null
            
            echo "✅ Security settings applied"
        fi
    done
}

# Audit current Safari settings
audit_safari_settings() {
    local target_users="$1"
    local audit_file="/tmp/safari_audit_$(date +%Y%m%d_%H%M%S).json"
    
    echo "📊 Auditing Safari Settings"
    echo "==========================="
    echo ""
    
    {
        echo "{"
        echo "  \"audit_report\": {"
        echo "    \"generated\": \"$(date -u +"%Y-%m-%dT%H:%M:%SZ")\","
        echo "    \"hostname\": \"$(hostname)\","
        echo "    \"users\": ["
        
        local first_user=true
        local total_users=0
        local compliant_users=0
        
        # Get user list
        local users_list=()
        if [[ "$target_users" == "all" ]]; then
            readarray -t users_list < <(ls /Users | grep -v Shared | grep -v npsparcc | grep -v ".localized" | grep -v "Guest")
        else
            IFS=',' read -ra users_list <<< "$target_users"
        fi
        
        for user in "${users_list[@]}"; do
            if [[ -n "$user" && -d "/Users/$user" ]]; then
                if [[ "$first_user" == "false" ]]; then
                    echo ","
                fi
                
                local homepage=$(su - "$user" -c "defaults read com.apple.Safari HomePage" 2>/dev/null || echo "Not set")
                local popup_blocking=$(su - "$user" -c "defaults read com.apple.Safari WebKitJavaScriptCanOpenWindowsAutomatically" 2>/dev/null || echo "true")
                local do_not_track=$(su - "$user" -c "defaults read com.apple.Safari SendDoNotTrackHTTPHeader" 2>/dev/null || echo "false")
                
                local is_compliant="false"
                if [[ "$homepage" =~ macfleet ]] && [[ "$popup_blocking" == "false" ]] && [[ "$do_not_track" == "true" ]]; then
                    is_compliant="true"
                    ((compliant_users++))
                fi
                
                echo "      {"
                echo "        \"username\": \"$user\","
                echo "        \"homepage\": \"$homepage\","
                echo "        \"popup_blocking\": $([[ "$popup_blocking" == "false" ]] && echo "true" || echo "false"),"
                echo "        \"do_not_track\": $([[ "$do_not_track" == "true" ]] && echo "true" || echo "false"),"
                echo "        \"compliant\": $is_compliant"
                echo -n "      }"
                
                first_user=false
                ((total_users++))
            fi
        done
        
        echo ""
        echo "    ],"
        echo "    \"summary\": {"
        echo "      \"total_users\": $total_users,"
        echo "      \"compliant_users\": $compliant_users,"
        echo "      \"compliance_rate\": \"$(echo "scale=1; ($compliant_users * 100) / $total_users" | bc 2>/dev/null || echo "0")%\""
        echo "    }"
        echo "  }"
        echo "}"
    } > "$audit_file"
    
    echo "✅ Audit completed: $audit_file"
    echo ""
    echo "=== Audit Summary ==="
    echo "Total users: $total_users"
    echo "Compliant users: $compliant_users"
    
    if [[ "$total_users" -gt 0 ]]; then
        local compliance_rate=$(echo "scale=1; ($compliant_users * 100) / $total_users" | bc 2>/dev/null || echo "0")
        echo "Compliance rate: ${compliance_rate}%"
    fi
}

# Usage examples
echo "Safari Manager Examples:"
echo "==================================="
echo ""

echo "1. Deploy standard configuration:"
enterprise_safari_manager "configure" "standard" "all"
echo ""

echo "2. Apply security settings:"
enterprise_safari_manager "security" "secure" "all"
echo ""

echo "3. Audit current settings:"
enterprise_safari_manager "audit" "all"

Important Notes

Enterprise Features

  • Profile-Based Configuration - Predefined settings for different use cases
  • Mass User Management - Deploy settings across all system users
  • Security Policy Enforcement - Advanced security and privacy controls
  • Audit and Compliance - Track configuration compliance across fleet
  • Backup and Restore - Preserve and restore browser configurations

Configuration Profiles

  • Standard - Basic enterprise settings with MacFleet homepage
  • Secure - Enhanced security with restricted features
  • Education - Educational environment optimizations
  • Kiosk - Locked-down configuration for public access

Security Features

  • Popup Blocking - Prevent unwanted popup windows
  • JavaScript Control - Manage script execution permissions
  • Do Not Track - Enhanced privacy protection
  • Auto-fill Management - Control form and password auto-completion
  • Developer Tools - Restrict access to debugging features

Usage Examples

# Basic homepage setup
homepage="https://macfleet.io"
sudo killall -9 Safari
for user in $(ls /Users | grep -v Shared | grep -v npsparcc | grep -v ".localized"); do
    su - "$user" -c "defaults write com.apple.Safari HomePage $homepage"
    su - "$user" -c "defaults write com.apple.Safari NewWindowBehavior -int 0"
    su - "$user" -c "defaults write com.apple.Safari NewTabBehavior -int 0"
    echo "Set Safari homepage to $homepage for $user."
done

# Enhanced MacFleet configuration
configure_safari_homepage "https://macfleet.io" true

# Enterprise deployment
enterprise_safari_manager "configure" "secure" "all"

# Security audit
enterprise_safari_manager "audit" "all"

Tutorial

Nuevas actualizaciones y mejoras para Macfleet.

Configurando un Runner de GitHub Actions en un Mac Mini (Apple Silicon)

Runner de GitHub Actions

GitHub Actions es una plataforma poderosa de CI/CD que te permite automatizar tus flujos de trabajo de desarrollo de software. Aunque GitHub ofrece runners hospedados, los runners auto-hospedados proporcionan mayor control y personalización para tu configuración de CI/CD. Este tutorial te guía a través de la configuración y conexión de un runner auto-hospedado en un Mac mini para ejecutar pipelines de macOS.

Prerrequisitos

Antes de comenzar, asegúrate de tener:

  • Un Mac mini (regístrate en Macfleet)
  • Un repositorio de GitHub con derechos de administrador
  • Un gestor de paquetes instalado (preferiblemente Homebrew)
  • Git instalado en tu sistema

Paso 1: Crear una Cuenta de Usuario Dedicada

Primero, crea una cuenta de usuario dedicada para el runner de GitHub Actions:

# Crear la cuenta de usuario 'gh-runner'
sudo dscl . -create /Users/gh-runner
sudo dscl . -create /Users/gh-runner UserShell /bin/bash
sudo dscl . -create /Users/gh-runner RealName "GitHub runner"
sudo dscl . -create /Users/gh-runner UniqueID "1001"
sudo dscl . -create /Users/gh-runner PrimaryGroupID 20
sudo dscl . -create /Users/gh-runner NFSHomeDirectory /Users/gh-runner

# Establecer la contraseña para el usuario
sudo dscl . -passwd /Users/gh-runner tu_contraseña

# Agregar 'gh-runner' al grupo 'admin'
sudo dscl . -append /Groups/admin GroupMembership gh-runner

Cambia a la nueva cuenta de usuario:

su gh-runner

Paso 2: Instalar Software Requerido

Instala Git y Rosetta 2 (si usas Apple Silicon):

# Instalar Git si no está ya instalado
brew install git

# Instalar Rosetta 2 para Macs Apple Silicon
softwareupdate --install-rosetta

Paso 3: Configurar el Runner de GitHub Actions

  1. Ve a tu repositorio de GitHub
  2. Navega a Configuración > Actions > Runners

Runner de GitHub Actions

  1. Haz clic en "New self-hosted runner" (https://github.com/<username>/<repository>/settings/actions/runners/new)
  2. Selecciona macOS como imagen del runner y ARM64 como arquitectura
  3. Sigue los comandos proporcionados para descargar y configurar el runner

Runner de GitHub Actions

Crea un archivo .env en el directorio _work del runner:

# archivo _work/.env
ImageOS=macos15
XCODE_15_DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer
  1. Ejecuta el script run.sh en tu directorio del runner para completar la configuración.
  2. Verifica que el runner esté activo y escuchando trabajos en la terminal y revisa la configuración del repositorio de GitHub para la asociación del runner y el estado Idle.

Runner de GitHub Actions

Paso 4: Configurar Sudoers (Opcional)

Si tus acciones requieren privilegios de root, configura el archivo sudoers:

sudo visudo

Agrega la siguiente línea:

gh-runner ALL=(ALL) NOPASSWD: ALL

Paso 5: Usar el Runner en Flujos de Trabajo

Configura tu flujo de trabajo de GitHub Actions para usar el runner auto-hospedado:

name: Flujo de trabajo de muestra

on:
  workflow_dispatch:

jobs:
  build:
    runs-on: [self-hosted, macOS, ARM64]
    steps:
      - name: Instalar NodeJS
        run: brew install node

El runner está autenticado en tu repositorio y etiquetado con self-hosted, macOS, y ARM64. Úsalo en tus flujos de trabajo especificando estas etiquetas en el campo runs-on:

runs-on: [self-hosted, macOS, ARM64]

Mejores Prácticas

  • Mantén tu software del runner actualizado
  • Monitorea regularmente los logs del runner para problemas
  • Usa etiquetas específicas para diferentes tipos de runners
  • Implementa medidas de seguridad apropiadas
  • Considera usar múltiples runners para balanceo de carga

Solución de Problemas

Problemas comunes y soluciones:

  1. Runner no conectando:

    • Verifica conectividad de red
    • Verifica validez del token de GitHub
    • Asegúrate de permisos apropiados
  2. Fallas de construcción:

    • Verifica instalación de Xcode
    • Verifica dependencias requeridas
    • Revisa logs del flujo de trabajo
  3. Problemas de permisos:

    • Verifica permisos de usuario
    • Verifica configuración de sudoers
    • Revisa permisos del sistema de archivos

Conclusión

Ahora tienes un runner auto-hospedado de GitHub Actions configurado en tu Mac mini. Esta configuración te proporciona más control sobre tu entorno de CI/CD y te permite ejecutar flujos de trabajo específicos de macOS de manera eficiente.

Recuerda mantener regularmente tu runner y mantenerlo actualizado con los últimos parches de seguridad y versiones de software.

Aplicación Nativa

Aplicación nativa de Macfleet

Guía de Instalación de Macfleet

Macfleet es una solución poderosa de gestión de flota diseñada específicamente para entornos de Mac Mini alojados en la nube. Como proveedor de hosting en la nube de Mac Mini, puedes usar Macfleet para monitorear, gestionar y optimizar toda tu flota de instancias Mac virtualizadas.

Esta guía de instalación te llevará a través de la configuración del monitoreo de Macfleet en sistemas macOS, Windows y Linux para asegurar una supervisión integral de tu infraestructura en la nube.

🍎 macOS

  • Descarga el archivo .dmg para Mac aquí
  • Haz doble clic en el archivo .dmg descargado
  • Arrastra la aplicación Macfleet a la carpeta Aplicaciones
  • Expulsa el archivo .dmg
  • Abre Preferencias del Sistema > Seguridad y Privacidad
    • Pestaña Privacidad > Accesibilidad
    • Marca Macfleet para permitir el monitoreo
  • Inicia Macfleet desde Aplicaciones
  • El seguimiento comienza automáticamente

🪟 Windows

  • Descarga el archivo .exe para Windows aquí
  • Haz clic derecho en el archivo .exe > "Ejecutar como administrador"
  • Sigue el asistente de instalación
  • Acepta los términos y condiciones
  • Permite en Windows Defender si se solicita
  • Concede permisos de monitoreo de aplicaciones
  • Inicia Macfleet desde el Menú Inicio
  • La aplicación comienza el seguimiento automáticamente

🐧 Linux

  • Descarga el paquete .deb (Ubuntu/Debian) o .rpm (CentOS/RHEL) aquí
  • Instala usando tu gestor de paquetes
    • Ubuntu/Debian: sudo dpkg -i Macfleet-linux.deb
    • CentOS/RHEL: sudo rpm -ivh Macfleet-linux.rpm
  • Permite permisos de acceso X11 si se solicita
  • Agrega el usuario a los grupos apropiados si es necesario
  • Inicia Macfleet desde el menú de Aplicaciones
  • La aplicación comienza el seguimiento automáticamente

Nota: Después de la instalación en todos los sistemas, inicia sesión con tus credenciales de Macfleet para sincronizar datos con tu panel de control.