Go to file Use this template
Pallab91 11b10d4bf6 # 2025-02-28 01:37:16 +05:30
.editorconfig use LF instead of CRLF (#28) 2022-04-15 14:13:31 -04:00
.eslintignore fix .eslintignore (#48) 2023-01-19 10:06:51 -05:00
.eslintrc add version bump script (#10) 2022-01-22 16:13:50 -05:00
.gitignore Update .gitignore (#25) 2022-01-28 10:34:53 -05:00
.npmrc add version bump script (#10) 2022-01-22 16:13:50 -05:00
LICENSE Add license, fixes #98 2025-01-27 21:38:01 +00:00
README.md # 2025-02-28 01:37:16 +05:30
esbuild.config.mjs build: minify prod build 2023-11-15 14:10:43 -05:00
main.ts # 2025-02-28 01:25:26 +05:30
manifest.json # 2025-02-28 01:26:49 +05:30
package.json Upgrade esbuild to v0.17.x (#47) 2023-01-25 13:49:50 -05:00
styles.css Update sample css file. 2022-08-09 13:39:02 -04:00
tsconfig.json Fix inconsistent indentation 2024-01-19 21:14:58 +02:00
version-bump.mjs add version bump script (#10) 2022-01-22 16:13:50 -05:00
versions.json Update for 0.15 2022-08-09 13:38:50 -04:00

README.md

GitHub Sync Plugin for Obsidian

🌟 Overview

This GitHub Sync Plugin allows you to synchronize your Obsidian notes with a GitHub repository using the GitHub API (without isomorphic-git). It works across Windows, Linux, Android, and iOS.

🚀 Features

  • Clone repository (manual setup required)
  • Pull latest changes from GitHub
  • Commit with a default message #
  • Push changes to GitHub
  • Authentication via GitHub Personal Access Token (hidden after first input)

📥 Installation

From Obsidian Community Plugins

  1. Open Obsidian and go to Settings → Community Plugins.
  2. Click Browse, search for GitHub Sync, and click Install.
  3. Enable the plugin from the Installed Plugins list.

Manual Installation

  1. Download the latest release from GitHub Releases.
  2. Copy these files to your Obsidian plugin directory:
    • dist/main.js
    • manifest.json
    • versions.json
  3. Restart Obsidian and enable the plugin from Settings → Community Plugins.

Plugin Folder Path:

  • Windows: %APPDATA%\Obsidian\plugins\github-sync
  • Linux: ~/.config/Obsidian/plugins/github-sync
  • Android: /storage/emulated/0/Obsidian/.obsidian/plugins/github-sync
  • iOS: (Community Plugin installation required)

🔧 Setup

  1. Go to Plugin Settings (Settings → Community Plugins → GitHub Sync)
  2. Enter your GitHub details:
    • Repository Owner (your GitHub username or organization)
    • Repository Name
    • Branch Name (default: main)
    • Authentication Token (hidden after first input)
    • Folder Path (subfolder in repo to sync, default: /)
  3. Save settings and restart Obsidian.

📌 Usage

Pull Latest Changes

  1. Open Command Palette (Ctrl + P or Cmd + P on macOS)
  2. Search for Pull from GitHub and execute it.
  3. The latest changes will be downloaded into Obsidian.

Commit & Push

  1. Open Command Palette
  2. Search for Commit & Push and execute it.
  3. All files in the specified folder will be committed and pushed with the message #.

🛠️ Build from Source

To build this plugin from source:

npm install
npm run build

This generates the dist/ folder with the necessary files.

📢 Contributing

Want to improve this plugin? Feel free to fork this repository and submit a pull request!

📜 License

This project is licensed under the MIT License.

FAQ

Why is my authentication token hidden after first input?

This is a security feature to prevent accidental exposure of your GitHub token.

Can I sync only a specific folder from my repository?

Yes! Set the Folder Path in settings to the specific subfolder you want to sync.

How do I update the plugin?

Download the latest version and replace the existing files in your Obsidian plugin folder, or update via the Obsidian Community Plugins tab.


🚀 Enjoy seamless GitHub sync in Obsidian!