@@ -351,21 +351,25 @@ try {
351
351
fs . appendFileSync ( `${ homeSsh } /known_hosts` , '\ngithub.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOMqqnkVzrm0SdG6UOoqKLsabgH5C9okWi0dh2l9GKJl\n' ) ;
352
352
fs . appendFileSync ( `${ homeSsh } /known_hosts` , '\ngithub.com ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq2A7hRGmdnm9tUDbO9IDSwBK6TbQa+PXYPCPy6rbTrTtw7PHkccKrpp0yVhp5HdEIcKr6pLlVDBfOLX9QUsyCOV0wzfjIJNlGEYsdlLJizHhbn2mUjvSAHQqZETYP81eFzLQNnPHt4EVVUh7VfDESU84KezmD5QlWpXLmvU31/yMf+Se8xhHTvKSCZIFImWwoG6mbUoWf9nzpIoaSjB+weqqUUmpaaasXVal72J+UX2B+2RPW3RcT0eOzQgqlJL3RKrTJvdsjE3JEAvGq3lGHSZXy28G3skua2SmVi/w4yCE6gbODqnTWlg7+wC604ydGXA8VJiS5ap43JXiUFFAaQ==\n' ) ;
353
353
354
- console . log ( "Starting ssh-agent" ) ;
355
-
356
354
const authSock = core . getInput ( 'ssh-auth-sock' ) ;
357
355
const sshAgentArgs = ( authSock && authSock . length > 0 ) ? [ '-a' , authSock ] : [ ] ;
358
356
359
- // Extract auth socket path and agent pid and set them as job variables
360
- child_process . execFileSync ( sshAgentCmd , sshAgentArgs ) . toString ( ) . split ( "\n" ) . forEach ( function ( line ) {
361
- const matches = / ^ ( S S H _ A U T H _ S O C K | S S H _ A G E N T _ P I D ) = ( .* ) ; e x p o r t \1/ . exec ( line ) ;
357
+ if ( child_process . spawnSync ( sshAdd , [ '-l' ] , { env : { ...process . env , SSH_AUTH_SOCK : authSock || process . env . SSH_AUTH_SOCK } } ) . status === 0 ) {
358
+ console . log ( 'ssh-agent is already running, not starting a new one' ) ;
359
+ } else {
360
+ console . log ( "Starting ssh-agent" ) ;
362
361
363
- if ( matches && matches . length > 0 ) {
364
- // This will also set process.env accordingly, so changes take effect for this script
365
- core . exportVariable ( matches [ 1 ] , matches [ 2 ] )
366
- console . log ( `${ matches [ 1 ] } =${ matches [ 2 ] } ` ) ;
367
- }
368
- } ) ;
362
+ // Extract auth socket path and agent pid and set them as job variables
363
+ child_process . execFileSync ( sshAgent , sshAgentArgs ) . toString ( ) . split ( "\n" ) . forEach ( function ( line ) {
364
+ const matches = / ^ ( S S H _ A U T H _ S O C K | S S H _ A G E N T _ P I D ) = ( .* ) ; e x p o r t \1/ . exec ( line ) ;
365
+
366
+ if ( matches && matches . length > 0 ) {
367
+ // This will also set process.env accordingly, so changes take effect for this script
368
+ core . exportVariable ( matches [ 1 ] , matches [ 2 ] ) ;
369
+ console . log ( `${ matches [ 1 ] } =${ matches [ 2 ] } ` ) ;
370
+ }
371
+ } ) ;
372
+ }
369
373
370
374
console . log ( "Adding private key(s) to agent" ) ;
371
375
0 commit comments