| @@ -145,7 +145,7 @@ class ProjectsController < ApplicationController | |||
| gitea_repo = Gitea::Repository::UpdateService.call(@owner, @project&.repository&.identifier, gitea_params) | |||
| @project.repository.update_attributes({hidden: gitea_repo["private"], identifier: gitea_repo["name"]}) | |||
| end | |||
| SendTemplateMessageJob.perform_later('ProjectSettingChanged', current_user.id, @project&.id, @project.previous_changes.slice(:name, :description, :project_category_id, :project_language_id, :is_public)) if Site.has_notice_menu? | |||
| SendTemplateMessageJob.perform_later('ProjectSettingChanged', current_user.id, @project&.id, @project.previous_changes.slice(:name, :description, :project_category_id, :project_language_id, :is_public, :identifier)) if Site.has_notice_menu? | |||
| end | |||
| rescue Exception => e | |||
| uid_logger_error(e.message) | |||
| @@ -0,0 +1,8 @@ | |||
| class TemplateMessageSettingsController < ApplicationController | |||
| before_action :require_login | |||
| def index | |||
| @group_settings = TemplateMessageSetting.group(:type).count | |||
| end | |||
| end | |||
| @@ -0,0 +1,36 @@ | |||
| class Users::TemplateMessageSettingsController < Users::BaseController | |||
| before_action :check_auth | |||
| before_action :get_current_setting | |||
| def current_setting | |||
| end | |||
| def update_setting | |||
| Rails.logger.info setting_params[:notification_body] | |||
| Rails.logger.info setting_params[:email_body] | |||
| @current_setting.notification_body = setting_params[:notification_body].to_hash | |||
| @current_setting.email_body = setting_params[:email_body].to_hash | |||
| return render_error("保存失败") unless @current_setting.save! | |||
| end | |||
| private | |||
| def check_auth | |||
| return render_forbidden unless current_user.admin? || observed_logged_user? | |||
| end | |||
| def get_current_setting | |||
| @current_setting = @_observed_user.user_template_message_setting | |||
| @current_setting = UserTemplateMessageSetting.build(@_observed_user.id) if @current_setting.nil? | |||
| end | |||
| def setting_params | |||
| params.require(:setting).permit(notification_body: {}, email_body: {}) | |||
| end | |||
| def valid_setting_params | |||
| setting_params[:notification_body].keys.equal?(UserTemplateMessageSetting.init_notification_body.keys) && setting_params[:email_body].keys.equal?(UserTemplateMessageSetting.init_email_body) | |||
| end | |||
| end | |||
| @@ -372,6 +372,290 @@ await octokit.request('PATCH/PUT /api/users/:login.json') | |||
| "message": "success" | |||
| } | |||
| ``` | |||
| ## 获取平台消息设置配置信息 | |||
| 获取平台消息设置配置信息 | |||
| > 示例: | |||
| ```shell | |||
| curl -X GET http://localhost:3000/api/template_message_settings.json | |||
| ``` | |||
| ```javascript | |||
| await octokit.request('GET /api/template_message_settings.json') | |||
| ``` | |||
| ### HTTP 请求 | |||
| `GET /api/template_message_settings.json` | |||
| ### 返回字段说明: | |||
| 参数 | 类型 | 字段说明 | |||
| --------- | ----------- | ----------- | |||
| |type |string |消息配置类型 | | |||
| |type_name |string |消息配置类型含义| | |||
| |total_settings_count |int |配置条数| | |||
| |settings.name |string |配置名称| | |||
| |settings.key |string |配置标识| | |||
| |settings.notification_disabled |boolean |站内信设置是否禁用| | |||
| |settings.email_disabled |boolean |邮件设置是否禁用| | |||
| > 返回的JSON示例: | |||
| ```json | |||
| { | |||
| "status": 0, | |||
| "message": "响应成功", | |||
| "setting_types": [ | |||
| { | |||
| "type": "TemplateMessageSetting::Normal", | |||
| "type_name": "", | |||
| "total_settings_count": 3, | |||
| "settings": [ | |||
| { | |||
| "name": "被拉入或移出组织", | |||
| "key": "Organization", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "被拉入或移出项目", | |||
| "key": "Project", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "有权限变更", | |||
| "key": "Permission", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| } | |||
| ] | |||
| }, | |||
| { | |||
| "type": "TemplateMessageSetting::CreateOrAssign", | |||
| "type_name": "我创建的或负责的", | |||
| "total_settings_count": 4, | |||
| "settings": [ | |||
| { | |||
| "name": "易修被指派", | |||
| "key": "IssueAssigned", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "合并请求被指派", | |||
| "key": "PullRequestAssigned", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| } | |||
| ] | |||
| }, | |||
| { | |||
| "type": "TemplateMessageSetting::ManageProject", | |||
| "type_name": "我管理的仓库", | |||
| "total_settings_count": 4, | |||
| "settings": [ | |||
| { | |||
| "name": "有新的易修", | |||
| "key": "Issue", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "有新的合并请求", | |||
| "key": "PullRequest", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "有成员变动", | |||
| "key": "Member", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| }, | |||
| { | |||
| "name": "设置更改", | |||
| "key": "SettingChanged", | |||
| "notification_disabled": true, | |||
| "email_disabled": false | |||
| } | |||
| ] | |||
| } | |||
| ] | |||
| } | |||
| ``` | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| ## 获取用户消息设置配置信息 | |||
| 获取用户消息设置配置信息 | |||
| > 示例: | |||
| ```shell | |||
| curl -X GET http://localhost:3000/api/users/yystopf/template_message_settings.json | |||
| ``` | |||
| ```javascript | |||
| await octokit.request('GET /api/uses/yystopf/template_message_settings.json') | |||
| ``` | |||
| ### HTTP 请求 | |||
| `GET /api/users/:user_id/template_message_settings.json` | |||
| ### 返回字段说明: | |||
| 参数 | 类型 | 字段说明 | |||
| --------- | ----------- | ----------- | |||
| |notification_body |string |站内信配置 | | |||
| |email_body |string |邮件配置| | |||
| > 返回的JSON示例: | |||
| ```json | |||
| { | |||
| "status": 0, | |||
| "message": "响应成功", | |||
| "user": { | |||
| "id": 2, | |||
| "type": "User", | |||
| "name": "heh", | |||
| "login": "yystopf", | |||
| "image_url": "system/lets/letter_avatars/2/H/188_239_142/120.png" | |||
| }, | |||
| "notification_body": { | |||
| "CreateOrAssign::IssueAssigned": true, | |||
| "CreateOrAssign::PullRequestAssigned": true, | |||
| "ManageProject::Issue": true, | |||
| "ManageProject::PullRequest": true, | |||
| "ManageProject::Member": true, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": true, | |||
| "Normal::Project": true, | |||
| "Normal::Permission": true | |||
| }, | |||
| "email_body": { | |||
| "CreateOrAssign::IssueAssigned": false, | |||
| "CreateOrAssign::PullRequestAssigned": false, | |||
| "ManageProject::Issue": false, | |||
| "ManageProject::PullRequest": false, | |||
| "ManageProject::Member": false, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": false, | |||
| "Normal::Project": true, | |||
| "Normal::Permission": false | |||
| } | |||
| } | |||
| ``` | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| ## 重新设置用户消息设置配置信息 | |||
| 重新设置用户消息设置配置信息 | |||
| > 示例: | |||
| ```shell | |||
| curl -X POST http://localhost:3000/api/users/yystopf/template_message_settings/update_setting.json | |||
| ``` | |||
| ```javascript | |||
| await octokit.request('POST /api/uses/yystopf/template_message_settings/update_setting.json') | |||
| ``` | |||
| ### HTTP 请求 | |||
| `POST /api/users/:user_id/template_message_settings/update_setting.json` | |||
| ### 请求字段说明: | |||
| 参数 | 类型 | 字段说明 | |||
| --------- | ----------- | ----------- | |||
| |notification_body |string |站内信配置 | | |||
| |email_body |string |邮件配置| | |||
| > 请求的JSON示例: | |||
| ```json | |||
| { | |||
| "setting": { | |||
| "notification_body": { | |||
| "CreateOrAssign::IssueAssigned": true, | |||
| "CreateOrAssign::PullRequestAssigned": true, | |||
| "ManageProject::Issue": true, | |||
| "ManageProject::PullRequest": true, | |||
| "ManageProject::Member": true, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": true, | |||
| "Normal::Project": true, | |||
| "Normal::Permission": true | |||
| }, | |||
| "email_body": { | |||
| "CreateOrAssign::IssueAssigned": false, | |||
| "CreateOrAssign::PullRequestAssigned": false, | |||
| "ManageProject::Issue": false, | |||
| "ManageProject::PullRequest": false, | |||
| "ManageProject::Member": false, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": false, | |||
| "Normal::Project": "t", | |||
| "Normal::Permission": false | |||
| } | |||
| } | |||
| } | |||
| ``` | |||
| ### 返回字段说明: | |||
| 参数 | 类型 | 字段说明 | |||
| --------- | ----------- | ----------- | |||
| |notification_body |string |站内信配置 | | |||
| |email_body |string |邮件配置| | |||
| > 返回的JSON示例: | |||
| ```json | |||
| { | |||
| "status": 0, | |||
| "message": "响应成功", | |||
| "user": { | |||
| "id": 2, | |||
| "type": "User", | |||
| "name": "heh", | |||
| "login": "yystopf", | |||
| "image_url": "system/lets/letter_avatars/2/H/188_239_142/120.png" | |||
| }, | |||
| "notification_body": { | |||
| "CreateOrAssign::IssueAssigned": true, | |||
| "CreateOrAssign::PullRequestAssigned": true, | |||
| "ManageProject::Issue": true, | |||
| "ManageProject::PullRequest": true, | |||
| "ManageProject::Member": true, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": true, | |||
| "Normal::Project": true, | |||
| "Normal::Permission": true | |||
| }, | |||
| "email_body": { | |||
| "CreateOrAssign::IssueAssigned": false, | |||
| "CreateOrAssign::PullRequestAssigned": false, | |||
| "ManageProject::Issue": false, | |||
| "ManageProject::PullRequest": false, | |||
| "ManageProject::Member": false, | |||
| "ManageProject::SettingChanged": true, | |||
| "Normal::Organization": false, | |||
| "Normal::Project": true, | |||
| "Normal::Permission": false | |||
| } | |||
| } | |||
| ``` | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| ## 获取用户星标项目 | |||
| 获取用户星标项目 | |||
| @@ -45,8 +45,12 @@ class SendTemplateMessageJob < ApplicationJob | |||
| issue = Issue.find_by_id(issue_id) | |||
| return unless operator.present? && issue.present? | |||
| receivers = User.where(id: [issue&.assigned_to_id, issue&.author_id]).where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::IssueChanged.get_message_content(receivers, operator, issue, change_params) | |||
| receivers_string, content, notification_url = MessageTemplate::IssueChanged.get_message_content(receivers, operator, issue, change_params.symbolize_keys) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, issue_id: issue.id, change_params: change_params.symbolize_keys}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::IssueChanged.get_email_message_content(receiver, operator, issue, change_params) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| when 'IssueCreatorExpire' | |||
| issue_id = args[0] | |||
| issue = Issue.find_by_id(issue_id) | |||
| @@ -61,6 +65,10 @@ class SendTemplateMessageJob < ApplicationJob | |||
| receivers = User.where(id: [issue_assigned_to_id, issue_author_id]).where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::IssueDeleted.get_message_content(receivers, operator, issue_title) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, issue_title: issue_title}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::IssueDeleted.get_email_message_content(receiver, operator, issue_title) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| when 'OrganizationJoined' | |||
| user_id, organization_id = args[0], args[1] | |||
| user = User.find_by_id(user_id) | |||
| @@ -193,7 +201,7 @@ class SendTemplateMessageJob < ApplicationJob | |||
| receivers_string, content, notification_url = MessageTemplate::ProjectRole.get_message_content(receivers, project, role) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, user_id: user.id, project_id: project.id, role: role}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::ProjectRole.get_email_message_content(receivers, project, role) | |||
| receivers_email_string, email_title, email_content = MessageTemplate::ProjectRole.get_email_message_content(receiver, project, role) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| when 'ProjectSettingChanged' | |||
| @@ -203,7 +211,7 @@ class SendTemplateMessageJob < ApplicationJob | |||
| return unless operator.present? && project.present? | |||
| receivers = project.all_managers.where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::ProjectSettingChanged.get_message_content(receivers, operator, project, change_params.symbolize_keys) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, project_id: project.id, change_params: change_params}) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, project_id: project.id, change_params: change_params.symbolize_keys}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::ProjectSettingChanged.get_email_message_content(receiver, operator, project, change_params.symbolize_keys) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| @@ -238,6 +246,10 @@ class SendTemplateMessageJob < ApplicationJob | |||
| receivers = User.where(id: [issue&.assigned_to_id, pull_request&.user_id]).where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::PullRequestChanged.get_message_content(receivers, operator, pull_request, change_params.symbolize_keys) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, pull_request_id: pull_request.id, change_params: change_params}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::PullRequestChanged.get_email_message_content(receiver, operator, pull_request, change_params.symbolize_keys) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| when 'PullRequestClosed' | |||
| operator_id, pull_request_id = args[0], args[1] | |||
| operator = User.find_by_id(operator_id) | |||
| @@ -246,6 +258,10 @@ class SendTemplateMessageJob < ApplicationJob | |||
| receivers = User.where(id: [pull_request&.issue&.assigned_to_id, pull_request&.user_id]).where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::PullRequestClosed.get_message_content(receivers, operator, pull_request) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, pull_request_id: pull_request.id}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::PullRequestClosed.get_email_message_content(receiver, operator, pull_request) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| when 'PullRequestMerged' | |||
| operator_id, pull_request_id = args[0], args[1] | |||
| operator = User.find_by_id(operator_id) | |||
| @@ -254,6 +270,10 @@ class SendTemplateMessageJob < ApplicationJob | |||
| receivers = User.where(id: [pull_request&.issue&.assigned_to_id, pull_request&.user_id]).where.not(id: operator&.id) | |||
| receivers_string, content, notification_url = MessageTemplate::PullRequestMerged.get_message_content(receivers, operator, pull_request) | |||
| Notice::Write::CreateService.call(receivers_string, content, notification_url, source, {operator_id: operator.id, pull_request_id: pull_request.id}) | |||
| receivers.find_each do |receiver| | |||
| receivers_email_string, email_title, email_content = MessageTemplate::PullRequestMerged.get_email_message_content(receiver, operator, pull_request) | |||
| Notice::Write::EmailCreateService.call(receivers_email_string, email_title, email_content) | |||
| end | |||
| end | |||
| end | |||
| end | |||
| @@ -20,16 +20,19 @@ class MessageTemplate < ApplicationRecord | |||
| self.create(type: 'MessageTemplate::IssueAssigned', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 指派给你一个易修:<b>{title}</b>', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}', email: email_html, email_title: '{nickname1} 在 {nickname2}/{repository} 指派给你一个易修') | |||
| self.create(type: 'MessageTemplate::IssueAssignerExpire', sys_notice: '您负责的易修 <b>{title}</b> 已临近截止日期,请尽快处理', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| self.create(type: 'MessageTemplate::IssueAtme', sys_notice: '<b>{nickname}</b> 在易修 <b>{title}</b> 中@我', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| self.create(type: 'MessageTemplate::IssueChanged', sys_notice: '在项目 <b>{nickname2}/{repository}</b> 的易修 <b>{title}</b> 中:{ifassigner}{nickname1}将负责人从 <b>{assigner1}</b> 修改为 <b>{assigner2}</b> {endassigner}{ifstatus}{nickname1}将状态从 <b>{status1}</b> 修改为 <b>{status2}</b> {endstatus}{iftracker}{nickname1}将类型从 <b>{tracker1}</b> 修改为 <b>{tracker2}</b> {endtracker}{ifpriority}{nickname1}将优先级从 <b>{priority1}</b> 修改为 <b>{priority2}</b> {endpriority}{ifmilestone}{nickname1}将里程碑从 <b>{milestone1}</b> 修改为 <b>{milestone2}</b> {endmilestone}{iftag}{nickname1}将标记从 <b>{tag1}</b> 修改为 <b>{tag2}</b> {endtag}{ifdoneratio}{nickname1}将完成度从 <b>{doneratio1}</b> 修改为 <b>{doneratio2}</b> {enddoneratio}{ifbranch}{nickname1}将指定分支从 <b>{branch1}</b> 修改为 <b>{branch2}</b> {endbranch}{ifstartdate}{nickname1}将开始日期从 <b>{startdate1}</b> 修改为 <b>{startdate2}</b> {endstartdate}{ifduedate}{nickname1}将结束日期从 <b>{duedate1}</b> 修改为 <b>{duedate2}</b> {endduedate}', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| email_html = File.read("#{email_template_html_dir}/issue_changed.html") | |||
| self.create(type: 'MessageTemplate::IssueChanged', sys_notice: '在项目 <b>{nickname2}/{repository}</b> 的易修 <b>{title}</b> 中:{ifassigner}{nickname1}将负责人从 <b>{assigner1}</b> 修改为 <b>{assigner2}</b> {endassigner}{ifstatus}{nickname1}将状态从 <b>{status1}</b> 修改为 <b>{status2}</b> {endstatus}{iftracker}{nickname1}将类型从 <b>{tracker1}</b> 修改为 <b>{tracker2}</b> {endtracker}{ifpriority}{nickname1}将优先级从 <b>{priority1}</b> 修改为 <b>{priority2}</b> {endpriority}{ifmilestone}{nickname1}将里程碑从 <b>{milestone1}</b> 修改为 <b>{milestone2}</b> {endmilestone}{iftag}{nickname1}将标记从 <b>{tag1}</b> 修改为 <b>{tag2}</b> {endtag}{ifdoneratio}{nickname1}将完成度从 <b>{doneratio1}</b> 修改为 <b>{doneratio2}</b> {enddoneratio}{ifbranch}{nickname1}将指定分支从 <b>{branch1}</b> 修改为 <b>{branch2}</b> {endbranch}{ifstartdate}{nickname1}将开始日期从 <b>{startdate1}</b> 修改为 <b>{startdate2}</b> {endstartdate}{ifduedate}{nickname1}将结束日期从 <b>{duedate1}</b> 修改为 <b>{duedate2}</b> {endduedate}', email: email_html, email_title: '易修 {title} 有状态变更', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| self.create(type: 'MessageTemplate::IssueCreatorExpire', sys_notice: '您发布的易修 <b>{title}</b> 已临近截止日期,请尽快处理', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| self.create(type: 'MessageTemplate::IssueDeleted', sys_notice: '{nickname}已将易修 <b>{title}</b> 删除', notification_url: '') | |||
| email_html = File.read("#{email_template_html_dir}/issue_deleted.html") | |||
| self.create(type: 'MessageTemplate::IssueDeleted', sys_notice: '{nickname}已将易修 <b>{title}</b> 删除', email: email_html, email_title: '易修 {title} 有状态变更', notification_url: '') | |||
| self.create(type: 'MessageTemplate::IssueJournal', sys_notice: '{nickname}评论易修{title}:<b>{notes}</b>', notification_url: '{baseurl}/{owner}/{identifier}/issues/{id}') | |||
| self.create(type: 'MessageTemplate::LoginIpTip', sys_notice: '您的账号{nickname}于{login_time)在非常用的IP地址{ip}登录,如非本人操作,请立即修改密码', notification_url: '') | |||
| email_html = File.read("#{email_template_html_dir}/organization_joined.html") | |||
| self.create(type: 'MessageTemplate::OrganizationJoined', sys_notice: '你已加入 <b>{organization}</b> 组织', notification_url: '{baseurl}/{login}', email: email_html, email_title: '你已加入 {organization} 组织') | |||
| email_html = File.read("#{email_template_html_dir}/organization_left.html") | |||
| self.create(type: 'MessageTemplate::OrganizationLeft', sys_notice: '你已被移出 <b>{organization}</b> 组织', notification_url: '', email: email_html, email_title: '你已被移出 {organization} 组织') | |||
| self.create(type: 'MessageTemplate::OrganizationRole', sys_notice: '组织 <b>{organization}</b> 已把你的角色改为 <b>{role}</b>', notification_url: '{baseurl}/{login}') | |||
| email_html = File.read("#{email_template_html_dir}/organization_role.html") | |||
| self.create(type: 'MessageTemplate::OrganizationRole', sys_notice: '组织 <b>{organization}</b> 已把你的角色改为 <b>{role}</b>', email: email_html, email_title: '在 {organization} 组织你的账号有权限变更', notification_url: '{baseurl}/{login}') | |||
| self.create(type: 'MessageTemplate::ProjectDeleted', sys_notice: '你关注的仓库{nickname}/{repository}已被删除', notification_url: '') | |||
| self.create(type: 'MessageTemplate::ProjectFollowed', sys_notice: '<b>{nickname}</b> 关注了你管理的仓库', notification_url: '{baseurl}/{login}') | |||
| self.create(type: 'MessageTemplate::ProjectForked', sys_notice: '<b>{nickname1}</b> 复刻了你管理的仓库{nickname1}/{repository1}到{nickname2}/{repository2}', notification_url: '{baseurl}/{owner}/{identifier}') | |||
| @@ -46,19 +49,23 @@ class MessageTemplate < ApplicationRecord | |||
| self.create(type: 'MessageTemplate::ProjectMilestone', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 创建了一个里程碑:<b>{title}</b>', notification_url: '{baseurl}/{owner}/{identifier}/milestones/{id}') | |||
| self.create(type: 'MessageTemplate::ProjectPraised', sys_notice: '<b>{nickname}</b> 点赞了你管理的仓库', notification_url: '{baseurl}/{login}') | |||
| email_html = File.read("#{email_template_html_dir}/project_pull_request.html") | |||
| self.create(type: 'MessageTemplate::ProjectPullRequest', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 提交了一个合并请求:<b>{title}</b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount', email: email_html, email_title: '{nickname1} 在 {nickname2}/{repository} 提交了一个合并请求') | |||
| self.create(type: 'MessageTemplate::ProjectRole', sys_notice: '仓库 <b>{repository}</b> 已把你的角色改为 <b>{role}</b>', notification_url: '{baseurl}/{owner}/{identifier}') | |||
| self.create(type: 'MessageTemplate::ProjectPullRequest', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 提交了一个合并请求:<b>{title}</b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}', email: email_html, email_title: '{nickname1} 在 {nickname2}/{repository} 提交了一个合并请求') | |||
| email_html = File.read("#{email_template_html_dir}/project_role.html") | |||
| self.create(type: 'MessageTemplate::ProjectRole', sys_notice: '仓库 <b>{nickname}/{repository}</b> 已把你的角色改为 <b>{role}</b>', email: email_html, email_title: '在 {nickname}/{repository} 项目你的账号有权限变更', notification_url: '{baseurl}/{owner}/{identifier}') | |||
| email_html = File.read("#{email_template_html_dir}/project_setting_changed.html") | |||
| self.create(type: 'MessageTemplate::ProjectSettingChanged', sys_notice: '{nickname1}更改了 <b>{nickname2}/{repository}</b> 仓库设置:{ifname}更改项目名称为"<b>{name}</b>"{endname}{ifdescription}更改项目简介为"<b>{description}</b>"{enddescription}{ifcategory}更改项目类别为"<b>{category}</b>"{endcategory}{iflanguage}更改项目语言为"<b>{language}</b>"{endlanguage}{ifpermission}将仓库设为"<b>{permission}</b>"{endpermission}{ifnavbar}将项目导航更改为"<b>{navbar}</b>"{endnavbar}', notification_url: '{baseurl}/{owner}/{identifier}/settings', email: email_html, email_title: '您管理的仓库 {nickname2}/{repository} 仓库设置已被更改') | |||
| self.create(type: 'MessageTemplate::ProjectSettingChanged', sys_notice: '{nickname1}更改了 <b>{nickname2}/{repository}</b> 仓库设置:{ifname}更改项目名称为"<b>{name}</b>"{endname}{ifidentifier}更改项目标识为"<b>{identifier}</b>"{endidentifier}{ifdescription}更改项目简介为"<b>{description}</b>"{enddescription}{ifcategory}更改项目类别为"<b>{category}</b>"{endcategory}{iflanguage}更改项目语言为"<b>{language}</b>"{endlanguage}{ifpermission}将仓库设为"<b>{permission}</b>"{endpermission}{ifnavbar}将项目导航更改为"<b>{navbar}</b>"{endnavbar}', notification_url: '{baseurl}/{owner}/{identifier}/settings', email: email_html, email_title: '您管理的仓库 {nickname2}/{repository} 仓库设置已被更改') | |||
| self.create(type: 'MessageTemplate::ProjectTransfer', sys_notice: '你关注的仓库{nickname1}/{repository1}已被转移至{nickname2}/{repository2}', notification_url: '{baseurl}/{owner}/{identifier}') | |||
| self.create(type: 'MessageTemplate::ProjectVersion', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 创建了发行版:<b>{title}</b>', notification_url: '{baseurl}/{owner}/{identifier}/releases') | |||
| email_html = File.read("#{email_template_html_dir}/pull_request_assigned.html") | |||
| self.create(type: 'MessageTemplate::PullRequestAssigned', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 指派给你一个合并请求:<b>{title}<b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount', email: email_html, email_title: '{nickname1} 在 {nickname2}/{repository} 指派给你一个合并请求') | |||
| self.create(type: 'MessageTemplate::PullRequestAtme', sys_notice: '<b>{nickname}</b> 在合并请求 <b>{title}</b> 中@我', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount') | |||
| self.create(type: 'MessageTemplate::PullRequestChanged', sys_notice: '在项目{nickname2}/{repository}的合并请求 <b>{title}</b> 中:{ifassigner}{nickname1}将审查成员从 <b>{assigner1}</b> 修改为 <b>{assigner2}</b> {endassigner}{ifmilestone}{nickname1}将里程碑从 <b>{milestone1}</b> 修改为 <b>{milestone2}</b> {endmilestone}{iftag}{nickname1}将标记从 <b>{tag1}</b> 修改为 <b>{tag2}</b> {endtag}{ifpriority}{nickname1}将优先级从 <b>{priority1}</b> 修改为 <b>{priority2}</b> {endpriority}', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount') | |||
| self.create(type: 'MessageTemplate::PullRequestClosed', sys_notice: '你提交的合并请求:{title} <b>被拒绝</b>', notification_url: '') | |||
| self.create(type: 'MessageTemplate::PullRequestJournal', sys_notice: '{nickname}评论合并请求{title}:<b>{notes}</b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount') | |||
| self.create(type: 'MessageTemplate::PullRequestMerged', sys_notice: '你提交的合并请求:{title} <b>已通过</b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}/Messagecount') | |||
| self.create(type: 'MessageTemplate::PullRequestAssigned', sys_notice: '{nickname1}在 <b>{nickname2}/{repository}</b> 指派给你一个合并请求:<b>{title}<b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}', email: email_html, email_title: '{nickname1} 在 {nickname2}/{repository} 指派给你一个合并请求') | |||
| self.create(type: 'MessageTemplate::PullRequestAtme', sys_notice: '<b>{nickname}</b> 在合并请求 <b>{title}</b> 中@我', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}') | |||
| email_html = File.read("#{email_template_html_dir}/pull_request_changed.html") | |||
| self.create(type: 'MessageTemplate::PullRequestChanged', sys_notice: '在项目{nickname2}/{repository}的合并请求 <b>{title}</b> 中:{ifassigner}{nickname1}将审查成员从 <b>{assigner1}</b> 修改为 <b>{assigner2}</b> {endassigner}{ifmilestone}{nickname1}将里程碑从 <b>{milestone1}</b> 修改为 <b>{milestone2}</b> {endmilestone}{iftag}{nickname1}将标记从 <b>{tag1}</b> 修改为 <b>{tag2}</b> {endtag}{ifpriority}{nickname1}将优先级从 <b>{priority1}</b> 修改为 <b>{priority2}</b> {endpriority}', email: email_html, email_title: '合并请求 {title} 有状态变更', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}') | |||
| email_html = File.read("#{email_template_html_dir}/pull_request_closed.html") | |||
| self.create(type: 'MessageTemplate::PullRequestClosed', sys_notice: '你提交的合并请求:{title} <b>被拒绝</b>', email: email_html, email_title: '合并请求 {title} 有状态变更', notification_url: '') | |||
| self.create(type: 'MessageTemplate::PullRequestJournal', sys_notice: '{nickname}评论合并请求{title}:<b>{notes}</b>', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}') | |||
| email_html = File.read("#{email_template_html_dir}/pull_request_merged.html") | |||
| self.create(type: 'MessageTemplate::PullRequestMerged', sys_notice: '你提交的合并请求:{title} <b>已通过</b>', email: email_html, email_title: '合并请求 {title} 有状态变更', notification_url: '{baseurl}/{owner}/{identifier}/pulls/{id}') | |||
| end | |||
| def self.sys_notice | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::IssueAssigned < MessageTemplate | |||
| # MessageTemplate::IssueAssigned.get_message_content(User.where(login: 'yystopf'), User.last, Issue.last) | |||
| def self.get_message_content(receivers, operator, issue) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::IssueAssigned"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| content = sys_notice.gsub('{nickname1}', operator&.real_name).gsub('{nickname2}', owner&.real_name).gsub('{repository}', project&.name).gsub('{title}', issue&.subject) | |||
| @@ -28,6 +34,9 @@ class MessageTemplate::IssueAssigned < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, operator, issue) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::IssueAssigned"] | |||
| end | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::IssueChanged < MessageTemplate | |||
| # MessageTemplate::IssueChanged.get_message_content(User.where(login: 'yystopf'), User.last, Issue.last, {status_id: [1, 2], assigned_to_id: [nil, 203], tracker_id: [4, 3], priority_id: [2, 4], fixed_version_id: [nil, 5], due_date: ['', '2021-09-11'], done_ratio: [0, 40], issue_tags_value: ["", "7"], branch_name: ["", "master"]}) | |||
| def self.get_message_content(receivers, operator, issue, change_params) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["CreateOrAssign::IssueChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| return '', '', '' if change_params.blank? | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| @@ -180,4 +186,183 @@ class MessageTemplate::IssueChanged < MessageTemplate | |||
| Rails.logger.info("MessageTemplate::IssueAssigned.get_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receiver, operator, issue, change_params) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["CreateOrAssign::IssueChanged"] | |||
| end | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| title.gsub!('{title}', issue&.subject) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{login1}', operator&.login) | |||
| content.gsub!('{nickname1}', operator&.real_name) | |||
| content.gsub!('{login2}', owner&.login) | |||
| content.gsub!('{nickname2}', owner&.real_name) | |||
| content.gsub!('{identifier}', project&.identifier) | |||
| content.gsub!('{repository}', project&.name) | |||
| content.gsub!('{title}', issue&.subject) | |||
| content.gsub!('{id}', issue&.id.to_s) | |||
| change_count = change_params.keys.size | |||
| # 易修负责人修改 | |||
| if change_params[:assigned_to_id].present? | |||
| assigner1 = User.find_by_id(change_params[:assigned_to_id][0]) | |||
| assigner2 = User.find_by_id(change_params[:assigned_to_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifassigner}', '<br/>') | |||
| else | |||
| content.sub!('{ifassigner}', '') | |||
| end | |||
| content.sub!('{endassigner}', '') | |||
| content.gsub!('{assigner1}', assigner1.present? ? assigner1&.real_name : '未指派成员') | |||
| content.gsub!('{assigner2}', assigner2.present? ? assigner2&.real_name : '未指派成员') | |||
| else | |||
| content.gsub!(/({ifassigner})(.*)({endassigner})/, '') | |||
| end | |||
| # 易修状态修改 | |||
| if change_params[:status_id].present? | |||
| status1 = IssueStatus.find_by_id(change_params[:status_id][0]) | |||
| status2 = IssueStatus.find_by_id(change_params[:status_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifstatus}', '<br/>') | |||
| else | |||
| content.sub!('{ifstatus}', '') | |||
| end | |||
| content.sub!('{endstatus}', '') | |||
| content.gsub!('{status1}', status1&.name) | |||
| content.gsub!('{status2}', status2&.name) | |||
| else | |||
| content.gsub!(/({ifstatus})(.*)({endstatus})/, '') | |||
| end | |||
| # 易修类型修改 | |||
| if change_params[:tracker_id].present? | |||
| tracker1 = Tracker.find_by_id(change_params[:tracker_id][0]) | |||
| tracker2 = Tracker.find_by_id(change_params[:tracker_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{iftracker}', '<br/>') | |||
| else | |||
| content.sub!('{iftracker}', '') | |||
| end | |||
| content.sub!('{endtracker}', '') | |||
| content.gsub!('{tracker1}', tracker1&.name) | |||
| content.gsub!('{tracker2}', tracker2&.name) | |||
| else | |||
| content.gsub!(/({iftracker})(.*)({endtracker})/, '') | |||
| end | |||
| # 易修里程碑修改 | |||
| if change_params[:fixed_version_id].present? | |||
| fix_version1 = Version.find_by_id(change_params[:fixed_version_id][0]) | |||
| fix_version2 = Version.find_by_id(change_params[:fixed_version_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifmilestone}', '<br/>') | |||
| else | |||
| content.sub!('{ifmilestone}', '') | |||
| end | |||
| content.sub!('{endmilestone}', '') | |||
| content.gsub!('{milestone1}', fix_version1.present? ? fix_version1&.name : '未选择里程碑') | |||
| content.gsub!('{milestone2}', fix_version2.present? ? fix_version2&.name : '未选择里程碑') | |||
| else | |||
| content.gsub!(/({ifmilestone})(.*)({endmilestone})/, '') | |||
| end | |||
| # 易修标记修改 | |||
| if change_params[:issue_tags_value].present? | |||
| issue_tags1 = IssueTag.where(id: change_params[:issue_tags_value][0]).distinct | |||
| issue_tags2 = IssueTag.where(id: change_params[:issue_tags_value][1]).distinct | |||
| tag1 = issue_tags1.pluck(:name).join(",").blank? ? '未选择标记' : issue_tags1.pluck(:name).join(",") | |||
| tag2 = issue_tags2.pluck(:name).join(",").blank? ? '未选择标记' : issue_tags2.pluck(:name).join(",") | |||
| if change_count > 1 | |||
| content.sub!('{iftag}', '<br/>') | |||
| else | |||
| content.sub!('{iftag}', '') | |||
| end | |||
| content.sub!('{endtag}', '') | |||
| content.gsub!('{tag1}', tag1) | |||
| content.gsub!('{tag2}', tag2) | |||
| else | |||
| content.gsub!(/({iftag})(.*)({endtag})()/, '') | |||
| end | |||
| # 易修优先级修改 | |||
| if change_params[:priority_id].present? | |||
| priority1 = IssuePriority.find_by_id(change_params[:priority_id][0]) | |||
| priority2 = IssuePriority.find_by_id(change_params[:priority_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifpriority}', '<br/>') | |||
| else | |||
| content.sub!('{ifpriority}', '') | |||
| end | |||
| content.sub!('{endpriority}', '') | |||
| content.gsub!('{priority1}', priority1&.name) | |||
| content.gsub!('{priority2}', priority2&.name) | |||
| else | |||
| content.gsub!(/({ifpriority})(.*)({endpriority})/, '') | |||
| end | |||
| # 易修完成度修改 | |||
| if change_params[:done_ratio].present? | |||
| doneratio1 = change_params[:done_ratio][0] | |||
| doneratio2 = change_params[:done_ratio][1] | |||
| if change_count > 1 | |||
| content.sub!('{ifdoneratio}', '<br/>') | |||
| else | |||
| content.sub!('{ifdoneratio}', '') | |||
| end | |||
| content.sub!('{enddoneratio}', '') | |||
| content.gsub!('{doneratio1}', "#{doneratio1}%") | |||
| content.gsub!('{doneratio2}', "#{doneratio2}%") | |||
| else | |||
| content.gsub!(/({ifdoneratio})(.*)({enddoneratio})/, '') | |||
| end | |||
| # 易修指定分支修改 | |||
| if change_params[:branch_name].present? | |||
| branch1 = change_params[:branch_name][0].blank? ? '分支未指定' : change_params[:branch_name][0] | |||
| branch2 = change_params[:branch_name][1].blank? ? '分支未指定' : change_params[:branch_name][1] | |||
| if change_count > 1 | |||
| content.sub!('{ifbranch}', '<br/>') | |||
| else | |||
| content.sub!('{ifbranch}', '') | |||
| end | |||
| content.sub!('{endbranch}', '') | |||
| content.gsub!('{branch1}', branch1) | |||
| content.gsub!('{branch2}', branch2) | |||
| else | |||
| content.gsub!(/({ifbranch})(.*)({endbranch})/, '') | |||
| end | |||
| # 易修开始日期修改 | |||
| if change_params[:start_date].present? | |||
| startdate1 = change_params[:start_date][0].blank? ? "未选择开始日期" : change_params[:start_date][0] | |||
| startdate2 = change_params[:start_date][1].blank? ? "未选择开始日期" : change_params[:start_date][1] | |||
| if change_count > 1 | |||
| content.sub!('{ifstartdate}', '<br/>') | |||
| else | |||
| content.sub!('{ifstartdate}', '') | |||
| end | |||
| content.sub!('{endstartdate}', '') | |||
| content.gsub!('{startdate1}', startdate1 ) | |||
| content.gsub!('{startdate2}', startdate2) | |||
| else | |||
| content.gsub!(/({ifstartdate})(.*)({endstartdate})/, '') | |||
| end | |||
| # 易修结束日期修改 | |||
| if change_params[:due_date].present? | |||
| duedate1 = change_params[:due_date][0].blank? ? '未选择结束日期' : change_params[:due_date][0] | |||
| duedate2 = change_params[:due_date][1].blank? ? '未选择结束日期' : change_params[:due_date][1] | |||
| if change_count > 1 | |||
| content.sub!('{ifduedate}', '<br/>') | |||
| else | |||
| content.sub!('{ifduedate}', '') | |||
| end | |||
| content.sub!('{endduedate}', '') | |||
| content.gsub!('{duedate1}', duedate1) | |||
| content.gsub!('{duedate2}', duedate2) | |||
| else | |||
| content.gsub!(/({ifduedate})(.*)({endduedate})/, '') | |||
| end | |||
| return receiver&.mail, title, content | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::IssueChanged.get_email_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| end | |||
| @@ -17,10 +17,35 @@ class MessageTemplate::IssueDeleted < MessageTemplate | |||
| # MessageTemplate::IssueDeleted.get_message_content(User.where(login: 'yystopf'), User.last, "hahah") | |||
| def self.get_message_content(receivers, operator, issue_title) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["CreateOrAssign::IssueChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname}', operator&.real_name).gsub('{title}', issue_title) | |||
| return receivers_string(receivers), content, notification_url | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::IssueAtme.get_message_content [ERROR] #{e}") | |||
| Rails.logger.info("MessageTemplate::IssueDeleted.get_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receiver, operator, issue_title) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["CreateOrAssign::IssueChanged"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{title}', issue_title) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{nickname}', operator&.real_name) | |||
| content.gsub!('{login}', operator&.login) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{title}', issue_title) | |||
| return receiver&.mail, title, content | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::IssueDeleted.get_email_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| end | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::OrganizationJoined < MessageTemplate | |||
| # MessageTemplate::OrganizationJoined.get_message_content(User.where(login: 'yystopf'), Organization.last) | |||
| def self.get_message_content(receivers, organization) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Organization"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{organization}', organization&.real_name) | |||
| url = notification_url.gsub('{login}', organization&.name) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::OrganizationJoined < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, organization) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Organization"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{organization}', organization&.real_name) | |||
| content = email | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::OrganizationLeft < MessageTemplate | |||
| # MessageTemplate::OrganizationLeft.get_message_content(User.where(login: 'yystopf'), Organization.last) | |||
| def self.get_message_content(receivers, organization) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Organization"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{organization}', organization&.real_name) | |||
| url = notification_url.gsub('{login}', organization&.name) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::OrganizationLeft < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, organization) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Organization"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{organization}', organization&.real_name) | |||
| content = email | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::OrganizationRole < MessageTemplate | |||
| # MessageTemplate::OrganizationRole.get_message_content(User.where(login: 'yystopf'), Organization.last, '管理员') | |||
| def self.get_message_content(receivers, organization, role) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Permission"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{organization}', organization&.real_name).gsub('{role}', role) | |||
| url = notification_url.gsub('{login}', organization&.login) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::OrganizationRole < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, organization, role) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Permission"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{organization}', organization&.real_name) | |||
| title.gsub!('{role}', role) | |||
| @@ -17,9 +17,15 @@ class MessageTemplate::ProjectIssue < MessageTemplate | |||
| # MessageTemplate::ProjectIssue.get_message_content(User.where(login: 'yystopf'), User.where(login: 'forgetest1'), User.last, Issue.last) | |||
| def self.get_message_content(managers, followers, operator, issue) | |||
| managers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| managers = managers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["ManageProject::Issue"] | |||
| end | |||
| end | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| receivers = managers + followers | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname1}', operator&.real_name).gsub('{nickname2}', owner&.real_name).gsub('{repository}', project&.name).gsub('{title}', issue&.subject) | |||
| url = notification_url.gsub('{owner}', owner&.login).gsub('{identifier}', project&.identifier).gsub('{id}', issue&.id.to_s) | |||
| @@ -30,6 +36,9 @@ class MessageTemplate::ProjectIssue < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, is_manager, operator, issue) | |||
| if receiver.user_template_message_setting.present? && is_manager | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["ManageProject::Issue"] | |||
| end | |||
| project = issue&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::ProjectJoined < MessageTemplate | |||
| # MessageTemplate::ProjectJoined.get_message_content(User.where(login: 'yystopf'), Project.last) | |||
| def self.get_message_content(receivers, project) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Project"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{repository}', project&.name) | |||
| url = notification_url.gsub('{owner}', project&.owner&.login).gsub('{identifier}', project&.identifier) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::ProjectJoined < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, project) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Project"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{repository}', project&.name) | |||
| @@ -17,6 +17,11 @@ class MessageTemplate::ProjectLeft < MessageTemplate | |||
| # MessageTemplate::ProjectLeft.get_message_content(User.where(login: 'yystopf'), Project.last) | |||
| def self.get_message_content(receivers, project) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Project"] | |||
| end | |||
| end | |||
| content = sys_notice.gsub('{repository}', project&.name) | |||
| url = notification_url.gsub('{owner}', project&.owner&.login).gsub('{identifier}', project&.identifier) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +31,9 @@ class MessageTemplate::ProjectLeft < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, project) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Project"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{repository}', project&.name) | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::ProjectMemberJoined < MessageTemplate | |||
| # MessageTemplate::ProjectMemberJoined.get_message_content(User.where(login: 'yystopf')) | |||
| def self.get_message_content(receivers, user, project) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["ManageProject::Member"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname1}', user&.real_name).gsub('{nickname2}', project&.owner&.real_name).gsub('{repository}', project&.name) | |||
| url = notification_url.gsub('{owner}', project&.owner&.login).gsub('{identifier}', project&.identifier) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::ProjectMemberJoined < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, user, project) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["ManageProject::Member"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{nickname1}', user&.real_name) | |||
| title.gsub!('{nickname2}', project&.owner&.real_name) | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::ProjectMemberLeft < MessageTemplate | |||
| # MessageTemplate::ProjectMemberLeft.get_message_content(User.where(login: 'yystopf'), User.last, Project.last) | |||
| def self.get_message_content(receivers, user, project) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["ManageProject::Member"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname1}', user&.real_name).gsub('{nickname2}', project&.owner&.real_name).gsub('{repository}', project&.name) | |||
| url = notification_url.gsub('{owner}', project&.owner&.login).gsub('{identifier}', project&.identifier) | |||
| return receivers_string(receivers), content, url | |||
| @@ -26,6 +32,9 @@ class MessageTemplate::ProjectMemberLeft < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, user, project) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["ManageProject::Member"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{nickname1}', user&.real_name) | |||
| title.gsub!('{nickname2}', project&.owner&.real_name) | |||
| @@ -17,9 +17,15 @@ class MessageTemplate::ProjectPullRequest < MessageTemplate | |||
| # MessageTemplate::ProjectPullRequest.get_message_content(User.where(login: 'yystopf'), User.where(login: 'testforge2'), User.last, PullRequest.last) | |||
| def self.get_message_content(managers, followers, operator, pull_request) | |||
| managers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| managers = managers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["ManageProject::PullRequest"] | |||
| end | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| receivers = managers + followers | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname1}', operator&.real_name).gsub('{nickname2}', owner&.real_name).gsub('{repository}', project&.name).gsub('{title}', pull_request&.title) | |||
| url = notification_url.gsub('{owner}', owner&.login).gsub('{identifier}', project&.identifier).gsub('{id}', pull_request&.id.to_s) | |||
| @@ -30,6 +36,9 @@ class MessageTemplate::ProjectPullRequest < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, is_manager, operator, pull_request) | |||
| if receiver.user_template_message_setting.present? && is_manager | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["ManageProject::PullRequest"] | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| @@ -17,7 +17,13 @@ class MessageTemplate::ProjectRole < MessageTemplate | |||
| # MessageTemplate::ProjectRole.get_message_content(User.where(login: 'yystopf'), Project.last, '管理员') | |||
| def self.get_message_content(receivers, project, role) | |||
| content = sys_notice.gsub('{repository}', project&.name).gsub('{role}', role) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::Permission"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| content = sys_notice.gsub('{nickname}', project&.owner&.real_name).gsub('{repository}', project&.name).gsub('{role}', role) | |||
| url = notification_url.gsub('{owner}', project&.owner&.login).gsub('{identifier}', project&.identifier) | |||
| return receivers_string(receivers), content, url | |||
| rescue => e | |||
| @@ -25,14 +31,19 @@ class MessageTemplate::ProjectRole < MessageTemplate | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receivers, project, role) | |||
| def self.get_email_message_content(receiver, project, role) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::Permission"] | |||
| end | |||
| title = email_title | |||
| title.gsub!('{repository}', project&.name) | |||
| title.gsub!('{role}', role) | |||
| title.gsub!('{nickname}', project&.owner&.real_name) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{login}', project&.owner&.login) | |||
| content.gsub!('{nickname}', project&.owner&.real_name) | |||
| content.gsub!('{identifier}', project&.identifier) | |||
| content.gsub!('{repository}', project&.name) | |||
| content.gsub!('{role}', role) | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::ProjectSettingChanged < MessageTemplate | |||
| # MessageTemplate::ProjectSettingChanged.get_message_content(User.where(login: 'yystopf'), User.last, Project.last, {description: '测试修改项目简介', category: '大数据', language: 'Ruby', permission: '公有', navbar: '易修, 合并请求'}) | |||
| def self.get_message_content(receivers, operator, project, change_params) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["ManageProject::SettingChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| return '', '', '' if change_params.blank? | |||
| owner = project&.owner | |||
| content = sys_notice.gsub('{nickname1}', operator&.real_name).gsub('{nickname2}', owner&.real_name).gsub('{repository}', project&.name) | |||
| @@ -34,6 +40,18 @@ class MessageTemplate::ProjectSettingChanged < MessageTemplate | |||
| else | |||
| content.gsub!(/({ifname})(.*)({endname})/, '') | |||
| end | |||
| # 项目标识更改 | |||
| if change_params[:identifier].present? | |||
| if change_count > 1 | |||
| content.sub!('{ifidentifier}', '<br/>') | |||
| else | |||
| content.sub!('{ifidentifier}', '') | |||
| end | |||
| content.sub!('{endidentifier}', '') | |||
| content.gsub!('{identifier}', change_params[:identifier][1]) | |||
| else | |||
| content.gsub!(/({ifidentifier})(.*)({endidentifier})/, '') | |||
| end | |||
| # 项目简介更改 | |||
| if change_params[:description].present? | |||
| if change_params[:description][1].blank? | |||
| @@ -141,6 +159,9 @@ class MessageTemplate::ProjectSettingChanged < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, operator, project, change_params) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["ManageProject::SettingChanged"] | |||
| end | |||
| return '', '', '' if change_params.blank? | |||
| owner = project&.owner | |||
| title = email_title | |||
| @@ -169,6 +190,18 @@ class MessageTemplate::ProjectSettingChanged < MessageTemplate | |||
| else | |||
| content.gsub!(/({ifname})(.*)({endname})/, '') | |||
| end | |||
| # 项目标识更改 | |||
| if change_params[:identifier].present? | |||
| if change_count > 1 | |||
| content.sub!('{ifidentifier}', '<br/>') | |||
| else | |||
| content.sub!('{ifidentifier}', '') | |||
| end | |||
| content.sub!('{endidentifier}', '') | |||
| content.gsub!('{identifier}', change_params[:identifier][1]) | |||
| else | |||
| content.gsub!(/({ifidentifier})(.*)({endidentifier})/, '') | |||
| end | |||
| # 项目简介更改 | |||
| if change_params[:description].present? | |||
| if change_params[:description][1].blank? | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::PullRequestAssigned < MessageTemplate | |||
| # MessageTemplate::PullRequestAssigned.get_message_content(User.where(login: 'yystopf'), User.last, PullRequest.last) | |||
| def self.get_message_content(receivers, operator, pull_request) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["Normal::PullRequestAssigned"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| content = sys_notice.gsub('{nickname1}', operator&.real_name).gsub('{nickname2}', owner&.real_name).gsub('{repository}', project&.name).gsub('{title}', pull_request&.title) | |||
| @@ -28,6 +34,9 @@ class MessageTemplate::PullRequestAssigned < MessageTemplate | |||
| end | |||
| def self.get_email_message_content(receiver, operator, pull_request) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["Normal::PullRequestAssigned"] | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::PullRequestChanged < MessageTemplate | |||
| # MessageTemplate::PullRequestChanged.get_message_content(User.where(login: 'yystopf'), User.last, PullRequest.last, {assigned_to_id: [nil, 203], priority_id: [2, 4], fixed_version_id: [nil, 5], issue_tags_value: ["", "7"]}) | |||
| def self.get_message_content(receivers, operator, pull_request, change_params) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| return '', '', '' if change_params.blank? | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| @@ -92,4 +98,95 @@ class MessageTemplate::PullRequestChanged < MessageTemplate | |||
| Rails.logger.info("MessageTemplate::PullRequestChanged.get_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receiver, operator, pull_request, change_params) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| title.gsub!('{title}', pull_request&.title) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{nickname1}', operator&.real_name) | |||
| content.gsub!('{login1}', operator&.login) | |||
| content.gsub!('{nickname2}', owner&.real_name) | |||
| content.gsub!('{login2}', owner&.login) | |||
| content.gsub!('{identifier}', project&.identifier) | |||
| content.gsub!('{repository}', project&.name) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{title}', pull_request&.title) | |||
| content.gsub!('{id}', pull_request&.id.to_s) | |||
| change_count = change_params.keys.size | |||
| # 合并请求审查成员修改 | |||
| if change_params[:assigned_to_id].present? | |||
| assigner1 = User.find_by_id(change_params[:assigned_to_id][0]) | |||
| assigner2 = User.find_by_id(change_params[:assigned_to_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifassigner}', '<br/>') | |||
| else | |||
| content.sub!('{ifassigner}', '') | |||
| end | |||
| content.sub!('{endassigner}', '') | |||
| content.gsub!('{assigner1}', assigner1.present? ? assigner1&.real_name : '未指派成员') | |||
| content.gsub!('{assigner2}', assigner2.present? ? assigner2&.real_name : '未指派成员') | |||
| else | |||
| content.gsub!(/({ifassigner})(.*)({endassigner})/, '') | |||
| end | |||
| # 合并请求里程碑修改 | |||
| if change_params[:fixed_version_id].present? | |||
| fix_version1 = Version.find_by_id(change_params[:fixed_version_id][0]) | |||
| fix_version2 = Version.find_by_id(change_params[:fixed_version_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifmilestone}', '<br/>') | |||
| else | |||
| content.sub!('{ifmilestone}', '') | |||
| end | |||
| content.sub!('{endmilestone}', '') | |||
| content.gsub!('{milestone1}', fix_version1.present? ? fix_version1&.name : '未选择里程碑') | |||
| content.gsub!('{milestone2}', fix_version2.present? ? fix_version2&.name : '未选择里程碑') | |||
| else | |||
| content.gsub!(/({ifmilestone})(.*)({endmilestone})/, '') | |||
| end | |||
| # 合并请求标记修改 | |||
| if change_params[:issue_tags_value].present? | |||
| issue_tags1 = IssueTag.where(id: change_params[:issue_tags_value][0]).distinct | |||
| issue_tags2 = IssueTag.where(id: change_params[:issue_tags_value][1]).distinct | |||
| tag1 = issue_tags1.pluck(:name).join(",").blank? ? '未选择标记' : issue_tags1.pluck(:name).join(",") | |||
| tag2 = issue_tags2.pluck(:name).join(",").blank? ? '未选择标记' : issue_tags2.pluck(:name).join(",") | |||
| if change_count > 1 | |||
| content.sub!('{iftag}', '<br/>') | |||
| else | |||
| content.sub!('{iftag}', '') | |||
| end | |||
| content.sub!('{endtag}', '') | |||
| content.gsub!('{tag1}', tag1) | |||
| content.gsub!('{tag2}', tag2) | |||
| else | |||
| content.gsub!(/({iftag})(.*)({endtag})()/, '') | |||
| end | |||
| # 合并请求优先级修改 | |||
| if change_params[:priority_id].present? | |||
| priority1 = IssuePriority.find_by_id(change_params[:priority_id][0]) | |||
| priority2 = IssuePriority.find_by_id(change_params[:priority_id][1]) | |||
| if change_count > 1 | |||
| content.sub!('{ifpriority}', '<br/>') | |||
| else | |||
| content.sub!('{ifpriority}', '') | |||
| end | |||
| content.sub!('{ifpriority}', '') | |||
| content.sub!('{endpriority}', '') | |||
| content.gsub!('{priority1}', priority1&.name) | |||
| content.gsub!('{priority2}', priority2&.name) | |||
| else | |||
| content.gsub!(/({ifpriority})(.*)({endpriority})/, '') | |||
| end | |||
| return receiver&.mail, title, content | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::PullRequestChanged.get_email_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| end | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::PullRequestClosed < MessageTemplate | |||
| # MessageTemplate::PullRequestClosed.get_message_content(User.where(login: 'yystopf'), User.last, PullRequest.last) | |||
| def self.get_message_content(receivers, operator, pull_request) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| content = sys_notice.gsub('{title}', pull_request&.title) | |||
| @@ -26,4 +32,30 @@ class MessageTemplate::PullRequestClosed < MessageTemplate | |||
| Rails.logger.info("MessageTemplate::PullRequestClosed.get_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receiver, operator, pull_request) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| title.gsub!('{title}', pull_request&.title) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{nickname1}', operator&.real_name) | |||
| content.gsub!('{login1}', operator&.login) | |||
| content.gsub!('{nickname2}', owner&.real_name) | |||
| content.gsub!('{login2}', owner&.login) | |||
| content.gsub!('{identifier}', project&.identifier) | |||
| content.gsub!('{repository}', project&.name) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{title}', pull_request&.title) | |||
| content.gsub!('{id}', pull_request&.id.to_s) | |||
| return receiver&.mail, title, content | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::PullRequestClosed.get_email_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| end | |||
| @@ -17,6 +17,12 @@ class MessageTemplate::PullRequestMerged < MessageTemplate | |||
| # MessageTemplate::PullRequestMerged.get_message_content(User.where(login: 'yystopf'), User.last, PullRequest.last) | |||
| def self.get_message_content(receivers, operator, pull_request) | |||
| receivers.each do |receiver| | |||
| if receiver.user_template_message_setting.present? | |||
| receivers = receivers.where.not(id: receiver.id) unless receiver.user_template_message_setting.notification_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| end | |||
| return '', '', '' if receivers.blank? | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| content = sys_notice.gsub('{title}', pull_request&.title) | |||
| @@ -26,4 +32,30 @@ class MessageTemplate::PullRequestMerged < MessageTemplate | |||
| Rails.logger.info("MessageTemplate::PullRequestMerged.get_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| def self.get_email_message_content(receiver, operator, pull_request) | |||
| if receiver.user_template_message_setting.present? | |||
| return '', '', '' unless receiver.user_template_message_setting.email_body["CreateOrAssign::PullRequestChanged"] | |||
| end | |||
| project = pull_request&.project | |||
| owner = project&.owner | |||
| title = email_title | |||
| title.gsub!('{title}', pull_request&.title) | |||
| content = email | |||
| content.gsub!('{receiver}', receiver&.real_name) | |||
| content.gsub!('{nickname1}', operator&.real_name) | |||
| content.gsub!('{login1}', operator&.login) | |||
| content.gsub!('{nickname2}', owner&.real_name) | |||
| content.gsub!('{login2}', owner&.login) | |||
| content.gsub!('{identifier}', project&.identifier) | |||
| content.gsub!('{repository}', project&.name) | |||
| content.gsub!('{baseurl}', base_url) | |||
| content.gsub!('{title}', pull_request&.title) | |||
| content.gsub!('{id}', pull_request&.id.to_s) | |||
| return receiver&.mail, title, content | |||
| rescue => e | |||
| Rails.logger.info("MessageTemplate::PullRequestMerged.get_email_message_content [ERROR] #{e}") | |||
| return '', '', '' | |||
| end | |||
| end | |||
| @@ -0,0 +1,30 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # type :string(255) | |||
| # name :string(255) | |||
| # key :string(255) | |||
| # openning :boolean | |||
| # notification_disabled :boolean | |||
| # email_disabled :boolean | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| class TemplateMessageSetting < ApplicationRecord | |||
| scope :openning, ->() {where(openning: true)} | |||
| def self.type_name | |||
| "" | |||
| end | |||
| def self.build_init_data | |||
| TemplateMessageSetting::CreateOrAssign.build_init_data | |||
| TemplateMessageSetting::ManageProject.build_init_data | |||
| TemplateMessageSetting::Normal.build_init_data | |||
| TemplateMessageSetting::WatchProject.build_init_data | |||
| end | |||
| end | |||
| @@ -0,0 +1,31 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # type :string(255) | |||
| # name :string(255) | |||
| # key :string(255) | |||
| # openning :boolean | |||
| # notification_disabled :boolean | |||
| # email_disabled :boolean | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| #我创建的或负责的 | |||
| class TemplateMessageSetting::CreateOrAssign < TemplateMessageSetting | |||
| def self.type_name | |||
| "我创建的或负责的" | |||
| end | |||
| def self.order_index | |||
| 20 | |||
| end | |||
| def self.build_init_data | |||
| self.find_or_create_by(name: "易修状态变更", key: "IssueChanged") | |||
| self.find_or_create_by(name: "合并请求状态变更", key: "PullRequestChanged") | |||
| end | |||
| end | |||
| @@ -0,0 +1,33 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # type :string(255) | |||
| # name :string(255) | |||
| # key :string(255) | |||
| # openning :boolean | |||
| # notification_disabled :boolean | |||
| # email_disabled :boolean | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| #我管理的 | |||
| class TemplateMessageSetting::ManageProject < TemplateMessageSetting | |||
| def self.type_name | |||
| "我管理的仓库" | |||
| end | |||
| def self.order_index | |||
| 30 | |||
| end | |||
| def self.build_init_data | |||
| self.find_or_create_by(name: "有新的易修", key: "Issue") | |||
| self.find_or_create_by(name: "有新的合并请求", key: "PullRequest") | |||
| self.find_or_create_by(name: "有成员变动", key: "Member") | |||
| self.find_or_create_by(name: "仓库设置被更改", key: "SettingChanged") | |||
| end | |||
| end | |||
| @@ -0,0 +1,33 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # type :string(255) | |||
| # name :string(255) | |||
| # key :string(255) | |||
| # openning :boolean | |||
| # notification_disabled :boolean | |||
| # email_disabled :boolean | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| class TemplateMessageSetting::Normal < TemplateMessageSetting | |||
| def self.type_name | |||
| "我的状态" | |||
| end | |||
| def self.order_index | |||
| 10 | |||
| end | |||
| def self.build_init_data | |||
| self.find_or_create_by(name: "账号有权限变更", key: "Permission") | |||
| self.find_or_create_by(name: "被拉入或移出组织", key: "Organization") | |||
| self.find_or_create_by(name: "被拉入或移出项目", key: "Project") | |||
| self.find_or_create_by(name: "有新的易修指派给我", key: "IssueAssigned") | |||
| self.find_or_create_by(name: "有新的合并请求指派给我", key: "PullRequestAssigned") | |||
| end | |||
| end | |||
| @@ -0,0 +1,29 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # type :string(255) | |||
| # name :string(255) | |||
| # key :string(255) | |||
| # openning :boolean | |||
| # notification_disabled :boolean | |||
| # email_disabled :boolean | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| #我关注的 | |||
| class TemplateMessageSetting::WatchProject < TemplateMessageSetting | |||
| def self.type_name | |||
| "我关注的仓库" | |||
| end | |||
| def self.order_index | |||
| 40 | |||
| end | |||
| def self.build_init_data | |||
| end | |||
| end | |||
| @@ -171,7 +171,9 @@ class User < Owner | |||
| has_many :issues, dependent: :destroy, foreign_key: :author_id | |||
| has_many :pull_requests, dependent: :destroy | |||
| has_many :public_keys, class_name: "Gitea::PublicKey",primary_key: :gitea_uid, foreign_key: :owner_id, dependent: :destroy | |||
| has_one :user_template_message_setting, dependent: :destroy | |||
| # Groups and active users | |||
| scope :active, lambda { where(status: [STATUS_ACTIVE, STATUS_EDIT_INFO]) } | |||
| scope :like, lambda { |keywords| | |||
| @@ -0,0 +1,72 @@ | |||
| # == Schema Information | |||
| # | |||
| # Table name: user_template_message_settings | |||
| # | |||
| # id :integer not null, primary key | |||
| # user_id :integer | |||
| # notification_body :text(65535) | |||
| # email_body :text(65535) | |||
| # created_at :datetime not null | |||
| # updated_at :datetime not null | |||
| # | |||
| # Indexes | |||
| # | |||
| # index_user_template_message_settings_on_user_id (user_id) | |||
| # | |||
| class UserTemplateMessageSetting < ApplicationRecord | |||
| serialize :notification_body, Hash | |||
| serialize :email_body, Hash | |||
| belongs_to :user | |||
| before_update :set_body_value | |||
| def self.build(user_id) | |||
| self.create!(user_id: user_id, notification_body: init_notification_body, email_body: init_email_body) | |||
| end | |||
| def self.init_notification_body | |||
| { | |||
| "Normal::Permission": true, | |||
| "Normal::Project": true, | |||
| "Normal::Organization": true, | |||
| "Normal::IssueAssigned": true, | |||
| "Normal::PullRequestAssigned": true, | |||
| "CreateOrAssign::IssueChanged": true, | |||
| "CreateOrAssign::PullRequestChanged": true, | |||
| "ManageProject::Issue": true, | |||
| "ManageProject::PullRequest": true, | |||
| "ManageProject::Member": true, | |||
| "ManageProject::SettingChanged": true, | |||
| }.stringify_keys! | |||
| end | |||
| def self.init_email_body | |||
| { | |||
| "Normal::Permission": true, | |||
| "Normal::Project": true, | |||
| "Normal::Organization": true, | |||
| "Normal::IssueAssigned": true, | |||
| "Normal::PullRequestAssigned": true, | |||
| "CreateOrAssign::IssueChanged": true, | |||
| "CreateOrAssign::PullRequestChanged": true, | |||
| "ManageProject::Issue": true, | |||
| "ManageProject::PullRequest": true, | |||
| "ManageProject::Member": true, | |||
| "ManageProject::SettingChanged": true, | |||
| }.stringify_keys! | |||
| end | |||
| private | |||
| def set_body_value | |||
| self.notification_body.each do |k, v| | |||
| self.notification_body[k] = ActiveModel::Type::Boolean.new.cast(v).nil? ? false : ActiveModel::Type::Boolean.new.cast(v) | |||
| end | |||
| self.email_body.each do |k, v| | |||
| self.email_body[k] = ActiveModel::Type::Boolean.new.cast(v).nil? ? false : ActiveModel::Type::Boolean.new.cast(v) | |||
| end | |||
| end | |||
| end | |||
| @@ -0,0 +1,37 @@ | |||
| module Gitea | |||
| module Repository | |||
| class GetBranchAndTagTotalNumService < Gitea::ClientService | |||
| attr_reader :owner, :repo, :token | |||
| def initialize(owner, repo, token=nil) | |||
| @owner = owner | |||
| @repo = repo | |||
| @token = token | |||
| end | |||
| def call | |||
| response = get(url, params) | |||
| render_result(response) | |||
| end | |||
| private | |||
| def params | |||
| Hash.new.merge(token: token) | |||
| end | |||
| def url | |||
| "/repos/#{owner}/#{repo}/branch_tag_count".freeze | |||
| end | |||
| def render_result(response) | |||
| case response.status | |||
| when 200 | |||
| JSON.parse(response.body) | |||
| else | |||
| {} | |||
| end | |||
| end | |||
| end | |||
| end | |||
| end | |||
| @@ -10,11 +10,9 @@ class Repositories::DetailService < ApplicationService | |||
| def call | |||
| return { | |||
| repo: repo_suitable, | |||
| release: release_suitable, | |||
| branch: branch_suitable, | |||
| tag: tag_suitable, | |||
| contributor: contributor_suitable, | |||
| language: language_suitable | |||
| language: language_suitable, | |||
| branch_tag_total_count: branch_tag_total_count | |||
| } | |||
| rescue | |||
| return { | |||
| @@ -30,25 +28,14 @@ class Repositories::DetailService < ApplicationService | |||
| end | |||
| private | |||
| def branch_tag_total_count | |||
| Gitea::Repository::GetBranchAndTagTotalNumService.call(@owner.login, @repo.identifier, @owner.gitea_token) | |||
| end | |||
| def repo_suitable | |||
| Gitea::Repository::GetService.call(@owner, @repo.identifier) | |||
| end | |||
| def release_suitable | |||
| releases = Gitea::Versions::ListService.call(@owner.gitea_token, @owner.try(:login), @repo.try(:identifier), {page: 1, limit: 1}) | |||
| releases.is_a?(Hash) && releases[:status] == -1 ? [] : releases | |||
| end | |||
| def branch_suitable | |||
| branches = Gitea::Repository::Branches::ListService.call(@owner, @repo.identifier) | |||
| branches.is_a?(Hash) && branches.key?(:status) ? [] : branches | |||
| end | |||
| def tag_suitable | |||
| tags = Gitea::Repository::Tags::ListService.call(@owner&.gitea_token, @owner.login, @repo.identifier) | |||
| tags.is_a?(Hash) && tags[:status] == -1 ? [] : tags | |||
| end | |||
| def contributor_suitable | |||
| contributors = Gitea::Repository::Contributors::GetService.call(@owner, @repo.identifier) | |||
| contributors.is_a?(Hash) && contributors.key?(:status) ? [] : contributors | |||
| @@ -51,28 +51,8 @@ if @result[:repo] | |||
| json.private @result[:repo]['private'] | |||
| end | |||
| json.license_name @project.license_name | |||
| json.release_versions do | |||
| json.list @result[:release].each do |release| | |||
| forge_version = VersionRelease.find_by(version_gid: release["id"]) | |||
| json.id forge_version&.id | |||
| json.name release["name"] | |||
| json.tag_name release["tag_name"] | |||
| json.created_at format_time(release["created_at"].to_time) | |||
| end | |||
| json.total_count @repository&.version_releases.size | |||
| end | |||
| json.branches do | |||
| json.list @result[:branch].each do |branch| | |||
| json.name branch["name"] | |||
| end | |||
| json.total_count @result[:branch].size | |||
| end | |||
| json.tags do | |||
| json.list @result[:tag].each do |tag| | |||
| json.name tag["name"] | |||
| end | |||
| json.total_count @result[:tag].size | |||
| end | |||
| json.branches_count @result[:branch_tag_total_count]['branch_count'] || 0 | |||
| json.tags_count @result[:branch_tag_total_count]['tag_count'] || 0 | |||
| json.contributors do | |||
| total_count = @result[:contributor].size | |||
| json.list @result[:contributor].each do |contributor| | |||
| @@ -0,0 +1,8 @@ | |||
| json.type type | |||
| json.type_name type.constantize.type_name | |||
| json.total_settings_count count | |||
| json.settings do | |||
| json.array! type.constantize.openning.limit(100).each do |setting| | |||
| json.(setting, :name, :key, :notification_disabled, :email_disabled) | |||
| end | |||
| end | |||
| @@ -0,0 +1,11 @@ | |||
| json.partial! "commons/success" | |||
| json.setting_types do | |||
| json.array! @group_settings.keys.sort_by{|i| i.constantize.order_index}.each do |k| | |||
| json.partial! "detail", type: k, count: @group_settings[k] | |||
| end | |||
| # json.array! @group_settings, partial: 'detail', as: :type | |||
| end | |||
| @@ -0,0 +1,5 @@ | |||
| json.user do | |||
| json.partial! 'users/user_simple', locals: { user: setting.user } | |||
| end | |||
| json.notification_body setting.notification_body | |||
| json.email_body setting.email_body | |||
| @@ -0,0 +1,2 @@ | |||
| json.partial! "commons/success" | |||
| json.partial! "detail", locals: {setting: @current_setting} | |||
| @@ -0,0 +1,2 @@ | |||
| json.partial! "commons/success" | |||
| json.partial! "detail", locals: {setting: @current_setting} | |||
| @@ -150,6 +150,8 @@ Rails.application.routes.draw do | |||
| resources :issue_depends, only: [:create, :destroy] | |||
| end | |||
| resources :template_message_settings, only: [:index] | |||
| resources :applied_projects, only: [:create] | |||
| resources :project_categories, only: [:index, :show] do | |||
| @@ -263,6 +265,8 @@ Rails.application.routes.draw do | |||
| end | |||
| scope module: :users do | |||
| get 'template_message_settings', to: 'template_message_settings#current_setting' | |||
| post 'template_message_settings/update_setting', to: 'template_message_settings#update_setting' | |||
| resources :applied_messages, only: [:index] | |||
| resources :applied_transfer_projects, only: [:index] do | |||
| member do | |||
| @@ -0,0 +1,17 @@ | |||
| class CreateTemplateMessageSettings < ActiveRecord::Migration[5.2] | |||
| def change | |||
| # 平台的通知设置 | |||
| create_table :template_message_settings do |t| | |||
| t.string :type | |||
| t.string :name | |||
| t.string :key | |||
| t.boolean :openning, default: true | |||
| t.boolean :notification_disabled, default: true | |||
| t.boolean :email_disabled, default: false | |||
| t.timestamps | |||
| end | |||
| TemplateMessageSetting.build_init_data | |||
| end | |||
| end | |||
| @@ -0,0 +1,12 @@ | |||
| class CreateUserTemplateMessageSettings < ActiveRecord::Migration[5.2] | |||
| def change | |||
| # 用户对系统通知的设置 | |||
| create_table :user_template_message_settings do |t| | |||
| t.references :user | |||
| t.text :notification_body | |||
| t.text :email_body | |||
| t.timestamps | |||
| end | |||
| end | |||
| end | |||
| @@ -360,6 +360,15 @@ | |||
| <li> | |||
| <a href="#c6da6881ac" class="toc-h2 toc-link" data-title="更改用户信息">更改用户信息</a> | |||
| </li> | |||
| <li> | |||
| <a href="#8469c9a565" class="toc-h2 toc-link" data-title="获取平台消息设置配置信息">获取平台消息设置配置信息</a> | |||
| </li> | |||
| <li> | |||
| <a href="#e731847818" class="toc-h2 toc-link" data-title="获取用户消息设置配置信息">获取用户消息设置配置信息</a> | |||
| </li> | |||
| <li> | |||
| <a href="#47e7414364" class="toc-h2 toc-link" data-title="重新设置用户消息设置配置信息">重新设置用户消息设置配置信息</a> | |||
| </li> | |||
| <li> | |||
| <a href="#16a4666845" class="toc-h2 toc-link" data-title="获取用户星标项目">获取用户星标项目</a> | |||
| </li> | |||
| @@ -1569,7 +1578,339 @@ Success — a happy kitten is an authenticated kitten! | |||
| </span><span class="nl">"status"</span><span class="p">:</span><span class="w"> </span><span class="mi">0</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"message"</span><span class="p">:</span><span class="w"> </span><span class="s2">"success"</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span></code></pre></div><h2 id='16a4666845'>获取用户星标项目</h2> | |||
| </span></code></pre></div><h2 id='8469c9a565'>获取平台消息设置配置信息</h2> | |||
| <p>获取平台消息设置配置信息</p> | |||
| <blockquote> | |||
| <p>示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/template_message_settings.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/template_message_settings.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-7'>HTTP 请求</h3> | |||
| <p><code>GET /api/template_message_settings.json</code></p> | |||
| <h3 id='7447e4874e-3'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| <th>类型</th> | |||
| <th>字段说明</th> | |||
| </tr> | |||
| </thead><tbody> | |||
| <tr> | |||
| <td>type</td> | |||
| <td>string</td> | |||
| <td>消息配置类型</td> | |||
| </tr> | |||
| <tr> | |||
| <td>type_name</td> | |||
| <td>string</td> | |||
| <td>消息配置类型含义</td> | |||
| </tr> | |||
| <tr> | |||
| <td>total_settings_count</td> | |||
| <td>int</td> | |||
| <td>配置条数</td> | |||
| </tr> | |||
| <tr> | |||
| <td>settings.name</td> | |||
| <td>string</td> | |||
| <td>配置名称</td> | |||
| </tr> | |||
| <tr> | |||
| <td>settings.key</td> | |||
| <td>string</td> | |||
| <td>配置标识</td> | |||
| </tr> | |||
| <tr> | |||
| <td>settings.notification_disabled</td> | |||
| <td>boolean</td> | |||
| <td>站内信设置是否禁用</td> | |||
| </tr> | |||
| <tr> | |||
| <td>settings.email_disabled</td> | |||
| <td>boolean</td> | |||
| <td>邮件设置是否禁用</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <blockquote> | |||
| <p>返回的JSON示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight json tab-json"><code><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"status"</span><span class="p">:</span><span class="w"> </span><span class="mi">0</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"message"</span><span class="p">:</span><span class="w"> </span><span class="s2">"响应成功"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"setting_types"</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"type"</span><span class="p">:</span><span class="w"> </span><span class="s2">"TemplateMessageSetting::Normal"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"type_name"</span><span class="p">:</span><span class="w"> </span><span class="s2">""</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"total_settings_count"</span><span class="p">:</span><span class="w"> </span><span class="mi">3</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"settings"</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"被拉入或移出组织"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"Organization"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"被拉入或移出项目"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"Project"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"有权限变更"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"Permission"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">]</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"type"</span><span class="p">:</span><span class="w"> </span><span class="s2">"TemplateMessageSetting::CreateOrAssign"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"type_name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"我创建的或负责的"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"total_settings_count"</span><span class="p">:</span><span class="w"> </span><span class="mi">4</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"settings"</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"易修被指派"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"IssueAssigned"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"合并请求被指派"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"PullRequestAssigned"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">]</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"type"</span><span class="p">:</span><span class="w"> </span><span class="s2">"TemplateMessageSetting::ManageProject"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"type_name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"我管理的仓库"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"total_settings_count"</span><span class="p">:</span><span class="w"> </span><span class="mi">4</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"settings"</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"有新的易修"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"Issue"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"有新的合并请求"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"PullRequest"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"有成员变动"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"Member"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"设置更改"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"key"</span><span class="p">:</span><span class="w"> </span><span class="s2">"SettingChanged"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"notification_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"email_disabled"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">]</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">]</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span></code></pre></div> | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| <h2 id='e731847818'>获取用户消息设置配置信息</h2> | |||
| <p>获取用户消息设置配置信息</p> | |||
| <blockquote> | |||
| <p>示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/template_message_settings.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/uses/yystopf/template_message_settings.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-8'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:user_id/template_message_settings.json</code></p> | |||
| <h3 id='7447e4874e-4'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| <th>类型</th> | |||
| <th>字段说明</th> | |||
| </tr> | |||
| </thead><tbody> | |||
| <tr> | |||
| <td>notification_body</td> | |||
| <td>string</td> | |||
| <td>站内信配置</td> | |||
| </tr> | |||
| <tr> | |||
| <td>email_body</td> | |||
| <td>string</td> | |||
| <td>邮件配置</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <blockquote> | |||
| <p>返回的JSON示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight json tab-json"><code><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"status"</span><span class="p">:</span><span class="w"> </span><span class="mi">0</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"message"</span><span class="p">:</span><span class="w"> </span><span class="s2">"响应成功"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"user"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"id"</span><span class="p">:</span><span class="w"> </span><span class="mi">2</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"type"</span><span class="p">:</span><span class="w"> </span><span class="s2">"User"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"heh"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"login"</span><span class="p">:</span><span class="w"> </span><span class="s2">"yystopf"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"image_url"</span><span class="p">:</span><span class="w"> </span><span class="s2">"system/lets/letter_avatars/2/H/188_239_142/120.png"</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="nl">"notification_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="nl">"email_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span></code></pre></div> | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| <h2 id='47e7414364'>重新设置用户消息设置配置信息</h2> | |||
| <p>重新设置用户消息设置配置信息</p> | |||
| <blockquote> | |||
| <p>示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/template_message_settings/update_setting.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">POST /api/uses/yystopf/template_message_settings/update_setting.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-9'>HTTP 请求</h3> | |||
| <p><code>POST /api/users/:user_id/template_message_settings/update_setting.json</code></p> | |||
| <h3 id='aa883f5d52-6'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| <th>类型</th> | |||
| <th>字段说明</th> | |||
| </tr> | |||
| </thead><tbody> | |||
| <tr> | |||
| <td>notification_body</td> | |||
| <td>string</td> | |||
| <td>站内信配置</td> | |||
| </tr> | |||
| <tr> | |||
| <td>email_body</td> | |||
| <td>string</td> | |||
| <td>邮件配置</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <blockquote> | |||
| <p>请求的JSON示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight json tab-json"><code><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"setting"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"notification_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="nl">"email_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="s2">"t"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span></code></pre></div><h3 id='7447e4874e-5'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| <th>类型</th> | |||
| <th>字段说明</th> | |||
| </tr> | |||
| </thead><tbody> | |||
| <tr> | |||
| <td>notification_body</td> | |||
| <td>string</td> | |||
| <td>站内信配置</td> | |||
| </tr> | |||
| <tr> | |||
| <td>email_body</td> | |||
| <td>string</td> | |||
| <td>邮件配置</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <blockquote> | |||
| <p>返回的JSON示例:</p> | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight json tab-json"><code><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"status"</span><span class="p">:</span><span class="w"> </span><span class="mi">0</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"message"</span><span class="p">:</span><span class="w"> </span><span class="s2">"响应成功"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"user"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"id"</span><span class="p">:</span><span class="w"> </span><span class="mi">2</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"type"</span><span class="p">:</span><span class="w"> </span><span class="s2">"User"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"name"</span><span class="p">:</span><span class="w"> </span><span class="s2">"heh"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"login"</span><span class="p">:</span><span class="w"> </span><span class="s2">"yystopf"</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"image_url"</span><span class="p">:</span><span class="w"> </span><span class="s2">"system/lets/letter_avatars/2/H/188_239_142/120.png"</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="nl">"notification_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="w"> | |||
| </span><span class="p">},</span><span class="w"> | |||
| </span><span class="nl">"email_body"</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::IssueAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"CreateOrAssign::PullRequestAssigned"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Issue"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::PullRequest"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::Member"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"ManageProject::SettingChanged"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Organization"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Project"</span><span class="p">:</span><span class="w"> </span><span class="kc">true</span><span class="p">,</span><span class="w"> | |||
| </span><span class="nl">"Normal::Permission"</span><span class="p">:</span><span class="w"> </span><span class="kc">false</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span><span class="p">}</span><span class="w"> | |||
| </span></code></pre></div> | |||
| <aside class="success"> | |||
| Success Data. | |||
| </aside> | |||
| <h2 id='16a4666845'>获取用户星标项目</h2> | |||
| <p>获取用户星标项目</p> | |||
| <blockquote> | |||
| @@ -1577,9 +1918,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/is_pinned_projects.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/is_pinned_projects.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-7'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-10'>HTTP 请求</h3> | |||
| <p><code>GET api/users/:login/is_pinned_projects.json</code></p> | |||
| <h3 id='7447e4874e-3'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-6'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -1764,9 +2105,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/is_pinned_projects/pin.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/is_pinned_projects/pin.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-8'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-11'>HTTP 请求</h3> | |||
| <p><code>POST /api/users/:login/is_pinned_projects/pin.json</code></p> | |||
| <h3 id='aa883f5d52-6'>请求字段说明:</h3><h4 id='0ca7f0efb8'>同时设定多个星标项目</h4> | |||
| <h3 id='aa883f5d52-7'>请求字段说明:</h3><h4 id='0ca7f0efb8'>同时设定多个星标项目</h4> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -1810,9 +2151,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> PATCH http://localhost:3000/api/users/yystopf/is_pinned_projects/11.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">PATCH/PUT /api/users/:login/is_pinned_projects/:id.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-9'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-12'>HTTP 请求</h3> | |||
| <p><code>PATCH/PUT /api/users/:login/is_pinned_projects/:id.json</code></p> | |||
| <h3 id='aa883f5d52-7'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-8'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -1851,9 +2192,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/statistics/activity.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/statistics/activity.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-10'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-13'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/statistics/activity.json</code></p> | |||
| <h3 id='7447e4874e-4'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-7'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -1940,9 +2281,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/headmaps.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/headmaps.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-11'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-14'>HTTP 请求</h3> | |||
| <p><code>GET api/users/:login/headmaps.json</code></p> | |||
| <h3 id='aa883f5d52-8'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-9'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -1956,7 +2297,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>年份</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-5'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-8'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2085,9 +2426,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/project_trends.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/project_trends.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-12'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-15'>HTTP 请求</h3> | |||
| <p><code>GET api/users/:login/project_trends.json</code></p> | |||
| <h3 id='aa883f5d52-9'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-10'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2101,7 +2442,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>日期,格式: 2021-05-28</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-6'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-9'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2402,9 +2743,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/statistics/develop.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/statistics/develop.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-13'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-16'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/statistics/develop.json</code></p> | |||
| <h3 id='aa883f5d52-10'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-11'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2423,7 +2764,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>时间戳,结束时间,格式:1622131200</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-7'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-10'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2545,9 +2886,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/statistics/role.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/statistics/role.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-14'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-17'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/statistics/role.json</code></p> | |||
| <h3 id='aa883f5d52-11'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-12'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2566,7 +2907,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>时间戳,结束时间,格式:1622131200</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-8'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-11'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2627,9 +2968,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/statistics/major.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/statistics/major.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-15'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-18'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/statistics/major.json</code></p> | |||
| <h3 id='aa883f5d52-12'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-13'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2648,7 +2989,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>时间戳,结束时间,格式:1622131200</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-9'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-12'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2688,9 +3029,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/applied_messages.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_messages.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-16'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-19'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_messages.json</code></p> | |||
| <h3 id='aa883f5d52-13'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-14'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2704,7 +3045,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>用户标识</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-10'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-13'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2967,9 +3308,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/applied_transfer_projects.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_transfer_projects.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-17'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-20'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_transfer_projects.json</code></p> | |||
| <h3 id='aa883f5d52-14'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-15'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -2983,7 +3324,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>用户标识</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-11'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-14'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3159,9 +3500,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/applied_transfer_projects/2/accept.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_transfer_projects/:id/accept.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-18'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-21'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_transfer_projects/:id/accept.json</code></p> | |||
| <h3 id='aa883f5d52-15'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-16'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3180,7 +3521,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>迁移id</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-12'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-15'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3350,9 +3691,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/applied_transfer_projects/2/refuse.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_transfer_projects/:id/refuse.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-19'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-22'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_transfer_projects/:id/refuse.json</code></p> | |||
| <h3 id='aa883f5d52-16'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-17'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3371,7 +3712,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>迁移id</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-13'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-16'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3541,9 +3882,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> GET http://localhost:3000/api/users/yystopf/applied_projects.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_projects.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-20'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-23'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_projects.json</code></p> | |||
| <h3 id='aa883f5d52-17'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-18'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3557,7 +3898,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>用户标识</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-14'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-17'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3701,9 +4042,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/applied_projects/2/accept.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_projects/:id/accept.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-21'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-24'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_projects/:id/accept.json</code></p> | |||
| <h3 id='aa883f5d52-18'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-19'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3722,7 +4063,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>申请id</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-15'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-18'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3860,9 +4201,9 @@ Success — a happy kitten is an authenticated kitten! | |||
| </blockquote> | |||
| <div class="highlight"><pre class="highlight shell tab-shell"><code>curl <span class="nt">-X</span> POST http://localhost:3000/api/users/yystopf/applied_projects/2/refuse.json | |||
| </code></pre></div><div class="highlight"><pre class="highlight javascript tab-javascript"><code><span class="k">await</span> <span class="nx">octokit</span><span class="p">.</span><span class="nx">request</span><span class="p">(</span><span class="dl">'</span><span class="s1">GET /api/users/:login/applied_projects/:id/refuse.json</span><span class="dl">'</span><span class="p">)</span> | |||
| </code></pre></div><h3 id='http-22'>HTTP 请求</h3> | |||
| </code></pre></div><h3 id='http-25'>HTTP 请求</h3> | |||
| <p><code>GET /api/users/:login/applied_projects/:id/refuse.json</code></p> | |||
| <h3 id='aa883f5d52-19'>请求字段说明:</h3> | |||
| <h3 id='aa883f5d52-20'>请求字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -3881,7 +4222,7 @@ Success — a happy kitten is an authenticated kitten! | |||
| <td>申请id</td> | |||
| </tr> | |||
| </tbody></table> | |||
| <h3 id='7447e4874e-16'>返回字段说明:</h3> | |||
| <h3 id='7447e4874e-19'>返回字段说明:</h3> | |||
| <table><thead> | |||
| <tr> | |||
| <th>参数</th> | |||
| @@ -0,0 +1,62 @@ | |||
| <html> | |||
| <head> | |||
| <title>有新的易修指派给我</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 在项目 <a href="{baseurl}/{login2}/{identifier}" style="font-weight:bold;color:#3b94d6;">{nickname2}/{repository}</a> 的易修 <a href="{baseurl}/{login2}/{identifier}/issues/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a> 中: | |||
| {ifassigner}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将负责人从 {assigner1} 修改为 {assigner2}{endassigner} | |||
| {ifstatus}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将状态从 {status1} 修改为 {status2}{endstatus} | |||
| {iftracker}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将类型从 {tracker1} 修改为 {tracker2}{endtracker} | |||
| {ifpriority}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将优先级从 {priority1} 修改为 {priority2}{endpriority} | |||
| {ifmilestone}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将里程碑从 {milestone1} 修改为 {milestone2}{endmilestone} | |||
| {iftag}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将标记从 {tag1} 修改为 {tag2}{endtag} | |||
| {ifdoneratio}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将完成度从 {doneratio1} 修改为 {doneratio2}{enddoneratio} | |||
| {ifbranch}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将指定分支从 {branch1} 修改为 {branch2}{endbranch} | |||
| {ifstartdate}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将开始日期从 {startdate1} 修改为 {startdate2}{endstartdate} | |||
| {ifduedate}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将结束日期从 {duedate1} 修改为 {duedate2}{endduedate} | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -0,0 +1,52 @@ | |||
| <html> | |||
| <head> | |||
| <title>易修状态改变</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| <a href="{baseurl}/{login}" style="font-weight:bold;color:#3b94d6;">{nickname}</a>已将易修 {title} 删除 | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -0,0 +1,52 @@ | |||
| <html> | |||
| <head> | |||
| <title>组织权限被更改</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 组织 <a href="{baseurl}/{login}" style="font-weight:bold;color:#3b94d6;">{organization}</a> 已把你的角色修改为 {role} | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -31,7 +31,7 @@ | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| <a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>在 {nickname2}/{repository} 提交了一个合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}/Messagecount" style="font-weight:bold;color:#3b94d6;">{title}</a><br/> | |||
| <a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>在 {nickname2}/{repository} 提交了一个合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a><br/> | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| @@ -0,0 +1,52 @@ | |||
| <html> | |||
| <head> | |||
| <title>移出项目</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 项目 <a href="{baseurl}/{login}" style="font-weight:bold;color:#3b94d6;">{nickname}/{repository}</a> 已把你的角色修改为 {role} | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -33,6 +33,7 @@ | |||
| {receiver},您好!<br/> | |||
| <a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a> 更改 <a href="{baseurl}/{login2}/{identifier}/settings" style="font-weight:bold;color:#3b94d6;">{nickname2}/{repository} 的仓库设置:</a> | |||
| {ifname}更改项目名称为"{name}"{endname} | |||
| {ifidentifier}更改项目标识为"{identifier}"{endidentifier} | |||
| {ifdescription}更改项目简介为"{description}"{enddescription} | |||
| {ifcategory}更改项目类别为"{category}"{endcategory} | |||
| {iflanguage}更改项目语言为"{language}"{endlanguage} | |||
| @@ -31,7 +31,7 @@ | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| <a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>在 {nickname2}/{repository} 指派给你一个合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}/Messagecount" style="font-weight:bold;color:#3b94d6;">{title}</a><br/> | |||
| <a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>在 {nickname2}/{repository} 指派给你一个合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a><br/> | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| @@ -0,0 +1,56 @@ | |||
| <html> | |||
| <head> | |||
| <title>合并请求被更改</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 在项目 <a href="{baseurl}/{login2}/{identifier}" style="font-weight:bold;color:#3b94d6;">{nickname2}/{repository}</a> 的合并请求 <a href="{baseurl}/{login2}/{identifier}/pulls/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a> 中: | |||
| {ifassigner}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将负责人从 {assigner1} 修改为 {assigner2}{endassigner} | |||
| {ifmilestone}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将里程碑从 {milestone1} 修改为 {milestone2}{endmilestone} | |||
| {iftag}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将标记从 {tag1} 修改为 {tag2}{endtag} | |||
| {ifpriority}<a href="{baseurl}/{login1}" style="font-weight:bold;color:#3b94d6;">{nickname1}</a>将优先级从 {priority1} 修改为 {priority2}{endpriority} | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -0,0 +1,52 @@ | |||
| <html> | |||
| <head> | |||
| <title>合并请求被关闭</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 你提交的合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a> 被拒绝; | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||
| @@ -0,0 +1,52 @@ | |||
| <html> | |||
| <head> | |||
| <title>合并请求被合并</title> | |||
| <style type="text/css"> | |||
| body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{ margin:0; padding:0;} | |||
| body,table,input,textarea,select,button { font-family: "微软雅黑","宋体"; font-size:12px;line-height:1.5; background:#eaebec;} | |||
| div,img,tr,td,table{ border:0;} | |||
| table,tr,td{border:0;} | |||
| ol,ul,li{ list-style-type:none} | |||
| .new_content{ background:#fff; width: 100%;} | |||
| .email-page-link{ } | |||
| .email-link-top{ } | |||
| .c_white{ color:#fff;} | |||
| .email-link-con{ } | |||
| .email-link-line{ } | |||
| .email-link-footer{ padding:15px; color:#333; line-height: 1.9; } | |||
| .c_grey02{ color: #888;} | |||
| .fb{ font-weight: normal;} | |||
| .f14{ } | |||
| </style> | |||
| </head> | |||
| <body style="background:#fff;"> | |||
| <div class="new_content"> | |||
| <div style="width: 598px; background:#fff; margin:20px auto;"> | |||
| <div style="height:50px; width: 578px; background:#3b94d6; padding:9px 10px 6px;border:1px solid #ddd; border-bottom:none;"> | |||
| <a href="https://www.trustie.net/"><img src="http://www.trustie.net/images/nav_logo.png" width="51" height="45" ></a> | |||
| <p style="color:#fff; float:right; margin-top:15px;">确实让创新更美好</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| <div style="width: 558px; border-left:1px solid #ddd;border-right:1px solid #ddd; background:#fff; padding:20px; color:#333; line-height: 1.9;"> | |||
| <p style="font-size: 14px; color:#333;"> | |||
| {receiver},您好!<br/> | |||
| 你提交的合并请求:<a href="{baseurl}/{login2}/{identifier}/pulls/{id}" style="font-weight:bold;color:#3b94d6;">{title}</a> 已通过; | |||
| </p> | |||
| <div style="width: 100%; border-top: 1px solid #ddd; margin:10px 0;"></div> | |||
| <img src="https://www.trustie.net/images/wechat/trustie_QR.jpg" width="120" height="120" > | |||
| <p style=" color:#666;"> | |||
| 扫一扫,关注trustie微信公众号,更方便获取平台动态,消息推送等提醒<br/> | |||
| 想了解更多信息,请访问 <a href="https://www.trustie.net/" style=" color:#3b94d6;"> www.trustie.net</a> | |||
| </p> | |||
| </div> | |||
| <div style="padding:20px; color:#333; line-height: 1.9;background: #eee;border:1px solid #ddd; border-top:none; width: 558px;"> | |||
| <p style="color:#888; float:left;">如果您在使用中有任何的疑问和建议,欢迎您给我们反馈意见<br/> | |||
| QQ群:1071514693</p> | |||
| <p style="color:#888; float:right;font-weight: bold;font-size: 16px;">Trustie团队</p> | |||
| <div style="clear:both; overflow:hidden;"></div> | |||
| </div> | |||
| </div> | |||
| </div> | |||
| </body> | |||
| </html> | |||