|  | @@ -1,7 +1,6 @@
 | 
											
												
													
														|  |  package samba
 |  |  package samba
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import (
 |  |  import (
 | 
											
												
													
														|  | -	"errors"
 |  | 
 | 
											
												
													
														|  |  	"fmt"
 |  |  	"fmt"
 | 
											
												
													
														|  |  	"log"
 |  |  	"log"
 | 
											
												
													
														|  |  	"os/exec"
 |  |  	"os/exec"
 | 
											
										
											
												
													
														|  | @@ -16,7 +15,7 @@ import (
 | 
											
												
													
														|  |  Functions requested by the file server service router
 |  |  Functions requested by the file server service router
 | 
											
												
													
														|  |  */
 |  |  */
 | 
											
												
													
														|  |  func (m *ShareManager) ServerToggle(enabled bool) error {
 |  |  func (m *ShareManager) ServerToggle(enabled bool) error {
 | 
											
												
													
														|  | -	return errors.New("not supported")
 |  | 
 | 
											
												
													
														|  | 
 |  | +	return SetSmbdEnableState(enabled)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  func (m *ShareManager) IsEnabled() bool {
 |  |  func (m *ShareManager) IsEnabled() bool {
 | 
											
										
											
												
													
														|  | @@ -29,13 +28,31 @@ func (m *ShareManager) IsEnabled() bool {
 | 
											
												
													
														|  |  	return smbdRunning
 |  |  	return smbdRunning
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func (m *ShareManager) GetEndpoints(userinfo *user.User) []*fileservers.Endpoint {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func (m *ShareManager) GetEndpoints(userInfo *user.User) []*fileservers.Endpoint {
 | 
											
												
													
														|  | 
 |  | +	//Get a list of connection endpoint for this user
 | 
											
												
													
														|  |  	eps := []*fileservers.Endpoint{}
 |  |  	eps := []*fileservers.Endpoint{}
 | 
											
												
													
														|  | -	eps = append(eps, &fileservers.Endpoint{
 |  | 
 | 
											
												
													
														|  | -		ProtocolName: "//",
 |  | 
 | 
											
												
													
														|  | -		Port:         0,
 |  | 
 | 
											
												
													
														|  | -		Subpath:      "/",
 |  | 
 | 
											
												
													
														|  | -	})
 |  | 
 | 
											
												
													
														|  | 
 |  | +	for _, fsh := range userInfo.GetAllAccessibleFileSystemHandler() {
 | 
											
												
													
														|  | 
 |  | +		if fsh.IsNetworkDrive() {
 | 
											
												
													
														|  | 
 |  | +			continue
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +		fshID := fsh.UUID
 | 
											
												
													
														|  | 
 |  | +		if fsh.RequierUserIsolation() {
 | 
											
												
													
														|  | 
 |  | +			//User seperated storage. Only mount the user one
 | 
											
												
													
														|  | 
 |  | +			fshID = userInfo.Username + "_" + fsh.UUID
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +		shareExists, err := m.ShareExists(fshID)
 | 
											
												
													
														|  | 
 |  | +		if err != nil || !shareExists {
 | 
											
												
													
														|  | 
 |  | +			continue
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +		eps = append(eps, &fileservers.Endpoint{
 | 
											
												
													
														|  | 
 |  | +			ProtocolName: "//",
 | 
											
												
													
														|  | 
 |  | +			Port:         0,
 | 
											
												
													
														|  | 
 |  | +			Subpath:      "/" + fshID,
 | 
											
												
													
														|  | 
 |  | +		})
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	return eps
 |  |  	return eps
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 |