# HG changeset patch # User Mads Kiilerich # Date 1670882471 -3600 # Node ID 9ab815f67c06cc0d2347d322607b5fbe33e867e9 # Parent 59185ce619c3fbfcc35866ce458a9fe4fa46e903# Parent 2f0f6f80c2131552bdc124bf3844ccd1c6cbf68b Merge from stable diff -r 59185ce619c3 -r 9ab815f67c06 CONTRIBUTORS --- a/CONTRIBUTORS Mon Dec 12 18:28:10 2022 +0100 +++ b/CONTRIBUTORS Mon Dec 12 23:01:11 2022 +0100 @@ -1,7 +1,13 @@ List of contributors to Kallithea project: + Mads Kiilerich 2016-2022 + Asterios Dimitriou 2016-2017 2020 2022 + Manuel Jacob 2019-2020 2022 + Jaime Marquínez Ferrándiz 2022 + toras9000 2022 + yzqzss 2022 + МАН69К 2022 Thomas De Schampheleire 2014-2021 - Mads Kiilerich 2016-2021 ssantos 2018-2021 Private 2019-2021 Étienne Gilli 2020-2021 @@ -11,10 +17,8 @@ Michalis 2021 vs 2021 Александр 2021 - Asterios Dimitriou 2016-2017 2020 Allan Nordhøy 2017-2020 Anton Schur 2017 2020 - Manuel Jacob 2019-2020 Artem 2020 David Ignjić 2020 Dennis Fink 2020 diff -r 59185ce619c3 -r 9ab815f67c06 dev_requirements.txt --- a/dev_requirements.txt Mon Dec 12 18:28:10 2022 +0100 +++ b/dev_requirements.txt Mon Dec 12 23:01:11 2022 +0100 @@ -1,9 +1,9 @@ -pytest >= 4.6.6, < 5.5 +pytest >= 4.6.6, < 6.3 pytest-sugar >= 0.9.2, < 0.10 pytest-benchmark >= 3.2.2, < 3.3 pytest-localserver >= 0.5.0, < 0.6 mock >= 3.0.0, < 4.1 -Sphinx >= 1.8.0, < 3.1 +Sphinx >= 1.8.0, < 5.2 WebTest >= 2.0.6, < 2.1 isort == 5.1.2 pyflakes == 2.2.0 diff -r 59185ce619c3 -r 9ab815f67c06 docs/api/api.rst --- a/docs/api/api.rst Mon Dec 12 18:28:10 2022 +0100 +++ b/docs/api/api.rst Mon Dec 12 23:01:11 2022 +0100 @@ -115,7 +115,7 @@ id : result : "Pulled from ``" - error : null + error : null rescan_repos ^^^^^^^^^^^^ @@ -138,7 +138,7 @@ id : result : "{'added': [], 'removed': []}" - error : null + error : null invalidate_cache ^^^^^^^^^^^^^^^^ @@ -160,7 +160,7 @@ id : result : "Caches of repository ``" - error : null + error : null get_ip ^^^^^^ @@ -175,24 +175,23 @@ api_key : "" method : "get_ip" args : { - "userid" : "", + "userid" : "" } OUTPUT:: id : result : { - "ip_addr_server": ", - "user_ips": [ + "ip_addr_server" : ", + "user_ips" : [ { - "ip_addr": "", - "ip_range": ["", ""], + "ip_addr" : "", + "ip_range" : ["", ""] }, ... - ] + ] } - - error : null + error : null get_user ^^^^^^^^ @@ -214,29 +213,29 @@ OUTPUT:: id : - result: None if user does not exist or - { + result : None if user does not exist or + { "user_id" : "", "api_key" : "", "username" : "", - "firstname": "", + "firstname" : "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "ip_addresses": "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", + "last_login" : "", "permissions": { "global": ["hg.create.repository", "repository.read", "hg.register.manual_activate"], - "repositories": {"repo1": "repository.none"}, - "repositories_groups": {"Group1": "group.read"} - }, - } - error: null + "repositories" : {"repo1" : "repository.none"}, + "repositories_groups" : {"Group1" : "group.read"} + } + } + error : null get_users ^^^^^^^^^ @@ -254,24 +253,24 @@ OUTPUT:: id : - result: [ + result : [ { "user_id" : "", "api_key" : "", "username" : "", - "firstname": "", + "firstname" : "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "ip_addresses": "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", + "last_login" : "" }, … - ] - error: null + ] + error : null .. _create-user: @@ -300,22 +299,22 @@ OUTPUT:: id : - result: { + result : { "msg" : "created new user ``", - "user": { + "user" : { "user_id" : "", "username" : "", "firstname": "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", - }, - } - error: null + "last_login": "" + } + } + error : null Example:: @@ -347,23 +346,23 @@ OUTPUT:: id : - result: { + result : { "msg" : "updated user ID: ", - "user": { + "user" : { "user_id" : "", "api_key" : "", "username" : "", "firstname": "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", - }, - } - error: null + "last_login": "" + } + } + error : null delete_user ^^^^^^^^^^^ @@ -377,17 +376,17 @@ api_key : "" method : "delete_user" args : { - "userid" : "", + "userid" : "" } OUTPUT:: id : - result: { + result : { "msg" : "deleted user ID: ", - "user": null - } - error: null + "user" : null + } + error : null get_user_group ^^^^^^^^^^^^^^ @@ -411,7 +410,7 @@ { "users_group_id" : "", "group_name" : "", - "active": "", + "active" : "", "members" : [ { "user_id" : "", @@ -420,11 +419,11 @@ "firstname": "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", + "last_login": "" }, … ] @@ -451,7 +450,7 @@ { "users_group_id" : "", "group_name" : "", - "active": "", + "active" : "" }, … ] @@ -468,24 +467,24 @@ id : api_key : "" method : "create_user_group" - args: { + args : { "group_name": "", "owner" : "", - "active": " = Optional(True)" + "active" : " = Optional(True)" } OUTPUT:: id : - result: { - "msg": "created new user group ``", - "users_group": { + result : { + "msg" : "created new user group ``", + "users_group" : { "users_group_id" : "", "group_name" : "", - "active": "", - }, - } - error: null + "active" : "" + } + } + error : null add_user_to_user_group ^^^^^^^^^^^^^^^^^^^^^^ @@ -499,20 +498,20 @@ id : api_key : "" method : "add_user_user_group" - args: { + args : { "usersgroupid" : "", - "userid" : "", + "userid" : "" } OUTPUT:: id : - result: { - "success": True|False # depends on if member is in group - "msg": "added member `` to a user group `` | - User is already in that group" - } - error: null + result : { + "success" : True|False, # depends on if member is in group + "msg" : "added member `` to a user group `` | + User is already in that group" + } + error : null remove_user_from_user_group ^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -526,20 +525,20 @@ id : api_key : "" method : "remove_user_from_user_group" - args: { + args : { "usersgroupid" : "", - "userid" : "", + "userid" : "" } OUTPUT:: id : - result: { - "success": True|False, # depends on if member is in group - "msg": "removed member from user group | - User wasn't in group" - } - error: null + result : { + "success" : True|False, # depends on if member is in group + "msg" : "removed member from user group | + User wasn't in group" + } + error : null get_repo ^^^^^^^^ @@ -554,144 +553,144 @@ id : api_key : "" method : "get_repo" - args: { + args : { "repoid" : "", - "with_revision_names": " = Optional(False)", - "with_pullrequests": " = Optional(False)", + "with_revision_names" : " = Optional(False)", + "with_pullrequests" : " = Optional(False)" } OUTPUT:: id : - result: None if repository does not exist or - { + result : None if repository does not exist or + { "repo_id" : "", - "repo_name" : "" + "repo_name" : "", "repo_type" : "", "clone_uri" : "", - "enable_downloads": "", + "enable_downloads" : "", "enable_statistics": "", - "private": "", + "private" : "", "created_on" : "", "description" : "", - "landing_rev": "", - "last_changeset": { - "author": "", - "date": "", - "message": "", - "raw_id": "", - "revision": "", - "short_id": "" + "landing_rev" : "", + "last_changeset" : { + "author" : "", + "date" : "", + "message" : "", + "raw_id" : "", + "revision": "", + "short_id": "" }, - "owner": "", - "fork_of": "", - "members" : [ + "owner" : "", + "fork_of" : "", + "members" : [ { - "type": "user", + "type" : "user", "user_id" : "", "api_key" : "", "username" : "", - "firstname": "", + "firstname" : "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", + "last_login" : "", "permission" : "repository.(read|write|admin)" }, … { - "type": "users_group", + "type" : "users_group", "id" : "", "name" : "", - "active": "", + "active" : "", "permission" : "repository.(read|write|admin)" }, … - ], - "followers": [ + ], + "followers" : [ { "user_id" : "", "username" : "", "api_key" : "", - "firstname": "", + "firstname" : "", "lastname" : "", "email" : "", - "emails": "", + "emails" : "", "ip_addresses": "", "active" : "", - "admin" :  "", + "admin" : "", "ldap_dn" : "", - "last_login": "", + "last_login" : "" }, … - ], - - "tags": { - "": "", + ], + + "tags" : { + "" : "", ... - }, - "branches": { - "": "", + }, + "branches" : { + "" : "", ... - }, - "bookmarks": { - "": "", + }, + "bookmarks" : { + "" : "", ... - }, + }, - "pull_requests": [ + "pull_requests" : [ { - "status": "", - "pull_request_id": , - "description": "", - "title": "", - "url": "", - "reviewers": [ + "status" : "", + "pull_request_id" : , + "description" : "", + "title" : "", + "url" : "", + "reviewers" : [ { - "username": "", + "username" : "" }, ... ], - "org_repo_url": "", - "org_ref_parts": [ + "org_repo_url" : "", + "org_ref_parts" : [ "", "", "" ], - "other_ref_parts": [ + "other_ref_parts" : [ "", "", "" ], - "comments": [ + "comments" : [ { - "username": "", - "text": "", - "comment_id": "", + "username" : "", + "text" : "", + "comment_id" : "" }, ... ], - "owner": "", - "statuses": [ + "owner" : "", + "statuses" : [ { - "status": "", # "under_review", "approved" or "rejected" - "reviewer": "", - "modified_at": "" # iso 8601 date, server's timezone + "status" : "", # "under_review", "approved" or "rejected" + "reviewer" : "", + "modified_at" : "" # iso 8601 date, server's timezone }, ... ], - "revisions": [ + "revisions" : [ "", ... ] }, ... ] - } - error: null + } + error : null get_repos ^^^^^^^^^ @@ -705,29 +704,29 @@ id : api_key : "" method : "get_repos" - args: { } + args : { } OUTPUT:: id : - result: [ + result : [ { "repo_id" : "", - "repo_name" : "" + "repo_name" : "", "repo_type" : "", "clone_uri" : "", "private" : "", "created_on" : "", "description" : "", - "landing_rev": "", - "owner": "", - "fork_of": "", - "enable_downloads": "", - "enable_statistics": "", + "landing_rev" : "", + "owner" : "", + "fork_of" : "", + "enable_downloads" : "", + "enable_statistics": "" }, … - ] - error: null + ] + error : null get_repo_nodes ^^^^^^^^^^^^^^ @@ -741,24 +740,24 @@ id : api_key : "" method : "get_repo_nodes" - args: { - "repoid" : "" - "revision" : "", + args : { + "repoid" : "", + "revision" : "", "root_path" : "", - "ret_type" : " = Optional('all')" + "ret_type" : " = Optional('all')" } OUTPUT:: id : - result: [ + result : [ { - "name" : "" - "type" : "", + "name" : "", + "type" : "" }, … - ] - error: null + ] + error : null create_repo ^^^^^^^^^^^ @@ -778,7 +777,7 @@ id : api_key : "" method : "create_repo" - args: { + args : { "repo_name" : "", "owner" : "", "repo_type" : " = Optional('hg')", @@ -786,31 +785,31 @@ "private" : " = Optional(False)", "clone_uri" : " = Optional(None)", "landing_rev" : " = Optional('tip')", - "enable_downloads": " = Optional(False)", - "enable_statistics": " = Optional(False)", + "enable_downloads" : " = Optional(False)", + "enable_statistics": " = Optional(False)" } OUTPUT:: id : - result: { - "msg": "Created new repository ``", - "repo": { + result : { + "msg" : "Created new repository ``", + "repo" : { "repo_id" : "", - "repo_name" : "" + "repo_name" : "", "repo_type" : "", "clone_uri" : "", "private" : "", "created_on" : "", "description" : "", - "landing_rev": "", - "owner": "", - "fork_of": "", - "enable_downloads": "", - "enable_statistics": "", - }, - } - error: null + "landing_rev" : "", + "owner" : "", + "fork_of" : "", + "enable_downloads" : "", + "enable_statistics": "" + } + } + error : null update_repo ^^^^^^^^^^^ @@ -825,8 +824,8 @@ id : api_key : "" method : "update_repo" - args: { - "repoid" : "" + args : { + "repoid" : "", "name" : " = Optional('')", "group" : " = Optional(None)", "owner" : "", @@ -834,39 +833,39 @@ "private" : " = Optional(False)", "clone_uri" : " = Optional(None)", "landing_rev" : " = Optional('tip')", - "enable_downloads": " = Optional(False)", - "enable_statistics": " = Optional(False)", + "enable_downloads" : " = Optional(False)", + "enable_statistics": " = Optional(False)" } OUTPUT:: id : - result: { - "msg": "updated repo ID:repo_id ``", - "repository": { + result : { + "msg" : "updated repo ID:repo_id ``", + "repository" : { "repo_id" : "", - "repo_name" : "" + "repo_name" : "", "repo_type" : "", "clone_uri" : "", - "private": "", + "private" : "", "created_on" : "", "description" : "", - "landing_rev": "", - "owner": "", - "fork_of": "", - "enable_downloads": "", + "landing_rev" : "", + "owner" : "", + "fork_of" : "", + "enable_downloads" : "", "enable_statistics": "", - "last_changeset": { - "author": "", - "date": "", - "message": "", - "raw_id": "", + "last_changeset" : { + "author" : "", + "date" : "", + "message" : "", + "raw_id" : "", "revision": "", "short_id": "" } - }, - } - error: null + } + } + error : null fork_repo ^^^^^^^^^ @@ -884,25 +883,24 @@ id : api_key : "" method : "fork_repo" - args: { + args : { "repoid" : "", - "fork_name": "", - "owner": "", - "description": "", + "fork_name" : "", + "owner" : "", + "description" : "", "copy_permissions": "", - "private": "", - "landing_rev": "" - + "private" : "", + "landing_rev" : "" } OUTPUT:: id : - result: { - "msg": "Created fork of `` as ``", - "success": true - } - error: null + result : { + "msg" : "Created fork of `` as ``", + "success" : true + } + error : null delete_repo ^^^^^^^^^^^ @@ -917,19 +915,19 @@ id : api_key : "" method : "delete_repo" - args: { + args : { "repoid" : "", - "forks" : "`delete` or `detach` = Optional(None)" + "forks" : "`delete` or `detach` = Optional(None)" } OUTPUT:: id : - result: { - "msg": "Deleted repository ``", - "success": true - } - error: null + result : { + "msg" : "Deleted repository ``", + "success" : true + } + error : null grant_user_permission ^^^^^^^^^^^^^^^^^^^^^ @@ -942,20 +940,20 @@ id : api_key : "" method : "grant_user_permission" - args: { - "repoid" : "" - "userid" : "" - "perm" : "(repository.(none|read|write|admin))", + args : { + "repoid" : "", + "userid" : "", + "perm" : "(repository.(none|read|write|admin))" } OUTPUT:: id : - result: { + result : { "msg" : "Granted perm: `` for user: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null revoke_user_permission ^^^^^^^^^^^^^^^^^^^^^^ @@ -967,20 +965,20 @@ id : api_key : "" - method : "revoke_user_permission" - args: { - "repoid" : "" + method : "revoke_user_permission" + args : { + "repoid" : "", "userid" : "" } OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm for user: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null grant_user_group_permission ^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -994,20 +992,20 @@ id : api_key : "" method : "grant_user_group_permission" - args: { - "repoid" : "" - "usersgroupid" : "" - "perm" : "(repository.(none|read|write|admin))", + args : { + "repoid" : "", + "usersgroupid" : "", + "perm" : "(repository.(none|read|write|admin))" } OUTPUT:: id : - result: { + result : { "msg" : "Granted perm: `` for group: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null revoke_user_group_permission ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -1019,20 +1017,20 @@ id : api_key : "" - method : "revoke_user_group_permission" - args: { - "repoid" : "" + method : "revoke_user_group_permission" + args : { + "repoid" : "", "usersgroupid" : "" } OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm for group: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null get_changesets ^^^^^^^^^^^^^^ @@ -1044,37 +1042,37 @@ id : api_key : "" - method : "get_changesets" - args: { + method : "get_changesets" + args : { "repoid" : "", - "start": " = Optional(None)", - "end": " = Optional(None)", - "start_date": " = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format - "end_date": " = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format - "branch_name": " = Optional(None)", - "reverse": " = Optional(False)", - "with_file_list": " = Optional(False)" + "start" : " = Optional(None)", + "end" : " = Optional(None)", + "start_date" : " = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format + "end_date" : " = Optional(None)", # in "%Y-%m-%dT%H:%M:%S" format + "branch_name" : " = Optional(None)", + "reverse" : " = Optional(False)", + "with_file_list" : " = Optional(False)" } OUTPUT:: id : - result: [ + result : [ { - "raw_id": "", - "short_id": "short_id": "", - "author": "", - "date": "", - "message": "", - "revision": "", + "raw_id" : "", + "short_id" : "", + "author" : "", + "date" : "", + "message" : "", + "revision" : "", - "added": [], - "changed": [], - "removed": [] + "added" : [], + "changed" : [], + "removed" : [] }, ... ] - error: null + error : null get_changeset ^^^^^^^^^^^^^ @@ -1087,32 +1085,32 @@ id : api_key : "" - method : "get_changeset" - args: { + method : "get_changeset" + args : { "repoid" : "", "raw_id" : "", - "with_reviews": " = Optional(False)" + "with_reviews" : " = Optional(False)" } OUTPUT:: id : - result: { - "author": "", - "date": "", - "message": "", - "raw_id": "", + result : { + "author" : "", + "date" : "", + "message" : "", + "raw_id" : "", "revision": "", "short_id": "", - "reviews": [{ - "reviewer": "", - "modified_at": "", # iso 8601 date, server's timezone - "status": "", # "under_review", "approved" or "rejected" + "reviews" : [{ + "reviewer" : "", + "modified_at" : "", # iso 8601 date, server's timezone + "status" : "", # "under_review", "approved" or "rejected" }, ... ] - } - error: null + } + error : null Example output:: @@ -1155,60 +1153,60 @@ id : api_key : "" - method : "get_pullrequest" - args: { - "pullrequest_id" : "", + method : "get_pullrequest" + args : { + "pullrequest_id" : "" } OUTPUT:: id : - result: { - "status": "", - "pull_request_id": , - "description": "", - "title": "", - "url": "", - "reviewers": [ + result : { + "status" : "", + "pull_request_id" : , + "description" : "", + "title" : "", + "url" : "", + "reviewers" : [ { - "username": "", + "username" : "" }, ... ], - "org_repo_url": "", - "org_ref_parts": [ + "org_repo_url" : "", + "org_ref_parts" : [ "", "", "" ], - "other_ref_parts": [ + "other_ref_parts" : [ "", "", "" ], - "comments": [ + "comments" : [ { - "username": "", - "text": "", - "comment_id": "", + "username" : "", + "text" : "", + "comment_id" : "" }, ... ], - "owner": "", - "statuses": [ + "owner" : "", + "statuses" : [ { - "status": "", # "under_review", "approved" or "rejected" - "reviewer": "", - "modified_at": "" # iso 8601 date, server's timezone + "status" : "", # "under_review", "approved" or "rejected" + "reviewer" : "", + "modified_at" : "" # iso 8601 date, server's timezone }, ... ], - "revisions": [ + "revisions" : [ "", ... ] }, - error: null + error : null comment_pullrequest ^^^^^^^^^^^^^^^^^^^ @@ -1220,19 +1218,19 @@ id : api_key : "" - method : "comment_pullrequest" - args: { - "pull_request_id": "", - "comment_msg": Optional(''), - "status": Optional(None), # "under_review", "approved" or "rejected" - "close_pr": Optional(False)", + method : "comment_pullrequest" + args : { + "pull_request_id" : "", + "comment_msg" : Optional(''), + "status" : Optional(None), # "under_review", "approved" or "rejected" + "close_pr" : Optional(False)" } OUTPUT:: id : - result: True - error: null + result : True + error : null API access for web views diff -r 59185ce619c3 -r 9ab815f67c06 docs/conf.py --- a/docs/conf.py Mon Dec 12 18:28:10 2022 +0100 +++ b/docs/conf.py Mon Dec 12 23:01:11 2022 +0100 @@ -47,7 +47,7 @@ # General information about the project. project = 'Kallithea' -copyright = '2010-2021 by various authors, licensed as GPLv3.' +copyright = '2010-2022 by various authors, licensed as GPLv3.' # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/config/application.py --- a/kallithea/config/application.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/config/application.py Mon Dec 12 23:01:11 2022 +0100 @@ -35,7 +35,7 @@ app = SimpleGit(app, config) # Enable https redirects based on HTTP_X_URL_SCHEME set by proxy - if any(asbool(config.get(x)) for x in ['url_scheme_variable', 'force_https', 'use_htsts']): + if config.get('url_scheme_variable') or asbool(config.get('force_https')) or asbool(config.get('use_htsts')): app = HttpsFixup(app, config) app = PermanentRepoUrl(app, config) diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/config/middleware/https_fixup.py --- a/kallithea/config/middleware/https_fixup.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/config/middleware/https_fixup.py Mon Dec 12 23:01:11 2022 +0100 @@ -26,7 +26,6 @@ """ -import kallithea from kallithea.lib.utils2 import asbool @@ -62,7 +61,7 @@ proto = 'https' else: # get protocol from configured WSGI environment variable - url_scheme_variable = kallithea.CONFIG.get('url_scheme_variable') + url_scheme_variable = self.config.get('url_scheme_variable') if url_scheme_variable: proto = environ.get(url_scheme_variable) diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/controllers/admin/repo_groups.py --- a/kallithea/controllers/admin/repo_groups.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/controllers/admin/repo_groups.py Mon Dec 12 23:01:11 2022 +0100 @@ -76,6 +76,7 @@ repo_group = db.RepoGroup.get_or_404(group_id) data = repo_group.get_dict() data['group_name'] = repo_group.name + data['owner'] = repo_group.owner.username # fill repository group users for p in repo_group.repo_group_to_perm: @@ -146,7 +147,7 @@ group_name=form_result['group_name'], group_description=form_result['group_description'], parent=form_result['parent_group_id'], - owner=request.authuser.user_id, # TODO: make editable + owner=request.authuser.user_id, copy_permissions=form_result['group_copy_permissions'] ) meta.Session().commit() @@ -245,6 +246,7 @@ @HasRepoGroupPermissionLevelDecorator('admin') def delete(self, group_name): gr = c.repo_group = db.RepoGroup.guess_instance(group_name) + parent_group = gr.parent_group repos = gr.repositories.all() if repos: webutils.flash(_('This group contains %s repositories and cannot be ' @@ -268,8 +270,8 @@ webutils.flash(_('Error occurred during deletion of repository group %s') % group_name, category='error') - if gr.parent_group: - raise HTTPFound(location=url('repos_group_home', group_name=gr.parent_group.group_name)) + if parent_group: + raise HTTPFound(location=url('repos_group_home', group_name=parent_group.group_name)) raise HTTPFound(location=url('repos_groups')) def show_by_name(self, group_name): diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/controllers/api/api.py --- a/kallithea/controllers/api/api.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/controllers/api/api.py Mon Dec 12 23:01:11 2022 +0100 @@ -172,23 +172,21 @@ OUTPUT:: - id : - result : { - "msg": "Pulled from ``" - "repository": "" - } - error : null + id : + result : { + "msg" : "Pulled from ``", + "repository" : "" + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "Unable to pull changes from ``" - } - + id : + result : null + error : { + "Unable to pull changes from ``" + } """ - repo = get_repo_or_error(repoid) try: @@ -220,23 +218,21 @@ OUTPUT:: - id : - result : { - 'added': [,...] - 'removed': [,...] - } - error : null + id : + result : { + 'added': [,...] + 'removed': [,...] + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - 'Error occurred during rescan repositories action' - } - + id : + result : null + error : { + 'Error occurred during rescan repositories action' + } """ - try: rm_obsolete = remove_obsolete added, removed = repo2db_mapper(ScmModel().repo_scan(), @@ -259,21 +255,20 @@ OUTPUT:: - id : - result : { - 'msg': Cache for repository `` was invalidated, - 'repository': - } - error : null + id : + result : { + 'msg': Cache for repository `` was invalidated, + 'repository': + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - 'Error occurred during cache invalidation action' - } - + id : + result : null + error : { + 'Error occurred during cache invalidation action' + } """ repo = get_repo_or_error(repoid) if not HasPermissionAny('hg.admin')(): @@ -308,16 +303,16 @@ id : result : { - "server_ip_addr": "", - "user_ips": [ + "server_ip_addr" : "", + "user_ips" : [ { - "ip_addr": "", - "ip_range": ["", ""], + "ip_addr" : "", + "ip_range" : ["", ""] }, ... - ] + ] } - + error : null """ if userid is None: userid = request.authuser.user_id @@ -336,17 +331,18 @@ """ return server info, including Kallithea version and installed packages - OUTPUT:: - id : - result : { - 'modules': [,...] - 'py_version': , - 'platform': , - 'kallithea_version': - } - error : null + id : + result : { + 'modules' : [ [, ], ...] + 'py_version' : , + 'platform' : , + 'kallithea_version' : , + 'git_version' : '', + 'git_path' : '' + } + error : null """ return db.Setting.get_server_info() @@ -364,33 +360,26 @@ OUTPUT:: id : - result: None if user does not exist or - { + result : None if user does not exist or + { "user_id" : "", - "api_key" : "", - "api_keys": "[]" "username" : "", - "firstname": "", + "firstname" : "", "lastname" : "", "email" : "", - "emails": "[]", - "ip_addresses": "[,...]", + "emails" : "[]", "active" : "", - "admin" :  "", - "extern_name" : "", - "extern_type" : " - "last_login": "", - "permissions": { - "global": ["hg.create.repository", - "repository.read", - "hg.register.manual_activate"], - "repositories": {"repo1": "repository.none"}, - "repositories_groups": {"Group1": "group.read"} - }, - } - - error: null - + "admin" : "", + "permissions" : { + "global" : ["hg.create.repository", + "repository.read", + "hg.register.manual_activate"], + "repositories" : {"repo1" : "repository.none"}, + "repositories_groups" : {"Group1" : "group.read"}, + "user_groups" : { "usrgrp1" : "usergroup.admin" } + } + } + error : null """ if not HasPermissionAny('hg.admin')(): # make sure normal user does not pass someone else userid, @@ -414,14 +403,12 @@ Lists all existing users. This command can be executed only using api_key belonging to user with admin rights. - OUTPUT:: id : - result: [, ...] - error: null + result : [, ...] + error : null """ - return [ user.get_api_data() for user in db.User.query() @@ -446,9 +433,9 @@ :param password: password :type password: Optional(str) :param firstname: firstname - :type firstname: Optional(str) + :type firstname: str :param lastname: lastname - :type lastname: Optional(str) + :type lastname: str :param active: active :type active: Optional(bool) :param admin: admin @@ -458,30 +445,27 @@ :param extern_type: extern_type :type extern_type: Optional(str) - OUTPUT:: id : - result: { + result : { "msg" : "created new user ``", - "user": - } - error: null + "user" : + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "user `` already exist" - or - "email `` already exist" - or - "failed to create user ``" - } - + id : + result : null + error : { + "user `` already exist" + or + "email `` already exist" + or + "failed to create user ``" + } """ - if db.User.get_by_username(username): raise JSONRPCError("user `%s` already exist" % (username,)) @@ -522,9 +506,9 @@ :param userid: userid to update :type userid: str or int :param username: new username - :type username: str or int + :type username: Optional(str or int) :param email: email - :type email: str + :type email: Optional(str) :param password: password :type password: Optional(str) :param firstname: firstname @@ -540,26 +524,23 @@ :param extern_type: :type extern_type: Optional(str) - OUTPUT:: id : - result: { + result : { "msg" : "updated user ID: ", - "user": , - } - error: null + "user" : + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "failed to update user ``" - } - + id : + result : null + error : { + "failed to update user ``" + } """ - user = get_user_or_error(userid) # only non optional arguments will be stored in updates @@ -602,20 +583,19 @@ OUTPUT:: id : - result: { + result : { "msg" : "deleted user ID: ", - "user": null - } - error: null + "user" : null + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "failed to delete user ID: " - } - + id : + result : null + error : { + "failed to delete user ID: " + } """ user = get_user_or_error(userid) @@ -649,11 +629,12 @@ { "users_group_id" : "", "group_name" : "", - "active": "", - "members" : [,...] + "group_description" : "", + "active" : "", + "owner" : "", + "members" : [,...] } error : null - """ user_group = get_user_group_or_error(usergroupid) if not HasPermissionAny('hg.admin')(): @@ -670,14 +651,12 @@ api_key belonging to user with admin rights or user who has at least read access to user group. - OUTPUT:: id : result : [,...] error : null """ - return [ user_group.get_api_data() for user_group in UserGroupList(db.UserGroup.query().all(), perm_level='read') @@ -694,7 +673,7 @@ :param group_name: name of new user group :type group_name: str :param description: group description - :type description: str + :type description: Optional(str) :param owner: owner of group. If not passed apiuser is the owner :type owner: Optional(str or int) :param active: group is active @@ -703,24 +682,22 @@ OUTPUT:: id : - result: { - "msg": "created new user group ``", - "user_group": - } - error: null + result : { + "msg" : "created new user group ``", + "user_group" : + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "user group `` already exist" - or - "failed to create group ``" - } - + id : + result : null + error : { + "user group `` already exist" + or + "failed to create group ``" + } """ - if UserGroupModel().get_by_name(group_name): raise JSONRPCError("user group `%s` already exist" % (group_name,)) @@ -763,10 +740,10 @@ id : result : { - "msg": 'updated user group ID: ', - "user_group": + "msg" : 'updated user group ID: ', + "user_group" : } - error : null + error : null ERROR OUTPUT:: @@ -775,7 +752,6 @@ error : { "failed to update user group ``" } - """ user_group = get_user_group_or_error(usergroupid) if not HasPermissionAny('hg.admin')(): @@ -810,15 +786,15 @@ belonging to user with admin rights or an admin of given user group :param usergroupid: - :type usergroupid: int + :type usergroupid: str or int OUTPUT:: id : result : { - "msg": "deleted user group ID: " + "msg" : "deleted user group ID: " } - error : null + error : null ERROR OUTPUT:: @@ -829,7 +805,6 @@ or "RepoGroup assigned to " } - """ user_group = get_user_group_or_error(usergroupid) if not HasPermissionAny('hg.admin')(): @@ -859,32 +834,30 @@ """ Adds a user to a user group. If user exists in that group success will be `false`. This command can be executed only using api_key - belonging to user with admin rights or an admin of given user group + belonging to user with admin rights or an admin of a given user group :param usergroupid: - :type usergroupid: int + :type usergroupid: str or int :param userid: - :type userid: int + :type userid: str or int OUTPUT:: - id : - result : { - "success": True|False # depends on if member is in group - "msg": "added member `` to user group `` | - User is already in that group" - - } - error : null + id : + result : { + "success" : True|False # depends on if member is in group + "msg" : "added member `` to a user group `` | + User is already in that group" + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "failed to add member to user group ``" - } - + id : + result : null + error : { + "failed to add member to user group ``" + } """ user = get_user_or_error(userid) user_group = get_user_group_or_error(usergroupid) @@ -923,17 +896,15 @@ :param usergroupid: :param userid: - OUTPUT:: id : - result: { - "success": True|False, # depends on if member is in group - "msg": "removed member from user group | - User wasn't in group" - } - error: null - + result : { + "success" : True|False, # depends on if member is in group + "msg" : "removed member from user group | + User wasn't in group" + } + error : null """ user = get_user_or_error(userid) user_group = get_user_group_or_error(usergroupid) @@ -972,61 +943,58 @@ OUTPUT:: - id : - result : { - { - "repo_id" : "", - "repo_name" : "" - "repo_type" : "", - "clone_uri" : "", - "enable_downloads": "", - "enable_statistics": "", - "private": "", - "created_on" : "", - "description" : "", - "landing_rev": "", - "last_changeset": { - "author": "", - "date": "", - "message": "", - "raw_id": "", - "revision": "", - "short_id": "" - } - "owner": "", - "fork_of": "", - "members" : [ - { - "name": "", - "type" : "user", - "permission" : "repository.(read|write|admin)" - }, - … - { - "name": "", - "type" : "user_group", - "permission" : "usergroup.(read|write|admin)" - }, - … - ] - "followers": [, ...], - - "tags": { - "": "", - ... - }, - "branches": { - "": "", - ... - }, - "bookmarks": { - "": "", - ... - }, - } - } - error : null - + id : + result : { + "repo_id" : "", + "repo_name" : "", + "repo_type" : "", + "clone_uri" : "", + "enable_downloads" : "", + "enable_statistics": "", + "private" : "", + "created_on" : "", + "description" : "", + "landing_rev" : "", + "last_changeset" : { + "author" : "", + "date" : "", + "message" : "", + "raw_id" : "", + "revision": "", + "short_id": "" + }, + "owner" : "", + "fork_of" : "", + "members" : [ + { + "name" : "", + "type" : "user", + "permission" : "repository.(read|write|admin)" + }, + … + { + "name" : "", + "type" : "user_group", + "permission" : "usergroup.(read|write|admin)" + }, + … + ], + "followers" : [, ...], + + "tags" : { + "" : "", + ... + }, + "branches" : { + "" : "", + ... + }, + "bookmarks" : { + "" : "", + ... + } + } + error : null """ repo = get_repo_or_error(repoid) @@ -1073,28 +1041,27 @@ api_key belonging to user with admin rights or regular user that have admin, write or read access to repository. - OUTPUT:: id : - result: [ + result : [ { "repo_id" : "", - "repo_name" : "" + "repo_name" : "", "repo_type" : "", "clone_uri" : "", - "private": : "", + "private" : "", "created_on" : "", "description" : "", - "landing_rev": "", - "owner": "", - "fork_of": "", - "enable_downloads": "", - "enable_statistics": "", + "landing_rev" : "", + "owner" : "", + "fork_of" : "", + "enable_downloads" : "", + "enable_statistics": "" }, … - ] - error: null + ] + error : null """ if not HasPermissionAny('hg.admin')(): repos = request.authuser.get_all_user_repos() @@ -1124,18 +1091,17 @@ :param ret_type: return type 'all|files|dirs' nodes :type ret_type: Optional(str) - OUTPUT:: id : - result: [ + result : [ { - "name" : "" - "type" : "", + "name" : "", + "type" : "" }, … - ] - error: null + ] + error : null """ repo = get_repo_or_error(repoid) @@ -1203,21 +1169,19 @@ OUTPUT:: id : - result: { - "msg": "Created new repository ``", - "success": true, - "task": "" - } - error: null + result : { + "msg" : "Created new repository ``", + "success" : true + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - 'failed to create repository `` - } - + id : + result : null + error : { + 'failed to create repository `` + } """ group_name = None repo_name_parts = repo_name.split('/') @@ -1266,8 +1230,8 @@ clone_uri=clone_uri, repo_group=group_name, repo_landing_rev=landing_rev, - enable_statistics=enable_statistics, - enable_downloads=enable_downloads, + repo_enable_statistics=enable_statistics, + repo_enable_downloads=enable_downloads, repo_copy_permissions=copy_permissions, ) @@ -1291,7 +1255,6 @@ clone_uri=None, landing_rev=None, enable_statistics=None, enable_downloads=None): - """ Updates repo @@ -1378,26 +1341,25 @@ id : api_key : "" - args: { + method : "fork_repo" + args : { "repoid" : "", - "fork_name": "", - "owner": "", - "description": "", + "fork_name" : "", + "owner" : "", + "description" : "", "copy_permissions": "", - "private": "", - "landing_rev": "" + "private" : "", + "landing_rev" : "" } OUTPUT:: id : - result: { - "msg": "Created fork of `` as ``", - "success": true, - "task": "" - } - error: null - + result : { + "msg" : "Created fork of `` as ``", + "success" : true + } + error : null """ repo = get_repo_or_error(repoid) repo_name = repo.repo_name @@ -1480,12 +1442,11 @@ OUTPUT:: id : - result: { - "msg": "Deleted repository ``", - "success": true - } - error: null - + result : { + "msg" : "Deleted repository ``", + "success" : true + } + error : null """ repo = get_repo_or_error(repoid) @@ -1535,11 +1496,11 @@ OUTPUT:: id : - result: { + result : { "msg" : "Granted perm: `` for user: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null """ repo = get_repo_or_error(repoid) user = get_user_or_error(userid) @@ -1577,14 +1538,12 @@ OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm for user: `` in repo: ``", - "success": true - } - error: null - + "success" : true + } + error : null """ - repo = get_repo_or_error(repoid) user = get_user_or_error(userid) try: @@ -1620,22 +1579,20 @@ OUTPUT:: - id : - result : { - "msg" : "Granted perm: `` for group: `` in repo: ``", - "success": true - - } - error : null + id : + result : { + "msg" : "Granted perm: `` for group: `` in repo: ``", + "success" : true + } + error : null ERROR OUTPUT:: - id : - result : null - error : { - "failed to edit permission for user group: `` in repo ``' - } - + id : + result : null + error : { + "failed to edit permission for user group: `` in repo ``' + } """ repo = get_repo_or_error(repoid) perm = get_perm_or_error(perm) @@ -1682,11 +1639,11 @@ OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm for group: `` in repo: ``", - "success": true - } - error: null + "success" : true + } + error : null """ repo = get_repo_or_error(repoid) user_group = get_user_group_or_error(usergroupid) @@ -1757,7 +1714,6 @@ def get_repo_groups(self): """ Returns all repository groups - """ return [ repo_group.get_api_data() @@ -1788,10 +1744,10 @@ id : result : { - "msg": "created new repo group ``" - "repo_group": + "msg" : "created new repo group ``", + "repo_group" : } - error : null + error : null ERROR OUTPUT:: @@ -1800,7 +1756,6 @@ error : { failed to create repo group `` } - """ if db.RepoGroup.get_by_group_name(group_name): raise JSONRPCError("repo group `%s` already exist" % (group_name,)) @@ -1836,13 +1791,14 @@ owner=None, parent=None): repo_group = get_repo_group_or_error(repogroupid) + parent_repo_group_id = None if parent is None else get_repo_group_or_error(parent).group_id updates = {} try: store_update(updates, group_name, 'group_name') store_update(updates, description, 'group_description') store_update(updates, owner, 'owner') - store_update(updates, parent, 'parent_group') + store_update(updates, parent_repo_group_id, 'parent_group_id') repo_group = RepoGroupModel().update(repo_group, updates) meta.Session().commit() return dict( @@ -1858,7 +1814,6 @@ @HasPermissionAnyDecorator('hg.admin') def delete_repo_group(self, repogroupid): """ - :param repogroupid: name or id of repository group :type repogroupid: str or int @@ -1866,10 +1821,10 @@ id : result : { - 'msg': 'deleted repo group ID: - 'repo_group': null + 'msg' : 'deleted repo group ID: + 'repo_group' : null } - error : null + error : null ERROR OUTPUT:: @@ -1878,7 +1833,6 @@ error : { "failed to delete repo group ID: " } - """ repo_group = get_repo_group_or_error(repogroupid) @@ -1916,11 +1870,11 @@ OUTPUT:: id : - result: { + result : { "msg" : "Granted perm: `` (recursive:) for user: `` in repo group: ``", - "success": true - } - error: null + "success" : true + } + error : null ERROR OUTPUT:: @@ -1929,9 +1883,7 @@ error : { "failed to edit permission for user: `` in repo group: ``" } - """ - repo_group = get_repo_group_or_error(repogroupid) if not HasPermissionAny('hg.admin')(): @@ -1978,11 +1930,11 @@ OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm (recursive:) for user: `` in repo group: ``", - "success": true - } - error: null + "success" : true + } + error : null ERROR OUTPUT:: @@ -1991,9 +1943,7 @@ error : { "failed to edit permission for user: `` in repo group: ``" } - """ - repo_group = get_repo_group_or_error(repogroupid) if not HasPermissionAny('hg.admin')(): @@ -2045,10 +1995,9 @@ id : result : { "msg" : "Granted perm: `` (recursive:) for user group: `` in repo group: ``", - "success": true - + "success" : true } - error : null + error : null ERROR OUTPUT:: @@ -2057,7 +2006,6 @@ error : { "failed to edit permission for user group: `` in repo group: ``" } - """ repo_group = get_repo_group_or_error(repogroupid) perm = get_perm_or_error(perm, prefix='group.') @@ -2112,11 +2060,11 @@ OUTPUT:: id : - result: { + result : { "msg" : "Revoked perm (recursive:) for user group: `` in repo group: ``", - "success": true - } - error: null + "success" : true + } + error : null ERROR OUTPUT:: @@ -2125,8 +2073,6 @@ error : { "failed to edit permission for user group: `` in repo group: ``" } - - """ repo_group = get_repo_group_or_error(repogroupid) user_group = get_user_group_or_error(usergroupid) @@ -2204,7 +2150,6 @@ def create_gist(self, files, owner=None, gist_type=db.Gist.GIST_PUBLIC, lifetime=-1, description=''): - """ Creates new Gist @@ -2219,16 +2164,16 @@ :param lifetime: time in minutes of gist lifetime :type lifetime: Optional(int) :param description: gist description - :type description: Optional(str) + :type description: str OUTPUT:: id : result : { - "msg": "created new gist", - "gist": {} + "msg" : "created new gist", + "gist" : } - error : null + error : null ERROR OUTPUT:: @@ -2237,7 +2182,6 @@ error : { "failed to create gist" } - """ try: if owner is None: @@ -2272,10 +2216,10 @@ id : result : { - "deleted gist ID: ", - "gist": null + "msg" : "deleted gist ID: ", + "gist" : null } - error : null + error : null ERROR OUTPUT:: @@ -2284,7 +2228,6 @@ error : { "failed to delete gist ID:" } - """ gist = get_gist_or_error(gistid) if not HasPermissionAny('hg.admin')(): diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/controllers/changelog.py --- a/kallithea/controllers/changelog.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/controllers/changelog.py Mon Dec 12 23:01:11 2022 +0100 @@ -114,7 +114,7 @@ webutils.flash(e, category='warning') raise HTTPFound(location=webutils.url('changelog_home', repo_name=repo_name)) else: - collection = c.db_repo_scm_instance.get_changesets(start=0, end=revision, + collection = c.db_repo_scm_instance.get_changesets(end=revision, branch_name=branch_name, reverse=True) c.total_cs = len(collection) diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/controllers/files.py --- a/kallithea/controllers/files.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/controllers/files.py Mon Dec 12 23:01:11 2022 +0100 @@ -44,7 +44,7 @@ from kallithea.lib import diffs, webutils from kallithea.lib.auth import HasRepoPermissionLevelDecorator, LoginRequired from kallithea.lib.exceptions import NonRelativePathError -from kallithea.lib.utils2 import asbool, convert_line_endings, detect_mode, safe_str +from kallithea.lib.utils2 import asbool, convert_line_endings, detect_mode, safe_bytes, safe_str from kallithea.lib.vcs.backends.base import EmptyChangeset from kallithea.lib.vcs.conf import settings from kallithea.lib.vcs.exceptions import (ChangesetDoesNotExistError, ChangesetError, EmptyRepositoryError, ImproperArchiveTypeError, NodeAlreadyExistsError, @@ -233,7 +233,7 @@ file_node = self.__get_filenode(cs, f_path) response.content_disposition = \ - 'attachment; filename=%s' % f_path.split(kallithea.URL_SEP)[-1] + 'attachment; filename=%s' % safe_bytes(f_path.split(kallithea.URL_SEP)[-1]).decode('latin1') response.content_type = file_node.mimetype return file_node.content diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/front-end/package-lock.json --- a/kallithea/front-end/package-lock.json Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/front-end/package-lock.json Mon Dec 12 23:01:11 2022 +0100 @@ -1,7 +1,2367 @@ { "name": "kallithea", + "lockfileVersion": 2, "requires": true, - "lockfileVersion": 1, + "packages": { + "": { + "name": "kallithea", + "dependencies": { + "at.js": "1.5.4", + "bootstrap": "3.3.7", + "codemirror": "5.49.0", + "datatables.net": "1.10.20", + "datatables.net-bs": "1.10.20", + "jquery": "3.4.1", + "jquery.caret": "0.3.1", + "jquery.flot": "0.8.3", + "select2": "3.5.1", + "select2-bootstrap-css": "1.4.6" + }, + "devDependencies": { + "eslint": "6.8.0", + "eslint-plugin-html": "6.0.0", + "less": "3.10.3", + "less-plugin-clean-css": "1.5.1", + "license-checker": "25.0.1" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", + "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.8.3" + } + }, + "node_modules/@babel/highlight": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.8.3.tgz", + "integrity": "sha512-PX4y5xQUvy0fnEVHrYOarRPXVWafSjTW9T0Hab8gVIawpl2Sj0ORyrygANq+KjcNlSSTw0YCLSNA8OyZ1I4yEg==", + "dev": true, + "dependencies": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + } + }, + "node_modules/abbrev": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "dev": true + }, + "node_modules/acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", + "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==", + "dev": true, + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0" + } + }, + "node_modules/ajv": { + "version": "6.10.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", + "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^2.0.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "node_modules/amdefine": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", + "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", + "dev": true, + "engines": { + "node": ">=0.4.2" + } + }, + "node_modules/ansi-escapes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", + "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", + "dev": true, + "dependencies": { + "type-fest": "^0.8.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", + "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/array-find-index": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", + "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=", + "dev": true + }, + "node_modules/asn1": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", + "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "dev": true, + "optional": true, + "dependencies": { + "safer-buffer": "~2.1.0" + } + }, + "node_modules/assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/astral-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", + "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true, + "optional": true + }, + "node_modules/at.js": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/at.js/-/at.js-1.5.4.tgz", + "integrity": "sha512-G8mgUb/PqShPoH8AyjuxsTGvIr1o716BtQUKDM44C8qN2W615y7KGJ68MlTGamd0J0D/m28emUkzagaHTdrGZw==", + "engines": { + "node": ">= 0.6.0" + }, + "peerDependencies": { + "jquery": ">=1.7.0 <4.0.0" + } + }, + "node_modules/aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", + "dev": true, + "optional": true, + "engines": { + "node": "*" + } + }, + "node_modules/aws4": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", + "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", + "dev": true, + "optional": true + }, + "node_modules/balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "node_modules/bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "dev": true, + "optional": true, + "dependencies": { + "tweetnacl": "^0.14.3" + } + }, + "node_modules/bootstrap": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-3.3.7.tgz", + "integrity": "sha1-WjiTlFSfIzMIdaOxUGVldPip63E=", + "engines": { + "node": ">=0.10.1" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true, + "optional": true + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true + }, + "node_modules/clean-css": { + "version": "3.4.28", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-3.4.28.tgz", + "integrity": "sha1-vxlF6C/ICPVWlebd6uwBQA79A/8=", + "dev": true, + "dependencies": { + "commander": "2.8.x", + "source-map": "0.4.x" + }, + "bin": { + "cleancss": "bin/cleancss" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/clean-css/node_modules/source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, + "dependencies": { + "amdefine": ">=0.0.4" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", + "dev": true, + "dependencies": { + "restore-cursor": "^3.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", + "dev": true + }, + "node_modules/clone": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", + "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", + "dev": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/codemirror": { + "version": "5.49.0", + "resolved": "https://registry.npmjs.org/codemirror/-/codemirror-5.49.0.tgz", + "integrity": "sha512-Hyzr0HToBdZpLBN9dYFO/KlJAsKH37/cXVHPAqa+imml0R92tb9AkmsvjnXL+SluEvjjdfkDgRjc65NG5jnMYA==" + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "optional": true, + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", + "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", + "dev": true, + "dependencies": { + "graceful-readlink": ">= 1.0.0" + }, + "engines": { + "node": ">= 0.6.x" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "node_modules/core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true, + "optional": true + }, + "node_modules/cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "dependencies": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + }, + "engines": { + "node": ">=4.8" + } + }, + "node_modules/dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": "^1.0.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/datatables.net": { + "version": "1.10.20", + "resolved": "https://registry.npmjs.org/datatables.net/-/datatables.net-1.10.20.tgz", + "integrity": "sha512-4E4S7tTU607N3h0fZPkGmAtr9mwy462u+VJ6gxYZ8MxcRIjZqHy3Dv1GNry7i3zQCktTdWbULVKBbkAJkuHEnQ==", + "dependencies": { + "jquery": ">=1.7" + } + }, + "node_modules/datatables.net-bs": { + "version": "1.10.20", + "resolved": "https://registry.npmjs.org/datatables.net-bs/-/datatables.net-bs-1.10.20.tgz", + "integrity": "sha512-NsMoOOYZ6NlteOpzhltw21lXsNdhjIMbIOxnqmcrb62ntl8eL9pYzk2AeiDXBlIKY4e550ZrExCq3CYKQ9myEg==", + "dependencies": { + "datatables.net": "1.10.20", + "jquery": ">=1.7" + } + }, + "node_modules/debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "deprecated": "Debug versions >=3.2.0 <3.2.7 || >=4 <4.3.1 have a low-severity ReDos regression when used in a Node.js environment. It is recommended you upgrade to 3.2.7 or 4.3.1. (https://github.com/visionmedia/debug/issues/797)", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/debuglog": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/debuglog/-/debuglog-1.0.1.tgz", + "integrity": "sha1-qiT/uaw9+aI1GDfPstJ5NgzXhJI=", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", + "dev": true + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/dezalgo": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/dezalgo/-/dezalgo-1.0.3.tgz", + "integrity": "sha1-f3Qt4Gb8dIvI24IFad3c5Jvw1FY=", + "dev": true, + "dependencies": { + "asap": "^2.0.0", + "wrappy": "1" + } + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", + "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", + "dev": true, + "dependencies": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + } + }, + "node_modules/dom-serializer/node_modules/domelementtype": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.0.1.tgz", + "integrity": "sha512-5HOHUDsYZWV8FGWN0Njbr/Rn7f/eWSQi1v7+HsUVwXgn8nWWlL64zKDkS0n8ZmQ3mlWOMuXOnR+7Nx/5tMO5AQ==", + "dev": true + }, + "node_modules/dom-serializer/node_modules/entities": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.0.tgz", + "integrity": "sha512-D9f7V0JSRwIxlRI2mjMqufDrRDnx8p+eEOz7aUM9SuvF8gsBzra0/6tbjl1m8eQHrZlYj6PxqE00hZ1SAIKPLw==", + "dev": true + }, + "node_modules/domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", + "dev": true + }, + "node_modules/domhandler": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz", + "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==", + "dev": true, + "dependencies": { + "domelementtype": "1" + } + }, + "node_modules/domutils": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", + "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", + "dev": true, + "dependencies": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "node_modules/ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "dev": true, + "optional": true, + "dependencies": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/entities": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", + "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", + "dev": true + }, + "node_modules/errno": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz", + "integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==", + "dev": true, + "optional": true, + "dependencies": { + "prr": "~1.0.1" + }, + "bin": { + "errno": "cli.js" + } + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint": { + "version": "6.8.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", + "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.0.0", + "ajv": "^6.10.0", + "chalk": "^2.1.0", + "cross-spawn": "^6.0.5", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "eslint-scope": "^5.0.0", + "eslint-utils": "^1.4.3", + "eslint-visitor-keys": "^1.1.0", + "espree": "^6.1.2", + "esquery": "^1.0.1", + "esutils": "^2.0.2", + "file-entry-cache": "^5.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.0.0", + "globals": "^12.1.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "inquirer": "^7.0.0", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.3.0", + "lodash": "^4.17.14", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "optionator": "^0.8.3", + "progress": "^2.0.0", + "regexpp": "^2.0.1", + "semver": "^6.1.2", + "strip-ansi": "^5.2.0", + "strip-json-comments": "^3.0.1", + "table": "^5.2.3", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^8.10.0 || ^10.13.0 || >=11.10.1" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-plugin-html": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-html/-/eslint-plugin-html-6.0.0.tgz", + "integrity": "sha512-PQcGippOHS+HTbQCStmH5MY1BF2MaU8qW/+Mvo/8xTa/ioeMXdSP+IiaBw2+nh0KEMfYQKuTz1Zo+vHynjwhbg==", + "dev": true, + "dependencies": { + "htmlparser2": "^3.10.1" + } + }, + "node_modules/eslint-scope": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", + "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", + "dev": true, + "dependencies": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/eslint-utils": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", + "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^1.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", + "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/eslint/node_modules/debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "deprecated": "Debug versions >=3.2.0 <3.2.7 || >=4 <4.3.1 have a low-severity ReDos regression when used in a Node.js environment. It is recommended you upgrade to 3.2.7 or 4.3.1. (https://github.com/visionmedia/debug/issues/797)", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint/node_modules/semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/espree": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", + "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", + "dev": true, + "dependencies": { + "acorn": "^7.1.0", + "acorn-jsx": "^5.1.0", + "eslint-visitor-keys": "^1.1.0" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true, + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esquery": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.1.0.tgz", + "integrity": "sha512-MxYW9xKmROWF672KqjO75sszsA8Mxhw06YFeS5VHlB98KDHbOSurm3ArsjO60Eaf3QmGMCP1yn+0JQkNLo/97Q==", + "dev": true, + "dependencies": { + "estraverse": "^4.0.0" + }, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/esrecurse": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", + "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "dev": true, + "dependencies": { + "estraverse": "^4.1.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true, + "optional": true + }, + "node_modules/external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "dev": true, + "dependencies": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true, + "engines": [ + "node >=0.6.0" + ], + "optional": true + }, + "node_modules/fast-deep-equal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", + "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "dev": true + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", + "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", + "dev": true + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "node_modules/figures": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", + "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", + "dev": true, + "dependencies": { + "escape-string-regexp": "^1.0.5" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/file-entry-cache": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", + "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "dev": true, + "dependencies": { + "flat-cache": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/flat-cache": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", + "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "dev": true, + "dependencies": { + "flatted": "^2.0.0", + "rimraf": "2.6.3", + "write": "1.0.3" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/flatted": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", + "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", + "dev": true + }, + "node_modules/forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true, + "optional": true, + "engines": { + "node": "*" + } + }, + "node_modules/form-data": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "dev": true, + "optional": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 0.12" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "node_modules/functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", + "dev": true + }, + "node_modules/getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": "^1.0.0" + } + }, + "node_modules/glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", + "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/globals": { + "version": "12.3.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-12.3.0.tgz", + "integrity": "sha512-wAfjdLgFsPZsklLJvOBUBmzYE8/CwhEqSBEMRXA3qxIiNtyqvjYurAtIfDh6chlEPUfmTY3MnZh5Hfh4q0UlIw==", + "dev": true, + "dependencies": { + "type-fest": "^0.8.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", + "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", + "dev": true + }, + "node_modules/graceful-readlink": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", + "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=", + "dev": true + }, + "node_modules/har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", + "dev": true, + "optional": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/har-validator": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", + "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", + "deprecated": "this library is no longer supported", + "dev": true, + "optional": true, + "dependencies": { + "ajv": "^6.5.5", + "har-schema": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/hosted-git-info": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", + "integrity": "sha512-kssjab8CvdXfcXMXVcvsXum4Hwdq9XGtRD3TteMEvEbq0LXyiNQr6AprqKqfeaDXze7SxWvRxdpwE6ku7ikLkg==", + "dev": true + }, + "node_modules/htmlparser2": { + "version": "3.10.1", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz", + "integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==", + "dev": true, + "dependencies": { + "domelementtype": "^1.3.1", + "domhandler": "^2.3.0", + "domutils": "^1.5.1", + "entities": "^1.1.1", + "inherits": "^2.0.1", + "readable-stream": "^3.1.1" + } + }, + "node_modules/http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + }, + "engines": { + "node": ">=0.8", + "npm": ">=1.3.7" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/image-size": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.5.5.tgz", + "integrity": "sha1-Cd/Uq50g4p6xw+gLiZA3jfnjy5w=", + "dev": true, + "optional": true, + "bin": { + "image-size": "bin/image-size.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/import-fresh": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", + "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "dev": true, + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "node_modules/inquirer": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.4.tgz", + "integrity": "sha512-Bu5Td5+j11sCkqfqmUTiwv+tWisMtP0L7Q8WrqA2C/BbBhy1YTdFrvjjlrKq8oagA/tLQBski2Gcx/Sqyi2qSQ==", + "dev": true, + "dependencies": { + "ansi-escapes": "^4.2.1", + "chalk": "^2.4.2", + "cli-cursor": "^3.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.3", + "figures": "^3.0.0", + "lodash": "^4.17.15", + "mute-stream": "0.0.8", + "run-async": "^2.2.0", + "rxjs": "^6.5.3", + "string-width": "^4.1.0", + "strip-ansi": "^5.1.0", + "through": "^2.3.6" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", + "dev": true + }, + "node_modules/is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true, + "optional": true + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "node_modules/isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true, + "optional": true + }, + "node_modules/jquery": { + "version": "3.4.1", + "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.4.1.tgz", + "integrity": "sha512-36+AdBzCL+y6qjw5Tx7HgzeGCzC81MDDgaUP8ld2zhx58HdqXGoBd+tHdrBMiyjGQs0Hxs/MLZTu/eHNJJuWPw==" + }, + "node_modules/jquery.caret": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/jquery.caret/-/jquery.caret-0.3.1.tgz", + "integrity": "sha1-nAkzGPrzJ+/zIugmyp8yQTaLx7g=" + }, + "node_modules/jquery.flot": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/jquery.flot/-/jquery.flot-0.8.3.tgz", + "integrity": "sha512-/tEE8J5NjwvStHDaCHkvTJpD7wDS4hE1OEL8xEmhgQfUe0gLUem923PIceNez1mz4yBNx6Hjv7pJcowLNd+nbg==" + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "dev": true, + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true, + "optional": true + }, + "node_modules/json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "node_modules/json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true, + "optional": true + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", + "dev": true + }, + "node_modules/json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true, + "optional": true + }, + "node_modules/jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "dev": true, + "engines": [ + "node >=0.6.0" + ], + "optional": true, + "dependencies": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + } + }, + "node_modules/less": { + "version": "3.10.3", + "resolved": "https://registry.npmjs.org/less/-/less-3.10.3.tgz", + "integrity": "sha512-vz32vqfgmoxF1h3K4J+yKCtajH0PWmjkIFgbs5d78E/c/e+UQTnI+lWK+1eQRE95PXM2mC3rJlLSSP9VQHnaow==", + "dev": true, + "dependencies": { + "clone": "^2.1.2" + }, + "bin": { + "lessc": "bin/lessc" + }, + "engines": { + "node": ">=6" + }, + "optionalDependencies": { + "errno": "^0.1.1", + "graceful-fs": "^4.1.2", + "image-size": "~0.5.0", + "mime": "^1.4.1", + "mkdirp": "^0.5.0", + "promise": "^7.1.1", + "request": "^2.83.0", + "source-map": "~0.6.0" + } + }, + "node_modules/less-plugin-clean-css": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/less-plugin-clean-css/-/less-plugin-clean-css-1.5.1.tgz", + "integrity": "sha1-zFeveqM5iVflbezr5jy2DCNClwM=", + "dev": true, + "dependencies": { + "clean-css": "^3.0.1" + }, + "engines": { + "node": ">=0.4.2" + } + }, + "node_modules/levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "dev": true, + "dependencies": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/license-checker": { + "version": "25.0.1", + "resolved": "https://registry.npmjs.org/license-checker/-/license-checker-25.0.1.tgz", + "integrity": "sha512-mET5AIwl7MR2IAKYYoVBBpV0OnkKQ1xGj2IMMeEFIs42QAkEVjRtFZGWmQ28WeU7MP779iAgOaOy93Mn44mn6g==", + "dev": true, + "dependencies": { + "chalk": "^2.4.1", + "debug": "^3.1.0", + "mkdirp": "^0.5.1", + "nopt": "^4.0.1", + "read-installed": "~4.0.3", + "semver": "^5.5.0", + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0", + "spdx-satisfies": "^4.0.0", + "treeify": "^1.1.0" + }, + "bin": { + "license-checker": "bin/license-checker" + } + }, + "node_modules/lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", + "dev": true + }, + "node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true, + "optional": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/mime-db": { + "version": "1.40.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", + "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", + "dev": true, + "optional": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.24", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", + "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", + "dev": true, + "optional": true, + "dependencies": { + "mime-db": "1.40.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true + }, + "node_modules/mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)", + "dev": true, + "dependencies": { + "minimist": "0.0.8" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", + "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", + "dev": true + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "node_modules/nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "node_modules/nopt": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", + "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", + "dev": true, + "dependencies": { + "abbrev": "1", + "osenv": "^0.1.4" + }, + "bin": { + "nopt": "bin/nopt.js" + } + }, + "node_modules/normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "dependencies": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "node_modules/oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", + "dev": true, + "optional": true, + "engines": { + "node": "*" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", + "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", + "dev": true, + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", + "dev": true, + "dependencies": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/os-homedir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/osenv": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", + "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", + "dev": true, + "dependencies": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true + }, + "node_modules/performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", + "dev": true, + "optional": true + }, + "node_modules/prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/promise": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz", + "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==", + "dev": true, + "optional": true, + "dependencies": { + "asap": "~2.0.3" + } + }, + "node_modules/prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=", + "dev": true, + "optional": true + }, + "node_modules/psl": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.4.0.tgz", + "integrity": "sha512-HZzqCGPecFLyoRj5HLfuDSKYTJkAfB5thKBIkRHtGjWwY7p1dAyveIbXIq4tO0KYfDF2tHqPUgY9SDnGm00uFw==", + "dev": true, + "optional": true + }, + "node_modules/punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/qs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", + "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/read-installed": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/read-installed/-/read-installed-4.0.3.tgz", + "integrity": "sha1-/5uLZ/GH0eTCm5/rMfayI6zRkGc=", + "dev": true, + "dependencies": { + "debuglog": "^1.0.1", + "read-package-json": "^2.0.0", + "readdir-scoped-modules": "^1.0.0", + "semver": "2 || 3 || 4 || 5", + "slide": "~1.1.3", + "util-extend": "^1.0.1" + }, + "optionalDependencies": { + "graceful-fs": "^4.1.2" + } + }, + "node_modules/read-package-json": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/read-package-json/-/read-package-json-2.1.0.tgz", + "integrity": "sha512-KLhu8M1ZZNkMcrq1+0UJbR8Dii8KZUqB0Sha4mOx/bknfKI/fyrQVrG/YIt2UOtG667sD8+ee4EXMM91W9dC+A==", + "dev": true, + "dependencies": { + "glob": "^7.1.1", + "json-parse-better-errors": "^1.0.1", + "normalize-package-data": "^2.0.0", + "slash": "^1.0.0" + }, + "optionalDependencies": { + "graceful-fs": "^4.1.2" + } + }, + "node_modules/readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/readdir-scoped-modules": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/readdir-scoped-modules/-/readdir-scoped-modules-1.1.0.tgz", + "integrity": "sha512-asaikDeqAQg7JifRsZn1NJZXo9E+VwlyCfbkZhwyISinqk5zNS6266HS5kah6P0SaQKGF6SkNnZVHUzHFYxYDw==", + "dev": true, + "dependencies": { + "debuglog": "^1.0.1", + "dezalgo": "^1.0.0", + "graceful-fs": "^4.1.2", + "once": "^1.3.0" + } + }, + "node_modules/regexpp": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", + "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", + "dev": true, + "engines": { + "node": ">=6.5.0" + } + }, + "node_modules/request": { + "version": "2.88.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", + "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", + "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", + "dev": true, + "optional": true, + "dependencies": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.0", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.4.3", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "dev": true, + "dependencies": { + "path-parse": "^1.0.6" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", + "dev": true, + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/rimraf": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", + "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "dev": true, + "dependencies": { + "is-promise": "^2.1.0" + }, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/rxjs": { + "version": "6.5.4", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.4.tgz", + "integrity": "sha512-naMQXcgEo3csAEGvw/NydRA0fuS2nDZJiw1YUWFKU7aPPAPGZEsD4Iimit96qwCieH6y614MCLYwdkrWx7z/7Q==", + "dev": true, + "dependencies": { + "tslib": "^1.9.0" + }, + "engines": { + "npm": ">=2.0.0" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", + "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", + "dev": true + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "node_modules/select2": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/select2/-/select2-3.5.1.tgz", + "integrity": "sha1-8oGUibvGX9bTKL5yu+K5XdfofP4=" + }, + "node_modules/select2-bootstrap-css": { + "version": "1.4.6", + "resolved": "https://registry.npmjs.org/select2-bootstrap-css/-/select2-bootstrap-css-1.4.6.tgz", + "integrity": "sha1-XPtoJG9SmcoYWOAe/XiIBMc0mX4=" + }, + "node_modules/semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "dependencies": { + "shebang-regex": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "node_modules/slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/slice-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", + "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.0", + "astral-regex": "^1.0.0", + "is-fullwidth-code-point": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/slide": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/slide/-/slide-1.1.6.tgz", + "integrity": "sha1-VusCfWW00tzmyy4tMsTUr8nh1wc=", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/spdx-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/spdx-compare/-/spdx-compare-1.0.0.tgz", + "integrity": "sha512-C1mDZOX0hnu0ep9dfmuoi03+eOdDoz2yvK79RxbcrVEG1NO1Ph35yW102DHWKN4pk80nwCgeMmSY5L25VE4D9A==", + "dev": true, + "dependencies": { + "array-find-index": "^1.0.2", + "spdx-expression-parse": "^3.0.0", + "spdx-ranges": "^2.0.0" + } + }, + "node_modules/spdx-correct": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", + "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", + "dev": true, + "dependencies": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "node_modules/spdx-exceptions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", + "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", + "dev": true + }, + "node_modules/spdx-expression-parse": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", + "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", + "dev": true, + "dependencies": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "node_modules/spdx-license-ids": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", + "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", + "dev": true + }, + "node_modules/spdx-ranges": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/spdx-ranges/-/spdx-ranges-2.1.1.tgz", + "integrity": "sha512-mcdpQFV7UDAgLpXEE/jOMqvK4LBoO0uTQg0uvXUewmEFhpiZx5yJSZITHB8w1ZahKdhfZqP5GPEOKLyEq5p8XA==", + "dev": true + }, + "node_modules/spdx-satisfies": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/spdx-satisfies/-/spdx-satisfies-4.0.1.tgz", + "integrity": "sha512-WVzZ/cXAzoNmjCWiEluEA3BjHp5tiUmmhn9MK+X0tBbR9sOqtC6UQwmgCNrAIZvNlMuBUYAaHYfb2oqlF9SwKA==", + "dev": true, + "dependencies": { + "spdx-compare": "^1.0.0", + "spdx-expression-parse": "^3.0.0", + "spdx-ranges": "^2.0.0" + } + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "node_modules/sshpk": { + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "dev": true, + "optional": true, + "dependencies": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + }, + "bin": { + "sshpk-conv": "bin/sshpk-conv", + "sshpk-sign": "bin/sshpk-sign", + "sshpk-verify": "bin/sshpk-verify" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "dev": true, + "dependencies": { + "safe-buffer": "~5.2.0" + } + }, + "node_modules/string-width": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", + "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width/node_modules/strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", + "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/strip-ansi/node_modules/ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/strip-json-comments": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", + "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/table": { + "version": "5.4.6", + "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", + "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", + "dev": true, + "dependencies": { + "ajv": "^6.10.2", + "lodash": "^4.17.14", + "slice-ansi": "^2.1.0", + "string-width": "^3.0.0" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/table/node_modules/emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "node_modules/table/node_modules/is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/table/node_modules/string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "dependencies": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", + "dev": true + }, + "node_modules/through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "node_modules/tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "dependencies": { + "os-tmpdir": "~1.0.2" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/tough-cookie": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", + "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", + "dev": true, + "optional": true, + "dependencies": { + "psl": "^1.1.24", + "punycode": "^1.4.1" + }, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/tough-cookie/node_modules/punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true, + "optional": true + }, + "node_modules/treeify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/treeify/-/treeify-1.1.0.tgz", + "integrity": "sha512-1m4RA7xVAJrSGrrXGs0L3YTwyvBs2S8PbRHaLZAkFw7JR8oIFwYtysxlBZhYIa7xSyiYJKZ3iGrrk55cGA3i9A==", + "dev": true, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/tslib": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.0.tgz", + "integrity": "sha512-BmndXUtiTn/VDDrJzQE7Mm22Ix3PxgLltW9bSNLoeCY31gnG2OPx0QqJnuc9oMIKioYrz487i6K9o4Pdn0j+Kg==", + "dev": true + }, + "node_modules/tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, + "optional": true, + "dependencies": { + "safe-buffer": "^5.0.1" + }, + "engines": { + "node": "*" + } + }, + "node_modules/tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true, + "optional": true + }, + "node_modules/type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true, + "dependencies": { + "prelude-ls": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-fest": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", + "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/uri-js": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", + "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true + }, + "node_modules/util-extend": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/util-extend/-/util-extend-1.0.3.tgz", + "integrity": "sha1-p8IW0mdUUWljeztu3GypEZ4v+T8=", + "dev": true + }, + "node_modules/uuid": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.3.tgz", + "integrity": "sha512-pW0No1RGHgzlpHJO1nsVrHKpOEIxkGg1xB+v0ZmdNH5OAeAwzAVrCnI2/6Mtx+Uys6iaylxa+D3g4j63IKKjSQ==", + "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", + "dev": true, + "optional": true, + "bin": { + "uuid": "bin/uuid" + } + }, + "node_modules/v8-compile-cache": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", + "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", + "dev": true + }, + "node_modules/validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "dependencies": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "node_modules/verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "dev": true, + "engines": [ + "node >=0.6.0" + ], + "optional": true, + "dependencies": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "node_modules/which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "which": "bin/which" + } + }, + "node_modules/word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "node_modules/write": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", + "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", + "dev": true, + "dependencies": { + "mkdirp": "^0.5.1" + }, + "engines": { + "node": ">=4" + } + } + }, "dependencies": { "@babel/code-frame": { "version": "7.8.3", @@ -39,7 +2399,8 @@ "version": "5.1.0", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==", - "dev": true + "dev": true, + "requires": {} }, "ajv": { "version": "6.10.2", @@ -137,7 +2498,8 @@ "at.js": { "version": "1.5.4", "resolved": "https://registry.npmjs.org/at.js/-/at.js-1.5.4.tgz", - "integrity": "sha512-G8mgUb/PqShPoH8AyjuxsTGvIr1o716BtQUKDM44C8qN2W615y7KGJ68MlTGamd0J0D/m28emUkzagaHTdrGZw==" + "integrity": "sha512-G8mgUb/PqShPoH8AyjuxsTGvIr1o716BtQUKDM44C8qN2W615y7KGJ68MlTGamd0J0D/m28emUkzagaHTdrGZw==", + "requires": {} }, "aws-sign2": { "version": "0.7.0", @@ -1663,6 +4025,15 @@ "tweetnacl": "~0.14.0" } }, + "string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "dev": true, + "requires": { + "safe-buffer": "~5.2.0" + } + }, "string-width": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", @@ -1685,15 +4056,6 @@ } } }, - "string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "requires": { - "safe-buffer": "~5.2.0" - } - }, "strip-ansi": { "version": "5.2.0", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/i18n/be/LC_MESSAGES/kallithea.po --- a/kallithea/i18n/be/LC_MESSAGES/kallithea.po Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/i18n/be/LC_MESSAGES/kallithea.po Mon Dec 12 23:01:11 2022 +0100 @@ -5,7 +5,7 @@ msgstr "" "Project-Id-Version: Kallithea 0.3\n" "Report-Msgid-Bugs-To: translations@kallithea-scm.org\n" -"POT-Creation-Date: 2022-12-12 22:25+0100\n" +"POT-Creation-Date: 2022-12-12 23:01+0100\n" "PO-Revision-Date: 2017-08-20 10:44+0000\n" "Last-Translator: Viktar Vauchkevich \n" "Language-Team: Belarusian \n" "Language-Team: Czech \n" "Language-Team: Danish \n" "Language-Team: German \n" "Language-Team: Greek \n" @@ -44,10 +44,10 @@ #: kallithea/controllers/admin/permissions.py:65 #: kallithea/controllers/admin/permissions.py:70 #: kallithea/controllers/changelog.py:136 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 #: kallithea/templates/admin/repos/repo_edit_permissions.html:7 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:6 #: kallithea/templates/base/perms_summary.html:14 msgid "None" msgstr "Ninguno" @@ -270,7 +270,7 @@ msgstr "Grupos" #: kallithea/controllers/home.py:87 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 #: kallithea/templates/admin/repos/repo_add.html:12 #: kallithea/templates/admin/repos/repo_add.html:16 #: kallithea/templates/admin/repos/repos.html:9 @@ -634,9 +634,9 @@ #: kallithea/controllers/admin/permissions.py:61 #: kallithea/controllers/admin/permissions.py:66 #: kallithea/controllers/admin/permissions.py:71 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 #: kallithea/templates/admin/repos/repo_edit_permissions.html:8 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 #: kallithea/templates/base/perms_summary.html:15 msgid "Read" msgstr "" @@ -644,9 +644,9 @@ #: kallithea/controllers/admin/permissions.py:62 #: kallithea/controllers/admin/permissions.py:67 #: kallithea/controllers/admin/permissions.py:72 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 #: kallithea/templates/admin/repos/repo_edit_permissions.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 #: kallithea/templates/base/perms_summary.html:16 msgid "Write" msgstr "" @@ -659,8 +659,8 @@ #: kallithea/templates/admin/permissions/permissions.html:9 #: kallithea/templates/admin/repo_groups/repo_group_add.html:9 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:9 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:47 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:46 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/admin/repos/repo_add.html:10 #: kallithea/templates/admin/repos/repo_add.html:14 @@ -668,8 +668,8 @@ #: kallithea/templates/admin/settings/settings.html:9 #: kallithea/templates/admin/user_groups/user_group_add.html:8 #: kallithea/templates/admin/user_groups/user_group_edit.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:47 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:46 #: kallithea/templates/admin/user_groups/user_groups.html:9 #: kallithea/templates/admin/users/user_add.html:8 #: kallithea/templates/admin/users/user_edit.html:9 @@ -725,57 +725,57 @@ msgid "Error occurred during update of permissions" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:164 +#: kallithea/controllers/admin/repo_groups.py:165 #, python-format msgid "Error occurred during creation of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:171 +#: kallithea/controllers/admin/repo_groups.py:172 #, python-format msgid "Created repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:224 +#: kallithea/controllers/admin/repo_groups.py:225 #, python-format msgid "Updated repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:240 +#: kallithea/controllers/admin/repo_groups.py:241 #, python-format msgid "Error occurred during update of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:250 +#: kallithea/controllers/admin/repo_groups.py:252 #, python-format msgid "This group contains %s repositories and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:257 +#: kallithea/controllers/admin/repo_groups.py:259 #, python-format msgid "This group contains %s subgroups and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:263 +#: kallithea/controllers/admin/repo_groups.py:265 #, python-format msgid "Removed repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:268 +#: kallithea/controllers/admin/repo_groups.py:270 #, python-format msgid "Error occurred during deletion of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:352 -#: kallithea/controllers/admin/repo_groups.py:382 +#: kallithea/controllers/admin/repo_groups.py:354 +#: kallithea/controllers/admin/repo_groups.py:384 #: kallithea/controllers/admin/user_groups.py:288 msgid "Cannot revoke permission for yourself as admin" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:367 +#: kallithea/controllers/admin/repo_groups.py:369 msgid "Repository group permissions updated" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:399 +#: kallithea/controllers/admin/repo_groups.py:401 #: kallithea/controllers/admin/repos.py:334 #: kallithea/controllers/admin/user_groups.py:300 msgid "An error occurred during revoking of permission" @@ -1294,69 +1294,69 @@ msgid "Invalid SSH key - it is a %s key but the base64 part contains %r" msgstr "" -#: kallithea/lib/webutils.py:623 +#: kallithea/lib/webutils.py:628 #, python-format msgid "%d year" msgid_plural "%d years" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:624 +#: kallithea/lib/webutils.py:629 #, python-format msgid "%d month" msgid_plural "%d months" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:625 +#: kallithea/lib/webutils.py:630 #, python-format msgid "%d day" msgid_plural "%d days" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:626 +#: kallithea/lib/webutils.py:631 #, python-format msgid "%d hour" msgid_plural "%d hours" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:627 +#: kallithea/lib/webutils.py:632 #, python-format msgid "%d minute" msgid_plural "%d minutes" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:628 +#: kallithea/lib/webutils.py:633 #, python-format msgid "%d second" msgid_plural "%d seconds" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:644 +#: kallithea/lib/webutils.py:649 #, python-format msgid "in %s" msgstr "" -#: kallithea/lib/webutils.py:646 -#, python-format -msgid "%s ago" -msgstr "" - -#: kallithea/lib/webutils.py:648 -#, python-format -msgid "in %s and %s" -msgstr "" - #: kallithea/lib/webutils.py:651 #, python-format +msgid "%s ago" +msgstr "" + +#: kallithea/lib/webutils.py:653 +#, python-format +msgid "in %s and %s" +msgstr "" + +#: kallithea/lib/webutils.py:656 +#, python-format msgid "%s and %s ago" msgstr "" -#: kallithea/lib/webutils.py:654 +#: kallithea/lib/webutils.py:659 msgid "just now" msgstr "" @@ -1840,10 +1840,10 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:58 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:60 #: kallithea/templates/admin/repo_groups/repo_group_add.html:35 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 #: kallithea/templates/admin/repo_groups/repo_groups.html:41 -#: kallithea/templates/admin/repos/repo_add_base.html:21 -#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/admin/repos/repo_add_base.html:26 +#: kallithea/templates/admin/repos/repo_edit_settings.html:31 #: kallithea/templates/admin/repos/repos.html:40 #: kallithea/templates/admin/user_groups/user_group_add.html:33 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:10 @@ -1875,8 +1875,9 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_advanced.html:10 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 #: kallithea/templates/admin/repo_groups/repo_groups.html:43 -#: kallithea/templates/admin/repos/repo_edit_settings.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:52 #: kallithea/templates/admin/repos/repos.html:43 #: kallithea/templates/admin/user_groups/user_group_edit_advanced.html:8 #: kallithea/templates/admin/user_groups/user_groups.html:43 @@ -2126,13 +2127,13 @@ #: kallithea/templates/admin/my_account/my_account_profile.html:47 #: kallithea/templates/admin/permissions/permissions_globals.html:87 #: kallithea/templates/admin/repo_groups/repo_group_add.html:58 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:27 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:84 -#: kallithea/templates/admin/repos/repo_edit_settings.html:99 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:97 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:34 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:86 +#: kallithea/templates/admin/repos/repo_edit_settings.html:96 #: kallithea/templates/admin/settings/settings_hooks.html:34 #: kallithea/templates/admin/user_groups/user_group_add.html:48 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:87 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:46 #: kallithea/templates/admin/users/user_add.html:80 #: kallithea/templates/admin/users/user_edit_profile.html:89 @@ -2147,21 +2148,21 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:42 +#: kallithea/templates/admin/repos/repo_add_base.html:10 #: kallithea/templates/admin/repos/repo_edit_fields.html:8 msgid "Type" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:34 -#: kallithea/templates/admin/repos/repo_add_base.html:56 -#: kallithea/templates/admin/repos/repo_edit_settings.html:62 +#: kallithea/templates/admin/repos/repo_add_base.html:54 +#: kallithea/templates/admin/repos/repo_edit_settings.html:59 #: kallithea/templates/data_table/_dt_elements.html:21 msgid "Private repository" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:37 -#: kallithea/templates/admin/repos/repo_add_base.html:59 -#: kallithea/templates/admin/repos/repo_edit_settings.html:65 +#: kallithea/templates/admin/repos/repo_add_base.html:57 +#: kallithea/templates/admin/repos/repo_edit_settings.html:62 #: kallithea/templates/forks/fork.html:61 msgid "" "Private repositories are only visible to people explicitly added as " @@ -2169,22 +2170,26 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:42 -#: kallithea/templates/admin/repos/repo_edit_settings.html:69 +#: kallithea/templates/admin/repos/repo_add_base.html:61 +#: kallithea/templates/admin/repos/repo_edit_settings.html:66 msgid "Enable statistics" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:45 -#: kallithea/templates/admin/repos/repo_edit_settings.html:72 +#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_edit_settings.html:69 msgid "Enable statistics window on summary page." msgstr "" #: kallithea/templates/admin/defaults/defaults.html:50 -#: kallithea/templates/admin/repos/repo_edit_settings.html:76 +#: kallithea/templates/admin/repos/repo_add_base.html:68 +#: kallithea/templates/admin/repos/repo_edit_settings.html:73 msgid "Enable downloads" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:53 -#: kallithea/templates/admin/repos/repo_edit_settings.html:79 +#: kallithea/templates/admin/repos/repo_add_base.html:71 +#: kallithea/templates/admin/repos/repo_edit_settings.html:76 msgid "Enable download menu on summary page." msgstr "" @@ -2309,15 +2314,15 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:66 #: kallithea/templates/admin/permissions/permissions_globals.html:88 #: kallithea/templates/admin/permissions/permissions_ips.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:99 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:28 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:35 #: kallithea/templates/admin/repos/repo_edit_fields.html:54 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:85 -#: kallithea/templates/admin/repos/repo_edit_settings.html:100 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:87 +#: kallithea/templates/admin/repos/repo_edit_settings.html:97 #: kallithea/templates/admin/settings/settings_global.html:50 #: kallithea/templates/admin/settings/settings_vcs.html:59 #: kallithea/templates/admin/settings/settings_visual.html:129 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:89 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 #: kallithea/templates/admin/users/user_edit_api_keys.html:14 #: kallithea/templates/admin/users/user_edit_api_keys.html:73 #: kallithea/templates/admin/users/user_edit_emails.html:47 @@ -2494,7 +2499,7 @@ #: kallithea/templates/admin/my_account/my_account_emails.html:46 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:65 #: kallithea/templates/admin/permissions/permissions_ips.html:33 -#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_add_base.html:76 #: kallithea/templates/admin/repos/repo_edit_fields.html:53 #: kallithea/templates/admin/users/user_edit_api_keys.html:72 #: kallithea/templates/admin/users/user_edit_emails.html:46 @@ -2591,7 +2596,7 @@ #: kallithea/templates/admin/my_account/my_account_repos.html:14 #: kallithea/templates/admin/my_account/my_account_watched.html:14 #: kallithea/templates/admin/repo_groups/repo_groups.html:40 -#: kallithea/templates/admin/repos/repo_add_base.html:6 +#: kallithea/templates/admin/repos/repo_add_base.html:4 #: kallithea/templates/admin/repos/repo_edit_settings.html:4 #: kallithea/templates/admin/repos/repos.html:39 #: kallithea/templates/admin/user_groups/user_groups.html:39 @@ -2687,8 +2692,8 @@ msgstr "" #: kallithea/templates/admin/permissions/permissions_globals.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:28 -#: kallithea/templates/admin/repos/repo_edit_settings.html:33 +#: kallithea/templates/admin/repos/repo_add_base.html:33 +#: kallithea/templates/admin/repos/repo_edit_settings.html:38 #: kallithea/templates/data_table/_dt_elements.html:140 #: kallithea/templates/forks/fork.html:42 msgid "Repository group" @@ -2780,7 +2785,7 @@ #: kallithea/templates/admin/repo_groups/repo_group_add.html:11 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:11 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/base/base.html:57 #: kallithea/templates/base/base.html:76 @@ -2795,17 +2800,17 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:42 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:26 msgid "Group parent" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:49 -#: kallithea/templates/admin/repos/repo_add_base.html:35 +#: kallithea/templates/admin/repos/repo_add_base.html:40 msgid "Copy parent group permissions" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:52 -#: kallithea/templates/admin/repos/repo_add_base.html:38 +#: kallithea/templates/admin/repos/repo_add_base.html:43 msgid "Copy permission set from parent repository group." msgstr "" @@ -2877,73 +2882,79 @@ msgid "Delete this repository group" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +msgid "Not visible" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -msgid "Not visible" +msgid "Visible" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 -msgid "Visible" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 #, fuzzy #| msgid "No response" msgid "Add repos" msgstr "No hay respuesta" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 msgid "Add/Edit groups" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:11 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 #: kallithea/templates/admin/repos/repo_edit_permissions.html:11 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:11 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 msgid "User/User Group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:28 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:45 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:27 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:44 #: kallithea/templates/admin/repos/repo_edit_permissions.html:23 #: kallithea/templates/admin/repos/repo_edit_permissions.html:36 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:28 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:45 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:27 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:44 msgid "Default" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:71 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:33 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:70 #: kallithea/templates/admin/repos/repo_edit_permissions.html:42 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:67 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:34 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:71 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:69 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:33 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:70 msgid "Revoke" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:81 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:77 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:81 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:80 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:79 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:80 msgid "Add new" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:86 msgid "Apply to children" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +msgid "Both" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:91 -msgid "Both" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:92 msgid "" "Set or revoke permission to all children of that group, including non-" "private repositories and other groups if selected." msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:14 +#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/pullrequests/pullrequest_show.html:131 +msgid "Type name of user" +msgstr "" + +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Remove this group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Confirm to delete this group" msgstr "" @@ -2960,40 +2971,46 @@ msgid "Number of Top-level Repositories" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:12 +#: kallithea/templates/admin/repos/repo_add_base.html:13 +msgid "Type of repository to create." +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:17 msgid "Clone remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:16 +#: kallithea/templates/admin/repos/repo_add_base.html:19 +#: kallithea/templates/admin/repos/repo_edit_settings.html:23 +msgid "Repository URL" +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:21 msgid "" "Optional: URL of a remote repository. If set, the repository will be " "created as a clone from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:24 -#: kallithea/templates/admin/repos/repo_edit_settings.html:57 +#: kallithea/templates/admin/repos/repo_add_base.html:29 +#: kallithea/templates/admin/repos/repo_edit_settings.html:34 #: kallithea/templates/forks/fork.html:37 msgid "" "Keep it short and to the point. Use a README file for longer descriptions." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:31 -#: kallithea/templates/admin/repos/repo_edit_settings.html:36 +#: kallithea/templates/admin/repos/repo_add_base.html:36 +#: kallithea/templates/admin/repos/repo_edit_settings.html:41 #: kallithea/templates/forks/fork.html:45 msgid "Optionally select a group to put this repository into." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:45 -msgid "Type of repository to create." -msgstr "" - -#: kallithea/templates/admin/repos/repo_add_base.html:49 -#: kallithea/templates/admin/repos/repo_edit_settings.html:40 +#: kallithea/templates/admin/repos/repo_add_base.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:45 #: kallithea/templates/forks/fork.html:50 msgid "Landing revision" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:52 +#: kallithea/templates/admin/repos/repo_add_base.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:48 msgid "" "Default revision for files page, downloads, full text search index and " "readme generation" @@ -3174,36 +3191,23 @@ msgid "" "In case this repository is renamed or moved into another group the " "repository URL changes.\n" -" Using the above permanent URL guarantees " -"that this repository always will be accessible on that URL.\n" -" This is useful for CI systems, or any " -"other cases that you need to hardcode the URL into a 3rd party service." +" Using the above permanent URL guarantees that " +"this repository always will be accessible on that URL.\n" +" This is useful for CI systems, or any other " +"cases that you need to hardcode the URL into a 3rd party service." msgstr "" #: kallithea/templates/admin/repos/repo_edit_settings.html:21 msgid "Remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:24 -msgid "Repository URL" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:28 +#: kallithea/templates/admin/repos/repo_edit_settings.html:26 msgid "" "Optional: URL of a remote repository. If set, the repository can be " "pulled from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:43 -msgid "Default revision for files page, downloads, whoosh and readme" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:49 -#: kallithea/templates/pullrequests/pullrequest_show.html:131 -msgid "Type name of user" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:55 msgid "Change owner of this repository." msgstr "" diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/i18n/fr/LC_MESSAGES/kallithea.po --- a/kallithea/i18n/fr/LC_MESSAGES/kallithea.po Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/i18n/fr/LC_MESSAGES/kallithea.po Mon Dec 12 23:01:11 2022 +0100 @@ -4,7 +4,7 @@ msgstr "" "Project-Id-Version: Kallithea 0.3\n" "Report-Msgid-Bugs-To: translations@kallithea-scm.org\n" -"POT-Creation-Date: 2022-12-12 22:25+0100\n" +"POT-Creation-Date: 2022-12-12 23:01+0100\n" "PO-Revision-Date: 2021-05-15 17:32+0000\n" "Last-Translator: Étienne Gilli \n" "Language-Team: French \n" "Language-Team: Hungarian \n" "Language-Team: Japanese \n" "Language-Team: LANGUAGE \n" @@ -43,10 +43,10 @@ #: kallithea/controllers/admin/permissions.py:65 #: kallithea/controllers/admin/permissions.py:70 #: kallithea/controllers/changelog.py:136 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 #: kallithea/templates/admin/repos/repo_edit_permissions.html:7 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:6 #: kallithea/templates/base/perms_summary.html:14 msgid "None" msgstr "" @@ -259,7 +259,7 @@ msgstr "" #: kallithea/controllers/home.py:87 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 #: kallithea/templates/admin/repos/repo_add.html:12 #: kallithea/templates/admin/repos/repo_add.html:16 #: kallithea/templates/admin/repos/repos.html:9 @@ -608,9 +608,9 @@ #: kallithea/controllers/admin/permissions.py:61 #: kallithea/controllers/admin/permissions.py:66 #: kallithea/controllers/admin/permissions.py:71 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 #: kallithea/templates/admin/repos/repo_edit_permissions.html:8 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 #: kallithea/templates/base/perms_summary.html:15 msgid "Read" msgstr "" @@ -618,9 +618,9 @@ #: kallithea/controllers/admin/permissions.py:62 #: kallithea/controllers/admin/permissions.py:67 #: kallithea/controllers/admin/permissions.py:72 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 #: kallithea/templates/admin/repos/repo_edit_permissions.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 #: kallithea/templates/base/perms_summary.html:16 msgid "Write" msgstr "" @@ -633,8 +633,8 @@ #: kallithea/templates/admin/permissions/permissions.html:9 #: kallithea/templates/admin/repo_groups/repo_group_add.html:9 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:9 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:47 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:46 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/admin/repos/repo_add.html:10 #: kallithea/templates/admin/repos/repo_add.html:14 @@ -642,8 +642,8 @@ #: kallithea/templates/admin/settings/settings.html:9 #: kallithea/templates/admin/user_groups/user_group_add.html:8 #: kallithea/templates/admin/user_groups/user_group_edit.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:47 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:46 #: kallithea/templates/admin/user_groups/user_groups.html:9 #: kallithea/templates/admin/users/user_add.html:8 #: kallithea/templates/admin/users/user_edit.html:9 @@ -699,57 +699,57 @@ msgid "Error occurred during update of permissions" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:164 +#: kallithea/controllers/admin/repo_groups.py:165 #, python-format msgid "Error occurred during creation of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:171 +#: kallithea/controllers/admin/repo_groups.py:172 #, python-format msgid "Created repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:224 +#: kallithea/controllers/admin/repo_groups.py:225 #, python-format msgid "Updated repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:240 +#: kallithea/controllers/admin/repo_groups.py:241 #, python-format msgid "Error occurred during update of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:250 +#: kallithea/controllers/admin/repo_groups.py:252 #, python-format msgid "This group contains %s repositories and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:257 +#: kallithea/controllers/admin/repo_groups.py:259 #, python-format msgid "This group contains %s subgroups and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:263 +#: kallithea/controllers/admin/repo_groups.py:265 #, python-format msgid "Removed repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:268 +#: kallithea/controllers/admin/repo_groups.py:270 #, python-format msgid "Error occurred during deletion of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:352 -#: kallithea/controllers/admin/repo_groups.py:382 +#: kallithea/controllers/admin/repo_groups.py:354 +#: kallithea/controllers/admin/repo_groups.py:384 #: kallithea/controllers/admin/user_groups.py:288 msgid "Cannot revoke permission for yourself as admin" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:367 +#: kallithea/controllers/admin/repo_groups.py:369 msgid "Repository group permissions updated" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:399 +#: kallithea/controllers/admin/repo_groups.py:401 #: kallithea/controllers/admin/repos.py:334 #: kallithea/controllers/admin/user_groups.py:300 msgid "An error occurred during revoking of permission" @@ -1258,69 +1258,69 @@ msgid "Invalid SSH key - it is a %s key but the base64 part contains %r" msgstr "" -#: kallithea/lib/webutils.py:623 +#: kallithea/lib/webutils.py:628 #, python-format msgid "%d year" msgid_plural "%d years" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:624 +#: kallithea/lib/webutils.py:629 #, python-format msgid "%d month" msgid_plural "%d months" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:625 +#: kallithea/lib/webutils.py:630 #, python-format msgid "%d day" msgid_plural "%d days" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:626 +#: kallithea/lib/webutils.py:631 #, python-format msgid "%d hour" msgid_plural "%d hours" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:627 +#: kallithea/lib/webutils.py:632 #, python-format msgid "%d minute" msgid_plural "%d minutes" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:628 +#: kallithea/lib/webutils.py:633 #, python-format msgid "%d second" msgid_plural "%d seconds" msgstr[0] "" msgstr[1] "" -#: kallithea/lib/webutils.py:644 +#: kallithea/lib/webutils.py:649 #, python-format msgid "in %s" msgstr "" -#: kallithea/lib/webutils.py:646 -#, python-format -msgid "%s ago" -msgstr "" - -#: kallithea/lib/webutils.py:648 -#, python-format -msgid "in %s and %s" -msgstr "" - #: kallithea/lib/webutils.py:651 #, python-format +msgid "%s ago" +msgstr "" + +#: kallithea/lib/webutils.py:653 +#, python-format +msgid "in %s and %s" +msgstr "" + +#: kallithea/lib/webutils.py:656 +#, python-format msgid "%s and %s ago" msgstr "" -#: kallithea/lib/webutils.py:654 +#: kallithea/lib/webutils.py:659 msgid "just now" msgstr "" @@ -1791,10 +1791,10 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:58 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:60 #: kallithea/templates/admin/repo_groups/repo_group_add.html:35 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 #: kallithea/templates/admin/repo_groups/repo_groups.html:41 -#: kallithea/templates/admin/repos/repo_add_base.html:21 -#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/admin/repos/repo_add_base.html:26 +#: kallithea/templates/admin/repos/repo_edit_settings.html:31 #: kallithea/templates/admin/repos/repos.html:40 #: kallithea/templates/admin/user_groups/user_group_add.html:33 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:10 @@ -1826,8 +1826,9 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_advanced.html:10 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 #: kallithea/templates/admin/repo_groups/repo_groups.html:43 -#: kallithea/templates/admin/repos/repo_edit_settings.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:52 #: kallithea/templates/admin/repos/repos.html:43 #: kallithea/templates/admin/user_groups/user_group_edit_advanced.html:8 #: kallithea/templates/admin/user_groups/user_groups.html:43 @@ -2077,13 +2078,13 @@ #: kallithea/templates/admin/my_account/my_account_profile.html:47 #: kallithea/templates/admin/permissions/permissions_globals.html:87 #: kallithea/templates/admin/repo_groups/repo_group_add.html:58 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:27 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:84 -#: kallithea/templates/admin/repos/repo_edit_settings.html:99 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:97 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:34 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:86 +#: kallithea/templates/admin/repos/repo_edit_settings.html:96 #: kallithea/templates/admin/settings/settings_hooks.html:34 #: kallithea/templates/admin/user_groups/user_group_add.html:48 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:87 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:46 #: kallithea/templates/admin/users/user_add.html:80 #: kallithea/templates/admin/users/user_edit_profile.html:89 @@ -2098,21 +2099,21 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:42 +#: kallithea/templates/admin/repos/repo_add_base.html:10 #: kallithea/templates/admin/repos/repo_edit_fields.html:8 msgid "Type" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:34 -#: kallithea/templates/admin/repos/repo_add_base.html:56 -#: kallithea/templates/admin/repos/repo_edit_settings.html:62 +#: kallithea/templates/admin/repos/repo_add_base.html:54 +#: kallithea/templates/admin/repos/repo_edit_settings.html:59 #: kallithea/templates/data_table/_dt_elements.html:21 msgid "Private repository" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:37 -#: kallithea/templates/admin/repos/repo_add_base.html:59 -#: kallithea/templates/admin/repos/repo_edit_settings.html:65 +#: kallithea/templates/admin/repos/repo_add_base.html:57 +#: kallithea/templates/admin/repos/repo_edit_settings.html:62 #: kallithea/templates/forks/fork.html:61 msgid "" "Private repositories are only visible to people explicitly added as " @@ -2120,22 +2121,26 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:42 -#: kallithea/templates/admin/repos/repo_edit_settings.html:69 +#: kallithea/templates/admin/repos/repo_add_base.html:61 +#: kallithea/templates/admin/repos/repo_edit_settings.html:66 msgid "Enable statistics" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:45 -#: kallithea/templates/admin/repos/repo_edit_settings.html:72 +#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_edit_settings.html:69 msgid "Enable statistics window on summary page." msgstr "" #: kallithea/templates/admin/defaults/defaults.html:50 -#: kallithea/templates/admin/repos/repo_edit_settings.html:76 +#: kallithea/templates/admin/repos/repo_add_base.html:68 +#: kallithea/templates/admin/repos/repo_edit_settings.html:73 msgid "Enable downloads" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:53 -#: kallithea/templates/admin/repos/repo_edit_settings.html:79 +#: kallithea/templates/admin/repos/repo_add_base.html:71 +#: kallithea/templates/admin/repos/repo_edit_settings.html:76 msgid "Enable download menu on summary page." msgstr "" @@ -2260,15 +2265,15 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:66 #: kallithea/templates/admin/permissions/permissions_globals.html:88 #: kallithea/templates/admin/permissions/permissions_ips.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:99 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:28 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:35 #: kallithea/templates/admin/repos/repo_edit_fields.html:54 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:85 -#: kallithea/templates/admin/repos/repo_edit_settings.html:100 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:87 +#: kallithea/templates/admin/repos/repo_edit_settings.html:97 #: kallithea/templates/admin/settings/settings_global.html:50 #: kallithea/templates/admin/settings/settings_vcs.html:59 #: kallithea/templates/admin/settings/settings_visual.html:129 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:89 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 #: kallithea/templates/admin/users/user_edit_api_keys.html:14 #: kallithea/templates/admin/users/user_edit_api_keys.html:73 #: kallithea/templates/admin/users/user_edit_emails.html:47 @@ -2445,7 +2450,7 @@ #: kallithea/templates/admin/my_account/my_account_emails.html:46 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:65 #: kallithea/templates/admin/permissions/permissions_ips.html:33 -#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_add_base.html:76 #: kallithea/templates/admin/repos/repo_edit_fields.html:53 #: kallithea/templates/admin/users/user_edit_api_keys.html:72 #: kallithea/templates/admin/users/user_edit_emails.html:46 @@ -2541,7 +2546,7 @@ #: kallithea/templates/admin/my_account/my_account_repos.html:14 #: kallithea/templates/admin/my_account/my_account_watched.html:14 #: kallithea/templates/admin/repo_groups/repo_groups.html:40 -#: kallithea/templates/admin/repos/repo_add_base.html:6 +#: kallithea/templates/admin/repos/repo_add_base.html:4 #: kallithea/templates/admin/repos/repo_edit_settings.html:4 #: kallithea/templates/admin/repos/repos.html:39 #: kallithea/templates/admin/user_groups/user_groups.html:39 @@ -2637,8 +2642,8 @@ msgstr "" #: kallithea/templates/admin/permissions/permissions_globals.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:28 -#: kallithea/templates/admin/repos/repo_edit_settings.html:33 +#: kallithea/templates/admin/repos/repo_add_base.html:33 +#: kallithea/templates/admin/repos/repo_edit_settings.html:38 #: kallithea/templates/data_table/_dt_elements.html:140 #: kallithea/templates/forks/fork.html:42 msgid "Repository group" @@ -2729,7 +2734,7 @@ #: kallithea/templates/admin/repo_groups/repo_group_add.html:11 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:11 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/base/base.html:57 kallithea/templates/base/base.html:76 msgid "Repository Groups" @@ -2743,17 +2748,17 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:42 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:26 msgid "Group parent" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:49 -#: kallithea/templates/admin/repos/repo_add_base.html:35 +#: kallithea/templates/admin/repos/repo_add_base.html:40 msgid "Copy parent group permissions" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:52 -#: kallithea/templates/admin/repos/repo_add_base.html:38 +#: kallithea/templates/admin/repos/repo_add_base.html:43 msgid "Copy permission set from parent repository group." msgstr "" @@ -2824,71 +2829,77 @@ msgid "Delete this repository group" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +msgid "Not visible" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -msgid "Not visible" +msgid "Visible" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 -msgid "Visible" +msgid "Add repos" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 -msgid "Add repos" +msgid "Add/Edit groups" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -msgid "Add/Edit groups" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:11 #: kallithea/templates/admin/repos/repo_edit_permissions.html:11 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:11 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 msgid "User/User Group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:28 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:45 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:27 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:44 #: kallithea/templates/admin/repos/repo_edit_permissions.html:23 #: kallithea/templates/admin/repos/repo_edit_permissions.html:36 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:28 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:45 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:27 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:44 msgid "Default" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:71 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:33 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:70 #: kallithea/templates/admin/repos/repo_edit_permissions.html:42 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:67 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:34 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:71 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:69 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:33 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:70 msgid "Revoke" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:81 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:77 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:81 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:80 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:79 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:80 msgid "Add new" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:86 msgid "Apply to children" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +msgid "Both" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:91 -msgid "Both" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:92 msgid "" "Set or revoke permission to all children of that group, including non-" "private repositories and other groups if selected." msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:14 +#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/pullrequests/pullrequest_show.html:131 +msgid "Type name of user" +msgstr "" + +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Remove this group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Confirm to delete this group" msgstr "" @@ -2905,39 +2916,45 @@ msgid "Number of Top-level Repositories" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:12 +#: kallithea/templates/admin/repos/repo_add_base.html:13 +msgid "Type of repository to create." +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:17 msgid "Clone remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:16 +#: kallithea/templates/admin/repos/repo_add_base.html:19 +#: kallithea/templates/admin/repos/repo_edit_settings.html:23 +msgid "Repository URL" +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:21 msgid "" "Optional: URL of a remote repository. If set, the repository will be " "created as a clone from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:24 -#: kallithea/templates/admin/repos/repo_edit_settings.html:57 +#: kallithea/templates/admin/repos/repo_add_base.html:29 +#: kallithea/templates/admin/repos/repo_edit_settings.html:34 #: kallithea/templates/forks/fork.html:37 msgid "Keep it short and to the point. Use a README file for longer descriptions." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:31 -#: kallithea/templates/admin/repos/repo_edit_settings.html:36 +#: kallithea/templates/admin/repos/repo_add_base.html:36 +#: kallithea/templates/admin/repos/repo_edit_settings.html:41 #: kallithea/templates/forks/fork.html:45 msgid "Optionally select a group to put this repository into." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:45 -msgid "Type of repository to create." -msgstr "" - -#: kallithea/templates/admin/repos/repo_add_base.html:49 -#: kallithea/templates/admin/repos/repo_edit_settings.html:40 +#: kallithea/templates/admin/repos/repo_add_base.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:45 #: kallithea/templates/forks/fork.html:50 msgid "Landing revision" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:52 +#: kallithea/templates/admin/repos/repo_add_base.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:48 msgid "" "Default revision for files page, downloads, full text search index and " "readme generation" @@ -3116,36 +3133,23 @@ msgid "" "In case this repository is renamed or moved into another group the " "repository URL changes.\n" -" Using the above permanent URL guarantees " -"that this repository always will be accessible on that URL.\n" -" This is useful for CI systems, or any " -"other cases that you need to hardcode the URL into a 3rd party service." +" Using the above permanent URL guarantees that " +"this repository always will be accessible on that URL.\n" +" This is useful for CI systems, or any other " +"cases that you need to hardcode the URL into a 3rd party service." msgstr "" #: kallithea/templates/admin/repos/repo_edit_settings.html:21 msgid "Remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:24 -msgid "Repository URL" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:28 +#: kallithea/templates/admin/repos/repo_edit_settings.html:26 msgid "" "Optional: URL of a remote repository. If set, the repository can be " "pulled from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:43 -msgid "Default revision for files page, downloads, whoosh and readme" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:49 -#: kallithea/templates/pullrequests/pullrequest_show.html:131 -msgid "Type name of user" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:55 msgid "Change owner of this repository." msgstr "" diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/i18n/lb/LC_MESSAGES/kallithea.po --- a/kallithea/i18n/lb/LC_MESSAGES/kallithea.po Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/i18n/lb/LC_MESSAGES/kallithea.po Mon Dec 12 23:01:11 2022 +0100 @@ -3,7 +3,7 @@ msgid "" msgstr "" "Report-Msgid-Bugs-To: translations@kallithea-scm.org\n" -"POT-Creation-Date: 2022-12-12 22:25+0100\n" +"POT-Creation-Date: 2022-12-12 23:01+0100\n" "PO-Revision-Date: 2020-04-13 19:42+0000\n" "Last-Translator: Dennis Fink \n" "Language: lb\n" @@ -40,10 +40,10 @@ #: kallithea/controllers/admin/permissions.py:65 #: kallithea/controllers/admin/permissions.py:70 #: kallithea/controllers/changelog.py:136 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 #: kallithea/templates/admin/repos/repo_edit_permissions.html:7 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:6 #: kallithea/templates/base/perms_summary.html:14 msgid "None" msgstr "Keng" @@ -257,7 +257,7 @@ msgstr "Gruppen" #: kallithea/controllers/home.py:87 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 #: kallithea/templates/admin/repos/repo_add.html:12 #: kallithea/templates/admin/repos/repo_add.html:16 #: kallithea/templates/admin/repos/repos.html:9 @@ -608,9 +608,9 @@ #: kallithea/controllers/admin/permissions.py:61 #: kallithea/controllers/admin/permissions.py:66 #: kallithea/controllers/admin/permissions.py:71 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 #: kallithea/templates/admin/repos/repo_edit_permissions.html:8 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 #: kallithea/templates/base/perms_summary.html:15 msgid "Read" msgstr "Liesen" @@ -618,9 +618,9 @@ #: kallithea/controllers/admin/permissions.py:62 #: kallithea/controllers/admin/permissions.py:67 #: kallithea/controllers/admin/permissions.py:72 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 #: kallithea/templates/admin/repos/repo_edit_permissions.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 #: kallithea/templates/base/perms_summary.html:16 msgid "Write" msgstr "Schreiwen" @@ -633,8 +633,8 @@ #: kallithea/templates/admin/permissions/permissions.html:9 #: kallithea/templates/admin/repo_groups/repo_group_add.html:9 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:9 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:47 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:46 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/admin/repos/repo_add.html:10 #: kallithea/templates/admin/repos/repo_add.html:14 @@ -642,8 +642,8 @@ #: kallithea/templates/admin/settings/settings.html:9 #: kallithea/templates/admin/user_groups/user_group_add.html:8 #: kallithea/templates/admin/user_groups/user_group_edit.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:47 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:46 #: kallithea/templates/admin/user_groups/user_groups.html:9 #: kallithea/templates/admin/users/user_add.html:8 #: kallithea/templates/admin/users/user_edit.html:9 @@ -699,57 +699,57 @@ msgid "Error occurred during update of permissions" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:164 +#: kallithea/controllers/admin/repo_groups.py:165 #, python-format msgid "Error occurred during creation of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:171 +#: kallithea/controllers/admin/repo_groups.py:172 #, python-format msgid "Created repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:224 +#: kallithea/controllers/admin/repo_groups.py:225 #, python-format msgid "Updated repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:240 +#: kallithea/controllers/admin/repo_groups.py:241 #, python-format msgid "Error occurred during update of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:250 +#: kallithea/controllers/admin/repo_groups.py:252 #, python-format msgid "This group contains %s repositories and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:257 +#: kallithea/controllers/admin/repo_groups.py:259 #, python-format msgid "This group contains %s subgroups and cannot be deleted" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:263 +#: kallithea/controllers/admin/repo_groups.py:265 #, python-format msgid "Removed repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:268 +#: kallithea/controllers/admin/repo_groups.py:270 #, python-format msgid "Error occurred during deletion of repository group %s" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:352 -#: kallithea/controllers/admin/repo_groups.py:382 +#: kallithea/controllers/admin/repo_groups.py:354 +#: kallithea/controllers/admin/repo_groups.py:384 #: kallithea/controllers/admin/user_groups.py:288 msgid "Cannot revoke permission for yourself as admin" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:367 +#: kallithea/controllers/admin/repo_groups.py:369 msgid "Repository group permissions updated" msgstr "" -#: kallithea/controllers/admin/repo_groups.py:399 +#: kallithea/controllers/admin/repo_groups.py:401 #: kallithea/controllers/admin/repos.py:334 #: kallithea/controllers/admin/user_groups.py:300 msgid "An error occurred during revoking of permission" @@ -1265,69 +1265,69 @@ msgid "Invalid SSH key - it is a %s key but the base64 part contains %r" msgstr "" -#: kallithea/lib/webutils.py:623 +#: kallithea/lib/webutils.py:628 #, python-format msgid "%d year" msgid_plural "%d years" msgstr[0] "%d Joer" msgstr[1] "%d Joer" -#: kallithea/lib/webutils.py:624 +#: kallithea/lib/webutils.py:629 #, python-format msgid "%d month" msgid_plural "%d months" msgstr[0] "%d Mount" msgstr[1] "%d Méint" -#: kallithea/lib/webutils.py:625 +#: kallithea/lib/webutils.py:630 #, python-format msgid "%d day" msgid_plural "%d days" msgstr[0] "%d Dag" msgstr[1] "%d Deeg" -#: kallithea/lib/webutils.py:626 +#: kallithea/lib/webutils.py:631 #, python-format msgid "%d hour" msgid_plural "%d hours" msgstr[0] "%d Stonn" msgstr[1] "%d Stonnen" -#: kallithea/lib/webutils.py:627 +#: kallithea/lib/webutils.py:632 #, python-format msgid "%d minute" msgid_plural "%d minutes" msgstr[0] "%d Minutt" msgstr[1] "%d Minutten" -#: kallithea/lib/webutils.py:628 +#: kallithea/lib/webutils.py:633 #, python-format msgid "%d second" msgid_plural "%d seconds" msgstr[0] "%d Sekonn" msgstr[1] "%d Sekonnen" -#: kallithea/lib/webutils.py:644 +#: kallithea/lib/webutils.py:649 #, python-format msgid "in %s" msgstr "" -#: kallithea/lib/webutils.py:646 -#, python-format -msgid "%s ago" -msgstr "" - -#: kallithea/lib/webutils.py:648 -#, python-format -msgid "in %s and %s" -msgstr "" - #: kallithea/lib/webutils.py:651 #, python-format +msgid "%s ago" +msgstr "" + +#: kallithea/lib/webutils.py:653 +#, python-format +msgid "in %s and %s" +msgstr "" + +#: kallithea/lib/webutils.py:656 +#, python-format msgid "%s and %s ago" msgstr "" -#: kallithea/lib/webutils.py:654 +#: kallithea/lib/webutils.py:659 msgid "just now" msgstr "" @@ -1800,10 +1800,10 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:58 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:60 #: kallithea/templates/admin/repo_groups/repo_group_add.html:35 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 #: kallithea/templates/admin/repo_groups/repo_groups.html:41 -#: kallithea/templates/admin/repos/repo_add_base.html:21 -#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/admin/repos/repo_add_base.html:26 +#: kallithea/templates/admin/repos/repo_edit_settings.html:31 #: kallithea/templates/admin/repos/repos.html:40 #: kallithea/templates/admin/user_groups/user_group_add.html:33 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:10 @@ -1835,8 +1835,9 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_advanced.html:10 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 #: kallithea/templates/admin/repo_groups/repo_groups.html:43 -#: kallithea/templates/admin/repos/repo_edit_settings.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:52 #: kallithea/templates/admin/repos/repos.html:43 #: kallithea/templates/admin/user_groups/user_group_edit_advanced.html:8 #: kallithea/templates/admin/user_groups/user_groups.html:43 @@ -2086,13 +2087,13 @@ #: kallithea/templates/admin/my_account/my_account_profile.html:47 #: kallithea/templates/admin/permissions/permissions_globals.html:87 #: kallithea/templates/admin/repo_groups/repo_group_add.html:58 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:27 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:84 -#: kallithea/templates/admin/repos/repo_edit_settings.html:99 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:97 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:34 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:86 +#: kallithea/templates/admin/repos/repo_edit_settings.html:96 #: kallithea/templates/admin/settings/settings_hooks.html:34 #: kallithea/templates/admin/user_groups/user_group_add.html:48 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:87 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:46 #: kallithea/templates/admin/users/user_add.html:80 #: kallithea/templates/admin/users/user_edit_profile.html:89 @@ -2107,21 +2108,21 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:42 +#: kallithea/templates/admin/repos/repo_add_base.html:10 #: kallithea/templates/admin/repos/repo_edit_fields.html:8 msgid "Type" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:34 -#: kallithea/templates/admin/repos/repo_add_base.html:56 -#: kallithea/templates/admin/repos/repo_edit_settings.html:62 +#: kallithea/templates/admin/repos/repo_add_base.html:54 +#: kallithea/templates/admin/repos/repo_edit_settings.html:59 #: kallithea/templates/data_table/_dt_elements.html:21 msgid "Private repository" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:37 -#: kallithea/templates/admin/repos/repo_add_base.html:59 -#: kallithea/templates/admin/repos/repo_edit_settings.html:65 +#: kallithea/templates/admin/repos/repo_add_base.html:57 +#: kallithea/templates/admin/repos/repo_edit_settings.html:62 #: kallithea/templates/forks/fork.html:61 msgid "" "Private repositories are only visible to people explicitly added as " @@ -2129,22 +2130,26 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:42 -#: kallithea/templates/admin/repos/repo_edit_settings.html:69 +#: kallithea/templates/admin/repos/repo_add_base.html:61 +#: kallithea/templates/admin/repos/repo_edit_settings.html:66 msgid "Enable statistics" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:45 -#: kallithea/templates/admin/repos/repo_edit_settings.html:72 +#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_edit_settings.html:69 msgid "Enable statistics window on summary page." msgstr "" #: kallithea/templates/admin/defaults/defaults.html:50 -#: kallithea/templates/admin/repos/repo_edit_settings.html:76 +#: kallithea/templates/admin/repos/repo_add_base.html:68 +#: kallithea/templates/admin/repos/repo_edit_settings.html:73 msgid "Enable downloads" msgstr "" #: kallithea/templates/admin/defaults/defaults.html:53 -#: kallithea/templates/admin/repos/repo_edit_settings.html:79 +#: kallithea/templates/admin/repos/repo_add_base.html:71 +#: kallithea/templates/admin/repos/repo_edit_settings.html:76 msgid "Enable download menu on summary page." msgstr "" @@ -2269,15 +2274,15 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:66 #: kallithea/templates/admin/permissions/permissions_globals.html:88 #: kallithea/templates/admin/permissions/permissions_ips.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:99 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:28 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:35 #: kallithea/templates/admin/repos/repo_edit_fields.html:54 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:85 -#: kallithea/templates/admin/repos/repo_edit_settings.html:100 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:87 +#: kallithea/templates/admin/repos/repo_edit_settings.html:97 #: kallithea/templates/admin/settings/settings_global.html:50 #: kallithea/templates/admin/settings/settings_vcs.html:59 #: kallithea/templates/admin/settings/settings_visual.html:129 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:89 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 #: kallithea/templates/admin/users/user_edit_api_keys.html:14 #: kallithea/templates/admin/users/user_edit_api_keys.html:73 #: kallithea/templates/admin/users/user_edit_emails.html:47 @@ -2454,7 +2459,7 @@ #: kallithea/templates/admin/my_account/my_account_emails.html:46 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:65 #: kallithea/templates/admin/permissions/permissions_ips.html:33 -#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_add_base.html:76 #: kallithea/templates/admin/repos/repo_edit_fields.html:53 #: kallithea/templates/admin/users/user_edit_api_keys.html:72 #: kallithea/templates/admin/users/user_edit_emails.html:46 @@ -2551,7 +2556,7 @@ #: kallithea/templates/admin/my_account/my_account_repos.html:14 #: kallithea/templates/admin/my_account/my_account_watched.html:14 #: kallithea/templates/admin/repo_groups/repo_groups.html:40 -#: kallithea/templates/admin/repos/repo_add_base.html:6 +#: kallithea/templates/admin/repos/repo_add_base.html:4 #: kallithea/templates/admin/repos/repo_edit_settings.html:4 #: kallithea/templates/admin/repos/repos.html:39 #: kallithea/templates/admin/user_groups/user_groups.html:39 @@ -2647,8 +2652,8 @@ msgstr "" #: kallithea/templates/admin/permissions/permissions_globals.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:28 -#: kallithea/templates/admin/repos/repo_edit_settings.html:33 +#: kallithea/templates/admin/repos/repo_add_base.html:33 +#: kallithea/templates/admin/repos/repo_edit_settings.html:38 #: kallithea/templates/data_table/_dt_elements.html:140 #: kallithea/templates/forks/fork.html:42 msgid "Repository group" @@ -2740,7 +2745,7 @@ #: kallithea/templates/admin/repo_groups/repo_group_add.html:11 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:11 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/base/base.html:57 #: kallithea/templates/base/base.html:76 @@ -2755,17 +2760,17 @@ msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:42 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:26 msgid "Group parent" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:49 -#: kallithea/templates/admin/repos/repo_add_base.html:35 +#: kallithea/templates/admin/repos/repo_add_base.html:40 msgid "Copy parent group permissions" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:52 -#: kallithea/templates/admin/repos/repo_add_base.html:38 +#: kallithea/templates/admin/repos/repo_add_base.html:43 msgid "Copy permission set from parent repository group." msgstr "" @@ -2837,71 +2842,77 @@ msgid "Delete this repository group" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +msgid "Not visible" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -msgid "Not visible" +msgid "Visible" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 -msgid "Visible" +msgid "Add repos" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 -msgid "Add repos" +msgid "Add/Edit groups" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -msgid "Add/Edit groups" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:11 #: kallithea/templates/admin/repos/repo_edit_permissions.html:11 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:11 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 msgid "User/User Group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:28 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:45 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:27 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:44 #: kallithea/templates/admin/repos/repo_edit_permissions.html:23 #: kallithea/templates/admin/repos/repo_edit_permissions.html:36 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:28 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:45 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:27 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:44 msgid "Default" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:71 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:33 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:70 #: kallithea/templates/admin/repos/repo_edit_permissions.html:42 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:67 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:34 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:71 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:69 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:33 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:70 msgid "Revoke" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:81 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:77 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:81 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:80 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:79 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:80 msgid "Add new" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:86 msgid "Apply to children" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +msgid "Both" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:91 -msgid "Both" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:92 msgid "" "Set or revoke permission to all children of that group, including non-" "private repositories and other groups if selected." msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:14 +#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/pullrequests/pullrequest_show.html:131 +msgid "Type name of user" +msgstr "" + +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Remove this group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Confirm to delete this group" msgstr "" @@ -2918,40 +2929,46 @@ msgid "Number of Top-level Repositories" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:12 +#: kallithea/templates/admin/repos/repo_add_base.html:13 +msgid "Type of repository to create." +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:17 msgid "Clone remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:16 +#: kallithea/templates/admin/repos/repo_add_base.html:19 +#: kallithea/templates/admin/repos/repo_edit_settings.html:23 +msgid "Repository URL" +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:21 msgid "" "Optional: URL of a remote repository. If set, the repository will be " "created as a clone from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:24 -#: kallithea/templates/admin/repos/repo_edit_settings.html:57 +#: kallithea/templates/admin/repos/repo_add_base.html:29 +#: kallithea/templates/admin/repos/repo_edit_settings.html:34 #: kallithea/templates/forks/fork.html:37 msgid "" "Keep it short and to the point. Use a README file for longer descriptions." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:31 -#: kallithea/templates/admin/repos/repo_edit_settings.html:36 +#: kallithea/templates/admin/repos/repo_add_base.html:36 +#: kallithea/templates/admin/repos/repo_edit_settings.html:41 #: kallithea/templates/forks/fork.html:45 msgid "Optionally select a group to put this repository into." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:45 -msgid "Type of repository to create." -msgstr "" - -#: kallithea/templates/admin/repos/repo_add_base.html:49 -#: kallithea/templates/admin/repos/repo_edit_settings.html:40 +#: kallithea/templates/admin/repos/repo_add_base.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:45 #: kallithea/templates/forks/fork.html:50 msgid "Landing revision" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:52 +#: kallithea/templates/admin/repos/repo_add_base.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:48 msgid "" "Default revision for files page, downloads, full text search index and " "readme generation" @@ -3130,36 +3147,23 @@ msgid "" "In case this repository is renamed or moved into another group the " "repository URL changes.\n" -" Using the above permanent URL guarantees " -"that this repository always will be accessible on that URL.\n" -" This is useful for CI systems, or any " -"other cases that you need to hardcode the URL into a 3rd party service." +" Using the above permanent URL guarantees that " +"this repository always will be accessible on that URL.\n" +" This is useful for CI systems, or any other " +"cases that you need to hardcode the URL into a 3rd party service." msgstr "" #: kallithea/templates/admin/repos/repo_edit_settings.html:21 msgid "Remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:24 -msgid "Repository URL" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:28 +#: kallithea/templates/admin/repos/repo_edit_settings.html:26 msgid "" "Optional: URL of a remote repository. If set, the repository can be " "pulled from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:43 -msgid "Default revision for files page, downloads, whoosh and readme" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:49 -#: kallithea/templates/pullrequests/pullrequest_show.html:131 -msgid "Type name of user" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:55 msgid "Change owner of this repository." msgstr "" diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/i18n/nb_NO/LC_MESSAGES/kallithea.po --- a/kallithea/i18n/nb_NO/LC_MESSAGES/kallithea.po Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/i18n/nb_NO/LC_MESSAGES/kallithea.po Mon Dec 12 23:01:11 2022 +0100 @@ -4,7 +4,7 @@ msgstr "" "Project-Id-Version: Kallithea 0.3.99\n" "Report-Msgid-Bugs-To: translations@kallithea-scm.org\n" -"POT-Creation-Date: 2022-12-12 22:25+0100\n" +"POT-Creation-Date: 2022-12-12 23:01+0100\n" "PO-Revision-Date: 2020-08-11 11:32+0000\n" "Last-Translator: Allan Nordhøy \n" "Language-Team: Norwegian Bokmål \n" "Language-Team: Flemish \n" "Language-Team: Polish \n" "Language-Team: none\n" @@ -46,10 +46,10 @@ #: kallithea/controllers/admin/permissions.py:65 #: kallithea/controllers/admin/permissions.py:70 #: kallithea/controllers/changelog.py:136 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 #: kallithea/templates/admin/repos/repo_edit_permissions.html:7 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:6 #: kallithea/templates/base/perms_summary.html:14 msgid "None" msgstr "Nenhum" @@ -267,7 +267,7 @@ msgstr "" #: kallithea/controllers/home.py:87 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 #: kallithea/templates/admin/repos/repo_add.html:12 #: kallithea/templates/admin/repos/repo_add.html:16 #: kallithea/templates/admin/repos/repos.html:9 @@ -619,9 +619,9 @@ #: kallithea/controllers/admin/permissions.py:61 #: kallithea/controllers/admin/permissions.py:66 #: kallithea/controllers/admin/permissions.py:71 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 #: kallithea/templates/admin/repos/repo_edit_permissions.html:8 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:7 #: kallithea/templates/base/perms_summary.html:15 msgid "Read" msgstr "Ler" @@ -629,9 +629,9 @@ #: kallithea/controllers/admin/permissions.py:62 #: kallithea/controllers/admin/permissions.py:67 #: kallithea/controllers/admin/permissions.py:72 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 #: kallithea/templates/admin/repos/repo_edit_permissions.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:8 #: kallithea/templates/base/perms_summary.html:16 msgid "Write" msgstr "Gravar" @@ -644,8 +644,8 @@ #: kallithea/templates/admin/permissions/permissions.html:9 #: kallithea/templates/admin/repo_groups/repo_group_add.html:9 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:9 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:47 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:46 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/admin/repos/repo_add.html:10 #: kallithea/templates/admin/repos/repo_add.html:14 @@ -653,8 +653,8 @@ #: kallithea/templates/admin/settings/settings.html:9 #: kallithea/templates/admin/user_groups/user_group_add.html:8 #: kallithea/templates/admin/user_groups/user_group_edit.html:9 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:47 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:9 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:46 #: kallithea/templates/admin/user_groups/user_groups.html:9 #: kallithea/templates/admin/users/user_add.html:8 #: kallithea/templates/admin/users/user_edit.html:9 @@ -710,57 +710,57 @@ msgid "Error occurred during update of permissions" msgstr "Ocorreu um erro durante a atualização das permissões" -#: kallithea/controllers/admin/repo_groups.py:164 +#: kallithea/controllers/admin/repo_groups.py:165 #, python-format msgid "Error occurred during creation of repository group %s" msgstr "Ocorreu um erro durante a criação do grupo de repositórios %s" -#: kallithea/controllers/admin/repo_groups.py:171 +#: kallithea/controllers/admin/repo_groups.py:172 #, python-format msgid "Created repository group %s" msgstr "Grupo de repositórios %s criado" -#: kallithea/controllers/admin/repo_groups.py:224 +#: kallithea/controllers/admin/repo_groups.py:225 #, python-format msgid "Updated repository group %s" msgstr "Grupo de repositórios %s atualizado" -#: kallithea/controllers/admin/repo_groups.py:240 +#: kallithea/controllers/admin/repo_groups.py:241 #, python-format msgid "Error occurred during update of repository group %s" msgstr "Ocorreu um erro durante a atualização do grupo de repositórios %s" -#: kallithea/controllers/admin/repo_groups.py:250 +#: kallithea/controllers/admin/repo_groups.py:252 #, python-format msgid "This group contains %s repositories and cannot be deleted" msgstr "Esse grupo contém %s repositórios e não pode ser apagado" -#: kallithea/controllers/admin/repo_groups.py:257 +#: kallithea/controllers/admin/repo_groups.py:259 #, python-format msgid "This group contains %s subgroups and cannot be deleted" msgstr "Este grupo contém %s subgrupos e não pode ser apagado" -#: kallithea/controllers/admin/repo_groups.py:263 +#: kallithea/controllers/admin/repo_groups.py:265 #, python-format msgid "Removed repository group %s" msgstr "Grupo de repositórios %s apagado" -#: kallithea/controllers/admin/repo_groups.py:268 +#: kallithea/controllers/admin/repo_groups.py:270 #, python-format msgid "Error occurred during deletion of repository group %s" msgstr "Ocorreu um erro durante a exclusão do grupo de repositórios %s" -#: kallithea/controllers/admin/repo_groups.py:352 -#: kallithea/controllers/admin/repo_groups.py:382 +#: kallithea/controllers/admin/repo_groups.py:354 +#: kallithea/controllers/admin/repo_groups.py:384 #: kallithea/controllers/admin/user_groups.py:288 msgid "Cannot revoke permission for yourself as admin" msgstr "Não pode revocar sua própria permissão de administrador" -#: kallithea/controllers/admin/repo_groups.py:367 +#: kallithea/controllers/admin/repo_groups.py:369 msgid "Repository group permissions updated" msgstr "Permissões atualizadas do Grupo de Repositórios" -#: kallithea/controllers/admin/repo_groups.py:399 +#: kallithea/controllers/admin/repo_groups.py:401 #: kallithea/controllers/admin/repos.py:334 #: kallithea/controllers/admin/user_groups.py:300 msgid "An error occurred during revoking of permission" @@ -1280,69 +1280,69 @@ msgid "Invalid SSH key - it is a %s key but the base64 part contains %r" msgstr "" -#: kallithea/lib/webutils.py:623 +#: kallithea/lib/webutils.py:628 #, python-format msgid "%d year" msgid_plural "%d years" msgstr[0] "%d ano" msgstr[1] "%d anos" -#: kallithea/lib/webutils.py:624 +#: kallithea/lib/webutils.py:629 #, python-format msgid "%d month" msgid_plural "%d months" msgstr[0] "%d mês" msgstr[1] "%d meses" -#: kallithea/lib/webutils.py:625 +#: kallithea/lib/webutils.py:630 #, python-format msgid "%d day" msgid_plural "%d days" msgstr[0] "%d dia" msgstr[1] "%d dias" -#: kallithea/lib/webutils.py:626 +#: kallithea/lib/webutils.py:631 #, python-format msgid "%d hour" msgid_plural "%d hours" msgstr[0] "%d hora" msgstr[1] "%d horas" -#: kallithea/lib/webutils.py:627 +#: kallithea/lib/webutils.py:632 #, python-format msgid "%d minute" msgid_plural "%d minutes" msgstr[0] "%d minuto" msgstr[1] "%d minutos" -#: kallithea/lib/webutils.py:628 +#: kallithea/lib/webutils.py:633 #, python-format msgid "%d second" msgid_plural "%d seconds" msgstr[0] "%d segundo" msgstr[1] "%d segundos" -#: kallithea/lib/webutils.py:644 +#: kallithea/lib/webutils.py:649 #, python-format msgid "in %s" msgstr "em %s" -#: kallithea/lib/webutils.py:646 +#: kallithea/lib/webutils.py:651 #, python-format msgid "%s ago" msgstr "%s atrás" -#: kallithea/lib/webutils.py:648 +#: kallithea/lib/webutils.py:653 #, python-format msgid "in %s and %s" msgstr "em %s e %s" -#: kallithea/lib/webutils.py:651 +#: kallithea/lib/webutils.py:656 #, python-format msgid "%s and %s ago" msgstr "%s e %s atrás" -#: kallithea/lib/webutils.py:654 +#: kallithea/lib/webutils.py:659 msgid "just now" msgstr "agora há pouco" @@ -1821,10 +1821,10 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:58 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:60 #: kallithea/templates/admin/repo_groups/repo_group_add.html:35 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 #: kallithea/templates/admin/repo_groups/repo_groups.html:41 -#: kallithea/templates/admin/repos/repo_add_base.html:21 -#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/admin/repos/repo_add_base.html:26 +#: kallithea/templates/admin/repos/repo_edit_settings.html:31 #: kallithea/templates/admin/repos/repos.html:40 #: kallithea/templates/admin/user_groups/user_group_add.html:33 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:10 @@ -1856,8 +1856,9 @@ msgstr "Ponta" #: kallithea/templates/admin/repo_groups/repo_group_edit_advanced.html:10 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:12 #: kallithea/templates/admin/repo_groups/repo_groups.html:43 -#: kallithea/templates/admin/repos/repo_edit_settings.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:52 #: kallithea/templates/admin/repos/repos.html:43 #: kallithea/templates/admin/user_groups/user_group_edit_advanced.html:8 #: kallithea/templates/admin/user_groups/user_groups.html:43 @@ -2107,13 +2108,13 @@ #: kallithea/templates/admin/my_account/my_account_profile.html:47 #: kallithea/templates/admin/permissions/permissions_globals.html:87 #: kallithea/templates/admin/repo_groups/repo_group_add.html:58 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:27 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:84 -#: kallithea/templates/admin/repos/repo_edit_settings.html:99 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:97 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:34 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:86 +#: kallithea/templates/admin/repos/repo_edit_settings.html:96 #: kallithea/templates/admin/settings/settings_hooks.html:34 #: kallithea/templates/admin/user_groups/user_group_add.html:48 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:87 #: kallithea/templates/admin/user_groups/user_group_edit_settings.html:46 #: kallithea/templates/admin/users/user_add.html:80 #: kallithea/templates/admin/users/user_edit_profile.html:89 @@ -2128,21 +2129,21 @@ msgstr "" #: kallithea/templates/admin/defaults/defaults.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:42 +#: kallithea/templates/admin/repos/repo_add_base.html:10 #: kallithea/templates/admin/repos/repo_edit_fields.html:8 msgid "Type" msgstr "Tipo" #: kallithea/templates/admin/defaults/defaults.html:34 -#: kallithea/templates/admin/repos/repo_add_base.html:56 -#: kallithea/templates/admin/repos/repo_edit_settings.html:62 +#: kallithea/templates/admin/repos/repo_add_base.html:54 +#: kallithea/templates/admin/repos/repo_edit_settings.html:59 #: kallithea/templates/data_table/_dt_elements.html:21 msgid "Private repository" msgstr "Repositório privado" #: kallithea/templates/admin/defaults/defaults.html:37 -#: kallithea/templates/admin/repos/repo_add_base.html:59 -#: kallithea/templates/admin/repos/repo_edit_settings.html:65 +#: kallithea/templates/admin/repos/repo_add_base.html:57 +#: kallithea/templates/admin/repos/repo_edit_settings.html:62 #: kallithea/templates/forks/fork.html:61 msgid "" "Private repositories are only visible to people explicitly added as " @@ -2152,22 +2153,26 @@ "adicionadas como colaboradores." #: kallithea/templates/admin/defaults/defaults.html:42 -#: kallithea/templates/admin/repos/repo_edit_settings.html:69 +#: kallithea/templates/admin/repos/repo_add_base.html:61 +#: kallithea/templates/admin/repos/repo_edit_settings.html:66 msgid "Enable statistics" msgstr "Ativar estatísticas" #: kallithea/templates/admin/defaults/defaults.html:45 -#: kallithea/templates/admin/repos/repo_edit_settings.html:72 +#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_edit_settings.html:69 msgid "Enable statistics window on summary page." msgstr "Ativar janela de estatísticas na página de sumário." #: kallithea/templates/admin/defaults/defaults.html:50 -#: kallithea/templates/admin/repos/repo_edit_settings.html:76 +#: kallithea/templates/admin/repos/repo_add_base.html:68 +#: kallithea/templates/admin/repos/repo_edit_settings.html:73 msgid "Enable downloads" msgstr "Ativar descarregas" #: kallithea/templates/admin/defaults/defaults.html:53 -#: kallithea/templates/admin/repos/repo_edit_settings.html:79 +#: kallithea/templates/admin/repos/repo_add_base.html:71 +#: kallithea/templates/admin/repos/repo_edit_settings.html:76 msgid "Enable download menu on summary page." msgstr "Ativar menu de descarregar na página de sumário." @@ -2292,15 +2297,15 @@ #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:66 #: kallithea/templates/admin/permissions/permissions_globals.html:88 #: kallithea/templates/admin/permissions/permissions_ips.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:99 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:28 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:98 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:35 #: kallithea/templates/admin/repos/repo_edit_fields.html:54 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:85 -#: kallithea/templates/admin/repos/repo_edit_settings.html:100 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:87 +#: kallithea/templates/admin/repos/repo_edit_settings.html:97 #: kallithea/templates/admin/settings/settings_global.html:50 #: kallithea/templates/admin/settings/settings_vcs.html:59 #: kallithea/templates/admin/settings/settings_visual.html:129 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:89 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:88 #: kallithea/templates/admin/users/user_edit_api_keys.html:14 #: kallithea/templates/admin/users/user_edit_api_keys.html:73 #: kallithea/templates/admin/users/user_edit_emails.html:47 @@ -2477,7 +2482,7 @@ #: kallithea/templates/admin/my_account/my_account_emails.html:46 #: kallithea/templates/admin/my_account/my_account_ssh_keys.html:65 #: kallithea/templates/admin/permissions/permissions_ips.html:33 -#: kallithea/templates/admin/repos/repo_add_base.html:64 +#: kallithea/templates/admin/repos/repo_add_base.html:76 #: kallithea/templates/admin/repos/repo_edit_fields.html:53 #: kallithea/templates/admin/users/user_edit_api_keys.html:72 #: kallithea/templates/admin/users/user_edit_emails.html:46 @@ -2574,7 +2579,7 @@ #: kallithea/templates/admin/my_account/my_account_repos.html:14 #: kallithea/templates/admin/my_account/my_account_watched.html:14 #: kallithea/templates/admin/repo_groups/repo_groups.html:40 -#: kallithea/templates/admin/repos/repo_add_base.html:6 +#: kallithea/templates/admin/repos/repo_add_base.html:4 #: kallithea/templates/admin/repos/repo_edit_settings.html:4 #: kallithea/templates/admin/repos/repos.html:39 #: kallithea/templates/admin/user_groups/user_groups.html:39 @@ -2673,8 +2678,8 @@ msgstr "" #: kallithea/templates/admin/permissions/permissions_globals.html:27 -#: kallithea/templates/admin/repos/repo_add_base.html:28 -#: kallithea/templates/admin/repos/repo_edit_settings.html:33 +#: kallithea/templates/admin/repos/repo_add_base.html:33 +#: kallithea/templates/admin/repos/repo_edit_settings.html:38 #: kallithea/templates/data_table/_dt_elements.html:140 #: kallithea/templates/forks/fork.html:42 msgid "Repository group" @@ -2769,7 +2774,7 @@ #: kallithea/templates/admin/repo_groups/repo_group_add.html:11 #: kallithea/templates/admin/repo_groups/repo_group_edit.html:11 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:89 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:88 #: kallithea/templates/admin/repo_groups/repo_groups.html:9 #: kallithea/templates/base/base.html:57 #: kallithea/templates/base/base.html:76 @@ -2784,17 +2789,17 @@ msgstr "Nome do grupo" #: kallithea/templates/admin/repo_groups/repo_group_add.html:42 -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:19 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:26 msgid "Group parent" msgstr "Progenitor do grupo" #: kallithea/templates/admin/repo_groups/repo_group_add.html:49 -#: kallithea/templates/admin/repos/repo_add_base.html:35 +#: kallithea/templates/admin/repos/repo_add_base.html:40 msgid "Copy parent group permissions" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_add.html:52 -#: kallithea/templates/admin/repos/repo_add_base.html:38 +#: kallithea/templates/admin/repos/repo_add_base.html:43 msgid "Copy permission set from parent repository group." msgstr "" @@ -2866,71 +2871,77 @@ msgid "Delete this repository group" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:6 +msgid "Not visible" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:7 -msgid "Not visible" +msgid "Visible" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:8 -msgid "Visible" +msgid "Add repos" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:9 -msgid "Add repos" +msgid "Add/Edit groups" msgstr "" #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:10 -msgid "Add/Edit groups" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:11 #: kallithea/templates/admin/repos/repo_edit_permissions.html:11 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:11 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:10 msgid "User/User Group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:28 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:45 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:27 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:44 #: kallithea/templates/admin/repos/repo_edit_permissions.html:23 #: kallithea/templates/admin/repos/repo_edit_permissions.html:36 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:28 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:45 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:27 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:44 msgid "Default" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:34 -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:71 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:33 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:70 #: kallithea/templates/admin/repos/repo_edit_permissions.html:42 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:67 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:34 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:71 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:69 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:33 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:70 msgid "Revoke" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:81 -#: kallithea/templates/admin/repos/repo_edit_permissions.html:77 -#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:81 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:80 +#: kallithea/templates/admin/repos/repo_edit_permissions.html:79 +#: kallithea/templates/admin/user_groups/user_group_edit_perms.html:80 msgid "Add new" msgstr "Adicionar novo" -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:87 +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:86 msgid "Apply to children" msgstr "" +#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:90 +msgid "Both" +msgstr "" + #: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:91 -msgid "Both" -msgstr "" - -#: kallithea/templates/admin/repo_groups/repo_group_edit_perms.html:92 msgid "" "Set or revoke permission to all children of that group, including non-" "private repositories and other groups if selected." msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:14 +#: kallithea/templates/admin/repos/repo_edit_settings.html:54 +#: kallithea/templates/pullrequests/pullrequest_show.html:131 +msgid "Type name of user" +msgstr "" + +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Remove this group" msgstr "" -#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:38 +#: kallithea/templates/admin/repo_groups/repo_group_edit_settings.html:45 msgid "Confirm to delete this group" msgstr "" @@ -2947,18 +2958,27 @@ msgid "Number of Top-level Repositories" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:12 +#: kallithea/templates/admin/repos/repo_add_base.html:13 +msgid "Type of repository to create." +msgstr "Tipo de repositório a criar." + +#: kallithea/templates/admin/repos/repo_add_base.html:17 msgid "Clone remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:16 +#: kallithea/templates/admin/repos/repo_add_base.html:19 +#: kallithea/templates/admin/repos/repo_edit_settings.html:23 +msgid "Repository URL" +msgstr "" + +#: kallithea/templates/admin/repos/repo_add_base.html:21 msgid "" "Optional: URL of a remote repository. If set, the repository will be " "created as a clone from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_add_base.html:24 -#: kallithea/templates/admin/repos/repo_edit_settings.html:57 +#: kallithea/templates/admin/repos/repo_add_base.html:29 +#: kallithea/templates/admin/repos/repo_edit_settings.html:34 #: kallithea/templates/forks/fork.html:37 msgid "" "Keep it short and to the point. Use a README file for longer descriptions." @@ -2966,23 +2986,20 @@ "Seja sucinto e objetivo. Use um ficheiro README para descrições mais " "longas." -#: kallithea/templates/admin/repos/repo_add_base.html:31 -#: kallithea/templates/admin/repos/repo_edit_settings.html:36 +#: kallithea/templates/admin/repos/repo_add_base.html:36 +#: kallithea/templates/admin/repos/repo_edit_settings.html:41 #: kallithea/templates/forks/fork.html:45 msgid "Optionally select a group to put this repository into." msgstr "Opcionalmente selecione um grupo no qual pôr esse repositório." -#: kallithea/templates/admin/repos/repo_add_base.html:45 -msgid "Type of repository to create." -msgstr "Tipo de repositório a criar." - -#: kallithea/templates/admin/repos/repo_add_base.html:49 -#: kallithea/templates/admin/repos/repo_edit_settings.html:40 +#: kallithea/templates/admin/repos/repo_add_base.html:47 +#: kallithea/templates/admin/repos/repo_edit_settings.html:45 #: kallithea/templates/forks/fork.html:50 msgid "Landing revision" msgstr "Revisão de pouso" -#: kallithea/templates/admin/repos/repo_add_base.html:52 +#: kallithea/templates/admin/repos/repo_add_base.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:48 msgid "" "Default revision for files page, downloads, full text search index and " "readme generation" @@ -3161,38 +3178,23 @@ msgid "" "In case this repository is renamed or moved into another group the " "repository URL changes.\n" -" Using the above permanent URL guarantees " -"that this repository always will be accessible on that URL.\n" -" This is useful for CI systems, or any " -"other cases that you need to hardcode the URL into a 3rd party service." +" Using the above permanent URL guarantees that " +"this repository always will be accessible on that URL.\n" +" This is useful for CI systems, or any other " +"cases that you need to hardcode the URL into a 3rd party service." msgstr "" #: kallithea/templates/admin/repos/repo_edit_settings.html:21 msgid "Remote repository" msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:24 -msgid "Repository URL" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:28 +#: kallithea/templates/admin/repos/repo_edit_settings.html:26 msgid "" "Optional: URL of a remote repository. If set, the repository can be " "pulled from this URL." msgstr "" -#: kallithea/templates/admin/repos/repo_edit_settings.html:43 -msgid "Default revision for files page, downloads, whoosh and readme" -msgstr "" -"Revisão predefinida para página de ficheiros, descarregamentos, whoosh e " -"readme" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:49 -#: kallithea/templates/pullrequests/pullrequest_show.html:131 -msgid "Type name of user" -msgstr "" - -#: kallithea/templates/admin/repos/repo_edit_settings.html:50 +#: kallithea/templates/admin/repos/repo_edit_settings.html:55 msgid "Change owner of this repository." msgstr "Mudar o dono desse repositório." @@ -5424,6 +5426,11 @@ msgid "Download %s as %s" msgstr "Descarregar %s como %s" +#~ msgid "Default revision for files page, downloads, whoosh and readme" +#~ msgstr "" +#~ "Revisão predefinida para página de ficheiros, descarregamentos, whoosh " +#~ "e readme" + #, python-format #~ msgid "" #~ "%s repository is not mapped to db perhaps it was created or renamed " diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/i18n/pt_BR/LC_MESSAGES/kallithea.po --- a/kallithea/i18n/pt_BR/LC_MESSAGES/kallithea.po Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/i18n/pt_BR/LC_MESSAGES/kallithea.po Mon Dec 12 23:01:11 2022 +0100 @@ -4,7 +4,7 @@ msgstr "" "Project-Id-Version: Kallithea 0.3\n" "Report-Msgid-Bugs-To: translations@kallithea-scm.org\n" -"POT-Creation-Date: 2022-12-12 22:25+0100\n" +"POT-Creation-Date: 2022-12-12 23:01+0100\n" "PO-Revision-Date: 2014-02-13 14:34+0000\n" "Last-Translator: Marcin Kuźmiński \n" "Language-Team: Portuguese (Brazil) \n" "Language-Team: Russian \n" "Language-Team: Slovak \n" "Language-Team: Turkish \n" "Language-Team: Ukrainian \n" "Language-Team: Chinese (Simplified) \n" "Language-Team: Chinese (Traditional) >>> MarkupRenderer.render('''''', '.md') - '

' + '

' >>> MarkupRenderer.render('''''', 'b.mkd') '

' >>> MarkupRenderer.render('''foo''', 'c.mkdn') diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/lib/vcs/backends/base.py --- a/kallithea/lib/vcs/backends/base.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/lib/vcs/backends/base.py Mon Dec 12 23:01:11 2022 +0100 @@ -171,7 +171,7 @@ :param start_date: :param end_date: :param branch_name: - :param reversed: + :param reverse: """ raise NotImplementedError diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/lib/vcs/backends/git/repository.py --- a/kallithea/lib/vcs/backends/git/repository.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/lib/vcs/backends/git/repository.py Mon Dec 12 23:01:11 2022 +0100 @@ -19,7 +19,12 @@ import urllib.request from collections import OrderedDict -import mercurial.util # import url as hg_url + +try: + from mercurial.utils.urlutil import url as hg_url +except ImportError: # urlutil was introduced in Mercurial 5.8 + from mercurial.util import url as hg_url + from dulwich.client import SubprocessGitClient from dulwich.config import ConfigFile from dulwich.objects import Tag @@ -226,7 +231,7 @@ if parsed_url.scheme not in ['http', 'https']: raise urllib.error.URLError("Unsupported protocol in URL %r" % url) - url_obj = mercurial.util.url(safe_bytes(url)) + url_obj = hg_url(safe_bytes(url)) test_uri, handlers = get_urllib_request_handlers(url_obj) if not test_uri.endswith(b'info/refs'): test_uri = test_uri.rstrip(b'/') + b'/info/refs' diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/lib/vcs/backends/hg/repository.py --- a/kallithea/lib/vcs/backends/hg/repository.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/lib/vcs/backends/hg/repository.py Mon Dec 12 23:01:11 2022 +0100 @@ -34,7 +34,12 @@ import mercurial.tags import mercurial.ui import mercurial.unionrepo -import mercurial.util + + +try: + from mercurial.utils.urlutil import url as hg_url +except ImportError: # urlutil was introduced in Mercurial 5.8 + from mercurial.util import url as hg_url from kallithea.lib.vcs.backends.base import BaseRepository, CollectionGenerator from kallithea.lib.vcs.exceptions import (BranchDoesNotExistError, ChangesetDoesNotExistError, EmptyRepositoryError, RepositoryError, TagAlreadyExistError, @@ -212,7 +217,7 @@ local = False try: - mercurial.tags.tag(self._repo, safe_bytes(name), mercurial.commands.nullid, safe_bytes(message), local, safe_bytes(user), date) + mercurial.tags.tag(self._repo, safe_bytes(name), mercurial.node.nullid, safe_bytes(message), local, safe_bytes(user), date) self.tags = self._get_tags() except mercurial.error.Abort as e: raise RepositoryError(e.args[0]) @@ -336,7 +341,7 @@ if '+' in parsed_url.scheme: # strip 'git+' for hg-git URLs url = url.split(b'+', 1)[1] - url_obj = mercurial.util.url(url) + url_obj = hg_url(url) test_uri, handlers = get_urllib_request_handlers(url_obj) url_obj.passwd = b'*****' @@ -523,7 +528,7 @@ :param start_date: :param end_date: :param branch_name: - :param reversed: return changesets in reversed order + :param reverse: return changesets in reversed order """ start_raw_id = self._get_revision(start) start_pos = None if start is None else self.revisions.index(start_raw_id) diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/lib/vcs/utils/helpers.py --- a/kallithea/lib/vcs/utils/helpers.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/lib/vcs/utils/helpers.py Mon Dec 12 23:01:11 2022 +0100 @@ -245,7 +245,7 @@ if authinfo: # authinfo is a tuple (realm, uris, user, password) where 'uris' itself # is a tuple of URIs. - # If url_obj is obtained via mercurial.util.url, the obtained authinfo + # If url_obj is obtained via mercurial urlutil, the obtained authinfo # values will be bytes, e.g. # (None, (b'http://127.0.0.1/repo', b'127.0.0.1'), b'user', b'pass') # However, urllib expects strings, not bytes, so we must convert them. diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/lib/webutils.py --- a/kallithea/lib/webutils.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/lib/webutils.py Mon Dec 12 23:01:11 2022 +0100 @@ -20,6 +20,7 @@ imported anywhere - just like the global variables can be used everywhere. """ +import collections import datetime import json import logging @@ -66,6 +67,10 @@ assert wrap_paragraphs +# work around webhelpers2 being a dead project that doesn't support Python 3.10 +collections.Sequence = collections.abc.Sequence + + # # General Kallithea URL handling # diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/model/forms.py --- a/kallithea/model/forms.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/model/forms.py Mon Dec 12 23:01:11 2022 +0100 @@ -173,6 +173,7 @@ group_copy_permissions = v.StringBoolean(if_missing=False) if edit: + owner = All(v.UnicodeString(not_empty=True), v.ValidRepoUser()) # FIXME: do a special check that we cannot move a group to one of # its children pass diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/model/repo.py --- a/kallithea/model/repo.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/model/repo.py Mon Dec 12 23:01:11 2022 +0100 @@ -711,13 +711,10 @@ copy_fork_permissions = form_data.get('copy_permissions') copy_group_permissions = form_data.get('repo_copy_permissions') fork_of = form_data.get('fork_parent_id') + enable_statistics = form_data['repo_enable_statistics'] + enable_downloads = form_data['repo_enable_downloads'] state = form_data.get('repo_state', db.Repository.STATE_PENDING) - # repo creation defaults, private and repo_type are filled in form - defs = db.Setting.get_default_repo_settings(strip_prefix=True) - enable_statistics = defs.get('repo_enable_statistics') - enable_downloads = defs.get('repo_enable_downloads') - try: db_repo = RepoModel()._create_repo( repo_name=repo_name_full, diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/model/repo_group.py --- a/kallithea/model/repo_group.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/model/repo_group.py Mon Dec 12 23:01:11 2022 +0100 @@ -281,14 +281,14 @@ old_path = repo_group.full_path # change properties + if 'owner' in repo_group_args: + repo_group.owner = db.User.get_by_username(repo_group_args['owner']) if 'group_description' in repo_group_args: repo_group.group_description = repo_group_args['group_description'] if 'parent_group_id' in repo_group_args: - repo_group.parent_group_id = repo_group_args['parent_group_id'] - - if 'parent_group_id' in repo_group_args: assert repo_group_args['parent_group_id'] != '-1', repo_group_args # RepoGroupForm should have converted to None repo_group.parent_group = db.RepoGroup.get(repo_group_args['parent_group_id']) + repo_group.group_name = repo_group.get_new_name(repo_group.name) if 'group_name' in repo_group_args: group_name = repo_group_args['group_name'] if kallithea.lib.utils2.repo_name_slug(group_name) != group_name: diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/model/scm.py --- a/kallithea/model/scm.py Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/model/scm.py Mon Dec 12 23:01:11 2022 +0100 @@ -713,6 +713,7 @@ log.error('error writing hook %s: %s', hook_file, e) elif h_type == 'pre-receive': # no longer used, so just remove any existing Kallithea hook if os.path.lexists(hook_file) and not other_hook: + log.warning('removing existing unused Kallithea hook %s', hook_file) os.remove(hook_file) diff -r 59185ce619c3 -r 9ab815f67c06 kallithea/public/js/base.js --- a/kallithea/public/js/base.js Mon Dec 12 18:28:10 2022 +0100 +++ b/kallithea/public/js/base.js Mon Dec 12 23:01:11 2022 +0100 @@ -677,6 +677,7 @@ 'class': 'btn-group' }).append( $('