Python-gitlab

Latest version: v5.6.0

Safety actively analyzes 723576 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 9 of 13

2.10.1

Not secure
Bug Fixes

- **deps**: Upgrade requests to 2.25.0 (see CVE-2021-33503)
([`ce995b2`](https://github.com/python-gitlab/python-gitlab/commit/ce995b256423a0c5619e2a6c0d88e917aad315ba))

- **mixins**: Improve deprecation warning
([`57e0187`](https://github.com/python-gitlab/python-gitlab/commit/57e018772492a8522b37d438d722c643594cf580))

Also note what should be changed

Chores

- Define root dir in mypy, not tox
([`7a64e67`](https://github.com/python-gitlab/python-gitlab/commit/7a64e67c8ea09c5e4e041cc9d0807f340d0e1310))

- Fix mypy pre-commit hook
([`bd50df6`](https://github.com/python-gitlab/python-gitlab/commit/bd50df6b963af39b70ea2db50fb2f30b55ddc196))

- **deps**: Group typing requirements with mypy additional_dependencies
([`38597e7`](https://github.com/python-gitlab/python-gitlab/commit/38597e71a7dd12751b028f9451587f781f95c18f))

- **deps**: Update codecov/codecov-action action to v2
([`44f4fb7`](https://github.com/python-gitlab/python-gitlab/commit/44f4fb78bb0b5a18a4703b68a9657796bf852711))

- **deps**: Update dependency isort to v5.9.3
([`ab46e31`](https://github.com/python-gitlab/python-gitlab/commit/ab46e31f66c36d882cdae0b02e702b37e5a6ff4e))

- **deps**: Update dependency types-pyyaml to v5.4.7
([`ec8be67`](https://github.com/python-gitlab/python-gitlab/commit/ec8be67ddd37302f31b07185cb4778093e549588))

- **deps**: Update dependency types-pyyaml to v5.4.8
([`2ae1dd7`](https://github.com/python-gitlab/python-gitlab/commit/2ae1dd7d91f4f90123d9dd8ea92c61b38383e31c))

- **deps**: Update dependency types-requests to v2.25.1
([`a2d133a`](https://github.com/python-gitlab/python-gitlab/commit/a2d133a995d3349c9b0919dd03abaf08b025289e))

- **deps**: Update dependency types-requests to v2.25.2
([`4782678`](https://github.com/python-gitlab/python-gitlab/commit/47826789a5f885a87ae139b8c4d8da9d2dacf713))

- **deps**: Update precommit hook pycqa/isort to v5.9.3
([`e1954f3`](https://github.com/python-gitlab/python-gitlab/commit/e1954f355b989007d13a528f1e49e9410256b5ce))

- **deps**: Update typing dependencies
([`34fc210`](https://github.com/python-gitlab/python-gitlab/commit/34fc21058240da564875f746692b3fb4c3f7c4c8))

- **deps**: Update wagoid/commitlint-github-action action to v4
([`ae97196`](https://github.com/python-gitlab/python-gitlab/commit/ae97196ce8f277082ac28fcd39a9d11e464e6da9))

Documentation

- **mergequests**: Gl.mergequests.list documentation was missleading
([`5b5a7bc`](https://github.com/python-gitlab/python-gitlab/commit/5b5a7bcc70a4ddd621cbd59e134e7004ad2d9ab9))

2.10.0

Not secure
Bug Fixes

- **api**: Do not require Release name for creation
([`98cd03b`](https://github.com/python-gitlab/python-gitlab/commit/98cd03b7a3085356b5f0f4fcdb7dc729b682f481))

Stop requiring a `name` attribute for creating a Release, since a release name has not been required
since GitLab 12.5.

Chores

- **deps**: Update dependency isort to v5.9.2
([`d5dcf1c`](https://github.com/python-gitlab/python-gitlab/commit/d5dcf1cb7e703ec732e12e41d2971726f27a4bdc))

- **deps**: Update dependency requests to v2.26.0
([`d3ea203`](https://github.com/python-gitlab/python-gitlab/commit/d3ea203dc0e4677b7f36c0f80e6a7a0438ea6385))

- **deps**: Update precommit hook pycqa/isort to v5.9.2
([`521cddd`](https://github.com/python-gitlab/python-gitlab/commit/521cdddc5260ef2ba6330822ec96efc90e1c03e3))

Documentation

- Add example for mr.merge_ref
([`b30b8ac`](https://github.com/python-gitlab/python-gitlab/commit/b30b8ac27d98ed0a45a13775645d77b76e828f95))

Signed-off-by: Matej Focko <mfockoredhat.com>

- **project**: Add example on getting a single project using name with namespace
([`ef16a97`](https://github.com/python-gitlab/python-gitlab/commit/ef16a979031a77155907f4160e4f5e159d839737))

- **readme**: Move contributing docs to CONTRIBUTING.rst
([`edf49a3`](https://github.com/python-gitlab/python-gitlab/commit/edf49a3d855b1ce4e2bd8a7038b7444ff0ab5fdc))

Move the Contributing section of README.rst to CONTRIBUTING.rst, so it is recognized by GitHub and
shown when new contributors make pull requests.

Features

- **api**: Add `name_regex_keep` attribute in `delete_in_bulk()`
([`e49ff3f`](https://github.com/python-gitlab/python-gitlab/commit/e49ff3f868cbab7ff81115f458840b5f6d27d96c))

- **api**: Add merge_ref for merge requests
([`1e24ab2`](https://github.com/python-gitlab/python-gitlab/commit/1e24ab247cc783ae240e94f6cb379fef1e743a52))

Support merge_ref on merge requests that returns commit of attempted merge of the MR.

Signed-off-by: Matej Focko <mfockoredhat.com>

Testing

- **functional**: Add mr.merge_ref tests
([`a9924f4`](https://github.com/python-gitlab/python-gitlab/commit/a9924f48800f57fa8036e3ebdf89d1e04b9bf1a1))

- Add test for using merge_ref on non-merged MR - Add test for using merge_ref on MR with conflicts

Signed-off-by: Matej Focko <mfockoredhat.com>

2.9.0

Not secure
Chores

- Add new required type packages for mypy
([`a7371e1`](https://github.com/python-gitlab/python-gitlab/commit/a7371e19520325a725813e328004daecf9259dd2))

New version of mypy flagged errors for missing types. Install the recommended type-* packages that
resolve the issues.

- Add type-hints to gitlab/v4/objects/projects.py
([`872dd6d`](https://github.com/python-gitlab/python-gitlab/commit/872dd6defd8c299e997f0f269f55926ce51bd13e))

Adding type-hints to gitlab/v4/objects/projects.py

- Skip EE test case in functional tests
([`953f207`](https://github.com/python-gitlab/python-gitlab/commit/953f207466c53c28a877f2a88da9160acef40643))

- **deps**: Update dependency isort to v5.9.1
([`0479dba`](https://github.com/python-gitlab/python-gitlab/commit/0479dba8a26d2588d9616dbeed351b0256f4bf87))

- **deps**: Update dependency mypy to v0.902
([`19c9736`](https://github.com/python-gitlab/python-gitlab/commit/19c9736de06d032569020697f15ea9d3e2b66120))

- **deps**: Update dependency mypy to v0.910
([`02a56f3`](https://github.com/python-gitlab/python-gitlab/commit/02a56f397880b3939b8e737483ac6f95f809ac9c))

- **deps**: Update dependency types-pyyaml to v0.1.8
([`e566767`](https://github.com/python-gitlab/python-gitlab/commit/e56676730d3407efdf4255b3ca7ee13b7c36eb53))

- **deps**: Update dependency types-pyyaml to v0.1.9
([`1f5b3c0`](https://github.com/python-gitlab/python-gitlab/commit/1f5b3c03b2ae451dfe518ed65ec2bec4e80c09d1))

- **deps**: Update dependency types-pyyaml to v5
([`5c22634`](https://github.com/python-gitlab/python-gitlab/commit/5c226343097427b3f45a404db5b78d61143074fb))

- **deps**: Update dependency types-requests to v0.1.11
([`6ba629c`](https://github.com/python-gitlab/python-gitlab/commit/6ba629c71a4cf8ced7060580a6e6643738bc4186))

- **deps**: Update dependency types-requests to v0.1.12
([`f84c2a8`](https://github.com/python-gitlab/python-gitlab/commit/f84c2a885069813ce80c18542fcfa30cc0d9b644))

- **deps**: Update dependency types-requests to v0.1.13
([`c3ddae2`](https://github.com/python-gitlab/python-gitlab/commit/c3ddae239aee6694a09c864158e355675567f3d2))

- **deps**: Update dependency types-requests to v2
([`a81a926`](https://github.com/python-gitlab/python-gitlab/commit/a81a926a0979e3272abfb2dc40d2f130d3a0ba5a))

- **deps**: Update precommit hook pycqa/isort to v5.9.1
([`c57ffe3`](https://github.com/python-gitlab/python-gitlab/commit/c57ffe3958c1475c8c79bb86fc4b101d82350d75))

Documentation

- Make Gitlab class usable for intersphinx
([`8753add`](https://github.com/python-gitlab/python-gitlab/commit/8753add72061ea01c508a42d16a27388b1d92677))

- **release**: Add update example
([`6254a5f`](https://github.com/python-gitlab/python-gitlab/commit/6254a5ff6f43bd7d0a26dead304465adf1bd0886))

- **tags**: Remove deprecated functions
([`1b1a827`](https://github.com/python-gitlab/python-gitlab/commit/1b1a827dd40b489fdacdf0a15b0e17a1a117df40))

Features

- **api**: Add group hooks
([`4a7e9b8`](https://github.com/python-gitlab/python-gitlab/commit/4a7e9b86aa348b72925bce3af1e5d988b8ce3439))

- **api**: Add MR pipeline manager in favor of pipelines() method
([`954357c`](https://github.com/python-gitlab/python-gitlab/commit/954357c49963ef51945c81c41fd4345002f9fb98))

- **api**: Add support for creating/editing reviewers in project merge requests
([`676d1f6`](https://github.com/python-gitlab/python-gitlab/commit/676d1f6565617a28ee84eae20e945f23aaf3d86f))

- **api**: Remove responsibility for API inconsistencies for MR reviewers
([`3d985ee`](https://github.com/python-gitlab/python-gitlab/commit/3d985ee8cdd5d27585678f8fbb3eb549818a78eb))

- **release**: Allow to update release
([`b4c4787`](https://github.com/python-gitlab/python-gitlab/commit/b4c4787af54d9db6c1f9e61154be5db9d46de3dd))

Release API now supports PUT.

Testing

- **releases**: Add unit-tests for release update
([`5b68a5a`](https://github.com/python-gitlab/python-gitlab/commit/5b68a5a73eb90316504d74d7e8065816f6510996))

- **releases**: Integration for release PUT
([`13bf61d`](https://github.com/python-gitlab/python-gitlab/commit/13bf61d07e84cd719931234c3ccbb9977c8f6416))

2.8.0

Not secure
Bug Fixes

- Add a check to ensure the MRO is correct
([`565d548`](https://github.com/python-gitlab/python-gitlab/commit/565d5488b779de19a720d7a904c6fc14c394a4b9))

Add a check to ensure the MRO (Method Resolution Order) is correct for classes in gitlab.v4.objects
when doing type-checking.

An example of an incorrect definition: class ProjectPipeline(RESTObject, RefreshMixin,
ObjectDeleteMixin): ^^^^^^^^^^ This should be at the end.

Correct way would be: class ProjectPipeline(RefreshMixin, ObjectDeleteMixin, RESTObject): Correctly
at the end ^^^^^^^^^^

Also fix classes which have the issue.

- Catch invalid type used to initialize RESTObject
([`c7bcc25`](https://github.com/python-gitlab/python-gitlab/commit/c7bcc25a361f9df440f9c972672e5eec3b057625))

Sometimes we have errors where we don't get a dictionary passed to RESTObject.__init__() method.
This breaks things but in confusing ways.

Check in the __init__() method and raise an exception if it occurs.

- Change mr.merge() to use 'post_data'
([`cb6a3c6`](https://github.com/python-gitlab/python-gitlab/commit/cb6a3c672b9b162f7320c532410713576fbd1cdc))

MR https://github.com/python-gitlab/python-gitlab/pull/1121 changed mr.merge() to use 'query_data'.
This appears to have been wrong.

From the Gitlab docs they state it should be sent in a payload body
https://docs.gitlab.com/ee/api/README.html#request-payload since mr.merge() is a PUT request.

> Request Payload

> API Requests can use parameters sent as query strings or as a > payload body. GET requests usually
send a query string, while PUT > or POST requests usually send the payload body

Fixes: 1452

Related to: 1120

- Ensure kwargs are passed appropriately for ObjectDeleteMixin
([`4e690c2`](https://github.com/python-gitlab/python-gitlab/commit/4e690c256fc091ddf1649e48dbbf0b40cc5e6b95))

- Functional project service test
([1500](https://github.com/python-gitlab/python-gitlab/pull/1500),
[`093db9d`](https://github.com/python-gitlab/python-gitlab/commit/093db9d129e0a113995501755ab57a04e461c745))

chore: fix functional project service test

- Iids not working as a list in projects.issues.list()
([`45f806c`](https://github.com/python-gitlab/python-gitlab/commit/45f806c7a7354592befe58a76b7e33a6d5d0fe6e))

Set the 'iids' values as type ListAttribute so it will pass the list as a comma-separated string,
instead of a list.

Add a functional test.

Closes: 1407

- **cli**: Add missing list filter for jobs
([`b3d1c26`](https://github.com/python-gitlab/python-gitlab/commit/b3d1c267cbe6885ee41b3c688d82890bb2e27316))

- **cli**: Fix parsing CLI objects to classnames
([`4252070`](https://github.com/python-gitlab/python-gitlab/commit/42520705a97289ac895a6b110d34d6c115e45500))

- **objects**: Add missing group attributes
([`d20ff4f`](https://github.com/python-gitlab/python-gitlab/commit/d20ff4ff7427519c8abccf53e3213e8929905441))

- **objects**: Allow lists for filters for in all objects
([`603a351`](https://github.com/python-gitlab/python-gitlab/commit/603a351c71196a7f516367fbf90519f9452f3c55))

- **objects**: Return server data in cancel/retry methods
([`9fed061`](https://github.com/python-gitlab/python-gitlab/commit/9fed06116bfe5df79e6ac5be86ae61017f9a2f57))

Chores

- Add a functional test for issue 1120
([`7d66115`](https://github.com/python-gitlab/python-gitlab/commit/7d66115573c6c029ce6aa00e244f8bdfbb907e33))

Going to switch to putting parameters from in the query string to having them in the 'data' body
section. Add a functional test to make sure that we don't break anything.

https://github.com/python-gitlab/python-gitlab/issues/1120

- Add a merge_request() pytest fixture and use it
([`8be2838`](https://github.com/python-gitlab/python-gitlab/commit/8be2838a9ee3e2440d066e2c4b77cb9b55fc3da2))

Added a pytest.fixture for merge_request(). Use this fixture in
tools/functional/api/test_merge_requests.py

- Add an isort tox environment and run isort in CI
([`dda646e`](https://github.com/python-gitlab/python-gitlab/commit/dda646e8f2ecb733e37e6cffec331b783b64714e))

* Add an isort tox environment * Run the isort tox environment using --check in the Github CI

https://pycqa.github.io/isort/

- Add functional test mr.merge() with long commit message
([`cd5993c`](https://github.com/python-gitlab/python-gitlab/commit/cd5993c9d638c2a10879d7e3ac36db06df867e54))

Functional test to show that https://github.com/python-gitlab/python-gitlab/issues/1452 is fixed.

Added a functional test to ensure that we can use large commit message (10_000+ bytes) in mr.merge()

Related to: 1452

- Add missing linters to pre-commit and pin versions
([`85bbd1a`](https://github.com/python-gitlab/python-gitlab/commit/85bbd1a5db5eff8a8cea63b2b192aae66030423d))

- Add missing optional create parameter for approval_rules
([`06a6001`](https://github.com/python-gitlab/python-gitlab/commit/06a600136bdb33bdbd84233303652afb36fb8a1b))

Add missing optional create parameter ('protected_branch_ids') to the project approvalrules.

https://docs.gitlab.com/ee/api/merge_request_approvals.html#create-project-level-rule

- Add type-hints to gitlab/v4/cli.py
([`2673af0`](https://github.com/python-gitlab/python-gitlab/commit/2673af0c09a7c5669d8f62c3cc42f684a9693a0f))

* Add type-hints to gitlab/v4/cli.py * Add required type-hints to other files based on adding
type-hints to gitlab/v4/cli.py

- Apply suggestions
([`fe7d19d`](https://github.com/python-gitlab/python-gitlab/commit/fe7d19de5aeba675dcb06621cf36ab4169391158))

- Apply typing suggestions
([`a11623b`](https://github.com/python-gitlab/python-gitlab/commit/a11623b1aa6998e6520f3975f0f3f2613ceee5fb))

Co-authored-by: John Villalovos <johnsodarock.com>

- Clean up tox, pre-commit and requirements
([`237b97c`](https://github.com/python-gitlab/python-gitlab/commit/237b97ceb0614821e59ea041f43a9806b65cdf8c))

- Correct a type-hint
([`046607c`](https://github.com/python-gitlab/python-gitlab/commit/046607cf7fd95c3d25f5af9383fdf10a5bba42c1))

- Fix import ordering using isort
([`f3afd34`](https://github.com/python-gitlab/python-gitlab/commit/f3afd34260d681bbeec974b67012b90d407b7014))

Fix the import ordering using isort.

https://pycqa.github.io/isort/

- Have black run at the top-level
([`429d6c5`](https://github.com/python-gitlab/python-gitlab/commit/429d6c55602f17431201de17e63cdb2c68ac5d73))

This will ensure everything is formatted with black, including setup.py.

- Have flake8 check the entire project
([`ab343ef`](https://github.com/python-gitlab/python-gitlab/commit/ab343ef6da708746aa08a972b461a5e51d898f8b))

Have flake8 run at the top-level of the projects instead of just the gitlab directory.

- Make certain dotfiles searchable by ripgrep
([`e4ce078`](https://github.com/python-gitlab/python-gitlab/commit/e4ce078580f7eac8cf1c56122e99be28e3830247))

By explicitly NOT excluding the dotfiles we care about to the .gitignore file we make those files
searchable by tools like ripgrep.

By default dotfiles are ignored by ripgrep and other search tools (not grep)

- Make Get.*Mixin._optional_get_attrs always present
([`3c1a0b3`](https://github.com/python-gitlab/python-gitlab/commit/3c1a0b3ba1f529fab38829c9d355561fd36f4f5d))

Always create GetMixin/GetWithoutIdMixin._optional_get_attrs attribute with a default value of
tuple()

This way we don't need to use hasattr() and we will know the type of the attribute.

- Move 'gitlab/tests/' dir to 'tests/unit/'
([`1ac0722`](https://github.com/python-gitlab/python-gitlab/commit/1ac0722bc086b18c070132a0eb53747bbdf2ce0a))

Move the 'gitlab/tests/' directory to 'tests/unit/' so we have all the tests located under the
'tests/' directory.

- Mypy: Disallow untyped definitions
([`6aef2da`](https://github.com/python-gitlab/python-gitlab/commit/6aef2dadf715e601ae9c302be0ad9958345a97f2))

Be more strict and don't allow untyped definitions on the files we check.

Also this adds type-hints for two of the decorators so that now functions/methods decorated by them
will have their types be revealed correctly.

- Remove commented-out print
([`0357c37`](https://github.com/python-gitlab/python-gitlab/commit/0357c37fb40fb6aef175177fab98d0eadc26b667))

- Rename 'tools/functional/' to 'tests/functional/'
([`502715d`](https://github.com/python-gitlab/python-gitlab/commit/502715d99e02105c39b2c5cf0e7457b3256eba0d))

Rename the 'tools/functional/' directory to 'tests/functional/'

This makes more sense as these are functional tests and not tools.

This was dicussed in: https://github.com/python-gitlab/python-gitlab/discussions/1468

- Simplify functional tests
([`df9b5f9`](https://github.com/python-gitlab/python-gitlab/commit/df9b5f9226f704a603a7e49c78bc4543b412f898))

Add a helper function to have less code duplication in the functional testing.

- Sync create and update attributes for Projects
([`0044bd2`](https://github.com/python-gitlab/python-gitlab/commit/0044bd253d86800a7ea8ef0a9a07e965a65cc6a5))

Sync the create attributes with: https://docs.gitlab.com/ee/api/projects.html#create-project

Sync the update attributes with documentation at:
https://docs.gitlab.com/ee/api/projects.html#edit-project

As a note the ordering of the attributes was done to match the ordering of the attributes in the
documentation.

Closes: 1497

- Use built-in function issubclass() instead of getmro()
([`81f6386`](https://github.com/python-gitlab/python-gitlab/commit/81f63866593a0486b03a4383d87ef7bc01f4e45f))

Code was using inspect.getmro() to replicate the functionality of the built-in function issubclass()

Switch to using issubclass()

- **ci**: Automate releases
([`0ef497e`](https://github.com/python-gitlab/python-gitlab/commit/0ef497e458f98acee36529e8bda2b28b3310de69))

- **ci**: Ignore .python-version from pyenv
([`149953d`](https://github.com/python-gitlab/python-gitlab/commit/149953dc32c28fe413c9f3a0066575caeab12bc8))

- **ci**: Ignore debug and type_checking in coverage
([`885b608`](https://github.com/python-gitlab/python-gitlab/commit/885b608194a55bd60ef2a2ad180c5caa8f15f8d2))

- **ci**: Use admin PAT for release workflow
([`d175d41`](https://github.com/python-gitlab/python-gitlab/commit/d175d416d5d94f4806f4262e1f11cfee99fb0135))

- **deps**: Update dependency docker-compose to v1.29.2
([`fc241e1`](https://github.com/python-gitlab/python-gitlab/commit/fc241e1ffa995417a969354e37d8fefc21bb4621))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.11.2-ce.0
([`434d15d`](https://github.com/python-gitlab/python-gitlab/commit/434d15d1295187d1970ebef01f4c8a44a33afa31))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.11.3-ce.0
([`f0b52d8`](https://github.com/python-gitlab/python-gitlab/commit/f0b52d829db900e98ab93883b20e6bd8062089c6))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.11.4-ce.0
([`4223269`](https://github.com/python-gitlab/python-gitlab/commit/4223269608c2e58b837684d20973e02eb70e04c9))

- **deps**: Update precommit hook alessandrojcm/commitlint-pre-commit-hook to v5
([`9ff349d`](https://github.com/python-gitlab/python-gitlab/commit/9ff349d21ed40283d60692af5d19d86ed7e72958))

- **docs**: Fix import order for readthedocs build
([`c3de1fb`](https://github.com/python-gitlab/python-gitlab/commit/c3de1fb8ec17f5f704a19df4a56a668570e6fe0a))

Code Style

- Clean up test run config
([`dfa40c1`](https://github.com/python-gitlab/python-gitlab/commit/dfa40c1ef85992e85c1160587037e56778ab49c0))

Documentation

- Fail on warnings during sphinx build
([`cbd4d52`](https://github.com/python-gitlab/python-gitlab/commit/cbd4d52b11150594ec29b1ce52348c1086a778c8))

This is useful when docs aren't included in the toctree and don't show up on RTD.

- Fix typo in http_delete docstring
([`5226f09`](https://github.com/python-gitlab/python-gitlab/commit/5226f095c39985d04c34e7703d60814e74be96f8))

- **api**: Add behavior in local attributes when updating objects
([`38f65e8`](https://github.com/python-gitlab/python-gitlab/commit/38f65e8e9994f58bdc74fe2e0e9b971fc3edf723))

Features

- Add code owner approval as attribute
([`fdc46ba`](https://github.com/python-gitlab/python-gitlab/commit/fdc46baca447e042d3b0a4542970f9758c62e7b7))

The python API was missing the field code_owner_approval_required as implemented in the GitLab REST
API.

- Add feature to get inherited member for project/group
([`e444b39`](https://github.com/python-gitlab/python-gitlab/commit/e444b39f9423b4a4c85cdb199afbad987df026f1))

- Add keys endpoint
([`a81525a`](https://github.com/python-gitlab/python-gitlab/commit/a81525a2377aaed797af0706b00be7f5d8616d22))

- Add support for lists of integers to ListAttribute
([`115938b`](https://github.com/python-gitlab/python-gitlab/commit/115938b3e5adf9a2fb5ecbfb34d9c92bf788035e))

Previously ListAttribute only support lists of integers. Now be more flexible and support lists of
items which can be coerced into strings, for example integers.

This will help us fix issue 1407 by using ListAttribute for the 'iids' field.

- Indicate that we are a typed package
([`e4421ca`](https://github.com/python-gitlab/python-gitlab/commit/e4421caafeeb0236df19fe7b9233300727e1933b))

By adding the file: py.typed it indicates that python-gitlab is a typed package and contains
type-hints.

https://www.python.org/dev/peps/pep-0561/

- **api**: Add deployment mergerequests interface
([`fbbc0d4`](https://github.com/python-gitlab/python-gitlab/commit/fbbc0d400015d7366952a66e4401215adff709f0))

- **objects**: Add pipeline test report support
([`ee9f96e`](https://github.com/python-gitlab/python-gitlab/commit/ee9f96e61ab5da0ecf469c21cccaafc89130a896))

- **objects**: Add support for billable members
([`fb0b083`](https://github.com/python-gitlab/python-gitlab/commit/fb0b083a0e536a6abab25c9ad377770cc4290fe9))

- **objects**: Add support for descendant groups API
([`1b70580`](https://github.com/python-gitlab/python-gitlab/commit/1b70580020825adf2d1f8c37803bc4655a97be41))

- **objects**: Add support for generic packages API
([`79d88bd`](https://github.com/python-gitlab/python-gitlab/commit/79d88bde9e5e6c33029e4a9f26c97404e6a7a874))

- **objects**: Add support for Group wikis
([1484](https://github.com/python-gitlab/python-gitlab/pull/1484),
[`74f5e62`](https://github.com/python-gitlab/python-gitlab/commit/74f5e62ef5bfffc7ba21494d05dbead60b59ecf0))

feat(objects): add support for Group wikis

- **objects**: Support all issues statistics endpoints
([`f731707`](https://github.com/python-gitlab/python-gitlab/commit/f731707f076264ebea65afc814e4aca798970953))

Testing

- **api**: Fix issues test
([`8e5b0de`](https://github.com/python-gitlab/python-gitlab/commit/8e5b0de7d9b1631aac4e9ac03a286dfe80675040))

Was incorrectly using the issue 'id' vs 'iid'.

- **cli**: Add more real class scenarios
([`8cf5031`](https://github.com/python-gitlab/python-gitlab/commit/8cf5031a2caf2f39ce920c5f80316cc774ba7a36))

- **cli**: Replace assignment expression
([`11ae11b`](https://github.com/python-gitlab/python-gitlab/commit/11ae11bfa5f9fcb903689805f8d35b4d62ab0c90))

This is a feature added in 3.8, removing it allows for the test to run with lower python versions.

- **functional**: Add test for skip_groups list filter
([`a014774`](https://github.com/python-gitlab/python-gitlab/commit/a014774a6a2523b73601a1930c44ac259d03a50e))

- **functional**: Explicitly remove deploy tokens on reset
([`19a55d8`](https://github.com/python-gitlab/python-gitlab/commit/19a55d80762417311dcebde3f998f5ebc7e78264))

Deploy tokens would remain in the instance if the respective project or group was deleted without
explicitly revoking the deploy tokens first.

- **functional**: Force delete users on reset
([`8f81456`](https://github.com/python-gitlab/python-gitlab/commit/8f814563beb601715930ed3b0f89c3871e6e2f33))

Timing issues between requesting group deletion and GitLab enacting that deletion resulted in errors
while attempting to delete a user which was the sole owner of said group (see: test_groups). Pass
the 'hard_delete' parameter to ensure user deletion.

- **functional**: Optionally keep containers running post-tests
([`4c475ab`](https://github.com/python-gitlab/python-gitlab/commit/4c475abe30c36217da920477f3748e26f3395365))

Additionally updates token creation to make use of `first_or_create()`, to avoid errors from the
script caused by GitLab constraints preventing duplicate tokens with the same value.

- **functional**: Start tracking functional test coverage
([`f875786`](https://github.com/python-gitlab/python-gitlab/commit/f875786ce338b329421f772b181e7183f0fcb333))

2.7.1

Not secure
Bug Fixes

- **files**: Do not url-encode file paths twice
([`8e25cec`](https://github.com/python-gitlab/python-gitlab/commit/8e25cecce3c0a19884a8d231ee1a672b80e94398))

2.7.0

Not secure
Bug Fixes

- Argument type was not a tuple as expected
([`062f8f6`](https://github.com/python-gitlab/python-gitlab/commit/062f8f6a917abc037714129691a845c16b070ff6))

While adding type-hints mypy flagged this as an issue. The third argument to register_custom_action
is supposed to be a tuple. It was being passed as a string rather than a tuple of strings.

- Better real life token lookup example
([`9ef8311`](https://github.com/python-gitlab/python-gitlab/commit/9ef83118efde3d0f35d73812ce8398be2c18ebff))

- Checking if RESTManager._from_parent_attrs is set
([`8224b40`](https://github.com/python-gitlab/python-gitlab/commit/8224b4066e84720d7efed3b7891c47af73cc57ca))

Prior to commit 3727cbd21fc40b312573ca8da56e0f6cf9577d08 RESTManager._from_parent_attrs did not
exist unless it was explicitly set. But commit 3727cbd21fc40b312573ca8da56e0f6cf9577d08 set it to
a default value of {}.

So the checks using hasattr() were no longer valid.

Update the checks to check if RESTManager._from_parent_attrs has a value.

- Correct ProjectFile.decode() documentation
([`b180baf`](https://github.com/python-gitlab/python-gitlab/commit/b180bafdf282cd97e8f7b6767599bc42d5470bfa))

ProjectFile.decode() returns 'bytes' and not 'str'.

Update the method's doc-string and add a type-hint.

ProjectFile.decode() returns the result of a call to base64.b64decode()

The docs for that function state it returns 'bytes':
https://docs.python.org/3/library/base64.html#base64.b64decode

Fixes: 1403

- Correct some type-hints in gitlab/mixins.py
([`8bd3124`](https://github.com/python-gitlab/python-gitlab/commit/8bd312404cf647674baea792547705ef1948043d))

Commit baea7215bbbe07c06b2ca0f97a1d3d482668d887 introduced type-hints for gitlab/mixins.py.

After starting to add type-hints to gitlab/v4/objects/users.py discovered a few errors.

Main error was using '=' instead of ':'. For example: _parent = Optional[...] should be _parent:
Optional[...]

Resolved those issues.

- Extend wait timeout for test_delete_user()
([`19fde8e`](https://github.com/python-gitlab/python-gitlab/commit/19fde8ed0e794d33471056e2c07539cde70a8699))

Have been seeing intermittent failures of the test_delete_user() functional test. Have made the
following changes to hopefully resolve the issue and if it still fails to know better why the
failure occurred.

* Extend the wait timeout for test_delete_user() from 30 to 60 tries of 0.5 seconds each.

* Modify wait_for_sidekiq() to return True if sidekiq process terminated. Return False if the
timeout expired.

* Modify wait_for_sidekiq() to loop through all processes instead of assuming there is only one
process. If all processes are not busy then return.

* Modify wait_for_sidekiq() to sleep at least once before checking for processes being busy.

* Check for True being returned in test_delete_user() call to wait_for_sidekiq()

- Handle tags like debian/2%2.6-21 as identifiers
([`b4dac5c`](https://github.com/python-gitlab/python-gitlab/commit/b4dac5ce33843cf52badeb9faf0f7f52f20a9a6a))

Git refnames are relatively free-form and can contain all sort for special characters, not just `/`
and ``, see http://git-scm.com/docs/git-check-ref-format

In particular, Debian's DEP-14 standard for storing packaging in git repositories mandates the use
of the `%` character in tags in some cases like `debian/2%2.6-21`.

Unfortunately python-gitlab currently only escapes `/` to `%2F` and in some cases `` to `%23`. This
means that when using the commit API to retrieve information about the `debian/2%2.6-21` tag only
the slash is escaped before being inserted in the URL path and the `%` is left untouched,
resulting in something like `/api/v4/projects/123/repository/commits/debian%2F2%2.6-21`. When
urllib3 seees that it detects the invalid `%` escape and then urlencodes the whole string,
resulting in `/api/v4/projects/123/repository/commits/debian%252F2%252.6-21`, where the original
`/` got escaped twice and produced `%252F`.

To avoid the issue, fully urlencode identifiers and parameters to avoid the urllib3 auto-escaping in
all cases.

Signed-off-by: Emanuele Aina <emanuele.ainacollabora.com>

- Handling config value in _get_values_from_helper
([`9dfb4cd`](https://github.com/python-gitlab/python-gitlab/commit/9dfb4cd97e6eb5bbfc29935cbb190b70b739cf9f))

- Honor parameter value passed
([`c2f8f0e`](https://github.com/python-gitlab/python-gitlab/commit/c2f8f0e7db9529e1f1f32d790a67d1e20d2fe052))

Gitlab allows setting the defaults for MR to delete the source. Also the inline help of the CLI
suggest that a boolean is expected, but no matter what value you set, it will always delete.

- Let the homedir be expanded in path of helper
([`fc7387a`](https://github.com/python-gitlab/python-gitlab/commit/fc7387a0a6039bc58b2a741ac9b73d7068375be7))

- Linting issues and test
([`b04dd2c`](https://github.com/python-gitlab/python-gitlab/commit/b04dd2c08b69619bb58832f40a4c4391e350a735))

- Make secret helper more user friendly
([`fc2798f`](https://github.com/python-gitlab/python-gitlab/commit/fc2798fc31a08997c049f609c19dd4ab8d75964e))

- Only add query_parameters to GitlabList once
([`ca2c3c9`](https://github.com/python-gitlab/python-gitlab/commit/ca2c3c9dee5dc61ea12af5b39d51b1606da32f9c))

Fixes 1386

- Only append kwargs as query parameters
([`b9ecc9a`](https://github.com/python-gitlab/python-gitlab/commit/b9ecc9a8c5d958bd7247946c4e8d29c18163c578))

Some arguments to `http_request` were being read from kwargs, but kwargs is where this function
creates query parameters from, by default. In the absence of a `query_parameters` param, the
function would construct URLs with query parameters such as `retry_transient_errors=True` despite
those parameters having no meaning to the API to which the request was sent.

This change names those arguments that are specific to `http_request` so that they do not end up as
query parameters read from kwargs.

- Remove duplicate class definitions in v4/objects/users.py
([`7c4e625`](https://github.com/python-gitlab/python-gitlab/commit/7c4e62597365e8227b8b63ab8ba0c94cafc7abc8))

The classes UserStatus and UserStatusManager were each declared twice. Remove the duplicate
declarations.

- Test_update_group() dependency on ordering
([`e78a8d6`](https://github.com/python-gitlab/python-gitlab/commit/e78a8d6353427bad0055f116e94f471997ee4979))

Since there are two groups we can't depend on the one we changed to always be the first one
returned.

Instead fetch the group we want and then test our assertion against that group.

- Tox pep8 target, so that it can run
([`f518e87`](https://github.com/python-gitlab/python-gitlab/commit/f518e87b5492f2f3c201d4d723c07c746a385b6e))

Previously running the pep8 target would fail as flake8 was not installed.

Now install flake8 for the pep8 target.

NOTE: Running the pep8 target fails as there are many warnings/errors.

But it does allow us to run it and possibly work on reducing these warnings/errors in the future.

In addition, add two checks to the ignore list as black takes care of formatting. The two checks
added to the ignore list are: * E501: line too long * W503: line break before binary operator

- Undefined name errors
([`48ec9e0`](https://github.com/python-gitlab/python-gitlab/commit/48ec9e0f6a2d2da0a24ef8292c70dc441836a913))

Discovered that there were some undefined names.

- Update doc for token helper
([`3ac6fa1`](https://github.com/python-gitlab/python-gitlab/commit/3ac6fa12b37dd33610ef2206ef4ddc3b20d9fd3f))

- Update user's bool data and avatar
([`3ba27ff`](https://github.com/python-gitlab/python-gitlab/commit/3ba27ffb6ae995c27608f84eef0abe636e2e63da))

If we want to update email, avatar and do not send email confirmation change (`skip_reconfirmation`
= True), `MultipartEncoder` will try to encode everything except None and bytes. So it tries to
encode bools. Casting bool's values to their stringified int representation fix it.

- Wrong variable name
([`15ec41c`](https://github.com/python-gitlab/python-gitlab/commit/15ec41caf74e264d757d2c64b92427f027194b82))

Discovered this when I ran flake8 on the file. Unfortunately I was the one who introduced this wrong
variable name :(

- **objects**: Add single get endpoint for instance audit events
([`c3f0a6f`](https://github.com/python-gitlab/python-gitlab/commit/c3f0a6f158fbc7d90544274b9bf09d5ac9ac0060))

- **types**: Prevent __dir__ from producing duplicates
([`5bf7525`](https://github.com/python-gitlab/python-gitlab/commit/5bf7525d2d37968235514d1b93a403d037800652))

Chores

- Add _create_attrs & _update_attrs to RESTManager
([`147f05d`](https://github.com/python-gitlab/python-gitlab/commit/147f05d43d302d9a04bc87d957c79ce9e54cdaed))

Add the attributes: _create_attrs and _update_attrs to the RESTManager class. This is so that we
stop using getattr() if we don't need to.

This also helps with type-hints being available for these attributes.

- Add additional type-hints for gitlab/base.py
([`ad72ef3`](https://github.com/python-gitlab/python-gitlab/commit/ad72ef35707529058c7c680f334c285746b2f690))

Add type-hints for the variables which are set via self.__dict__

mypy doesn't see them when they are assigned via self.__dict__. So declare them in the class
definition.

- Add and fix some type-hints in gitlab/client.py
([`8837207`](https://github.com/python-gitlab/python-gitlab/commit/88372074a703910ba533237e6901e5af4c26c2bd))

Was able to figure out better type-hints for gitlab/client.py

- Add test
([`f8cf1e1`](https://github.com/python-gitlab/python-gitlab/commit/f8cf1e110401dcc6b9b176beb8675513fc1c7d17))

- Add type hints to gitlab/base.py
([`3727cbd`](https://github.com/python-gitlab/python-gitlab/commit/3727cbd21fc40b312573ca8da56e0f6cf9577d08))

- Add type hints to gitlab/base.py:RESTManager
([`9c55593`](https://github.com/python-gitlab/python-gitlab/commit/9c55593ae6a7308176710665f8bec094d4cadc2e))

Add some additional type hints to gitlab/base.py

- Add type hints to gitlab/utils.py
([`acd9294`](https://github.com/python-gitlab/python-gitlab/commit/acd9294fac52a636a016a7a3c14416b10573da28))

- Add type-hints for gitlab/mixins.py
([`baea721`](https://github.com/python-gitlab/python-gitlab/commit/baea7215bbbe07c06b2ca0f97a1d3d482668d887))

* Added type-hints for gitlab/mixins.py * Changed use of filter with a lambda expression to
list-comprehension. mypy was not able to understand the previous code. Also list-comprehension is
better :)

- Add type-hints to gitlab/cli.py
([`10b7b83`](https://github.com/python-gitlab/python-gitlab/commit/10b7b836d31fbe36a7096454287004b46a7799dd))

- Add type-hints to gitlab/client.py
([`c9e5b4f`](https://github.com/python-gitlab/python-gitlab/commit/c9e5b4f6285ec94d467c7c10c45f4e2d5f656430))

Adding some initial type-hints to gitlab/client.py

- Add type-hints to gitlab/config.py
([`213e563`](https://github.com/python-gitlab/python-gitlab/commit/213e5631b1efce11f8a1419cd77df5d9da7ec0ac))

- Add type-hints to gitlab/const.py
([`a10a777`](https://github.com/python-gitlab/python-gitlab/commit/a10a7777caabd6502d04f3947a317b5b0ac869f2))

- Bump version to 2.7.0
([`34c4052`](https://github.com/python-gitlab/python-gitlab/commit/34c4052327018279c9a75d6b849da74eccc8819b))

- Del 'import *' in gitlab/v4/objects/project_access_tokens.py
([`9efbe12`](https://github.com/python-gitlab/python-gitlab/commit/9efbe1297d8d32419b8f04c3758ca7c83a95f199))

Remove usage of 'import *' in gitlab/v4/objects/project_access_tokens.py.

- Disallow incomplete type defs
([`907634f`](https://github.com/python-gitlab/python-gitlab/commit/907634fe4d0d30706656b8bc56260b5532613e62))

Don't allow a partially annotated function definition. Either none of the function is annotated or
all of it must be.

Update code to ensure no-more partially annotated functions.

Update gitlab/cli.py with better type-hints. Changed Tuple[Any, ...] to Tuple[str, ...]

- Explicitly import gitlab.v4.objects/cli
([`233b79e`](https://github.com/python-gitlab/python-gitlab/commit/233b79ed442aac66faf9eb4b0087ea126d6dffc5))

As we only support the v4 Gitlab API, explicitly import gitlab.v4.objects and gitlab.v4.clie instead
of dynamically importing it depending on the API version.

This has the added benefit of mypy being able to type check the Gitlab __init__() function as
currently it will fail if we enable type checking of __init__() it will fail.

Also, this also helps by not confusing tools like pyinstaller/cx_freeze with dynamic imports so you
don't need hooks for standalone executables. And according to https://docs.gitlab.com/ee/api/,

"GraphQL co-exists with the current v4 REST API. If we have a v5 API, this should be a compatibility
layer on top of GraphQL."

- Fix E711 error reported by flake8
([`630901b`](https://github.com/python-gitlab/python-gitlab/commit/630901b30911af01da5543ca609bd27bc5a1a44c))

E711: Comparison to none should be 'if cond is none:'

https://www.flake8rules.com/rules/E711.html

- Fix E712 errors reported by flake8
([`83670a4`](https://github.com/python-gitlab/python-gitlab/commit/83670a49a3affd2465f8fcbcc3c26141592c1ccd))

E712: Comparison to true should be 'if cond is true:' or 'if cond:'

https://www.flake8rules.com/rules/E712.html

- Fix E741/E742 errors reported by flake8
([`380f227`](https://github.com/python-gitlab/python-gitlab/commit/380f227a1ecffd5e22ae7aefed95af3b5d830994))

Fixes to resolve errors for: https://www.flake8rules.com/rules/E741.html Do not use variables named
'I', 'O', or 'l' (E741)

https://www.flake8rules.com/rules/E742.html Do not define classes named 'I', 'O', or 'l' (E742)

- Fix F401 errors reported by flake8
([`ff21eb6`](https://github.com/python-gitlab/python-gitlab/commit/ff21eb664871904137e6df18308b6e90290ad490))

F401: Module imported but unused

https://www.flake8rules.com/rules/F401.html

- Fix F841 errors reported by flake8
([`40f4ab2`](https://github.com/python-gitlab/python-gitlab/commit/40f4ab20ba0903abd3d5c6844fc626eb264b9a6a))

Local variable name is assigned to but never used

https://www.flake8rules.com/rules/F841.html

- Fix package file test naming
([`8c80268`](https://github.com/python-gitlab/python-gitlab/commit/8c802680ae7d3bff13220a55efeed9ca79104b10))

- Fix typo in mr events
([`c5e6fb3`](https://github.com/python-gitlab/python-gitlab/commit/c5e6fb3bc74c509f35f973e291a7551b2b64dba5))

- Have _create_attrs & _update_attrs be a namedtuple
([`aee1f49`](https://github.com/python-gitlab/python-gitlab/commit/aee1f496c1f414c1e30909767d53ae624fe875e7))

Convert _create_attrs and _update_attrs to use a NamedTuple (RequiredOptional) to help with code
readability. Update all code to use the NamedTuple.

- Import audit events in objects
([`35a190c`](https://github.com/python-gitlab/python-gitlab/commit/35a190cfa0902d6a298aba0a3135c5a99edfe0fa))

- Improve type-hints for gitlab/base.py
([`cbd43d0`](https://github.com/python-gitlab/python-gitlab/commit/cbd43d0b4c95e46fc3f1cffddc6281eced45db4a))

Determined the base class for obj_cls and adding type-hints for it.

- Make _types always present in RESTManager
([`924f83e`](https://github.com/python-gitlab/python-gitlab/commit/924f83eb4b5e160bd231efc38e2eea0231fa311f))

We now create _types = {} in RESTManager class.

By making _types always present in RESTManager it makes the code simpler. We no longer have to do:
types = getattr(self, "_types", {})

And the type checker now understands the type.

- Make lint happy
([`7a7c9fd`](https://github.com/python-gitlab/python-gitlab/commit/7a7c9fd932def75a2f2c517482784e445d83881a))

- Make lint happy
([`b5f43c8`](https://github.com/python-gitlab/python-gitlab/commit/b5f43c83b25271f7aff917a9ce8826d39ff94034))

- Make lint happy
([`732e49c`](https://github.com/python-gitlab/python-gitlab/commit/732e49c6547c181de8cc56e93b30dc399e87091d))

- Make ListMixin._list_filters always present
([`8933113`](https://github.com/python-gitlab/python-gitlab/commit/89331131b3337308bacb0c4013e80a4809f3952c))

Always create ListMixin._list_filters attribute with a default value of tuple().

This way we don't need to use hasattr() and we will know the type of the attribute.

- Make RESTObject._short_print_attrs always present
([`6d55120`](https://github.com/python-gitlab/python-gitlab/commit/6d551208f4bc68d091a16323ae0d267fbb6003b6))

Always create RESTObject._short_print_attrs with a default value of None.

This way we don't need to use hasattr() and we will know the type of the attribute.

- Put assert statements inside 'if TYPE_CHECKING:'
([`b562458`](https://github.com/python-gitlab/python-gitlab/commit/b562458f063c6be970f58c733fe01ec786798549))

To be safe that we don't assert while running, put the assert statements, which are used by mypy to
check that types are correct, inside an 'if TYPE_CHECKING:' block.

Also, instead of asserting that the item is a dict, instead assert that it is not a
requests.Response object. Theoretically the JSON could return as a list or dict, though at this
time we are assuming a dict.

- Remove import of gitlab.utils from __init__.py
([`39b9183`](https://github.com/python-gitlab/python-gitlab/commit/39b918374b771f1d417196ca74fa04fe3968c412))

Initially when extracting out the gitlab/client.py code we tried to remove this but functional tests
failed.

Later we fixed the functional test that was failing, so now remove the unneeded import.

- Remove Python 2 code
([`b5d4e40`](https://github.com/python-gitlab/python-gitlab/commit/b5d4e408830caeef86d4c241ac03a6e8781ef189))

httplib is a Python 2 library. It was renamed to http.client in Python 3.

https://docs.python.org/2.7/library/httplib.html

- Remove unused ALLOWED_KEYSET_ENDPOINTS variable
([`3d5d5d8`](https://github.com/python-gitlab/python-gitlab/commit/3d5d5d8b13fc8405e9ef3e14be1fd8bd32235221))

The variable ALLOWED_KEYSET_ENDPOINTS was added in commit f86ef3bbdb5bffa1348a802e62b281d3f31d33ad.

Then most of that commit was removed in commit e71fe16b47835aa4db2834e98c7ffc6bdec36723, but
ALLOWED_KEYSET_ENDPOINTS was missed.

- Remove unused function _construct_url()
([`009d369`](https://github.com/python-gitlab/python-gitlab/commit/009d369f08e46d1e059b98634ff8fe901357002d))

The function _construct_url() was used by the v3 API. All usage of the function was removed in
commit fe89b949922c028830dd49095432ba627d330186

- Remove unused function sanitize_parameters()
([`443b934`](https://github.com/python-gitlab/python-gitlab/commit/443b93482e29fecc12fdbd2329427b37b05ba425))

The function sanitize_parameters() was used when the v3 API was in use. Since v3 API support has
been removed there are no more users of this function.

- Remove usage of 'from ... import *'
([`c83eaf4`](https://github.com/python-gitlab/python-gitlab/commit/c83eaf4f395300471311a67be34d8d306c2b3861))

In gitlab/v4/objects/*.py remove usage of: * from gitlab.base import * * from gitlab.mixins import *

Change them to: * from gitlab.base import CLASS_NAME * from gitlab.mixins import CLASS_NAME

Programmatically update code to explicitly import needed classes only.

After the change the output of: $ flake8 gitlab/v4/objects/*py | grep 'REST\|Mixin'

Is empty. Before many messages about unable to determine if it was a valid name.

- Remove usage of 'from ... import *' in client.py
([`bf0c8c5`](https://github.com/python-gitlab/python-gitlab/commit/bf0c8c5d123a7ad0587cb97c3aafd97ab2a9dabf))

In gitlab/client.py remove usage of: * from gitlab.const import * * from gitlab.exceptions import *

Change them to: * import gitlab.const * import gitlab.exceptions

Update code to explicitly reference things in gitlab.const and gitlab.exceptions

A flake8 run no longer lists any undefined variables. Before it listed possible undefined variables.

- Remove usage of getattr()
([`2afd18a`](https://github.com/python-gitlab/python-gitlab/commit/2afd18aa28742a3267742859a88be6912a803874))

Remove usage of getattr(self, "_update_uses_post", False)

Instead add it to class and set default value to False.

Add a tests that shows it is set to True for the ProjectMergeRequestApprovalManager and
ProjectApprovalManager classes.

- **api**: Move repository endpoints into separate module
([`1ed154c`](https://github.com/python-gitlab/python-gitlab/commit/1ed154c276fb2429d3b45058b9314d6391dbff02))

- **ci**: Deduplicate PR jobs
([`63918c3`](https://github.com/python-gitlab/python-gitlab/commit/63918c364e281f9716885a0f9e5401efcd537406))

- **config**: Allow simple commands without external script
([`91ffb8e`](https://github.com/python-gitlab/python-gitlab/commit/91ffb8e97e213d2f14340b952630875995ecedb2))

- **deps**: Update dependency docker-compose to v1.28.3
([`2358d48`](https://github.com/python-gitlab/python-gitlab/commit/2358d48acbe1c378377fb852b41ec497217d2555))

- **deps**: Update dependency docker-compose to v1.28.4
([`8938484`](https://github.com/python-gitlab/python-gitlab/commit/89384846445be668ca6c861f295297d048cae914))

- **deps**: Update dependency docker-compose to v1.28.5
([`f4ab558`](https://github.com/python-gitlab/python-gitlab/commit/f4ab558f2cd85fe716e24f3aa4ede5db5b06e7c4))

- **deps**: Update dependency docker-compose to v1.28.6
([`46b05d5`](https://github.com/python-gitlab/python-gitlab/commit/46b05d525d0ade6f2aadb6db23fadc85ad48cd3d))

- **deps**: Update dependency docker-compose to v1.29.1
([`a89ec43`](https://github.com/python-gitlab/python-gitlab/commit/a89ec43ee7a60aacd1ac16f0f1f51c4abeaaefef))

- **deps**: Update dependency sphinx to v3.4.3
([`37c992c`](https://github.com/python-gitlab/python-gitlab/commit/37c992c09bfd25f3ddcb026f830f3a79c39cb70d))

- **deps**: Update dependency sphinx to v3.5.0
([`188c5b6`](https://github.com/python-gitlab/python-gitlab/commit/188c5b692fc195361c70f768cc96c57b3686d4b7))

- **deps**: Update dependency sphinx to v3.5.1
([`f916f09`](https://github.com/python-gitlab/python-gitlab/commit/f916f09d3a9cac07246035066d4c184103037026))

- **deps**: Update dependency sphinx to v3.5.2
([`9dee5c4`](https://github.com/python-gitlab/python-gitlab/commit/9dee5c420633bc27e1027344279c47862f7b16da))

- **deps**: Update dependency sphinx to v3.5.4
([`a886d28`](https://github.com/python-gitlab/python-gitlab/commit/a886d28a893ac592b930ce54111d9ae4e90f458e))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.10.0-ce.0
([`5221e33`](https://github.com/python-gitlab/python-gitlab/commit/5221e33768fe1e49456d5df09e3f50b46933c8a4))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.10.1-ce.0
([`1995361`](https://github.com/python-gitlab/python-gitlab/commit/1995361d9a767ad5af5338f4555fa5a3914c7374))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.10.3-ce.0
([`eabe091`](https://github.com/python-gitlab/python-gitlab/commit/eabe091945d3fe50472059431e599117165a815a))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.11.0-ce.0
([`711896f`](https://github.com/python-gitlab/python-gitlab/commit/711896f20ff81826c58f1f86dfb29ad860e1d52a))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.11.1-ce.0
([`3088714`](https://github.com/python-gitlab/python-gitlab/commit/308871496041232f555cf4cb055bf7f4aaa22b23))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.8.2-ce.0
([`7c12038`](https://github.com/python-gitlab/python-gitlab/commit/7c120384762e23562a958ae5b09aac324151983a))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.8.3-ce.0
([`e6c20f1`](https://github.com/python-gitlab/python-gitlab/commit/e6c20f18f3bd1dabdf181a070b9fdbfe4a442622))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.8.4-ce.0
([`832cb88`](https://github.com/python-gitlab/python-gitlab/commit/832cb88992cd7af4903f8b780e9475c03c0e6e56))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.9.0-ce.0
([`3aef19c`](https://github.com/python-gitlab/python-gitlab/commit/3aef19c51713bdc7ca0a84752da3ca22329fd4c4))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.9.1-ce.0
([`f6fd995`](https://github.com/python-gitlab/python-gitlab/commit/f6fd99530d70f2a7626602fd9132b628bb968eab))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.9.2-ce.0
([`933ba52`](https://github.com/python-gitlab/python-gitlab/commit/933ba52475e5dae4cf7c569d8283e60eebd5b7b6))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.9.3-ce.0
([`2ddf45f`](https://github.com/python-gitlab/python-gitlab/commit/2ddf45fed0b28e52d31153d9b1e95d0cae05e9f5))

- **deps**: Update gitlab/gitlab-ce docker tag to v13.9.4-ce.0
([`939f769`](https://github.com/python-gitlab/python-gitlab/commit/939f769e7410738da2e1c5d502caa765f362efdd))

- **deps**: Update precommit hook alessandrojcm/commitlint-pre-commit-hook to v4
([`505a8b8`](https://github.com/python-gitlab/python-gitlab/commit/505a8b8d7f16e609f0cde70be88a419235130f2f))

- **deps**: Update wagoid/commitlint-github-action action to v3
([`b3274cf`](https://github.com/python-gitlab/python-gitlab/commit/b3274cf93dfb8ae85e4a636a1ffbfa7c48f1c8f6))

- **objects**: Make Project refreshable
([`958a6aa`](https://github.com/python-gitlab/python-gitlab/commit/958a6aa83ead3fb6be6ec61bdd894ad78346e7bd))

Helps getting the real state of the project from the server.

- **objects**: Remove noisy deprecation warning for audit events
([`2953642`](https://github.com/python-gitlab/python-gitlab/commit/29536423e3e8866eda7118527a49b120fefb4065))

It's mostly an internal thing anyway and can be removed in 3.0.0

- **tests**: Remove unused URL segment
([`66f0b6c`](https://github.com/python-gitlab/python-gitlab/commit/66f0b6c23396b849f8653850b099e664daa05eb4))

Documentation

- Add docs and examples for custom user agent
([`a69a214`](https://github.com/python-gitlab/python-gitlab/commit/a69a214ef7f460cef7a7f44351c4861503f9902e))

- Add information about the gitter community
([`6ff67e7`](https://github.com/python-gitlab/python-gitlab/commit/6ff67e7327b851fa67be6ad3d82f88ff7cce0dc9))

Add a section in the README.rst about the gitter community. The badge already exists and is useful
but very easy to miss.

- Change travis-ci badge to githubactions
([`2ba5ba2`](https://github.com/python-gitlab/python-gitlab/commit/2ba5ba244808049aad1ee3b42d1da258a9db9f61))

- **api**: Add examples for resource state events
([`4d00c12`](https://github.com/python-gitlab/python-gitlab/commit/4d00c12723d565dc0a83670f62e3f5102650d822))

- **api**: Add release links API docs
([`36d65f0`](https://github.com/python-gitlab/python-gitlab/commit/36d65f03db253d710938c2d827c1124c94a40506))

Features

- Add an initial mypy test to tox.ini
([`fdec039`](https://github.com/python-gitlab/python-gitlab/commit/fdec03976a17e0708459ba2fab22f54173295f71))

Add an initial mypy test to test gitlab/base.py and gitlab/__init__.py

- Add personal access token API
([`2bb16fa`](https://github.com/python-gitlab/python-gitlab/commit/2bb16fac18a6a91847201c174f3bf1208338f6aa))

See: https://docs.gitlab.com/ee/api/personal_access_tokens.html

- Add project audit endpoint
([`6660dbe`](https://github.com/python-gitlab/python-gitlab/commit/6660dbefeeffc2b39ddfed4928a59ed6da32ddf4))

- Add ProjectPackageFile
([`b9d469b`](https://github.com/python-gitlab/python-gitlab/commit/b9d469bc4e847ae0301be28a0c70019a7f6ab8b6))

Add ProjectPackageFile and the ability to list project package package_files.

Fixes 1372

- Import from bitbucket server
([`ff3013a`](https://github.com/python-gitlab/python-gitlab/commit/ff3013a2afeba12811cb3d860de4d0ea06f90545))

I'd like to use this libary to automate importing Bitbucket Server repositories into GitLab. There
is a [GitLab API
endpoint](https://docs.gitlab.com/ee/api/import.html#import-repository-from-bitbucket-server) to
do this, but it is not exposed through this library.

* Add an `import_bitbucket_server` method to the `ProjectManager`. This method calls this GitLab API
endpoint: https://docs.gitlab.com/ee/api/import.html#import-repository-from-bitbucket-server *
Modify `import_gitlab` method docstring for python3 compatibility * Add a skipped stub test for
the existing `import_github` method

- Option to add a helper to lookup token
([`8ecf559`](https://github.com/python-gitlab/python-gitlab/commit/8ecf55926f8e345960560e5c5dd6716199cfb0ec))

- **api,cli**: Make user agent configurable
([`4bb201b`](https://github.com/python-gitlab/python-gitlab/commit/4bb201b92ef0dcc14a7a9c83e5600ba5b118fc33))

- **issues**: Add missing get verb to IssueManager
([`f78ebe0`](https://github.com/python-gitlab/python-gitlab/commit/f78ebe065f73b29555c2dcf17b462bb1037a153e))

- **objects**: Add Release Links API support
([`28d7518`](https://github.com/python-gitlab/python-gitlab/commit/28d751811ffda45ff0b1c35e0599b655f3a5a68b))

- **objects**: Add support for group audit events API
([`2a0fbdf`](https://github.com/python-gitlab/python-gitlab/commit/2a0fbdf9fe98da6c436230be47b0ddb198c7eca9))

- **objects**: Add support for resource state events API
([`d4799c4`](https://github.com/python-gitlab/python-gitlab/commit/d4799c40bd12ed85d4bb834464fdb36c4dadcab6))

- **projects**: Add project access token api
([`1becef0`](https://github.com/python-gitlab/python-gitlab/commit/1becef0253804f119c8a4d0b8b1c53deb2f4d889))

- **users**: Add follow/unfollow API
([`e456869`](https://github.com/python-gitlab/python-gitlab/commit/e456869d98a1b7d07e6f878a0d6a9719c1b10fd4))

Refactoring

- Move Gitlab and GitlabList to gitlab/client.py
([`53a7645`](https://github.com/python-gitlab/python-gitlab/commit/53a764530cc3c6411034a3798f794545881d341e))

Move the classes Gitlab and GitlabList from gitlab/__init__.py to the newly created gitlab/client.py
file.

Update one test case that was depending on requests being defined in gitlab/__init__.py

- **api**: Explicitly export classes for star imports
([`f05c287`](https://github.com/python-gitlab/python-gitlab/commit/f05c287512a9253c7f7d308d3437240ac8257452))

- **objects**: Move instance audit events where they belong
([`48ba88f`](https://github.com/python-gitlab/python-gitlab/commit/48ba88ffb983207da398ea2170c867f87a8898e9))

- **v4**: Split objects and managers per API resource
([`a5a48ad`](https://github.com/python-gitlab/python-gitlab/commit/a5a48ad08577be70c6ca511d3b4803624e5c2043))

Testing

- Don't add duplicate fixture
([`5d94846`](https://github.com/python-gitlab/python-gitlab/commit/5d9484617e56b89ac5e17f8fc94c0b1eb46d4b89))

Co-authored-by: Nejc Habjan <hab.nejcgmail.com>

- **api**: Add functional test for release links API
([`ab2a1c8`](https://github.com/python-gitlab/python-gitlab/commit/ab2a1c816d83e9e308c0c9c7abf1503438b0b3be))

- **api,cli**: Add tests for custom user agent
([`c5a37e7`](https://github.com/python-gitlab/python-gitlab/commit/c5a37e7e37a62372c250dfc8c0799e847eecbc30))

- **object**: Add test for __dir__ duplicates
([`a8e591f`](https://github.com/python-gitlab/python-gitlab/commit/a8e591f742f777f8747213b783271004e5acc74d))

- **objects**: Add tests for resource state events
([`10225cf`](https://github.com/python-gitlab/python-gitlab/commit/10225cf26095efe82713136ddde3330e7afc6d10))

- **objects**: Add unit test for instance audit events
([`84e3247`](https://github.com/python-gitlab/python-gitlab/commit/84e3247d0cd3ddb1f3aa0ac91fb977c3e1e197b5))

Page 9 of 13

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.