def show_package_schema(self): ''' Returns the schema for mapping package data from the database into a format suitable for the form ''' from ckanext.harvest.logic.schema import harvest_source_show_package_schema return harvest_source_show_package_schema()
def show_package_schema(self): ''' Returns the schema for mapping package data from the database into a format suitable for the form ''' schema = harvest_source_show_package_schema() schema['config'] = [convert_from_extras, harvest_source_convert_from_config, ignore_missing] return schema
def harvest_source_update(context, data_dict): """ Updates an existing harvest source This method just proxies the request to package_update, which will create a harvest_source dataset type and the HarvestSource object. All auth checks and validation will be done there .We only make sure to set the dataset type Note that the harvest source type (ckan, waf, csw, etc) is now set via the source_type field. :param id: the name or id of the harvest source to update :type id: string :param url: the URL for the harvest source :type url: string :param name: the name of the new harvest source, must be between 2 and 100 characters long and contain only lowercase alphanumeric characters :type name: string :param title: the title of the dataset (optional, default: same as ``name``) :type title: string :param notes: a description of the harvest source (optional) :type notes: string :param source_type: the harvester type for this source. This must be one of the registerd harvesters, eg 'ckan', 'csw', etc. :type source_type: string :param frequency: the frequency in wich this harvester should run. See ``ckanext.harvest.model`` source for possible values. Default is 'MANUAL' :type frequency: string :param config: extra configuration options for the particular harvester type. Should be a serialized as JSON. (optional) :type config: string :returns: the newly created harvest source :rtype: dictionary """ log.info("Updating harvest source: %r", data_dict) data_dict["type"] = DATASET_TYPE_NAME context["extras_as_string"] = True package_dict = logic.get_action("package_update")(context, data_dict) context["schema"] = harvest_source_show_package_schema() source = logic.get_action("package_show")(context, package_dict) return source
def harvest_source_update(context, data_dict): ''' Updates an existing harvest source This method just proxies the request to package_update, which will create a harvest_source dataset type and the HarvestSource object. All auth checks and validation will be done there .We only make sure to set the dataset type Note that the harvest source type (ckan, waf, csw, etc) is now set via the source_type field. :param id: the name or id of the harvest source to update :type id: string :param url: the URL for the harvest source :type url: string :param name: the name of the new harvest source, must be between 2 and 100 characters long and contain only lowercase alphanumeric characters :type name: string :param title: the title of the dataset (optional, default: same as ``name``) :type title: string :param notes: a description of the harvest source (optional) :type notes: string :param source_type: the harvester type for this source. This must be one of the registerd harvesters, eg 'ckan', 'csw', etc. :type source_type: string :param frequency: the frequency in wich this harvester should run. See ``ckanext.harvest.model`` source for possible values. Default is 'MANUAL' :type frequency: string :param config: extra configuration options for the particular harvester type. Should be a serialized as JSON. (optional) :type config: string :returns: the newly created harvest source :rtype: dictionary ''' log.info('Updating harvest source: %r', data_dict) data_dict['type'] = DATASET_TYPE_NAME context['extras_as_string'] = True package_dict = logic.get_action('package_update')(context, data_dict) context['schema'] = harvest_source_show_package_schema() source = logic.get_action('package_show')(context, package_dict) return source
def harvest_source_show_package_schema(cls): from ckanext.harvest.logic.schema import harvest_source_show_package_schema return cls._harvest_non_unique_url(harvest_source_show_package_schema())
def harvest_source_show_package_schema(cls): from ckanext.harvest.logic.schema import harvest_source_show_package_schema return cls._harvest_non_unique_url( harvest_source_show_package_schema())