# macOS Default Sandbox Debug {{#include ../../../../banners/hacktricks-training.md}} На цій сторінці ви можете знайти, як створити додаток для запуску довільних команд зсередини стандартного пісочниці macOS: 1. Скомпілюйте додаток: ```objectivec:main.m #include int main(int argc, const char * argv[]) { @autoreleasepool { while (true) { char input[512]; printf("Enter command to run (or 'exit' to quit): "); if (fgets(input, sizeof(input), stdin) == NULL) { break; } // Remove newline character size_t len = strlen(input); if (len > 0 && input[len - 1] == '\n') { input[len - 1] = '\0'; } if (strcmp(input, "exit") == 0) { break; } system(input); } } return 0; } ``` Скомпілюйте, запустивши: `clang -framework Foundation -o SandboxedShellApp main.m` 2. Створіть пакет `.app` ```bash mkdir -p SandboxedShellApp.app/Contents/MacOS mv SandboxedShellApp SandboxedShellApp.app/Contents/MacOS/ cat << EOF > SandboxedShellApp.app/Contents/Info.plist CFBundleIdentifier com.example.SandboxedShellApp CFBundleName SandboxedShellApp CFBundleVersion 1.0 CFBundleExecutable SandboxedShellApp EOF ``` 3. Визначте права доступу {{#tabs}} {{#tab name="sandbox"}} ```bash cat << EOF > entitlements.plist com.apple.security.app-sandbox EOF ``` {{#endtab}} {{#tab name="пісочниця + завантаження"}} ```bash cat << EOF > entitlements.plist com.apple.security.app-sandbox com.apple.security.files.downloads.read-write EOF ``` {{#endtab}} {{#endtabs}} 4. Підпишіть додаток (вам потрібно створити сертифікат у ключниці) ```bash codesign --entitlements entitlements.plist -s "YourIdentity" SandboxedShellApp.app ./SandboxedShellApp.app/Contents/MacOS/SandboxedShellApp # An d in case you need this in the future codesign --remove-signature SandboxedShellApp.app ``` {{#include ../../../../banners/hacktricks-training.md}}