initial commit
This commit is contained in:
commit
3b3c9a9417
258 changed files with 20086 additions and 0 deletions
12
services/myblog/api_server/app/__init__.py
Normal file
12
services/myblog/api_server/app/__init__.py
Normal file
|
|
@ -0,0 +1,12 @@
|
|||
from quart import Quart
|
||||
from flask_sqlalchemy import SQLAlchemy
|
||||
import os, re
|
||||
from quart_cors import cors, route_cors
|
||||
|
||||
app = Quart(__name__)
|
||||
app = cors(app, allow_origin=re.compile(r"http:\/\/.*:3000"), allow_credentials=True)#cors(app, allow_origin="http://10.50.20.4:3000", allow_credentials=True)
|
||||
app.config["REDIRECT_SERVER"] = os.getenv('REDIRECT_SERVER') or "127.0.0.1:8080"#"10.50.20.7:8080"
|
||||
app.config["CONTENT_SERVER"] = os.getenv('CONTENT_SERVER') or "127.0.0.1:13379"#"10.50.20.6:13379"
|
||||
app.config["SQLALCHEMY_DATABASE_URI"] = os.getenv('SQLALCHEMY_DATABASE_URI') or 'sqlite:///data.db'
|
||||
app.config["SECRET_KEY"] = 'hack_me'
|
||||
db = SQLAlchemy(app)
|
||||
45
services/myblog/api_server/app/models.py
Normal file
45
services/myblog/api_server/app/models.py
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
from werkzeug.security import generate_password_hash, check_password_hash
|
||||
from nanoid import generate
|
||||
from . import db
|
||||
|
||||
class User(db.Model):
|
||||
def __init__(self, username, blog_url):
|
||||
self.username = username
|
||||
self.blog_url = blog_url
|
||||
__tablename__ = 'users'
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
username = db.Column(db.Text, unique=True)
|
||||
password = db.Column(db.Text)
|
||||
blog_url = db.Column(db.Text, db.ForeignKey('blogs.url', ondelete='CASCADE'), unique=True)
|
||||
blog = db.relationship('Blog', backref='blog_user', cascade="all,delete")
|
||||
def set_password(self, password):
|
||||
self.password = generate_password_hash(password)
|
||||
|
||||
def check_password(self, password):
|
||||
return check_password_hash(self.password, password)
|
||||
|
||||
class Blog(db.Model):
|
||||
def __init__(self, url, is_private=False):
|
||||
self.url = url
|
||||
self.is_private = is_private
|
||||
__tablename__ = "blogs"
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
url = db.Column(db.Text, unique=True)
|
||||
is_private = db.Column(db.Boolean, default=False) #TODO this is must be private (VULN)
|
||||
user = db.relationship('User', backref='blog_user', cascade="all,delete", lazy='dynamic')
|
||||
posts = db.relationship("Post", cascade="all,delete")
|
||||
|
||||
|
||||
#TODO дописать стуруктуру БД
|
||||
|
||||
class Post(db.Model):
|
||||
def __init__(self, title, body, blog_url):
|
||||
self.title = title
|
||||
self.body = body
|
||||
self.blog_url = blog_url
|
||||
__tablename__ = "posts"
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
title = db.Column(db.String)
|
||||
body = db.Column(db.String)
|
||||
blog_url = db.Column(db.String, db.ForeignKey("blogs.url"))
|
||||
blog = db.relationship("Blog", cascade="all,delete")
|
||||
Loading…
Add table
Add a link
Reference in a new issue