Back to Blog

How to Restore Deleted GitHub Repositories: Complete Recovery Guide for 2023

How to Restore Deleted GitHub Repositories: Complete Recovery Guide for 2023

Introduction

Accidentally deleting a GitHub repository can feel like a disaster, especially when it contains important code, documentation, or project history. Fortunately, GitHub provides a safety net by keeping deleted repositories recoverable for a limited time. This comprehensive guide will walk you through the exact steps to restore your deleted GitHub repositories and share best practices to prevent accidental deletions in the future.

Understanding GitHub's Repository Deletion Policy

Before diving into the recovery process, it's important to understand GitHub's deletion policy:

  • Deleted repositories are retained for 90 days after deletion
  • After 90 days, the repository and all its data are permanently deleted
  • Repository restoration may take up to an hour to complete
  • You must have admin or owner permissions to restore a repository
  • Restored repositories retain all their previous data, including issues, pull requests, and commit history

This policy applies to both personal accounts and organizations, providing a reasonable window for recovery while also respecting data deletion requirements.

Step-by-Step Repository Restoration Process

Follow these detailed steps to recover your deleted GitHub repository:

1. Log in to Your GitHub Account

Access your GitHub account with the credentials associated with the deleted repository.

2. Navigate to Account Settings

Click on your profile icon in the top-right corner of GitHub and select Settings from the dropdown menu.

GitHub Settings Navigation

3. Access the Repositories Section

In the left sidebar, find the "Code, planning, and automation" category and click on Repositories.

GitHub Repositories Section

4. Find Deleted Repositories

Scroll down to find and click the Deleted repositories button near the bottom of the page.

Deleted Repositories Button

5. Restore Your Repository

You'll see a list of all repositories deleted within the last 90 days. Find the repository you want to restore and click the Restore button next to it.

After confirming the action, GitHub will begin the restoration process, which may take several minutes to complete depending on the repository's size.

Troubleshooting Common Restoration Issues

If you encounter problems during the restoration process, consider these common solutions:

Repository Not Listed in Deleted Repositories

If your repository isn't visible in the deleted repositories list, check these possible causes:

  • Time limit exceeded: The 90-day recovery period may have passed
  • Permission issues: You may not have the required admin permissions
  • Different account: The repository might have been under a different user or organization account

Partial Data Recovery

In some cases, not all repository data may be restored. This is often related to:

  • Large LFS files: Large files stored with Git LFS might require separate restoration
  • Action logs: Certain GitHub Actions logs might not persist through restoration
  • Webhook configurations: Custom webhook settings may need to be reconfigured

Preventing Accidental Repository Deletions

The best recovery strategy is prevention. Here are effective ways to protect your repositories:

Repository Settings Protections

For valuable repositories, consider these safeguards:

  1. Make repositories private instead of deleting them if you're unsure
  2. Archive repositories that are no longer active but contain valuable information
  3. Enable deletion protection for organization repositories in the organization settings

Regular Backup Strategies

Implement these backup practices for critical repositories:

# Clone repository with all branches and tags
git clone --mirror https://github.com/username/repository.git

# Create regular local backups using cron jobs or scheduled tasks
# Example cron job (Linux/Mac) to back up weekly
# 0 0 * * 0 cd /path/to/backups && git clone --mirror https://github.com/username/repository.git

Documentation Best Practices

Maintain clear documentation about your repositories:

  • Keep an inventory of all important repositories
  • Document repository purposes and relationships
  • Record external dependencies and integration points

Beyond Basic Recovery: Advanced Considerations

Recovering Specific Repository Elements

Sometimes you need to recover specific parts of a repository rather than the entire thing:

  • Recovering specific commits: Use git reflog in a recent clone to find and restore specific commits
  • Extracting code from archived repositories: Clone and extract only the needed portions
  • Forking before deletion: Create a fork as a backup before planned deletions

Organization-Level Recovery Policies

For GitHub organizations, establish clear policies:

  • Designate specific admins responsible for repository recovery
  • Create a recovery request workflow for team members
  • Document the timeline and process for restoration requests

Conclusion

GitHub's repository recovery system provides a valuable safety net for accidental deletions, but it's crucial to act within the 90-day window. By following the steps outlined in this guide, you can successfully restore your deleted repositories and recover your valuable code and project history.

Remember that prevention is always better than recovery. Implementing proper backup strategies and careful repository management practices will help ensure you never permanently lose important work.

Looking to improve your GitHub repository management beyond just recovery? Check out Gitdash for tools that help you organize, manage, and optimize your GitHub workflow.

Have you ever had to recover a deleted GitHub repository? Share your experience in the comments below!