neo-core-fastapi


Nameneo-core-fastapi JSON
Version 0.1.0 PyPI version JSON
download
home_pagehttps://github.com/neo-core/neo-core-fastapi
SummaryCore library for FastAPI dynamic module loader with shared models, services, and utilities
upload_time2025-08-14 03:28:41
maintainerNone
docs_urlNone
authorNeo Core Team
requires_python>=3.8
licenseMIT
keywords fastapi core models services utilities database
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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"
}
        
Elapsed time: 1.61014s