mirror of
https://github.com/coder/coder.git
synced 2025-07-15 22:20:27 +00:00
fix: allow example files to be reused and not error (#5402)
This commit is contained in:
@ -878,21 +878,39 @@ func (api *API) postTemplateVersionsByOrganization(rw http.ResponseWriter, r *ht
|
|||||||
// upload a copy of the template tar as a file in the database
|
// upload a copy of the template tar as a file in the database
|
||||||
hashBytes := sha256.Sum256(tar)
|
hashBytes := sha256.Sum256(tar)
|
||||||
hash := hex.EncodeToString(hashBytes[:])
|
hash := hex.EncodeToString(hashBytes[:])
|
||||||
file, err = api.Database.InsertFile(ctx, database.InsertFileParams{
|
// Check if the file already exists.
|
||||||
ID: uuid.New(),
|
file, err := api.Database.GetFileByHashAndCreator(ctx, database.GetFileByHashAndCreatorParams{
|
||||||
Hash: hash,
|
Hash: hash,
|
||||||
CreatedBy: apiKey.UserID,
|
CreatedBy: apiKey.UserID,
|
||||||
CreatedAt: database.Now(),
|
|
||||||
Mimetype: tarMimeType,
|
|
||||||
Data: tar,
|
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{
|
if !errors.Is(err, sql.ErrNoRows) {
|
||||||
Message: "Internal error creating file.",
|
httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{
|
||||||
Detail: err.Error(),
|
Message: "Internal error fetching file.",
|
||||||
|
Detail: err.Error(),
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the example tar file doesn't exist, create it.
|
||||||
|
file, err = api.Database.InsertFile(ctx, database.InsertFileParams{
|
||||||
|
ID: uuid.New(),
|
||||||
|
Hash: hash,
|
||||||
|
CreatedBy: apiKey.UserID,
|
||||||
|
CreatedAt: database.Now(),
|
||||||
|
Mimetype: tarMimeType,
|
||||||
|
Data: tar,
|
||||||
})
|
})
|
||||||
return
|
if err != nil {
|
||||||
|
httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{
|
||||||
|
Message: "Internal error creating file.",
|
||||||
|
Detail: err.Error(),
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
req.FileID = file.ID
|
||||||
}
|
}
|
||||||
|
|
||||||
if req.FileID != uuid.Nil {
|
if req.FileID != uuid.Nil {
|
||||||
|
@ -179,6 +179,15 @@ func TestPostTemplateVersionsByOrganization(t *testing.T) {
|
|||||||
tar, err := examples.Archive(ls[0].ID)
|
tar, err := examples.Archive(ls[0].ID)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.EqualValues(t, tar, fl)
|
require.EqualValues(t, tar, fl)
|
||||||
|
|
||||||
|
// ensure we don't get file conflicts on multiple uses of the same example
|
||||||
|
tv, err = client.CreateTemplateVersion(ctx, user.OrganizationID, codersdk.CreateTemplateVersionRequest{
|
||||||
|
Name: "my-example",
|
||||||
|
StorageMethod: codersdk.ProvisionerStorageMethodFile,
|
||||||
|
ExampleID: ls[0].ID,
|
||||||
|
Provisioner: codersdk.ProvisionerTypeEcho,
|
||||||
|
})
|
||||||
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user