iagitup
iagitup copied to clipboard
A command line tool to archive a git repository from GitHub to the Internet Archive.
iagitup - a command line tool to archive a GitHub repository to the Internet Archive
The python script downloads the GitHub repository, creates a git bundle and uploads it on an Internet Archive item with metadata from the GitHub API and a description from the repository readme.
Prerequisites
This script strongly recommends Linux or some sort of POSIX system (such as Mac OS X).
- Internet Archive Account - If you don't already have an account on archive.org, register.
- Python - This script should work with Python 3.9.
- libffi-dev and libssl-dev
- git
Install iagitup
Prerequisites (with Debian or Ubuntu):
sudo apt update
sudo apt install python python-pip python-dev libffi-dev libssl-dev git
from source code:
Clone the repo and install the package...
git clone https://github.com/gdamdam/iagitup.git
cd iagitup
pip install .
Usage
To upload a repo:
iagitup <github_repo_url>
You can add also custom metadata:
iagitup --metadata=<key:value,key2:val2> <github_repo_url>
To know the version:
iagitup -v
Example:
iagitup https://github.com/<GITHUBUSER>/<RESPOSITORY>
The script downloads the git repo from github, creates a git bundle and uploads it on the Internet Archive.
The repo will be archived in an item at url containing the repository name and the date of the last push, something like:
https://archive.org/details/github.com-<GITHUBUSER>-<RESPOSITORY>_-_<DATE-LAST-PUSH>
The git repo bundle will be available at url:
https://archive.org/download/github.com-<GITHUBUSER>-<RESPOSITORY>_-_<DATE-LAST-PUSH>/<BUNDLENAME>.bundle
Restore an archived github repository
Download the bundle file, form the archived item:
https://archive.org/download/.../<ARCHIVED_REPO>.bundle
Just download the .bundle file and run:
git clone file.bundle
License (GPLv3)
Copyright (C) 2017-2018 Giovanni Damiola
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.