feat: implement cmd management for targets, LUNs, and TPGTs (fixes #36)

- Fix target delete URL path mismatch (/targets/ -> /target/)
- Implement target create/delete server handlers with proper validation
- Add DeleteTarget method with force flag and mutex locking to SCSITargetService
- Implement full LU management: create/list/delete through CLI, client, and server
- Add TPGT list command to show target portal group tags
- Add unit tests for target/LU router handlers and SCSI service

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Lei Xue
2026-03-14 20:30:47 +08:00
parent bbd373ba0e
commit 93e1476a0f
16 changed files with 760 additions and 36 deletions

View File

@@ -0,0 +1,13 @@
package client
import (
"github.com/gostor/gotgt/pkg/api"
"golang.org/x/net/context"
)
// LuCreate creates a LU in the SCSI Target.
func (cli *Client) LuCreate(ctx context.Context, options api.LuCreateRequest) error {
resp, err := cli.post(ctx, "/lu/create", nil, options, nil)
ensureReaderClosed(resp)
return err
}

View File

@@ -0,0 +1,13 @@
package client
import (
"github.com/gostor/gotgt/pkg/api"
"golang.org/x/net/context"
)
// LuRemove removes a LU from a target in the SCSI Target.
func (cli *Client) LuRemove(ctx context.Context, options api.LuRemoveOptions) error {
resp, err := cli.post(ctx, "/lu/delete", nil, options, nil)
ensureReaderClosed(resp)
return err
}

25
pkg/api/client/lu_list.go Normal file
View File

@@ -0,0 +1,25 @@
package client
import (
"encoding/json"
"net/url"
"github.com/gostor/gotgt/pkg/api"
"golang.org/x/net/context"
)
// LuList lists LUs for a target in the SCSI Target.
func (cli *Client) LuList(ctx context.Context, options api.LuListOptions) ([]api.LuInfo, error) {
var lus []api.LuInfo
query := url.Values{}
if options.TargetName != "" {
query.Set("target", options.TargetName)
}
resp, err := cli.get(ctx, "/lu/list", query, nil)
if err != nil {
return lus, err
}
err = json.NewDecoder(resp.body).Decode(&lus)
ensureReaderClosed(resp)
return lus, err
}

View File

@@ -29,7 +29,7 @@ func (cli *Client) TargetRemove(ctx context.Context, options api.TargetRemoveOpt
if options.Force {
query.Set("force", "1")
}
resp, err := cli.delete(ctx, "/targets/"+options.Name, query, nil)
resp, err := cli.delete(ctx, "/target/"+options.Name, query, nil)
ensureReaderClosed(resp)
return err
}

View File

@@ -0,0 +1,25 @@
package client
import (
"encoding/json"
"net/url"
"github.com/gostor/gotgt/pkg/api"
"golang.org/x/net/context"
)
// TpgtList lists TPGTs for a target in the SCSI Target.
func (cli *Client) TpgtList(ctx context.Context, options api.TpgtListOptions) ([]api.TpgtInfo, error) {
var tpgts []api.TpgtInfo
query := url.Values{}
if options.TargetName != "" {
query.Set("target", options.TargetName)
}
resp, err := cli.get(ctx, "/target/tpgt/list", query, nil)
if err != nil {
return tpgts, err
}
err = json.NewDecoder(resp.body).Decode(&tpgts)
ensureReaderClosed(resp)
return tpgts, err
}