# Neo Core FastAPI
A comprehensive FastAPI-based core library providing essential services for modern web applications.
## 🚀 特性
### 核心模型
- **用户管理**: 用户模型、认证、权限控制
- **角色权限**: RBAC权限模型,支持细粒度权限控制
- **应用管理**: 多应用支持,应用配置管理
- **审计日志**: 完整的操作审计和日志记录
### 数据库管理
- **SQLAlchemy 2.0**: 现代化的ORM支持
- **Alembic迁移**: 数据库版本管理
- **连接池**: 高性能数据库连接管理
- **多数据库**: 支持PostgreSQL、MySQL、SQLite
### 服务层
- **基础服务**: 通用CRUD操作封装
- **认证服务**: JWT令牌管理、密码加密
- **权限服务**: 权限检查、角色管理
- **缓存服务**: Redis缓存集成
### 中间件
- **认证中间件**: 自动用户认证
- **权限中间件**: 路由级权限控制
- **日志中间件**: 请求响应日志记录
- **CORS中间件**: 跨域请求处理
### 工具库
- **密码工具**: 密码加密、验证
- **JWT工具**: 令牌生成、验证、刷新
- **验证工具**: 数据验证、格式化
- **时间工具**: 时区处理、格式转换
## 📦 安装
```bash
# 基础安装
pip install neo-core-fastapi
# 开发环境安装
pip install neo-core-fastapi[dev]
# 测试环境安装
pip install neo-core-fastapi[testing]
# 文档环境安装
pip install neo-core-fastapi[docs]
```
## 🔧 快速开始
### 1. 基础配置
```python
from neo_core.config import CoreSettings
from neo_core.database import DatabaseManager
from neo_core.auth import AuthManager
# 配置设置
settings = CoreSettings(
database_url="postgresql://user:pass@localhost/dbname",
redis_url="redis://localhost:6379",
secret_key="your-secret-key"
)
# 初始化数据库
db_manager = DatabaseManager(settings)
await db_manager.initialize()
# 初始化认证
auth_manager = AuthManager(settings)
```
### 2. 使用核心模型
```python
from neo_core.models import User, Role, Permission
from neo_core.services import UserService, RoleService
# 创建用户服务
user_service = UserService(db_session)
# 创建用户
user = await user_service.create_user(
username="admin",
email="admin@example.com",
password="secure_password"
)
# 分配角色
role = await RoleService(db_session).get_role_by_name("admin")
await user_service.assign_role(user.id, role.id)
```
### 3. 使用认证中间件
```python
from fastapi import FastAPI, Depends
from neo_core.middleware import AuthMiddleware
from neo_core.dependencies import get_current_user
from neo_core.models import User
app = FastAPI()
# 添加认证中间件
app.add_middleware(AuthMiddleware)
@app.get("/protected")
async def protected_route(current_user: User = Depends(get_current_user)):
return {"message": f"Hello, {current_user.username}!"}
```
### 4. 使用权限控制
```python
from neo_core.dependencies import require_permission
from neo_core.models import User
@app.get("/admin-only")
async def admin_only(
current_user: User = Depends(require_permission("admin.read"))
):
return {"message": "Admin access granted"}
```
## 📚 核心组件
### 模型层 (Models)
```python
# 用户模型
from neo_core.models import User, Role, Permission, Application
# 用户管理
user = User(
username="john_doe",
email="john@example.com",
is_active=True
)
# 角色权限
role = Role(name="editor", description="Content Editor")
permission = Permission(name="content.edit", description="Edit Content")
```
### 服务层 (Services)
```python
# 基础服务
from neo_core.services import BaseService, UserService, RoleService
# 自定义服务
class CustomService(BaseService[CustomModel]):
async def custom_method(self, param: str) -> CustomModel:
# 自定义业务逻辑
return await self.create({"field": param})
```
### 工具库 (Utils)
```python
# 密码工具
from neo_core.utils.password import hash_password, verify_password
hashed = hash_password("my_password")
is_valid = verify_password("my_password", hashed)
# JWT工具
from neo_core.utils.jwt import create_access_token, decode_token
token = create_access_token(data={"sub": "user_id"})
payload = decode_token(token)
# 验证工具
from neo_core.utils.validators import validate_email, validate_phone
is_valid_email = validate_email("test@example.com")
is_valid_phone = validate_phone("+1234567890")
```
## 🗄️ 数据库管理
### 迁移管理
```bash
# 创建迁移
alembic revision --autogenerate -m "Add new table"
# 应用迁移
alembic upgrade head
# 回滚迁移
alembic downgrade -1
```
### 数据库初始化
```python
from neo_core.database import init_database, create_default_data
# 初始化数据库结构
await init_database()
# 创建默认数据
await create_default_data()
```
## 🔐 安全特性
### 密码安全
- bcrypt加密算法
- 密码强度验证
- 密码历史记录
### JWT认证
- 访问令牌和刷新令牌
- 令牌黑名单机制
- 自动令牌刷新
### 权限控制
- 基于角色的访问控制(RBAC)
- 细粒度权限管理
- 动态权限检查
## 📊 监控和日志
### 结构化日志
```python
from neo_core.logging import get_logger
logger = get_logger(__name__)
logger.info("User logged in", user_id=123, ip="192.168.1.1")
```
### 性能监控
```python
from neo_core.monitoring import track_performance
@track_performance
async def slow_operation():
# 自动记录执行时间
pass
```
## 🧪 测试
```bash
# 运行所有测试
pytest
# 运行特定测试
pytest tests/test_auth.py
# 生成覆盖率报告
pytest --cov=neo_core --cov-report=html
```
## 📖 文档
- [API文档](https://neo-core-fastapi.readthedocs.io/)
- [用户指南](docs/user-guide.md)
- [开发指南](docs/development.md)
- [迁移指南](docs/migration.md)
## 🤝 贡献
我们欢迎所有形式的贡献!请查看 [贡献指南](CONTRIBUTING.md) 了解如何参与项目开发。
### 开发环境设置
```bash
# 克隆项目
git clone https://github.com/neo-core/neo-core-fastapi.git
cd neo-core-fastapi
# 安装开发依赖
pip install -e ".[dev]"
# 安装pre-commit钩子
pre-commit install
# 运行测试
pytest
```
## 📄 许可证
MIT License - 详见 [LICENSE](LICENSE) 文件
## 🔗 相关项目
- [FastAPI Dynamic Loader](https://github.com/your-org/fastapi-dynamic-loader) - 使用本库的动态模块加载系统
- [Neo Core CLI](https://github.com/neo-core/neo-core-cli) - 命令行工具
## 📞 支持
如果您遇到问题或有疑问:
1. 查看 [文档](https://neo-core-fastapi.readthedocs.io/)
2. 搜索 [已知问题](https://github.com/neo-core/neo-core-fastapi/issues)
3. 创建新的 [Issue](https://github.com/neo-core/neo-core-fastapi/issues/new)
4. 加入 [讨论](https://github.com/neo-core/neo-core-fastapi/discussions)
---
⭐ 如果这个项目对您有帮助,请给我们一个星标!
Raw data
{
"_id": null,
"home_page": "https://github.com/neo-core/neo-core-fastapi",
"name": "neo-core-fastapi",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": "Neo Core Team <dev@neo-core.com>",
"keywords": "fastapi, core, models, services, utilities, database",
"author": "Neo Core Team",
"author_email": "Neo Core Team <dev@neo-core.com>",
"download_url": "https://files.pythonhosted.org/packages/d1/00/ca2acc4ea165d12c5709fcfd1f712be9ffcaa197f14d5c54dfaf4067f003/neo_core_fastapi-0.1.0.tar.gz",
"platform": null,
"description": "# Neo Core FastAPI\r\n\r\nA comprehensive FastAPI-based core library providing essential services for modern web applications.\r\n\r\n## \ud83d\ude80 \u7279\u6027\r\n\r\n### \u6838\u5fc3\u6a21\u578b\r\n- **\u7528\u6237\u7ba1\u7406**: \u7528\u6237\u6a21\u578b\u3001\u8ba4\u8bc1\u3001\u6743\u9650\u63a7\u5236\r\n- **\u89d2\u8272\u6743\u9650**: RBAC\u6743\u9650\u6a21\u578b\uff0c\u652f\u6301\u7ec6\u7c92\u5ea6\u6743\u9650\u63a7\u5236\r\n- **\u5e94\u7528\u7ba1\u7406**: \u591a\u5e94\u7528\u652f\u6301\uff0c\u5e94\u7528\u914d\u7f6e\u7ba1\u7406\r\n- **\u5ba1\u8ba1\u65e5\u5fd7**: \u5b8c\u6574\u7684\u64cd\u4f5c\u5ba1\u8ba1\u548c\u65e5\u5fd7\u8bb0\u5f55\r\n\r\n### \u6570\u636e\u5e93\u7ba1\u7406\r\n- **SQLAlchemy 2.0**: \u73b0\u4ee3\u5316\u7684ORM\u652f\u6301\r\n- **Alembic\u8fc1\u79fb**: \u6570\u636e\u5e93\u7248\u672c\u7ba1\u7406\r\n- **\u8fde\u63a5\u6c60**: \u9ad8\u6027\u80fd\u6570\u636e\u5e93\u8fde\u63a5\u7ba1\u7406\r\n- **\u591a\u6570\u636e\u5e93**: \u652f\u6301PostgreSQL\u3001MySQL\u3001SQLite\r\n\r\n### \u670d\u52a1\u5c42\r\n- **\u57fa\u7840\u670d\u52a1**: \u901a\u7528CRUD\u64cd\u4f5c\u5c01\u88c5\r\n- **\u8ba4\u8bc1\u670d\u52a1**: JWT\u4ee4\u724c\u7ba1\u7406\u3001\u5bc6\u7801\u52a0\u5bc6\r\n- **\u6743\u9650\u670d\u52a1**: \u6743\u9650\u68c0\u67e5\u3001\u89d2\u8272\u7ba1\u7406\r\n- **\u7f13\u5b58\u670d\u52a1**: Redis\u7f13\u5b58\u96c6\u6210\r\n\r\n### \u4e2d\u95f4\u4ef6\r\n- **\u8ba4\u8bc1\u4e2d\u95f4\u4ef6**: \u81ea\u52a8\u7528\u6237\u8ba4\u8bc1\r\n- **\u6743\u9650\u4e2d\u95f4\u4ef6**: \u8def\u7531\u7ea7\u6743\u9650\u63a7\u5236\r\n- **\u65e5\u5fd7\u4e2d\u95f4\u4ef6**: \u8bf7\u6c42\u54cd\u5e94\u65e5\u5fd7\u8bb0\u5f55\r\n- **CORS\u4e2d\u95f4\u4ef6**: \u8de8\u57df\u8bf7\u6c42\u5904\u7406\r\n\r\n### \u5de5\u5177\u5e93\r\n- **\u5bc6\u7801\u5de5\u5177**: \u5bc6\u7801\u52a0\u5bc6\u3001\u9a8c\u8bc1\r\n- **JWT\u5de5\u5177**: \u4ee4\u724c\u751f\u6210\u3001\u9a8c\u8bc1\u3001\u5237\u65b0\r\n- **\u9a8c\u8bc1\u5de5\u5177**: \u6570\u636e\u9a8c\u8bc1\u3001\u683c\u5f0f\u5316\r\n- **\u65f6\u95f4\u5de5\u5177**: \u65f6\u533a\u5904\u7406\u3001\u683c\u5f0f\u8f6c\u6362\r\n\r\n## \ud83d\udce6 \u5b89\u88c5\r\n\r\n```bash\r\n# \u57fa\u7840\u5b89\u88c5\r\npip install neo-core-fastapi\r\n\r\n# \u5f00\u53d1\u73af\u5883\u5b89\u88c5\r\npip install neo-core-fastapi[dev]\r\n\r\n# \u6d4b\u8bd5\u73af\u5883\u5b89\u88c5\r\npip install neo-core-fastapi[testing]\r\n\r\n# \u6587\u6863\u73af\u5883\u5b89\u88c5\r\npip install neo-core-fastapi[docs]\r\n```\r\n\r\n## \ud83d\udd27 \u5feb\u901f\u5f00\u59cb\r\n\r\n### 1. \u57fa\u7840\u914d\u7f6e\r\n\r\n```python\r\nfrom neo_core.config import CoreSettings\r\nfrom neo_core.database import DatabaseManager\r\nfrom neo_core.auth import AuthManager\r\n\r\n# \u914d\u7f6e\u8bbe\u7f6e\r\nsettings = CoreSettings(\r\n database_url=\"postgresql://user:pass@localhost/dbname\",\r\n redis_url=\"redis://localhost:6379\",\r\n secret_key=\"your-secret-key\"\r\n)\r\n\r\n# \u521d\u59cb\u5316\u6570\u636e\u5e93\r\ndb_manager = DatabaseManager(settings)\r\nawait db_manager.initialize()\r\n\r\n# \u521d\u59cb\u5316\u8ba4\u8bc1\r\nauth_manager = AuthManager(settings)\r\n```\r\n\r\n### 2. \u4f7f\u7528\u6838\u5fc3\u6a21\u578b\r\n\r\n```python\r\nfrom neo_core.models import User, Role, Permission\r\nfrom neo_core.services import UserService, RoleService\r\n\r\n# \u521b\u5efa\u7528\u6237\u670d\u52a1\r\nuser_service = UserService(db_session)\r\n\r\n# \u521b\u5efa\u7528\u6237\r\nuser = await user_service.create_user(\r\n username=\"admin\",\r\n email=\"admin@example.com\",\r\n password=\"secure_password\"\r\n)\r\n\r\n# \u5206\u914d\u89d2\u8272\r\nrole = await RoleService(db_session).get_role_by_name(\"admin\")\r\nawait user_service.assign_role(user.id, role.id)\r\n```\r\n\r\n### 3. \u4f7f\u7528\u8ba4\u8bc1\u4e2d\u95f4\u4ef6\r\n\r\n```python\r\nfrom fastapi import FastAPI, Depends\r\nfrom neo_core.middleware import AuthMiddleware\r\nfrom neo_core.dependencies import get_current_user\r\nfrom neo_core.models import User\r\n\r\napp = FastAPI()\r\n\r\n# \u6dfb\u52a0\u8ba4\u8bc1\u4e2d\u95f4\u4ef6\r\napp.add_middleware(AuthMiddleware)\r\n\r\n@app.get(\"/protected\")\r\nasync def protected_route(current_user: User = Depends(get_current_user)):\r\n return {\"message\": f\"Hello, {current_user.username}!\"}\r\n```\r\n\r\n### 4. \u4f7f\u7528\u6743\u9650\u63a7\u5236\r\n\r\n```python\r\nfrom neo_core.dependencies import require_permission\r\nfrom neo_core.models import User\r\n\r\n@app.get(\"/admin-only\")\r\nasync def admin_only(\r\n current_user: User = Depends(require_permission(\"admin.read\"))\r\n):\r\n return {\"message\": \"Admin access granted\"}\r\n```\r\n\r\n## \ud83d\udcda \u6838\u5fc3\u7ec4\u4ef6\r\n\r\n### \u6a21\u578b\u5c42 (Models)\r\n\r\n```python\r\n# \u7528\u6237\u6a21\u578b\r\nfrom neo_core.models import User, Role, Permission, Application\r\n\r\n# \u7528\u6237\u7ba1\u7406\r\nuser = User(\r\n username=\"john_doe\",\r\n email=\"john@example.com\",\r\n is_active=True\r\n)\r\n\r\n# \u89d2\u8272\u6743\u9650\r\nrole = Role(name=\"editor\", description=\"Content Editor\")\r\npermission = Permission(name=\"content.edit\", description=\"Edit Content\")\r\n```\r\n\r\n### \u670d\u52a1\u5c42 (Services)\r\n\r\n```python\r\n# \u57fa\u7840\u670d\u52a1\r\nfrom neo_core.services import BaseService, UserService, RoleService\r\n\r\n# \u81ea\u5b9a\u4e49\u670d\u52a1\r\nclass CustomService(BaseService[CustomModel]):\r\n async def custom_method(self, param: str) -> CustomModel:\r\n # \u81ea\u5b9a\u4e49\u4e1a\u52a1\u903b\u8f91\r\n return await self.create({\"field\": param})\r\n```\r\n\r\n### \u5de5\u5177\u5e93 (Utils)\r\n\r\n```python\r\n# \u5bc6\u7801\u5de5\u5177\r\nfrom neo_core.utils.password import hash_password, verify_password\r\n\r\nhashed = hash_password(\"my_password\")\r\nis_valid = verify_password(\"my_password\", hashed)\r\n\r\n# JWT\u5de5\u5177\r\nfrom neo_core.utils.jwt import create_access_token, decode_token\r\n\r\ntoken = create_access_token(data={\"sub\": \"user_id\"})\r\npayload = decode_token(token)\r\n\r\n# \u9a8c\u8bc1\u5de5\u5177\r\nfrom neo_core.utils.validators import validate_email, validate_phone\r\n\r\nis_valid_email = validate_email(\"test@example.com\")\r\nis_valid_phone = validate_phone(\"+1234567890\")\r\n```\r\n\r\n## \ud83d\uddc4\ufe0f \u6570\u636e\u5e93\u7ba1\u7406\r\n\r\n### \u8fc1\u79fb\u7ba1\u7406\r\n\r\n```bash\r\n# \u521b\u5efa\u8fc1\u79fb\r\nalembic revision --autogenerate -m \"Add new table\"\r\n\r\n# \u5e94\u7528\u8fc1\u79fb\r\nalembic upgrade head\r\n\r\n# \u56de\u6eda\u8fc1\u79fb\r\nalembic downgrade -1\r\n```\r\n\r\n### \u6570\u636e\u5e93\u521d\u59cb\u5316\r\n\r\n```python\r\nfrom neo_core.database import init_database, create_default_data\r\n\r\n# \u521d\u59cb\u5316\u6570\u636e\u5e93\u7ed3\u6784\r\nawait init_database()\r\n\r\n# \u521b\u5efa\u9ed8\u8ba4\u6570\u636e\r\nawait create_default_data()\r\n```\r\n\r\n## \ud83d\udd10 \u5b89\u5168\u7279\u6027\r\n\r\n### \u5bc6\u7801\u5b89\u5168\r\n- bcrypt\u52a0\u5bc6\u7b97\u6cd5\r\n- \u5bc6\u7801\u5f3a\u5ea6\u9a8c\u8bc1\r\n- \u5bc6\u7801\u5386\u53f2\u8bb0\u5f55\r\n\r\n### JWT\u8ba4\u8bc1\r\n- \u8bbf\u95ee\u4ee4\u724c\u548c\u5237\u65b0\u4ee4\u724c\r\n- \u4ee4\u724c\u9ed1\u540d\u5355\u673a\u5236\r\n- \u81ea\u52a8\u4ee4\u724c\u5237\u65b0\r\n\r\n### \u6743\u9650\u63a7\u5236\r\n- \u57fa\u4e8e\u89d2\u8272\u7684\u8bbf\u95ee\u63a7\u5236(RBAC)\r\n- \u7ec6\u7c92\u5ea6\u6743\u9650\u7ba1\u7406\r\n- \u52a8\u6001\u6743\u9650\u68c0\u67e5\r\n\r\n## \ud83d\udcca \u76d1\u63a7\u548c\u65e5\u5fd7\r\n\r\n### \u7ed3\u6784\u5316\u65e5\u5fd7\r\n\r\n```python\r\nfrom neo_core.logging import get_logger\r\n\r\nlogger = get_logger(__name__)\r\nlogger.info(\"User logged in\", user_id=123, ip=\"192.168.1.1\")\r\n```\r\n\r\n### \u6027\u80fd\u76d1\u63a7\r\n\r\n```python\r\nfrom neo_core.monitoring import track_performance\r\n\r\n@track_performance\r\nasync def slow_operation():\r\n # \u81ea\u52a8\u8bb0\u5f55\u6267\u884c\u65f6\u95f4\r\n pass\r\n```\r\n\r\n## \ud83e\uddea \u6d4b\u8bd5\r\n\r\n```bash\r\n# \u8fd0\u884c\u6240\u6709\u6d4b\u8bd5\r\npytest\r\n\r\n# \u8fd0\u884c\u7279\u5b9a\u6d4b\u8bd5\r\npytest tests/test_auth.py\r\n\r\n# \u751f\u6210\u8986\u76d6\u7387\u62a5\u544a\r\npytest --cov=neo_core --cov-report=html\r\n```\r\n\r\n## \ud83d\udcd6 \u6587\u6863\r\n\r\n- [API\u6587\u6863](https://neo-core-fastapi.readthedocs.io/)\r\n- [\u7528\u6237\u6307\u5357](docs/user-guide.md)\r\n- [\u5f00\u53d1\u6307\u5357](docs/development.md)\r\n- [\u8fc1\u79fb\u6307\u5357](docs/migration.md)\r\n\r\n## \ud83e\udd1d \u8d21\u732e\r\n\r\n\u6211\u4eec\u6b22\u8fce\u6240\u6709\u5f62\u5f0f\u7684\u8d21\u732e\uff01\u8bf7\u67e5\u770b [\u8d21\u732e\u6307\u5357](CONTRIBUTING.md) \u4e86\u89e3\u5982\u4f55\u53c2\u4e0e\u9879\u76ee\u5f00\u53d1\u3002\r\n\r\n### \u5f00\u53d1\u73af\u5883\u8bbe\u7f6e\r\n\r\n```bash\r\n# \u514b\u9686\u9879\u76ee\r\ngit clone https://github.com/neo-core/neo-core-fastapi.git\r\ncd neo-core-fastapi\r\n\r\n# \u5b89\u88c5\u5f00\u53d1\u4f9d\u8d56\r\npip install -e \".[dev]\"\r\n\r\n# \u5b89\u88c5pre-commit\u94a9\u5b50\r\npre-commit install\r\n\r\n# \u8fd0\u884c\u6d4b\u8bd5\r\npytest\r\n```\r\n\r\n## \ud83d\udcc4 \u8bb8\u53ef\u8bc1\r\n\r\nMIT License - \u8be6\u89c1 [LICENSE](LICENSE) \u6587\u4ef6\r\n\r\n## \ud83d\udd17 \u76f8\u5173\u9879\u76ee\r\n\r\n- [FastAPI Dynamic Loader](https://github.com/your-org/fastapi-dynamic-loader) - \u4f7f\u7528\u672c\u5e93\u7684\u52a8\u6001\u6a21\u5757\u52a0\u8f7d\u7cfb\u7edf\r\n- [Neo Core CLI](https://github.com/neo-core/neo-core-cli) - \u547d\u4ee4\u884c\u5de5\u5177\r\n\r\n## \ud83d\udcde \u652f\u6301\r\n\r\n\u5982\u679c\u60a8\u9047\u5230\u95ee\u9898\u6216\u6709\u7591\u95ee\uff1a\r\n\r\n1. \u67e5\u770b [\u6587\u6863](https://neo-core-fastapi.readthedocs.io/)\r\n2. \u641c\u7d22 [\u5df2\u77e5\u95ee\u9898](https://github.com/neo-core/neo-core-fastapi/issues)\r\n3. \u521b\u5efa\u65b0\u7684 [Issue](https://github.com/neo-core/neo-core-fastapi/issues/new)\r\n4. \u52a0\u5165 [\u8ba8\u8bba](https://github.com/neo-core/neo-core-fastapi/discussions)\r\n\r\n---\r\n\r\n\u2b50 \u5982\u679c\u8fd9\u4e2a\u9879\u76ee\u5bf9\u60a8\u6709\u5e2e\u52a9\uff0c\u8bf7\u7ed9\u6211\u4eec\u4e00\u4e2a\u661f\u6807\uff01\r\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Core library for FastAPI dynamic module loader with shared models, services, and utilities",
"version": "0.1.0",
"project_urls": {
"Bug Tracker": "https://github.com/neo-core/neo-core-fastapi/issues",
"Changelog": "https://github.com/neo-core/neo-core-fastapi/blob/main/CHANGELOG.md",
"Documentation": "https://neo-core-fastapi.readthedocs.io/",
"Homepage": "https://github.com/neo-core/neo-core-fastapi",
"Repository": "https://github.com/neo-core/neo-core-fastapi.git"
},
"split_keywords": [
"fastapi",
" core",
" models",
" services",
" utilities",
" database"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "91453622501a6a5068d01a4161d30ba755c30357b7f7ef6ad101b846975aa99e",
"md5": "4478dbbeb8ef133bfb0718bd72e65a63",
"sha256": "acb11adf5ff7cfd2ad0ea3e5428cbd93796febbdd7ea267fdf2201044bdc375c"
},
"downloads": -1,
"filename": "neo_core_fastapi-0.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "4478dbbeb8ef133bfb0718bd72e65a63",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 112218,
"upload_time": "2025-08-14T03:28:40",
"upload_time_iso_8601": "2025-08-14T03:28:40.146356Z",
"url": "https://files.pythonhosted.org/packages/91/45/3622501a6a5068d01a4161d30ba755c30357b7f7ef6ad101b846975aa99e/neo_core_fastapi-0.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "d100ca2acc4ea165d12c5709fcfd1f712be9ffcaa197f14d5c54dfaf4067f003",
"md5": "46f504a41efe6e9bde3384e6d888c6ca",
"sha256": "ebdbed04effb49a2f912e076e5ce71ef73223ba96f87560b54fd8fa2f4a8c679"
},
"downloads": -1,
"filename": "neo_core_fastapi-0.1.0.tar.gz",
"has_sig": false,
"md5_digest": "46f504a41efe6e9bde3384e6d888c6ca",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 115232,
"upload_time": "2025-08-14T03:28:41",
"upload_time_iso_8601": "2025-08-14T03:28:41.546743Z",
"url": "https://files.pythonhosted.org/packages/d1/00/ca2acc4ea165d12c5709fcfd1f712be9ffcaa197f14d5c54dfaf4067f003/neo_core_fastapi-0.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-08-14 03:28:41",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "neo-core",
"github_project": "neo-core-fastapi",
"github_not_found": true,
"lcname": "neo-core-fastapi"
}