刘凡 9ff4d1d109 add S3,archive,truncate 2 years ago
..
iagitup 9ff4d1d109 add S3,archive,truncate 2 years ago
.gitignore 9ff4d1d109 add S3,archive,truncate 2 years ago
LICENSE 9ff4d1d109 add S3,archive,truncate 2 years ago
README.md 9ff4d1d109 add S3,archive,truncate 2 years ago
requirements.txt 9ff4d1d109 add S3,archive,truncate 2 years ago
setup.cfg 9ff4d1d109 add S3,archive,truncate 2 years ago
setup.py 9ff4d1d109 add S3,archive,truncate 2 years ago

README.md

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/.