Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
elp
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Incidents
Environments
Packages & Registries
Packages & Registries
Package Registry
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
崔为之
elp
Commits
4349e634
Commit
4349e634
authored
Nov 11, 2023
by
崔为之
💪🏽
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update project
parent
9bdb96fb
Changes
16
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
94 additions
and
110 deletions
+94
-110
application/__init__.py
application/__init__.py
+3
-17
application/common/__init__.py
application/common/__init__.py
+1
-3
application/common/config.py
application/common/config.py
+8
-36
application/extensions/__init__.py
application/extensions/__init__.py
+0
-2
application/extensions/init_celery.py
application/extensions/init_celery.py
+0
-28
application/extensions/init_sqlalchemy.py
application/extensions/init_sqlalchemy.py
+3
-0
application/libs/flask_elasticsearch/elasticsearch.py
application/libs/flask_elasticsearch/elasticsearch.py
+1
-1
application/libs/flask_loguru/logger.py
application/libs/flask_loguru/logger.py
+1
-1
application/libs/helper/__init__.py
application/libs/helper/__init__.py
+15
-0
application/libs/helper/config.py
application/libs/helper/config.py
+50
-0
application/libs/helper/env.py
application/libs/helper/env.py
+0
-0
application/libs/helper/file.py
application/libs/helper/file.py
+0
-0
application/libs/tasks/task.py
application/libs/tasks/task.py
+0
-10
application/utils/loaders/consul_loader.py
application/utils/loaders/consul_loader.py
+1
-1
application/utils/loaders/yaml_loader.py
application/utils/loaders/yaml_loader.py
+1
-1
application/views/user/user.py
application/views/user/user.py
+10
-10
No files found.
application/__init__.py
View file @
4349e634
...
@@ -18,7 +18,7 @@ from application.extensions import init_plugs
...
@@ -18,7 +18,7 @@ from application.extensions import init_plugs
from
application.views
import
init_views
from
application.views
import
init_views
from
application.script
import
init_script
from
application.script
import
init_script
from
application.utils
import
make_celery
from
application.utils
import
make_celery
from
celery.schedules
import
crontab
from
application.common
import
config
def
create_app
()
->
Flask
:
def
create_app
()
->
Flask
:
...
@@ -38,22 +38,8 @@ def create_app() -> Flask:
...
@@ -38,22 +38,8 @@ def create_app() -> Flask:
# This could include things like database connectors, authentication systems, etc.
# This could include things like database connectors, authentication systems, etc.
init_plugs
(
app
)
init_plugs
(
app
)
celery
=
make_celery
(
app
)
# Set universal config
celery
.
conf
.
update
(
app
.
config
)
config
.
Universal
=
app
.
config
@
celery
.
task
(
bind
=
True
)
def
update_database
(
self
):
# Add your database operations here
print
(
"update database"
)
celery
.
conf
.
beat_schedule
=
{
'update-database-every-minute'
:
{
'task'
:
'application.__init__.update_database'
,
'schedule'
:
crontab
(
minute
=
'*'
)
# Execute every minute
}
}
app
.
celery
=
celery
# Register the routes that this application will respond to.
# Register the routes that this application will respond to.
# This includes both the route URLs and the handlers for each route.
# This includes both the route URLs and the handlers for each route.
...
...
application/common/__init__.py
View file @
4349e634
...
@@ -10,6 +10,4 @@
...
@@ -10,6 +10,4 @@
# @Description :
# @Description :
"""
"""
from
.config
import
ConfigHelper
from
.config
import
Config
from
.env
import
EnvVarHelper
from
.file
import
FileHelper
application/common/config.py
View file @
4349e634
...
@@ -5,46 +5,18 @@
...
@@ -5,46 +5,18 @@
# @Software : Sublime Text 4
# @Software : Sublime Text 4
# @Author : StudentCWZ
# @Author : StudentCWZ
# @Email : StudentCWZ@outlook.com
# @Email : StudentCWZ@outlook.com
# @Date : 2023/11/
3 19:43
# @Date : 2023/11/
11 14:11
# @File : config.py
# @File : config.py
# @Description :
# @Description :
"""
"""
from
typing
import
Any
# config.py
class
Config
:
"""Configuration for the application."""
def
__init__
(
self
):
self
.
Universal
=
None
from
flask
import
Flask
from
loguru
import
logger
from
application.libs
import
ConfigKeyError
# This creates a global instance of the Config class
config
=
Config
()
class
ConfigHelper
:
"""
The ConfigHelper class is a utility for fetching configuration values
from a Flask application.
:param app: The Flask application instance from which to fetch configuration values.
"""
def
__init__
(
self
,
app
:
Flask
):
self
.
app
=
app
def
__getattr__
(
self
,
name
:
str
)
->
Any
:
"""
Get a config value as an attribute.
:param name: The name of the config key.
:return: The value for the provided key, or None if it does not exist.
"""
try
:
return
self
.
app
.
config
[
name
]
except
KeyError
:
logger
.
error
(
f
'Key
{
name
}
not found in configuration'
)
raise
ConfigKeyError
(
name
)
def
__repr__
(
self
):
return
f
"<ConfigHelper with app
{
self
.
app
}
>"
def
__str__
(
self
):
return
f
"ConfigHelper for app
{
self
.
app
}
"
application/extensions/__init__.py
View file @
4349e634
...
@@ -21,7 +21,6 @@ from .init_migrate import init_migrate
...
@@ -21,7 +21,6 @@ from .init_migrate import init_migrate
from
.init_apispec
import
init_apispec
from
.init_apispec
import
init_apispec
from
.init_marshmallow
import
init_marshmallow
from
.init_marshmallow
import
init_marshmallow
from
.init_elasticsearch
import
init_elasticsearch
from
.init_elasticsearch
import
init_elasticsearch
# from .init_celery import init_celery
def
init_plugs
(
app
:
Flask
)
->
None
:
def
init_plugs
(
app
:
Flask
)
->
None
:
...
@@ -34,4 +33,3 @@ def init_plugs(app: Flask) -> None:
...
@@ -34,4 +33,3 @@ def init_plugs(app: Flask) -> None:
init_marshmallow
(
app
)
init_marshmallow
(
app
)
init_elasticsearch
(
app
)
init_elasticsearch
(
app
)
init_cors
(
app
)
init_cors
(
app
)
# init_celery(app)
application/extensions/init_celery.py
deleted
100644 → 0
View file @
9bdb96fb
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
# @Version : Python 3.11.4
# @Software : Sublime Text 4
# @Author : StudentCWZ
# @Email : StudentCWZ@outlook.com
# @Date : 2023/11/7 16:10
# @File : init_celery.py
# @Description :
"""
from
flask
import
Flask
from
celery.schedules
import
crontab
from
application.utils
import
make_celery
def
init_celery
(
app
:
Flask
)
->
None
:
celery
=
make_celery
(
app
)
app
.
celery
=
celery
celery
.
conf
.
beat_schedule
=
{
'update-database-every-day'
:
{
'task'
:
'application.libs.tasks.task.update_database'
,
'schedule'
:
crontab
(
minute
=
'*'
)
# Execute every minute
}
}
application/extensions/init_sqlalchemy.py
View file @
4349e634
...
@@ -36,4 +36,7 @@ def init_database(app: Flask) -> None:
...
@@ -36,4 +36,7 @@ def init_database(app: Flask) -> None:
driver
=
cfg
.
Driver
,
driver
=
cfg
.
Driver
,
)
)
app
.
config
.
setdefault
(
'SQLALCHEMY_DATABASE_URI'
,
uri
.
create
())
app
.
config
.
setdefault
(
'SQLALCHEMY_DATABASE_URI'
,
uri
.
create
())
db
.
app
=
app
db
.
init_app
(
app
)
db
.
init_app
(
app
)
with
app
.
app_context
():
db
.
create_all
()
application/libs/flask_elasticsearch/elasticsearch.py
View file @
4349e634
...
@@ -19,7 +19,7 @@ from flask import _app_ctx_stack as stack_context
...
@@ -19,7 +19,7 @@ from flask import _app_ctx_stack as stack_context
from
flask_elasticsearch
import
FlaskElasticsearch
as
BaseFlaskElasticsearch
from
flask_elasticsearch
import
FlaskElasticsearch
as
BaseFlaskElasticsearch
from
loguru
import
logger
from
loguru
import
logger
from
application.
common
import
ConfigHelper
from
application.
libs.helper
import
ConfigHelper
class
FlaskElasticsearch
(
BaseFlaskElasticsearch
):
class
FlaskElasticsearch
(
BaseFlaskElasticsearch
):
...
...
application/libs/flask_loguru/logger.py
View file @
4349e634
...
@@ -17,7 +17,7 @@ from flask import Flask, request, g
...
@@ -17,7 +17,7 @@ from flask import Flask, request, g
from
loguru
import
logger
from
loguru
import
logger
from
.format
import
patching
from
.format
import
patching
from
application.
common
import
ConfigHelper
from
application.
libs.helper
import
ConfigHelper
class
FlaskLoguru
:
class
FlaskLoguru
:
...
...
application/libs/helper/__init__.py
0 → 100644
View file @
4349e634
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
# @Version : Python 3.11.4
# @Software : Sublime Text 4
# @Author : StudentCWZ
# @Email : StudentCWZ@outlook.com
# @Date : 2023/11/11 14:05
# @File : __init__.py
# @Description :
"""
from
.config
import
ConfigHelper
from
.env
import
EnvVarHelper
from
.file
import
FileHelper
application/libs/helper/config.py
0 → 100644
View file @
4349e634
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
# @Version : Python 3.11.4
# @Software : Sublime Text 4
# @Author : StudentCWZ
# @Email : StudentCWZ@outlook.com
# @Date : 2023/11/3 19:43
# @File : config.py
# @Description :
"""
from
typing
import
Any
from
flask
import
Flask
from
loguru
import
logger
from
application.libs
import
ConfigKeyError
class
ConfigHelper
:
"""
The ConfigHelper class is a utility for fetching configuration values
from a Flask application.
:param app: The Flask application instance from which to fetch configuration values.
"""
def
__init__
(
self
,
app
:
Flask
):
self
.
app
=
app
def
__getattr__
(
self
,
name
:
str
)
->
Any
:
"""
Get a config value as an attribute.
:param name: The name of the config key.
:return: The value for the provided key, or None if it does not exist.
"""
try
:
return
self
.
app
.
config
[
name
]
except
KeyError
:
logger
.
error
(
f
'Key
{
name
}
not found in configuration'
)
raise
ConfigKeyError
(
name
)
def
__repr__
(
self
):
return
f
"<ConfigHelper with app
{
self
.
app
}
>"
def
__str__
(
self
):
return
f
"ConfigHelper for app
{
self
.
app
}
"
application/
common
/env.py
→
application/
libs/helper
/env.py
View file @
4349e634
File moved
application/
common
/file.py
→
application/
libs/helper
/file.py
View file @
4349e634
File moved
application/libs/tasks/task.py
View file @
4349e634
...
@@ -9,13 +9,3 @@
...
@@ -9,13 +9,3 @@
# @File : task.py
# @File : task.py
# @Description :
# @Description :
"""
"""
from
flask
import
current_app
@
current_app
.
celery
.
task
def
update_database
():
# Add your database operations here
print
(
123312312
)
pass
application/utils/loaders/consul_loader.py
View file @
4349e634
...
@@ -16,8 +16,8 @@ import requests
...
@@ -16,8 +16,8 @@ import requests
from
dynaconf.base
import
LazySettings
from
dynaconf.base
import
LazySettings
from
dynaconf.utils.parse_conf
import
parse_conf_data
from
dynaconf.utils.parse_conf
import
parse_conf_data
from
application.common
import
EnvVarHelper
from
application.libs
import
ConsulConfig
from
application.libs
import
ConsulConfig
from
application.libs.helper
import
EnvVarHelper
IDENTIFIER
=
"consul_loader"
IDENTIFIER
=
"consul_loader"
...
...
application/utils/loaders/yaml_loader.py
View file @
4349e634
...
@@ -17,8 +17,8 @@ from typing import Union
...
@@ -17,8 +17,8 @@ from typing import Union
from
dynaconf.base
import
LazySettings
from
dynaconf.base
import
LazySettings
from
dynaconf.utils.parse_conf
import
parse_conf_data
from
dynaconf.utils.parse_conf
import
parse_conf_data
from
application.common
import
FileHelper
from
application.libs
import
LocalConfig
from
application.libs
import
LocalConfig
from
application.libs.helper
import
FileHelper
IDENTIFIER
=
"yaml_loader"
IDENTIFIER
=
"yaml_loader"
...
...
application/views/user/user.py
View file @
4349e634
...
@@ -18,7 +18,7 @@ from marshmallow import ValidationError
...
@@ -18,7 +18,7 @@ from marshmallow import ValidationError
from
application.schemas
import
UserSchema
from
application.schemas
import
UserSchema
from
application.utils
import
ElasticsearchUtil
from
application.utils
import
ElasticsearchUtil
from
application.
common
import
ConfigHelper
from
application.
libs.helper
import
ConfigHelper
user_api
=
Blueprint
(
'user_api'
,
__name__
)
user_api
=
Blueprint
(
'user_api'
,
__name__
)
api_users
=
Api
(
user_api
)
api_users
=
Api
(
user_api
)
...
@@ -54,16 +54,16 @@ def create_user():
...
@@ -54,16 +54,16 @@ def create_user():
@
user_api
.
route
(
'/tests'
,
methods
=
[
'POST'
])
@
user_api
.
route
(
'/tests'
,
methods
=
[
'POST'
])
def
test_user
():
def
test_user
():
data
=
request
.
get_json
()
#
data = request.get_json()
start
=
data
.
get
(
'start'
)
#
start = data.get('start')
end
=
data
.
get
(
'end'
)
#
end = data.get('end')
dsl
=
ElasticsearchUtil
.
dsl
(
start
,
end
)
#
dsl = ElasticsearchUtil.dsl(start, end)
index
=
current_app
.
config
.
Elasticsearch
.
Index
#
index = current_app.config.Elasticsearch.Index
res
=
ElasticsearchUtil
.
search
(
index
,
dsl
)
#
res = ElasticsearchUtil.search(index, dsl)
print
(
len
(
res
))
#
print(len(res))
data
=
{
res
=
{
"user_name"
:
"libai"
,
"user_name"
:
"libai"
,
"user_age"
:
18
,
"user_age"
:
18
,
}
}
res_json
=
json
.
dumps
(
data
)
res_json
=
json
.
dumps
(
res
)
return
res_json
,
200
return
res_json
,
200
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment