欧美三区_成人在线免费观看视频_欧美极品少妇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)論
主站蜘蛛池模板: 奇米影视 首页 | 欧美激情五月 | 一区二区欧美视频 | 亚洲欧美日韩精品中文乱码 | 国产精品爽爽va在线观看网站 | 国产一区亚洲一区 | 在线观看亚洲一区二区三区 | 日日夜夜爱 | 性久久久久久久久波多野结衣 | 国产成人精品综合 | 狠狠色狠狠色综合久久第一次 | 天天艹天天 | 欧美亚洲另类视频 | 夜夜草 | 久久精品a| 波多野结衣在线视频观看 | 看免费一级毛片 | 亚洲欧美一区二区三区久本道 | 不卡一二区| 玖玖操 | 一级欧美在线的视频 | 国产精品不卡一区 | 日产精品久久久久久久 | 日韩av电影在线免费观看 | 久热精品视频 | 亚洲永久精品国产 | 亚洲 日本 欧美 日韩精品 | 欧美性猛交一区二区三区精品 | 国产精品爱啪在线线免费观看 | 精品国产福利片在线观看 | 国产AV亚洲精品久久久久 | 亚洲伦理在线 | 日本色网址 | 91精品一区二区综合在线 | 精品视频www | 一区视频 | 五月婷婷激情网 | 国产精品九九久久99视频 | 欧美一区二区三区四区视频 | 99久久久精品国产一区二区 | 亚洲午夜在线 |