Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
PyFund
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
陈涛
PyFund
Commits
1dcac753
Commit
1dcac753
authored
Jun 19, 2023
by
confusion
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改净值接口查询 添加权限验证
parent
c05520fe
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
16 deletions
+38
-16
nav.py
api/nav.py
+38
-16
No files found.
api/nav.py
View file @
1dcac753
import
datetime
import
datetime
from
typing
import
Optional
import
re
import
re
from
loguru
import
logger
from
loguru
import
logger
import
pytz
import
pytz
from
fastapi
import
APIRouter
,
Depends
,
Query
,
Body
from
fastapi
import
APIRouter
,
Depends
,
Query
,
Body
from
fastapi.background
import
BackgroundTasks
from
fastapi.background
import
BackgroundTasks
from
motor.core
import
AgnosticCollection
from
motor.core
import
AgnosticCollection
from
dependencies
import
get_nav_collect
,
get_fund_collect
from
dependencies
import
get_nav_collect
,
get_fund_collect
,
get_permission_user_collect
,
get_permission_role_collect
,
\
get_current_user
from
model
import
SortParams
,
FilterTime
,
Page
,
PageResponse
,
Response
from
model
import
SortParams
,
FilterTime
,
Page
,
PageResponse
,
Response
from
model.fund
import
StakingFundNav
from
model.fund
import
StakingFundNav
from
service.nav
import
calculate_nav
,
build_fund_nav
from
service.nav
import
calculate_nav
,
build_fund_nav
from
service.permission
import
check_permission
from
tools.jwt_tools
import
User
router
=
APIRouter
()
router
=
APIRouter
()
...
@@ -17,11 +19,18 @@ router = APIRouter()
...
@@ -17,11 +19,18 @@ router = APIRouter()
@
router
.
get
(
"/{fund_id}/"
,
response_model
=
PageResponse
[
StakingFundNav
],
summary
=
"查询净值记录"
)
@
router
.
get
(
"/{fund_id}/"
,
response_model
=
PageResponse
[
StakingFundNav
],
summary
=
"查询净值记录"
)
async
def
get_nav
(
async
def
get_nav
(
fund_id
:
str
,
fund_id
:
str
,
user
:
User
=
Depends
(
get_current_user
),
sort_by
:
SortParams
=
Depends
(
SortParams
),
sort_by
:
SortParams
=
Depends
(
SortParams
),
filter_time
:
FilterTime
=
Depends
(
FilterTime
),
filter_time
:
FilterTime
=
Depends
(
FilterTime
),
page
:
Page
=
Depends
(
Page
),
page
:
Page
=
Depends
(
Page
),
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
)
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
),
permission_user_collect
:
AgnosticCollection
=
Depends
(
get_permission_user_collect
),
permission_role_collect
:
AgnosticCollection
=
Depends
(
get_permission_role_collect
)
):
):
await
check_permission
([
'data_permission.nav.query'
],
fund_id
,
user
.
email
,
permission_user_collect
,
permission_role_collect
)
query
=
{
"fund_id"
:
fund_id
}
query
=
{
"fund_id"
:
fund_id
}
if
filter_time
.
start_time
and
filter_time
.
end_time
:
if
filter_time
.
start_time
and
filter_time
.
end_time
:
query
.
update
({
'record_date'
:
filter_time
.
to_mongodb_query
()})
query
.
update
({
'record_date'
:
filter_time
.
to_mongodb_query
()})
...
@@ -34,16 +43,6 @@ async def get_nav(
...
@@ -34,16 +43,6 @@ async def get_nav(
return
response
return
response
@
router
.
post
(
"/{fund_id}/"
,
response_model
=
Response
[
StakingFundNav
],
summary
=
"插入净值记录"
)
async
def
insert_nav
(
fund_id
:
str
,
calc_time
:
Optional
[
datetime
.
datetime
]
=
Query
(
default
=
None
,
title
=
"时间"
),
):
fund_nav
=
await
calculate_nav
(
fund_id
=
fund_id
,
calc_time
=
calc_time
)
if
calc_time
else
await
calculate_nav
(
fund_id
)
response
=
Response
[
StakingFundNav
](
data
=
fund_nav
)
return
response
@
router
.
post
(
"/"
,
response_model
=
Response
[
bool
],
summary
=
"新增净值记录"
)
@
router
.
post
(
"/"
,
response_model
=
Response
[
bool
],
summary
=
"新增净值记录"
)
async
def
create_nav
(
async
def
create_nav
(
fund_id
:
str
=
Body
(
...
,
title
=
"基金id"
),
fund_id
:
str
=
Body
(
...
,
title
=
"基金id"
),
...
@@ -52,9 +51,18 @@ async def create_nav(
...
@@ -52,9 +51,18 @@ async def create_nav(
fund_share
:
float
=
Body
(
...
,
title
=
"份额"
),
fund_share
:
float
=
Body
(
...
,
title
=
"份额"
),
fund_collect
:
AgnosticCollection
=
Depends
(
get_fund_collect
),
fund_collect
:
AgnosticCollection
=
Depends
(
get_fund_collect
),
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
),
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
),
user
:
User
=
Depends
(
get_current_user
),
permission_user_collect
:
AgnosticCollection
=
Depends
(
get_permission_user_collect
),
permission_role_collect
:
AgnosticCollection
=
Depends
(
get_permission_role_collect
)
):
):
await
check_permission
([
'data_permission.nav.add'
],
fund_id
,
user
.
email
,
permission_user_collect
,
permission_role_collect
)
fund_data
=
await
fund_collect
.
find_one
({
"id"
:
fund_id
})
fund_data
=
await
fund_collect
.
find_one
({
"id"
:
fund_id
})
fund_nav
=
build_fund_nav
(
fund_data
,
record_date
.
replace
(
hour
=
0
,
minute
=
0
,
second
=
0
,
microsecond
=
0
,
tzinfo
=
pytz
.
UTC
),
fund_share
,
nav
)
fund_nav
=
build_fund_nav
(
fund_data
,
record_date
.
replace
(
hour
=
0
,
minute
=
0
,
second
=
0
,
microsecond
=
0
,
tzinfo
=
pytz
.
UTC
),
fund_share
,
nav
)
insert
=
await
nav_collect
.
insert_one
(
fund_nav
)
insert
=
await
nav_collect
.
insert_one
(
fund_nav
)
response
=
Response
(
data
=
insert
.
acknowledged
)
response
=
Response
(
data
=
insert
.
acknowledged
)
return
response
return
response
...
@@ -67,12 +75,19 @@ async def update_nav(
...
@@ -67,12 +75,19 @@ async def update_nav(
record_date
:
datetime
.
datetime
=
Body
(
...
,
title
=
"记录日期"
),
record_date
:
datetime
.
datetime
=
Body
(
...
,
title
=
"记录日期"
),
nav
:
float
=
Body
(
...
,
title
=
"净值"
),
nav
:
float
=
Body
(
...
,
title
=
"净值"
),
fund_share
:
float
=
Body
(
...
,
title
=
"份额"
),
fund_share
:
float
=
Body
(
...
,
title
=
"份额"
),
fund_collect
:
AgnosticCollection
=
Depends
(
get_fund_collect
),
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
),
nav_collect
:
AgnosticCollection
=
Depends
(
get_nav_collect
),
user
:
User
=
Depends
(
get_current_user
),
permission_user_collect
:
AgnosticCollection
=
Depends
(
get_permission_user_collect
),
permission_role_collect
:
AgnosticCollection
=
Depends
(
get_permission_role_collect
)
):
):
await
check_permission
([
'data_permission.nav.edit'
],
fund_id
,
user
.
email
,
permission_user_collect
,
permission_role_collect
)
update_result
=
await
nav_collect
.
update_one
(
update_result
=
await
nav_collect
.
update_one
(
{
"id"
:
nav_id
,
"fund_id"
:
fund_id
},
{
"id"
:
nav_id
,
"fund_id"
:
fund_id
},
{
"$set"
:
{
"record_date"
:
record_date
.
replace
(
hour
=
0
,
minute
=
0
,
second
=
0
,
microsecond
=
0
,
tzinfo
=
pytz
.
UTC
),
"nav"
:
nav
,
"fund_share"
:
fund_share
}}
{
"$set"
:
{
"record_date"
:
record_date
.
replace
(
hour
=
0
,
minute
=
0
,
second
=
0
,
microsecond
=
0
,
tzinfo
=
pytz
.
UTC
),
"nav"
:
nav
,
"fund_share"
:
fund_share
}}
)
)
response
=
Response
(
data
=
update_result
.
modified_count
)
response
=
Response
(
data
=
update_result
.
modified_count
)
return
response
return
response
...
@@ -85,7 +100,14 @@ async def recalculate_nav(
...
@@ -85,7 +100,14 @@ async def recalculate_nav(
start
:
datetime
.
datetime
=
Query
(
...
,
title
=
"开始时间"
),
start
:
datetime
.
datetime
=
Query
(
...
,
title
=
"开始时间"
),
end
:
datetime
.
datetime
=
Query
(
None
,
title
=
"结束时间"
),
end
:
datetime
.
datetime
=
Query
(
None
,
title
=
"结束时间"
),
fund_collect
:
AgnosticCollection
=
Depends
(
get_fund_collect
),
fund_collect
:
AgnosticCollection
=
Depends
(
get_fund_collect
),
user
:
User
=
Depends
(
get_current_user
),
permission_user_collect
:
AgnosticCollection
=
Depends
(
get_permission_user_collect
),
permission_role_collect
:
AgnosticCollection
=
Depends
(
get_permission_role_collect
)
):
):
await
check_permission
([
'data_permission.nav.recalculate'
],
fund_id
,
user
.
email
,
permission_user_collect
,
permission_role_collect
)
fund_data
=
await
fund_collect
.
find_one
({
"id"
:
fund_id
})
fund_data
=
await
fund_collect
.
find_one
({
"id"
:
fund_id
})
end
=
end
or
datetime
.
datetime
.
utcnow
()
end
=
end
or
datetime
.
datetime
.
utcnow
()
delta
=
end
-
start
delta
=
end
-
start
...
...
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