func (s *Server) isAllowedByPolicy(p *peer.Peer, req *msg.OcReq) (bool, msg.OcRespStatus) { fmt.Printf("is allowed? %v\n", s) paidPv, err := p.AmountPaid(SERVER_PAYMENT_MIN_CONF, s.BtcConf) if err != nil { return false, msg.SERVER_ERROR } consumedPv, err := p.AmountConsumed() if err != nil { return false, msg.SERVER_ERROR } fmt.Printf("paid: %v, consumed: %v\n", paidPv, consumedPv) // policies := s.Conf.MatchingPolicies(req.Service, req.Method) // for _, policy := range policies { // fmt.Printf("check against policy: %v\n", policy) // switch policy.Cmd { // case conf.ALLOW: // continue // case conf.DENY: // return false, msg.ACCESS_DENIED // case conf.MIN_FEE: // min := policy.Args[0].(msg.PaymentValue) // fmt.Printf("min fee: %v, pt: %v\n", min, req.PaymentType) // if req.PaymentType != msg.ATTACHED { // return false, msg.PAYMENT_REQUIRED // } // // TODO(ortutay): implement // return false, msg.SERVER_ERROR // } // } return true, msg.OK }