mirror of
https://github.com/Tautulli/Tautulli.git
synced 2025-07-05 20:51:15 -07:00
Bump cloudinary from 1.29.0 to 1.30.0 (#1890)
* Bump cloudinary from 1.29.0 to 1.30.0 Bumps [cloudinary](https://github.com/cloudinary/pycloudinary) from 1.29.0 to 1.30.0. - [Release notes](https://github.com/cloudinary/pycloudinary/releases) - [Changelog](https://github.com/cloudinary/pycloudinary/blob/master/CHANGELOG.md) - [Commits](https://github.com/cloudinary/pycloudinary/compare/1.29.0...1.30.0) --- updated-dependencies: - dependency-name: cloudinary dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Update cloudinary==1.30.0 Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: JonnyWong16 <9099342+JonnyWong16@users.noreply.github.com> [skip ci]
This commit is contained in:
parent
7f132439be
commit
6b835226cd
18 changed files with 61 additions and 27 deletions
|
@ -1,14 +1,14 @@
|
|||
from __future__ import absolute_import
|
||||
|
||||
import abc
|
||||
from copy import deepcopy
|
||||
import hashlib
|
||||
import os
|
||||
import re
|
||||
import logging
|
||||
import numbers
|
||||
import certifi
|
||||
import os
|
||||
import re
|
||||
from copy import deepcopy
|
||||
from math import ceil
|
||||
|
||||
import certifi
|
||||
from six import python_2_unicode_compatible, add_metaclass
|
||||
|
||||
logger = logging.getLogger("Cloudinary")
|
||||
|
@ -23,7 +23,7 @@ from cloudinary.cache import responsive_breakpoints_cache
|
|||
from cloudinary.http_client import HttpClient
|
||||
from cloudinary.compat import urlparse, parse_qs
|
||||
|
||||
from platform import python_version
|
||||
from platform import python_version, platform
|
||||
|
||||
CERT_KWARGS = {
|
||||
'cert_reqs': 'CERT_REQUIRED',
|
||||
|
@ -38,15 +38,17 @@ CL_BLANK = "
|
|||
URI_SCHEME = "cloudinary"
|
||||
API_VERSION = "v1_1"
|
||||
|
||||
VERSION = "1.29.0"
|
||||
VERSION = "1.30.0"
|
||||
|
||||
USER_AGENT = "CloudinaryPython/{} (Python {})".format(VERSION, python_version())
|
||||
_USER_PLATFORM_DETAILS = "; ".join((platform(), "Python {}".format(python_version())))
|
||||
|
||||
USER_AGENT = "CloudinaryPython/{} ({})".format(VERSION, _USER_PLATFORM_DETAILS)
|
||||
""" :const: USER_AGENT """
|
||||
|
||||
USER_PLATFORM = ""
|
||||
"""
|
||||
Additional information to be passed with the USER_AGENT, e.g. "CloudinaryMagento/1.0.1".
|
||||
This value is set in platform-specific implementations that use cloudinary_php.
|
||||
Additional information to be passed with the USER_AGENT, e.g. "CloudinaryCLI/1.2.3".
|
||||
This value is set in platform-specific implementations that use pycloudinary.
|
||||
|
||||
The format of the value should be <ProductName>/Version[ (comment)].
|
||||
@see http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.43
|
||||
|
|
|
@ -93,6 +93,23 @@ def resources_by_ids(public_ids, **options):
|
|||
return call_api("get", uri, params, **options)
|
||||
|
||||
|
||||
def resources_by_asset_folder(asset_folder, **options):
|
||||
"""
|
||||
Returns the details of the resources (assets) under a specified asset_folder.
|
||||
|
||||
:param asset_folder: The Asset Folder of the asset
|
||||
:type asset_folder: string
|
||||
:param options: Additional options
|
||||
:type options: dict, optional
|
||||
:return: Resources (assets) of a specific asset_folder
|
||||
:rtype: Response
|
||||
"""
|
||||
uri = ["resources", "by_asset_folder"]
|
||||
params = only(options, "max_results", "tags", "moderations", "context", "next_cursor")
|
||||
params["asset_folder"] = asset_folder
|
||||
return call_api("get", uri, params, **options)
|
||||
|
||||
|
||||
def resources_by_asset_ids(asset_ids, **options):
|
||||
"""Retrieves the resources (assets) indicated in the asset IDs.
|
||||
This method does not return deleted assets even if they have been backed up.
|
||||
|
@ -131,7 +148,7 @@ def resources_by_context(key, value=None, **options):
|
|||
resource_type = options.pop("resource_type", "image")
|
||||
uri = ["resources", resource_type, "context"]
|
||||
params = only(options, "next_cursor", "max_results", "tags",
|
||||
"context", "moderations", "direction", "metadata")
|
||||
"context", "moderations", "direction", "metadata")
|
||||
params["key"] = key
|
||||
if value is not None:
|
||||
params["value"] = value
|
||||
|
@ -194,10 +211,18 @@ def update(public_id, **options):
|
|||
options.get("custom_coordinates"))
|
||||
if "context" in options:
|
||||
params["context"] = utils.encode_context(options.get("context"))
|
||||
if "metadata" in options:
|
||||
params["metadata"] = utils.encode_context(options.get("metadata"))
|
||||
if "auto_tagging" in options:
|
||||
params["auto_tagging"] = str(options.get("auto_tagging"))
|
||||
if "access_control" in options:
|
||||
params["access_control"] = utils.json_encode(utils.build_list_of_dicts(options.get("access_control")))
|
||||
if "asset_folder" in options:
|
||||
params["asset_folder"] = options.get("asset_folder")
|
||||
if "display_name" in options:
|
||||
params["display_name"] = options.get("display_name")
|
||||
if "unique_display_name" in options:
|
||||
params["unique_display_name"] = options.get("unique_display_name")
|
||||
|
||||
return call_api("post", uri, params, **options)
|
||||
|
||||
|
|
|
@ -30,7 +30,9 @@ def generate(url=None, acl=None, start_time=None, duration=None,
|
|||
token_parts.append("st=%d" % start_time)
|
||||
token_parts.append("exp=%d" % expiration)
|
||||
if acl is not None:
|
||||
token_parts.append("acl=%s" % _escape_to_lower(acl))
|
||||
acl_list = acl if type(acl) is list else [acl]
|
||||
acl_list = [_escape_to_lower(a) for a in acl_list]
|
||||
token_parts.append("acl=%s" % "!".join(acl_list))
|
||||
to_sign = list(token_parts)
|
||||
if url is not None and acl is None:
|
||||
to_sign.append("url=%s" % _escape_to_lower(url))
|
||||
|
|
|
@ -106,7 +106,7 @@ class CloudinaryField(models.Field):
|
|||
value = super(CloudinaryField, self).pre_save(model_instance, add)
|
||||
if isinstance(value, UploadedFile):
|
||||
options = {"type": self.type, "resource_type": self.resource_type}
|
||||
options.update(self.options)
|
||||
options.update({key: val(model_instance) if callable(val) else val for key, val in self.options.items()})
|
||||
if hasattr(value, 'seekable') and value.seekable():
|
||||
value.seek(0)
|
||||
instance_value = uploader.upload_resource(value, **options)
|
||||
|
|
|
@ -65,7 +65,7 @@ def create_sub_account(name, cloud_name=None, custom_attributes=None, enabled=No
|
|||
"cloud_name": cloud_name,
|
||||
"custom_attributes": custom_attributes,
|
||||
"enabled": enabled,
|
||||
"base_account": base_account}
|
||||
"base_sub_account_id": base_account}
|
||||
return _call_account_api("POST", uri, params=params, **options)
|
||||
|
||||
|
||||
|
|
|
@ -1093,11 +1093,11 @@ var slice = [].slice,
|
|||
*
|
||||
* If the parameter is an object,
|
||||
* @param {(string|Object)} param - the video codec as either a String or a Hash
|
||||
* @return {string} the video codec string in the format codec:profile:level
|
||||
* @return {string} the video codec string in the format codec:profile:level:b_frames
|
||||
* @example
|
||||
* vc_[ :profile : [level]]
|
||||
* vc_[ :profile : [level : [b_frames]]]
|
||||
* or
|
||||
{ codec: 'h264', profile: 'basic', level: '3.1' }
|
||||
{ codec: 'h264', profile: 'basic', level: '3.1', b_frames: false }
|
||||
* @ignore
|
||||
*/
|
||||
|
||||
|
@ -1112,6 +1112,9 @@ var slice = [].slice,
|
|||
video += ":" + param['profile'];
|
||||
if ('level' in param) {
|
||||
video += ":" + param['level'];
|
||||
if ('b_frames' in param && param['b_frames'] === false) {
|
||||
video += ":bframes_no";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,14 +1,14 @@
|
|||
{% load static %}
|
||||
|
||||
<script src="{% static "js/jquery.ui.widget.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.iframe-transport.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.fileupload.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.cloudinary.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.ui.widget.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.iframe-transport.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.fileupload.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.cloudinary.js" %}" type="text/javascript"></script>
|
||||
|
||||
{% if processing %}
|
||||
<script src="{% static "js/load-image.all.min.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/canvas-to-blob.min.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.fileupload-process.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.fileupload-image.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "js/jquery.fileupload-validate.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/load-image.all.min.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/canvas-to-blob.min.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.fileupload-process.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.fileupload-image.js" %}" type="text/javascript"></script>
|
||||
<script src="{% static "cloudinary/js/jquery.fileupload-validate.js" %}" type="text/javascript"></script>
|
||||
{% endif %}
|
||||
|
|
|
@ -94,6 +94,8 @@ __SIMPLE_UPLOAD_PARAMS = [
|
|||
"proxy",
|
||||
"folder",
|
||||
"asset_folder",
|
||||
"use_asset_folder_as_public_id_prefix",
|
||||
"unique_display_name",
|
||||
"overwrite",
|
||||
"moderation",
|
||||
"raw_convert",
|
||||
|
|
|
@ -9,7 +9,7 @@ bleach==5.0.1
|
|||
certifi==2022.9.24
|
||||
cheroot==8.6.0
|
||||
cherrypy==18.8.0
|
||||
cloudinary==1.29.0
|
||||
cloudinary==1.30.0
|
||||
distro==1.7.0
|
||||
dnspython==2.2.1
|
||||
facebook-sdk==3.1.0
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue