// Copyright (c) 2015-2021 MinIO, Inc. // // This file is part of MinIO Object Storage stack // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // 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 Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . package stats import ( "io" "net/http" "sync/atomic" ) // IncomingTrafficMeter counts the incoming bytes from the underlying request.Body. type IncomingTrafficMeter struct { countBytes int64 io.ReadCloser } // Read calls the underlying Read and counts the transferred bytes. func (r *IncomingTrafficMeter) Read(p []byte) (n int, err error) { n, err = r.ReadCloser.Read(p) atomic.AddInt64(&r.countBytes, int64(n)) return n, err } // BytesCount returns the number of transferred bytes func (r IncomingTrafficMeter) BytesCount() int64 { return atomic.LoadInt64(&r.countBytes) } // OutgoingTrafficMeter counts the outgoing bytes through the responseWriter. type OutgoingTrafficMeter struct { countBytes int64 // wrapper for underlying http.ResponseWriter. http.ResponseWriter } // Write calls the underlying write and counts the output bytes func (w *OutgoingTrafficMeter) Write(p []byte) (n int, err error) { n, err = w.ResponseWriter.Write(p) atomic.AddInt64(&w.countBytes, int64(n)) return n, err } // Flush calls the underlying Flush. func (w *OutgoingTrafficMeter) Flush() { w.ResponseWriter.(http.Flusher).Flush() } // BytesCount returns the number of transferred bytes func (w OutgoingTrafficMeter) BytesCount() int64 { return atomic.LoadInt64(&w.countBytes) }