My fork of airsonic with experimental fixes and improvements. See branch "custom"
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

197 lines
5.0 KiB

/*
This file is part of Libresonic.
Libresonic is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Libresonic 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 Libresonic. If not, see <http://www.gnu.org/licenses/>.
Copyright 2016 (C) Libresonic Authors
Based upon Subsonic, Copyright 2009 (C) Sindre Mehus
*/
package org.libresonic.player.domain;
import com.google.common.base.Function;
import com.google.common.base.Objects;
import com.google.common.collect.Lists;
import java.io.File;
import java.io.Serializable;
import java.util.Date;
import java.util.List;
/**
* Represents a top level directory in which music or other media is stored.
*
* @author Sindre Mehus
* @version $Revision: 1.1 $ $Date: 2005/11/27 14:32:05 $
*/
public class MusicFolder implements Serializable {
private Integer id;
private File path;
private String name;
private boolean isEnabled;
private Date changed;
/**
* Creates a new music folder.
*
* @param id The system-generated ID.
* @param path The path of the music folder.
* @param name The user-defined name.
* @param enabled Whether the folder is enabled.
* @param changed When the corresponding database entry was last changed.
*/
public MusicFolder(Integer id, File path, String name, boolean enabled, Date changed) {
this.id = id;
this.path = path;
this.name = name;
isEnabled = enabled;
this.changed = changed;
}
/**
* Creates a new music folder.
*
* @param path The path of the music folder.
* @param name The user-defined name.
* @param enabled Whether the folder is enabled.
* @param changed When the corresponding database entry was last changed.
*/
public MusicFolder(File path, String name, boolean enabled, Date changed) {
this(null, path, name, enabled, changed);
}
/**
* Returns the system-generated ID.
*
* @return The system-generated ID.
*/
public Integer getId() {
return id;
}
/**
* Returns the path of the music folder.
*
* @return The path of the music folder.
*/
public File getPath() {
return path;
}
/**
* Sets the path of the music folder.
*
* @param path The path of the music folder.
*/
public void setPath(File path) {
this.path = path;
}
/**
* Returns the user-defined name.
*
* @return The user-defined name.
*/
public String getName() {
return name;
}
/**
* Sets the user-defined name.
*
* @param name The user-defined name.
*/
public void setName(String name) {
this.name = name;
}
/**
* Returns whether the folder is enabled.
*
* @return Whether the folder is enabled.
*/
public boolean isEnabled() {
return isEnabled;
}
/**
* Sets whether the folder is enabled.
*
* @param enabled Whether the folder is enabled.
*/
public void setEnabled(boolean enabled) {
isEnabled = enabled;
}
/**
* Returns when the corresponding database entry was last changed.
*
* @return When the corresponding database entry was last changed.
*/
public Date getChanged() {
return changed;
}
/**
* Sets when the corresponding database entry was last changed.
*
* @param changed When the corresponding database entry was last changed.
*/
public void setChanged(Date changed) {
this.changed = changed;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
return Objects.equal(id, ((MusicFolder) o).id);
}
@Override
public int hashCode() {
return Objects.hashCode(id);
}
public static List<Integer> toIdList(List<MusicFolder> from) {
return Lists.transform(from, toId());
}
public static List<String> toPathList(List<MusicFolder> from) {
return Lists.transform(from, toPath());
}
public static Function<MusicFolder, Integer> toId() {
return new Function<MusicFolder, Integer>() {
@Override
public Integer apply(MusicFolder from) {
return from.getId();
}
};
}
public static Function<MusicFolder, String> toPath() {
return new Function<MusicFolder, String>() {
@Override
public String apply(MusicFolder from) {
return from.getPath().getPath();
}
};
}
}