示例#1
0
    def GetValue(self):

        service_key = self._service_keys.GetValue()

        if service_key is None:

            raise HydrusExceptions.VetoException(
                'Please select a rating service!')

        action = self._flip_or_set_action.GetValue()

        if self._ratings_numerical_remove.isChecked():

            rating = None

        else:

            value = self._ratings_numerical_slider.GetValue()

            rating = self._current_ratings_numerical_service.ConvertStarsToRating(
                value)

        return CAC.ApplicationCommand(
            CAC.APPLICATION_COMMAND_TYPE_CONTENT,
            (service_key, HC.CONTENT_TYPE_RATINGS, action, rating))
示例#2
0
 def GetValue( self ):
     
     action = self._simple_actions.GetValue()
     
     if action == '':
         
         raise HydrusExceptions.VetoException( 'Please select an action!' )
         
     else:
         
         if action == CAC.SIMPLE_MEDIA_SEEK_DELTA:
             
             direction = self._seek_direction.GetValue()
             
             s = self._seek_duration_s.value()
             ms = self._seek_duration_ms.value() + ( 1000 * s )
             
             simple_data = ( direction, ms )
             
         else:
             
             simple_data = None
             
         
         return CAC.ApplicationCommand.STATICCreateSimpleCommand( action, simple_data = simple_data )
示例#3
0
    def _GetRatingsLike(self):

        selection = self._ratings_like_service_keys.currentIndex()

        if selection != -1:

            service_key = QP.GetClientData(self._ratings_like_service_keys,
                                           selection)

            action = self._flip_or_set_action.GetValue()

            if self._ratings_like_like.isChecked():

                value = 1.0

            elif self._ratings_like_dislike.isChecked():

                value = 0.0

            else:

                value = None

            return ClientData.ApplicationCommand(
                CC.APPLICATION_COMMAND_TYPE_CONTENT,
                (service_key, HC.CONTENT_TYPE_RATINGS, action, value))

        else:

            raise HydrusExceptions.VetoException(
                'Please select a rating service!')
示例#4
0
    def CommitChanges(self):

        services = self._services_listctrl.GetData()

        try:

            response = self._clientside_admin_service.Request(
                HC.POST, 'services', {'services': services})

        except Exception as e:

            HydrusData.ShowException(e)

            raise HydrusExceptions.VetoException(
                'There was an error: {}'.format(str(e)))

        service_keys_to_access_keys = dict(
            response['service_keys_to_access_keys'])

        admin_service_key = self._clientside_admin_service.GetServiceKey()

        with HG.dirty_object_lock:

            HG.client_controller.WriteSynchronous('update_server_services',
                                                  admin_service_key, services,
                                                  service_keys_to_access_keys,
                                                  self._deletee_service_keys)

            HG.client_controller.RefreshServices()
示例#5
0
 def GetValue( self ):
     
     service_key = self._service_keys.GetValue()
     
     if service_key is None:
         
         raise HydrusExceptions.VetoException( 'Please select a rating service!' )
         
     
     action = self._flip_or_set_action.GetValue()
     
     if self._ratings_like_like.isChecked():
         
         value = 1.0
         
     elif self._ratings_like_dislike.isChecked():
         
         value = 0.0
         
     else:
         
         value = None
         
     
     return CAC.ApplicationCommand( CAC.APPLICATION_COMMAND_TYPE_CONTENT, ( service_key, HC.CONTENT_TYPE_RATINGS, action, value ) )
示例#6
0
 def CheckValid( self ):
     
     services = self._services_listctrl.GetData()
     
     unique_ports = { service.GetPort() for service in services }
     
     if len( unique_ports ) < len( services ):
         
         raise HydrusExceptions.VetoException( 'It looks like some of those services share ports! Please give them unique ports!' )
示例#7
0
    def CheckValid(self):

        try:

            predicates = self.GetPredicates()

        except Exception as e:

            raise HydrusExceptions.VetoException(str(e))
示例#8
0
 def GetValue( self ):
     
     service_key = self._service_keys.GetValue()
     
     if service_key is None:
         
         raise HydrusExceptions.VetoException( 'Please select a tag service!' )
         
     
     action = self._flip_or_set_action.GetValue()
     
     tag = self._tag_value.text()
     
     if tag == '':
         
         raise HydrusExceptions.VetoException( 'Please enter a tag!' )
         
     
     return CAC.ApplicationCommand( CAC.APPLICATION_COMMAND_TYPE_CONTENT, ( service_key, HC.CONTENT_TYPE_MAPPINGS, action, tag ) )
示例#9
0
def CheckImporterCanDoFileWorkBecausePausifyingProblem(
        file_import_options: FileImportOptions):

    try:

        file_import_options.CheckReadyToImport()

    except Exception as e:

        raise HydrusExceptions.VetoException(str(e))
 def GetValue( self ):
     
     action = self._simple_actions.GetValue()
     
     if action == '':
         
         raise HydrusExceptions.VetoException( 'Please select an action!' )
         
     else:
         
         return CAC.ApplicationCommand( CAC.APPLICATION_COMMAND_TYPE_SIMPLE, action )
示例#11
0
def CheckImporterCanDoGalleryWorkBecausePaused(
    paused: bool, gallery_seed_log: typing.Optional[
        ClientImportGallerySeeds.GallerySeedLog]):

    if paused:

        raise HydrusExceptions.VetoException('paused')

    if HG.client_controller.new_options.GetBoolean(
            'pause_all_gallery_searches'):

        raise HydrusExceptions.VetoException(
            'all gallery searches are paused!')

    if gallery_seed_log is not None:

        work_pending = gallery_seed_log.WorkToDo()

        if not work_pending:

            raise HydrusExceptions.VetoException()
示例#12
0
    def _GetSimple(self):

        action = self._simple_actions.currentText()

        if action == '':

            raise HydrusExceptions.VetoException('Please select an action!')

        else:

            return ClientData.ApplicationCommand(
                CC.APPLICATION_COMMAND_TYPE_SIMPLE, action)
示例#13
0
def CheckImporterCanDoFileWorkBecausePaused(
        paused: bool, file_seed_cache: ClientImportFileSeeds.FileSeedCache,
        page_key: bytes):

    if paused:

        raise HydrusExceptions.VetoException('paused')

    if HG.client_controller.new_options.GetBoolean('pause_all_file_queues'):

        raise HydrusExceptions.VetoException(
            'all file import queues are paused!')

    work_pending = file_seed_cache.WorkToDo()

    if not work_pending:

        raise HydrusExceptions.VetoException()

    if HG.client_controller.PageClosedButNotDestroyed(page_key):

        raise HydrusExceptions.VetoException('page is closed')
示例#14
0
 def GetValue( self ):
     
     service_key = self._service_keys.GetValue()
     
     if service_key is None:
         
         raise HydrusExceptions.VetoException( 'Please select a service!' )
         
     
     action = self._add_or_move_action.GetValue()
     
     value = None
     
     return CAC.ApplicationCommand( CAC.APPLICATION_COMMAND_TYPE_CONTENT, ( service_key, HC.CONTENT_TYPE_FILES, action, value ) )
示例#15
0
 def GetValue( self ):
     
     service_key = self._service_keys.GetValue()
     
     if service_key is None:
         
         raise HydrusExceptions.VetoException( 'Please select a rating service!' )
         
     
     action = self._ratings_numerical_incdec.GetValue()
     
     distance = 1
     
     return CAC.ApplicationCommand( CAC.APPLICATION_COMMAND_TYPE_CONTENT, ( service_key, HC.CONTENT_TYPE_RATINGS, action, distance ) )
示例#16
0
    def CheckTagsVeto(self, tags: typing.Collection[str],
                      sibling_tags: typing.Collection[str]):

        tags = set(tags)

        sibling_tags = set(sibling_tags)

        for test_tags in (tags, sibling_tags):

            ok_tags = self._tag_blacklist.Filter(
                test_tags, apply_unnamespaced_rules_to_namespaced_tags=True)

            if len(ok_tags) < len(test_tags):

                bad_tags = test_tags.difference(ok_tags)

                bad_tags = HydrusTags.SortNumericTags(bad_tags)

                raise HydrusExceptions.VetoException(', '.join(bad_tags) +
                                                     ' is blacklisted!')

        if len(self._tag_whitelist) > 0:

            all_tags = tags.union(sibling_tags)

            for tag in list(all_tags):

                (namespace, subtag) = HydrusTags.SplitTag(tag)

                all_tags.add(subtag)

            intersecting_tags = all_tags.intersection(self._tag_whitelist)

            if len(intersecting_tags) == 0:

                raise HydrusExceptions.VetoException(
                    'did not pass the whitelist!')
示例#17
0
    def _GetTag(self):

        selection = self._tag_service_keys.currentIndex()

        if selection != -1:

            service_key = QP.GetClientData(self._tag_service_keys, selection)

            action = self._flip_or_set_action.GetValue()

            value = self._tag_value.text()

            if value == '':

                raise HydrusExceptions.VetoException('Please enter a tag!')

            return ClientData.ApplicationCommand(
                CC.APPLICATION_COMMAND_TYPE_CONTENT,
                (service_key, HC.CONTENT_TYPE_MAPPINGS, action, value))

        else:

            raise HydrusExceptions.VetoException(
                'Please select a tag service!')
    def GetValue(self):

        name = self._name.text()

        if self._this_is_custom and name in ClientGUIShortcuts.SHORTCUTS_RESERVED_NAMES:

            raise HydrusExceptions.VetoException(
                'That name is reserved--please pick another!')

        shortcut_set = ClientGUIShortcuts.ShortcutSet(name)

        for (shortcut, command) in self._shortcuts.GetData():

            shortcut_set.SetCommand(shortcut, command)

        return shortcut_set
示例#19
0
    def _GetRatingsNumericalIncDec(self):

        selection = self._ratings_numerical_incdec_service_keys.currentIndex()

        if selection != -1:

            service_key = QP.GetClientData(
                self._ratings_numerical_incdec_service_keys, selection)

            action = self._ratings_numerical_incdec.GetValue()

            value = 1

            return ClientData.ApplicationCommand(
                CC.APPLICATION_COMMAND_TYPE_CONTENT,
                (service_key, HC.CONTENT_TYPE_RATINGS, action, value))

        else:

            raise HydrusExceptions.VetoException(
                'Please select a rating service!')
示例#20
0
    def _GetRatingsNumerical(self):

        selection = self._ratings_numerical_service_keys.currentIndex()

        if selection != -1:

            service_key = QP.GetClientData(
                self._ratings_numerical_service_keys, selection)

            action = self._flip_or_set_action.GetValue()

            if self._ratings_numerical_remove.isChecked():

                value = None

            else:

                value = self._ratings_numerical_slider.GetValue()

                num_stars = self._current_ratings_numerical_service.GetNumStars(
                )
                allow_zero = self._current_ratings_numerical_service.AllowZero(
                )

                if allow_zero:

                    value = value / num_stars

                else:

                    value = (value - 1) / (num_stars - 1)

            return ClientData.ApplicationCommand(
                CC.APPLICATION_COMMAND_TYPE_CONTENT,
                (service_key, HC.CONTENT_TYPE_RATINGS, action, value))

        else:

            raise HydrusExceptions.VetoException(
                'Please select a rating service!')
示例#21
0
 def CheckCanDoGalleryWork( self ):
     
     with self._lock:
         
         try:
             
             ClientImportControl.CheckImporterCanDoWorkBecauseStopped( self._page_key )
             
         except HydrusExceptions.VetoException:
             
             self._gallery_repeating_job.Cancel()
             
             raise
             
         
         if len( self._pending_jobs ) == 0:
             
             raise HydrusExceptions.VetoException()
             
         
         ClientImportControl.CheckImporterCanDoGalleryWorkBecausePaused( self._gallery_paused, None )
         
     
     return self.CheckCanDoNetworkWork()
 def WorkOnURL( self, gallery_token_name, gallery_seed_log, file_seeds_callable, status_hook, title_hook, network_job_factory, network_job_presentation_context_factory, file_import_options, gallery_urls_seen_before = None ):
     
     if gallery_urls_seen_before is None:
         
         gallery_urls_seen_before = set()
         
     
     gallery_urls_seen_before.add( self.url )
     
     # maybe something like 'append urls' vs 'reverse-prepend' for subs or something
     
     # should also take--and populate--a set of urls we have seen this 'run', so we can bomb out if next_gallery_url ends up in some loop
     
     num_urls_added = 0
     num_urls_already_in_file_seed_cache = 0
     num_urls_total = 0
     result_404 = False
     added_new_gallery_pages = False
     stop_reason = ''
     
     try:
         
         gallery_url = self.url
         
         url_for_child_referral = gallery_url
         
         ( url_type, match_name, can_parse, cannot_parse_reason ) = HG.client_controller.network_engine.domain_manager.GetURLParseCapability( gallery_url )
         
         if url_type not in ( HC.URL_TYPE_GALLERY, HC.URL_TYPE_WATCHABLE ):
             
             raise HydrusExceptions.VetoException( 'Did not recognise this as a gallery or watchable URL!' )
             
         
         if not can_parse:
             
             raise HydrusExceptions.VetoException( 'Cannot parse {}: {}'.format( match_name, cannot_parse_reason) )
             
         
         ( url_to_check, parser ) = HG.client_controller.network_engine.domain_manager.GetURLToFetchAndParser( gallery_url )
         
         status_hook( 'downloading gallery page' )
         
         if self._referral_url is not None and self._referral_url != url_to_check:
             
             referral_url = self._referral_url
             
         elif gallery_url != url_to_check:
             
             referral_url = gallery_url
             
         else:
             
             referral_url = None
             
         
         network_job = network_job_factory( 'GET', url_to_check, referral_url = referral_url )
         
         network_job.SetGalleryToken( gallery_token_name )
         
         network_job.OverrideBandwidth( 30 )
         
         HG.client_controller.network_engine.AddJob( network_job )
         
         with network_job_presentation_context_factory( network_job ) as njpc:
             
             network_job.WaitUntilDone()
             
         
         parsing_text = network_job.GetContentText()
         
         actual_fetched_url = network_job.GetActualFetchedURL()
         
         do_parse = True
         
         if actual_fetched_url != url_to_check:
             
             ( url_type, match_name, can_parse, cannot_parse_reason ) = HG.client_controller.network_engine.domain_manager.GetURLParseCapability( actual_fetched_url )
             
             if url_type == HC.URL_TYPE_GALLERY:
                 
                 if can_parse:
                     
                     gallery_url = actual_fetched_url
                     
                     url_for_child_referral = gallery_url
                     
                     ( url_to_check, parser ) = HG.client_controller.network_engine.domain_manager.GetURLToFetchAndParser( gallery_url )
                     
                 else:
                     
                     do_parse = False
                     
                     status = CC.STATUS_ERROR
                     
                     note = 'Could not parse {}: {}'.format( match_name, cannot_parse_reason )
                     
                 
             else:
                 
                 do_parse = False
                 
                 from hydrus.client.importing import ClientImportFileSeeds
                 
                 file_seed = ClientImportFileSeeds.FileSeed( ClientImportFileSeeds.FILE_SEED_TYPE_URL, actual_fetched_url )
                 
                 file_seed.SetReferralURL( url_for_child_referral )
                 
                 file_seeds = [ file_seed ]
                 
                 file_seeds_callable( ( file_seed, ) )
                 
                 status = CC.STATUS_SUCCESSFUL_AND_NEW
                 
                 note = 'was redirected to a non-gallery url, which has been queued as a file import'
                 
             
         
         if do_parse:
             
             parsing_context = {}
             
             parsing_context[ 'gallery_url' ] = gallery_url
             parsing_context[ 'url' ] = url_to_check
             parsing_context[ 'post_index' ] = '0'
             
             all_parse_results = parser.Parse( parsing_context, parsing_text )
             
             if len( all_parse_results ) == 0:
                 
                 raise HydrusExceptions.VetoException( 'The parser found nothing in the document!' )
                 
             
             file_seeds = ClientImporting.ConvertAllParseResultsToFileSeeds( all_parse_results, url_for_child_referral, file_import_options )
             
             title = ClientParsing.GetTitleFromAllParseResults( all_parse_results )
             
             if title is not None:
                 
                 title_hook( title )
                 
             
             for file_seed in file_seeds:
                 
                 file_seed.SetExternalFilterableTags( self._external_filterable_tags )
                 file_seed.SetExternalAdditionalServiceKeysToTags( self._external_additional_service_keys_to_tags )
                 
             
             num_urls_total = len( file_seeds )
             
             ( num_urls_added, num_urls_already_in_file_seed_cache, can_search_for_more_files, stop_reason ) = file_seeds_callable( file_seeds )
             
             status = CC.STATUS_SUCCESSFUL_AND_NEW
             
             note = HydrusData.ToHumanInt( num_urls_added ) + ' new urls found'
             
             if num_urls_already_in_file_seed_cache > 0:
                 
                 note += ' (' + HydrusData.ToHumanInt( num_urls_already_in_file_seed_cache ) + ' of page already in)'
                 
             
             if not can_search_for_more_files:
                 
                 note += ' - ' + stop_reason
                 
             
             if parser.CanOnlyGenerateGalleryURLs() or self._force_next_page_url_generation:
                 
                 can_add_more_gallery_urls = True
                 
             else:
                 
                 # only keep searching if we found any files, otherwise this could be a blank results page with another stub page
                 can_add_more_gallery_urls = num_urls_added > 0 and can_search_for_more_files
                 
             
             flattened_results = list( itertools.chain.from_iterable( all_parse_results ) )
             
             sub_gallery_urls = ClientParsing.GetURLsFromParseResults( flattened_results, ( HC.URL_TYPE_SUB_GALLERY, ), only_get_top_priority = True )
             
             sub_gallery_urls = HydrusData.DedupeList( sub_gallery_urls )
             
             new_sub_gallery_urls = [ sub_gallery_url for sub_gallery_url in sub_gallery_urls if sub_gallery_url not in gallery_urls_seen_before ]
             
             num_new_sub_gallery_urls = len( new_sub_gallery_urls )
             
             if num_new_sub_gallery_urls > 0:
                 
                 sub_gallery_seeds = [ GallerySeed( sub_gallery_url ) for sub_gallery_url in new_sub_gallery_urls ]
                 
                 for sub_gallery_seed in sub_gallery_seeds:
                     
                     sub_gallery_seed.SetRunToken( self._run_token )
                     sub_gallery_seed.SetExternalFilterableTags( self._external_filterable_tags )
                     sub_gallery_seed.SetExternalAdditionalServiceKeysToTags( self._external_additional_service_keys_to_tags )
                     
                 
                 gallery_seed_log.AddGallerySeeds( sub_gallery_seeds )
                 
                 added_new_gallery_pages = True
                 
                 gallery_urls_seen_before.update( sub_gallery_urls )
                 
                 note += ' - {} sub-gallery urls found'.format( HydrusData.ToHumanInt( num_new_sub_gallery_urls ) )
                 
             
             if self._can_generate_more_pages and can_add_more_gallery_urls:
                 
                 next_page_urls = ClientParsing.GetURLsFromParseResults( flattened_results, ( HC.URL_TYPE_NEXT, ), only_get_top_priority = True )
                 
                 if self.url in next_page_urls:
                     
                     next_page_urls.remove( self.url )
                     
                 
                 if url_to_check in next_page_urls:
                     
                     next_page_urls.remove( url_to_check )
                     
                 
                 if len( next_page_urls ) > 0:
                     
                     next_page_generation_phrase = ' next gallery pages found'
                     
                 else:
                     
                     # we have failed to parse a next page url, but we would still like one, so let's see if the url match can provide one
                     
                     url_class = HG.client_controller.network_engine.domain_manager.GetURLClass( url_to_check )
                     
                     if url_class is not None and url_class.CanGenerateNextGalleryPage():
                         
                         try:
                             
                             next_page_url = url_class.GetNextGalleryPage( url_to_check )
                             
                             next_page_urls = [ next_page_url ]
                             
                         except Exception as e:
                             
                             note += ' - Attempted to generate a next gallery page url, but failed!'
                             note += os.linesep
                             note += traceback.format_exc()
                             
                         
                     
                     next_page_generation_phrase = ' next gallery pages extrapolated from url class'
                     
                 
                 if len( next_page_urls ) > 0:
                     
                     next_page_urls = HydrusData.DedupeList( next_page_urls )
                     
                     new_next_page_urls = [ next_page_url for next_page_url in next_page_urls if next_page_url not in gallery_urls_seen_before ]
                     
                     duplicate_next_page_urls = gallery_urls_seen_before.intersection( new_next_page_urls )
                     
                     num_new_next_page_urls = len( new_next_page_urls )
                     num_dupe_next_page_urls = len( duplicate_next_page_urls )
                     
                     if num_new_next_page_urls > 0:
                         
                         next_gallery_seeds = [ GallerySeed( next_page_url ) for next_page_url in new_next_page_urls ]
                         
                         for next_gallery_seed in next_gallery_seeds:
                             
                             next_gallery_seed.SetRunToken( self._run_token )
                             next_gallery_seed.SetReferralURL( url_for_child_referral )
                             next_gallery_seed.SetExternalFilterableTags( self._external_filterable_tags )
                             next_gallery_seed.SetExternalAdditionalServiceKeysToTags( self._external_additional_service_keys_to_tags )
                             
                         
                         gallery_seed_log.AddGallerySeeds( next_gallery_seeds )
                         
                         added_new_gallery_pages = True
                         
                         gallery_urls_seen_before.update( new_next_page_urls )
                         
                         if num_dupe_next_page_urls == 0:
                             
                             note += ' - ' + HydrusData.ToHumanInt( num_new_next_page_urls ) + next_page_generation_phrase
                             
                         else:
                             
                             note += ' - ' + HydrusData.ToHumanInt( num_new_next_page_urls ) + next_page_generation_phrase + ', but ' + HydrusData.ToHumanInt( num_dupe_next_page_urls ) + ' had already been visited this run and were not added'
                             
                         
                     else:
                         
                         note += ' - ' + HydrusData.ToHumanInt( num_dupe_next_page_urls ) + next_page_generation_phrase + ', but they had already been visited this run and were not added'
                         
                     
                 
             
         
         self.SetStatus( status, note = note )
         
     except HydrusExceptions.ShutdownException:
         
         pass
         
     except HydrusExceptions.VetoException as e:
         
         status = CC.STATUS_VETOED
         
         note = str( e )
         
         self.SetStatus( status, note = note )
         
         if isinstance( e, HydrusExceptions.CancelledException ):
             
             status_hook( 'cancelled!' )
             
             time.sleep( 2 )
             
         
     except HydrusExceptions.InsufficientCredentialsException:
         
         status = CC.STATUS_VETOED
         note = '403'
         
         self.SetStatus( status, note = note )
         
         status_hook( '403' )
         
         time.sleep( 2 )
         
         result_404 = True
         
     except HydrusExceptions.NotFoundException:
         
         status = CC.STATUS_VETOED
         note = '404'
         
         self.SetStatus( status, note = note )
         
         status_hook( '404' )
         
         time.sleep( 2 )
         
         result_404 = True
         
     except Exception as e:
         
         status = CC.STATUS_ERROR
         
         self.SetStatus( status, exception = e )
         
         status_hook( 'error!' )
         
         time.sleep( 3 )
         
         if isinstance( e, HydrusExceptions.NetworkException ): # so the larger queue can set a delaywork or whatever
             
             raise
             
         
     finally:
         
         gallery_seed_log.NotifyGallerySeedsUpdated( ( self, ) )
         
     
     return ( num_urls_added, num_urls_already_in_file_seed_cache, num_urls_total, result_404, added_new_gallery_pages, stop_reason )
示例#23
0
def CheckImporterCanDoWorkBecauseStopped(page_key: bytes):

    if PageImporterShouldStopWorking(page_key):

        raise HydrusExceptions.VetoException('page should stop working')