文档首页/ 制品仓库 CodeArts Artifact/ API参考/ API/ 仓库管理/ 创建maven仓库 - CreateMavenRepo
更新时间:2025-12-03 GMT+08:00

创建maven仓库 - CreateMavenRepo

功能介绍

创建maven语言类型的仓库,支持设置仓库所属的项目,访问路径白名单等。

调用方法

请参见如何调用API

授权信息

账号具备所有API的调用权限,如果使用账号下的IAM用户调用当前API,该IAM用户需具备如下身份策略权限,更多的权限说明请参见权限和授权项

授权项

访问级别

资源类型(*为必须)

条件键

别名

依赖的授权项

codeartsartifact:repository:create

Write

-

-

-

-

URI

POST /cloudartifact/v5/maven/repositories

请求参数

表1 请求Body参数

参数

是否必选

参数类型

描述

repository_name

String

参数解释:

仓库名称。

约束限制:

长度1-50。

取值范围:

不涉及。

默认取值:

无。

format

String

参数解释:

制品类型。

约束限制:

不涉及。

取值范围:

maven2。

默认取值:

无。

description

String

参数解释:

仓库描述。

约束限制:

最大长度200。

取值范围:

不涉及。

默认取值:

无。

release

String

参数解释:

release仓库名称。

约束限制:

长度1-50。

取值范围:

不涉及。

默认取值:

无。

snapshot

String

参数解释:

snapshot仓库名称。

约束限制:

长度1-50。

取值范围:

不涉及。

默认取值:

无。

includes_pattern

String

参数解释:

路径包含规则。

约束限制:

最大长度512。

取值范围:

不涉及。

默认取值:

无。

share_right

String

参数解释:

共享权限级别。

约束限制:

不涉及。

取值范围:

PROJECT。

默认取值:

无。

project_id

String

参数解释:

项目ID,可以从调用API处获取,也可以从控制台获取。获取方式请参考获取项目ID

约束限制:

只能由英文字母、数字组成,且长度为32个字符。

取值范围:

不涉及。

默认取值:

无。

type

String

参数解释:

仓库类型。

约束限制:

不涉及。

取值范围:

hosted:本地仓库。

默认取值:

无。

响应参数

状态码:200

表2 响应Body参数

参数

参数类型

描述

status

String

参数解释

请求成功或失败状态。

取值范围

  • success:请求成功。

  • error:请求失败。

trace_id

String

参数解释

请求ID,当前请求的唯一标识。

取值范围

数字及中划线(-)组成的字符串。

result

CreateMavenRepoResult object

参数解释:

创建的maven仓库信息。

取值范围:

不涉及。

表3 CreateMavenRepoResult

参数

参数类型

描述

release

String

参数解释:

release仓库id。

取值范围:

不涉及。

snapshot

String

参数解释:

snapshot仓库id。

取值范围:

不涉及。

请求示例

创建maven仓库

https://artifact.cn-south-1.myhuaweicloud.com/cloudartifact/v5/maven/repositories

{
  "repository_name" : "testmaven",
  "format" : "maven2",
  "description" : "",
  "release" : "testmaven",
  "snapshot" : "testmaven",
  "includes_pattern" : "**/*",
  "share_right" : "PROJECT",
  "project_id" : "e2ee90487d6349dd944a5767225f6f55",
  "type" : "hosted"
}

响应示例

状态码:200

OK

{
  "status" : "success",
  "trace_id" : "143002-1701175135227-77",
  "result" : {
    "release" : "xx-xxxxx-x_5a775fdcb14f4431b6c0015618140bc3_maven_1_201",
    "snapshot" : "xx-xxxxx-x_5a775fdcb14f4431b6c0015618140bc3_maven_2_201"
  }
}

SDK代码示例

SDK代码示例如下。

Java

创建maven仓库

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.codeartsartifact.v2.region.CodeArtsArtifactRegion;
import com.huaweicloud.sdk.codeartsartifact.v2.*;
import com.huaweicloud.sdk.codeartsartifact.v2.model.*;


public class CreateMavenRepoSolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");

        ICredential auth = new BasicCredentials()
                .withAk(ak)
                .withSk(sk);

        CodeArtsArtifactClient client = CodeArtsArtifactClient.newBuilder()
                .withCredential(auth)
                .withRegion(CodeArtsArtifactRegion.valueOf("<YOUR REGION>"))
                .build();
        CreateMavenRepoRequest request = new CreateMavenRepoRequest();
        IDERepositoryDO body = new IDERepositoryDO();
        body.withType("hosted");
        body.withProjectId("e2ee90487d6349dd944a5767225f6f55");
        body.withShareRight("PROJECT");
        body.withIncludesPattern("**/*");
        body.withSnapshot("testmaven");
        body.withRelease("testmaven");
        body.withDescription("");
        body.withFormat("maven2");
        body.withRepositoryName("testmaven");
        request.withBody(body);
        try {
            CreateMavenRepoResponse response = client.createMavenRepo(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}

Python

创建maven仓库

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# coding: utf-8

import os
from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkcodeartsartifact.v2.region.codeartsartifact_region import CodeArtsArtifactRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkcodeartsartifact.v2 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]

    credentials = BasicCredentials(ak, sk)

    client = CodeArtsArtifactClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(CodeArtsArtifactRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = CreateMavenRepoRequest()
        request.body = IDERepositoryDO(
            type="hosted",
            project_id="e2ee90487d6349dd944a5767225f6f55",
            share_right="PROJECT",
            includes_pattern="**/*",
            snapshot="testmaven",
            release="testmaven",
            description="",
            format="maven2",
            repository_name="testmaven"
        )
        response = client.create_maven_repo(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

Go

创建maven仓库

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    codeartsartifact "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/codeartsartifact/v2"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/codeartsartifact/v2/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/codeartsartifact/v2/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")

    auth := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        Build()

    client := codeartsartifact.NewCodeArtsArtifactClient(
        codeartsartifact.CodeArtsArtifactClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.CreateMavenRepoRequest{}
	typeIdeRepositoryDo:= "hosted"
	projectIdIdeRepositoryDo:= "e2ee90487d6349dd944a5767225f6f55"
	shareRightIdeRepositoryDo:= "PROJECT"
	includesPatternIdeRepositoryDo:= "**/*"
	snapshotIdeRepositoryDo:= "testmaven"
	releaseIdeRepositoryDo:= "testmaven"
	descriptionIdeRepositoryDo:= ""
	formatIdeRepositoryDo:= "maven2"
	repositoryNameIdeRepositoryDo:= "testmaven"
	request.Body = &model.IdeRepositoryDo{
		Type: &typeIdeRepositoryDo,
		ProjectId: &projectIdIdeRepositoryDo,
		ShareRight: &shareRightIdeRepositoryDo,
		IncludesPattern: &includesPatternIdeRepositoryDo,
		Snapshot: &snapshotIdeRepositoryDo,
		Release: &releaseIdeRepositoryDo,
		Description: &descriptionIdeRepositoryDo,
		Format: &formatIdeRepositoryDo,
		RepositoryName: &repositoryNameIdeRepositoryDo,
	}
	response, err := client.CreateMavenRepo(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

更多

更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。

状态码

状态码

描述

200

OK

错误码

请参见错误码