- 新增图像生成接口,支持试用、积分和自定义API Key模式 - 实现生成图片结果异步上传至MinIO存储,带重试机制 - 优化积分预扣除和异常退还逻辑,保障用户积分准确 - 添加获取生成历史记录接口,支持时间范围和分页 - 提供本地字典配置接口,支持模型、比例、提示模板和尺寸 - 实现图片批量上传接口,支持S3兼容对象存储 feat(admin): 增加管理员角色管理与权限分配接口 - 实现角色列表查询、角色创建、更新及删除功能 - 增加权限列表查询接口 - 实现用户角色分配接口,便于统一管理用户权限 - 增加系统字典增删查改接口,支持分类过滤和排序 - 权限控制全面覆盖管理接口,保证安全访问 feat(auth): 完善用户登录注册及权限相关接口与页面 - 实现手机号验证码发送及校验功能,保障注册安全 - 支持手机号注册、登录及退出接口,集成日志记录 - 增加修改密码功能,验证原密码后更新 - 提供动态导航菜单接口,基于权限展示不同菜单 - 实现管理界面路由及日志、角色、字典管理页面访问权限控制 - 添加系统日志查询接口,支持关键词和等级筛选 feat(app): 初始化Flask应用并配置蓝图与数据库 - 创建应用程序工厂,加载配置,初始化数据库和Redis客户端 - 注册认证、API及管理员蓝图,整合路由 - 根路由渲染主页模板 - 应用上下文中自动创建数据库表,保证运行环境准备完毕 feat(database): 提供数据库创建与迁移支持脚本 - 新增数据库创建脚本,支持自动检测是否已存在 - 添加数据库表初始化脚本,支持创建和删除所有表 - 实现RBAC权限初始化,包含基础权限和角色创建 - 新增字段手动修复脚本,添加用户API Key和积分字段 - 强制迁移脚本支持清理连接和修复表结构,初始化默认数据及角色分配 feat(config): 新增系统配置参数 - 配置数据库、Redis、Session和MinIO相关参数 - 添加AI接口地址及试用Key配置 - 集成阿里云短信服务配置及开发模式相关参数 feat(extensions): 初始化数据库、Redis和MinIO客户端 - 创建全局SQLAlchemy数据库实例和Redis客户端 - 配置基于boto3的MinIO兼容S3客户端 chore(logs): 添加示例系统日志文件 - 记录用户请求、验证码发送成功与失败的日志信息
118 lines
4.0 KiB
Plaintext
118 lines
4.0 KiB
Plaintext
Metadata-Version: 2.4
|
|
Name: greenlet
|
|
Version: 3.3.0
|
|
Summary: Lightweight in-process concurrent programming
|
|
Home-page: https://greenlet.readthedocs.io/
|
|
Author: Alexey Borzenkov
|
|
Author-email: snaury@gmail.com
|
|
Maintainer: Jason Madden
|
|
Maintainer-email: jason@seecoresoftware.com
|
|
License: MIT AND Python-2.0
|
|
Project-URL: Bug Tracker, https://github.com/python-greenlet/greenlet/issues
|
|
Project-URL: Source Code, https://github.com/python-greenlet/greenlet/
|
|
Project-URL: Documentation, https://greenlet.readthedocs.io/
|
|
Project-URL: Changes, https://greenlet.readthedocs.io/en/latest/changes.html
|
|
Keywords: greenlet coroutine concurrency threads cooperative
|
|
Platform: any
|
|
Classifier: Development Status :: 5 - Production/Stable
|
|
Classifier: Intended Audience :: Developers
|
|
Classifier: Natural Language :: English
|
|
Classifier: Programming Language :: C
|
|
Classifier: Programming Language :: Python
|
|
Classifier: Programming Language :: Python :: 3
|
|
Classifier: Programming Language :: Python :: 3 :: Only
|
|
Classifier: Programming Language :: Python :: 3.10
|
|
Classifier: Programming Language :: Python :: 3.11
|
|
Classifier: Programming Language :: Python :: 3.12
|
|
Classifier: Programming Language :: Python :: 3.13
|
|
Classifier: Programming Language :: Python :: 3.14
|
|
Classifier: Operating System :: OS Independent
|
|
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
|
Requires-Python: >=3.10
|
|
Description-Content-Type: text/x-rst
|
|
License-File: LICENSE
|
|
License-File: LICENSE.PSF
|
|
Provides-Extra: docs
|
|
Requires-Dist: Sphinx; extra == "docs"
|
|
Requires-Dist: furo; extra == "docs"
|
|
Provides-Extra: test
|
|
Requires-Dist: objgraph; extra == "test"
|
|
Requires-Dist: psutil; extra == "test"
|
|
Requires-Dist: setuptools; extra == "test"
|
|
Dynamic: author
|
|
Dynamic: author-email
|
|
Dynamic: classifier
|
|
Dynamic: description
|
|
Dynamic: description-content-type
|
|
Dynamic: home-page
|
|
Dynamic: keywords
|
|
Dynamic: license
|
|
Dynamic: license-file
|
|
Dynamic: maintainer
|
|
Dynamic: maintainer-email
|
|
Dynamic: platform
|
|
Dynamic: project-url
|
|
Dynamic: provides-extra
|
|
Dynamic: requires-python
|
|
Dynamic: summary
|
|
|
|
.. This file is included into docs/history.rst
|
|
|
|
|
|
Greenlets are lightweight coroutines for in-process concurrent
|
|
programming.
|
|
|
|
The "greenlet" package is a spin-off of `Stackless`_, a version of
|
|
CPython that supports micro-threads called "tasklets". Tasklets run
|
|
pseudo-concurrently (typically in a single or a few OS-level threads)
|
|
and are synchronized with data exchanges on "channels".
|
|
|
|
A "greenlet", on the other hand, is a still more primitive notion of
|
|
micro-thread with no implicit scheduling; coroutines, in other words.
|
|
This is useful when you want to control exactly when your code runs.
|
|
You can build custom scheduled micro-threads on top of greenlet;
|
|
however, it seems that greenlets are useful on their own as a way to
|
|
make advanced control flow structures. For example, we can recreate
|
|
generators; the difference with Python's own generators is that our
|
|
generators can call nested functions and the nested functions can
|
|
yield values too. (Additionally, you don't need a "yield" keyword. See
|
|
the example in `test_generator.py
|
|
<https://github.com/python-greenlet/greenlet/blob/adca19bf1f287b3395896a8f41f3f4fd1797fdc7/src/greenlet/tests/test_generator.py#L1>`_).
|
|
|
|
Greenlets are provided as a C extension module for the regular unmodified
|
|
interpreter.
|
|
|
|
.. _`Stackless`: http://www.stackless.com
|
|
|
|
|
|
Who is using Greenlet?
|
|
======================
|
|
|
|
There are several libraries that use Greenlet as a more flexible
|
|
alternative to Python's built in coroutine support:
|
|
|
|
- `Concurrence`_
|
|
- `Eventlet`_
|
|
- `Gevent`_
|
|
|
|
.. _Concurrence: http://opensource.hyves.org/concurrence/
|
|
.. _Eventlet: http://eventlet.net/
|
|
.. _Gevent: http://www.gevent.org/
|
|
|
|
Getting Greenlet
|
|
================
|
|
|
|
The easiest way to get Greenlet is to install it with pip::
|
|
|
|
pip install greenlet
|
|
|
|
|
|
Source code archives and binary distributions are available on the
|
|
python package index at https://pypi.org/project/greenlet
|
|
|
|
The source code repository is hosted on github:
|
|
https://github.com/python-greenlet/greenlet
|
|
|
|
Documentation is available on readthedocs.org:
|
|
https://greenlet.readthedocs.io
|