Search in sources :

Example 26 with OnmsApplication

use of org.opennms.netmgt.model.OnmsApplication in project opennms by OpenNMS.

the class DefaultLocationDataService method getApplicationsForLocation.

/**
 * {@inheritDoc}
 */
@Transactional
@Override
public Collection<ApplicationInfo> getApplicationsForLocation(final LocationInfo locationInfo) {
    waitForGeocoding("getApplicationsForLocation");
    final Map<String, ApplicationInfo> apps = new HashMap<String, ApplicationInfo>();
    for (final OnmsLocationSpecificStatus status : m_locationDao.getMostRecentStatusChangesForLocation(locationInfo.getName())) {
        for (final OnmsApplication app : status.getMonitoredService().getApplications()) {
            if (!apps.containsKey(app.getName())) {
                apps.put(app.getName(), getApplicationInfo(app));
            }
        }
    }
    return apps.values();
}
Also used : HashMap(java.util.HashMap) LinkedHashMap(java.util.LinkedHashMap) OnmsLocationSpecificStatus(org.opennms.netmgt.model.OnmsLocationSpecificStatus) ApplicationInfo(org.opennms.features.poller.remote.gwt.client.ApplicationInfo) OnmsApplication(org.opennms.netmgt.model.OnmsApplication) Transactional(org.springframework.transaction.annotation.Transactional)

Example 27 with OnmsApplication

use of org.opennms.netmgt.model.OnmsApplication in project opennms by OpenNMS.

the class DefaultLocationDataService method getLocationDetails.

/**
 * <p>getLocationDetails</p>
 *
 * @param def a {@link org.opennms.netmgt.model.OnmsMonitoringLocationDefinition} object.
 * @return a {@link org.opennms.features.poller.remote.gwt.client.location.LocationDetails} object.
 */
@Transactional
@Override
public LocationDetails getLocationDetails(final OnmsMonitoringLocation def) {
    waitForGeocoding("getLocationDetails");
    final LocationDetails ld = new LocationDetails();
    final DefaultLocationDataService.MonitorStatusTracker mst = new DefaultLocationDataService.MonitorStatusTracker(def.getLocationName());
    final DefaultLocationDataService.ApplicationStatusTracker ast = new DefaultLocationDataService.ApplicationStatusTracker(def.getLocationName());
    final List<GWTLocationMonitor> monitors = new ArrayList<GWTLocationMonitor>();
    for (OnmsLocationMonitor mon : m_locationDao.findByLocationDefinition(def)) {
        monitors.add(transformLocationMonitor(mon));
    }
    final Set<ApplicationInfo> applications = new HashSet<ApplicationInfo>();
    for (final OnmsApplication application : m_applicationDao.findAll()) {
        applications.add(transformApplication(m_monitoredServiceDao.findByApplication(application), application));
    }
    // for (final OnmsMonitoredService service : m_monitoredServiceDao.findAll()) {
    // for (final OnmsApplication app : service.getApplications()) {
    // final String appName = app.getName();
    // Set<OnmsMonitoredService> serv = services.get(appName);
    // if (serv == null) {
    // serv = new HashSet<OnmsMonitoredService>();
    // services.put(appName, serv);
    // }
    // serv.add(service);
    // }
    // }
    final Date to = new Date();
    final Date from = new Date(to.getTime() - AVAILABILITY_MS);
    for (OnmsLocationSpecificStatus status : m_locationDao.getMostRecentStatusChangesForLocation(def.getLocationName())) {
        mst.onStatus(status);
        ast.onStatus(status);
    }
    ld.setLocationMonitorState(new LocationMonitorState(monitors, mst.drain()));
    ld.setApplicationState(new ApplicationState(from, to, applications, monitors, ast.drainStatuses()));
    LOG.debug("getLocationDetails({}) returning {}", def.getLocationName(), ld);
    return ld;
}
Also used : LocationDetails(org.opennms.features.poller.remote.gwt.client.location.LocationDetails) OnmsLocationSpecificStatus(org.opennms.netmgt.model.OnmsLocationSpecificStatus) ApplicationState(org.opennms.features.poller.remote.gwt.client.ApplicationState) ArrayList(java.util.ArrayList) ApplicationInfo(org.opennms.features.poller.remote.gwt.client.ApplicationInfo) LocationMonitorState(org.opennms.features.poller.remote.gwt.client.LocationMonitorState) GWTLocationMonitor(org.opennms.features.poller.remote.gwt.client.GWTLocationMonitor) OnmsApplication(org.opennms.netmgt.model.OnmsApplication) Date(java.util.Date) OnmsLocationMonitor(org.opennms.netmgt.model.OnmsLocationMonitor) HashSet(java.util.HashSet) LinkedHashSet(java.util.LinkedHashSet) Transactional(org.springframework.transaction.annotation.Transactional)

Example 28 with OnmsApplication

use of org.opennms.netmgt.model.OnmsApplication in project opennms by OpenNMS.

the class DefaultLocationDataService method getInfoForAllApplications.

/**
 * <p>getInfoForAllApplications</p>
 *
 * @return a {@link java.util.List} object.
 */
@Transactional
@Override
public List<ApplicationInfo> getInfoForAllApplications() {
    waitForGeocoding("handleAllApplications");
    Map<OnmsApplication, StatusDetails> statusDetails = getStatusDetailsForAllApplications();
    final List<ApplicationInfo> appInfos = new ArrayList<ApplicationInfo>();
    for (Map.Entry<OnmsApplication, StatusDetails> entry : statusDetails.entrySet()) {
        final ApplicationInfo appInfo = getApplicationInfo(entry.getKey(), entry.getValue());
        appInfos.add(appInfo);
    }
    return appInfos;
}
Also used : StatusDetails(org.opennms.features.poller.remote.gwt.client.StatusDetails) ApplicationInfo(org.opennms.features.poller.remote.gwt.client.ApplicationInfo) ArrayList(java.util.ArrayList) OnmsApplication(org.opennms.netmgt.model.OnmsApplication) Map(java.util.Map) HashMap(java.util.HashMap) LinkedHashMap(java.util.LinkedHashMap) Transactional(org.springframework.transaction.annotation.Transactional)

Example 29 with OnmsApplication

use of org.opennms.netmgt.model.OnmsApplication in project opennms by OpenNMS.

the class DefaultAdminApplicationService method addNewApplication.

/**
 * {@inheritDoc}
 */
@Override
public OnmsApplication addNewApplication(String name) {
    OnmsApplication application = new OnmsApplication();
    application.setName(name);
    m_applicationDao.save(application);
    return application;
}
Also used : OnmsApplication(org.opennms.netmgt.model.OnmsApplication)

Example 30 with OnmsApplication

use of org.opennms.netmgt.model.OnmsApplication in project opennms by OpenNMS.

the class DefaultAdminApplicationService method findByMonitoredService.

/**
 * {@inheritDoc}
 */
@Override
public List<OnmsApplication> findByMonitoredService(int id) {
    OnmsMonitoredService service = m_monitoredServiceDao.get(id);
    if (service == null) {
        throw new IllegalArgumentException("monitored service with " + "id of " + id + " could not be found");
    }
    List<OnmsApplication> sortedApplications = new ArrayList<OnmsApplication>(service.getApplications());
    Collections.sort(sortedApplications);
    return sortedApplications;
}
Also used : ArrayList(java.util.ArrayList) OnmsApplication(org.opennms.netmgt.model.OnmsApplication) OnmsMonitoredService(org.opennms.netmgt.model.OnmsMonitoredService)

Aggregations

OnmsApplication (org.opennms.netmgt.model.OnmsApplication)42 OnmsMonitoredService (org.opennms.netmgt.model.OnmsMonitoredService)20 OnmsLocationMonitor (org.opennms.netmgt.model.OnmsLocationMonitor)14 ArrayList (java.util.ArrayList)13 OnmsMonitoringLocation (org.opennms.netmgt.model.monitoringLocations.OnmsMonitoringLocation)12 Date (java.util.Date)11 OnmsLocationSpecificStatus (org.opennms.netmgt.model.OnmsLocationSpecificStatus)11 LinkedList (java.util.LinkedList)8 Transactional (org.springframework.transaction.annotation.Transactional)6 HashSet (java.util.HashSet)5 ApplicationInfo (org.opennms.features.poller.remote.gwt.client.ApplicationInfo)4 StatusDetails (org.opennms.features.poller.remote.gwt.client.StatusDetails)4 SimpleWebTable (org.opennms.web.svclayer.model.SimpleWebTable)4 LinkedHashMap (java.util.LinkedHashMap)3 List (java.util.List)3 Test (org.junit.Test)3 OnmsNode (org.opennms.netmgt.model.OnmsNode)3 OnmsServiceType (org.opennms.netmgt.model.OnmsServiceType)3 DistributedStatusHistoryModel (org.opennms.web.svclayer.model.DistributedStatusHistoryModel)3 HashMap (java.util.HashMap)2