// 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 org.apache.cloudstack.storage.datastore.provider; import java.util.HashSet; import java.util.Map; import java.util.Set; import javax.inject.Inject; import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreLifeCycle; import org.apache.cloudstack.engine.subsystem.api.storage.HypervisorHostListener; import org.apache.cloudstack.engine.subsystem.api.storage.PrimaryDataStoreDriver; import org.apache.cloudstack.engine.subsystem.api.storage.PrimaryDataStoreProvider; import org.apache.cloudstack.storage.datastore.PrimaryDataStoreProviderManager; import org.apache.cloudstack.storage.datastore.driver.SamplePrimaryDataStoreDriverImpl; import org.apache.cloudstack.storage.datastore.lifecycle.SamplePrimaryDataStoreLifeCycleImpl; import com.cloud.utils.component.ComponentContext; public class SamplePrimaryDatastoreProviderImpl implements PrimaryDataStoreProvider { private final String providerName = "sample primary data store provider"; protected PrimaryDataStoreDriver driver; protected HypervisorHostListener listener; @Inject PrimaryDataStoreProviderManager storeMgr; protected DataStoreLifeCycle lifecycle; @Override public String getName() { return providerName; } @Override public DataStoreLifeCycle getDataStoreLifeCycle() { return this.lifecycle; } @Override public boolean configure(Map<String, Object> params) { lifecycle = ComponentContext.inject(SamplePrimaryDataStoreLifeCycleImpl.class); driver = ComponentContext.inject(SamplePrimaryDataStoreDriverImpl.class); listener = ComponentContext.inject(DefaultHostListener.class); return true; } @Override public PrimaryDataStoreDriver getDataStoreDriver() { return this.driver; } @Override public HypervisorHostListener getHostListener() { return this.listener; } @Override public Set<DataStoreProviderType> getTypes() { Set<DataStoreProviderType> types = new HashSet<DataStoreProviderType>(); types.add(DataStoreProviderType.PRIMARY); return types; } }