예제 #1
0
파일: views.py 프로젝트: soitun/commcare-hq
    def post(self, request, *args, **kwargs):
        handle = request.FILES['bulk_upload_file']
        extension = os.path.splitext(handle.name)[1][1:].strip().lower()
        if extension not in valid_extensions:
            messages.error(request, _("Please choose a file with one of the following extensions: "
                                      "{}").format(", ".join(valid_extensions)))
            return self.get(request, *args, **kwargs)

        meta = transient_file_store.write_file(handle, handle.name, self.domain)
        file_id = meta.identifier

        f = transient_file_store.get_tempfile_ref_for_contents(file_id)
        try:
            open_spreadsheet_download_ref(f)
        except SpreadsheetFileExtError:
            messages.error(request, _("File does not appear to be an Excel file. Please choose another file."))
            return self.get(request, *args, **kwargs)

        from corehq.apps.app_manager.views.media_utils import interpolate_media_path
        from corehq.apps.hqmedia.view_helpers import validate_multimedia_paths_rows, update_multimedia_paths

        # Get rows, filtering out header, no-ops, and any extra "Usages" columns
        rows = []
        with get_spreadsheet(f) as spreadsheet:
            for row in list(spreadsheet.iter_rows())[1:]:
                if row[1]:
                    rows.append(row[:2])

        (errors, warnings) = validate_multimedia_paths_rows(self.app, rows)
        if len(errors):
            for msg in errors:
                messages.error(request, msg, extra_tags='html')
            return self.get(request, *args, **kwargs)

        paths = {
            row[0]: interpolate_media_path(row[1]) for row in rows if row[1]
        }
        successes = update_multimedia_paths(self.app, paths)
        self.app.save()

        # Force all_media to reset
        self.app.all_media.reset_cache(self.app)
        self.app.all_media_paths.reset_cache(self.app)

        # Warn if any old paths remain in app (because they're used in a place this function doesn't know about)
        warnings = []
        self.app.remove_unused_mappings()
        app_paths = {m.path: True for m in self.app.all_media()}
        for old_path, new_path in paths.items():
            if old_path in app_paths:
                warnings.append(_("Could not completely update path <code>{}</code>, "
                                  "please check app for remaining references.").format(old_path))

        for msg in successes:
            messages.success(request, msg, extra_tags='html')
        for msg in warnings:
            messages.warning(request, msg, extra_tags='html')
        return self.get(request, *args, **kwargs)
예제 #2
0
    def check_file(self):
        """
        open a spreadsheet download ref just to test there are no errors opening it

        :raise ImporterError subtypes
        """
        tempfile = self.get_tempfile()
        if not tempfile:
            raise ImporterRefError('file not found in cache')
        open_spreadsheet_download_ref(tempfile)
예제 #3
0
    def check_file(self):
        """
        open a spreadsheet download ref just to test there are no errors opening it

        :raise ImporterError subtypes
        """
        tempfile = self.get_tempfile()
        if not tempfile:
            raise ImporterRefError('file not found in cache')
        open_spreadsheet_download_ref(tempfile)
예제 #4
0
def update_multimedia_paths(request, domain, app_id):
    if not request.FILES:
        return json_response(
            {'error': _("Please choose an Excel file to import.")})

    handle = request.FILES['file']

    extension = os.path.splitext(handle.name)[1][1:].strip().lower()
    if extension not in ALLOWED_EXTENSIONS:
        return json_response({
            'error':
            _("Please choose a file with one of the following extensions: "
              "{}").format(", ".join(ALLOWED_EXTENSIONS))
        })

    meta = transient_file_store.write_file(handle, handle.name, domain)
    file_id = meta.identifier

    f = transient_file_store.get_tempfile_ref_for_contents(file_id)
    try:
        open_spreadsheet_download_ref(f)
    except SpreadsheetFileExtError:
        return json_response({
            'error':
            _("File does not appear to be an Excel file. Please choose another file."
              )
        })

    app = get_app(domain, app_id)
    from corehq.apps.app_manager.views.media_utils import interpolate_media_path
    from corehq.apps.hqmedia.view_helpers import validate_multimedia_paths_rows, update_multimedia_paths

    # Get rows, filtering out header, no-ops, and any extra "Usages" columns
    rows = []
    with get_spreadsheet(f) as spreadsheet:
        for row in list(spreadsheet.iter_rows())[1:]:
            if row[1]:
                rows.append(row[:2])

    (errors, warnings) = validate_multimedia_paths_rows(app, rows)
    if len(errors):
        return json_response({
            'complete': 1,
            'errors': errors,
        })

    paths = {row[0]: interpolate_media_path(row[1]) for row in rows if row[1]}
    successes = update_multimedia_paths(app, paths)
    app.save()

    # Force all_media to reset
    app.all_media.reset_cache(app)
    app.all_media_paths.reset_cache(app)

    # Warn if any old paths remain in app (because they're used in a place this function doesn't know about)
    warnings = []
    app.remove_unused_mappings()
    app_paths = {m.path: True for m in app.all_media()}
    for old_path, new_path in paths.items():
        if old_path in app_paths:
            warnings.append(
                _("Could not completely update path <code>{}</code>, "
                  "please check app for remaining references.").format(
                      old_path))

    return json_response({
        'complete': 1,
        'successes': successes,
        'warnings': warnings,
    })
예제 #5
0
파일: views.py 프로젝트: dimagi/commcare-hq
def update_multimedia_paths(request, domain, app_id):
    if not request.FILES:
        return json_response({
            'error': _("Please choose an Excel file to import.")
        })

    handle = request.FILES['file']

    extension = os.path.splitext(handle.name)[1][1:].strip().lower()
    if extension not in ALLOWED_EXTENSIONS:
        return json_response({
            'error': _("Please choose a file with one of the following extensions: "
                       "{}").format(", ".join(ALLOWED_EXTENSIONS))
        })

    meta = transient_file_store.write_file(handle, handle.name, domain)
    file_id = meta.identifier

    f = transient_file_store.get_tempfile_ref_for_contents(file_id)
    try:
        open_spreadsheet_download_ref(f)
    except SpreadsheetFileExtError:
        return json_response({
            'error': _("File does not appear to be an Excel file. Please choose another file.")
        })

    app = get_app(domain, app_id)
    from corehq.apps.app_manager.views.media_utils import interpolate_media_path
    from corehq.apps.hqmedia.view_helpers import validate_multimedia_paths_rows, update_multimedia_paths

    # Get rows, filtering out header, no-ops, and any extra "Usages" columns
    rows = []
    with get_spreadsheet(f) as spreadsheet:
        for row in list(spreadsheet.iter_rows())[1:]:
            if row[1]:
                rows.append(row[:2])

    (errors, warnings) = validate_multimedia_paths_rows(app, rows)
    if len(errors):
        return json_response({
            'complete': 1,
            'errors': errors,
        })

    paths = {
        row[0]: interpolate_media_path(row[1]) for row in rows if row[1]
    }
    successes = update_multimedia_paths(app, paths)
    app.save()

    # Force all_media to reset
    app.all_media.reset_cache(app)
    app.all_media_paths.reset_cache(app)

    # Warn if any old paths remain in app (because they're used in a place this function doesn't know about)
    warnings = []
    app.remove_unused_mappings()
    app_paths = {m.path: True for m in app.all_media()}
    for old_path, new_path in six.iteritems(paths):
        if old_path in app_paths:
            warnings.append(_("Could not completely update path <code>{}</code>, "
                              "please check app for remaining references.").format(old_path))

    return json_response({
        'complete': 1,
        'successes': successes,
        'warnings': warnings,
    })