001// --------------------------------------------------------------------------------
002// Copyright 2002-2024 Echo Three, LLC
003//
004// Licensed under the Apache License, Version 2.0 (the "License");
005// you may not use this file except in compliance with the License.
006// You may obtain a copy of the License at
007//
008//     http://www.apache.org/licenses/LICENSE-2.0
009//
010// Unless required by applicable law or agreed to in writing, software
011// distributed under the License is distributed on an "AS IS" BASIS,
012// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013// See the License for the specific language governing permissions and
014// limitations under the License.
015// --------------------------------------------------------------------------------
016
017package com.echothree.control.user.authentication.server.command;
018
019import com.echothree.model.control.user.server.logic.UserVisitLogic;
020import com.echothree.model.data.user.common.pk.UserVisitPK;
021import com.echothree.util.common.command.BaseResult;
022import com.echothree.util.server.control.BaseSimpleCommand;
023
024public class InvalidateUserVisitCommand
025        extends BaseSimpleCommand {
026    
027    /** Creates a new instance of InvalidateUserVisitCommand */
028    public InvalidateUserVisitCommand(UserVisitPK userVisitPK) {
029        super(userVisitPK, null, false);
030
031        // Prevent the possible creation of an extra UserSession when we're just going to be deleting it anyway.
032        setCheckIdentityVerifiedTime(false);
033
034        // This isn't really the user executing a command, don't bother with this. Also, UserVisit may have been
035        // delete or removed at the point this is done.
036        setUpdateLastCommandTime(false);
037    }
038    
039    @Override
040    protected BaseResult execute() {
041        UserVisitLogic.getInstance().invalidateUserVisit(getUserVisitPK(), getPartyPK());
042        
043        return null;
044    }
045    
046}