def add_asset_to_envelope(request): envelope_id = get_parameter_from_request(request, 'envelope_id', True) latitude = get_parameter_from_request(request, 'latitude', False) longitude = get_parameter_from_request(request, 'longitude', False) if latitude == None: latitude = 0.0 if longitude == None: longitude = 0.0 tagset = [] tags = get_parameter_from_request(request, 'tags', False) if tags != None: ids = tags.split(',') tagset = models.Tag.objects.filter(id__in=ids) envelope = models.Envelope.objects.get(id=envelope_id) session = envelope.session submitted = get_parameter_from_request(request, 'submitted', False) if submitted == None: submitted=session.project.auto_submit db.log_event("start_upload", session.id,request.GET) fileitem = request.FILES.get('file') if fileitem.name: logging.debug("Processing " + fileitem.name) (filename_prefix, filename_extension) = \ os.path.splitext(fileitem.name) fn = time.strftime("%Y%m%d-%H%M%S") + filename_extension fileout = open(os.path.join(settings.config["upload_dir"], fn), 'wb') fileout.write(fileitem.file.read()) fileout.close() newfilename = convertaudio.convert_uploaded_file(fn) if newfilename: asset = models.Asset(latitude=latitude,longitude=longitude, filename=newfilename, session=session, submitted=submitted, volume=1.0) asset.project = session.project asset.save() for t in tagset: asset.tags.add(t) discover_audiolength.discover_and_set_audiolength(asset, newfilename) asset.save() envelope.assets.add(asset) envelope.save() else: raise RoundException("File not converted successfully: " + newfilename) else: raise RoundException("No file in request") rounddbus.emit_stream_signal(0, "refresh_recordings", "") return {"success":True}
def process_recorded_file_helper (user, request, filename, submityn): newfilename = convertaudio.convert_uploaded_file(filename) #TODO: For now it's easiest to call these three functions because they already #exist, but in the long term, it'll be more efficient to just create one row in the #database instead of creating, and updating it twice like I'm doing here. if newfilename: recordingid = db.store_recording(user, request, newfilename) discover_audiolength.discover_and_set_audiolength(recordingid, newfilename) if submityn == 'Y': db.submit_recording(recordingid) return recordingid else: raise RoundException("File not converted successfully: " + newfilename)
def add_asset_to_envelope(request): #get asset_id from the GET request asset_id = get_parameter_from_request(request, 'asset_id', False) asset = None #grab the Asset from the database, if an asset_id has been passed in if asset_id: try: asset = models.Asset.objects.get(pk=asset_id) except models.Asset.DoesNotExist: raise roundexception.RoundException( "Invalid Asset ID Provided. No Asset exists with ID %s" % asset_id) envelope_id = get_parameter_from_request(request, 'envelope_id', True) envelope = models.Envelope.objects.select_related('session').get( id=envelope_id) session = envelope.session db.log_event("start_upload", session.id, request.GET) fileitem = request.FILES.get('file') if not asset else asset.file #get mediatype from the GET request mediatype = get_parameter_from_request( request, 'mediatype', False) if not asset else asset.mediatype #if mediatype parameter not passed, set to 'audio' #this ensures backwards compatibility if mediatype is None: mediatype = "audio" if fileitem.name: #copy the file to a unique name (current time and date) logging.debug("Processing " + fileitem.name) (filename_prefix, filename_extension) = \ os.path.splitext(fileitem.name) fn = time.strftime("%Y%m%d-%H%M%S") + filename_extension fileout = open(os.path.join(settings.config["upload_dir"], fn), 'wb') fileout.write(fileitem.file.read()) fileout.close() #delete the uploaded original after the copy has been made if asset: asset.file.delete() # re-assign file to asset asset.file.name = fn asset.filename = fn asset.save() #make sure everything is in wav form only if mediatype is audio if mediatype == "audio": newfilename = convertaudio.convert_uploaded_file(fn) else: newfilename = fn if newfilename: #create the new asset if request comes in from a source other #than the django admin interface if not asset: #get location data from request latitude = get_parameter_from_request(request, 'latitude', False) longitude = get_parameter_from_request(request, 'longitude', False) #if no location data in request, default to project latitude and longitude if not latitude: latitude = session.project.latitude if not longitude: longitude = session.project.longitude tagset = [] tags = get_parameter_from_request(request, 'tags', False) if tags is not None: ids = tags.split(',') tagset = models.Tag.objects.filter(id__in=ids) # get optional submitted parameter from request (Y, N or blank string are only acceptable values) submitted = get_parameter_from_request(request, 'submitted', False) # set submitted variable to proper boolean value if it is passed as parameter if submitted == "N": submitted = False elif submitted == "Y": submitted = True # if blank string or not included as parameter, check if in range of project and if so # set asset.submitted based on project.auto_submit boolean value elif submitted is None or len(submitted) == 0: submitted = False if is_listener_in_range_of_stream(request.GET, session.project): submitted = session.project.auto_submit asset = models.Asset(latitude=latitude, longitude=longitude, filename=newfilename, session=session, submitted=submitted, mediatype=mediatype, volume=1.0, language=session.language, project=session.project) asset.file.name = fn asset.save() for t in tagset: asset.tags.add(t) #if the request comes from the django admin interface #update the Asset with the right information else: #update asset with session asset.session = session asset.filename = newfilename #get the audiolength of the file only if mediatype is audio and update the Asset if mediatype == "audio": discover_audiolength.discover_and_set_audiolength( asset, newfilename) asset.save() envelope.assets.add(asset) envelope.save() else: raise roundexception.RoundException( "File not converted successfully: " + newfilename) else: raise roundexception.RoundException("No file in request") rounddbus.emit_stream_signal(0, "refresh_recordings", "") return {"success": True, "asset_id": asset.id}
def add_asset_to_envelope(request): #get asset_id from the GET request asset_id = get_parameter_from_request(request, 'asset_id', False) asset = None #grab the Asset from the database, if an asset_id has been passed in if asset_id: try: asset = models.Asset.objects.get(pk=asset_id) except models.Asset.DoesNotExist: raise roundexception.RoundException("Invalid Asset ID Provided. No Asset exists with ID %s" % asset_id) envelope_id = get_parameter_from_request(request, 'envelope_id', True) envelope = models.Envelope.objects.select_related('session').get(id=envelope_id) session = envelope.session db.log_event("start_upload", session.id, request.GET) fileitem = request.FILES.get('file') if not asset else asset.file #get mediatype from the GET request mediatype = get_parameter_from_request(request, 'mediatype', False) if not asset else asset.mediatype #if mediatype parameter not passed, set to 'audio' #this ensures backwards compatibility if mediatype is None: mediatype = "audio" if fileitem.name: #copy the file to a unique name (current time and date) logging.debug("Processing " + fileitem.name) (filename_prefix, filename_extension) = \ os.path.splitext(fileitem.name) fn = time.strftime("%Y%m%d-%H%M%S") + filename_extension fileout = open(os.path.join(settings.config["upload_dir"], fn), 'wb') fileout.write(fileitem.file.read()) fileout.close() #delete the uploaded original after the copy has been made if asset: asset.file.delete() # re-assign file to asset asset.file.name = fn asset.filename = fn asset.save() #make sure everything is in wav form only if mediatype is audio if mediatype == "audio": newfilename = convertaudio.convert_uploaded_file(fn) else: newfilename = fn if newfilename: #create the new asset if request comes in from a source other #than the django admin interface if not asset: #get location data from request latitude = get_parameter_from_request(request, 'latitude', False) longitude = get_parameter_from_request(request, 'longitude', False) #if no location data in request, default to project latitude and longitude if not latitude: latitude = session.project.latitude if not longitude: longitude = session.project.longitude tagset = [] tags = get_parameter_from_request(request, 'tags', False) if tags is not None: ids = tags.split(',') tagset = models.Tag.objects.filter(id__in=ids) # get optional submitted parameter from request (Y, N or blank string are only acceptable values) submitted = get_parameter_from_request(request, 'submitted', False) # set submitted variable to proper boolean value if it is passed as parameter if submitted == "N": submitted = False elif submitted == "Y": submitted = True # if blank string or not included as parameter, check if in range of project and if so # set asset.submitted based on project.auto_submit boolean value elif submitted is None or len(submitted) == 0: submitted = False if is_listener_in_range_of_stream(request.GET, session.project): submitted = session.project.auto_submit asset = models.Asset(latitude=latitude, longitude=longitude, filename=newfilename, session=session, submitted=submitted, mediatype=mediatype, volume=1.0, language=session.language, project = session.project) asset.file.name = fn asset.save() for t in tagset: asset.tags.add(t) #if the request comes from the django admin interface #update the Asset with the right information else: #update asset with session asset.session = session asset.filename = newfilename #get the audiolength of the file only if mediatype is audio and update the Asset if mediatype == "audio": discover_audiolength.discover_and_set_audiolength(asset, newfilename) asset.save() envelope.assets.add(asset) envelope.save() else: raise roundexception.RoundException("File not converted successfully: " + newfilename) else: raise roundexception.RoundException("No file in request") rounddbus.emit_stream_signal(0, "refresh_recordings", "") return {"success": True, "asset_id": asset.id}