i18n/tools/zanata/zanata_userinfo.py
Ian Y. Choi e7806cd03a zanata_userinfo.py: get user name and email
The script generates a csv file by reading a yaml file
which contains the list of translators (e.g., translation_team.yaml)
with user name and e-mail addresses by interacting with Zanata API.

The script utilizes ZanataUtils in openstack-infra/project-config
to read zanata.ini configuration file which contains Zanata API key.
Note that the Zanata API key is required to use Zanata accounts API.

Change-Id: I078742c5956b2c72eb1dabb10b9d3b4667b8f7e6
2017-03-18 14:44:01 +00:00

204 lines
6.9 KiB
Python
Executable File

#!/usr/bin/env python
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
# implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import argparse
import csv
import io
import operator
import os
import sys
from oslo_log import log as logging
import yaml
from ZanataUtils import IniConfig
from ZanataUtils import ZanataRestService
LOG = logging.getLogger(__name__)
class ZanataAccounts(object):
"""Object that retrieves Zanata account information.
Retrieve name and e-mail address using Zanata ID.
Attributes:
zconfig (IniConfig): zanata.ini values
verify (Bool): True if communicating with non-SSL server
"""
def __init__(self, zconfig, verify, **kwargs):
accept = 'application/vnd.zanata.account+json'
content_type = 'application/json'
self.rest_service = ZanataRestService(zconfig, accept=accept,
content_type=content_type,
verify=verify)
for key, value in kwargs.items():
setattr(self, key, value)
def get_account_data(self, zanata_id):
"""Get detail account information
Retrieve name and e-mail address information by Zanata ID
using Zanata's REST API.
"""
r = self.rest_service.query(
'/rest/accounts/u/%s'
% (zanata_id))
account_data = r.json()
return account_data
def _make_language_team(name, team_info):
return {
'tag': 'language_team',
'language_code': name,
'language': team_info['language'],
# Zanata ID which only consists of numbers is a valid ID
# and such entry is interpreted as integer unless it is
# quoted in the YAML file. Ensure to stringify them.
'translators': [str(i) for i in team_info['translators']],
'reviewers': [str(i) for i in team_info.get('reviewers', [])],
'coordinators': [str(i) for i in team_info.get('coordinators', [])],
}
def _make_user(user_id, language_code, language):
return {
'user_id': user_id,
'lang_code': language_code,
'lang': language,
'name': '',
'email': ''
}
def read_language_team_yaml(translation_team_uri, lang_list):
LOG.debug('Process list of language team from uri: %s',
translation_team_uri)
content = yaml.safe_load(io.open(translation_team_uri, 'r'))
language_teams = {}
if lang_list:
lang_notfound = [lang_code for lang_code in lang_list
if lang_code not in content]
if lang_notfound:
print('Language %s not tound in %s.' %
(', '.join(lang_notfound),
translation_team_uri))
sys.exit(1)
for lang_code, team_info in content.items():
if lang_list and lang_code not in lang_list:
continue
language_teams[lang_code] = _make_language_team(lang_code, team_info)
return language_teams
def get_zanata_userdata(zc, verify, role, language_teams):
print('Getting user data in Zanata...')
accounts = ZanataAccounts(zc, verify)
users = {}
if not role:
role = 'translators'
for language_code in language_teams:
language_team = language_teams[language_code]
language_name = language_team['language']
for user in language_team[role]:
users[user] = _make_user(user, language_code, language_name)
for user_id in users:
user = users.get(user_id)
print('Getting user detail data for user %(user_id)s'
% {'user_id': user_id})
user_data = accounts.get_account_data(user_id)
if user_data:
user['name'] = user_data['name'].encode('utf-8')
user['email'] = user_data['email']
return users
def write_userdata_to_file(users, output_file):
userdata = [user for user in
sorted(users.values(),
key=operator.itemgetter('lang', 'user_id'))]
_write_userdata_to_csvfile(userdata, output_file)
print('Userdata has been written to %s' % output_file)
def _write_userdata_to_csvfile(userdata, output_file):
with open(output_file, 'wb') as csvfile:
writer = csv.writer(csvfile)
writer.writerow(['user_id', 'lang_code', 'lang',
'name', 'email'])
for data in userdata:
writer.writerow([data['user_id'], data['lang_code'],
data['lang'], data['name'], data['email']])
def _comma_separated_list(s):
return s.split(',')
def main():
# Loads zanata.ini configuration file
try:
zc = IniConfig(os.path.expanduser('~/.config/zanata.ini'))
except ValueError as e:
sys.exit(e)
# Parses command option(s)
parser = argparse.ArgumentParser(description='Generate a csv file which '
'contains the list of translators for '
'a specified target role with name and '
'e-mail address. Require a privilege '
'to access Zanata accounts API.')
parser.add_argument("-o", "--output-file",
help=("Specify the output file. "
"Default: zanata_userinfo_output.csv."))
parser.add_argument("-r", "--role",
help=("Specify the target role. "
"Roles: coordinators, translators, reviewers."
"Default: translators."))
parser.add_argument("-l", "--lang",
type=_comma_separated_list,
help=("Specify language(s). Comma-separated list. "
"Language code like zh-CN, ja needs to be used. "
"Otherwise all languages are processed."))
parser.add_argument('--no-verify', action='store_false', dest='verify',
help='Do not perform HTTPS certificate verification')
parser.add_argument("user_yaml",
help="YAML file of the user list")
options = parser.parse_args()
# Reads langauge team information
language_teams = read_language_team_yaml(options.user_yaml, options.lang)
users = get_zanata_userdata(zc, options.verify, options.role,
language_teams)
output_file = (options.output_file or 'zanata_userinfo_output.csv')
write_userdata_to_file(users, output_file)
if __name__ == '__main__':
main()