|
@@ -8,6 +8,7 @@ import ( |
|
|
"code.fnuoos.com/zhimeng/model.git/src/super/implement" |
|
|
"code.fnuoos.com/zhimeng/model.git/src/super/implement" |
|
|
"code.fnuoos.com/zhimeng/model.git/src/super/model" |
|
|
"code.fnuoos.com/zhimeng/model.git/src/super/model" |
|
|
"errors" |
|
|
"errors" |
|
|
|
|
|
"fmt" |
|
|
"github.com/shopspring/decimal" |
|
|
"github.com/shopspring/decimal" |
|
|
"time" |
|
|
"time" |
|
|
) |
|
|
) |
|
@@ -41,24 +42,24 @@ func GenerateWxAdData(req md.GenerateWxAdData) (err error, generateWxAdData mode |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// 3、计算媒体、代理收益、平台留存、佣金留存、协议分成、协议总分成 |
|
|
// 3、计算媒体、代理收益、平台留存、佣金留存、协议分成、协议总分成 |
|
|
publisherIncome := originalWxAdData.PublisherIncome |
|
|
|
|
|
mediaRevenue := publisherIncome * mediumDivisionStrategy.MediaRevenueRate / 100 // 媒体收益 |
|
|
|
|
|
agentRevenue := publisherIncome * mediumDivisionStrategy.AgentRevenueRate / 100 // 代理收益 |
|
|
|
|
|
platformRetention := publisherIncome * mediumDivisionStrategy.PlatformRetentionRate / 100 // 平台留存 |
|
|
|
|
|
commissionRetention := publisherIncome * mediumDivisionStrategy.CommissionRetentionRate / 100 // 佣金留存 |
|
|
|
|
|
agreementSharingTotal := (mediaRevenue + agentRevenue) / (100 - mediumDivisionStrategy.AgreementSharingRate) // 协议总分成(倒推) |
|
|
|
|
|
agreementSharing := agreementSharingTotal - (mediaRevenue + agentRevenue) // 协议分成 |
|
|
|
|
|
|
|
|
publisherIncome := float64(originalWxAdData.PublisherIncome) |
|
|
|
|
|
mediaRevenue := publisherIncome * float64(mediumDivisionStrategy.MediaRevenueRate) / 100 // 媒体收益 |
|
|
|
|
|
agentRevenue := publisherIncome * float64(mediumDivisionStrategy.AgentRevenueRate) / 100 // 代理收益 |
|
|
|
|
|
platformRetention := publisherIncome * float64(mediumDivisionStrategy.PlatformRetentionRate) / 100 // 平台留存 |
|
|
|
|
|
commissionRetention := publisherIncome * float64(mediumDivisionStrategy.CommissionRetentionRate) / 100 // 佣金留存 |
|
|
|
|
|
agreementSharingTotal := (mediaRevenue + agentRevenue) / ((100 - float64(mediumDivisionStrategy.AgreementSharingRate)) / 100) // 协议总分成(倒推) |
|
|
|
|
|
agreementSharing := agreementSharingTotal - (mediaRevenue + agentRevenue) // 协议分成 |
|
|
|
|
|
|
|
|
// 3、判断是否有调价留存 |
|
|
// 3、判断是否有调价留存 |
|
|
var priceAdjustmentRetention int |
|
|
var priceAdjustmentRetention int |
|
|
if req.NowEcpm != req.OriginalEcpm || req.NowExposureCount != req.OriginalExposureCount { |
|
|
if req.NowEcpm != req.OriginalEcpm || req.NowExposureCount != req.OriginalExposureCount { |
|
|
tmpMediaRevenue := int(utils.StrToFloat64(req.NowEcpm) * float64(req.NowExposureCount) / 1000) |
|
|
tmpMediaRevenue := int(utils.StrToFloat64(req.NowEcpm) * float64(req.NowExposureCount) / 1000) |
|
|
priceAdjustmentRetention = tmpMediaRevenue - mediaRevenue |
|
|
|
|
|
mediaRevenue = tmpMediaRevenue |
|
|
|
|
|
|
|
|
priceAdjustmentRetention = int(float64(tmpMediaRevenue) - mediaRevenue) |
|
|
|
|
|
mediaRevenue = float64(tmpMediaRevenue) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// 4、计算各代理收益 |
|
|
// 4、计算各代理收益 |
|
|
var extraRevenue int |
|
|
|
|
|
|
|
|
var extraRevenue float64 |
|
|
var agentRevenueFlows []struct { |
|
|
var agentRevenueFlows []struct { |
|
|
AgentId int `json:"agent_id"` |
|
|
AgentId int `json:"agent_id"` |
|
|
AgentRevenueRate int `json:"agent_revenue_rate"` |
|
|
AgentRevenueRate int `json:"agent_revenue_rate"` |
|
@@ -67,8 +68,8 @@ func GenerateWxAdData(req md.GenerateWxAdData) (err error, generateWxAdData mode |
|
|
ExtraRevenue int `json:"extra_revenue"` |
|
|
ExtraRevenue int `json:"extra_revenue"` |
|
|
} |
|
|
} |
|
|
for _, v := range *mediumDivisionStrategyWithAgentFlows { |
|
|
for _, v := range *mediumDivisionStrategyWithAgentFlows { |
|
|
tmpAgentRevenue := agentRevenue * v.AgentRevenueRate / 100 |
|
|
|
|
|
tmpExtraRevenue := commissionRetention * v.ExtraRevenueRate / 100 |
|
|
|
|
|
|
|
|
tmpAgentRevenue := agentRevenue * float64(v.AgentRevenueRate) / 100 |
|
|
|
|
|
tmpExtraRevenue := commissionRetention * float64(v.ExtraRevenueRate) / 100 |
|
|
extraRevenue += tmpExtraRevenue |
|
|
extraRevenue += tmpExtraRevenue |
|
|
agentRevenueFlows = append(agentRevenueFlows, struct { |
|
|
agentRevenueFlows = append(agentRevenueFlows, struct { |
|
|
AgentId int `json:"agent_id"` |
|
|
AgentId int `json:"agent_id"` |
|
@@ -80,8 +81,8 @@ func GenerateWxAdData(req md.GenerateWxAdData) (err error, generateWxAdData mode |
|
|
AgentId: v.AgentId, |
|
|
AgentId: v.AgentId, |
|
|
AgentRevenueRate: v.AgentRevenueRate, |
|
|
AgentRevenueRate: v.AgentRevenueRate, |
|
|
ExtraRevenueRate: v.ExtraRevenueRate, |
|
|
ExtraRevenueRate: v.ExtraRevenueRate, |
|
|
AgentRevenue: tmpAgentRevenue, |
|
|
|
|
|
ExtraRevenue: tmpExtraRevenue, |
|
|
|
|
|
|
|
|
AgentRevenue: int(tmpAgentRevenue), |
|
|
|
|
|
ExtraRevenue: int(tmpExtraRevenue), |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@@ -106,14 +107,14 @@ func GenerateWxAdData(req md.GenerateWxAdData) (err error, generateWxAdData mode |
|
|
ClickCount: originalWxAdData.ClickCount, |
|
|
ClickCount: originalWxAdData.ClickCount, |
|
|
ClickRate: originalWxAdData.ClickRate, |
|
|
ClickRate: originalWxAdData.ClickRate, |
|
|
Ecpm: req.NowEcpm, // 现-ecpm |
|
|
Ecpm: req.NowEcpm, // 现-ecpm |
|
|
PlatformRetention: platformRetention, |
|
|
|
|
|
CommissionRetention: commissionRetention, |
|
|
|
|
|
|
|
|
PlatformRetention: int(platformRetention), |
|
|
|
|
|
CommissionRetention: int(commissionRetention), |
|
|
PriceAdjustmentRetention: priceAdjustmentRetention, |
|
|
PriceAdjustmentRetention: priceAdjustmentRetention, |
|
|
MediaRevenue: mediaRevenue, |
|
|
|
|
|
AgentRevenue: agentRevenue, |
|
|
|
|
|
ExtraRevenue: extraRevenue, |
|
|
|
|
|
AgreementSharing: agreementSharing, |
|
|
|
|
|
AgreementSharingTotal: agreementSharingTotal, |
|
|
|
|
|
|
|
|
MediaRevenue: int(mediaRevenue), |
|
|
|
|
|
AgentRevenue: int(agentRevenue), |
|
|
|
|
|
ExtraRevenue: int(extraRevenue), |
|
|
|
|
|
AgreementSharing: int(agreementSharing), |
|
|
|
|
|
AgreementSharingTotal: int(agreementSharingTotal), |
|
|
PlatformRetentionRate: mediumDivisionStrategy.PlatformRetentionRate, |
|
|
PlatformRetentionRate: mediumDivisionStrategy.PlatformRetentionRate, |
|
|
CommissionRetentionRate: mediumDivisionStrategy.CommissionRetentionRate, |
|
|
CommissionRetentionRate: mediumDivisionStrategy.CommissionRetentionRate, |
|
|
MediaRevenueRate: mediumDivisionStrategy.MediaRevenueRate, |
|
|
MediaRevenueRate: mediumDivisionStrategy.MediaRevenueRate, |
|
@@ -203,8 +204,9 @@ func ClacEcpm(req md.ClacEcpmReq) (err error, ecpm string) { |
|
|
mediaRevenue := publisherIncome.Mul(mediaRevenueRate.Div(rateValue)) // 媒体收益 |
|
|
mediaRevenue := publisherIncome.Mul(mediaRevenueRate.Div(rateValue)) // 媒体收益 |
|
|
agentRevenue := publisherIncome.Mul(agentRevenueRate.Div(rateValue)) // 代理收益 |
|
|
agentRevenue := publisherIncome.Mul(agentRevenueRate.Div(rateValue)) // 代理收益 |
|
|
|
|
|
|
|
|
agreementSharingTotal := (mediaRevenue.Add(agentRevenue)).Div(rateValue.Sub(agreementSharingRate)) // 协议总分成(倒推) |
|
|
|
|
|
|
|
|
agreementSharingTotal := mediaRevenue.Add(agentRevenue).Div(rateValue.Sub(agreementSharingRate).Div(rateValue)) // 协议总分成(倒推) |
|
|
|
|
|
|
|
|
|
|
|
fmt.Println(mediaRevenue, agentRevenue, agreementSharingRate, rateValue.Sub(agreementSharingRate), agreementSharingTotal) |
|
|
// 4、倒退出当前ecpm值 |
|
|
// 4、倒退出当前ecpm值 |
|
|
ecpm = agreementSharingTotal.Div(exposureCount.Div(thousandRateValue)).Round(2).String() |
|
|
ecpm = agreementSharingTotal.Div(exposureCount.Div(thousandRateValue)).Round(2).String() |
|
|
return |
|
|
return |
|
|