mirror of https://github.com/apache/cloudstack.git
105 lines
4.1 KiB
Java
105 lines
4.1 KiB
Java
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing,
|
|
// software distributed under the License is distributed on an
|
|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
// KIND, either express or implied. See the License for the
|
|
// specific language governing permissions and limitations
|
|
// under the License.
|
|
|
|
package com.cloud.network.rules;
|
|
|
|
import org.apache.cloudstack.network.topology.NetworkTopologyVisitor;
|
|
|
|
import com.cloud.agent.api.routing.NetworkElementCommand;
|
|
import com.cloud.agent.api.routing.SavePasswordCommand;
|
|
import com.cloud.agent.manager.Commands;
|
|
import com.cloud.dc.DataCenterVO;
|
|
import com.cloud.exception.ResourceUnavailableException;
|
|
import com.cloud.network.Network;
|
|
import com.cloud.network.router.VirtualRouter;
|
|
import com.cloud.storage.VMTemplateVO;
|
|
import com.cloud.utils.PasswordGenerator;
|
|
import com.cloud.vm.NicProfile;
|
|
import com.cloud.vm.NicVO;
|
|
import com.cloud.vm.UserVmVO;
|
|
import com.cloud.vm.VirtualMachineProfile;
|
|
|
|
public class SshKeyToRouterRules extends RuleApplier {
|
|
|
|
private final NicProfile _nic;
|
|
private final VirtualMachineProfile _profile;
|
|
private final String _sshPublicKey;
|
|
|
|
private NicVO _nicVo;
|
|
private VMTemplateVO _template;
|
|
private UserVmVO _userVM;
|
|
|
|
public SshKeyToRouterRules(final Network network, final NicProfile nic, final VirtualMachineProfile profile, final String sshPublicKey) {
|
|
super(network);
|
|
|
|
_nic = nic;
|
|
_profile = profile;
|
|
_sshPublicKey = sshPublicKey;
|
|
}
|
|
|
|
@Override
|
|
public boolean accept(final NetworkTopologyVisitor visitor, final VirtualRouter router) throws ResourceUnavailableException {
|
|
_router = router;
|
|
_userVM = _userVmDao.findById(_profile.getVirtualMachine().getId());
|
|
_userVmDao.loadDetails(_userVM);
|
|
|
|
_nicVo = _nicDao.findById(_nic.getId());
|
|
// for basic zone, send vm data/password information only to the router in the same pod
|
|
_template = _templateDao.findByIdIncludingRemoved(_profile.getTemplateId());
|
|
|
|
return visitor.visit(this);
|
|
}
|
|
|
|
public void createPasswordCommand(final VirtualRouter router, final VirtualMachineProfile profile, final NicVO nic, final Commands cmds) {
|
|
final String password = (String)profile.getParameter(VirtualMachineProfile.Param.VmPassword);
|
|
final DataCenterVO dcVo = _dcDao.findById(router.getDataCenterId());
|
|
|
|
// password should be set only on default network element
|
|
if (password != null && nic.isDefaultNic()) {
|
|
final String encodedPassword = PasswordGenerator.rot13(password);
|
|
final SavePasswordCommand cmd =
|
|
new SavePasswordCommand(encodedPassword, nic.getIp4Address(), profile.getVirtualMachine().getHostName(), _networkModel.getExecuteInSeqNtwkElmtCmd());
|
|
cmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId()));
|
|
cmd.setAccessDetail(NetworkElementCommand.ROUTER_GUEST_IP, _routerControlHelper.getRouterIpInNetwork(nic.getNetworkId(), router.getId()));
|
|
cmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName());
|
|
cmd.setAccessDetail(NetworkElementCommand.ZONE_NETWORK_TYPE, dcVo.getNetworkType().toString());
|
|
|
|
cmds.addCommand("password", cmd);
|
|
}
|
|
|
|
}
|
|
|
|
public VirtualMachineProfile getProfile() {
|
|
return _profile;
|
|
}
|
|
|
|
public String getSshPublicKey() {
|
|
return _sshPublicKey;
|
|
}
|
|
|
|
public UserVmVO getUserVM() {
|
|
return _userVM;
|
|
}
|
|
|
|
public NicVO getNicVo() {
|
|
return _nicVo;
|
|
}
|
|
|
|
public VMTemplateVO getTemplate() {
|
|
return _template;
|
|
}
|
|
} |