Source code of PyDigger
See the about page on the web site for some explanation.
See the Video recording series following the development of the application. Specifically in the first episode you can see an explanation about it.
- Clone the repository.
git clone https://github.com/szabgab/pydigger.com
- Install Docker.
- Install docker-compose.
- Copy
config-skeleton.yml
todev.yml
. - Sign up to GitHub
- Create a Personal access token with a name that you can easily recognize, e.g. "PyDigger Development Token" using the following rights:
repo
x public_repo
user
x read:user
x user:email
- Save the token it in the
dev.yml
file in thegithub-token
field. - Copy
docker-compose.override.yml.example
todocker-compose.override.yml
and personalize it if necessary.
In one terminal:
docker-compose up --build
Visit the web page at http://localhost:6001 At this point the database is empty.
docker exec -it pydiggercom_cron_1 bash
To run the tests type in
pytest --cache-clear -vs
We could also use the flake8 flag but due to a bug pytest-flake8 does not work with the recent versions of flake8.
pytest --cache-clear --flake8 -vs
To collect data from a single GitHub repository:
python fetch_recent.py --update url --url https://github.com/szabgab/pydigger.com --log DEBUG --screen
To collect data for a single PyPI package:
python fetch_recent.py --update package --package <PyPI package name> --log DEBUG --screen
For example:
python fetch_recent.py --update package --package flask --log DEBUG --screen
Fetch data of recently uploaded packages using the RSS feed of PyPI:
python fetch_recent.py --update rss --screen --log DEBUG
python fetch_recent.py --update deps --screen --log DEBUG
$ docker exec -it pydiggercom_mymongo_1 bash
# mongo -u root -p Secret # to login to mongodb
> use pydigger # pydigger is our database name
> db.dropDatabase() # To drop the pydigger database
> db.packages.find() # To list all the entries
Cleaning up database (during development)
docker exec pydiggercom_web_1 python remove_db.py
ssh to the server and run
./deploy.sh
Copyright 2023 Gábor Szabó
The source code in this repository is licensed under the MIT License.
The content of the site as collected from the various sources are copyright the respective parties.
- Upasana Shukla
- Ed Sabol
- Greg Lawrance