Github-archive

Latest version: v6.3.0

Safety actively analyzes 723625 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 4 of 6

4.1.0

- Adds a new `--https` flag which will authenticate via HTTPS instead of the default `SSH`
- Fixes a bug where using the `--stars` flag would not properly run due to a missing parameter. This parameter wasn't actually being used anymore and has been removed. Tests were beefed up for this function to protect against this happening again

4.0.0

Breaking Changes

- Reworks the entire app config to use CLI flags solely instead of a mix of CLI flags and env variables, additionally, most flags have changed names and functionality. See the README for new usage instructions or run `github-archive --help` (closes 30)
- Repos or gists that fail to clone or pull will now be completely removed so that they can be retried from scratch on the next run of the tool. This was an especially important change for bad clones as the tool would previously leave an empty initialized git folder even if the clone failed which would not possess the actual git repo yet. In this state, you could not properly pull new changes because the content of the repo hadn't properly been cloned yet
- Bumps required Python version from 3.6 to 3.7

Features

- Adds a new `--users` flag which can be used to clone or pull git assets for a list of comma separated users (closes 20)
- Adds a new `--threads` flag which can specify the number of concurrent threads to run at once, default is `10` (closes 22)
- Adds a new `--view` flag which allows you to "dry run" the application, seeing the entire list of repos and gists based on the input provided (closes 25)
- Adds a new `--stars` flag which you can pass a comma separated list of users to and GitHub Archive will retrieve all of their starred repos which you can then view, clone, or pull (closes 26)
- Adds a new `--forks` flag which will include forks for whatever lists and operations you provide, default is `False` (closes 17))

Fixes

- Removed verbose logging of skipped actions and "Already up to date" messages. Added additional logging related to API calls
- Added proper validation and type checking of variables and environment on startup
- Various code refactors, bug fixes, and optimizations
- Bumped the default git operation timeout from `180 seconds` to `300 seconds` to assist with cloning or pulling larger repos (closes 22)
- Removes `mock` library in favor of builtin `unittest.mock` library

3.1.1

- Removed `branch` flag and functionality as it was causing issues and inconsistencies when cloning/pulling and branches didn't match up. This became especially prevelant when repos started changing from `master` to `main`

3.1.0

- Changed all classmethods to staticmethods
- Corrected a bug where org names may not have had whitespace stripped properly
- CLI arguments now have an explicit default of `False`, this shouldn't change behavior from previous versions
- CLI default argument for `branch` has been changed from `master` to `None` and is handled via logic now. If no branch is specified, the default repo branch will be used instead of blindly assuming that `master` is the default branch (closes 18)
- Revamped the entire test suite to use conftest, simplified boilerplate, etc

3.0.1

- Fixed broken entrypoint after shifting code around

3.0.0

- Refactored the entire codebase to be more pythonic, simpler, DRY, and documented (closes 15)
- Better error handling by raising errors where applicable and switching from a homegrown logger to the built-in Python logger (closes 12)
- Added unit tests and test coverage (closes 14)
- Added various additional configuration options
- Automated releasing on PyPi via Travis
- Various bug fixes throughout
- Better documentation on exactly what is possible with this tool
- Added a Makefile
- Adjusted most of the command and option names to be more uniform and explicit

Page 4 of 6

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.