mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2026-02-11 05:39:45 +08:00
Compare commits
9 Commits
395aacdcdd
...
794e66b335
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
794e66b335 | ||
|
|
41c5b9677a | ||
|
|
116be8badd | ||
|
|
9df4ea095f | ||
|
|
1a253c375a | ||
|
|
67cd8c4673 | ||
|
|
0074e724f8 | ||
|
|
db66764f46 | ||
|
|
8b95897adb |
6
.github/workflows/dependencies.yml
vendored
6
.github/workflows/dependencies.yml
vendored
@ -13,12 +13,12 @@ jobs:
|
|||||||
contents: write # this is needed to push commits and branches
|
contents: write # this is needed to push commits and branches
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
- name: Authenticate as @ohmyzsh
|
- name: Authenticate as @ohmyzsh
|
||||||
@ -28,7 +28,7 @@ jobs:
|
|||||||
app-id: ${{ secrets.OHMYZSH_APP_ID }}
|
app-id: ${{ secrets.OHMYZSH_APP_ID }}
|
||||||
private-key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }}
|
private-key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }}
|
||||||
- name: Setup Python
|
- name: Setup Python
|
||||||
uses: actions/setup-python@83679a892e2d95755f2dac6acb0bfd1e9ac5d548 # v6.1.0
|
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
|
||||||
with:
|
with:
|
||||||
python-version: "3.12"
|
python-version: "3.12"
|
||||||
cache: "pip"
|
cache: "pip"
|
||||||
|
|||||||
8
.github/workflows/installer.yml
vendored
8
.github/workflows/installer.yml
vendored
@ -26,12 +26,12 @@ jobs:
|
|||||||
- macos-latest
|
- macos-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
|
|
||||||
- name: Set up git repository
|
- name: Set up git repository
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||||
- name: Install zsh
|
- name: Install zsh
|
||||||
if: runner.os == 'Linux'
|
if: runner.os == 'Linux'
|
||||||
run: sudo apt-get update; sudo apt-get install zsh
|
run: sudo apt-get update; sudo apt-get install zsh
|
||||||
@ -47,12 +47,12 @@ jobs:
|
|||||||
- test
|
- test
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||||
- name: Install Vercel CLI
|
- name: Install Vercel CLI
|
||||||
run: npm install -g vercel
|
run: npm install -g vercel
|
||||||
- name: Setup project and deploy
|
- name: Setup project and deploy
|
||||||
|
|||||||
4
.github/workflows/main.yml
vendored
4
.github/workflows/main.yml
vendored
@ -24,12 +24,12 @@ jobs:
|
|||||||
if: github.repository == 'ohmyzsh/ohmyzsh'
|
if: github.repository == 'ohmyzsh/ohmyzsh'
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
|
|
||||||
- name: Set up git repository
|
- name: Set up git repository
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||||
- name: Install zsh
|
- name: Install zsh
|
||||||
run: sudo apt-get update; sudo apt-get install zsh
|
run: sudo apt-get update; sudo apt-get install zsh
|
||||||
- name: Check syntax
|
- name: Check syntax
|
||||||
|
|||||||
2
.github/workflows/project.yml
vendored
2
.github/workflows/project.yml
vendored
@ -17,7 +17,7 @@ jobs:
|
|||||||
if: github.repository == 'ohmyzsh/ohmyzsh'
|
if: github.repository == 'ohmyzsh/ohmyzsh'
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
- name: Authenticate as @ohmyzsh
|
- name: Authenticate as @ohmyzsh
|
||||||
|
|||||||
6
.github/workflows/scorecard.yml
vendored
6
.github/workflows/scorecard.yml
vendored
@ -36,12 +36,12 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Harden the runner (Audit all outbound calls)
|
- name: Harden the runner (Audit all outbound calls)
|
||||||
uses: step-security/harden-runner@20cf305ff2072d973412fa9b1e3a4f227bda3c76 # v2.14.0
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
||||||
with:
|
with:
|
||||||
egress-policy: audit
|
egress-policy: audit
|
||||||
|
|
||||||
- name: "Checkout code"
|
- name: "Checkout code"
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||||
with:
|
with:
|
||||||
persist-credentials: false
|
persist-credentials: false
|
||||||
|
|
||||||
@ -60,6 +60,6 @@ jobs:
|
|||||||
retention-days: 5
|
retention-days: 5
|
||||||
|
|
||||||
- name: "Upload to code-scanning"
|
- name: "Upload to code-scanning"
|
||||||
uses: github/codeql-action/upload-sarif@cdefb33c0f6224e58673d9004f47f7cb3e328b89 # v4.31.10
|
uses: github/codeql-action/upload-sarif@45cbd0c69e560cd9e7cd7f8c32362050c9b7ded2 # v4.32.2
|
||||||
with:
|
with:
|
||||||
sarif_file: results.sarif
|
sarif_file: results.sarif
|
||||||
|
|||||||
52
plugins/backupzshrc/README.md
Normal file
52
plugins/backupzshrc/README.md
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
# Oh My Zsh Backup Plugin
|
||||||
|
|
||||||
|
This plugin provides a convenient way to back up your `~/.zshrc` file locally and to a GitHub repository. It automatically detects changes in the `.zshrc` file, commits them with a timestamped message, and pushes changes to the specified GitHub repository. If you ever rm your zshrc, simply go to your Github repo and check it out.
|
||||||
|
|
||||||
|
## Dependencies
|
||||||
|
1. Locally installed git with a git config for pulling the repo url and username
|
||||||
|
2. A repo in Github https://github.com/yourusername/oh-my-zsh-backup
|
||||||
|
Example: https://github.com/yourusername/oh-my-zsh-backup
|
||||||
|
3. Push privileges configured to the main/master origin branch
|
||||||
|
4. Create directory privileges for this script - create "$HOME/projects/backups" manually otherwise
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
1. Clone this repository into your Oh My Zsh custom plugins directory:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/yourusername/oh-my-zsh-backup ~/.oh-my-zsh/custom/plugins/backup
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Add `backup` to the plugins array in your `~/.zshrc` file:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
plugins=(... backup)
|
||||||
|
```
|
||||||
|
|
||||||
|
3. Restart your terminal.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
Simply open your terminal or source your `~/.zshrc` file, and the backup will be triggered automatically. Any changes detected in `~/.zshrc` will be backed up to the specified GitHub repository.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
### GitHub Username
|
||||||
|
|
||||||
|
If your GitHub username is not already set globally, the plugin will prompt you to enter it the first time you run it. Alternatively, you can set it manually using:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git config --global user.name "Your Username"
|
||||||
|
```
|
||||||
|
|
||||||
|
### Branch
|
||||||
|
|
||||||
|
By default, the plugin pushes changes to the branch specified GitHub repository is checked out to locally in the "$HOME/projects/backups" backup directory. You can change the target branch by checking out to a new branch in the backup directory.
|
||||||
|
|
||||||
|
## Contributions
|
||||||
|
|
||||||
|
Contributions are welcome! If you encounter any issues or have suggestions for improvements, please feel free to open an issue or submit a pull request on GitHub.
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
This plugin is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.
|
||||||
54
plugins/backupzshrc/backupzshrc.plugin.zsh
Normal file
54
plugins/backupzshrc/backupzshrc.plugin.zsh
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
function backup_zshrc() {
|
||||||
|
# Function to back up ~/.zshrc locally and to a GitHub repository
|
||||||
|
# Runs every time zsh is opened or source ~/.zshrc is run
|
||||||
|
# Checks for git changes, will commit and push changes if detected
|
||||||
|
#
|
||||||
|
|
||||||
|
local current_dir=$(pwd)
|
||||||
|
local backup_dir="$HOME/projects/backups"
|
||||||
|
github_username=$(git config --global user.name | tr '[:upper:]' '[:lower:]' | tr -d '[:space:]')
|
||||||
|
local commit_message="Backup ~/.zshrc at $(date +'%Y_%m_%d-%H%M%S')"
|
||||||
|
|
||||||
|
# Prompt for GitHub username if not set
|
||||||
|
if [[ -z "$github_username" ]]; then
|
||||||
|
read -p "Enter your GitHub username: " github_username
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create a backup directory if it doesn't exist
|
||||||
|
mkdir -p "$backup_dir"
|
||||||
|
|
||||||
|
cd "$backup_dir" || return
|
||||||
|
|
||||||
|
# Backup ~/.zshrc with a timestamp
|
||||||
|
local timestamp=$(date +'%Y_%m_%d-%H%M%S')
|
||||||
|
local backup_file="$backup_dir/zshrc_backup_$timestamp"
|
||||||
|
cp "$HOME/.zshrc" "$backup_dir/.zshrc"
|
||||||
|
|
||||||
|
changes=$(git diff --quiet --exit-code -- "$backup_dir" || echo "yes")
|
||||||
|
|
||||||
|
if [[ "$changes" == "yes" ]]; then
|
||||||
|
echo "Changes detected in $backup_dir/.zshrc"
|
||||||
|
cp "$HOME/.zshrc" "$backup_file"
|
||||||
|
git add . > /dev/null 2>&1
|
||||||
|
if git commit -m "$commit_message" > /dev/null 2>&1; then
|
||||||
|
if git push > /dev/null 2>&1; then
|
||||||
|
repo_url="https://github.com/$github_username/backups"
|
||||||
|
echo "Backup successfully pushed to GitHub. View it at: $repo_url"
|
||||||
|
else
|
||||||
|
push_error=$(git push 2>&1)
|
||||||
|
echo "Error: Failed to push backup to GitHub. Error details: $push_error"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
commit_error=$(git commit -m "$commit_message" 2>&1)
|
||||||
|
echo "Error: Failed to commit changes for backup. Error details: $commit_error"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "No changes detected in $backup_dir for .zshrc"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd "$backup_dir" || return
|
||||||
|
git add . > /dev/null 2>&1
|
||||||
|
cd "$current_dir" || return
|
||||||
|
}
|
||||||
|
|
||||||
|
backup_zshrc
|
||||||
Loading…
Reference in New Issue
Block a user