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']
|