代码拉取完成,页面将自动刷新
同步操作将从 tupelo-shen/mysnapd 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
/*
* Copyright (C) 2014-2020 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package daemon
import (
"encoding/json"
"net/http"
"gitee.com/mysnapcore/mysnapd/client"
"gitee.com/mysnapcore/mysnapd/overlord/auth"
"gitee.com/mysnapcore/mysnapd/store"
)
// TODO: this is unsupported and when supported will have a new implementation,
// make these simply return errors and remove all the related code from
// the store package except maybe errors
var (
buyCmd = &Command{
Path: "/v2/buy",
POST: postBuy,
WriteAccess: authenticatedAccess{},
}
readyToBuyCmd = &Command{
Path: "/v2/buy/ready",
GET: readyToBuy,
ReadAccess: authenticatedAccess{},
}
)
func postBuy(c *Command, r *http.Request, user *auth.UserState) Response {
var opts client.BuyOptions
decoder := json.NewDecoder(r.Body)
err := decoder.Decode(&opts)
if err != nil {
return BadRequest("cannot decode buy options from request body: %v", err)
}
s := storeFrom(c.d)
buyResult, err := s.Buy(&opts, user)
if resp := convertBuyError(err); resp != nil {
return resp
}
return SyncResponse(buyResult)
}
func readyToBuy(c *Command, r *http.Request, user *auth.UserState) Response {
s := storeFrom(c.d)
if resp := convertBuyError(s.ReadyToBuy(user)); resp != nil {
return resp
}
return SyncResponse(true)
}
func convertBuyError(err error) Response {
var kind client.ErrorKind
switch err {
case nil:
return nil
case store.ErrInvalidCredentials:
return Unauthorized(err.Error())
case store.ErrUnauthenticated:
kind = client.ErrorKindLoginRequired
case store.ErrTOSNotAccepted:
kind = client.ErrorKindTermsNotAccepted
case store.ErrNoPaymentMethods:
kind = client.ErrorKindNoPaymentMethods
case store.ErrPaymentDeclined:
kind = client.ErrorKindPaymentDeclined
default:
return InternalError("%v", err)
}
return &apiError{
Status: 400,
Message: err.Error(),
Kind: kind,
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。