-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fs: "fs" is a new provider with one first "file" resource.
This new provider will allow frieza to cleanup local resources like files and folders. This should also ease core testing. close #34 ref #35 Signed-off-by: Jérôme Jutteau <[email protected]>
- Loading branch information
1 parent
7825fe8
commit a78442f
Showing
3 changed files
with
128 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,23 +1 @@ | ||
# Providers and supported objects | ||
|
||
## s3 | ||
- object | ||
- bucket | ||
|
||
## outscale_oapi | ||
- vm | ||
- load_balancer | ||
- nat_service | ||
- security_group | ||
- public_ip | ||
- volume | ||
- keypair | ||
- route_table | ||
- internet_service | ||
- subnet | ||
- net | ||
- image | ||
- snapshot | ||
- vpn_connection | ||
- virtual_gateway | ||
- nic |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
package fs | ||
|
||
import ( | ||
"errors" | ||
"fmt" | ||
"log" | ||
"os" | ||
"path" | ||
|
||
. "github.com/outscale-dev/frieza/internal/common" | ||
"github.com/teris-io/cli" | ||
) | ||
|
||
const Name = "fs" | ||
const typeFile = "File" | ||
|
||
type FileProvider struct { | ||
Path string | ||
} | ||
|
||
func checkConfig(config ProviderConfig) error { | ||
if len(config["path"]) == 0 { | ||
return errors.New("path is needed") | ||
} | ||
return nil | ||
} | ||
|
||
func New(config ProviderConfig, debug bool) (*FileProvider, error) { | ||
if err := checkConfig(config); err != nil { | ||
return nil, err | ||
} | ||
return &FileProvider{ | ||
Path: config["path"], | ||
}, nil | ||
} | ||
|
||
func Types() []ObjectType { | ||
object_types := []ObjectType{typeFile} | ||
return object_types | ||
} | ||
|
||
func Cli() (string, cli.Command) { | ||
return Name, cli.NewCommand(Name, "create new file system profile"). | ||
WithOption(cli.NewOption("path", "folder path")) | ||
} | ||
|
||
func (provider *FileProvider) Name() string { | ||
return Name | ||
} | ||
|
||
func (provider *FileProvider) Types() []ObjectType { | ||
return Types() | ||
} | ||
|
||
func (provider *FileProvider) AuthTest() error { | ||
// Will test if we can access the folder | ||
if _, err := os.ReadDir(provider.Path); err != nil { | ||
return fmt.Errorf("cannot move to directory: %s", err.Error()) | ||
} | ||
return nil | ||
} | ||
|
||
func (provider *FileProvider) ReadObjects(typeName string) []Object { | ||
switch typeName { | ||
case typeFile: | ||
return provider.readFiles() | ||
} | ||
return []Object{} | ||
} | ||
|
||
func (provider *FileProvider) DeleteObjects(typeName string, objects []Object) { | ||
switch typeName { | ||
case typeFile: | ||
provider.deleteFiles(objects) | ||
} | ||
} | ||
|
||
func (provider *FileProvider) StringObject(object string, typeName string) string { | ||
return object | ||
} | ||
|
||
func (provider *FileProvider) readFiles() []Object { | ||
files := make([]Object, 0) | ||
|
||
if err := os.Chdir(provider.Path); err != nil { | ||
log.Printf("cannot move to directory: %s", err.Error()) | ||
return files | ||
} | ||
|
||
folderStack := []string{"."} | ||
for len(folderStack) > 0 { | ||
dirPath := folderStack[len(folderStack)-1] | ||
folderStack = folderStack[:len(folderStack)-1] | ||
dir, err := os.ReadDir(dirPath) | ||
if err != nil { | ||
log.Printf("cannot read directory: %s", err.Error()) | ||
continue | ||
} | ||
for _, node := range dir { | ||
nodePath := path.Join(dirPath, node.Name()) | ||
if node.IsDir() { | ||
folderStack = append(folderStack, nodePath) | ||
} | ||
if node.Type().IsRegular() { | ||
files = append(files, nodePath) | ||
} | ||
} | ||
} | ||
return files | ||
} | ||
|
||
func (provider *FileProvider) deleteFiles(files []Object) { | ||
for _, relativeFilePath := range files { | ||
filePath := path.Join(provider.Path, relativeFilePath) | ||
log.Printf("Deleting file %s ... ", filePath) | ||
if err := os.Remove(filePath); err != nil { | ||
log.Printf("cannot remove file %s\n", err.Error()) | ||
continue | ||
} | ||
log.Println("OK") | ||
} | ||
} |