PageRenderTime 57ms CodeModel.GetById 11ms RepoModel.GetById 1ms app.codeStats 0ms

/Arkbot/post.py

https://github.com/Arkanosis/Wikipedia
Python | 85 lines | 69 code | 8 blank | 8 comment | 4 complexity | d9f62bdcfb1b5bd38ac52de57ecb2902 MD5 | raw file
  1. #! /usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. # Post v0.1
  4. # (C) 2010 Arkanosis
  5. # jroquet@arkanosis.net
  6. # http://github.com/Arkanosis/Wikipedia/Arkbot
  7. # Ce script est mis à disposition sous licence MIT
  8. # http://www.opensource.org/licenses/mit-license.php
  9. import datetime
  10. import getpass
  11. import logging
  12. import sys
  13. import time
  14. import arkbot
  15. import utils
  16. def post(bot, filename, dump, mode, debug):
  17. if mode == 1:
  18. _page = 'Projet:Pages en impasse/liste des pages en impasse'
  19. _summary = 'Pages en impasse au %s' % dump
  20. _pages = 'en impasse'
  21. elif mode == 2:
  22. _page = 'Projet:Pages vides/liste des pages vides'
  23. _summary = 'Pages vides au %s' % dump
  24. _pages = 'vides'
  25. elif mode == 3:
  26. _page = 'Utilisateur:Arkbot/Pages redirigeant hors de l\'espace de nom principal'
  27. _summary = 'Pages redirigeant hors de l\'espace de nom principal au %s' % dump
  28. _pages = 'redirigeant hors de l\'espace de nom principal'
  29. else:
  30. print('Unknown mode', mode)
  31. sys.exit(1)
  32. text = """{{Mise à jour bot|Arkanosis}}
  33. == Pages %s ==\n\nDernière mise à jour le ~~~~~ avec le dump du %s.
  34. """ % (_pages, dump)
  35. with open(filename) as inputFile:
  36. for line in inputFile:
  37. text += '# [[:%s]]\n' % line.rstrip()
  38. if debug:
  39. print((_page, _summary, text, True))
  40. else:
  41. bot.edit(_page, _summary, text, bot=True)
  42. if __name__ == '__main__':
  43. print('Post 0.1')
  44. print('(C) 2010 Arkanosis')
  45. print('jroquet@arkanosis.net')
  46. print()
  47. dump = utils.getValue('dump')
  48. mode = int(utils.getValue('mode'))
  49. debug = utils.getOption('debug')
  50. if len(sys.argv) != 2:
  51. print('Usage: post.py <fichier>')
  52. sys.exit(1)
  53. date = datetime.datetime.now()
  54. logger = logging.getLogger('ArkbotLogger')
  55. formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s', '%H:%M:%S')
  56. logger.setLevel(logging.INFO)
  57. bot = arkbot.Arkbot(arkbot._botName, arkbot._wiki, logger)
  58. try:
  59. if not debug:
  60. bot.login(getpass.getpass('Bot password ? '))
  61. post(bot, sys.argv[1], dump, mode, debug)
  62. if not debug:
  63. bot.logout()
  64. except (arkbot.ArkbotException) as e:
  65. print(e)
  66. sys.exit(2)