PhotosAPI/modules/database.py

37 lines
1.1 KiB
Python
Raw Normal View History

2022-12-20 02:22:32 +02:00
from modules.utils import configGet
2023-01-02 16:08:46 +02:00
from pymongo import MongoClient, GEOSPHERE
2022-12-20 02:22:32 +02:00
db_config = configGet("database")
if db_config["user"] is not None and db_config["password"] is not None:
2023-03-12 15:59:13 +02:00
con_string = "mongodb://{0}:{1}@{2}:{3}/{4}".format(
2022-12-20 02:22:32 +02:00
db_config["user"],
db_config["password"],
db_config["host"],
db_config["port"],
2023-03-12 15:59:13 +02:00
db_config["name"],
2022-12-20 02:22:32 +02:00
)
else:
2023-03-12 15:59:13 +02:00
con_string = "mongodb://{0}:{1}/{2}".format(
db_config["host"], db_config["port"], db_config["name"]
2022-12-20 02:22:32 +02:00
)
db_client = MongoClient(con_string)
db = db_client.get_database(name=db_config["name"])
collections = db.list_collection_names()
2023-01-07 22:48:43 +02:00
for collection in ["users", "albums", "photos", "videos", "tokens", "emails"]:
2022-12-20 02:22:32 +02:00
if not collection in collections:
db.create_collection(collection)
2022-12-20 12:37:42 +02:00
col_users = db.get_collection("users")
2022-12-20 02:22:32 +02:00
col_albums = db.get_collection("albums")
col_photos = db.get_collection("photos")
2022-12-21 00:59:35 +02:00
col_videos = db.get_collection("videos")
2023-01-02 16:08:46 +02:00
col_tokens = db.get_collection("tokens")
2023-01-07 22:48:43 +02:00
col_emails = db.get_collection("emails")
2023-01-02 16:08:46 +02:00
2023-03-12 15:59:13 +02:00
col_photos.create_index([("location", GEOSPHERE)])