8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster/**
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Copyright (c) 2009 Sun Microsystems Inc. All Rights Reserved
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * The contents of this file are subject to the terms
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * of the Common Development and Distribution License
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * (the License). You may not use this file except in
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * compliance with the License.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * You can obtain a copy of the License at
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * https://opensso.dev.java.net/public/CDDLv1.0.html or
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * opensso/legal/CDDLv1.0.txt
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * See the License for the specific language governing
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * permission and limitations under the License.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * When distributing Covered Code, include this CDDL
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Header Notice in each file and include the License file
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * at opensso/legal/CDDLv1.0.txt.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * If applicable, add the following below the CDDL Header,
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * with the fields enclosed by brackets [] replaced by
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * your own identifying information:
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * "Portions Copyrighted [year] [name of copyright owner]"
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * $Id: EntitlementsStats.java,v 1.2 2009/10/13 22:36:30 veiming Exp $
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster/*
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Portions Copyrighted [2011] [ForgeRock AS]
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterpackage com.sun.identity.entitlement.opensso;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterimport java.util.Set;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterimport com.sun.identity.entitlement.util.NetworkMonitor;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterimport com.sun.identity.shared.stats.StatsListener;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterimport com.sun.identity.shared.stats.Stats;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Fosterpublic class EntitlementsStats implements StatsListener {
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster private Stats stats;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster public EntitlementsStats(Stats stats) {
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster this.stats = stats;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster }
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster @Override
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster public void printStats() {
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster StringBuilder sb = new StringBuilder(100);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("Entitlements statistics:");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\n-----------------------------");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster Set<String> ntwStats = NetworkMonitor.getInstanceNames();
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster for (String ntwStat : ntwStats) {
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster NetworkMonitor nm = NetworkMonitor.getInstance(ntwStat);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nNetworkMonitor: ").append(ntwStat);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nResponse Time(ms): ").append(nm.responseTime());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nThroughput: ").append(nm.throughput());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster nm.reset();
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\n-----------------------------");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster }
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster // Cache statistics
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nPolicyCache: ");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append(OpenSSOIndexStore.getNumCachedPolicies());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nReferralCache: ");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append(OpenSSOIndexStore.getNumCachedReferrals());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nTotal policies: ");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append(DataStore.getNumberOfPolicies());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\nTotal referrals: ");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append(DataStore.getNumberOfReferrals());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster sb.append("\n-----------------------------\n");
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster stats.record(sb.toString());
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster }
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster}