it probably never came up because the usecase is indeed weird .... the only 
change I can think of is that record archiving used to archive a row for 
every modification, even if all the fields were unchanged. The "new" method 
stores an archive row only if something changes, and I guess it's in that 
loop of checking differences with the current that it stumbles...

On Thursday, September 10, 2015 at 6:31:28 PM UTC+2, Jim S wrote:
>
> Because I'm lazy.
>
> In some of my code I do this:
>
> #  Set all fields as not editable
> for field in db.contact.fields:
>  db.contact[field].writable = False
>
>
> #  Enable the specific fields that will be editable in the form
> db.contact.first_name.writable = True
> db.contact.last_name.writable = True
>
>
>
> I can then set which fields are writable based on different access levels. 
>  Obviously I just need to exclude the 'id' field where I set writable to 
> False.  But, this is where it came from.
>
> -Jim
>
>
>
> On Thursday, September 10, 2015 at 10:07:22 AM UTC-5, Niphlod wrote:
>>
>> uhm. why the id should be set to not writable ? it is not writable by 
>> default because it's an identity .....
>>
>> On Thursday, September 10, 2015 at 4:54:35 PM UTC+2, Jim S wrote:
>>>
>>> I just fixed an issue I was having - it used to work so much be a newer 
>>> version of web2py that introduced it (I think, cannot confirm that it 
>>> worked on earlier version)
>>>
>>> I have a table with record versioning active.  I'm updating it via 
>>> SQLFORM.grid but before the SQLFORM.grid call I was making the 'id' field 
>>> non-writable.     db.contact.id.writable = False
>>>
>>> With that in place I'm getting this traceback...
>>>
>>> Traceback (most recent call last):
>>>  File "C:\dev\web2py\gluon\restricted.py", line 227, in restricted
>>>  exec ccode in environment
>>>  File "C:/dev/web2py/applications/connect/controllers/contacts.py" 
>>> <http://127.0.0.1:8000/admin/default/edit/connect/controllers/contacts.py>, 
>>> line 892, in <module>
>>>  File "C:\dev\web2py\gluon\globals.py", line 412, in <lambda>
>>>  self._caller = lambda f: f()
>>>  File "C:\dev\web2py\gluon\tools.py", line 3775, in f
>>>  return action(*a, **b)
>>>  File "C:/dev/web2py/applications/connect/controllers/contacts.py" 
>>> <http://127.0.0.1:8000/admin/default/edit/connect/controllers/contacts.py>, 
>>> line 231, in index
>>>  paginate=15, maxtextlength=45, formstyle=my_formstyle, ui=grid_ui)
>>>  File "C:\dev\web2py\gluon\sqlhtml.py", line 2308, in grid
>>>  next=referrer)
>>>  File "C:\dev\web2py\gluon\html.py", line 2301, in process
>>>  self.validate(**kwargs)
>>>  File "C:\dev\web2py\gluon\html.py", line 2238, in validate
>>>  if self.accepts(**kwargs):
>>>  File "C:\dev\web2py\gluon\sqlhtml.py", line 1709, in accepts
>>>  self.id_field_name]).update(**fields)
>>>  File "C:\dev\web2py\gluon\packages\dal\pydal\objects.py", line 2045, in 
>>> update
>>>  if any(f(self,update_fields) for f in table._before_update):
>>>  File "C:\dev\web2py\gluon\packages\dal\pydal\objects.py", line 2045, in 
>>> <genexpr>
>>>  if any(f(self,update_fields) for f in table._before_update):
>>>  File "C:\dev\web2py\gluon\packages\dal\pydal\objects.py", line 415, in 
>>> <lambda>
>>>  archive_record(qset, fs, db[an], cn))
>>>  File "C:\dev\web2py\gluon\packages\dal\pydal\helpers\methods.py", line 91, 
>>> in archive_record
>>>  if fields[k] != v:
>>> KeyError: 'id'
>>>
>>>
>>> With the 'id' field writable I do not get the traceback.
>>>
>>> Version 2.12.3-stable+timestamp.2015.08.18.19.14.07
>>>
>>> Should this be reported as a bug or is it just me having issues?
>>>
>>>

-- 
Resources:
- http://web2py.com
- http://web2py.com/book (Documentation)
- http://github.com/web2py/web2py (Source code)
- https://code.google.com/p/web2py/issues/list (Report Issues)
--- 
You received this message because you are subscribed to the Google Groups 
"web2py-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to web2py+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to