欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

CloudStack API編程指引

系統(tǒng) 1936 0

原文地址: https://cwiki.apache.org/confluence/display/CLOUDSTACK/CloudStack+API+Coding+Guidelines

前言

本文闡述為CloudStack編寫新API或者更新已存在API時(shí)應(yīng)遵循的約定和編程指引。

參考文檔

?(暫略)

介紹

當(dāng)你需要為CS添加新的API時(shí),需要?jiǎng)?chuàng)建一個(gè)Request類和Response類(或者在擴(kuò)展CS API功能時(shí)它的API Responese已經(jīng)定義的情況下重用已經(jīng)存在的API Response類)。

編寫CS API Request類

1、request繼承自*Cmd抽象類

CUD(新增/更新/刪除 命令)

CloudStack API編程指引

R(讀取列表)命令

?

CloudStack API編程指引

重要- 從2.x開始,新的CUD API命令不再繼承自 BaseCmd 類,它們被看做是異步命令,繼承自 BaseAsyncCmd或者 BaseAsyncCreateCmd。

? ? ? ?擴(kuò)展BaseAsyncCmd或者BaseAsyncCreateCmd,創(chuàng)建新的CS實(shí)體命令擴(kuò)展BaseAsyncCreateCmd,UD命令擴(kuò)展BaseAsyncCmd。

2、新添加的command類應(yīng)以“*Cmd”結(jié)尾且標(biāo)注 @ApiCommand。更多請(qǐng)閱參考文檔 ? Annotations use in the API 中的 @ parameters。

3、定義所有的請(qǐng)求參數(shù),且所有的都用@Parameter標(biāo)注。

4、為RUD命令實(shí)現(xiàn)execute()方法,為R命令實(shí)現(xiàn) execute()/create()。

5、增加s_name--響應(yīng)的名字,并且為小寫。

6、在為命令命名時(shí),根據(jù)含義優(yōu)先使用 create/delete/update/list,只有當(dāng)這些前綴不能滿足你的邏輯時(shí)才考慮用你自己的(如assign)。

編寫CS API Response類

?1、讓你的類繼承自 BaseResponse。

?2、用 @EntityReference標(biāo)注Response類,并設(shè)定關(guān)聯(lián)的CloudStack接口,它是你返回給API用戶的對(duì)象。比如 VolumeResponse 用 EntityReference 標(biāo)注關(guān)聯(lián)Volume接口。

?3、將每個(gè)參數(shù)用 @SerializedName 和?@Param注解。?請(qǐng)閱在 Annotations use in the API 中關(guān)于這些注解的細(xì)節(jié)。

?4、參數(shù)名稱都是小寫。

?5、確保沒有將真實(shí)的DB id設(shè)置到id字段將其暴漏,請(qǐng)用 UUID值代替。

API位置和注冊(cè)

命令的位置取決于該命令將是可用/禁用插件或者CloudStack核心的一部分。

當(dāng)命令是CS核心的一部分

  • 位置:Reque/Response代碼放在 cloud-api/cloud-engine-api下。
  • 訪問權(quán)限:命令的訪問控制權(quán)限(誰有能調(diào)用它)在 commands.properties.in里注冊(cè)。
  • 命令注冊(cè):命令應(yīng)添加到CS支持的所有的API列表中,該列表由 ManagementServerImpl.? getCommands()獲得

注意當(dāng)命令調(diào)用完成時(shí),它們關(guān)聯(lián)的只能是 cloud-api 或 cloud-util包里的接口

CloudStack API編程指引

?

當(dāng)命令是插件/服務(wù)的一部分

  • 位置:Reque/Response代碼放在plugin包下。
  • 訪問權(quán)限:在Cmd文件里定義權(quán)限,使用 @APICommand 注解 "authorized"字段,如 authorized = {RoleType.Admin}) 。
  • 命令注冊(cè):讓插件管理類繼承自 PluggableService 接口,增加到命令列表的命令由getCommands()返回。

定義在插件中的命令只關(guān)聯(lián)位于 cloud-api/cloud-utils/<your plugin>中的接口。

CloudStack API編程指引

?

修改已存在API的規(guī)則

1、對(duì)Request:不要將參數(shù)從可選改為必需的;

2、對(duì)Request:不要在已存在的命令里增加一個(gè) required=true的參數(shù);

3、對(duì)Request:不要降低command的權(quán)限,從對(duì)普通用戶可用降到只對(duì)管理員可用;

4、對(duì)Request/Response:不要重命名已有的參數(shù);

5、對(duì)Request/Response:不要更改參數(shù)的類型(如從String改為Map)

6、對(duì)Response:不要?jiǎng)h除Response的參數(shù),由于第三方軟件會(huì)依賴它。

其它規(guī)則:

1、當(dāng)新增一個(gè)參數(shù)時(shí),應(yīng)該在它的 ?@Parameter 里標(biāo)注 "since=release #" 字段;

2、如果你認(rèn)為有些參數(shù)會(huì)在未來被刪除掉,請(qǐng)標(biāo)注 @Deprecated,并確保在第n版本里記錄。當(dāng)它發(fā)布后,客戶有機(jī)會(huì)去檢查/修改代碼以去掉這個(gè)參數(shù)。于是可以在第n+1個(gè)版本去除該參數(shù)。

?

CloudStack API編程指引


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦?。?!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 超碰免费在线观看 | 国产精品无码2021在线观看 | 九色视频网站 | 九九综合视频 | 亚洲精品久久久一区二区三区 | 精品视频一区二区三区 | 日韩中文字幕不卡 | 亚洲一区二区免费看 | 日韩一区二区三区视频 | 国产福利观看 | 日韩加勒比 | 夜夜夜操 | 在线亚洲一区二区 | 成人深夜视频在线观看 | 日本久久精品视频 | 亚洲精品国产第1页 | 欧美成人一区二区 | 很黄很色又爽很黄很色又爽 | 亚洲xx站 | 久久96国产精品 | 大香一本蕉伊线亚洲网 | 欧美日韩一区二区在线视频播放 | 狠狠综合久久av一区二区小说 | 一本大道香蕉中文日本不卡高清二区 | 国产精品夜夜春夜夜爽久久 | 国产精品免费一区 | 精品欧美| 亚洲精品人成网在线播放影院 | 久久久久久天天夜夜天天 | 亚洲精品久久久久久无码AV | 91短视频在线观看 | 一级做a爰片性色毛片2021 | 91色欧美| 国产真实乱freesex | 欧美日韩一区二区三区免费视频 | 男女在线观看啪网站 | 欧美在线播放一区 | 成人在线视屏 | 欧美一区二区三区视频 | 久久国产这里只精品免费 | 日日爽 |