Hilft Dir dabei, Deine BÜNDNIS 90/DIE GRÜNEN Website zu optimieren https://green-spider.netzbegruenung.de/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
dependabot[bot] 935f4c30a1
Bump alpine from 3.14 to 3.15.0
11 hours ago
.github Upgrade to GitHub-native Dependabot (#203) 7 months ago
checks Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
config Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
devops Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
export Fix full JSON export 3 years ago
kubernetes Veraltetes K8s Job-Beispiel löschen (#233) 2 weeks ago
manager Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
rating Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
spider Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
.dockerignore Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
.gitignore Ignore k8s-jobs 3 weeks ago
.travis.yml Fehlerbehebung im url_reachability check (#108) 3 years ago
Dockerfile Bump alpine from 3.14 to 3.15.0 11 hours ago
KRITERIEN.md Liste der Qualitätskriterien aktualisiert (#155) 2 years ago
LICENSE Create LICENSE 3 years ago
Makefile Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
README.md Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
cli.py Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
docker-compose.yaml Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
index.yaml Add webapp deployment (#87) 3 years ago
job.py Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
k8s-job-manager.py Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago
requirements.txt Job-Verwaltung mit RQ, und vieles mehr (#149) 3 weeks ago

README.md

Green Spider

Initiative und Tools zur Förderung eines benutzer*innenfreundlichen Auftritts von Bündnis 90/Die Grünen im Web.

Zur Auswertung: https://green-spider.netzbegruenung.de/

Tools

Aktivitäten

Es ist geplant, auf Basis der gesammelten Informationen (siehe Spider) Informationen an die Betreiber*innen der Websites zu versenden. Hierzu müssen Prozesse erarbeitet und vermutlich weitere Tools geschaffen werden.

Community

Green Spider ist ein Projekt des netzbegrünung e. V. -- Mitwirkung ist herzlich willkommen.

Zur Kommunikation dient der Chatbegrünung-Kanal #green-spider sowie die Issues hier in diesem Repository.

Betrieb

Alle Informationen zum Betrieb befinden sich im Verzeichnis devops.

Entwicklung

Green Spider ist in Python 3 geschrieben und wird aktuell unter 3.6 getestet und ausgeführt.

Aufgrund zahlreicher Abhängigkeiten empfiehlt es sich, den Spider Code lokal in Docker auszuführen.

Das Image wird über den folgenden Befehl erzeugt:

make

Das dauert beim ersten Ausführen einige Zeit, wiel einige Python-Module das Kompilieren diverser Libraries erfordern. Nach dem ersten erfolgreichen Durchlauf dauert ein neuer Aufruf von make nur noch wenige Sekunden.

Tests ausführen

In aller Kürze: make test

Spider testweise ausführen (Debugging)

Der Spider kann einzelne URLs verarbeiten, ohne die Ergebnisse in eine Datenbank zu schreiben. Am einfachsten geht das über den make spider Befehl, so:

make spider ARGS="--url http://www.example.com/"

Ohne ARGS aufgerufen, arbeitet der Spider eine Jobliste ab. Dies erfordert Zugriff auf die entsprechende Datenbank.

Wenn nur eine einzelne Site gespidert werden soll, die Ergebnisse aber in die Datenbank geschrieben werden sollen, kann der Spider so mit --job und einem JSON-Object aufgerufen werden (Beispiel):

docker run --rm -ti \
  -v $(pwd)/volumes/dev-shm:/dev/shm \
  -v $(pwd)/secrets:/secrets \
  -v $(pwd)/screenshots:/screenshots \
  -v $(pwd)/volumes/chrome-userdir:/opt/chrome-userdir \
  --shm-size=2g \
  quay.io/netzbegruenung/green-spider:latest python3 cli.py \
    --credentials-path /secrets/datastore-writer.json \
    --loglevel debug \
    spider --job '{"url": "https://gruene-porta-westfalica.de/", "city": "Porta Westfalica", "country": "DE", "district": "Minden-Lübbecke", "level": "DE:ORTSVERBAND", "state":" Nordrhein-Westfalen", "type": "REGIONAL_CHAPTER"}'