Ltd-conveyor

Latest version: v0.8.3

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

Scan your dependencies

Page 2 of 3

0.4.2

Bugs fixed

- Fixed a bug where `ltdconveyor.s3.delete_dir`, since 0.4.1, would raise a `TypeError` while deleting an empty directory (no objects in the S3 prefix).

0.4.1

Bugs fixed

- Fixed a bug where `ltdconveyor.s3.delete_dir` would fail if there are more than 1000 objects under a path prefix that is being deleted.
- Fixed title of the project in the documentation by updating to use a Documenteer-based Sphinx set up.

0.4.0

New features

- Added a new command-line app, `ltd`, that provides subcommands for clients to work with the LSST the Docs API. This app is implemented with Click, and its documentation is automatically generated from the command-line help with `sphinx-click`.

The first subcommand is `ltd upload`, which lets a client upload a site to LTD as a new build.
This command includes special features for using the client from Travis CI (`ltd upload --travis` option) to populate the version information from the Travis environment.
Other flags allow `ltd upload` to become a no-op under certain circumstances (for example, skip uploads on pull requests) or arbitrarily (set `ltd upload --skip` or `export LTD_SKIP_UPLOAD=true`).

With this feature, LTD Conveyor effectively deprecates [LTD Mason](https://github.com/lsst-sqre/ltd-mason).
LTD Mason was the original uploader for LSST the Docs, but it was also designed around the idea of building the `LSST Science Pipelines` documentation as well (hence the term "mason").
Over time, we realized it is better to have a general purpose client and uploader for LSST the Docs (LTD Conveyor) and a dedicated tool for assembling the multi-package Sphinx documentation site (Documenteer).

- Added the `ltdconveyor.keeper` subpackage that widens the scope of LTD Conveyor to be a full-service library for building LTD clients, not just an S3 upload client.

- The `ltdconveyor.keeper.login.get_keeper_token` function lets you obtain a temporary auth token for the LTD Keeper API.

- The `ltdconveyor.keeper.build` module includes functions for performing the build upload handshake with the LTD Keeper API.

Other changes

- Removed Python 2.7 and 3.4 compatibility.
Now the codebase is entirely Python 3 (3.5, 3.6)-oriented.

- Completely reorganized Python namespace.
Now all S3 APIs are in `ltdconveyor.s3`.
Fastly APIs are available from `ltdconveyor.fastly`.

- Switched to using `setuptools_scm` to generate version strings for releases.

- Switched to using `extras_require` for development dependencies (`pip install -e ".[dev]"`).
This lets us exclusively coordinate dependencies in `setup.py`.

- Enable testing via `python setup.py test`.
Also upgrade the testing stack to `pytest` 3.5 and `pytest-flake8` 1.0.

- Compatibility updates to the Sphinx documentation infrastructure.

- Default to `acl=None` to support more AWS IAM users.
It turns out that not all IAM users with `PutObject` permissions also have permissions to set the `ACL` for an object.
We want to make it possible for many lightweight IAM users to upload to restricted sub-directories of the `lsst-the-docs` bucket, but it seems hard to make these users ACL grantees too.
We now seek an alternative:

- The `lsst-the-docs` bucket now has a PublicRead _bucket_ policy
- No ACL is set on individual objects.

Bugs fixed

- Changed assertions to `RuntimeErrors`.
Assertions shouldn't be used to raise exceptions in production code.

0.3.1

New features

- Add `open_bucket` function. This provides a convenient API for getting a boto3 bucket resource, particularly for clients that use the upload_object and upload_file APIs directly that take a bucket only.

0.3.0

New features

- Added `content_type` parameter to `upload_object` so that a user can specify `text/html` for an HTML upload.
The `upload_file`/`upload_dir` functions avoid this problem by using Python's `mimetypes` library to guess the encoding, but `upload_object` is lower-level and warrants having the user explicitly provide the content type.

- Refactored new function `create_dir_redirect_object`.
This code used to be inside `upload_dir`, but in LTD Dasher it seems necessary to upload files one at a time, and thus it's necessary to directly create these directory redirect objects.

Bugs fixed

- Fix issue where `'..'` shows up in directory names (seen when doing `upload_dir` with `LTD Dasher` asset directories).

0.2.0

New features

- Ported Fastly `purge_key` function from LTD Keeper.
Any LTD application that uploads objects to S3 might also need to purge Fastly CDN caches.
This purge capability is presented as a simple function.

Page 2 of 3

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.