2  * ============LICENSE_START==========================================
 
   4  * ===================================================================
 
   5  * Copyright © 2018 AT&T Intellectual Property. All rights reserved.
 
   6  * ===================================================================
 
   8  * Unless otherwise specified, all software contained herein is licensed
 
   9  * under the Apache License, Version 2.0 (the "License");
 
  10  * you may not use this software except in compliance with the License.
 
  11  * You may obtain a copy of the License at
 
  13  *             http://www.apache.org/licenses/LICENSE-2.0
 
  15  * Unless required by applicable law or agreed to in writing, software
 
  16  * distributed under the License is distributed on an "AS IS" BASIS,
 
  17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  18  * See the License for the specific language governing permissions and
 
  19  * limitations under the License.
 
  21  * Unless otherwise specified, all documentation contained herein is licensed
 
  22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
 
  23  * you may not use this documentation except in compliance with the License.
 
  24  * You may obtain a copy of the License at
 
  26  *             https://creativecommons.org/licenses/by/4.0/
 
  28  * Unless required by applicable law or agreed to in writing, documentation
 
  29  * distributed under the License is distributed on an "AS IS" BASIS,
 
  30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  31  * See the License for the specific language governing permissions and
 
  32  * limitations under the License.
 
  34  * ============LICENSE_END============================================
 
  38 package org.onap.portalapp.music.conf;
 
  41 import java.util.concurrent.ConcurrentHashMap;
 
  43 import org.onap.music.eelf.logging.EELFLoggerDelegate;
 
  44 import org.onap.music.exceptions.MusicLockingException;
 
  45 import org.onap.music.exceptions.MusicServiceException;
 
  46 import org.onap.portalapp.music.service.MusicService;
 
  47 import org.onap.portalapp.music.util.MusicUtil;
 
  48 import org.springframework.session.Session;
 
  50 public class MusicSessionRepositoryHandler {
 
  52         private static final EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(MusicSessionRepositoryHandler.class);
 
  53         private final Map<String, Session> sessions = new ConcurrentHashMap<>();
 
  54         private boolean musicCache = MusicUtil.isCached();
 
  57         public Session get(String id) {
 
  59                  // todo need to add the clean up for "sessions" map if musicCache is enabled        
 
  60                         return this.sessions.get(id);
 
  63                                 Session session = MusicService.getMetaAttribute(id);
 
  65                         } catch (Exception e) {
 
  66                                 logger.error(EELFLoggerDelegate.errorLogger, "get failed with id " + id, e);
 
  74         public void remove(String id) {
 
  76                          // todo need to add the clean up for "sessions" map if musicCache is enabled        
 
  80                                 MusicService.removeSession(id);
 
  81                         } catch (MusicLockingException e) {
 
  82                                 logger.error(EELFLoggerDelegate.errorLogger, "removeSession locking failed with id " + id, e);
 
  83                         } catch (MusicServiceException e) {
 
  84                                 logger.error(EELFLoggerDelegate.errorLogger, "removeSession failed with id " + id, e);
 
  91         public void put(String id, MusicSession musicSession) {
 
  93                          // todo need to add the clean up for "sessions" map if musicCache is enabled        
 
  94                         sessions.put(id, musicSession);         
 
  97                                 MusicService.setMetaAttribute(musicSession);
 
  98                                 MusicService.cleanUpMusic();
 
  99                         } catch (Exception e) {
 
 100                                 logger.error(EELFLoggerDelegate.errorLogger, "setMetaAttribute failed with id " + id, e);