<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Oct 30, 2014 at 12:02 PM, Shahar Havivi <span dir="ltr"><<a href="mailto:shaharh@redhat.com" target="_blank">shaharh@redhat.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">On 30.10.14 10:06, Branimir Pejakovic wrote:<br>
> On Thu, Oct 30, 2014 at 7:22 AM, Shahar Havivi <<a href="mailto:shaharh@redhat.com">shaharh@redhat.com</a>> wrote:<br>
><br>
> > On 29.10.14 17:35, Branimir Pejakovic wrote:<br>
> > > Hi list,<br>
> > ><br>
> > > I was wondering is there a way to add multiple files to a vm via<br>
> > cloud-init<br>
> > > using python SDK. I was able to add /etc/resolv.conf and additionally I<br>
> > > would like to add config files for NICs (ifcfg-ethX) with appropriate<br>
> > > values (ip,gw,netmask). I used an example given here:<br>
> > > <a href="http://www.ovirt.org/Features/Cloud-Init_Integration" target="_blank">http://www.ovirt.org/Features/Cloud-Init_Integration</a> . But<br>
> > unfortunately I<br>
> > > cannot do the same thing If I want to write multiple files to a vm in<br>
> > > params.Action class.<br>
> > ><br>
> > > Thank you in advance!<br>
> > you can use the custom script text box in oVirts cloud-init section,<br>
> > there you can add any cloud-init section - adding files examples can be<br>
> > found<br>
> > here:<br>
> ><br>
> > <a href="http://cloudinit.readthedocs.org/en/latest/topics/examples.html#writing-out-arbitrary-files" target="_blank">http://cloudinit.readthedocs.org/en/latest/topics/examples.html#writing-out-arbitrary-files</a><br>
> ><br>
> > Shahar Havivi.<br>
> ><br>
> ><br>
> Hi Shahar,<br>
><br>
> Thank you for the reply.<br>
><br>
> To be honest I knew for those scripts but I want to do it in automate<br>
> fashion just like in that example that I put in my original message. I have<br>
> tried to specify in params.Files class multiple files:<br>
><br>
> vm_file1 = params.Files(file=[params.File(name = 'file1', content =<br>
> file1_content, type_= 'PLAINTEXT')])<br>
> vm_file2 = params.Files(file=[params.File(name = 'file2', content =<br>
> file2_content, type_= 'PLAINTEXT')])<br>
><br>
> and then give them as arguments to params.CloudInit _init_ constructor<br>
> (files=...) just like in that example above but it seems that I am doing<br>
> something wrong because it does not write multiple files - it writes only<br>
> when you specify one file all right. The exception is "Error: 'list' object<br>
> has no attribute 'export'" (I tried to specify those files as a list -<br>
> files=[vm_file1,vm_file2]).<br>
><br>
> Thanks for any help.<br>
</div></div>The custom script is currently the only option to add files via Cloud-Init<br>
<br>
Thanks,<br>
<div class=""><div class="h5"> Shahar Havivi.<br>
<br clear="all"></div></div></blockquote><div><br><div>Hi Shahar,<br><br></div><div>Granted. But the example in python <a href="http://www.ovirt.org/Features/Cloud-Init_Integration" target="_blank">http://www.ovirt.org/Features/Cloud-Init_Integration</a>
uses custom script :) I just want to know how to do the same thing in
case when I want to write more than one file to a VM - and yes - all
those multiple files that I want to write are specified via custom scripts.<br><br></div><div>From the link - (The "Python SDK" paragraph: scontent object holds the custom script):<br><pre> scontent = "write_files:\n- content: |\n search <a href="http://example.com">example.com</a>\n nameserver 10.10.10.1\n nameserver 10.10.10.2\n path: /etc/resolv.conf"</pre>For
example (and just for example), I want to write to /etc/issue and
/etc/hosts not only /etc/resolv.conf. In essence, when vm goes to run-once mode I want to write more than one file to a vm via Python (using CloudInit) in
automated fashion (and not touching oVirt GUI at all). <br><br></div><div>Thanks in advance!<br><br></div>Best regards,<br><br>Branimir <br></div></div><br><div class="gmail_signature"><div dir="ltr"><div><br></div></div></div>
</div></div>