當前位置: 首頁>>代碼示例>>Java>>正文


Java StandardCertificateCredentials類代碼示例

本文整理匯總了Java中com.cloudbees.plugins.credentials.common.StandardCertificateCredentials的典型用法代碼示例。如果您正苦於以下問題:Java StandardCertificateCredentials類的具體用法?Java StandardCertificateCredentials怎麽用?Java StandardCertificateCredentials使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


StandardCertificateCredentials類屬於com.cloudbees.plugins.credentials.common包,在下文中一共展示了StandardCertificateCredentials類的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: extractFromCertificate

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
/**
 * Extract the private key a client certificate from a X509 certificate and write them to disk.
 *
 * @param certificatCredential Jenkins certificateCredential
 * @param clientCrtFile        path where to write of the certificate
 * @param clientKeyFile        path where to write of the private key
 * @throws IOException          lol
 * @throws InterruptedException on file operation
 */
public static void extractFromCertificate(StandardCertificateCredentials certificatCredential,
                                          FilePath clientCrtFile,
                                          FilePath clientKeyFile) throws IOException, InterruptedException {
    try {
        KeyStore keyStore = certificatCredential.getKeyStore();
        String alias = keyStore.aliases().nextElement();
        X509Certificate certificate = (X509Certificate) keyStore.getCertificate(alias);

        // Get private key using passphrase
        Key key = keyStore.getKey(alias, Secret.toString(certificatCredential.getPassword()).toCharArray());

        // Write certificate
        String encodedClientCrt = wrapCertificate(Base64.encodeBase64String(certificate.getEncoded()));
        clientCrtFile.write(encodedClientCrt, null);

        // Write private key
        String encodedClientKey = wrapPrivateKey(Base64.encodeBase64String(key.getEncoded()));
        clientKeyFile.write(encodedClientKey, null);
    } catch (KeyStoreException | UnrecoverableKeyException | NoSuchAlgorithmException | CertificateEncodingException e) {
        throw new AbortException(e.getMessage());
    }
}
 
開發者ID:maxlaverse,項目名稱:kubernetes-cli-plugin,代碼行數:32,代碼來源:CertificateHelper.java

示例2: doFillCredentialsIdItems

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
public ListBoxModel doFillCredentialsIdItems(@AncestorInPath Item item, @QueryParameter String serverUrl) {
    return new StandardListBoxModel()
            .withEmptySelection()
            .withMatching(
                    CredentialsMatchers.anyOf(
                            CredentialsMatchers.instanceOf(StandardUsernamePasswordCredentials.class),
                            CredentialsMatchers.instanceOf(TokenProducer.class),
                            CredentialsMatchers.instanceOf(StandardCertificateCredentials.class)
                    ),
                    CredentialsProvider.lookupCredentials(
                            StandardCredentials.class,
                            item,
                            null,
                            URIRequirementBuilder.fromUri(serverUrl).build()
                    )
            );

}
 
開發者ID:carlossg,項目名稱:jenkins-kubernetes-plugin,代碼行數:19,代碼來源:KubectlBuildWrapper.java

示例3: doFillCredentialsIdItems

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
public ListBoxModel doFillCredentialsIdItems(@QueryParameter String serverUrl) {
    return new StandardListBoxModel().withEmptySelection() //
            .withMatching( //
                    CredentialsMatchers.anyOf(
                            CredentialsMatchers.instanceOf(StandardUsernamePasswordCredentials.class),
                            CredentialsMatchers.instanceOf(TokenProducer.class),
                            CredentialsMatchers.instanceOf(
                                    org.jenkinsci.plugins.kubernetes.credentials.TokenProducer.class),
                            CredentialsMatchers.instanceOf(StandardCertificateCredentials.class),
                            CredentialsMatchers.instanceOf(StringCredentials.class)), //
                    CredentialsProvider.lookupCredentials(StandardCredentials.class, //
                            Jenkins.getInstance(), //
                            ACL.SYSTEM, //
                            serverUrl != null ? URIRequirementBuilder.fromUri(serverUrl).build()
                                    : Collections.EMPTY_LIST //
                    ));

}
 
開發者ID:carlossg,項目名稱:jenkins-kubernetes-plugin,代碼行數:19,代碼來源:KubernetesCloud.java

示例4: basicsPipeline

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
@Test
public void basicsPipeline() throws Exception {
	// create the Credentials
	String alias = "androiddebugkey";
	String password = "android";
	StandardCertificateCredentials c = new CertificateCredentialsImpl(CredentialsScope.GLOBAL, "my-certificate", alias,
			password, new CertificateCredentialsImpl.FileOnMasterKeyStoreSource(certificate.getAbsolutePath()));
	CredentialsProvider.lookupStores(r.jenkins).iterator().next().addCredentials(Domain.global(), c);
	// create the Pipeline job
	WorkflowJob p = r.jenkins.createProject(WorkflowJob.class, "p");
	String pipelineScript = IOUtils.toString(getTestResourceInputStream("basicsPipeline-Jenkinsfile"));
	p.setDefinition(new CpsFlowDefinition(pipelineScript, true));
	// copy resources into workspace
	FilePath workspace = r.jenkins.getWorkspaceFor(p);
	copyTestResourceIntoWorkspace(workspace, "basicsPipeline-step1.bat", 0755);
	copyTestResourceIntoWorkspace(workspace, "basicsPipeline-step2.bat", 0755);
	copyTestResourceIntoWorkspace(workspace, "basicsPipeline-step1.sh", 0755);
	copyTestResourceIntoWorkspace(workspace, "basicsPipeline-step2.sh", 0755);
	// execute the pipeline
	WorkflowRun b = p.scheduleBuild2(0).waitForStart();
	r.waitForCompletion(b);
	r.assertBuildStatusSuccess(b);
}
 
開發者ID:jenkinsci,項目名稱:credentials-binding-plugin,代碼行數:24,代碼來源:CertificateMultiBindingTest.java

示例5: setCredentials

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
/**
 * Set the user section of the kube configuration file.
 *
 * @throws IOException          on file operations
 * @throws InterruptedException on file operations
 */
private void setCredentials(String configFile) throws IOException, InterruptedException {
    Set<String> tempFiles = newHashSet();
    final StandardCredentials credentials = getCredentials(build);

    String credentialsArgs;
    int sensitiveFieldsCount = 1;
    if (credentials == null) {
        throw new AbortException("No credentials defined to setup Kubernetes CLI");
    } else if (credentials instanceof TokenProducer) {
        credentialsArgs = "--token=\"" + ((TokenProducer) credentials).getToken(serverUrl, null, true) + "\"";
    } else if (credentials instanceof StringCredentials) {
        credentialsArgs = "--token=\"" + ((StringCredentials) credentials).getSecret() + "\"";
    } else if (credentials instanceof UsernamePasswordCredentials) {
        UsernamePasswordCredentials upc = (UsernamePasswordCredentials) credentials;
        credentialsArgs = "--username=\"" + upc.getUsername() + "\" --password=\"" + Secret.toString(upc.getPassword()) + "\"";
    } else if (credentials instanceof StandardCertificateCredentials) {
        sensitiveFieldsCount = 0;
        FilePath clientCrtFile = workspace.createTempFile("client", "crt");
        FilePath clientKeyFile = workspace.createTempFile("client", "key");
        CertificateHelper.extractFromCertificate((StandardCertificateCredentials) credentials, clientCrtFile, clientKeyFile);
        tempFiles.add(clientCrtFile.getRemote());
        tempFiles.add(clientKeyFile.getRemote());
        credentialsArgs = "--embed-certs=true --client-certificate=" + clientCrtFile.getRemote() + " --client-key="
                + clientKeyFile.getRemote();
    } else {
        throw new AbortException("Unsupported Credentials type " + credentials.getClass().getName());
    }

    String[] cmds = QuotedStringTokenizer.tokenize(String.format("%s config set-credentials %s %s",
            KUBECTL_BINARY,
            USERNAME,
            credentialsArgs));

    int status = launcher.launch()
            .envs(String.format("KUBECONFIG=%s", configFile))
            .cmds(cmds)
            .masks(getMasks(cmds.length, sensitiveFieldsCount))
            .stdout(launcher.getListener())
            .join();
    if (status != 0) throw new IOException("Failed to add kubectl credentials (exit code  " + status + ")");

    for (String tempFile : tempFiles) {
        workspace.child(tempFile).delete();
    }

}
 
開發者ID:maxlaverse,項目名稱:kubernetes-cli-plugin,代碼行數:53,代碼來源:KubeConfigWriter.java

示例6: type

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
@Override
protected Class<StandardCertificateCredentials> type() {
	return StandardCertificateCredentials.class;
}
 
開發者ID:jenkinsci,項目名稱:credentials-binding-plugin,代碼行數:5,代碼來源:CertificateMultiBinding.java

示例7: basics

import com.cloudbees.plugins.credentials.common.StandardCertificateCredentials; //導入依賴的package包/類
@Test
public void basics() throws Exception {
	String alias = "androiddebugkey";
	String password = "android";
	StandardCertificateCredentials c = new CertificateCredentialsImpl(CredentialsScope.GLOBAL, null, alias,
			password, new CertificateCredentialsImpl.FileOnMasterKeyStoreSource(certificate.getAbsolutePath()));
	CredentialsProvider.lookupStores(r.jenkins).iterator().next().addCredentials(Domain.global(), c);
	FreeStyleProject p = r.createFreeStyleProject();
	CertificateMultiBinding binding = new CertificateMultiBinding("keystore", c.getId());
	binding.setAliasVariable("alias");
	binding.setPasswordVariable("password");
	p.getBuildWrappersList().add(new SecretBuildWrapper(Collections
			.<MultiBinding<?>> singletonList(binding)));
	if (Functions.isWindows()) {
		p.getBuildersList().add(new BatchFile(
				  "echo | set /p=\"%alias%/%password%/\" > secrets.txt\r\n"
				+ "IF EXIST %keystore% (\r\n"
				+ "echo | set /p=\"exists\" >> secrets.txt\r\n"
				+ ") ELSE (\r\n"
				+ "echo | set /p=\"missing\" >> secrets.txt\r\n"
				+ ")\r\n"
                   + "exit 0"));
	} else {
		p.getBuildersList().add(new Shell(
				  "printf $alias/$password/ > secrets.txt\n"
				+ "if [ -f \"$keystore\" ]\n"
				+ "then\n"
				+ "printf exists >> secrets.txt\n"
				+ "else\n"
				+ "printf missing >> secrets.txt\n"
				+ "fi"));
	}
	r.configRoundtrip((Item) p);
	SecretBuildWrapper wrapper = p.getBuildWrappersList().get(SecretBuildWrapper.class);
	assertNotNull(wrapper);
	List<? extends MultiBinding<?>> bindings = wrapper.getBindings();
	assertEquals(1, bindings.size());
	MultiBinding<?> testBinding = bindings.get(0);
	assertEquals(c.getId(), testBinding.getCredentialsId());
	assertEquals(CertificateMultiBinding.class, testBinding.getClass());
	assertEquals("password", ((CertificateMultiBinding) testBinding).getPasswordVariable());
	assertEquals("alias", ((CertificateMultiBinding) testBinding).getAliasVariable());
	assertEquals("keystore", ((CertificateMultiBinding) testBinding).getKeystoreVariable());
	FreeStyleBuild b = r.buildAndAssertSuccess(p);
	r.assertLogNotContains(password, b);
	assertEquals(alias + '/' + password + "/exists", b.getWorkspace().child("secrets.txt").readToString().trim());
	assertThat(b.getSensitiveBuildVariables(), containsInAnyOrder("keystore", "password", "alias"));
}
 
開發者ID:jenkinsci,項目名稱:credentials-binding-plugin,代碼行數:49,代碼來源:CertificateMultiBindingTest.java


注:本文中的com.cloudbees.plugins.credentials.common.StandardCertificateCredentials類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。