Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

List all Users + Gitlab 8.6 with python-gitlab #106

Closed
Asher256 opened this issue Mar 23, 2016 · 8 comments
Closed

List all Users + Gitlab 8.6 with python-gitlab #106

Asher256 opened this issue Mar 23, 2016 · 8 comments

Comments

@Asher256
Copy link
Contributor

Hi Gauvain,

Before the update from Gitlab 8.5 to 8.6, python-gitlab was working perfectly.

But after the update to Gitlab 8.6, this code raised the exception below:

result = {}
for user in git.User(all=True):
    result[user.email.lower()] = user

The exception (It says it took too much time to respond, but the exception is raised instantaneously):

 File "./buggy.py", line 424, in <module>
    main()
  File "./buggy.py", line 420, in main
    add_missing_emails_to_projects(ldap_emails, gpg_emails, acl_emails)
  File "./buggy.py", line 218, in add_missing_emails_to_projects
    gitlab_users = gitlab_get_users()
  File "./buggy.py", line 201, in gitlab_get_users
    for user in git.User(all=True):
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 717, in User
    return User._get_list_or_object(self, id, **kwargs)
  File "/var/lib/work/.bin/python/gitlab/objects.py", line 279, in _get_list_or_object
    return cls.list(gl, **kwargs)
  File "/var/lib/work/.bin/python/gitlab/objects.py", line 246, in list
    return gl.list(cls, **kwargs)
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 398, in list
    results.extend(self.list(obj_class, **args))
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 398, in list
    results.extend(self.list(obj_class, **args))
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 398, in list
    results.extend(self.list(obj_class, **args))
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 398, in list
    results.extend(self.list(obj_class, **args))
  File "/var/lib/work/.bin/python/gitlab/__init__.py", line 376, in list
    raise_error_from_response(r, GitlabListError)
  File "/var/lib/work/.bin/python/gitlab/exceptions.py", line 135, in raise_error_from_response
    response_body=response.content)
gitlab.exceptions.GitlabListError: 502: b'<!DOCTYPE html>\n<html>\n<head>\n  <title>GitLab is not responding (502)</title>\n  <style>\n    body {\n      color: #666;\n      text-align: center;\n      font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;\n      margin: 0;\n      width: 800px;\n      margin: auto;\n      font-size: 14px;\n    }\n\n    h1 {\n      font-size: 56px;\n      line-height: 100px;\n      font-weight: normal;\n      color: #456;\n    }\n\n    h2 {\n      font-size: 24px;\n      color: #666;\n      line-height: 1.5em;\n    }\n\n    h3 {\n      color: #456;\n      font-size: 20px;\n      font-weight: normal;\n      line-height: 28px;\n    }\n\n    hr {\n      margin: 18px 0;\n      border: 0;\n      border-top: 1px solid #EEE;\n      border-bottom: 1px solid white;\n    }\n  </style>\n</head>\n<body>\n  <h1>\n    <img src="" /><br />\n    502\n  </h1>\n  <h3>Whoops, GitLab is taking too much time to respond.</h3>\n  <hr/>\n  <p>Try refreshing the page, or going back and attempting the action again.</p>\n  <p>Please contact your GitLab administrator if this problem persists.</p>\n</body>\n</html>\n'

Any idea Gauvain?

Thank you in advance!

Asher256

PS: I tried the same thing with pyapi-gitlab:

result = {}
for user in old_git.getall(old_git.getusers, per_page=100):
    result[user['email']] = user

And it listed the users without any error.

@Asher256
Copy link
Contributor Author

I also have a warning:

/var/lib/work/.bin/python/gitlab/__init__.py:716: DeprecationWarning: `User` is deprecated, use `users` instead
  DeprecationWarning)

@Asher256
Copy link
Contributor Author

Another test:

In [17]: git.users.search(query='', all=True)
---------------------------------------------------------------------------
GitlabListError                           Traceback (most recent call last)
/var/lib/work/.hidden.git/scripts/gitlab_api/helper.py in <module>()
----> 1 git.users.search(query='', all=True)

/var/lib/work/.bin/python/gitlab/objects.py in search(self, query, **kwargs)
    570         """
    571         url = self.obj_cls._url + '?search=' + query
--> 572         return self.gitlab._raw_list(url, self.obj_cls, **kwargs)
    573 
    574     def get_by_username(self, username, **kwargs):

/var/lib/work/.bin/python/gitlab/__init__.py in _raw_list(self, path, cls, **kwargs)
    292             args = kwargs.copy()
    293             args['next_url'] = r.links['next']['url']
--> 294             results.extend(self.list(cls, **args))
    295         return results
    296 

/var/lib/work/.bin/python/gitlab/__init__.py in list(self, obj_class, **kwargs)
    396             args = kwargs.copy()
    397             args['next_url'] = r.links['next']['url']
--> 398             results.extend(self.list(obj_class, **args))
    399         return results
    400 

/var/lib/work/.bin/python/gitlab/__init__.py in list(self, obj_class, **kwargs)
    396             args = kwargs.copy()
    397             args['next_url'] = r.links['next']['url']
--> 398             results.extend(self.list(obj_class, **args))
    399         return results
    400 

/var/lib/work/.bin/python/gitlab/__init__.py in list(self, obj_class, **kwargs)
    396             args = kwargs.copy()
    397             args['next_url'] = r.links['next']['url']
--> 398             results.extend(self.list(obj_class, **args))
    399         return results
    400 

/var/lib/work/.bin/python/gitlab/__init__.py in list(self, obj_class, **kwargs)
    374                 "Can't connect to GitLab server (%s)" % e)
    375 
--> 376         raise_error_from_response(r, GitlabListError)
    377 
    378         cls = obj_class

/var/lib/work/.bin/python/gitlab/exceptions.py in raise_error_from_response(response, error, expected_code)
    133     raise error(error_message=message,
    134                 response_code=response.status_code,
--> 135                 response_body=response.content)

GitlabListError: 502: b'<!DOCTYPE html>\n<html>\n<head>\n  <title>GitLab is not responding (502)</title>\n  <style>\n    body {\n      color: #666;\n      text-align: center;\n      font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;\n      margin: 0;\n      width: 800px;\n      margin: auto;\n      font-size: 14px;\n    }\n\n    h1 {\n      font-size: 56px;\n      line-height: 100px;\n      font-weight: normal;\n      color: #456;\n    }\n\n    h2 {\n      font-size: 24px;\n      color: #666;\n      line-height: 1.5em;\n    }\n\n    h3 {\n      color: #456;\n      font-size: 20px;\n      font-weight: normal;\n      line-height: 28px;\n    }\n\n    hr {\n      margin: 18px 0;\n      border: 0;\n      border-top: 1px solid #EEE;\n      border-bottom: 1px solid white;\n    }\n  </style>\n</head>\n<body>\n  <h1>\n    <img src="" /><br />\n    502\n  </h1>\n  <h3>Whoops, GitLab is taking too much time to respond.</h3>\n  <hr/>\n  <p>Try refreshing the page, or going back and attempting the action again.</p>\n  <p>Please contact your GitLab administrator if this problem persists.</p>\n</body>\n</html>\n'

@gpocentek
Copy link
Contributor

I don't really understand why this suddenly fails, and I can't test right now (hotel wifi...). I'll have a closer look as soon as I can.

@Asher256
Copy link
Contributor Author

Yes, it is a strange behaviour. Let me know ;-) . Thank you Gauvain.

@FlorianKaiser
Copy link

I encountered the same problem.

next_url somehow gets passed down through kwargs and is appended recursively to the url.
After a certain number of users (recursive paging), the request size gets too big which leads to the reported Gitlab error. Maybe the request size limit is more strict in Gitlab 8.6.

2016/04/06 11:36:02 [error] 12425#0: *11 upstream sent too big header while reading response header from upstream, client: 172.17.42.1, server: xxx, request: "GET /api/v3/users?all=True&next_url=http%3A%2F%2Flocalhost%3A1234%2Fapi%2Fv3%2Fusers%3Fall%3DTrue%26next_url%3Dhttp%253A%252F%252Flocalhost%253A1234%252Fapi%252Fv3%252Fusers%253Fall%253DTrue%2526 (...)

As a workaround, add the following in __init__.py:369 (in the list() function before the request ist sent):

if params.has_key('next_url'): del params['next_url']

@Asher256
Copy link
Contributor Author

Asher256 commented Apr 6, 2016

+1

@gdubicki
Copy link

+1

I used code similar to this #93 (comment) as a workaround.

@gpocentek
Copy link
Contributor

Thanks for the investigation. This seems to be fixed now.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Nov 29, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants