@ -28,32 +28,61 @@ export function isExactKeyMatch(key: string, cacheKey?: string): boolean {
 
		
	
		
			
				    ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				export  async  function  deleteCacheByKey ( key : string ,  owner : string ,  repo : string )  {  
		
	
		
			
				export  function  logWarning ( message : string ) :  void  {  
		
	
		
			
				    const  warningPrefix  =  "[warning]" ; 
 
		
	
		
			
				    core . info ( ` ${ warningPrefix } ${ message } ` ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				export  async  function  deleteCacheByKey ( key : string ,  owner : string ,  repo : string )  :  Promise  < number  |  void >  {  
		
	
		
			
				    const  octokit  =  new  Octokit ( ) ; 
 
		
	
		
			
				    let  response ; 
 
		
	
		
			
				    try  { 
 
		
	
		
			
				        response  =  await  octokit . rest . actions . deleteActionsCacheByKey ( { 
 
		
	
		
			
				        const  gitRef  =  process . env [ RefKey ] ; 
 
		
	
		
			
				        let  cacheEntry  =  await  octokit . rest . actions . getActionsCacheList ( { 
 
		
	
		
			
				            owner : owner , 
 
		
	
		
			
				            repo : repo , 
 
		
	
		
			
				            key : key , 
 
		
	
		
			
				            ref : gitRef 
 
		
	
		
			
				            } ) ; 
 
		
	
		
			
				        const  {  data :  { 
 
		
	
		
			
				            total_count , 
 
		
	
		
			
				            actions_caches 
 
		
	
		
			
				            } 
 
		
	
		
			
				        }  =  cacheEntry ; 
 
		
	
		
			
				        if  ( total_count  !==  1  ||  total_count  !==  actions_caches . length )  {  // leave all find logic to the actual cache implementation. We just want to make sure we're returned a single element so we don't accidentally delete an entry that belongs to a different gitref.
 
 
		
	
		
			
				            if  ( total_count  >  1 )  { 
 
		
	
		
			
				                exports . logWarning ( ` More than one cache entry found for key  ${ key } ` ) ; 
 
		
	
		
			
				            } 
 
		
	
		
			
				            else  if  ( total_count  ===  0  ||  actions_caches . length  ===  0 )  { 
 
		
	
		
			
				                exports . logWarning ( ` No cache entries for key  ${ key }  belong to gitref  ${ gitRef } . ` ) ; 
 
		
	
		
			
				            } 
 
		
	
		
			
				            // This situation is likely never actually going to come up.
 
 
		
	
		
			
				            // Istanbul is being dumb and I can't ignore this path.
 
 
		
	
		
			
				            else  if  ( total_count  !==  actions_caches . length )  { 
 
		
	
		
			
				                exports . logWarning ( ` Reported cache entry matches for  ${ key }  does not match length of 'actions_caches' array in API response. ` ) ; 
 
		
	
		
			
				            } 
 
		
	
		
			
				            core . info ( ` Skip trying to delete cache entry for key  ${ key } . ` ) 
 
		
	
		
			
				            return ; 
 
		
	
		
			
				        } 
 
		
	
		
			
				        let  id  =  actions_caches [ 0 ] . id ; 
 
		
	
		
			
				        response  =  await  octokit . rest . actions . deleteActionsCacheById ( { 
 
		
	
		
			
				            owner : owner , 
 
		
	
		
			
				            repo : repo , 
 
		
	
		
			
				            key : key 
 
		
	
		
			
				            cache_id: id  
 
		
	
		
			
				            } ) ; 
 
		
	
		
			
				        if  ( response . status  ===  200 )  { 
 
		
	
		
			
				            core . info ( ` Succesfully deleted cache with key:  ${ response . data . actions_caches [ 0 ] . key } ` ) ; 
 
		
	
		
			
				        if  ( response . status  ===  204 )  { 
 
		
	
		
			
				            core . info ( ` Succesfully deleted cache with key:  ${ key } , id:  ${ id } ` ) ; 
 
		
	
		
			
				             return  204 ; 
 
		
	
		
			
				        } 
 
		
	
		
			
				    }  catch  ( e )  { 
 
		
	
		
			
				        if  ( e  instanceof  RequestError )  { 
 
		
	
		
			
				            let  err  =  e  as  RequestError ; 
 
		
	
		
			
				            let  errData  =  err . response ? . data  as  any  |  undefined ; 
 
		
	
		
			
				            exports . logWarning ( ` ${ err . name }  ' ${ err . status } :  ${ errData ? . message } ' trying to delete cache with key:  ${ key } ` ) ; 
 
		
	
		
			
				            exports . logWarning ( ` Github API reported error:  ${ err . name }  ' ${ err . status } :  ${ errData ? . message } ' ` ) ; 
 
		
	
		
			
				        } 
 
		
	
		
			
				        response  =  e ; 
 
		
	
		
			
				        core . info ( ` Couldn't delete cache entry for key  ${ key } . ` ) 
 
		
	
		
			
				        return ; 
 
		
	
		
			
				    } 
 
		
	
		
			
				    return  response ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				export  function  logWarning ( message : string ) :  void  {  
		
	
		
			
				    const  warningPrefix  =  "[warning]" ; 
 
		
	
		
			
				    core . info ( ` ${ warningPrefix } ${ message } ` ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				// Cache token authorized for all events that are tied to a ref