-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Error: private method `open' called for #<ActiveStorage::Attached::Many #127
Comments
Hi, I'm actually not using activestorage myself, but as you have a def copy
@source = Compitem.find(params[:id])
@source.deep_clone do |original, kopy|
if kopy.is_a?(Compitem) && original.uploads.attached?
original.uploads.each do |upload|
upload.open do |tempfile|
kopy.uploads.attach({
io: File.open(tempfile.path),
filename: upload.blob.filename,
content_type: upload.blob.content_type
})
end
end
end
end
render 'new'
end |
One more thing; I assume here that this is a simplified example. When you're not including associations in your copy, you might as well just use ActiveRecord's |
Thanks for getting back to me. The above code works to clone the record, but I still do not see the file attachments linked to the new record created. I also do not see entries in the active storage tables in the DB. I do see these entries in the log:
Anything else I am missing here? Also yes I was using dup at first which produced the same results. The record was cloned fine, but the attachments were not. |
When you're not including any associations, this gem does exactly the same as The ActiveStorage tests assign new blobs as follows. Looks about the same as my example, only my io object is a file IO instead of a StringIO. Maybe the IO object should be built differently? See also this comment, it might help. Could you let me know if you find out what the issue was? |
Looking at the code I would already rewrite it a little. Moreover, after reading this, I think using Resulting in this, I hope this works for you: def copy
@source = Compitem.find(params[:id])
@source.deep_clone do |original, kopy|
if kopy.is_a?(Compitem) && original.uploads.attached?
new_blobs = original.uploads.map do |upload|
{ io: StringIO.new(upload.download), filename: upload.filename, content_type: upload.content_type }
end
kopy.uploads.attach(*new_blobs)
end
end
render 'new'
end |
Thanks for the help! I am playing around with this now. On the above code I am getting the error: ActiveStorage::FileNotFoundError on { io: StringIO.new(upload.download), filename: upload.filename, content_type: upload.content_type } |
@spacerobotTR In that case it looks like one or more of the original uploads are already broken somehow? |
I think I am close. It runs without error but now I am getting an error trying to display the form: undefined method `errors' for nil:NilClass
|
|
The following goes through fine without error, clones the record, but still does not clone the attachments. I am using active storage that write files to <%= Rails.root.join("public/uploads") %>. Do I need to specify that path?
|
I actually don't know how AR would be able to render copies in the form. Maybe you need to save the copy first and redirect to an edit form instead. |
Down and dirty do you know how I would keep the files and just copy the records in active storage to point to the same files? Without actually creating new files? |
As far as I know, AS uses has_many through associations for the blobs. So in theory, you could just achieve that by calling |
Strange. Same results. Record clones fine without error, but no attachment links. |
This also depends on how the form is rendered. You could also try to include via the direct association, for example |
Thanks I'll play around with it and see if I can get it to work. I appreciate the help! I know I went off topic on this one. |
I got it working! Final answer. Had to save:
|
I'm having a similar issue that I'm wondering if you could shed some light on. I'm iterating over a collection and making a bunch of copies, like so: def create_desks
coordinates = [
[0, 8],
[0, 13],
[5, 8],
[5, 13],
[10, 8],
[10, 13]
]
desk_prototype = Relic.find(73)
coordinates.each do |coord|
new_desk = desk_prototype.deep_clone include: [:sprite, :content], skip_missing_associations: true do |orig, kopy|
if orig.sprite.attached?
orig.sprite.open do |tempfile|
kopy.sprite.attach(
io: File.open(tempfile.path),
filename: orig.sprite.blob.filename,
content_type: orig.sprite.blob.content_type
)
end
end
if orig.image.attached?
kopy.image.attach(
io: File.open(tempfile.path),
filename: orig.image.blob.filename,
content_type: orig.image.blob.content_type
)
end
end
new_desk.x = coord.first
new_desk.y = coord.second
new_desk.team = self
new_desk.name = "Empty Desk"
new_desk.save!
end
end The issue: only the FIRST in the loop gets the attachments copied over. I've pulled my hair out and cannot for the life of me figure out why. Any ideas? |
You mean that only the first 'new_desk' with coordinates [0,8] gets the attachments and not the others? No clue actually :/ |
Yes. It's bizarre. |
Not sure what I am doing wrong. I am using rails 6 and attempting to clone a record and it's attached uploads. Any ideas why this is generating this error?
Model:
Copy method
The text was updated successfully, but these errors were encountered: