2
0
mirror of https://github.com/WikiTeam/wikiteam synced 2024-11-18 21:27:45 +00:00
wikiteam/listsofwikis/checkalive.py
2014-01-05 10:50:18 +00:00

63 lines
1.7 KiB
Python

#!/usr/bin/python
# -*- coding: utf-8 -*-
# Copyright (C) 2011-2012 WikiTeam
# 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/>.
# Script to check if a list of wikis are alive or dead
import thread
import time
import sys
import urllib2
import re
#configuration
delay = 10
limit = 100
def printapi(api):
print api, 'is alive'
open('wikisalive.txt', 'a').write(('%s\n' % api.strip()).encode('utf-8'))
def checkcore(api):
try:
raw = urllib2.urlopen(api, None, delay).read()
if '&lt;api' in raw:
printapi(api)
else:
rsd = re.search(r'(?:link rel="EditURI".+href=")(?:https?:)?(.+api.php)\?action=rsd', raw)
if rsd:
api = 'http:' + rsd.group(1)
printapi(api)
except:
print api, 'is dead or has errors'
pass
def check(apis):
for api in apis:
thread.start_new_thread(checkcore, (api,))
time.sleep(0.1)
time.sleep(delay+1)
apis = []
for api in open('wikistocheck.txt', 'r').read().strip().splitlines():
if not api in apis:
apis.append(api)
if len(apis) >= limit:
check(apis)
apis = []
check(apis)