#obsidian, #git, #sync, #windows, #cron, #task scheduler, #powershell
Syncing Obsidian in Windows with Windows Task Scheduler and git
Obsidian is a powerful note-taking and knowledge management tool that has gained a dedicated following among researchers, writers, and knowledge workers. To make the most of Obsidian, it's essential to keep your notes synchronized across devices and ensure your data is regularly backed up.Obsidian is the private and flexible writing app that adapts to the way you think.
Obsidian is free for personal use.It does not charge based on features or usage.You only pay if you use Obsidian commercially.
In this article, we'll guide you through the process of setting up automated synchronization for your Obsidian vault on Windows using Windows Task Scheduler and a PowerShell script.1
Before we dive into setting up the synchronization task, ensure you have the following prerequisites in place:
Obsidian Installed: Make sure Obsidian is installed on your Windows computer, and you have an existing Obsidian vault that you want to sync.
Git Installed: You'll need Git installed and configured with your Obsidian vault's repository. If you haven't already done this, you can download Git from the official website and follow the installation instructions.
PowerShell Script: The provided PowerShell script, sync.ps1, should be located in your Obsidian vault folder.
The provided PowerShell script, sync.ps1, is the heart of our synchronization task. It automates the process of committing changes in your Obsidian vault's Git repository and pushing them to your remote repository (e.g., GitHub or GitLab). Here's a brief overview of the script:
# Define the folder path
$FolderPath = "C:\path\to\obsidian-vault"
# Change directory to the repository folder
Set-Location -Path $FolderPath
# Check if the working tree is clean
$IsClean = (git diff-index --quiet HEAD --) -or (git diff-files --quiet)
if ($IsClean) {
Write-Host "Working tree is clean. Skipping commit and pushing changes."
git push
} else {
# Get the current date in the desired format (Day - Date)
$CommitMessage = "$(Get-Date -Format 'dddd - yyyy-MM-dd HH:mm:ss')"
# Commit the changes
git add .
git commit -m $CommitMessage
# Push the changes
git push
}
This script does the following:
Now that we have our PowerShell script ready, let's set up a scheduled task using Windows Task Scheduler to automate the synchronization process. Follow these steps:
Open an Elevated PowerShell Prompt: To run the necessary commands, open PowerShell as an administrator.
Define Task Variables: Execute the following commands to define variables for your task:
$ScriptPath = "C:\path\to\obsidian-vault\sync.ps1"
$TaskName = "obsidian-sync"
$UserAccount = "$env:USERDOMAIN\$env:USERNAME"
Replace $ScriptPath with the actual path to your sync.ps1 script, $TaskName with a name for your task.
Configure Task Trigger: Set up a trigger for your task. In this example, we'll schedule the task to run daily at 9:00 PM:
$Trigger = New-ScheduledTaskTrigger -Daily -At '9:00 PM'
You can adjust the schedule according to your preference.
Define Task Principal and Settings: Configure the task's principal (the user account under which the task will run) and settings:
$Principal = New-ScheduledTaskPrincipal -UserId $UserAccount -RunLevel Highest
$Settings = New-ScheduledTaskSettingsSet -AllowStartIfOnBatteries -RunOnlyIfNetworkAvailable -WakeToRun
These settings ensure that the task runs with the necessary privileges and conditions.
Define Task Action: Specify the action that the task will perform, which is running the PowerShell script:
$Action = New-ScheduledTaskAction -Execute 'PowerShell.exe' -Argument "-ExecutionPolicy Bypass -WindowStyle Hidden -File `"$ScriptPath`""
This action runs PowerShell with the provided script.
Create the Scheduled Task: Finally, create the scheduled task and register it with Windows Task Scheduler:
$Task = New-ScheduledTask -Action $Action -Trigger $Trigger -Principal $Principal -Settings $Settings
Register-ScheduledTask -TaskName $TaskName -InputObject $Task
The Obsidian synchronization task is now set up and ready to run automatically based on the schedule you defined.
When looking up on how to implement this I found some breakthrough from this stack overflow post. There are suggestions on how to do this using cron jobs in wsl. They are worth a look at. This article on powershell with windows server was also helpful.
This method is only optimal for desktop sync. To sync across devices obsidian has a paid plan that has some extra features Such as Sync notes across devices, End-to-end encryption, Version history, Priority email support. Consider checking it out at https://obsidian.md/pricing