/* * AndFHEM - Open Source Android application to control a FHEM home automation * server. * * Copyright (c) 2011, Matthias Klass or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors. All third-party contributions are * distributed under license by Red Hat Inc. * * This copyrighted material is made available to anyone wishing to use, modify, * copy, or redistribute it subject to the terms and conditions of the GNU GENERAL PUBLIC LICENSE, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU GENERAL PUBLIC LICENSE * for more details. * * You should have received a copy of the GNU GENERAL PUBLIC LICENSE * along with this distribution; if not, write to: * Free Software Foundation, Inc. * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301 USA */ package li.klass.fhem.util.io; import android.content.Context; import android.os.Build; import android.os.Environment; import java.io.File; import javax.inject.Inject; import javax.inject.Singleton; import static com.google.common.base.Preconditions.checkArgument; @Singleton public class FileSystemService { @Inject public FileSystemService() { } public File getDocumentsFolder() { File directory; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { directory = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOCUMENTS); } else { String path = Environment.getExternalStorageDirectory().getAbsolutePath() + "/Documents"; directory = new File(path); } if (!directory.exists()) { checkArgument(directory.mkdir()); } return directory; } public File getOrCreateDirectoryIn(File file, String directoryName) { checkArgument(file.exists() && file.isDirectory()); File newFile = new File(file, directoryName); if (!newFile.exists()) { checkArgument(newFile.mkdir()); } return newFile; } public File getCacheDir(Context context) { return context.getCacheDir(); } }