openlp-core team mailing list archive
  
  - 
     openlp-core team openlp-core team
- 
    Mailing list archive
  
- 
    Message #13985
  
 [Merge] lp:~raoul-snyman/openlp/i18n-transifex into	lp:openlp
  
Raoul Snyman has proposed merging lp:~raoul-snyman/openlp/i18n-transifex into lp:openlp.
Requested reviews:
  OpenLP Core (openlp-core)
For more details, see:
https://code.launchpad.net/~raoul-snyman/openlp/i18n-transifex/+merge/91595
Updated the translation script to work with Transifex.
-- 
https://code.launchpad.net/~raoul-snyman/openlp/i18n-transifex/+merge/91595
Your team OpenLP Core is requested to review the proposed merge of lp:~raoul-snyman/openlp/i18n-transifex into lp:openlp.
=== modified file 'scripts/translation_utils.py'
--- scripts/translation_utils.py	2011-08-22 08:45:03 +0000
+++ scripts/translation_utils.py	2012-02-05 21:38:24 +0000
@@ -28,22 +28,22 @@
 
 """
 This script is used to maintain the translation files in OpenLP. It downloads
-the latest translation files from the Pootle translation server, updates the
-local translation files from both the source code and the files from Pootle,
+the latest translation files from the Transifex translation server, updates the
+local translation files from both the source code and the files from Transifex,
 and can also generate the compiled translation files.
 
 Create New Language
 -------------------
 
-To create a new language, simply run this script with the ``-a`` command line
+To create a new language, simply run this script with the ``-c`` command line
 option::
 
-    @:~$ ./translation_utils.py -a
+    @:~$ ./translation_utils.py -c
 
 Update Translation Files
 ------------------------
 
-The best way to update the translations is to download the files from Pootle,
+The best way to update the translations is to download the files from Transifex,
 and then update the local files using both the downloaded files and the source.
 This is done easily via the ``-d``, ``-p`` and ``-u`` options::
 
@@ -51,20 +51,26 @@
 
 """
 import os
-import urllib
+import urllib2
 import re
 from shutil import copy
+from getpass import getpass
+import base64
+import json
+import webbrowser
 
 from optparse import OptionParser
 from PyQt4 import QtCore
 from BeautifulSoup import BeautifulSoup
 
-SERVER_URL = u'http://pootle.projecthq.biz/export/openlp/'
+SERVER_URL = u'http://www.transifex.net/api/2/project/openlp/'
 IGNORED_PATHS = [u'scripts']
 IGNORED_FILES = [u'setup.py']
 
 verbose_mode = False
 quiet_mode = False
+username = ''
+password = ''
 
 class Command(object):
     """
@@ -172,35 +178,38 @@
     print_verbose(u'Error(s):\n%s' % process.readAllStandardError())
     print_verbose(u'Output:\n%s' % process.readAllStandardOutput())
 
-def update_export_at_pootle(source_filename):
-    """
-    This is needed because of database and exported *.ts file can be out of sync
-
-    ``source_filename``
-        The file to sync.
-
-    """
-    language = source_filename[:-3]
-    REVIEW_URL = u'http://pootle.projecthq.biz/%s/openlp/review.html' % language
-    print_verbose(u'Accessing: %s' % (REVIEW_URL))
-    page = urllib.urlopen(REVIEW_URL)
-    page.close()
-
 def download_translations():
     """
     This method downloads the translation files from the Pootle server.
     """
-    print_quiet(u'Download translation files from Pootle')
-    page = urllib.urlopen(SERVER_URL)
-    soup = BeautifulSoup(page)
-    languages = soup.findAll(text=re.compile(r'.*\.ts'))
-    for language_file in languages:
-        update_export_at_pootle(language_file)
-    for language_file in languages:
+    global username, password
+    if not username:
+        username = raw_input('Transifex username: ')
+    if not password:
+        password = getpass('Transifex password: ')
+    print_quiet(u'Download translation files from Transifex')
+    # First get the list of languages
+    url = SERVER_URL + 'resource/ents/'
+    base64string = base64.encodestring(
+        '%s:%s' % (username, password))[:-1]
+    auth_header =  'Basic %s' % base64string
+    request = urllib2.Request(url + '?details')
+    request.add_header('Authorization', auth_header)
+    print_verbose('Downloading list of languages from: %s' % url)
+    json_response = urllib2.urlopen(request)
+    json_dict = json.loads(json_response.read())
+    languages = [lang['code'] for lang in json_dict['available_languages']]
+    for language in languages:
+        lang_url = url + 'translation/%s/?file' % language
+        request = urllib2.Request(lang_url)
+        request.add_header('Authorization', auth_header)
         filename = os.path.join(os.path.abspath(u'..'), u'resources', u'i18n',
-            language_file)
+            language + '.ts')
         print_verbose(u'Get Translation File: %s' % filename)
-        urllib.urlretrieve(SERVER_URL + language_file, filename)
+        response = urllib2.urlopen(request)
+        fd = open(filename, 'w')
+        fd.write(response.read())
+        fd.close()
     print_quiet(u'   Done.')
 
 def prepare_project():
@@ -252,7 +261,7 @@
 def update_translations():
     print_quiet(u'Update the translation files')
     if not os.path.exists(os.path.join(os.path.abspath(u'..'), u'openlp.pro')):
-        print u'You have no generated a project file yet, please run this ' + \
+        print u'You have not generated a project file yet, please run this ' + \
             u'script with the -p option.'
         return
     else:
@@ -274,24 +283,16 @@
         print_quiet(u'   Done.')
 
 
-def create_translation(language):
-    """
-    This method creates a new translation file.
-
-    ``language``
-        The language file to create.
-    """
-    print_quiet(u'Create new Translation File')
-    if not language.endswith(u'.ts'):
-        language += u'.ts'
-    filename = os.path.join(os.path.abspath(u'..'), u'resources', u'i18n', language)
-    urllib.urlretrieve(SERVER_URL + u'en.ts', filename)
-    print_quiet(u'   ** Please Note **')
-    print_quiet(u'   In order to get this file into OpenLP and onto the '
-        u'Pootle translation server you will need to subscribe to the '
-        u'OpenLP Translators mailing list, and request that your language '
-        u'file be added to the project.')
-    print_quiet(u'   Done.')
+def create_translation():
+    """
+    This method opens a browser to the OpenLP project page at Transifex so
+    that the user can request a new language.
+    """
+    print_quiet(u'Please request a new language at the OpenLP project on '
+        'Transifex.')
+    webbrowser.open('https://www.transifex.net/projects/p/openlp/'
+        'resource/ents/')
+    print_quiet(u'Opening browser to OpenLP project...')
 
 def process_stack(command_stack):
     """
@@ -314,23 +315,26 @@
             elif command == Command.Generate:
                 generate_binaries()
             elif command == Command.Create:
-                arguments = command_stack.arguments()
-                create_translation(*arguments)
+                create_translation()
         print_quiet(u'Finished processing commands.')
     else:
         print_quiet(u'No commands to process.')
 
 def main():
-    global verbose_mode, quiet_mode
+    global verbose_mode, quiet_mode, username, password
     # Set up command line options.
     usage = u'%prog [options]\nOptions are parsed in the order they are ' + \
         u'listed below. If no options are given, "-dpug" will be used.\n\n' + \
         u'This script is used to manage OpenLP\'s translation files.'
     parser = OptionParser(usage=usage)
+    parser.add_option('-U', '--username', dest='username', metavar='USERNAME',
+        help='Transifex username, used for authentication')
+    parser.add_option('-P', '--password', dest='password', metavar='PASSWORD',
+        help='Transifex password, used for authentication')
     parser.add_option('-d', '--download-ts', dest='download',
-        action='store_true', help='download language files from Pootle')
-    parser.add_option('-c', '--create', dest='create', metavar='LANG',
-        help='create a new translation file for language LANG, e.g. "en_GB"')
+        action='store_true', help='download language files from Transifex')
+    parser.add_option('-c', '--create', dest='create', action='store_true',
+        help='go to Transifex to request a new translation file')
     parser.add_option('-p', '--prepare', dest='prepare', action='store_true',
         help='generate a project file, used to update the translations')
     parser.add_option('-u', '--update', action='store_true', dest='update',
@@ -356,6 +360,10 @@
         command_stack.append(Command.Generate)
     verbose_mode = options.verbose
     quiet_mode = options.quiet
+    if options.username:
+        username = options.username
+    if options.password:
+        password = options.password
     if not command_stack:
         command_stack.append(Command.Download)
         command_stack.append(Command.Prepare)
Follow ups