186 lines
7.6 KiB
Python
186 lines
7.6 KiB
Python
# -*- coding:utf-8 -*-
|
||
# @name: db
|
||
# @auth: rainy-autumn@outlook.com
|
||
# @version:
|
||
from motor.motor_asyncio import AsyncIOMotorClient, AsyncIOMotorCursor
|
||
from core.default import *
|
||
from core.config import *
|
||
from core.util import string_to_postfix
|
||
from loguru import logger
|
||
|
||
|
||
async def get_mongo_db():
|
||
client = AsyncIOMotorClient(f"mongodb://{DATABASE_USER}:{DATABASE_PASSWORD}@{MONGODB_IP}:{str(MONGODB_PORT)}",
|
||
serverSelectionTimeoutMS=10000, unicode_decode_error_handler='ignore')
|
||
db = client[DATABASE_NAME]
|
||
try:
|
||
yield db
|
||
finally:
|
||
client.close()
|
||
|
||
|
||
async def create_database():
|
||
client = None
|
||
try:
|
||
# 创建新的 MongoDB 客户端
|
||
client = AsyncIOMotorClient(f"mongodb://{DATABASE_USER}:{DATABASE_PASSWORD}@{MONGODB_IP}:{str(MONGODB_PORT)}",
|
||
serverSelectionTimeoutMS=2000)
|
||
|
||
# 获取数据库列表
|
||
database_names = await client.list_database_names()
|
||
|
||
# 如果数据库不存在,创建数据库
|
||
if DATABASE_NAME not in database_names:
|
||
# 在数据库中创建一个集合,比如名为 "user"
|
||
collection = client[DATABASE_NAME]["user"]
|
||
|
||
# 用户数据
|
||
await collection.insert_one({"username": "ScopeSentry",
|
||
'password': 'b0ce71fcbed8a6ca579d52800145119cc7d999dc8651b62dfc1ced9a984e6e64'})
|
||
|
||
collection = client[DATABASE_NAME]["config"]
|
||
# 系统配置
|
||
await collection.insert_one(
|
||
{"name": "timezone", 'value': 'Asia/Shanghai', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "MaxTaskNum", 'value': '7', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "DirscanThread", 'value': '15', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "PortscanThread", 'value': '15', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "CrawlerThread", 'value': '2', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "UrlMaxNum", 'value': '500', 'type': 'system'})
|
||
await collection.insert_one(
|
||
{"name": "UrlThread", 'value': '5', 'type': 'system'})
|
||
# 设置时区为Asia/Shanghai
|
||
# SHA_TZ = timezone(TIMEZONE)
|
||
# timezone('Asia/Shanghai')
|
||
# utc_now = datetime.utcnow().replace(tzinfo=timezone.utc)
|
||
# time_now = utc_now.astimezone(SHA_TZ)
|
||
# formatted_time = time_now.strftime("%Y-%m-%d %H:%M:%S")
|
||
# subfinder配置
|
||
collection = client[DATABASE_NAME]["config"]
|
||
# 插入一条数据
|
||
await collection.insert_one(
|
||
{"name": "SubfinderApiConfig", 'value': subfinderApiConfig, 'type': 'subfinder'})
|
||
await collection.insert_one(
|
||
{"name": "RadConfig", 'value': radConfig, 'type': 'rad'})
|
||
dirDict = get_dirDict()
|
||
await collection.insert_one(
|
||
{"name": "DirDic", 'value': dirDict, 'type': 'dirDict'})
|
||
await collection.insert_one(
|
||
{"name": "notification", 'dirScanNotification': True,
|
||
'portScanNotification': True, 'sensitiveNotification': True,
|
||
'subdomainTakeoverNotification': True,
|
||
'pageMonNotification': True,
|
||
'subdomainNotification': True,
|
||
'vulNotification': True,
|
||
'type': 'notification'})
|
||
domainDict = get_domainDict()
|
||
await collection.insert_one(
|
||
{"name": "DomainDic", 'value': domainDict, 'type': 'domainDict'})
|
||
sensitive_data = get_sensitive()
|
||
collection = client[DATABASE_NAME]["SensitiveRule"]
|
||
if sensitiveList:
|
||
await collection.insert_many(sensitive_data)
|
||
|
||
collection = client[DATABASE_NAME]["ScheduledTasks"]
|
||
await collection.insert_one(
|
||
{"id": "page_monitoring", "name": "Page Monitoring", 'hour': 24, 'node': [], 'allNode': True, 'type': 'Page Monitoring', 'state': True})
|
||
|
||
collection = client[DATABASE_NAME]
|
||
await collection.create_collection("notification")
|
||
|
||
collection = client[DATABASE_NAME]["PortDict"]
|
||
await collection.insert_many(portDic)
|
||
|
||
collection = client[DATABASE_NAME]["PocList"]
|
||
pocData = get_poc()
|
||
await collection.insert_many(pocData)
|
||
|
||
collection = client[DATABASE_NAME]["project"]
|
||
project_data, target_data = get_project_data()
|
||
await collection.insert_many(project_data)
|
||
|
||
collection = client[DATABASE_NAME]["ProjectTargetData"]
|
||
await collection.insert_many(target_data)
|
||
|
||
collection = client[DATABASE_NAME]["FingerprintRules"]
|
||
fingerprint_rules = get_fingerprint_data()
|
||
for rule in fingerprint_rules:
|
||
express = string_to_postfix(rule['rule'])
|
||
if express == "":
|
||
continue
|
||
default_rule = {
|
||
'name': rule['product'],
|
||
'rule': rule['rule'],
|
||
'express': express,
|
||
'category': rule['category'],
|
||
'parent_category': rule['parent_category'],
|
||
'company': rule['company'],
|
||
'amount': 0,
|
||
'state': True
|
||
}
|
||
await collection.insert_one(default_rule)
|
||
else:
|
||
collection = client[DATABASE_NAME]["config"]
|
||
result = await collection.find_one({"name": "timezone"})
|
||
set_timezone(result.get('value', 'Asia/Shanghai'))
|
||
|
||
collection = client[DATABASE_NAME]["ScheduledTasks"]
|
||
result = await collection.find_one({"id": "page_monitoring"})
|
||
if not result:
|
||
await collection.insert_one(
|
||
{"id": "page_monitoring", "name": "Page Monitoring", 'hour': 24, 'type': 'Page Monitoring', 'state': True})
|
||
await get_fingerprint(client[DATABASE_NAME])
|
||
await get_sens_rule(client[DATABASE_NAME])
|
||
await get_pocList(client[DATABASE_NAME])
|
||
await get_project(client[DATABASE_NAME])
|
||
except Exception as e:
|
||
# 处理异常
|
||
logger.error(f"Error creating database: {e}")
|
||
exit(0)
|
||
finally:
|
||
# 在适当的地方关闭 MongoDB 客户端
|
||
if client:
|
||
client.close()
|
||
|
||
|
||
async def get_fingerprint(client):
|
||
collection = client["FingerprintRules"]
|
||
cursor = collection.find({}, {"_id": 1, "name": 1})
|
||
async for document in cursor:
|
||
document['id'] = str(document['_id'])
|
||
del document['_id']
|
||
APP[document['id']] = document['name']
|
||
|
||
|
||
async def get_sens_rule(client):
|
||
collection = client["SensitiveRule"]
|
||
cursor = collection.find({}, {"_id": 1, "name": 1, "color": 1})
|
||
async for document in cursor:
|
||
document['id'] = str(document['_id'])
|
||
del document['_id']
|
||
SensitiveRuleList[document['id']] = {
|
||
"name": document['name'],
|
||
"color": document['color']
|
||
}
|
||
|
||
|
||
async def get_pocList(client):
|
||
collection = client["PocList"]
|
||
cursor = collection.find({}, {"_id": 1, "level": 1})
|
||
async for document in cursor:
|
||
document['id'] = str(document['_id'])
|
||
POC_LIST[document['id']] = document['level']
|
||
|
||
|
||
async def get_project(client):
|
||
collection = client["project"]
|
||
cursor = collection.find({}, {"_id": 1, "name": 1})
|
||
async for document in cursor:
|
||
document['id'] = str(document['_id'])
|
||
Project_List[document['name'].lower()] = document['id']
|