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