def validate_title(self, value): if self.edit: return slug = slugify(value) obj = db.get(db.Key.from_path('Recipe', slug, parent=get_request().user.key())) if obj: raise validators.ValidationError(u"Masz już przepis o zbliżonej nazwie. Użyj innej.")
def post(self): if self.form.validate(self.request.form): try: # utwórz przepis recipe = models.Recipe( parent=self.request.user, key_name=slugify(self.form['title']), title=self.form['title'], recipe=self.form['recipe'], recipe_html=markdown2html(self.form['recipe']), tags=models.Tag.split_elements(self.form['tags']), category=self.form['category'], phase=self.form['phase'], type=self.form['type'], ig=self.form['ig'], time=int(self.form['time']), rec_vis=self.form['rec_vis'], ingr_count=len(self.form['ingr']), disabled=False ) # zapisz dane przepisu recipe.put() # dodaj osobno skladniki # + AC składników ingr_to_save = [] for i, ingr in enumerate(self.form['ingr']): ingr_to_save.append(models.RecipeIngr(parent=recipe, key_name='%2d'%(i+1), product=ingr['product'], portion=ingr['portion'], weight=ingr['weight'])) ingr_to_save.append(models.IngrACIndex(key_name=ingr['product'], idx=models.IngrACIndex.make_index(ingr['product']))) db.put(ingr_to_save) # uaktualnij użytkownika if recipe.rec_vis == VISIBILITY[2]: def utx(): user = PMMUser.get(self.request.user.key()) user.rec_pub += 1 user.put() cache_delete('gfcu', self.request.user.key().name()) db.run_in_transaction(utx) # Dodaj podwójny licznik... Counter.init_shards(SHARD_RECIPE_KEY % recipe.key(), 2) # 2 means about 15 writes/s per recipe # na później odłóż indeksację, uaktualnienie tagów i licznika kategorii deferred_lib.defer(deferred.recipe_update, recipe.key(), 'add') # wyślij powiadomienie o dodaniu przepisu! if recipe.rec_vis != VISIBILITY[0]: try: create_activity(self.request.user.key().name(), u'%s dodał(a) przepis <a href="%s">%s</a>' % (self.request.user.display_name, recipe.get_url(True), recipe.title), u'Przejrzyj go, oceń lub dodaj do ulubionych.' ) except Exception, e: pass self.request.notifications.success('Przepis dodany!') return redirect(recipe.get_url()) except Exception, e: logging.exception('Recipe add failed (%s): ' % self.request.user + str(e)) self.request.notifications.error('Przepisu nie dodano! Wystąpił błąd zapisu, spróbuj ponownie...')
def put(self): if not self.is_saved(): # TODO: we are risking having the same slug for several props! self.slug = slugify(self.key().name()) super(Tag, self).put()