add documentation on how to use macOS
This commit is contained in:
@@ -77,6 +77,7 @@ nav:
|
|||||||
- Migrate existing Flakes: guides/migrations/migration-guide.md
|
- Migrate existing Flakes: guides/migrations/migration-guide.md
|
||||||
- Migrate inventory Services: guides/migrations/migrate-inventory-services.md
|
- Migrate inventory Services: guides/migrations/migrate-inventory-services.md
|
||||||
- Facts Vars Migration: guides/migrations/migration-facts-vars.md
|
- Facts Vars Migration: guides/migrations/migration-facts-vars.md
|
||||||
|
- MacOS: guides/macos.md
|
||||||
- Reference:
|
- Reference:
|
||||||
- Overview: reference/index.md
|
- Overview: reference/index.md
|
||||||
- Clan Services:
|
- Clan Services:
|
||||||
|
|||||||
93
docs/site/guides/macos.md
Normal file
93
docs/site/guides/macos.md
Normal file
@@ -0,0 +1,93 @@
|
|||||||
|
# Managing macOS Machines with Clan
|
||||||
|
|
||||||
|
This guide explains how to manage macOS machines using Clan.
|
||||||
|
|
||||||
|
## Supported Features
|
||||||
|
|
||||||
|
Currently, Clan supports the following features for macOS:
|
||||||
|
|
||||||
|
- `clan machines update` for existing [nix-darwin](https://github.com/nix-darwin/nix-darwin) installations.
|
||||||
|
- Support for [vars](../guides/vars-backend.md).
|
||||||
|
|
||||||
|
## Step 1: Add Your Machine to Your Clan Flake
|
||||||
|
|
||||||
|
In this example, we'll name the machine `yourmachine`. Replace this with your preferred machine name.
|
||||||
|
|
||||||
|
=== "**If using core.lib.buildClan**"
|
||||||
|
|
||||||
|
```nix
|
||||||
|
buildClan {
|
||||||
|
inventory = {
|
||||||
|
machines.yourmachine.machineClass = "darwin";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
=== "**If using flake-parts**"
|
||||||
|
|
||||||
|
```nix
|
||||||
|
{
|
||||||
|
clan = {
|
||||||
|
inventory = {
|
||||||
|
machines.yourmachine.machineClass = "darwin";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 2: Add a `configuration.nix` for Your Machine
|
||||||
|
|
||||||
|
Create the file `./machines/yourmachine/configuration.nix` with the following content (replace `yourmachine` with your chosen machine name):
|
||||||
|
|
||||||
|
```nix
|
||||||
|
{
|
||||||
|
clan.core.networking.targetHost = "root@ip_or_hostname";
|
||||||
|
nixpkgs.hostPlatform = "aarch64-darwin"; # Use "x86_64-darwin" for Intel-based Macs
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
After creating the file, run `git add` to ensure Nix recognizes it.
|
||||||
|
|
||||||
|
## Step 3: Generate Vars (If Needed)
|
||||||
|
|
||||||
|
If your machine uses vars, generate them with:
|
||||||
|
|
||||||
|
```
|
||||||
|
clan vars generate yourmachine
|
||||||
|
```
|
||||||
|
|
||||||
|
Replace `yourmachine` with your chosen machine name.
|
||||||
|
|
||||||
|
## Step 4: Install Nix
|
||||||
|
|
||||||
|
Install Nix on your macOS machine using one of the methods described in the [nix-darwin prerequisites](https://github.com/nix-darwin/nix-darwin?tab=readme-ov-file#prerequisites).
|
||||||
|
|
||||||
|
|
||||||
|
## Step 4: Install darwin-nix
|
||||||
|
|
||||||
|
For installation the `clan flake` needs to be uploaded to the macOS machine.
|
||||||
|
Run this command inside your flake (replacing `yourmachine` with the name chosen in Step 1)
|
||||||
|
|
||||||
|
```command
|
||||||
|
sudo nix run nix-darwin/master#darwin-rebuild -- switch --flake .#yourmachine
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 5: Install nix-darwin
|
||||||
|
|
||||||
|
Upload your Clan flake to the macOS machine. Then, from within your flake directory, run:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
sudo nix run nix-darwin/master#darwin-rebuild -- switch --flake .#yourmachine
|
||||||
|
```
|
||||||
|
|
||||||
|
Replace `yourmachine` with your chosen machine name.
|
||||||
|
|
||||||
|
## Step 6: Manage Your Machine with Clan
|
||||||
|
|
||||||
|
Once all the steps above are complete, you can start managing your machine with:
|
||||||
|
|
||||||
|
```
|
||||||
|
clan machines update yourmachine
|
||||||
|
```
|
||||||
|
|
||||||
|
This command can be run from any computer that can reach this machine via SSH.
|
||||||
@@ -44,6 +44,12 @@ hide:
|
|||||||
|
|
||||||
Discover how to set up a development environment to contribute to Clan!
|
Discover how to set up a development environment to contribute to Clan!
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Manage macOS machines with nix-darwin
|
||||||
|
|
||||||
|
- [MacOS machines](./guides/macos.md)
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
## API Reference
|
## API Reference
|
||||||
|
|||||||
Reference in New Issue
Block a user